@charset "utf-8";
@import url("https://cdn.jsdelivr.net/gh/sun-typeface/SUIT/fonts/static/woff2/SUIT.css");
@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");

/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #005aab;
	--color-sub: #2ac4f4;
	--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-a4: rgba(255, 255, 255, 0.4);
	--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-a4: rgba(0, 0, 0, 0.4);
	--color-black-a6: rgba(0, 0, 0, 0.6);
	--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-montserrat: 'Montserrat', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, 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 'SUIT', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif; letter-spacing: -0.025em; color: #666;}
.is-fix {--header-height: 80px;}
.is-open {overflow: hidden !important; padding-right: var(--scroll-width) !important;}
.inner {position: relative; margin: 0 var(--inner-padding);}

.col1 {color: var(--color-main);}
.col2 {color: var(--color-sub);}

@media (max-width: 1280px) { 
	:root {font-size: 9px;} 
	body {--header-height: 80px; } 
}
@media (max-width: 768px) {	
	:root {font-size: 8px;} 
	body, .is-fix {--header-height: 70px; } 
}
@media (max-width: 480px) {	:root {font-size: 7px;} }
@media (max-width: 360px) {	:root {--inner-padding: 15px;} }


/* 기본 스타일 ========================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER ============================================== */
.header {--allmenu-gap: 5%; --allmenu-img-width: 20%; position: absolute; inset: 0 0 auto; z-index: 1000; } 
.header-inner { display: flex; justify-content: space-between; align-items: 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::after {display: block; content: ''; width: 424px; height: 170px; background: url(../images/common/header-util_bg.png) no-repeat top right; position: absolute; top: 0; right: 0; transition: all 0.3s ease-in-out;}
.header-inner::before {display: block; content: ''; width: 75%; height: 140px; background: url(../images/common/header-lnb_bg.png) no-repeat right bottom / cover; position: absolute; top: 0; left: 0; transition: all 0.3s ease-in-out;}
.is-open .header-inner { padding-right: calc(var(--outer-padding) + var(--scroll-width)); } 
.header-logo { position: absolute; left: var(--outer-padding); width: 20rem; transition: left .5s;} 

.is-fix .header-inner::after {width: calc(153px + (var(--outer-padding) * 2)); height: var(--header-height); left: auto; right: 0;}
.is-fix .header-inner::before {background-size: 120%; width: 100%; height: var(--header-height); border-bottom: 1px solid #eee;}
.is-fix .header-inner {background-color: #fff;}

/* GNB */
.gnb { transition: opacity .3s; } 
.gnb-wrap { display: flex; margin-right: 4vw; padding-left: 300px;} 
.depth1 { position: relative; } 
/* .depth1::after {display: block; content: ''; width: 0; height: 0; border-radius: 50%; background: var(--color-sub) url(../images/common/ico_logo.png) no-repeat center; position: absolute; bottom: 0; left: 50%; transform: translate(-50%, 30%); z-index: 1; transition: 0.3s ease-in-out;} */
.depth1 > a {padding: 0 3vw; line-height: var(--header-height); position: relative; z-index: 1;} 
.depth1 > a span { letter-spacing: normal; font-size: 20px; font-weight: 700; color: #222; white-space: nowrap; } 

.depth2 {border: 2px solid var(--color-sub); display: none; position: absolute; top: 20px; right: 0; width: 100%; padding: 4em 0 1.2em; background-color: #fff; border-radius: 20px; transition: border 0.5s ease-in-out;} 
.depth2 a {font-size: 16px; font-weight: 700; padding: 0.8em 1.6vw 0.6em; text-align: center;} 

.depth3 {margin-bottom: 10px;}
.depth3 a {font-size: 14px; padding: 5px; color: #484848;}

.is-menu .gnb { visibility: hidden; opacity: 0; } 
:where(.is-hover, .is-fix) .depth1 > a span { color: #222; } 
.depth1:hover > a span { color: var(--color-main); } 
.depth1:hover::after {width: 30px; height: 30px;}
.depth1:hover::before {display: block; content: ''; width: 100%; height: 80px; border-radius: 20px 20px 0 0; background: #fff; position: absolute; top: 20px; left: 0;}
.depth2 li:hover > a span {color: #222; border-bottom: 1px solid #222;}
.depth3 li:hover a span {color: var(--color-sub); border-color: var(--color-sub);}

/* 유틸 */
.header-util { display: flex; align-items: center; column-gap: 3rem; z-index: 1;} 

/* 언어선택 버튼 */
.util-lang { position: relative; font-size: 15px; } 
.util-lang-btn {padding-left: 34px; height: 24px; background: url(../images/common/ico_lang.svg) no-repeat 0 center; font-size: 12px; font-weight: 700; color: #fff; transition: all .3s; } 
.util-lang-list {border-radius: 5px; display: none; position: absolute; top: calc(100% + 10px); left: 50%; padding: 0.4em 0; background-color: #fff; box-shadow: 0 0 1.5em var(--color-black-a1); color: #444; transform: translateX(-50%);} 
.util-lang-list a { padding: 0.4em 1em; } 
.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; } 
.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); } 

/* 전체메뉴 버튼 */
.util-allmenu-btn {font-weight: 700; color: #fff; font-size: 12px; padding-left: 30px; text-transform: uppercase; transition: .3s; position: relative;} 
.header-util .util-allmenu-btn::after {display: block; content: ''; width: 22px; height: 30px; background: url(../images/common/ico_allmenu.png) no-repeat center; position: absolute; top: 50%; left: 0; transform: translateY(-50%);}
.util-allmenu-btn:hover span:not(:nth-child(2)) { width: 18px; } 
.util-allmenu-btn span:nth-child(1) { transform: translateY(-8px); } 
.util-allmenu-btn span:nth-child(3) { transform: translateY(8px); } 
.is-menu .util-allmenu-btn span { width: 31px; transform: rotate(45deg) translate(-3px, 3px); } 
.is-menu .util-allmenu-btn span:nth-child(2) { opacity: 0; } 
.is-menu .util-allmenu-btn span:nth-child(3) { transform: rotate(-45deg) translate(-3px, -3px); } 

/* 전체메뉴 */
.allmenu { display: flex; position: fixed; z-index: 1101; width: 0; height: 0; border-bottom-left-radius: 100vw; background-color: #fff; top: -10%; right: -10%; transition: 0.5s, border-bottom-left-radius 1s, padding-right 0s, background-color 1s ease-in-out; text-align: center;} 
.allmenu-wrap {flex-grow: 1;/*  height: 100%; 옆 배경 없을 때 scroll생성 */}
.allmenu-top {display: flex; justify-content: space-between; position: fixed; top: 0; padding: 30px 30px; width: 100%; z-index: 1;}
.allmenu-top::before {display: block; content: ''; width: 250px; height: 126px; background: url(../images/common/header-util_bg.png); position: absolute; top: 0; right: 0;}
.allmenu-top .util-allmenu-btn {width: 40px; height: 60px; background: url() no-repeat center; position: relative;}
.allmenu-top .util-allmenu-btn span {display: block; width: 20px; height: 20px; padding: 0; background: url(../images/common/ico_x.png) no-repeat center; transform: rotate(0) translateX(-50%); position: absolute; bottom: 10px; left: 50%;}
.allmenu-top .util-allmenu-btn:hover {background: url(../images/common/ico_drop.svg) no-repeat center;}
.allmenu-top .util-allmenu-btn:hover span {width: 20px !important;}
.allmenu-top .util-allmenu-btn span::after {display: none;}
.allmenu-cont {max-width: 1400px; overflow: hidden; opacity: 0; height: 0; height: 0; margin: 0 auto;} 
.allmenu-cont::-webkit-scrollbar { width: 6px; } 
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); } 
.allmenu-list { display: flex;} 
.is-menu .allmenu {background-color: #fff; top: 0; right: 0; width: 100%; height: 100%; transform: translate(0); border-radius: 0;} 
.is-menu .allmenu-cont {width: 100%; height: 100%; animation-name: allmenu-cont; animation-delay: 0.5s; animation-duration: 2s; animation-fill-mode: forwards;} 

@keyframes allmenu-cont { 
	0% {opacity: 0; transform: translate(0, -10%);} 
	100% {opacity: 1; transform: translate(0, 0);} 
  }

.all-depth1 {height: 100vh; flex: 1; padding: calc(var(--header-height) + 12rem) 8rem 3rem; box-sizing: border-box; transition: background-color 0.3s ease-in-out;} 
.all-depth1-btn {width: 100%; padding-bottom: 0.4em; margin-bottom: 3rem; font-size: 3.4rem; font-weight: 700; color: #222; letter-spacing: -0.02em; white-space: nowrap; cursor: default; text-align: center; position: relative;} 
.all-depth1-btn::after {display: block; content: ''; width: 100%; height: 7px; background: url(../images/common/ico_allmenu-depth1-01.png) repeat-x left / contain; position: absolute; bottom: 0; left: 0;}
.all-depth1:hover {background: var(--color-main) url(../images/common/ico_allmenu-depth1-bg.png) no-repeat right bottom;}
.all-depth1:hover .all-depth1-btn {color: #fff;}
.all-depth1:hover .all-depth1-btn::after {background-image: url(../images/common/ico_allmenu-depth1-02.png);}
.all-depth2 { font-size: 20px; font-weight: 500; color: #484848; letter-spacing: -0.02em;} 
.all-depth2-btn { padding: 2em 0 0; position: relative;} 
.all-depth1:hover .all-depth2 {color: #fff;}
.all-depth2 li .all-depth2-btn::after {content: ''; display: block; width: 0; height: 0; background: url(../images/common/ico_drop.svg) no-repeat center / contain; position: absolute; top: 20px; left: 50%; transform: translateX(-50%); transition: all 0.3s ease-in-out;}
.all-depth2 li:hover .all-depth2-btn::after {width: 12px; height: 16px;}
.all-depth3 {padding-bottom: 0.5em; margin-top: 5px;}
.all-depth3:not(:has(li)) {display: none;}
.all-depth3 a {display: flex; justify-content: center; padding: 5px 0; font-size: 16px; font-weight: 500; color: #888; letter-spacing: -0.02em;}
.all-depth1:hover .all-depth3 a {color: #b7d7f3;}
.all-depth1 .all-depth3 a:hover {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):not(.is-menu) .gnb-dim { opacity: 1; } 

@media (hover: hover) and (pointer: fine) {
	
.is-menu .util-allmenu-btn:hover span { width: 31px; } 
}
@media (max-width: 1600px) {
	.header-inner::before {width: 95%;}
}
@media (max-width: 1440px) {
	.header-inner::after {top: -20px;}
	.is-fix .header-inner::after {top: 0;}

	.depth1 > a span {font-size: 18px;}
	.depth2 a {font-size: 14px;}
 }
@media (max-width: 1280px) {
	.header-inner::after {top: -60px;}
	.header-inner::before {width: 100%;}
	.is-fix .header-inner::after {width: 200px; left: calc(100% - 200px);}
	.gnb {z-index: 1;}

	.all-depth1 {padding: calc(var(--header-height) + 8rem) 4rem 3rem;}
 }
@media (max-width: 1024px) {
	.header-inner::after,
	.is-fix .header-inner::after {width: calc(153px + (var(--outer-padding) * 2)); height: var(--header-height); left: auto; right: 0; top: 0;}
	.header-inner::before {background: #fff; height: var(--header-height);}
	.header-util {position: absolute; top: 50%; right: var(--outer-padding); transform: translateY(-50%);}
	.gnb { display: none; } 
	.all-depth1 {padding: calc(var(--header-height) + 8rem) 2rem 3rem;}
	.all-depth1-btn {font-size: 2.8rem;}
	.all-depth2 { font-size: 16px; } 
	.all-depth2 li:hover .all-depth2-btn::after {top: 10px;}
}
@media (max-width: 768px) {
	.header {--allmenu-gap: var(--inner-padding); --allmenu-img-width: 120px; }
	.allmenu-cont::-webkit-scrollbar { width: 0; } 
	.allmenu-list { display: block; padding-top: calc(var(--header-height) + 8rem) ;} 
	.all-depth1 { padding: 0; height: auto;} 
	.all-depth1-btn {padding: 20px; cursor: pointer; margin-bottom: 10px;}
	.all-depth1-btn::after {width: 50%; left: 50%; transform: translateX(-50%);}
	.all-depth2 {display: none; padding-bottom: 2rem;}
	.all-depth2-btn br {display: none;}
	.all-depth1:hover {background-image: none;}
}
@media (max-width: 576px) { 
	.header {--allmenu-img-width: 0px;}
	.allmenu { transform: none; } 
	.is-menu .allmenu { transform: none;} 
} 
@media (max-width: 480px) { 
	.header-inner::after {width: calc(80px + (var(--outer-padding) * 2));}
	.is-fix .header-inner::after {width: calc(80px + (var(--outer-padding) * 2)); left: auto; right: 0;}
	.allmenu-top {align-items: flex-start; justify-content: flex-end;}
	.header-util {column-gap: 0;} 
	.allmenu-top .logo {position: absolute; left: 50%; top: calc(var(--header-height) + 5rem); transform: translateX(-50%);}
	.util-lang {margin-right: 10px;}
	.util-lang-btn,
	.util-allmenu-btn {font-size: 0;}
	.util-allmenu-btn span {display: block; font-size: 0; height: 24px;}
	.util-allmenu-btn span:nth-child(1) { transform: translateY(-2px); }
	.allmenu-list {padding-top: calc(var(--header-height) + 12rem);}
	.allmenu-top .util-allmenu-btn span { transform: translate(-50%, -2px); }
	.all-depth2-btn {padding-top: 1.5em;}
	.all-depth2 li:hover .all-depth2-btn::after {top: 5px;}
	.all-depth3 {padding-bottom: 0;}
	.all-depth3 a {font-size: 14px; padding: 2px 0;}
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 6rem 0; background-color: #333; color: #fff; position: relative;} 
.footer .water-wave {position: absolute; top: 0; left: 0; transform: translateY(-100%); width: 100%;}
.waves {
	position:relative;
	width: 100%;
	height:15vh;
	margin-bottom:-7px; /*Fix for safari gap*/
	min-height:40px;
	max-height:80px;
  }
.parallax > use {
	animation: move-forever 25s cubic-bezier(.55,.5,.45,.5)     infinite;
  }
  .parallax > use:nth-child(1) {
	animation-delay: -2s;
	animation-duration: 7s;
  }
  .parallax > use:nth-child(2) {
	animation-delay: -3s;
	animation-duration: 10s;
  }
  @keyframes move-forever {
	0% {
	 transform: translate3d(-90px,0,0);
	}
	100% { 
	  transform: translate3d(85px,0,0);
	}
  }

.footer .inner {display: flex; justify-content: space-between; padding-top: 7rem;}
.footer .footer-logo {position: absolute; top: 0; left: 0;}
.footer-menu { display: flex; justify-content: end; align-items: center; border-top: 1px solid #717171; border-bottom: 1px solid #717171;} 
.footer-menu .item { display: flex; align-items: center; } 
.footer-menu .item a {font-size: 16px; font-weight: 400; color: #999; padding: 1rem 4rem; } 
.footer-menu .item + .item::before { width: 5px; height: 5px; border-radius: 50%; background-color: var(--color-sub); content: ''; } 

.footer-contact { display: flex; flex-wrap: wrap; gap: 5px 40px; margin-bottom: 4rem; } 
.footer-contact .item { display: flex; font-size: 18px; font-weight: 400; color: #828282;} 
.footer-contact .item dt {margin-right: 10px; font-weight: 700; color: #ccc;} 
.footer-contact .item.addr { width: 100%; } 
.footer-contact .item:last-child {margin-top: 25px;}

.footer-copy {font-size: 16px; font-weight: 400; line-height: 1.3; color: #828282; margin-top: 30px; white-space: nowrap;} 

/* 탑버튼 */
.top-btn {position: absolute; top: -80px; right: 40px; width: 60px; height: 80px; background: url(../images/common/ico_drop.svg) no-repeat center/contain;} 
.top-btn::before {display: block; width: 25px; height: 33px; margin: auto; background: url(../images/common/ico_top.svg) no-repeat center/contain; content: ''; transform: translateY(5px);}  
@keyframes top-btn {
	33% { transform: translateY(2px); } 
	66% { transform: translateY(-4px); } 
}

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover::before { animation: top-btn 1.5s infinite linear; }
}
@media (max-width: 1280px) { } 
@media (max-width: 1024px) {
	.footer .footer-logo {left: 50%; transform: translateX(-50%);}
	.footer .inner {flex-wrap: wrap; justify-content: center;}
	.footer-contact,
	.footer-contact .item.addr,
	.footer-menu {justify-content: center;}
 } 
@media (max-width: 768px) {
	.footer-contact .item {font-size: 16px;} 
	.footer-copy {font-size: 14px;}
} 
@media (max-width: 640px) {
	.footer-contact .item {width: 100%; justify-content: center; margin-bottom: 10px;}
	.footer-contact .item.addr {display: block; text-align: center;}
	.footer-contact .item.addr dt {margin: 0 0 5px;}
 } 
@media (max-width: 480px) {
	.footer-menu {flex-wrap: wrap;}
	.footer-menu .item {position: relative; width: 100%;}
	.footer-menu .item a {width: 100%; text-align: center;}
	.footer-menu .item + .item::before {position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%);}
	.footer-copy {white-space: wrap; text-align: center;}
 } 
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 70px;}
/* SUV-VISUAL */
.sub-visual {position: relative; height: calc(25rem + 200px); margin-bottom: -50px; } 
.sub-visual::before { position: absolute; left: -80px; bottom: 0; width: 390px; height: 306px; background: url(../images/main/bg-deco.png) no-repeat center / contain; content: ''; } 
.sub-visual-bg { overflow: hidden; position: absolute; inset: 0; mask-image: url(../images/common/sub-visual-mask.svg); mask-repeat: no-repeat; mask-size: cover; mask-position: center bottom;} 
.sub-visual-bg span { position: absolute; inset: 0; background: #444 no-repeat center/cover; transform: scale(1.1); animation: sub-visual 5s linear both; } 
@keyframes sub-visual { to { transform: scale(1); } } 
.sub-visual-txt { display: flex; flex-direction: column; justify-content: center; align-items: flex-end; height: 100%; height: 100%; padding: 100px 8rem var(--sub-tab-height) 0; text-align: right; color: #fff;} 
.sub-visual-tit {font-size: 7rem; font-weight: 700; padding-left: 90px;} 
.sub-visual-slogan {font-size: 24px; font-weight: 400; color: var(--color-white-a6); line-height: 1.1;}

.sub-visual-txt {position: relative;}
.sub-visual-txt .tit-wave {position: absolute; top: 35px; left: 0; transform: translateY(-50%);}
.sub-visual-txt .tit-wave span {display: inline-block; width: 4px; height: 70px; background: url(../images/main/visual-txt01.png) no-repeat center / contain; margin-left: 5px; animation: tit-wave 3s linear infinite;}
.sub-visual-txt .tit-wave span:first-child {margin-left: 0;}
.sub-visual-txt .tit-wave span.nth-2 {background-image: url(../images/main/visual-txt02.png); animation-delay: -3s; animation-duration: 7s;}
.sub-visual-txt .tit-wave span.nth-3 {background-image: url(../images/main/visual-txt03.png); animation-delay: -5s;}
.sub-visual-txt .tit-wave span.nth-4 {background-image: url(../images/main/visual-txt04.png); animation-delay: -7s; animation-duration: 10s;}
.sub-visual-txt .tit-wave span.nth-5 {background-image: url(../images/main/visual-txt05.png); animation-delay: -5s;}
.sub-visual-txt .tit-wave span.nth-6 {background-image: url(../images/main/visual-txt06.png); animation-delay: -3s; animation-duration: 5s;}
.sub-visual-txt .tit-wave span.nth-7 {background-image: url(../images/main/visual-txt07.png); animation-delay: -7s;}

@keyframes tit-wave { 
  0% { transform: translateY(-10%);} 
  50% { transform: translateY(10%);} 
  100% { transform: translateY(-10%);}
}

@media (max-width: 1280px) {
	.sub-visual-txt {padding: var(--header-height) 8rem var(--sub-tab-height) 0;} 
}
@media (max-width: 1024px) {
	.sub-visual-txt {padding-right: 0;}
	.sub-visual-tit {font-size: 6rem; margin: 0 auto;}
	.sub-visual-slogan {font-size: 22px; margin: 0 auto;}
}

@media (max-width: 768px) {
	.sub-visual-txt .tit-wave {top: 28px;}
	.sub-visual-txt .tit-wave span {width: 3px; height: 60px; margin-left: 6px;}
}

@media (max-width: 480px) {
	.sub-visual-tit {font-size: 5rem; padding-left: 6rem;}
	.sub-visual-slogan {font-size: 18px;}

	.sub-visual-txt .tit-wave {top: 20px;}
	.sub-visual-txt .tit-wave span {width: 2px; height: 50px; margin-left: 4px;}
}

/* SUB-TAB */
.sub-tab { position: relative; z-index: 10; margin-top: calc(-1 * var(--sub-tab-height)); font-weight: 700; font-size: 18px;} 
.sub-tab::before {display: block; content: ''; width: 100%; height: 6px; background: linear-gradient(to left, var(--color-sub) 0%, var(--color-sub) 46px, var(--color-main) 47px, var(--color-main) 61px, var(--color-sub) 62px, var(--color-sub) 100%) no-repeat right bottom/100% 6px; position: absolute; top: 50%; right: calc(100% - var(--inner-padding));}
.sub-tab-inner { display: flex;}

.sub-tab-home {height: 7rem; width: 7rem; border-radius: 50%; flex-shrink: 0; background: var(--color-sub) url(../images/common/ico_home.png) no-repeat center; position: relative; z-index: 1;} 
.sub-tab-item { position: relative; min-width: 13rem;} 
.sub-tab-item:nth-of-type(1) {margin-left: 20px;}
.sub-tab-item:nth-of-type(1)::before {display: block; content: ''; width: 6rem; height: 7rem; background: var(--color-main); position: absolute; top: 0; left: -5.5rem;}
.sub-tab-item:last-child .sub-tab-btn {padding-right: 100px;}
.sub-tab-btn { overflow: hidden; display: block; position: relative; z-index: 5; width: 100%; height: var(--sub-tab-height); padding: 0 calc(10% + 50px) 0 10%; text-align: left; color: var(--color-sub); white-space: nowrap; transition: .2s; background: var(--color-main);} 
.sub-tab-item:last-child .sub-tab-btn {border-radius: 0 70px 70px 0;}
.sub-tab-item:last-child .sub-tab-btn::before {right: 40px;}
.sub-tab-btn::before { position: absolute; top: 50%; right: 8%; width: 24px; height: 24px; border-radius: 50%; background: url(../images/common/ico_arrow02.png) no-repeat center 10px; content: ''; transform: translateY(-50%) rotate(-90deg); transition: .2s;} 
.sub-tab-item.is-active .sub-tab-btn {color: #fff;}
.sub-tab-item.is-active .sub-tab-btn::before { background-color: var(--color-sub); transform: translateY(-50%) rotate(0); } 
/* 리스트 */
.sub-tab-list {border-radius: 20px; border: 1px solid var(--color-main); display: none; position: absolute; top: calc(100% - 10px); z-index: 5; width: 100%; background-color: #fff; box-shadow: 0 0 2em var(--color-black-a1); font-size: var(--font-16);} 
.sub-tab-list a { padding: 0.85em 10%; font-size: 16px; font-weight: 700; color: #666;} 
.sub-tab-list li.on a {color: #222;}
.sub-tab-list li.on span {border-bottom: 1px solid #222;}
@media (max-width: 768px) {
	.sub-tab {font-size: 16px;}
	.sub-tab-list a {font-size: 14px;}
}

@media (max-width: 640px) {
	.sub-tab-item:last-child .sub-tab-btn::before {right: 20px;}
}

@media (max-width: 480px) {
	.sub-tab-item:nth-of-type(1) {margin-left: 0;}
	.sub-tab-item:nth-of-type(1)::before {left: -3.5rem;}
	.sub-tab-btn::before {right: 0;}
	.sub-tab-item:last-child .sub-tab-btn {padding-right: 50px; text-overflow: ellipsis;}
}


/* SUB-CONTENT */
.sub-content-tit h3 { padding: 14rem 0 8rem; font-weight: 700; font-size: 4rem; text-align: center; color: #222; background: url(../images/common/ico_sub-content-tit.png) no-repeat center 8rem;} 
.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) {
	.sub-tab-list li a:hover {color: #222;} 
	.sub-content-tab li:not(.on) a:hover {color: var(--color-main); text-shadow: 0 0 0.04em var(--color-main);}
}
@media (max-width: 1280px) {
	.body-sub { --sub-tab-height: 63px; } 
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 56px;} 
	.sub-content-tit h3 {font-size: 3rem;}
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-height: 49px; } 
	.sub-content-tit h3 {font-size: 2.5rem;}
	.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 =============================================== */
















/* 24.06.27 추가 */
.sub-content-tit h3 {background: url(../images/common/ico_sub-visual-tit.png) no-repeat center 6rem;} 

@media (max-width: 768px) {
	.sub-content-tit h3 {background: url(../images/common/ico_sub-visual-tit.png) no-repeat center 6rem; background-size: 40px 46px;}
}
@media (max-width: 480px) {
	.sub-content-tit h3 {background: url(../images/common/ico_sub-visual-tit.png) no-repeat center 7rem; background-size: 30px 36px;}
}