@charset "utf-8";


#wrap {width: 100%;}

/* input */


@media screen and (max-width: 768px) {
  
}


/* btn */
.btn {display: inline-flex; align-items: center; justify-content: center; transition: 0.3s; font-weight: 700; line-height: 1; gap: 10px; font-size: 18px; width: fit-content; box-sizing: border-box; overflow: hidden; position: relative;}
.btn::before {content:""; width: 100%; height: 100%; position: absolute; left: 0; top: 0; transform: translateY(101%); transition: 0.3s;}
.btn span {position: relative; z-index: 1; transition: 0.3s;}

.btn.size-m {padding: 0 30px; height: 47px; font-size: var(--font18); font-weight: 700; border-radius: 25px;}

.btn.btn-light {border: 1px solid #fff; color: #fff;}
.btn.btn-light span {color: #fff;}
.btn.btn-light::before {background: #fff;}
.btn.btn-dark {border: 1px solid #bbb; color: #000;}
.btn.btn-dark span {color: #000;}
.btn.btn-dark::before {background: #000; }
.btn.btn-black {border: 1px solid #000; color: #000;}
.btn.btn-black span {color: #000;}
.btn.btn-black::before {background: #000; }

.btn:hover::before {transform: translateY(0);}

.banner-hover {background: var(--mainC); position: relative; overflow: hidden;}
.banner-hover span {color: var(--white); transition: 0.5s; z-index: 1; position: relative;}
.banner-hover::before {content:""; width: 100%; height: 100%; position: absolute; z-index: 0; background: #000; transition: 0.5s; transform: translateY(101%); left: 0; top: 0;}
.banner-hover::after {content:""; background-position: center; background-repeat: no-repeat; background-image: url(/img/com/icon_go.svg); background-size: cover; z-index: 1; position: relative; transition: 0.4s;}

.banner-hover:hover {}
.banner-hover:hover span {color: var(--mainC);}
.banner-hover:hover::before {transform: translateY(0);}
.banner-hover:hover::after {background-image: url(/img/com/icon_go_color.svg)}



@media (hover: hover) {
  .btn.btn-light:hover span { color: var(--mainC2);}

  .btn.btn-dark:hover span {color:var(--mainC)}
  
  .btn.btn-black:hover span {color: var(--mainC);}
}


@media screen and (max-width: 768px){
  .btn.size-m {height: 42px;}
  .btn.btn-dark {border-color: #000; color: var(--mainC); background: #000;}
  .btn.btn-dark span {color: inherit;}
}
@media screen and (max-width:480px) {

}


/* layer */

 



/* s:header */
#header {position: fixed; left: 0; top: 0; width: 100%; z-index: 999; transition: 0.4s; }
#header .header {width: 100%; max-width: 1660px; width: 80%; margin: auto; display: flex; align-items: center; justify-content: space-between; height: var(--headerH); position: relative;}

#header .logo {width: 235px; height: 32px; background-image: url(/img/com/logo_white.svg); background-position: right center; background-size: 99% auto; background-repeat: no-repeat; margin-left: 20px;}
#header .logo a {display: block; width: 100%; height: 100%;}
#header .gnb {display: flex; gap: var(--gap40); color: #fff; font-size: var(--font24); font-weight: 700; }
#header .gnb > li {position: relative;}
#header .gnb > li > a {display: flex; align-items: center; justify-content: center; padding: 0 calc(var(--gap40)/2); height: var(--headerH); }
#header .gnb > li .lnb {position: absolute; left: 50%; transform: translateX(-50%); top: var(--headerH); padding-top: 20px; display: none;}
#header .gnb > li .lnb ul {display: block; text-align: center; min-width: 160px; border-radius: 10px; overflow: hidden; background: #000; padding: 34px;}
#header .gnb > li .lnb li {margin-bottom: 25px; font-size: var(--font16); font-weight: 700; line-height: 1.7; color: var(--mainC);}
#header .gnb > li .lnb li:last-child {margin-bottom: 0;}
#header .gnb > li .lnb li a:hover {text-decoration: underline; text-underline-position: under;}

#header .sitemap-btn {display: none; width: 32px; height: 25px; border: 3px solid #fff; position: relative; box-sizing: border-box; border-right: 0; border-left: 0; cursor: pointer;}
#header .sitemap-btn span {width: 100%; height: 3px; background: #fff; display: block; position: absolute; left: 0; top: 8px; }

/* sitemap */
#sitemap {position: fixed; right: 0; top: 0; width: 100%; height: 100vh;   z-index: 9999; pointer-events: none;  }
#sitemap .sitemap-box {width: 290px; height: 100%; background: #000; transform: translateX(100%); transition: 0.4s; color: #fff; position: absolute; right: 0; top: 0; padding: 75px 0;}
#sitemap .mo-gnb-wrap {padding: 0 25px; width: 100%; height: 100%; overflow: auto;}
#sitemap .mo-gnb-top {width: 100%; display: flex; justify-content: space-between; align-items: center; }
#sitemap .mo-gnb-top .logo {width: 142px; font-size: 0;}
#sitemap .mo-gnb-top .close-btn {width: 32px; height: 32px; position: relative; font-size: 1px; color: rgba(0,0,0,0); }
#sitemap .mo-gnb-top .close-btn a {display: block; width: 100%; height: 100%;}
#sitemap .mo-gnb-top .close-btn::before,
#sitemap .mo-gnb-top .close-btn::after {content:""; width: 28px; height: 2px; background: #fff; border-radius: 1px; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%) rotate(45deg); }
#sitemap .mo-gnb-top .close-btn::after {transform: translate(-50%,-50%) rotate(-45deg);}

#sitemap .mo-gnb {margin-top: 40px;}
#sitemap .mo-gnb > ul > li {margin-bottom: 5px;}
#sitemap .mo-gnb > ul > li > a {font-weight: 800; display: flex; height: 70px; padding: 0 10px; font-size: 24px; align-items: center;}
#sitemap .mo-gnb > ul > li:has(.lnb) > a {color: var(--mainC); text-decoration: underline; text-underline-position: under;}
#sitemap .mo-gnb > ul > li .lnb {padding: 10px 0 5px;}
#sitemap .mo-gnb > ul > li .lnb li a {line-height: 45px; font-weight: 600; font-size: 16px; padding: 0 10px; }

#sitemap.active {pointer-events: auto; background: rgba(0,0,0,0.67); }
#sitemap.active .sitemap-box {transform: translateX(0); }


#header.scroll {background: #fff;}
#header.scroll .logo {background-image: url(/img/com/logo_black.svg);}
#header.scroll .gnb {color: #000;}
#header.scroll .sitemap-btn {border-color: #000;}
#header.scroll .sitemap-btn span {background: #000;}

#header.black .logo {background-image: url(/img/com/logo_black.svg);}
#header.black .gnb {color: #000;}
#header.black .sitemap-btn {border-color: #000;}
#header.black .sitemap-btn span {background: #000;}

@media (hover: hover) {
  #header:hover {background: #000;}
  #header.scroll:hover {background: #fff;}
  #header.black:hover {background: #fff;}
}
@media screen and (max-width:1260px){
  #header nav {display: none;}
  #header .sitemap-btn {display: block;}
  #header .logo {margin-left: 0; width: 160px; height: 20px;}
}
@media screen and (max-width:1024px){
  #header .header {width: 90%;}
  
}
@media screen and (max-width:768px) {
  
}
@media screen and (max-width:480px) {
 
}

@media screen and (min-width:1261px){
  #wrap:has(#main.nonepc) #header .gnb {display: none;}
  #wrap:has(#main.nonepc) #header .sitemap-btn {display: block;}
}
/* e:header */



/* s:footer */
#footer {border-top: 1px solid #BFBFBF; width: 100%; background: #fff; }
#footer .footer {width: 90%; max-width: 1600px; padding: 100px 0; margin: auto;}
#footer .footer > div {display: flex; justify-content: space-between;}
#footer .footer .f-top {align-items: center; margin-bottom: 50px;}
#footer .footer .f-top .foot-logo {width: 270px; font-size: 0;}
#footer .footer .f-top .privacy {font-weight: 700; font-size: var(--font18); color: #222;}
#footer .footer .f-btm {align-items: end; font-size: var(--font16);}
#footer .footer .f-btm address {color: #333;}
#footer .footer .f-btm address ul {display: flex; max-width: 710px; flex-wrap: wrap; gap: 16px 31px;}
#footer .footer .f-btm address ul li {position: relative; line-height: 1.5;}
#footer .footer .f-btm address ul li::before {content:""; width: 1px; height: 12px; position: absolute; right: -15px; top: 50%; transform: translateY(-50%); background: #BCBCBC; }
#footer .footer .f-btm address ul li:nth-child(3)::before,
#footer .footer .f-btm address ul li:nth-child(5)::before {display: none;}
#footer .footer .f-btm address span {color: #8E8E8E; }
#footer .footer .f-btm .copyright {color: #aaa; font-weight: 600;}

#quick {position: fixed; right: 65px; bottom: 0; padding-bottom: 30px;}
#quick a {display: block; width: 60px; height: 60px; border-radius: 50%; border: 1px solid #fff; background-color: var(--mainC); background-image: url(/img/com/icon_top.svg); background-position: center; background-repeat: no-repeat; font-size: 1px; color: rgba(0,0,0,0); }

@media screen and (max-width:1260px) {
  #quick {right: 2%;}
  #quick a {width: 40px; height: 40px; background-size: 24px; }
}
@media screen and (max-width:1024px) {
  

}
@media screen and (max-width:768px){
  #footer .footer {padding: 56px 0 80px; }
  #footer .footer .f-top {flex-direction: column; align-items: start; gap: 40px; margin-bottom: 40px; }
  #footer .footer .f-top .foot-logo {width: 190px;}

  #footer .footer .f-btm {flex-wrap: wrap;}
  #footer .footer .f-btm address ul {gap: 10px 21px; }
  #footer .footer .f-btm address ul li:nth-child(n+3) {width: 100%;}
  #footer .footer .f-btm address ul li::before {right: -10px;}
  #footer .footer .f-btm address ul li:not(:first-child)::before {display: none;}
  #footer .footer .f-btm .copyright {width: 100%; font-size: 12px; margin-top: 40px;}


}
@media screen and (max-width:480px) {
  
}
/* e:footer */

/* contact */
.contact-bnr {width: 100%; height: 180px; background: url(/img/contact/img_contact_bnr.jpg) center no-repeat; background-size: cover; display: flex; align-items: center; justify-content: center; padding: 30px 0; position: relative;}
.contact-bnr::before {content:""; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: rgba(0,0,0,0.5);}
.contact-bnr > div {width: 100%; position: relative; z-index: 1;}
.contact-bnr ul {width: 90%; margin: auto; display: flex; flex-wrap: wrap; gap: 26px 20px;}
.contact-bnr ul li {width: calc(50% - 10px); display: flex; gap: 0.6em 40px; font-size: var(--font24); line-height: 1; justify-content: center; color: #fff; }
.contact-bnr ul li .tit {width: 170px; font-weight: 600;}
.contact-bnr ul li .tel {width: 170px;}
.contact-bnr ul li .mail {max-width: 250px; width: 100%;}

@media screen and (max-width:1600px){
  .contact-bnr ul li {font-size: 20px; gap: 0.6em 20px;}
  .contact-bnr ul li .tit {width: 120px;}
  .contact-bnr ul li .tel {width: 140px;}
  .contact-bnr ul li .mail {max-width: 220px;}
}
@media screen and (max-width:1260px){
  .contact-bnr {height: unset;}
  .contact-bnr ul {max-width: 500px;}
  .contact-bnr ul li {flex-wrap: wrap; justify-content: start; font-size: 16px; }
  .contact-bnr ul li .tit, .contact-bnr ul li .tel {width: 100%;}
  .contact-bnr ul li .mail {max-width: 100%;}
}
@media screen and (max-width:480px){
  .contact-bnr {padding: 40px 0;}
  .contact-bnr ul { gap: 24px 8px;}
  .contact-bnr ul li {font-size: 14px; width: calc(50% - 4px);}
}



/* 임시 */
.form-contact .privacy-filed {overflow: auto; max-height: 380px; }
.form-contact .privacy-filed .wrap-privacy {width: 100%; padding-top: 0; font-size: 20px;}
.form-contact .privacy-filed .guideline { margin-top: 0;}
.form-contact .privacy-filed .divsion {}
.form-contact .privacy-filed .divsion h3 { font-size: 20px;}
@media screen and (max-width:768px) {
  .form-contact .privacy-filed .wrap-privacy,
  .form-contact .privacy-filed .divsion h3 {font-size: 4.266vw;}
}