@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: #e60612;
	--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-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-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 'Montserrat', 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;} }
@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; justify-content: end; align-items: center; position: absolute; inset: 0 0 auto; z-index: 1100; height: var(--header-height); padding: 0 var(--outer-padding); transition: .3s, padding 0s; } 
.header-inner::before {display: none; 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-image: linear-gradient(to left, transparent, transparent); } 
.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 { width: 20rem; transition: left .5s;} 
:is(.is-hover, .is-fix, .is-menu) #header-logo-white { opacity: 1; 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) #header-logo { opacity: 1; } 
.is-menu .header-logo {left: calc(var(--allmenu-img-width) + var(--allmenu-gap)); opacity: 0; visibility: hidden;}

.header-logo .logo-txt {font-size:1.6rem; font-weight: 700; color:#fff; white-space: nowrap; margin-top:0.4rem; display: block; letter-spacing: 0.025em;}



/* GNB */
.gnb { transition: opacity .3s; flex-grow: 1; display: flex; justify-content: center; --gnb-padding :3.5rem; letter-spacing: 0;} 
.gnb-wrap { display: flex;} 
.depth1 { position: relative; } 
.depth1 > a { padding:0 var(--gnb-padding); line-height: var(--header-height); font-size:1.8rem; font-weight: 800;}
.depth1 > a span { letter-spacing: normal; color: #fff; white-space: nowrap;} 
.depth1 > a::before,
.depth1 > a::after {content:''; display: block; position: absolute; bottom:0; left:0; background-color: var(--color-main); transition:all 0.3s ease-in-out;}
.depth1 > a::before {width:5px; height:5px; border-radius: 50%; bottom:-1px;left:calc(var(--gnb-padding) - 1rem); opacity: 0;}
.depth1 > a::after {width:0; height:2px; left:var(--gnb-padding);}

.depth2 { display: none; position: absolute; top: var(--header-height); left:0; min-width: 100%; padding: 2rem 0 1rem; } 
.depth2 a {padding: 0.5rem 1rem 0.5rem var(--gnb-padding); font-size:1.6rem;}
.depth2 span { white-space: nowrap;  color:#fff;}

.depth3 {padding: 0.5em 0;} 
.depth3 a { padding: 0.5rem 1rem 0.5rem var(--gnb-padding); font-size:1.4rem; font-weight: 300; position: relative; display: flex; gap:0.5rem; align-items: center;}
.depth3 a::before {content:''; display: block; width:4px; height:1px; background-color: #fff;}
.depth3 span { color:#fff;}



.is-menu .gnb { visibility: hidden; opacity: 0; } 
:where(.is-hover, .is-fix) .depth1 > a span { color: #fff; } 

.depth1:hover > a span { color: var(--color-main); } 
.depth1:hover > a::before {opacity: 1;}
.depth1:hover > a::after{width:calc(100% - 2 * var(--gnb-padding) + 1rem); transition-delay: 0.2s;}

.depth2 a:hover span {text-decoration: underline; text-underline-offset: 0.3em;} 






/* 유틸 */
.header-util { display: flex; align-items: center; column-gap: 2rem; margin-left:auto;} 

/* 언어선택 버튼 */
.util-lang { position: relative; font-size:13px; } 
.util-lang-list { display: flex; } 
.util-lang-list li {position: relative;}
.util-lang-list li + li::before {content:''; display: block; width:1px; height:9px; background-color: var(--color-white-a2); position: absolute; left:0; top:50%; transform: translate(0, -50%);}


.util-lang-list a { padding: 1rem 1.5rem; } 
.util-lang-list a span { background: linear-gradient(to top, #fff, #fff) no-repeat center bottom/0 2px; transition: all .3s; color:#fff; font-weight: 700; padding:0.5rem 0; }
.util-lang-list li.on a span { font-weight: 700; background-size: 100% 2px;} 
.util-lang-list li:not(.on) a:hover span { background: linear-gradient(to top, var(--color-main), var(--color-main)) no-repeat center bottom/100% 2px; color: var(--color-main); } 

:is(.is-hover, .is-fix, .is-menu) .util-lang-btn { background-image: url(../images/common/ico_lang_on.svg); } 

@media (max-width: 480px) {
	.header-util {column-gap: 1rem;} 

	.util-lang-list li.on {display: none;}
	.util-lang-list li.on:first-child + li::before {display: none;}
}


/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 4rem; height: 4rem; } 
.util-allmenu-btn span { position: absolute; top: 50%; left: 50%; width: 100%; height: 2px; background-color: #fff; transition: .3s; } 
.util-allmenu-btn span:nth-child(1) { transform: translate(-50%, calc(-50% - 5px));}
.util-allmenu-btn span:nth-child(2) { transform: translate(-50%, calc(-50% + 5px));}
.util-allmenu-btn:hover span:nth-child(1) { transform: translate(-50%, calc(-50% - 10px));}
.util-allmenu-btn:hover span:nth-child(2) { transform: translate(-50%, calc(-50% + 10px));}

:is(.is-hover, .is-fix, .is-menu) .util-allmenu-btn span { background-color: #fff; } 
.is-menu .util-allmenu-btn span { width: 4.8rem;} 
.is-menu .util-allmenu-btn span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); } 
.is-menu .util-allmenu-btn span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg);} 

.is-menu .util-allmenu-btn:hover span:nth-child(1) { transform: translate(-50%, -50%) rotate(-45deg);}
.is-menu .util-allmenu-btn:hover span:nth-child(2) { transform: translate(-50%, -50%) rotate(45deg);}




/* 전체메뉴 */
.allmenu { display: flex; visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; padding-right: var(--scroll-width); background: #231916; transform: translateX(-20%); transition: .5s, padding-right 0s, width 0s;z-index: 1001; } 
.allmenu::before {  content: ''; display: block; width:100%; height:calc(100% - var(--header-height) - 12rem); left:0; top:calc(var(--header-height) + 12rem); position: absolute; background: url(../images/common/allmenu_bg01.jpg) no-repeat center/cover; z-index: -1;}
.allmenu::after {content:''; display: block; width:100%; height:calc(100% - var(--header-height)); position: absolute; bottom:0; right:0; background: url('../images/common/allmenu_bg_logo.png') no-repeat center 101%; background-size: 72% auto; opacity: 0; z-index: 1; transition: all 0.7s ease .5s; background-blend-mode:luminosity;}

.allmenu-wrap {flex-grow: 1; padding-left: var(--allmenu-gap);/*  height: 100%; 옆 배경 없을 때 scroll생성 */}
.allmenu-cont { visibility: hidden; overflow: hidden auto; opacity: 0; height: 100%; transition: .3s;} 
.allmenu-cont::-webkit-scrollbar { width: 6px; } 
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); } 
.allmenu-list {display: flex; margin: 0 var(--inner-padding); justify-content: center; position: relative; z-index: 2; height: 100%;}

.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateX(0);} 
.is-menu .allmenu::after {opacity: 1;}
.is-menu .allmenu-cont { visibility: visible; opacity: 1; transition: .6s ease-out .2s; } 

.all-depth1 {padding: var(--header-height) 3rem; flex:1 1 20%; position: relative;}
.all-depth1::before {content:''; display: block; width:1px; height:0%; background-color: var(--color-main); position: absolute; top:0; left:0; transition: all 0.5s ease-in-out;}


.all-depth1-btn {display: flex; height:12rem; align-items: center; text-align: center;  cursor: default; font-size:3.6rem; font-weight: 800; color:#fff; width:100%;transition: all 0.3s ease-in-out;} 






@media (hover: hover) and (pointer: fine) {
	.all-depth1:hover {z-index: 1;}
	.all-depth1:hover::before {height: 100%;}
	.all-depth1:hover .all-depth1-btn {color:var(--color-main); z-index: 1;}
}


.all-depth2 {padding-top:3rem;} 
.all-depth2-btn { padding: 0.6em 0em; font-size:1.8rem; font-weight:600; line-height: 1.25; color: #222; text-decoration: underline; text-decoration-color: transparent; text-decoration-thickness: 2px; text-underline-offset: 0.25em; transition: all .2s, text-decoration-color .1s;} 


@media (hover: hover) and (pointer: fine) {
	.all-depth1:hover .all-depth2-btn:hover {color:var(--color-main); text-decoration-color: currentColor;}
}


.all-depth3 {padding-bottom: 0.5em;}
.all-depth3:not(:has(li)) {display: none;}
.all-depth3 a {display: flex; padding: 0.25em 0 0.25em 2rem; font-size: 1.5rem; color: #222; transition: all 0.3s ease-in-out; font-weight: 500; position: relative;}
.all-depth3 a::before {content: ''; display: block; width:4px; height:2px; background-color: #222; position: absolute; top:1.1rem; left:1rem;}
@media (hover: hover) and (pointer: fine) {
	.all-depth3 a:hover {color:var(--color-main);}
	.all-depth3 a:hover::before {background-color: var(--color-main);}
}

/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 1000; background-color: var(--color-black-a8); transition: opacity .3s; pointer-events: none; } 
:is(.is-hover):not(.is-menu) .gnb-dim { opacity: 1; } 

@media (hover: hover) and (pointer: fine) {

}
@media (max-width: 1280px) { }
@media (max-width: 1024px) {

	.is-menu .header-inner {background-color: #231916;}
	.is-menu .header-logo {left: calc(var(--allmenu-img-width) + var(--allmenu-gap)); opacity: 1; visibility: visible;}
	.gnb { display: none; } 

	
	.allmenu::before {height:100%;top:0;}

	.allmenu-wrap {padding-top:var(--header-height); padding-bottom:11rem;}

	.allmenu-cont::-webkit-scrollbar { width: 0; } 
	.allmenu-list { display: block; }
	.all-depth1 { padding: 0;} 
	.all-depth1::before {display: none;}
	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 1.8rem 2rem; margin: 0; border-bottom: 1px solid var(--color-main); cursor: pointer; height: auto; color:#231916; font-size:2.4rem; } 
	.all-depth1-btn::after { flex-shrink: 0; width: 18px; height: 10px; background-image: url(../images/common/chevron_w18.svg); content: ''; transition: .3s; } 
	.all-depth1-btn.on { color: var(--color-main); } 
	.all-depth1-btn.on::after { transform: rotate(180deg); } 
	.all-depth2 { display: none; padding: 0.8em 0; background-color: var(--color-black-a1);} 
	.all-depth2-btn { padding: 1rem 2rem; font-size: 2rem;} 



	.all-depth3 a {padding: 1rem 2rem 1rem 4rem; font-size: 1.8rem;}
	.all-depth3 a::before {top:1.8rem; left:3rem;}
	
}
@media (max-width: 768px) {
	.allmenu::after {background-position: 50% 100%;}
}
@media (max-width: 576px) { 
	.header {--allmenu-img-width: 0px;}
	.allmenu { transform: none; } 
	.is-menu .allmenu { transform: none;} 
} 
@media (max-width: 480px) { 
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 8.5rem 0 0; background-color: #fff;}
.body-sub .footer {border-top:1px solid #f3f3f3;}
.footer-wrap {display: flex; flex-direction: column; align-items: center;}
.footer-logo {max-width: 35%;}

.footer-contact { display: flex; align-items: center; justify-content:center ; flex-wrap: wrap; gap: 4rem; margin-top: 7rem; position: relative;  background-color: #f4f4f4; width: 100%; height: 7rem;} 
.footer-contact .item { display: flex; font-size:1.5rem; font-weight: 700; color:#2f2f2f; align-items: center;}
.footer-contact .item dt {color:#6e6e6e;}
.footer-contact .item dt::after { margin: 0 5px 0 2px; content: '.'; } 


.footer-copy {margin-top:4rem; font-size:1.4rem; color:#7d7d7d; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase;}


.footer-menu { display: flex; align-items: center; margin-top: 4rem;}
.footer-menu .item { display: flex; height:5rem; position: relative;}
.footer-menu .item a {display: flex; padding: 0 3rem; height:100%;  align-items: center; transition: all 0.3s ease-in-out; border:1px solid #231916; border-bottom:0; font-size: 1.6rem; color:#231916; font-weight: 800;}
.footer-menu .item + .item a {margin-left:-1px;}
.footer-menu .item:first-of-type a {border-radius:1rem 0 0 0;}
.footer-menu .item:last-of-type a {border-radius:0 1rem 0 0;}
.footer-menu .item:hover {z-index: 2;}
.footer-menu .item a:hover {background-color: var(--color-main); color:#fff; border-color: var(--color-main);}




/* 탑버튼 */
.top-btn { display: flex; width: 7rem; height: 7rem;  background-color: var(--color-main); position: absolute; top:50%; right:0; transform: translate(0, -50%); transition: all 0.3s ease-in-out;}
.top-btn::before { width: 2.2rem; height: 3rem; margin: auto; background: url('../images/common/ico_top.svg') no-repeat center/contain; content: ''; }
@keyframes top-btn {
	33% { transform: translateY(2px); } 
	66% { transform: translateY(-4px); } 
}

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover {background-color: #2f2f2f;}
	.top-btn:hover::before { animation: top-btn 1.5s infinite linear; }
}



@media (max-width: 1280px) {
	.footer { padding: 8rem 0 0;}
	.footer-contact {row-gap: 0; margin-top: 6rem; height: 7rem; padding:1rem 8rem;}
	.footer-contact .item {align-items: center; justify-content: center; }

} 
@media (max-width: 1024px) {
	.footer { padding: 6rem 0 0;}

	.footer-contact {margin-top: 5rem;} 
	.footer-contact .item.addr {width:100%;}
	.footer-copy {margin-top:3rem; font-size:1.5rem; letter-spacing: 0.05em;}
	.footer-menu { margin-top: 3rem;}
}
@media (max-width: 768px) { 
	.footer { padding: 5rem 0 0;}

	.footer-contact {margin-top: 4rem; height: auto; row-gap: 1rem; padding:2rem 8rem;} 
	.footer-contact .item {width:100%; justify-content: flex-start;}
	.footer-copy {letter-spacing: 0em;}
	
} 
@media (max-width: 480px) {
	.footer-logo{max-width: 50%;}
	.footer-contact {margin-top: 4rem; height: auto; row-gap: 1rem; padding:2rem 8rem 2rem var(--inner-padding);} 
	.footer-copy {padding:0 var(--inner-padding); text-align: center;}
}

/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 5.6rem;}
/* SUV-VISUAL */
.sub-visual {position: relative; height: calc(40rem + 100px); 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.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: ''; display: none;} 

.sub-visual .sub-visual-bg span {background-image: url('../images/common/sub_visual01.jpg');}
.sub-visual.nth-1 .sub-visual-bg span {background-image: url('../images/common/sub_visual01.jpg');}
.sub-visual.nth-2 .sub-visual-bg span {background-image: url('../images/common/sub_visual02.jpg');}
.sub-visual.nth-3 .sub-visual-bg span {background-image: url('../images/common/sub_visual03.jpg');}
.sub-visual.nth-4 .sub-visual-bg span {background-image: url('../images/common/sub_visual04.jpg');}
.sub-visual.nth-5 .sub-visual-bg span {background-image: url('../images/common/sub_visual05.jpg');}
.sub-visual.nth-6 .sub-visual-bg span {background-image: url('../images/common/sub_visual06.jpg');}
.sub-visual.nth-7 .sub-visual-bg span {background-image: url('../images/common/sub_visual07.jpg');}


.sub-visual-txt { display: flex; flex-direction: column; justify-content: center; height: 100%; height: 100%; padding: 100px 0 var(--sub-tab-height); text-align: center; color: #fff;} 
.sub-visual-tit { margin-bottom: 1rem; font-weight: 700; font-size: 2rem; letter-spacing: 0; color:var(--color-main); text-decoration: underline;  text-underline-offset: 0.3em; text-transform: uppercase;}
.sub-visual-stit {font-weight: 800; font-size: 5.5rem; letter-spacing: -0.025em; }

@media (max-width: 768px) { 
	.sub-visual-stit {font-weight: 700; font-size: 4.2rem;}
}


/* SUB-TAB */
.sub-tab { position: relative; z-index: 50; height: var(--sub-tab-height); margin: calc(-1 * var(--sub-tab-height) - 3rem) var(--inner-padding) 0; text-align: center;}
.sub-tab-wrap {display: inline-flex; align-items: center; justify-content: center; height:var(--sub-tab-height); position: relative; z-index: 1;background-color: var(--color-black-a5); border-radius: 3rem; padding:0 2rem;}
.sub-tab-wrap::before,
.sub-tab-wrap::after {content:''; display: block; height:100%; width:8rem; position: absolute; top:50%; background-image: linear-gradient(to left, transparent, rgba(60, 255, 106, 0.5)); border-radius: 3rem;}
.sub-tab-wrap::before {background-image: linear-gradient(to right, transparent 30%, rgba(60, 191, 195, 0.5)); left:0; transform: translate(calc(-100% + 1rem), -50%);}
.sub-tab-wrap::after {background-image: linear-gradient(to right, rgba(60, 255, 106, 0.5), transparent 70%); left:0; transform: translate(0%, -50%);}

.sub-tab-home {display: flex; width:3.6rem; height:3.6rem; font-size:0; background: url('../images/common/ico_home.svg') 50% 50% no-repeat; border-radius: 3rem; position: relative; z-index: 1; transition: all 0.3s ease-in-out;}
.sub-tab-home:hover {background-color:var(--color-black-a6);}
.sub-tab-btn { display: none; position: relative; z-index: 5; width: 100%; height: 100%; background-color: transparent;} 
.sub-tab-list { width: 100%; }

.sub-tab-list ul { display: flex; overflow-x: auto; height:3rem; column-gap: 1rem; } 
.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 { flex: 1; } 
.sub-tab-list li a { display: flex; justify-content: center; align-items: center; height: 100%; padding: 0 2rem; background-color:transparent; text-align: center;  white-space: nowrap; color:#fff; font-size:1.6rem; font-weight: 600; border-radius: 2rem; transition: all 0.3s ease-in-out;} 
.sub-tab-list li.on a { background-color: #fff; font-weight: 800; color: #222; } 
@media (max-width: 768px) { 
	.sub-tab-wrap {width:100%;}
	.sub-tab-btn { display: block; padding: 0 15px 0 1rem; color:#fff;} 
	.sub-tab-btn::before { position: absolute; top: 50%; right: 0; 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-a2); background-color: #fff;border-radius: 2rem; overflow: hidden;} 
	.sub-tab-list ul { flex-direction: column; height: auto; } 
	.sub-tab-list li a { padding: 1.5rem 1rem; color:#222; font-size:2rem; }
	.sub-tab-list li.on a { background-color: var(--color-main); font-weight: 600; border-radius: 0; color: #fff; } 
}






/* SUB-CONTENT */
.sub-content {padding-top:9rem;}
.sub-content-tit h3 { padding: 6rem 0; font-weight: 700; font-size: 4rem; 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;  padding: 1px; margin: 0 auto;}
.sub-content-tab li {outline: 1px solid var(--color-main); flex:1 1;}
.sub-content-tab li.on {z-index: 5; outline-color: var(--color-main);}
.sub-content-tab li a { padding: 1.5rem 1rem; font-size: 1.8rem; transition: .3s;font-weight:700; color:#222; display: flex; width:100%; text-align: center; justify-content: center; height: 100%; align-items: center;}
.sub-content-tab li.on a { background-color: var(--color-main); 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: 5.6rem; }
	.sub-visual-txt {padding: var(--header-height) 0 var(--sub-tab-height);} 
}
@media (max-width: 768px) {
	.body-sub { --sub-tab-height: 5.6rem; }
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-height: 5.6rem; }
	.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 =============================================== */



.newBoard [data-aos] {
	opacity: 1 !important;
	transform: none !important;
	transition: none !important;
}


