@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 .tel {color: var(--white); transition: 0.5s; z-index: 1; }
.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 .tel {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; }

/* SNS Icons */
#header .sns-icons {display: flex; gap: 16px; align-items: center;}
#header .sns-icons a {display: block; width: 28px; height: 28px; flex-shrink: 0;}
#header .sns-icons a img {width: 100%; height: 100%; object-fit: contain;}

/* 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;}

  /* SNS Icons 크기 조정 */
  #header .sns-icons {gap: 12px;}
  #header .sns-icons a {width: 24px; height: 24px;}
}
@media screen and (max-width:1024px){
  #header .header {width: 90%;}
  
}
@media screen and (max-width:768px) {
  /* SNS Icons 모바일 크기 조정 */
  #header .sns-icons {gap: 10px;}
  #header .sns-icons a {width: 20px; height: 20px;}
}
@media screen and (max-width:480px) {
  /* SNS Icons 소형 모바일 크기 조정 */
  #header .sns-icons {gap: 8px;}
  #header .sns-icons a {width: 18px; height: 18px;}
}

@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; z-index: 999;}
#quick .floating-btn {width: 90px; box-sizing: border-box; border: 1px solid var(--white); border-radius: 45px; background: linear-gradient(to bottom, #30BBA3, #2779FF); color: var(--white); font-weight: 700; font-size: 14px; padding: 12px 0 18px; line-height: 1.3; margin-bottom: 20px;}
#quick .floating-btn.hide {display: none;}
#quick .floating-btn > div {width: 100%; position: relative;}
#quick .floating-btn > div a {width: 100%; display: block; text-align: center; padding: 25px 0;}
#quick .floating-btn .icon {font-size: 0; margin-bottom: 2px;}
#quick .floating-btn .tel {font-weight: 800; margin-top: 4px;}

#quick .floating-btn .menu02 {}
#quick .floating-btn .menu02 p {margin: 16px 0 8px; }
#quick .floating-btn .menu02::before,
#quick .floating-btn .menu02::after {content:""; width: 60px; height: 1px; background: #fff; position: absolute; left: 50%; transform: translateX(-50%);}
#quick .floating-btn .menu02::before {top: 0;}
#quick .floating-btn .menu02::after {bottom: 0;}
#quick .floating-btn .menu02 .icon.go img {width: 24px;}

#quick .arrow {width: 50px; height: 50px; border: 1px solid #30BBA3; background: #fff; border-radius: 50%; color: #30BBA3; font-size: 10px; font-weight: 800; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 2px; line-height: 1; justify-content: center; text-align: center; margin: 0 auto;} 
#quick .arrow.down {display: none; margin-top: 8px;}
#quick .arrow::before {content:""; width: 25px; height: 25px;  background-size: cover; background-position: center; background-repeat: no-repeat; display: block;}
#quick .arrow.up::before {background-image: url(/img/com/quick_top.svg);}
#quick .arrow.up::after {content:"TOP";}
#quick .arrow.down::before {background-image: url(/img/com/quick_down.svg);}
/* #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); } */

#quick.main {}
#quick.main .arrow.down {display: flex;}
#quick.main .arrow.up::before {background-image: url(/img/com/quick_up.svg);}
#quick.main .arrow.up::after {display: none;}

@media screen and (max-width:1260px) {
  #quick {right: 2%;}
  #quick .arrow {width: 40px; height: 40px; }

  #quick.main .arrow.down {display: none;}
  #quick.main .arrow.up::before {background-image: url(/img/com/quick_top.svg);}
  #quick .arrow.up::after {display: none;}

  #quick .floating-btn {display: none;}
}
@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;}
}

/* Contact Info Popup */
.contact-info-popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
}

.contact-info-popup.active {
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-info-popup .popup-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  cursor: pointer;
}

.contact-info-popup .popup-content {
  position: relative;
  background: #fff;
  border-radius: 15px;
  width: 90%;
  max-width: 500px;
  z-index: 1;
  animation: popupSlideIn 0.3s ease-out;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

@keyframes popupSlideIn {
  from {
    opacity: 0;
    transform: scale(0.9) translateY(-20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.contact-info-popup .popup-header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px 30px 20px;
  border-bottom: 1px solid #eee;
  position: relative;
}

.contact-info-popup .popup-header h2 {
  font-size: 26px;
  font-weight: 700;
  color: #333;
  margin: 0;
  text-align: center;
}

.contact-info-popup .popup-close {
  background: none;
  border: none;
  font-size: 28px;
  color: #999;
  cursor: pointer;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s;
  position: absolute;
  right: 30px;
}

.contact-info-popup .popup-close:hover {
  color: #333;
}

.contact-info-popup .popup-body {
  padding: 30px;
  text-align: center;
}

.contact-info-popup .popup-message {
  font-size: 16px;
  line-height: 1.6;
  color: #555;
  margin: 0 0 40px;
  word-break: keep-all;
}

.contact-info-popup .popup-buttons {
  display: flex;
  gap: 15px;
  justify-content: center;
}

.contact-info-popup .btn-online-reservation,
.contact-info-popup .btn-phone-reservation {
  flex: 1;
  padding: 15px 20px;
  border: none;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s;
  text-align: center;
  white-space: nowrap;
}

.contact-info-popup .btn-online-reservation {
  background: var(--mainC);
  color: #fff;
}

.contact-info-popup .btn-online-reservation:hover {
  background: #0066cc;
  transform: translateY(-1px);
}

.contact-info-popup .btn-phone-reservation {
  background: #28a745;
  color: #fff;
}

.contact-info-popup .btn-phone-reservation:hover {
  background: #218838;
  transform: translateY(-1px);
}

@media screen and (max-width: 768px) {
  .contact-info-popup .popup-content {
    width: 95%;
    margin: 20px;
  }

  .contact-info-popup .popup-header {
    padding: 25px 20px 15px;
  }

  .contact-info-popup .popup-header h2 {
    font-size: 22px;
  }

  .contact-info-popup .popup-body {
    padding: 25px 20px;
  }

  .contact-info-popup .popup-message {
    font-size: 15px;
    margin-bottom: 30px;
  }

  .contact-info-popup .popup-buttons {
    flex-direction: column;
    gap: 12px;
  }

  .contact-info-popup .btn-online-reservation,
  .contact-info-popup .btn-phone-reservation {
    padding: 16px 20px;
    font-size: 15px;
  }
}

@media screen and (max-width: 480px) {
  .contact-info-popup .popup-header h2 {
    font-size: 20px;
  }

  .contact-info-popup .popup-close {
    right: 20px;
  }

  .contact-info-popup .popup-message {
    font-size: 14px;
  }

  .contact-info-popup .btn-online-reservation,
  .contact-info-popup .btn-phone-reservation {
    font-size: 14px;
  }
}
/* e:Contact Info Popup */