@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+KR:100,300,400,500,700,900');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");

@font-face {
    font-family: 'SOYO';
	src: url('https://cdn.jsdelivr.net/gh/fontbee/font@main/Ddc/SOYOMapleRegularTTF.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: 'SOYO';
    src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_2310@1.0/SOYOMapleBoldTTF.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
}


/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #028697;
	--color-sub: #1e8f52;
	--color-sub2: #74b115;
	--color-sub3: #d79d00;
	--color-sub4: #db395d;
	--color-white-a05: rgba(255, 255, 255, 0.05);
	--color-white-a1: rgba(255, 255, 255, 0.1);
	--color-white-a2: rgba(255, 255, 255, 0.2);
	--color-white-a3: rgba(255, 255, 255, 0.3);
	--color-white-a4: rgba(255, 255, 255, 0.4);
	--color-white-a5: rgba(255, 255, 255, 0.5);
	--color-white-a6: rgba(255, 255, 255, 0.6);
	--color-white-a8: rgba(255, 255, 255, 0.8);
	--color-white-a9: rgba(255, 255, 255, 0.9);
	--color-black-a05: rgba(0, 0, 0, 0.05);
	--color-black-a1: rgba(0, 0, 0, 0.1);
	--color-black-a2: rgba(0, 0, 0, 0.2);
	--color-black-a3: rgba(0, 0, 0, 0.35);
	--color-black-a4: rgba(0, 0, 0, 0.4);
	--color-black-a5: rgba(0, 0, 0, 0.5);
	--color-black-a6: rgba(0, 0, 0, 0.6);
	--color-black-a7: rgba(0, 0, 0, 0.7);
	--color-black-a8: rgba(0, 0, 0, 0.8);
	--color-black-a9: rgba(0, 0, 0, 0.9);
	--scroll-width: 0px;
	--inner-width: calc(100vw - var(--scroll-width));
	--inner-padding: max(20px, calc(((var(--inner-width)) - 1400px) / 2));
	--outer-padding: min(var(--inner-padding), 45px);
	--font-noto: 'Noto Sans KR', Roboto,'Malgun Gothic','돋움', dotum, sans-serif;
	--font-pretendard: Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-mont: 'Montserrat', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-soyo: 'SOYO', sans-serif;
	font-size: 10px;
}
html::-webkit-scrollbar {width: 8px; background-color: #eee;}
html::-webkit-scrollbar-thumb {background-color: #444;}
body {--header-height: 100px; font: 16px/1.2 Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif; letter-spacing: -0.025em; color: #666;}
body:where(.is-fix) {--header-height: 80px;}
.is-open {overflow: hidden !important; padding-right: var(--scroll-width) !important;}
.inner {position: relative; margin: 0 var(--inner-padding);}


@media (max-width: 1280px) { 
	:root {font-size: 9px;} 
	body {--header-height: 80px; } 
}
@media (max-width: 768px) {	
	:root {font-size: 8px;} 
	body {--header-height: 70px; } 
}
@media (max-width: 480px) {
	:root {font-size: 7px;} 
	body {--header-height: 60px;}
}
@media (max-width: 360px) {	:root {--inner-padding: 15px;} }
/* 기본 스타일 ========================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER ============================================== */
.header {--allmenu-gap: 0%; --allmenu-img-width: 0%; position: absolute; inset: 0 0 auto; z-index: 1000; } 
.header-inner { display: flex; align-items: center; justify-content: center; position: fixed; inset: 0 0 auto; z-index: 1100; height: var(--header-height); padding: 0 var(--outer-padding); transition: .3s, padding 0s;} 
.header-inner::before { position: absolute; inset: 0; background: linear-gradient(to left, var(--color-white-a2) 0%, var(--color-white-a2) 100%) no-repeat right bottom/100% 1px; content: ''; transition: .3s, background-size .5s; } 
.is-open .header-inner { padding-right: calc(var(--outer-padding) + var(--scroll-width)); } 
:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .header-inner::before { background-color: #fff; background-image: linear-gradient(to left, #eee, #eee); } 
.is-menu .header-inner::before { background-image: linear-gradient(to left, var(--color-black-a2), var(--color-black-a2)); background-size: calc(100% - var(--allmenu-gap) - var(--allmenu-img-width)) 1px;visibility: hidden; opacity: 0;}

.header-logo { position: relative; width:15rem; transition: left .5s; left:0; position: absolute; top: 50%; left: 20px; transform: translateY(-50%);} 
:is(.is-hover, .is-fix, .is-menu, .is-hover-header) #header-logo-white { opacity: 0; transition: opacity .5s;} 
.header-logo #header-logo { opacity: 0; position: absolute; inset: 0; object-fit: contain; transition: opacity .5s;} 
:is(.is-hover, .is-fix, .is-menu, .is-hover-header) #header-logo { opacity: 1; } 
.is-menu .header-logo {left: calc(var(--allmenu-img-width) + var(--allmenu-gap));}
:is(.is-menu) #header-logo {opacity: 0;}

/* GNB */
.gnb { transition: opacity .3s; flex-grow: 1;} 
.gnb::before { position: absolute;inset: 100% 0 auto; height: var(--gnb-height);background-color: #fff;content: '';transform: scaleY(0); transform-origin: top;transition: .3s;}
.gnb-wrap { display: flex; justify-content: center; } 
.depth1 { position: relative;} 
.depth1 > a { padding: 0 4rem; line-height: var(--header-height); } 
.depth1 > a span {color: #fff; white-space: nowrap; font-size: 20px; font-weight: 800; transition: all 0.3s ease-in-out; display: inline-block; position: relative;}
.depth1 > a span::before {content: ''; position: absolute; bottom: 5px; left: 0%; width: 44px; height: 44px; background:url('../images/common/ico_gnb_on.png') 50% 50% no-repeat; background-size: contain; transform: translate(0%, 50%); visibility: hidden; opacity: 0;  transition: all 0.3s ease-in-out;}

.depth2 {visibility: hidden; opacity: 0; position: absolute; top: var(--header-height); padding: 4rem 0 6.5rem; left:50%; transform: translate(-50%, 0); min-width: 100%; transition: all 0.1s ease-in-out;}
.depth2 ul {display: flex; justify-content: center; flex-direction:column ;}
.depth2 a {display: block; margin: 2.5px 0; padding: 10px 1.6vw; border-radius: 40px; transition: all 0.3s ease-in-out; font-weight: 800; font-size:1.6rem;}
.depth2 span { white-space: nowrap; }


.is-menu .gnb { visibility: hidden; opacity: 0; }
.is-hover .gnb::before {transform: scaleY(1);}
:where(.is-hover, .is-fix, .is-hover-header) .depth1 > a span { color: #222; }

.depth1:hover > a span { color: var(--color-main); } 
.depth1:hover > a span::before {left:40%; transform: translate(-50%, 50%); opacity: 1; visibility: visible;}

.is-hover .depth2{visibility: visible; opacity: 1;transition: all 0.5s ease-in-out;}
.depth2 a:hover {background-color: var(--color-main); color: #fff;}



/* 유틸 */
.header-util { display: flex; align-items: center; transition: all 0.3s ease-in-out; z-index: 10; column-gap: 4rem; position: absolute; top: 50%; right: 20px; transform: translateY(-50%);}
:is(.is-menu) .util-lang {opacity: 0;}

@keyframes ani-util {
	75% { height:calc(var(--header-height) * 2);} 
	100% { height:auto; } 
}
.body-main.is-fix .header-util::before {border-width:0;}

.body-sub .header-util::before{border-width:0;}
.is-menu .header-util::before{display: none;}

/* 언어선택 버튼 */
.util-lang-btn { background:var(--color-black-a9) url(../images/common/ico_lang.svg) no-repeat center; transition: all .3s;  height:50px;}

.util-lang-list { display: flex; background:transparent url('../images/common/ico_lang.svg') no-repeat left center; padding: 5px 0 5px 24px; align-items: center;}
.util-lang-list a { padding: 0 2rem; position: relative;} 
.util-lang-list a span { background: linear-gradient(to top, var(--color-main), var(--color-main)) no-repeat center bottom/0 1px; transition: all .3s; color: var(--color-white-a8);} 
.util-lang-list li + li a:first-child::before {content: ''; display:block; width:1px; height:1.2rem; background-color: var(--color-white-a4); position: absolute; left:0; top:50%; transform: translate(0, -50%);}
.util-lang-list li.on a span { font-weight: 700; color: var(--color-main); } 
.util-lang-list li:not(.on) a:hover span { background-size: 100% 1px; color: var(--color-main); } 
:is(.is-hover, .is-fix, .is-hover-header):not(.is-hover-header.is-menu, .is-menu) .util-lang-list { background-image: url(../images/common/ico_lang_on.svg); }
:is(.is-hover, .is-fix, .is-hover-header):not(.is-hover-header.is-menu, .is-menu) .util-lang-list a span{color:#000;}
:is(.is-hover, .is-fix, .is-hover-header):not(.is-hover-header.is-menu, .is-menu) .util-lang-list li + li a:first-child::before {background-color: #000;}


/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width:5rem; height:5rem; background-color:var(--color-main); border-radius: 50%; transition: all 0.3s ease-in-out;} 
.util-allmenu-btn span { position: absolute; width: 2px; height: 2px; background-color: #fff; transition: .3s; top:50%; left:50%; transform: translate(-50%, -50%);}
.util-allmenu-btn span::before,
.util-allmenu-btn span::after {content:''; display: block; position: absolute; width: 100%; height: 100%; background-color: #fff; transition: .3s; top:0; left:0;}
.util-allmenu-btn span::before {transform: translate(-8px, 0);}
.util-allmenu-btn span::after {transform: translate(8px, 0);}

.util-allmenu-btn span:nth-child(1) {transform: translate(-50%, calc(-50% - 8px));}
.util-allmenu-btn span:nth-child(3) {transform: translate(-50%, calc(-50% + 8px));}

:is(.is-hover, .is-fix, .is-menu) .util-allmenu-btn span:not(:nth-child(4)) { background-color: #fff; } 

.util-allmenu-btn:hover {background-color: #000;}
.util-allmenu-btn:hover span { width: 18px; background-color: #fff;}
.util-allmenu-btn:hover span::before,
.util-allmenu-btn:hover span::after {opacity: 0;}




.is-menu .util-allmenu-btn {background-color:var(--color-sub);}
.is-menu .util-allmenu-btn span {width: 24px;}
.is-menu .util-allmenu-btn span:nth-child(1) {transform:translate(-50%, -50%) rotate(-45deg);} 
.is-menu .util-allmenu-btn span:nth-child(3) {transform:translate(-50%, -50%) rotate(45deg);} 
.is-menu .util-allmenu-btn span:nth-child(2),
.is-menu .util-allmenu-btn span::before,
.is-menu .util-allmenu-btn span::after {opacity: 0;}


.is-menu .util-allmenu-btn:hover {background-color:var(--color-sub2); transform: rotate(180deg);}







/* 전체메뉴 */
.allmenu { display: flex; visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; padding-right: var(--scroll-width); background-blend-mode: screen; transform: translateY(0%); transition: .5s, padding-right 0s, width 0s; z-index: 1001; } 
.allmenu::before {content:''; display: block; width:100%; height:1px; position: absolute; top: 19rem; left: 0; background-color:var(--color-white-a1); z-index: -1; }

.allmenu-wrap {flex-grow: 1; padding-left: var(--allmenu-gap); height:100%;/*  height: 100%; 옆 배경 없을 때 scroll생성 */}
.allmenu-cont { visibility: hidden; overflow: hidden auto; opacity: 0; height: 100%; height: calc(100% - var(--header-height)); transition: .3s;} 
.allmenu-cont::-webkit-scrollbar { width: 6px; } 
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); } 
.allmenu-list { display: flex; justify-content: center;} 

.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateY(0);} 
.is-menu .allmenu-cont { visibility: visible; opacity: 1; transition: .7s ease-out .2s; } 

.all-depth1 {max-width: 20%;} 
.all-depth1-btn {width: 100%; line-height: 19rem; padding: 0 4rem; margin-bottom: 3rem; text-align: left; white-space: nowrap; cursor: default; font-family: var(--font-soyo); font-size:3.5rem; font-weight: 400; color:#fff; position: relative;} 
.all-depth1-btn::after {content:''; display: block; width:0; height:0; border-radius: 50%; position:absolute; bottom:0; left:50%; background: #fff url('../images/common/ico_allmenu01.png') 50% 50% no-repeat; background-size:60%; transform: translate(-50%, 50%); transition: all 0.3s ease-in-out;}
.all-depth1-btn::before {display: block; content: ''; width: 0; height: 1px; background: #fff; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); transition: all 0.3s ease-in-out;}
.all-depth1:nth-of-type(2) .all-depth1-btn::after {background-image: url('../images/common/ico_allmenu02.png');}
.all-depth1:nth-of-type(3) .all-depth1-btn::after {background-image: url('../images/common/ico_allmenu03.png');}
.all-depth1:nth-of-type(4) .all-depth1-btn::after {background-image: url('../images/common/ico_allmenu04.png');}
.all-depth1:nth-of-type(5) .all-depth1-btn::after {background-image: url('../images/common/ico_allmenu05.png');}

.all-depth1:hover .all-depth1-btn {color: var(--color-main); font-weight: 800;}
.all-depth1:hover .all-depth1-btn::after {width:98px; height:98px;}
.all-depth1:hover .all-depth1-btn::before {width: 100%;}

.all-depth2 { font-size: 1.8rem; color:#fff; padding-top: 3rem;} 
.all-depth2-btn {padding: 0.6em 0.4em 0.6em 4rem; font-size: 18px; font-weight: 800; line-height: 1.25; color: #fff; text-decoration: underline; text-decoration-color: transparent; text-decoration-thickness: 2px; text-underline-offset: 0.5em; transition: all .2s, text-decoration-color .1s; position: relative;} 

.all-depth2 > ul > li:hover .all-depth2-btn {color: var(--color-main);}
.all-depth2 > ul > li:hover .all-depth2-btn::after {display: block; content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--color-main); position: absolute; top: 50%; left: 2rem; transform: translate(-50%, -50%);}

.all-depth3 {padding-bottom: 0.5em;}
.all-depth3:not(:has(li)) {display: none;}
.all-depth3 a {display: flex; border-radius: 8px; padding: 10px 0 10px 4.5rem; font-size: calc(1em - 1px); transition: all 0.3s ease-in-out;}
.all-depth3 a::before { margin-right: 0.3em; content: '-'; }

.all-depth2 li:hover .all-depth3 a {color: #63aeb9;}
.all-depth2 .all-depth3 a:hover {background: var(--color-main); color: #fff;}




/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 1000; background-color: var(--color-black-a6); transition: opacity .3s; pointer-events: none; } 
:is(.is-hover, .is-menu) .gnb-dim { opacity: 1; } 
.is-menu .gnb-dim {-webkit-backdrop-filter: blur(8px);backdrop-filter: blur(8px);}

/*
@media (hover: hover) and (pointer: fine) {
.is-menu .util-allmenu-btn:hover span { width: 18px; } 
}
*/

@media (max-width: 1440px) { 
	.depth1 > a {padding: 0 3rem;}

	.header-util {column-gap: 0;}

	.is-menu .allmenu-cont {padding-top: var(--header-height);}
	.allmenu::before {top: calc(19rem + var(--header-height));}
}
@media (max-width: 1280px) { 
	.gnb-wrap {margin-right: 10%;}
	.depth1 > a span {font-size: 18px;}

	.allmenu::before {top: calc(15rem + var(--header-height));}
	.all-depth1-btn {font-size: 30px; line-height: 15rem;}
	.all-depth1:hover .all-depth1-btn::after {width: 60px; height: 60px;}
}
@media (max-width: 1024px) {
	.gnb { display: none; } 

	.all-depth1 {flex: 1;}
	.all-depth1-btn {padding: 0 2rem; font-size: 24px;}
	.all-depth2-btn {padding-left: 2rem; font-size: 16px; } 
	.all-depth2 > ul > li:hover .all-depth2-btn::after {left: 3px;}
}
@media (max-width: 768px) {
	.header {--allmenu-gap: 0; --allmenu-img-width: 0; }

	.allmenu {width: 320px; top: 0; left: 100%; background: linear-gradient(to bottom, var(--color-main), var(--color-main) 70px, #fff 71px);}
	.is-menu .allmenu {transform: translateX(-320px);}
	.allmenu::before {display: none;}
	.allmenu-cont {padding-top: var(--header-height);}
	.allmenu-wrap {margin: 0;}
	.allmenu-list {display: block;}
	.all-depth1 {max-width: none; border-bottom: 1px solid #eee;}
	.all-depth1-btn {line-height: 70px; margin-bottom: 0; color: #222;}
	.all-depth1-btn.on,
	.all-depth1:hover .all-depth1-btn {background: var(--color-main); color: #fff;}
	.all-depth1-btn::before,
	.all-depth1-btn::after {display: none;}
	.all-depth2-btn {color: #666; padding-left: 4rem;}
	.all-depth2 {padding: 2rem 0; display: none;}
	.all-depth2 > ul > li:hover .all-depth2-btn::after {left: 2rem;}
}
@media (max-width: 640px) { 
	.header {--allmenu-img-width: 0px;}
	.body-main .header-util {height:auto;}
} 
@media (max-width: 480px) { 
	.header-logo {width: 10rem;}
	.util-lang-list {background-image: none;}
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer {background-color: #1a1a1a; padding-top: 9rem; position: relative;}
.footer-wrap {display: flex; justify-content: space-between; position: relative;}

.footer-logo {position: absolute; top: 0; left: 0;}

.footer-contact {margin-left: 35rem; padding-bottom: 10rem;}
.footer-contact .item {display: flex; font-size: 16px; font-weight: 800; color: #fff;}
.footer-contact .item+.item {margin-top: 10px;}
.footer-contact dt {color: #949494; margin-right: 2rem; min-width: 124px; position: relative;}
.footer-contact dt::after {display: block; content: ''; width: 1px; height: 11px; background-color: #484848; position: absolute; right: 0; top: 50%; transform: translateY(-50%);}

.footer-menu {display: flex; font-family: var(--font-soyo); font-size: 15px; font-weight: 700; color: #fff;}
.footer-menu a {display: block; padding: 0 30px; transition: all 0.3s ease-in-out;}
.footer-menu .item:last-child a {padding-right: 0; position: relative;}
.footer-menu .item:last-child a::after {display: block; content: ''; width: 4px; height: 4px; border-radius: 50%; background-color: var(--color-main); position: absolute; top: 50%; left: 0; transform: translate(-50%, -50%);}
.footer-menu a:hover {color: var(--color-sub2);}

.footer-copy {padding: 4rem 20px 3rem; border-top: 1px solid #313131; text-align: center; font-size: 15px; font-weight: 400; color: #9a9a9a; letter-spacing: 0.6em;}

/* 탑버튼 */
.top-btn { display: flex; width: 46px; height: 68px; margin-left: auto; background: url('../images/common/footer_top.png') no-repeat center/contain; position: absolute; top:6rem; right:var(--outer-padding); z-index: 1;} 
.top-btn::before { width: 19px; height: 38px; margin: 80% auto auto; background: url(../images/common/ico_top.png) no-repeat center/contain; content: ''; }  
@keyframes top-btn {
	33% { transform: translateY(3px); } 
	66% { transform: translateY(-6px); } 
}
 
@media (hover: hover) and (pointer: fine) {
	.top-btn:hover::before { animation: top-btn 1.5s infinite linear; }
}
@media (max-width: 1620px) { 
	.top-btn {top: 0; transform: translateY(-50%);}
}
@media (max-width: 1440px) { 
	.footer-contact {margin-left: 30rem;}
}
@media (max-width: 1280px) { 
	.footer-logo {width: 200px;}
	.footer-contact {margin-left: 25rem;}
} 
@media (max-width: 1024px) { 
	.footer-wrap {flex-wrap: wrap;}
	.footer-logo {top: -5rem;}
	.footer-contact {order: 2; margin-top: 5rem; padding-bottom: 5rem; margin-left: 0;}
	.footer-menu {order: 1; width: 100%; margin-right: 10px; justify-content: flex-end;}
} 
@media (max-width: 768px) {
	.footer-logo {width: 150px;}
	.footer-copy {font-size: 14px; }
 } 
 @media (max-width: 640px) {
	.footer-contact {margin-top: 3rem;}
	.footer-contact .item {font-size: 14px;}
	.footer-menu {margin-top: 5rem; justify-content: flex-start; font-size: 14px;}
	.footer-menu .item:first-child a {padding-left: 0;}
 }
@media (max-width: 480px) { 
	.footer-logo {width: 100px;}
	.footer-menu {margin-top: 6rem;}
	.footer-copy {font-size: 12px; }
} 
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 70px;}
/* SUV-VISUAL */
.sub-visual {position: relative; height: 47rem; transition: height 0.5s ease-in-out} 
.sub-visual-bg { overflow: hidden; position: absolute; inset: 0;} 
.sub-visual-bg span { position: absolute; inset: 0; background: #444 no-repeat center/cover; transform: scale(1.2); animation: sub-visual 5s linear both; } 
@keyframes sub-visual { to { transform: scale(1); } } 

.sub-visual-bg::before { position: absolute; inset: 60% 0 0 0; height:30%; content: ''; z-index: 1; background: repeating-linear-gradient(to bottom, var(--color-black-a6) 0 3px, transparent 3px calc(3px + 14%)); animation: sub-visual-mask 1s linear both; display: none;}
@keyframes sub-visual-mask { to { inset:70% 0 0 0; height:30%;} }

.sub-visual-bg::after { position: absolute; inset: 0; background-color: var(--color-black-a6); content: '';}

.sub-visual-txt { display: flex; align-items: flex-end; height: 100%; padding: 100px 0 var(--sub-tab-height); color: #fff; font-family: var(--font-soyo);} 
.sub-visual-tit { margin-bottom: 5rem; font-weight: 700; font-size: 5.5rem;} 

.sub-visual-slogan {display: inline-block; margin-left: 5px; vertical-align: text-bottom; font-size: 16px; font-weight: 700;}

.sub-visual.nth-1 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual01.jpg');}
.sub-visual.nth-2 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual02.jpg');}
.sub-visual.nth-3 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual03.jpg');}
.sub-visual.nth-4 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual06.jpg');}
.sub-visual.nth-5 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual04.jpg');}
.sub-visual.nth-6 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual05.jpg');}
.sub-visual.nth-7 .sub-visual-bg span {background-image: url('/home/images/common/sub_visual07.jpg');}


@media (max-width: 1280px) {
	.sub-visual {height: 46rem;}
}
@media (max-width: 1024px) {
	.sub-visual-tit {margin-bottom: 7rem;}
}
@media (max-width: 768px) {
	.sub-visual {height: 42rem;}
	.sub-visual-tit {font-size: 4.5rem;}
	.sub-visual-slogan {font-size: 14px;}
}
@media (max-width: 480px) {
	.sub-visual-tit {margin-bottom: 3rem;}
}








/* SUB-TAB */
.sub-tab { position: relative;  z-index: 50; height: var(--sub-tab-height); margin: calc(-1 * var(--sub-tab-height)) 0 0; color: #fff; border-top: 1px solid rgba(255, 255, 255, 0.15);}
.sub-tab-btn { display: none; position: relative; z-index: 5; width: 100%; height: 100%;} 
.sub-tab-list { width: calc(100% - (var(--inner-padding) * 2)); margin: 0 auto;} 
.sub-tab-list ul { display: flex; height: var(--sub-tab-height); } 
.sub-tab-list ul::-webkit-scrollbar {height: 6px;}
.sub-tab-list ul::-webkit-scrollbar-thumb {border: 1px solid transparent; background-clip: content-box;}
.sub-tab-list li { flex: 1;} 
.sub-tab-list li a { display: flex; justify-content: center; align-items: center; height: 100%; padding: 0 1em; text-align: center; font-size: 18px; font-weight: 800; white-space: nowrap; color: rgba(255, 255, 255, 0.6); position: relative; transition: all 0.3s ease-in-out;} 
.sub-tab-list li a::after {display: block; content: ''; width: 0; height: 3px; background: #fff; position: absolute; top: 0; left: 20px; transform: translateY(-100%);}
.sub-tab-list li a::before {display: block; content: ''; width: 32px; height: 32px; background: url(../images/common/ico_sub-tab.png) no-repeat left bottom; position: absolute; left: 0; bottom: 100%; z-index:9; opacity: 0;}

.sub-tab-list li.on a::after {animation: sub-tab-list 1s linear both; animation-delay: 0.3s;}
@keyframes sub-tab-list { 
	to { width: 100%; } 
} 
.sub-tab-list li.on a::before {animation: sub-tab-dot 0.5s linear both;}
@keyframes sub-tab-dot { 
	to {opacity: 1;} 
} 
.sub-tab-list li.on a,
.sub-tab-list li:hover a {color: #fff;} 

.sub-visual_util {position: absolute; top: 45%; right: 5rem;}
.sub-visual_util .util-item+.util-item {margin-top: 1rem;}
.sub-visual_util a {display: block; width: 50px; height: 50px; border-radius: 50%; background: var(--color-main) url(../images/common/ico_sub-util01.png) no-repeat center; transition: all 0.3s ease-in-out;}
.sub-visual_util .util-item+.util-item a {background-color: var(--color-sub); background-image: url(../images/common/ico_sub-util02.png);}
.sub-visual_util .util-item a:hover {background-color: #fff; background-image: url(../images/common/ico_sub-util01_on.png);}
.sub-visual_util .util-item+.util-item a:hover {background-image: url(../images/common/ico_sub-util02_on.png);}

@media (max-width: 1440px) {
	.sub-visual_util {right: 20px;}
}
@media (max-width: 1280px) {
}
@media (max-width: 768px) {
	.sub-tab-list li a {font-size: 16px;}
}
@media (max-width: 480px) {
	.sub-visual_util {top: 50%; transform: translateY(-50%);}

	.sub-tab {left:0; top:auto; bottom:0; width:100%; padding:0 var(--inner-padding); animation: fade-up 0.5s linear 1.5s both; z-index: 1;}
	.sub-tab-item {flex-grow: 1;}
	.sub-tab-btn { overflow: hidden; display: block; position: relative; z-index: 5; width: 100%; height: var(--sub-tab-height); padding: 0 20px 0 15px; text-align: left; color: #fff; white-space: nowrap; text-overflow: ellipsis; transition: .2s; font-size: 18px; font-weight: 600;} 

	.sub-tab-list {display: none; left:50%; width: 100%; min-width:auto; font-size:1.8rem; padding:10px 0; clip-path:none; box-shadow: 0 0 1.5em var(--color-black-a4); background: #fff;}
	.sub-tab-list ul {display: block; height: auto;}
	.sub-tab-list li a {color: #222; justify-content: flex-start; padding: 0 10px; line-height: 50px;}
	.sub-tab-list li.on a, .sub-tab-list li:hover a {color: var(--color-main);}
	.sub-tab-list li a::before,
	.sub-tab-list li a::after {display: none;}

	.sub-visual_util {top: 45%;}
	.sub-visual_util a {width: 40px; height: 40px; background-size: 45%;}
}


/* SUB-CONTENT */
.sub-content-tit h3 { padding: 7rem 0; font-family: var(--font-soyo); font-weight: 700; font-size: 5rem; text-align: center; color: #222; } 
.sub-content-wrap::after {display: block; visibility: hidden; width: 100%; height: 1px; content: ''; margin-bottom: -1px;}
/* SUB-CONTENT-TAB */
.sub-content-tab { overflow-x: auto; padding: 0 var(--inner-padding); margin-bottom: 7rem; text-align: center;}
.sub-content-tab:not(:has(li)) { display: none; }
.sub-content-tab::-webkit-scrollbar {height: 6px; background-color: #fff;}
.sub-content-tab::-webkit-scrollbar-thumb {border: 1px solid transparent; background-color: var(--color-main); background-clip: content-box;}
.sub-content-tab ul {display: flex; gap: 1px; width: fit-content; padding: 1px; margin: 0 auto;}
.sub-content-tab li {outline: 1px solid #eee;}
.sub-content-tab li.on {z-index: 5; outline-color: var(--color-main);}
.sub-content-tab li a { min-width: 12em; padding: 1em 2em; font-size: calc(1rem + 8px); transition: .3s;}
.sub-content-tab li.on a { background-color: var(--color-main); font-weight: 600;color: #fff; }

@media (hover: hover) and (pointer: fine) {
	
}
@media (max-width: 1280px) {
	.body-sub { --sub-tab-height: 66px; } 
	.sub-visual-txt {padding: var(--header-height) 0 var(--sub-tab-height);} 
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 62px;} 
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-height: 58px; } 
	.sub-content-tab ul { flex-direction: column; width: 100%;}
}
/* SUB-LAYOUT ========================================== */
/* ===================================================== */


/* ===================================================== */
/* MODAL =============================================== */
#modal { z-index: 9999; position: relative; letter-spacing: -0.02em;}
.modal-item { display: flex;visibility: hidden; opacity: 0; position: fixed; inset: 0; background-color: var(--color-black-a4); transition: .3s, margin 0s;}
.is-open .modal-item {margin-right: var(--scroll-width);}
.modal-item.on {visibility: visible; opacity: 1;}
.modal-inner {display: grid; grid-template-rows: auto 1fr; width: 90%; padding: 2.5rem; margin: auto; background-color: #fff; max-width: 700px;}
.modal-top {display: flex; justify-content: space-between; padding-bottom: 0.8em; margin-bottom: 1em; border-bottom: 2px solid #333; font-size: 2.4rem; line-height: 1; align-items: center; column-gap: 0.5em;}
.modal-tit { font-weight: 700; color: #333;white-space: nowrap;}
.modal-close { flex-shrink: 0; width: 2rem; aspect-ratio: 1 / 1; }
.modal-close::before { display: block; height: 100%; background: url(../images/common/ico_close.svg) no-repeat center/contain;content: '';}
.modal-cont { overflow: hidden auto; max-height: 50vh; padding: 4%; border: 1px solid #eee; overscroll-behavior: contain;}
.modal-cont::-webkit-scrollbar {width: calc(1rem - 3px); background-color: #eee;}
.modal-cont::-webkit-scrollbar-thumb { min-height: 30%; background-color: var(--color-main);}

/* 개인정보처리방침 */
.privacy {font-size: calc(9px + 0.6rem); line-height: 1.6; padding: 1.5em 0 2em;}
.privacy a {display: inline;}
.privacy h4 { padding-top: 1em;font-weight: 500; font-size: calc(1em + 1px); color: #444;}
.privacy-header { margin-bottom: 1em; font-weight: 600; font-size: calc(1em + 1px);color: #333;}
.privacy-inner {padding: 0.6em 0.6em 0.8em;}
.privacy-comment {padding-top: 1em;}

/* 이메일무단수집거부 */
.refusal-mail {font-size: calc(10px + 0.6rem); padding: 1.8em 0 2em; text-align: center; font-weight: 500;}
.refusal-mail h4 {font-size: 1.75em; color: #333; margin-bottom: 0.4em; font-weight: 700;}
.refusal-mail h5 {font-size: 1.25em; color: #444;}
.refusal-mail h5::after {display: block; width: 1em; height: 2px; background-color: #333; content: ''; margin: 1em auto;}
.refusal-mail p { line-height: 1.7;}
@media (max-width: 576px) {
	.refusal-mail h4 {font-size: calc(2.2vw + 12px);}
	.refusal-mail h5 {font-size: 1.2em;}
	.refusal-mail p br {display: none;}
}
/* MODAL =============================================== */