@charset "UTF-8";

#container{min-height: 100vh;}
.inner{max-width: calc(1420px + 80px);width: 100%;margin: 0 auto;padding: 0 40px;}

/************************* header *************************/
#hd{background-color: transparent;}
#hd{position: fixed;z-index: 999;width: 100%;transition: .4s;background: #fff;box-shadow: 0px 5px 20px 0px rgba(0, 0, 0, 0.10);}
#hd.on{background-color: #fff; box-shadow: 0 3px 6px rgba(0,0,0,0.15);}
#hd:before { display:block; } 
#hd_h1 { position:absolute; font-size:0; line-height:0; overflow:hidden } 
#hd_wrapper { position:relative; margin:0 auto; zoom:1; z-index: 1000; max-width: none; } 
#logo a {max-width: 262px;display: flex;align-items: center;justify-content: center;} 
#logo a .img{width: 262px;height: 38px;background: no-repeat 50% / cover;background-image: url(../../images/cmn/logo.svg);}
#gnb {position:relative;/* float: right; *//* padding-top: 42px; *//* padding-left: 328px; *//* padding-bottom: 56px; */z-index: 9;} 
#gnb.on{background-color: #fff;}
#gnb h2 { position:absolute; font-size:0; line-height:0; overflow:hidden } 
#gnb .gnb_wrap {margin:0 auto;position:relative;max-width: none;} 
#gnb.on .gnb_wrap{border-bottom: 1px solid #e4e4e4;}
#gnb #gnb_1dul {height: 90px;display: flex;margin: 0 -50px;} 
#gnb #gnb_1dul:after { display:block; clear:both; content:""; } 
#gnb .gnb_1dli {height: 100%;display: flex;align-items: center;justify-content: center;position: relative;text-align: center;padding: 0 50px;white-space: nowrap;} 
.gnb_1dli:nth-child(2) .gnb_2dli:last-child, .gnb_1dli:nth-child(2) .gnb_2dli:nth-last-child(2), .gnb_1dli:nth-child(2) .gnb_2dli:nth-last-child(3){display: none;}
#gnb .gnb_1dli:hover { /* background:#1a30a7; */-webkit-transition: background-color 2s ease-out; -moz-transition: background-color 0.3s ease-out; -o-transition: background-color 0.3s ease-out; transition: background-color 0.3s ease-out; } 
#gnb .gnb_1dli:hover>a, #gnb .gnb_1dli.active>a {color: #000; } 
.gnb_1dli .bg { display: none; width:10px; height:10px; overflow:hidden; background:url(../img/gnb_bg2.gif) no-repeat 50% 50%; text-indent:-999px;} 
.gnb_1da {display:inline-block;text-decoration:none;letter-spacing: -0.5px;word-spacing: -2px;width: 100%;display: flex;align-items: center;font-size: var(--font-22); font-weight: 600;justify-content: center;color: var(--color-black);transition: .4s;} 
.gnb_2dli:first-child {margin-top: 15px;} 
.gnb_2dul_wr{display: none;position: absolute;top: 100%;width: 100%;height: 370px;margin-top: 40px;}
.gnb_2dul {position: relative;height: 100%; margin-top: 25px;} 
.gnb_2da {text-align: center;  margin-bottom: 15px; color: #5B5B5B; font-weight: 300;} 
.gnb_1dli:hover .gnb_2dul .gnb_2da:hover,
.gnb_1dli > a:focus ~ .gnb_2dul .gnb_2da:hover {font-weight: 500;} 
.gnb_1dli:hover .gnb_2dul .gnb_2da, 
.gnb_1dli > a:focus ~ .gnb_2dul .gnb_2da{ color: #000; } 
.gnb_2dul.focus::before { content: ''; position: absolute; width: 100%; height: 2px; top: 0px; left: 0; background-color: var(--color-main-green); } 
.gnb_1dli_over2 .gnb_2dul { display:block; right:0 } 
.gnb_wrap .gnb_empty { padding:10px 0; width:100%; text-align:center; line-height:2em; color:#fff } 
.gnb_wrap .gnb_empty a { color:#fff; text-decoration:underline } 
.gnb_wrap .gnb_al_ul .gnb_empty, .gnb_wrap .gnb_al_ul .gnb_empty a { color:#555 } 
#gnb .gnb_close_btn {display: none; background:#4158d1; color:#fff; width:50px; height:50px; border:0; vertical-align:top; font-size:18px; position:absolute; top:-50px; left:0 } 
#gnb .gnb_mnal { padding:0; display: none; } 
#gnb_all {display:none;position: fixed;top: 0;padding-top: 80px;width:100%;z-index:99;height: 100% !important;background: #fff;} 
#gnb_all .gnb_al_ul:after { display:block; visibility:hidden; clear:both; content:"" } 
#gnb_all .gnb_al_li.active > a {color: #000; font-weight: 700;} 
#gnb_all .gnb_al_li li {width: 100%;} 
#gnb_all .gnb_al_li li i { color:#9ca6cc; display: none; } 
#gnb_all .gnb_al_li li a {padding: 23px 0;width: 100%;border-bottom: 1px solid #E4E4E4;} 
#gnb_all .gnb_al_li li a:hover,
#gnb_all .gnb_al_li li a:active{text-decoration: underline;}
.menu-bg {width: 100%;height: 370px;background: #fff;display: none;position: absolute;top: 100%;left: 0;border-bottom: 1px solid #e4e4e4;border-top: 1px solid #E4E4E4;} 
.menu-bg img{position: absolute; left: 55px; bottom: 10px; max-width: 272px; height: auto;}
#gnb .gnb-btn {position: relative;right: 0;background: none;width: 30px;height: 30px;border:0;display: none;align-items: center;justify-content: center;margin-left: 5px;}
#gnb .gnb-btn span{display: block;height: 2px;width: 20px;background: var(--color-black);position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);transition: all 0.5s;border-radius: 10px;}
#gnb .gnb-btn span:before {content: '';display: block;height: 100%;width: 100%;background: var(--color-black);position: absolute;top: -8px;transform: rotate(0deg);transition: all 0.5s;border-radius: 10px;} 
#gnb .gnb-btn span:after {content: '';display: block;height: 100%;width: 100%;background: var(--color-black);position: absolute;top: 8px;transform: rotate(0deg);transition: all 0.5s;border-radius: 10px;} 
#gnb .gnb-btn.active span {background: transparent;width: 20px;} 
#gnb .gnb-btn.active span:before {transform: rotate(135deg);top: 0;background: #000;} 
#gnb .gnb-btn.active span:after {transform: rotate(-135deg);top: 0;background: #000;} 
.gnb_1dul_wr {height: 80px;display: flex;justify-content: space-between;}
.gnb_1dul_wr.inner{max-width: calc(1520px + 80px);}
#gnb_1dul{}
#gnb .gnb_1dli:not(:last-child)::after{}
.gnb_2dul_wr::after {content: '';position: absolute;top: -10px;right: 0;width: 1px;height: 270px;background: #e4e4e4;} 
.gnb_2dul_wr .depth-tit{font-size: 1.125em;font-weight: 500;}
#hd.on .gnb_1da{color: #000;}
#hd.hovered{background-color: #fff;}
#hd.hovered .gnb_1da{color: #000;}
.hd-control{display: none;}



/************************* footer *************************/
#ft {background-color: var(--color-main);padding: 60px 0;margin:0 auto;position: relative;min-height: 354px;border-radius: 100px 100px 0px 0px;} 
#ft h1 { position:absolute; font-size:0; line-height:0; overflow:hidden } 
#ft_wr {margin:0 auto;max-width: calc(1280px + 80px);padding: 0 40px;display: flex;align-items: center;justify-content: space-between;} 
#ft_wr .r{display: flex; flex-direction: column; justify-content: space-between; align-items: flex-end;}
#ft_wr #ft_link { padding: 30px 0 10px 0; /* border-bottom:1px solid #eee; */ } 
#ft_wr #ft_link a { display:inline-block; padding: 0 11px; line-height:1.083em; font-size: 16px; color: #333333; border-left: 2px solid #333333; } 
#ft_wr #ft_link a:first-child { padding-left:0; border-left:0 } 
#ft_wr #ft_catch { margin: 70px 50px 0px 0px; position: absolute; float: right; right: 0; } 
#ft_wr #ft_catch img { margin: 0 16px; } 
#ft_wr #ft_adrr { padding: 10px 0; font-size: 14px; } 
#ft_wr #ft_adrr span { padding: 0 10px; border-left: 1px solid #fff; } 
#ft_wr #ft_adrr span.nonborder { border-left:none } 
#ft_wr #ft_adrr span:first-child { padding-left:0; border-left:0 } 
#ft_wr #ft_copy { font-size: 14px; margin-top: 60px;} 
#ft_copy br.mobile-ver{display: none;}
#ft_wr .ft-cont { margin-top: 24px; width: 100%; } 
#ft_wr .ft-cont h2 { font-size: 14px; } 
#ft_wr .ft_info span { margin-top: 8px; display: block; font-size: 14px; } 
#ft_wr .ft_info span b { margin-right: 8px; } 
.admin-login.btn { color: var(--color-main-blue); text-decoration: underline; font-weight: 700; } 
#top_btn { position: absolute; right: 85px; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; background: no-repeat 50% / cover; background-color: var(--color-main-blue); border-radius: 50%; background-image: url(../../images/cmn/ico-top.svg); background-size: 13px 16px; transition: .4s; } 
#top_btn:hover { background-image: url(../../images/cmn/ico-top_small.svg); } 
.ft-tit b {color: #fff;text-align: center;font-size: var(--font-28);font-weight: 800;line-height: 1.3; /* 128.571% */}
.ft-tit p { color: #fff; text-align: center; font-size: 16px; font-weight: 500; margin-top: 4px; } 
.ft-sns{margin-top: 20px; display: flex; justify-content: center; align-items: center; gap: 20px;}
.ft-sns .btn{width: 60px; height: 60px; border-radius: 10px; background: var(--color-main2); display: flex; align-items: center; justify-content: center;}
.ft-sns .btn i{width: 44px; height: 44px; background-repeat: no-repeat; background-size: cover; background-position: 50%;}
.ft-sns .sns-insta i{background-image: url(../../images/ico/ico-insta.svg);}
.ft-sns .sns-discord i{background-image: url(../../images/ico/ico-discord.svg);}
.ft-sns .sns-kakao i{background-image: url(../../images/ico/ico-kakao.svg);}
#ft address{margin-top: 40px;}
#ft address span{color: #fff; opacity: .8; font-weight: 500; margin-right: 10px; padding-right: 10px; position: relative;}
#ft address span:not(:last-child)::after{content: ''; position: absolute; top: 50%; transform: translateY(-50%); right: 0; width: 1px; height: 10px; background: #fff; opacity: .2;}
#ft .copyRight{margin-top: 14px; font-weight: 600; color: #fff; opacity: .3;}

.aside-control{position: fixed; bottom: 50px; right: 30px; z-index: 99;}
.btn-top{ width: 54px; height: 54px; display: flex; align-items: center; justify-content: center; border-radius: 15px; background: #fff;  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.10);}
.btn-top i{width: 16px; height: 18px; background: url(../../images/ico/ico-top.svg) no-repeat 50% / cover;}



/*--------------------------------------------------------------------- 반응형 --------------------------*/
@media screen and (max-width: 1600px){
  .inner{max-width: 1160px;}
  .gnb_1dul_wr.inner {max-width: 1260px;}
}


@media screen and (min-width:1201px) {
  #gnb_all{display: none !important;}
}

@media screen and (max-width: 1200px) {

  .inner{padding: 0 40px;}
  /************************* header *************************/
  #logo a .img{width: 198px;height: 0;padding-bottom: calc((38 / 262) * 100%);}
  .hd-control {display: block;}
  #gnb .gnb_1dul_wr #gnb_1dul{display: none;margin: 0;}
  .gnb_1dul_wr.inner {}
  #gnb .gnb_1dul_wr{height: 80px;max-width: 100%;position: relative;z-index: 999;justify-content: space-between;}
  #gnb .gnb-btn{display: flex;}
  #gnb_all .gnb_al_li li a{border: 0;font-size: var(--font-14);color: #5B5B5B;padding: 10px 0;}
  .gnb-left {margin-top: 50px;}
  #gnb_all .gnb_al_li > ul {display: none;text-align: center;padding-top: 10px;}
  #gnb_all .gnb_al_li{padding: 30px 0; position: relative;}
  #gnb_all .gnb_al_li:not(:last-child)::after{content: ''; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); width: 28px; border-bottom: 1px solid #BABABA;}
  #gnb_all .gnb_al_li > a {text-align: center;font-size: 18px;font-weight: 500;}
  #gnb .gnb_wrap.active .gnb_1dul_wr {border-bottom: 1px solid #e4e4e4;}
  #gnb .gnb_wrap.active #logo a .img{}
  #hd.on #gnb .gnb-btn:not(.active) span,
  #hd.on #gnb .gnb-btn span::before,
  #hd.on #gnb .gnb-btn span::after{background: #000;}
  #gnb .gnb_wrap.active .menu-bg {display: block !important;width: 150px;height: 144px;position: absolute;top: auto;bottom: 60px;left: 10px;border: 0;background: transparent;}
  #gnb .gnb_wrap.active .menu-bg img {position: static; width: 100%; height: 100%; max-width: 100%;}
  #gnb .gnb_wrap.active .copyRight {position: absolute;left: 50%;transform: translateX(-50%);bottom: 40px;width: 100%;text-align: center;font-size: 12px;color: #757575;}

}

@media screen and (max-width: 768px) {
  .inner{padding: 0 20px;}

  /*  */
  #gnb_all{padding-top: 54px;}
  #logo a .img{width: 180px;height: 26px;padding-bottom: 0;}
  #gnb .gnb_1dul_wr{
    padding: 0 20px;
}
  #container{min-height: auto;}
 
  /************************* footer *************************/
  #ft {padding: 50px 0;min-height: auto;border-radius: 60px 60px 0 0;} 
  #ft .inner { display: block; } 
  .ft-logo img {width: 200px;}
  .ft-l { width: 100%; text-align: center; margin-bottom: 20px; } 
  #ft .ft-l b { margin-top: 7px; } 
  #ft address p { text-align: center; } 
  .ft-tit b { font-size: 24px; } 
  .ft-tit p { font-size: 14px; } 
  #ft address span { margin: 0; padding: 0; font-size: 14px; } 
  #ft address { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 6px; } 
  #ft address span:not(:last-child)::after { display: none; } 
  #ft .copyRight { font-size: 14px; } 
  .aside-control{bottom: 30px; right: 15px;}
}




@media screen and (-ms-high-contrast: active),(-ms-high-contrast: none) {
}