@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");


/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #2e5ea3;
	--color-sub: ;
	--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;}
#wrap {overflow: hidden;}
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); max-width: 1400px;}

@media (max-width: 1420px) {
	.inner {width: calc(100% - (var(--inner-padding)*2));}
}
@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;} }
@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: end; 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::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):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-a1), var(--color-black-a1)); background-size: calc(100% - var(--allmenu-gap) - var(--allmenu-img-width)) 1px;}

.header-logo { position: absolute; left: var(--outer-padding); width: 20rem; transition: left .5s;} 
:is(.is-hover, .is-fix):not(.is-menu) #header-logo-white,
.is-menu #header-logo { 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):not(.is-menu) #header-logo,
.is-menu #header-logo-white { opacity: 1; } 

/* GNB */
.gnb {transition: opacity .3s;} 
.gnb-wrap {display: flex; position: absolute; top: 0; left: 50%; transform: translateX(-50%);} 
.depth1 { position: relative; } 
.depth1 > a { padding: 0 1.6vw; line-height: var(--header-height); position: relative;} 
.depth1 > a span {font-family: var(--font-montserrat); font-size: 18px; font-weight: 700; letter-spacing: normal; color: #fff; white-space: nowrap;} 
.depth1 > a::after {display: block; content: ''; width: 12px; height: 12px; border-radius: 50%; background: var(--color-main); position: absolute; top: 2rem; left: 1rem; opacity: 0; transition: all 0.3s ease-in-out;}

.depth2 { display: none; position: absolute; top: var(--header-height); right: 0; min-width: 100%; padding: 1.2em 0; background-color: var(--color-main); border-radius: 0 30px 30px 30px;} 
.depth2 a {padding: 0.6em 1.6vw; font-size: 16px; font-weight: 700; color: #fff;} 
.depth2 span { white-space: nowrap; } 

.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 > a::after {opacity: 1;}

/* 유틸 */
.header-util { display: flex; align-items: center; column-gap: 3rem; } 

/* 브로슈어 버튼 */
.util-e-brochure {width: 26px; height: 22px; background: url(../images/common/ico_e-brochure.png) no-repeat center; transition: all .3s; position: relative; z-index: 1;}
:is(.is-hover, .is-fix):not(.is-menu) .util-e-brochure {background-image: url(../images/common/ico_e-brochure_on.png);}
.is-menu .util-e-brochure { visibility: hidden; opacity: 0; } 

/* 언어선택 버튼 */
.util-lang { position: relative; font-size: 15px; } 
.util-lang-btn { width: 24px; height: 24px; background: url(../images/common/ico_lang.svg) no-repeat center; transition: all .3s; } 
.util-lang-list { 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); } 
:is(.is-hover, .is-fix):not(.is-menu) .util-lang-btn { background-image: url(../images/common/ico_lang_on.svg); } 
.is-menu .util-lang-btn { visibility: hidden; opacity: 0; } 

/* 전체메뉴 버튼 */
.util-allmenu-btn {display: flex; flex-direction: column; align-items: center; justify-content: space-between; position: relative; width: 20px; height: 20px; } 
.util-allmenu-btn span {display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: #fff; position: relative;}
.util-allmenu-btn span+span {margin-top: 3px;}
.util-allmenu-btn span::before {display: block; content: ''; width: 5px; height: 5px; border-radius: 50%; background: #fff; position: absolute; top: 0; left: -8px;}
.util-allmenu-btn span::after {display: block; content: ''; width: 5px; height: 5px; border-radius: 50%; background: #fff; position: absolute; top: 0; right: -8px;}

.is-menu .util-allmenu-btn span {width: 31px; height: 3px; border-radius: 0; transform: rotate(45deg) translate(-3px, 3px); position: absolute; top: 10px; left: 0;} 
.is-menu .util-allmenu-btn span+span {margin-top: 0;}
.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); }
.is-menu .util-allmenu-btn span::before,
.is-menu .util-allmenu-btn span::after {opacity: 0;}

:is(.is-hover, .is-fix):not(.is-menu) .util-allmenu-btn span,
:is(.is-hover, .is-fix):not(.is-menu) .util-allmenu-btn span::before,
:is(.is-hover, .is-fix):not(.is-menu) .util-allmenu-btn span::after {background: #000;}

/* 전체메뉴 */
.allmenu {display: flex; visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; transform: translateX(calc(-1 * (var(--allmenu-img-width) + var(--allmenu-gap)))); transition: .5s, padding-right 0s, width 0s;}
.allmenu-wrap {width: 100%;}
.allmenu-cont {display: flex; height: 100%; background: #1c1d21 url(../images/common/allmenu_bg01.jpg) no-repeat right center/cover;}
.allmenu-cont::-webkit-scrollbar { width: 6px; } 
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); } 
.allmenu-info {display: flex; flex-direction: column; justify-content: flex-end; max-width: 30%; padding: 4rem; background: var(--color-main); border-top-right-radius: 30px;}
.allmenu-add {font-size: 15px; font-weight: 700; color: #5e8fd7; letter-spacing: 0.05em;}
.allmenu-add+.allmenu-add {margin-top: 5rem;}
.allmenu-add p {line-height: 1.3;}
.allmenu-add p+p {margin-top: 2rem;}
.allmenu-add span {display: block; font-weight: 900;}
.allmenu-add+.allmenu-add span {line-height: 1.1;}

.allmenu-list {display: flex; flex-direction: column; flex: 1; padding-top: calc(var(--header-height) + 2rem); position: relative;}
.allmenu-list::before {display: block; content: ''; width: 1px; height: 100%; background: #292a2f; position: absolute; top: 0; left: 32rem;}
.all-depth1 {display: flex; align-items: flex-start; min-height: 15rem;}
.all-depth1-btn {min-width: 32rem; padding-left: 6rem; font-family: var(--font-montserrat); font-size: 3.5rem; font-weight: 700; color: #4d4d4d; text-align: left; position: relative; transition: all 0.3s ease-in-out;}
.all-depth1-btn::after {display: block; content: ''; width: 41px; height: 38px; background: url(../images/common/ico_allmenu.png) no-repeat center; position: absolute; top: 50%; left: 100%; transform: translate(-10px, -50%); opacity: 0; transition: all 0.3s ease-in-out;}
.all-depth1:hover .all-depth1-btn {color: var(--color-main);}
.all-depth1:hover .all-depth1-btn::after {opacity: 1;}

.all-depth2 > ul {display: flex; margin-top: 1.5rem;}
.all-depth2 > ul > li {padding-left: 4rem;}
.all-depth2-btn {font-size: 18px; font-weight: 700; color: #fff; transition: all 0.3s ease-in-out;}
.all-depth2-btn span {position: relative;}
.all-depth2-btn span::after {display: block; content: ''; width: 0; height: 2px; background: var(--color-main); position: absolute; top: 100%; left: 0; transition: all 0.3s ease-in-out;}
.all-depth2 > ul > li:hover .all-depth2-btn {color: var(--color-main);}
.all-depth2 > ul > li:hover .all-depth2-btn span::after {width: 100%;}

.all-depth3 {margin-top: 1rem;}
.all-depth3 li {padding-bottom: 0.5em;}
.all-depth3:not(:has(li)) {display: none;}
.all-depth3 a {font-size: 16px; font-weight: 700; color: #a6a6a6; position: relative; transition: all 0.3s ease-in-out;}
.all-depth3 a::before { margin-right: 0.3em; content: '-'; }
.all-depth3 a:hover {color: #fff;}


.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateX(0);} 
.is-menu .allmenu-cont { visibility: visible; opacity: 1; transition: .6s ease-out .2s; }

/* 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: 1620px) { 
	.allmenu-list::before {left: 28rem;}
	.allmenu-info {padding: 3rem;}
	.allmenu-add:first-child {display: none;}
	.all-depth1-btn {padding-left: 6rem; min-width: 28rem; font-size: 3rem;}
}
@media (max-width: 1440px) { 
	.allmenu-info {display: none;}
	.all-depth2 > ul > li {padding-left: 6rem;}
	.all-depth2-btn {font-size: 16px;}
}
@media (max-width: 1280px) {
	.allmenu-list::before {left: 25rem;}
	.all-depth1-btn {padding-left: 2rem; min-width: 25rem;}
	.all-depth2 > ul {margin-top: 1rem;}
	.all-depth2 > ul > li {padding-left: 5rem;}
 }
@media (max-width: 1024px) {
	.gnb { display: none; } 

	.allmenu-list { display: block; } 
	.allmenu-list::before {display: none;}
	.all-depth1 {padding: 0; min-height: 1px;} 
	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; max-width: none; min-width: 22rem; padding: 2.4rem max(3%, 12px); margin: 0; font-size: 24px; cursor: pointer; } 
	.all-depth2 { display: none; background-color: var(--color-black-a05); font-size: 16px;} 
	.all-depth2 > ul > li {padding-left: 3rem;}
	.all-depth2 > ul > li:first-child {padding-left: 0;}
	.all-depth2-btn { padding: 0.6em max(4%, 16px); } 
	.all-depth3 a { padding-left: max(4%, 16px);}

	.header {--allmenu-gap: var(--inner-padding); --allmenu-img-width: 120px; }
	.allmenu-cont::-webkit-scrollbar { width: 0; } 
	.all-depth1 {display: block;}
	.all-depth1-btn {width: 100%; border-bottom: 1px solid var(--color-main); position: relative;} 
	.all-depth1-btn::after {display: block; content: ''; flex-shrink: 0; width: 18px; height: 10px; background-image: url(../images/common/chevron_w18.svg); transition: .3s; position: static; top: auto; left: auto; transform: translateX(25%); z-index: 1; opacity: 1; transform-origin: 50%;} 
	.all-depth1-btn.on::after { transform: translateX(25%) rotate(180deg);} 
	.all-depth2 { display: none; padding: 0.8em max(1.5%, 12px); background-color: var(--color-black-a05); font-size: 16px;} 
	.all-depth2 > ul {display: block; margin-top: 0;}
	.all-depth2 > ul > li {padding-left: 0;}
	.all-depth2-btn {font-size: 16px; padding: 0.6em max(4%, 16px); } 
	.all-depth3 a {padding-left: max(4%, 16px);}
}
@media (max-width: 768px) {
}
@media (max-width: 576px) { 
	.header {--allmenu-img-width: 0px;}
	.allmenu { transform: none; } 
	.is-menu .allmenu { transform: none;} 
} 
@media (max-width: 480px) { 
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer {background: #fff; color: #666; position: relative;}
.body-sub .footer::before {display: block; content: ''; width: 100%; height: 20rem; background: linear-gradient(to top, #f3f6fb, rgba(255, 255, 255, 0)); position: absolute; bottom: 100%; left: 0; z-index: -1;}
.footer .inner {display: flex; align-items: flex-start; padding: 9rem 0;}

.footer-logo {padding-right: 5rem; border-right: 1px solid #e2e2e2;}

.footer-contact {display: flex; flex: 1; flex-wrap: wrap; justify-content: space-between; padding-bottom: 9rem; margin-left: 4rem; letter-spacing: 0.015em; position: relative;}
.footer-contact address {font-size: 16px;}
.footer-contact .addr {line-height: 1.6;}
.footer-contact .addr .tit,
.footer-contact .contact dt {font-weight: 900; color: var(--color-main);}
.footer-contact .addr .item {display: flex; flex-direction: column; margin-top: 0.5rem;}
.footer-contact .addr dt {min-width: 150px; font-weight: 900; color: #222; padding-right: 12px; margin-right: 12px; position: relative;}
.footer-contact .addr dt::after {display: block; content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--color-main); position: absolute; top: 38px; left: 0; transform: translate(50%, -50%);}
.footer-contact .addr dd {padding-left: 1rem;}
.footer-contact .contact {flex: 1; margin-top: 5rem; display: flex; column-gap: 3rem; width: 100%;}
.footer-contact .contact dd {font-weight: 700; color: #666;}
.footer-contact .contact .item {margin-bottom: 1.5rem; display: flex; column-gap: 1rem;}

.footer-menu {margin-top: 0.5rem; display: flex; column-gap: 2rem; margin-top: 3rem; width: 100%;}
.footer-menu a {padding: 0.5rem 0; font-size: 15px; font-weight: 800; color: #222;}

.footer-copy {position: absolute; bottom: 0; right: 0; font-family: var(--font-montserrat); font-size: 13px; font-weight: 700; letter-spacing: 0.32em; color: #b9b9b9; text-transform: uppercase;}

/* 탑버튼 */
.top-btn {display: flex; align-items: center; justify-content: center; width: 70px; height: 70px; background: var(--color-main); position: absolute; bottom: 0; right: 0; cursor: pointer;}
.top-btn button {width: 20px; height: 40px; background: url(../images/common/ico_top.svg) no-repeat center/contain;}
@keyframes top-btn {
	33% { transform: translateY(2px); } 
	66% { transform: translateY(-4px); } 
}

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover button { animation: top-btn 1.5s infinite linear; }
}
@media (max-width: 1440px) { 
	.footer-logo {padding-right: 5rem;}
	.footer-contact {margin-left: 5rem;}
	.footer-contact {flex-wrap: wrap; padding-bottom: 4rem;}
	.footer-menu {display: flex; justify-content: flex-end; width: 100%; margin-top: 3rem;}
	.footer-menu li+li {margin-left: 3rem;}
	.footer-contact address {width: 100%;}
	.footer-contact .addr .item {flex-direction: column; align-items: flex-start;}
	.footer-contact address.contact {display: flex; margin-top: 2rem;}
	.footer-contact address.contact .item+.item {margin-left: 3rem;}
} 
@media (max-width: 1280px) { 
} 
@media (max-width: 1024px) { 
} 
@media (max-width: 768px) { 
	.footer .inner {flex-direction: column; align-items: center;}
	.footer-logo {padding-right: 0; border: 0;}
	.footer-contact {margin-left: 0; margin-top: 3rem;}
} 
@media (max-width: 576px) { 
	.footer .inner {padding: 6rem 0 12rem;}
	.footer-logo img {max-width: 70px;}
	.footer-contact address {font-size: 14px;}
	.footer-contact .addr .item {flex-direction: column; align-items: flex-start;}
	.footer-copy {font-size: 12px;}
	.footer-contact .addr dt::after {top: 33px;} 
} 
@media (max-width: 480px) { 
	.footer-contact {text-align: center; padding-bottom: 8rem;}
	.footer-contact .addr .item {align-items: center;}
	.footer-contact .addr dt {margin-right: 0; padding-right: 0;}
	.footer-contact .addr dt::after {display: none;}
	.footer-contact address.contact {flex-direction: column; align-items: center;}
	.footer-contact address.contact .item+.item {margin-left: 0;}
	.footer-menu {justify-content: center; flex-direction: column;}
	.footer-menu li+li {margin-left: 0; margin-top: 1rem;}
} 
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 70px;}
/* SUV-VISUAL */
.sub-visual {height: calc(25rem + 200px); position: relative;} 
.sub-visual::after {display: block; content: ''; width: 237px; height: 173px; background: url(../images/common/sub-visual.png) no-repeat right bottom; position: absolute; right: 0; bottom: 0;}
.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.1); animation: sub-visual 5s linear both; } 
@keyframes sub-visual { to { transform: scale(1); } } 
.sub-visual-bg::after { position: absolute; inset: 0; background-color: var(--color-black-a6); content: ''; } 
.sub-visual-txt {display: flex; flex-direction: column; justify-content: center; align-items: flex-start; height: 100%; padding-top: var(--header-height); text-align: center; color: #fff; z-index: 1;} 
.sub-visual-tit {padding: 0 0.5rem 0 1rem; font-family: var(--font-montserrat); font-size: 25px; font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase; background: var(--color-main);}
.sub-visual-slogan {margin-top: 1rem; margin-left: 1rem; font-size: 16px; font-weight: 700; letter-spacing: 0; text-align: left;}

@media (max-width: 768px) {
	.sub-visual {height: 40rem; padding-bottom: 2rem;}
}
@media (max-width: 480px) {
	.sub-visual {padding-bottom: 5rem;}
	.sub-visual-tit {font-size: 20px;}
	.sub-visual-slogan {text-align: left; margin-left: 0; font-size: 14px; font-weight: 500;}
}


/* SUB-TAB */
.sub-tab {position: relative; z-index: 50; height: var(--sub-tab-height); padding: 0 var(--inner-padding);}
.sub-tab-deco-box {position: absolute; bottom: -20px; right: 29.4rem;}
.sub-tab-deco-bg {width: 138px; height: 138px; border-radius: 50%; background: #fff; box-shadow: 0 0 106px rgba(0, 0, 0, 0.21); position: relative;}
.sub-tab-deco-bg::after {display: block; content: ''; width: calc(100% - 20px); height: calc(100% - 20px); background: url(../images/common/sub-tab-deco01.png) no-repeat center; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); animation: deco-any 50s linear infinite;}
@keyframes deco-any {
	100% {transform: translate(-50%, -50%) rotate(360deg);}
  }
.sub-tab-deco-bg::before {display: block; content: ''; width: calc(100% + 310px); height: calc(100% + 310px); background: url(../images/common/sub-tab-deco.png) no-repeat center; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}
.sub-tab-deco {display: flex; align-items: center; justify-content: center; width: 65px; height: 65px; border-radius: 50%; background-color: var(--color-main); position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1;}
.sub-tab-deco .bluetooth {width: 17px; height: 30px; background: url(../images/common/bluetooth-deco.png) no-repeat center; position: relative;}
.sub-tab-deco .bluetooth-deco {display: flex; position: absolute; top: 50%; left: -15px; transform: translateY(-50%);}
.sub-tab-deco .bluetooth-deco:last-child {left: auto; right: -15px; transform: translateY(-50%) rotate(180deg);}
.sub-tab-deco .bluetooth-deco span {display: inline-block; width: 4px; height: 16px; opacity: 0;}
.sub-tab-deco .bluetooth-deco span:first-child {background: url(../images/common/bluetooth-deco01.png) no-repeat center; transform: translateX(2px); animation: bluetooth-deco-any 2s linear infinite; animation-delay: 1s;}
.sub-tab-deco .bluetooth-deco span:nth-of-type(2) {background: url(../images/common/bluetooth-deco02.png) no-repeat center; transform: translateX(0.5px); animation: bluetooth-deco-any 2s linear infinite; animation-delay: 0.5s;}
.sub-tab-deco .bluetooth-deco span:last-child {background: url(../images/common/bluetooth-deco03.png) no-repeat center; animation: bluetooth-deco-any 2s linear infinite;}
@keyframes bluetooth-deco-any {
	0% {opacity: 1;}
	100% {opacity: 0;}
  }

.sub-tab-btn {display: none; position: relative; z-index: 5; width: 100%; height: 100%; background-color: var(--color-main); color: #fff; font-size: 18px; font-weight: 500;} 
.sub-tab-list {width: 100%; position: relative; z-index: 1;} 
.sub-tab-list::before {display: block; content: ''; width: calc(100% + (var(--inner-padding)*2)); height: 1px; background: linear-gradient(to left, rgba(0, 0, 0, 0) 10rem, #ecedef); position: absolute; left: calc(-1 * var(--inner-padding)); bottom: 0; transition: all 0.3s ease-in-out;}
.sub-tab-list::after {display: block; content: ''; width: var(--inner-padding); height: 1px; background: var(--color-main); position: absolute; left: calc(-1 * var(--inner-padding));}
.sub-tab-line { position: absolute; bottom: -1px; height: 1px; background-color: var(--color-main); transition: all 0.3s ease-in-out;}
.sub-tab-list ul {display: flex; align-items: center; overflow-x: auto; height: var(--sub-tab-height); } 
.sub-tab-list ul::-webkit-scrollbar {height: 6px; background-color: #fff;}
.sub-tab-list ul::-webkit-scrollbar-thumb {border: 1px solid transparent; background-color: var(--color-main); background-clip: content-box;}
.sub-tab-list li a {padding: 0 2rem; font-size: 18px; font-weight: 700; color: #222;}
.sub-tab-list li:first-child a {padding-left: 0;}
.sub-tab-list li.on a {color: var(--color-main); font-weight: 800;}

@media (max-width: 1620px) {
	.sub-tab-deco-box {right: 12rem;}
}
@media (max-width: 1280px) {
	.sub-tab-deco-box {bottom: -28px;}
}
@media (max-width: 1024px) {
	.sub-tab-deco-box {right: 6rem;}
}
@media (max-width: 768px) {
	.sub-tab-deco-box {right: 2rem;}
}
@media (max-width: 576px) {
	.sub-tab {padding: 0; background-color: var(--color-main);}
	.sub-tab-btn { display: block; padding: 0 1em; } 
	.sub-tab-btn::before { position: absolute; top: 50%; right: 5%; width: 13px; height: 8px; background-color: #fff; mask-image: url(../images/common/chevron_w13.svg); -webkit-mask-image: url(../images/common/chevron_w13.svg); content: ''; transform: translateY(-50%); transition: .3s;} 
	.sub-tab.is-active .sub-tab-btn::before { transform: translateY(-50%) rotate(180deg); } 
	.sub-tab-list { display: none; position: absolute; top: 100%; left: 0; height: auto; box-shadow: 0 0 3em var(--color-black-a1);} 
	.sub-tab-list ul { flex-direction: column; height: auto; background: #fff;} 
	.sub-tab-list li {width: 100%;}
	.sub-tab-list li a,
	.sub-tab-list li:first-child a { padding: 1.2em 1em; text-align: center;}

	.sub-tab-deco-box {bottom: 2rem; right: 1rem;}
	.sub-tab-deco-bg::before {display: none;}
}
@media (max-width: 480px) {
	.sub-tab-deco-bg {width: 127px; height: 127px;}
}

/* SUB-CONTENT */
.sub-content-tit h3 {padding: 5rem 0 12rem; font-weight: 700; font-size: 5.5rem; color: #222; } 
/* SUB-CONTENT-TAB */
.sub-content-tab { overflow-x: auto; padding: 0 var(--inner-padding); margin-bottom: 7rem; text-align: center; position: relative; z-index: 50;}
.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 var(--color-main);}
.sub-content-tab li.on {z-index: 5;}
.sub-content-tab li a { min-width: 20rem; padding: 1rem 4rem; font-size: 18px; font-weight: 500; color: #666; transition: .3s;}
.sub-content-tab li.on a { background-color: var(--color-main); font-weight: 700; color: #fff; }

@media (hover: hover) and (pointer: fine) {
	.sub-tab-list li a:hover { background-color: #fff; color: var(--color-main); } 
	.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: 66px; } 
	.sub-content-tit h3 {font-size: 4.5rem; padding-bottom: 8rem;}
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 62px;} 

	.sub-content-tab ul {width: 100%; justify-content: center;}
	.sub-content-tab li a {padding: 1rem; font-size: 16px;}
}
@media (max-width: 576px) {
	.sub-content-tit h3 {font-size: 28px;}

	.sub-content-tab {z-index: 1;}
	.sub-tab-line {display: none;}
	.sub-content-tab li {flex-grow: 1;}
	.sub-content-tab li a {min-width: 1px;}
}
@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 =============================================== */