@charset "utf-8";

body { background-color: #fff; overflow-x: hidden; }
#wrap { overflow-x: hidden; }


.logo .logo-link { display: block; width: 174px; height: 50px; background: url(../img/layout/logo.png) no-repeat center / contain;}
.logo .logo-link.wh {filter: grayscale(100%) brightness(100);}
.logo .logo-link strong { display: none; line-height: 1.2; font-weight: 600; font-size: 2rem;} 

@media only screen and (max-width: 767px) {
	.logo .logo-link {width: 120px;}
}

/********* 컨텐츠 넓이 *********/
.inner-padding { width: 100%; max-width: 1400px; margin: 0 auto;}

@media only screen and (max-width: 1460px) {
	.inner-padding { padding: 0 30px; }
}
@media only screen and (max-width: 1023px) {
	.inner-padding { padding: 0 20px; }	
}
@media only screen and (max-width: 767px) {
	.inner-padding { padding: 0 15px; }	
}


/********* thead *********/
.header { position: absolute; top: 0; left: 0; z-index: 100; width: 100%; border-bottom: 1px solid #d0d8de;}
.header .top { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 20px 0;} 
.header .logo {position: relative; z-index: 101;}

@media only screen and (max-width: 767px) {
	.header .top { padding: 10px 0; }
}


/********* gnb-box *********/
/* .gnb-box {position: relative;} */
.gnb-box .gnb {display: flex; align-items: center; width: 100%;}
.gnb-box .gnb .dep1 {flex: 1; position: relative; text-align: center;}
.gnb-box .gnb .dep1 .gnb-tit { position: relative; display: inline-block; padding: 24px 0; line-height: 1.4; font-weight: 700; font-size: 18px; white-space: nowrap; transition: all .3s;}
.gnb-box .gnb .dep1 .gnb-tit::after {content: ""; position: absolute; bottom: 0; left: 50%; width: 0; height: 4px; background-color: var(--primary500); transform: translateX(-50%); transition: all .3s;}
.gnb-box .gnb .dep1:hover .gnb-tit {color: var(--primary500);}
.gnb-box .gnb .dep1:hover .gnb-tit::after {width: 100%;}
.gnb-box .gnb-bg {position: absolute; top: 168px; left: 0; z-index: -1; width: 100%; height: 0; background-color: #fff; box-shadow: 0 6px 4px 0 rgba(0, 0, 0, 0.05); transition: height .3s;}
.gnb-box .gnb.on ~ .gnb-bg {height: 400px; }
.gnb-box .gnb .dep2-wrap { position: absolute; top: 73px; left: 0; width: 100%; height: 0; padding-top: 24px; opacity: 0; transform: translateY(-50px); overflow: hidden; transition: all .4s;}
.gnb-box .gnb:hover .dep2-wrap {height: fit-content; opacity: 1; transform: translateY(0);}
.gnb-box .gnb .dep2-wrap .dep2-list { width: 100%; border-radius: 50px; }
.gnb-box .gnb .dep2-wrap .dep2-list .dep2 .dep2-tit { display: block; line-height: 1.4; padding: 10px 20px; font-weight: 500; font-size: 16px; color: #666c70; text-align: center; word-break: keep-all; border-radius: 50px; white-space: nowrap; }
.gnb-box .gnb .dep2-wrap .dep2-list .dep2 .dep2-tit:hover { color: #2b2e30; text-decoration: underline;}
.gnb-box .gnb .dep2-wrap .dep2-list .dep2 .dep2-tit[target="_blank"] { background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-copy' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4 2a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2zm2-1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1zM2 5a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1v-1h1v1a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h1v1z'/%3E%3C/svg%3E") no-repeat right 20px center / auto 12px; }

@media only screen and (max-width: 1023px) {
	.header .gnb-box { display: none; }
	.header .search-wrap { display: none; }
}

.header .util-menu { position: relative; z-index: 100; display: flex; align-items: center; gap: 20px;  }

.header .util-menu .user-wrap {  }
.header .util-menu .user {display: inline-flex; align-items: center; justify-content: center; gap: 5px; padding: 8px 18px; background-color: var(--primary600); border-radius: 100px;}

.header .search-wrap .search-box-pc {position: fixed; left: 0; top: 0; z-index: 10; width: 100%; height: auto; padding: 60px 20px; background-color: #fff; box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15); transform: translateY(-600px); transition: transform 0.3s;}
.header .search-wrap .search-box {position: relative; display: flex; align-items: center; gap: 10px; width: 100%; max-width: 650px; margin: 0 auto; padding-right: 20px; border: 1px solid var(--gray-e5); border-radius: 50px; overflow: hidden;}
.header .search-wrap .search-box input {width: 100%; border: 0; padding-left: 25px; font-size: 1.8rem; line-height: 5rem;}
.header .search-wrap .search-box input:focus {outline: none;}
.header .search-wrap .search-box button {position: relative; font-size: 0;}
.header .search-wrap .search-box-pc > ul li {}
.header .search-wrap .search-box-pc > ul li a {display: block; padding: 0.8rem 1.6rem; font-size: 14px; background-color: var(--gray-f5); border-radius: 100px;}
.header .search-wrap .search-box-pc .search-close {position: absolute; right: 60px; top: 40px; width: 24px; height: 24px; padding: 0; font-size: 2.2rem;}
.header .search-wrap .search-box-pc.open {transform: translateY(0);}

@media only screen and (max-width: 767px) {
	.header .util-menu {gap: 10px;}
}

/********* mbtn-box *********/
.mbtn-box { display: none; }
.mbtn-box .mbtn-btn svg {width: 18px; height: 18px;}

.mbtn-box .open { display: block; width: 20px; height: 20px; }
.mbtn-box .mgnb-con { position: fixed; top: 0; left: 0; right: 0; z-index: -1; width: 100vw; height: 100vh; opacity: 0; visibility: hidden; transform: translateX(100%); transition: transform .3s;}
.mbtn-box .mgnb-con.on { visibility: inherit; opacity: 1; transform: translateX(0);}
.mbtn-box .mgnb-con .mgnb-search { padding: 15px;}
.mbtn-box .mgnb-con .mgnb-search .sch-inp-st1 {min-width: unset; max-width: 600px; margin: 0 auto; box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);}
.mbtn-box .mgnb-con .mgnb-box { position: absolute; top: 0; right: 0; width: 100%; height: inherit; background: #fff; }
.mbtn-box .mgnb-con .mgnb-box .top { display: flex; align-items: center; justify-content: space-between; padding: 25px 15px; } 
.mbtn-box .mgnb-con .mgnb-box .top .close { width: 30px; height: 30px; font-size: 0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42.06 42.06' width='15px' height='15px'%3E%3Cdefs%3E%3Cstyle%3E .cls-1 %7B fill: none; stroke: %23333; stroke-linecap: round; stroke-linejoin: round; stroke-width: 6px; %7D %3C/style%3E%3C/defs%3E%3Cg id='icon'%3E%3Cline class='cls-1' x1='3' y1='3' x2='39.06' y2='39.06'/%3E%3Cline class='cls-1' x1='39.06' y1='3' x2='3' y2='39.06'/%3E%3C/g%3E%3C/svg%3E") no-repeat center center / auto 15px; }

.mbtn-box .mgnb { height: 100%; padding: 15px 20px; overflow-y: scroll; }
.mgnb-box .dep1 + .dep1 {margin-top: 10px;}
.mgnb-box .dep1 .gnb-tit { position: relative; display: block; padding: 20px; font-weight: 700; font-size: 1.8rem; color: #333; border: 1px solid var(--bd1); border-radius: 10px;} 
.mgnb-box .dep1 .gnb-tit.arr { background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23aaa' class='bi bi-chevron-right' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M3.646 1.646a1 1 0 0 1 1.415 0l6 6a1 1 0 0 1 0 1.415l-6 6a1 1 0 0 1-1.415-1.415L9.086 8 3.646 2.561a1 1 0 0 1 0-1.415'/%3E%3C/svg%3E") no-repeat center right 20px / auto; }
.mgnb-box .dep1 .gnb-tit.arr.on {color: #fff; border: 1px solid var(--primary500); background: var(--primary500) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-chevron-right' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M3.646 1.646a1 1 0 0 1 1.415 0l6 6a1 1 0 0 1 0 1.415l-6 6a1 1 0 0 1-1.415-1.415L9.086 8 3.646 2.561a1 1 0 0 1 0-1.415'/%3E%3C/svg%3E") no-repeat center right 20px / auto;} 


/* dep2-list */
.mgnb-box .dep2-wrap { display: none; } 
.mgnb-box .dep2-wrap.on { display: block; } 
.mgnb-box .dep2-wrap .dep2-list {margin-top: 10px; padding: 20px; background-color: #F6FBFF; border: 1px solid var(--bd1); border-radius: 10px;} 
.mgnb-box .dep2-wrap .dep2-list .dep2 .dep2-tit { display: flex; align-items: center; gap: 5px; line-height: 1.2; font-weight: 700; font-size: 16px; color: #333; transition: all .3s;} 
.mgnb-box .dep2-wrap .dep2-list .dep2 .dep2-tit:hover {color: var(--primary500); text-decoration: underline;}
.mgnb-box .dep2-wrap .dep2-list .dep2 .dep2-tit::before {content: ''; display: inline-block; width: 4px; height: 4px; background-color: #555; border-radius: 100%; transition: background .3s;}
.mgnb-box .dep2-wrap .dep2-list .dep2 .dep2-tit:hover::before {background-color: var(--primary500);}
.mgnb-box .dep2-wrap .dep2-list .dep2 + .dep2 { margin-top: 15px; } 
/* dep3-list */
.mgnb-box .dep3-list { margin-top: 6px; }
.mgnb-box .dep3 { margin-bottom: 6px; }
.mgnb-box .dep3 .dep3-tit { display: block; position: relative; padding-left: 15px; color: #999; }
.mgnb-box .dep3 .dep3-tit::before { content:""; position: absolute; top: 8px; left: 0; width: 5px; height: 1px; background: #999; }

.mgnb-con.active { visibility: inherit; opacity: 1; transition: all 0.4s; } 
.mgnb-con.active .mgnb-box { right: 0; transition: all 0.4s; } 


@media only screen and (max-width: 1023px) {
	.mbtn-box { display: block; }	
}



/********* search-box *********/
.header .sch-box .open { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; }
.header .sch-box .open i { font-size: 20px; }



/********* sub-content *********/
.sub-content {padding: 6rem 0;}

.lnb > .inner-padding {display: flex; justify-content: space-between;}
.lnb ul li a {flex-shrink: 0; display: flex; align-items: center; justify-content: center; width: 50px; height: 50px; font-size: 1.8rem;}
.lnb .location { display: flex; align-items: center; gap: 1.5rem; }
.lnb .location li { display: flex; align-items: center; gap: 2rem; }
.lnb .location li + li::before { content:""; display: block; width: 8px; height: 12px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='12' viewBox='0 0 8 12' fill='none'%3E%3Cpath d='M-1.0258e-08 1.20857L5.31746 6L-8.48017e-07 10.7914L1.34124 12L8 6L1.34124 3.71547e-07L-1.0258e-08 1.20857Z' fill='%23666C70'/%3E%3C/svg%3E") no-repeat center / contain;}
.lnb .location li.home a {background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M15 5.15137V15H1V5.15137L8 1.15137L15 5.15137Z' stroke='%23666C70' stroke-width='2'/%3E%3Cmask id='path-2-inside-1_654_2340' fill='white'%3E%3Cpath d='M7 10H9V16H7V10Z'/%3E%3C/mask%3E%3Cpath d='M7 10V8H5V10H7ZM9 10H11V8H9V10ZM9 16V18H11V16H9ZM7 16H5V18H7V16ZM7 10V12H9V10V8H7V10ZM9 10H7V16H9H11V10H9ZM9 16V14H7V16V18H9V16ZM7 16H9V10H7H5V16H7Z' fill='%23666C70' mask='url(%23path-2-inside-1_654_2340)'/%3E%3C/svg%3E") no-repeat center / 16px 16px;}
.lnb .location li:last-child {font-weight: 700;}
.lnb .lnb-util {display: flex;}
.lnb .lnb-util li {border-left: 1px solid var(--gray-dd);}
.lnb .lnb-util li:last-child {border-right: 1px solid var(--gray-dd);}

@media only screen and (max-width: 600px) {
	.lnb > .inner-padding {flex-flow: column wrap;}
	.lnb .location {border-bottom: 1px solid var(--gray-dd);}
	.lnb .lnb-util {margin-left: auto;}
}

/********* con-header *********/
.con-header {text-align: center;}
.con-header .sub-tit { display: block; margin-bottom: 10px; line-height: 1.2; font-weight: 600; font-size: clamp(28px, 4.6875vw, 40px); color: var(--gray-44); word-break: keep-all; word-wrap: break-word; }

.con-body { min-height: 50vh; padding-top: 6rem; }

@media only screen and (max-width: 767px) {
	.con-header strong { font-size: 4rem; }
}

/********* no-content *********/
.no-content { margin: 0 auto; padding: 100px 0; }
.no-content .img-wrap {width: 100%; max-width: 350px; margin: 0 auto 40px; text-align: center; }
.no-content .txt-wrap > strong { display: block; font-weight: 600; font-size: 2.6rem; color: #333; text-align: center; }
.no-content .txt-wrap em { display: block; margin-top: 20px; line-height: 1.3; font-weight: 400; font-size: 1.8rem; color: #757575; text-align: center; }


/********* f-banner *********/
.f-banner {padding: 2rem 0; border-top: 1px solid var(--bd1);}
.f-banner > .inner-padding {display: flex; justify-content: space-between; align-items: center; gap: 20px;}
.f-banner .lf {display: flex; align-items: center; gap: 20px;}
.f-banner .banner-swiper {margin: 0;}
.f-banner .banner-swiper .swiper-slide {width: 260px;}
.f-banner .banner-swiper .loca-icon {display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; background-color: var(--primary500); border-radius: 100%;}
.f-banner .banner-swiper a:hover .loca-icon {background-color: #fff;}
.f-banner .banner-swiper a:hover .loca-icon svg path {fill: var(--primary500);}

@media only screen and (max-width: 1023px) {
	.f-banner > .inner-padding {flex-flow: column wrap; align-items: flex-start;}
	.f-banner .lf {justify-content: space-between; width: 100%;}
	.f-banner .banner-swiper {width: 100%;}
	.f-banner .banner-swiper .swiper-slide {width: fit-content;}
	.f-banner .banner-swiper a {gap: 15px; width: fit-content; height: 48px; line-height: 48px;}
	.f-banner .banner-swiper a span {font-size: 14px;}
	.f-banner .banner-swiper a img {width: 24px; height: 24px;}
	.f-banner .banner-swiper .loca-icon {width: 24px; height: 24px;}
	.f-banner .banner-swiper .loca-icon svg {width: 12px; height: 14px;}
}

/********* footer *********/
.footer { padding: 5rem 0; background-color: var(--gray-f9); border-top: 1px solid var(--bd1);}
.footer .inner-padding {  }
.footer .top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 2rem; }
.footer .top .f-menu li {position: relative;}
.footer .top .f-menu li + li {padding-left: 10px;}
.footer .top .f-menu li + li::before {content: ''; position: absolute; left: 0; top: 50%; width: 1px; height: 10px; background-color: var(--bd1); transform: translateY(-50%);}
.footer .top .family-site { position: relative; width: fit-content; }
.footer .top .family-site .family-btn { display: flex; align-items: center; justify-content: space-between; gap: 20px; width: 280px; height: 50px; line-height: 50px; padding: 0 15px; font-size: 15px; white-space: nowrap; background-color: #fff; border: 1px solid var(--bd1); border-radius: 10px;}
.footer .top .family-site .family-btn i {color: var(--gray-aa); transition: all .3s ease; }
.footer .top .family-site .family-btn i::before {font-weight: 700 !important;}
.footer .top .family-site .family-btn.on {border: 2px solid var(--primary500);}
.footer .top .family-site .family-btn.on i {color: var(--primary500); transform: rotate(180deg); }
.footer .top .family-site .family-btn span { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: #fff; border-radius: .5rem; }
.footer .top .family-site .family-list { display: none; position: absolute; bottom: calc(100% + 5px); left: 0; z-index: 10; width: 100%; max-height: 450px; background: #fff; border: 1px solid var(--bd1); border-radius: 10px; overflow-y: scroll; box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.25);}
.footer .top .family-site .family-list > li a { display: block; padding: 15px; font-size: 15px;}
.footer .top .family-site .family-list > li a:hover {color: var(--primary600); background-color: var(--primary200);}
.footer .logo {filter: grayscale(100);}
.footer .bottom { display: flex; flex-wrap: wrap; gap: 20px;}
.footer .bottom .txt-wrap {flex: 1;}
.footer .bottom .tel-list li {display: flex; flex-wrap: wrap; gap: 10px;}
.footer .bottom .tel-list li + li {margin-top: 5px;}
.footer .bottom .tel-list li em {flex-shrink: 0; display: inline-block; width: 85px; font-weight: 600;}
.footer .bottom .call-center {width: 280px;}

@media only screen and (max-width: 1200px) {
	.footer .bottom .call-center {flex: 0 0 100%; width: 100%; text-align: center;}
}
@media only screen and (max-width: 767px) {
	.footer {padding: 3rem 0;}
	.footer .logo .logo-link {width: 195px; height: 60px;}
	.footer .bottom {flex-direction: column;}
}
@media only screen and (max-width: 600px) {
	.footer .top {flex-flow: column wrap; gap: 10px;}
	.footer .bottom .tel-list li em {width: 100%;}
}
@media only screen and (max-width: 400px) {
	.footer .top .family-site {width: 100%;}
	.footer .top .family-site .family-btn {width: 100%;}
}
