@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: #03408c;
	--color-sub: #fff;
	--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-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), 50px);
	--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;
	--font-base: 'Paperlogy', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-sebang: 'SEBANG Gothic', 'Paperlogy', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;

	--clip-path-1 : polygon(80% 0, 100% 0, 100% 100%, 0 100%);
}
html::-webkit-scrollbar {width: 8px; background-color: #eee;}
html::-webkit-scrollbar-thumb {background-color: #444;}
body {--header-height: 100px; font: 16px/1.2 var(--font-base); 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: 70px; }
}
@media (max-width: 768px) {
	:root {font-size: 8px;}
	body {--header-height: 60px; }
}
@media (max-width: 480px) {
	:root {font-size: 7px;}
	body {--header-height: 54px;}
}
@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: space-between; position: fixed; inset: 0 0 auto; z-index: 1100;
	height: var(--header-height); padding: 0 calc(var(--outer-padding)); transition: .3s, padding 0s; gap:3rem; }
.header-inner::before { position: absolute; inset: 0;  content: ''; transition:all 0.3s ease-in-out; background-color: transparent;
	border-bottom:1px solid rgba(231, 231, 231, 0.0);}
.is-open .header-inner,
.is-menu .header-inner { background-color: transparent; }

:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .header-inner {background-color: #fff;}
:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .header-inner::before { border-color:rgba(231, 231, 231, 1);}
.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:16.2rem; transition: all .3s; left:0; flex-shrink: 0;}
/* .header-logo img {object-fit: contain;} */
#header-logo {display: none;}
:is(.is-hover, .is-fix, .is-hover-header) #header-logo-white { display: none; }
:is(.is-hover, .is-fix, .is-hover-header) #header-logo { display: block; }
.is-menu .header-logo {left: calc(var(--allmenu-img-width) + var(--allmenu-gap)); opacity: 0;}

@media (max-width: 1024px) {
	/* .is-open .header-inner,
	.is-menu .header-inner { padding-right:calc(  var(--scroll-width) + var(--outer-padding)); background-color: #fff; } */
	/* .is-menu .header-logo {opacity: 1;} */

}



/* GNB */
.gnb { transition: opacity .3s; flex-grow: 1; --gnb-padding : 4rem; --widthDep:180px; --heightDep: 100px;}
.gnb::before { position: absolute;inset: var(--header-height) 0 auto; height: var(--gnb-height);background-color: #fff; content: '';
	transform: scaleY(0); transform-origin: top;transition: .3s; z-index: -1; border-radius: 1rem;}
.gnb .gnb-wrap { display: flex; justify-content: center;  align-items: center; }

.gnb .depth1 { position: relative; transition: all 0.5s; flex-grow:0; z-index: 2; }
.gnb .depth1 > a { padding: 0 var(--gnb-padding);  text-align: center; position: relative; z-index: 2; transition: all 1s ease-in-out; display: flex; height: var(--header-height); align-items: center; justify-content: center;}
.gnb .depth1 > a span,
.gnb .direct > a span { color: #fff; font-size:1.7rem; font-weight: 500; transition: all 0.3s ease-in-out; display: inline-block; line-height: 1.2; }
/* .gnb .depth1 > a::before {content: ''; position: absolute; bottom: 0; left:50%; width: 0; height:4px; background-color: var(--color-sub); transform: translate(-50%, 2px); visibility: hidden; opacity: 0;  transition: all 0.3s ease-in-out;} */

:where(.is-hover, .is-fix, .is-hover-header) .gnb .depth1 > a span { color: #222; }

.gnb .direct {margin-left: 2rem;z-index: 1}
.gnb .direct > a {padding:3px 15px;background: var(--color-main);}

.gnb .depth1:hover > a span { color:var(--color-sub);}
/* .gnb .depth1:hover > a::before {opacity: 1; visibility: visible; width:calc(100% - var(--gnb-padding) * 2); } */

.gnb .depth2 {--paddingLR: 5.5rem; position: absolute; top:0; left:50%; width:var(--widthDep); transform: translateX(-50%) translateY(-100%);
	line-height: 1.3; z-index: 1;}
.gnb .depth2::before {content: "";position: absolute;top:0;left:0;width:100%;height:var(--header-height);background: var(--color-main);}
.gnb .depth2::after {content: "";position: absolute;top:calc(var(--header-height) - 1px);left:0;width:0;height:0;border-right:var(--widthDep) solid var(--color-main);border-bottom: var(--heightDep) solid transparent;}
.gnb .depth2 ul {margin-top: calc(var(--header-height) + var(--heightDep) + 8px);opacity: 0;display: flex; justify-content: center; flex-direction:column;position: relative;
	background-color: #fff;transition: 0.5s;gap:0.3rem;padding:2rem 0 5rem;transform: translateY(-10px);}
.gnb .depth2 ul::before {content: "";position: absolute;top:calc(var(--heightDep) * -1);left:0;width:0;height: 0;border-left:calc(var(--widthDep) + 1px) solid #fff;
	border-top: var(--heightDep) solid transparent;transform: translateY(1px);transition-delay: 1s;}
.gnb .depth2 a { padding: 0.8rem var(--paddingLR);  transition: all 0.3s ease-in-out; font-weight: 500; font-size:1.5rem}
.gnb .depth2 a span { white-space: nowrap; color:#222; position: relative;}
.gnb .depth2 a span::before {content: "";position: absolute;left:0;top:100%;width:0;height: 1px;background: var(--color-main);transition: width 0.3s;}


.is-menu .gnb { visibility: hidden; opacity: 0; }
.is-hover .gnb::before {transform: scaleY(1);}
.is-hover .gnb .depth1 {transition: all 1s ease-in-out;}
.is-hover .gnb .depth2 {transition: transform 0.3s ease-in-out;}

/* .is-hover .gnb .depth1:hover {z-index: 4;} */
.is-hover .gnb .depth1:hover .depth2 {transform: translateX(-50%) translateY(0);}
.is-hover .gnb .depth1:hover .depth2 ul {opacity: 1; transition-delay: 0.1s; transform: translateY(0);}
.is-hover .gnb .depth1:hover .depth2 ul::before {transform: translateY(0);}
/* .is-hover .gnb .depth1:hover .depth2 span {color:#222;} */
.is-hover .gnb .depth1:hover .depth2 a:hover span{ color:var(--color-main); font-weight: 700;}
.is-hover .gnb .depth1:hover .depth2 a:hover span::before {width: 100%;}



@media (max-width: 1600px) {

}

@media (max-width: 1440px) {
	.gnb { --gnb-padding : 2.5rem; --widthDep: 150px;}
	.gnb .depth2 {--paddingLR: 4rem;}
}

@media (max-width: 1280px) {
	.gnb { --gnb-padding : 2rem; --widthDep: 130px;}
	.gnb .depth2 {--paddingLR: 3.5rem;}

}

@media (max-width: 1024px) {
	.gnb{display: none;}

}

@media (max-width: 768px) {


}







/* 유틸 */
.header-util { display: flex; column-gap: 5rem;align-items: center; transition: all 0.3s ease-in-out; position: relative;z-index: 10; }

@media (max-width: 1440px) {
	.header-util{column-gap: 2rem;}
}



/* 언어선택 버튼 */
.util-lang-btn {display: none;}

.util-lang-list {--lang-border-color: rgba(255, 255, 255, 0.5); --lang-color:#fff; display: flex;align-items: center;justify-content: center;
	box-sizing: border-box; border: 1px solid var(--lang-border-color); transition: all 0.5s ease-in-out;}
.util-lang-list li a {font-size:max(1.2rem, 11px); font-weight: 800;color:var(--lang-color);position: relative;padding:0.4rem 1.5rem; letter-spacing: 0.1em; transition: all 0.5s ease-in-out;}
.util-lang-list li:not(:first-child) a::before {content:"";position: absolute;left:-1px;top:50%;width: 1px;height: 50%;
	transform: translateY(-55%);background: var(--lang-border-color);}

:is(.is-hover, .is-fix, .is-hover-header) .util-lang-list {--lang-border-color:rgba(0,0,0,0.5); --lang-color:#222}
:is(.is-hover, .is-fix, .is-hover-header) .util-lang-list li a {font-weight: 800;}
.is-menu .util-lang {display: none;}


.util-lang-list:hover {border-color:var(--color-main);}
.util-lang-list li a:hover {background-color: var(--color-main); color:#fff;}

@media (max-width: 768px) {
	.util-lang-list li a {padding:0.4rem 1.2rem;}
}







/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 2.2rem; height:2.2rem; transition:all 0.5s ease-in-out; font-size:0; text-indent: -9999px; }
.util-allmenu-btn span {display: block;  width: 0.6rem; height: 0.6rem; background-color: #fff; position: absolute;  transition: all 0.3s ease-in-out;}
.util-allmenu-btn span::before,
.util-allmenu-btn span::after {content:''; display: block; width:100%; height:100%; position: absolute; background-color: #fff; transition: all 0.3s ease-in-out; top:0;}
.util-allmenu-btn span::before {left:0; transform:translate(-0.8rem, 0);}
.util-allmenu-btn span::after {right:0; transform:translate(0.8rem, 0);}


.util-allmenu-btn span:nth-child(1) {top:0; left:50%; transform: translate(-50%, 0%);}
.util-allmenu-btn span:nth-child(2) {top:50%; left:50%; transform: translate(-50%, -50%);}
.util-allmenu-btn span:nth-child(3) {bottom:0%; left:50%; transform: translate(-50%, 0%);}



:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn {transition-duration: 0.3s;}
:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn span,
:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn span::before,
:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn span::after{background-color: #222;}


.is-menu .util-allmenu-btn {width:5rem; height:5rem;}

.is-menu .util-allmenu-btn span:nth-child(1),
.is-menu .util-allmenu-btn span:nth-child(3) {opacity: 0; width:0;}

.is-menu .util-allmenu-btn span:nth-child(2) { width: 5rem; height:2px;  background-color:rgba(255, 255, 255, 0);  left:50%; top:50%; transform: translate(-50%, -50%);}
.is-menu .util-allmenu-btn span:nth-child(2)::before,
.is-menu .util-allmenu-btn span:nth-child(2)::after { background-color:rgba(255, 255, 255, 1); left:50%; top:50%;}
.is-menu .util-allmenu-btn span:nth-child(2)::before { transform: translate(-50%, -50%) rotate(45deg); }
.is-menu .util-allmenu-btn span:nth-child(2)::after { transform: translate(-50%, -50%) rotate(-45deg);}




/*:is(.is-hover, .is-fix, .is-menu) .util-allmenu-btn span:not(:nth-child(4)) { background-color: #fff; } */

@media (max-width: 1024px) {
	.is-menu .util-allmenu-btn { width: 4rem; height: 4rem;}
	.is-menu .util-allmenu-btn span:nth-child(2) {width:4rem; height:2px;}
}


@media (hover: hover) and (pointer: fine) {
	/*
	.util-allmenu-btn:hover span{ width:3rem; height: 2px; background-color:rgba(255, 255, 255, 0);}
	.util-allmenu-btn:hover span::before { left:50%; top:50%; width:100%; transform: translate(-50%, calc(0px - 100% - 6px));}
	.util-allmenu-btn:hover span::after { left:50%; top:50%; transform: translate(-50%, calc(100% + 6px));}
	*/
	:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn:hover {height:3.2rem; transition-duration: 0.2s;}
	:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn:hover span,
	:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn:hover span::before,
	:is(.is-hover, .is-fix, .is-hover-header) .util-allmenu-btn:hover span::after{background-color: var(--color-main);}

	.is-menu .util-allmenu-btn:hover span:nth-child(2) { width: 5rem; height:2px;  background-color:rgba(255, 255, 255, 0); transform:  translate(-50%, -50%) rotate(360deg); transition: 1s;}
	.is-menu .util-allmenu-btn:hover span:nth-child(2)::before {background-color: #fff; transform: translate(-50%, -50%) rotate(45deg); }
	.is-menu .util-allmenu-btn:hover span:nth-child(2)::after {background-color: #fff; transform: translate(-50%, -50%) rotate(-45deg);}
}


/* 전체메뉴 */
.allmenu {--allmenu-padding:4rem; display: flex; visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; padding-right: var(--scroll-width); background-blend-mode: normal; transform: translateY(-100%); transition: .5s, padding-right 0s, width 0s; z-index: 1001; background:transparent; overflow: hidden;}

.allmenu-wrap {flex-grow: 1; padding-left: var(--allmenu-gap); height:100%;}
.allmenu-cont { visibility: hidden; overflow: hidden auto; opacity: 0; height: 100%;  transition: .5s;}
.allmenu-cont::-webkit-scrollbar { width: 6px; }
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); }
.allmenu-list { display: flex; height: 100%; margin:0 var(--inner-padding); border-right:1px solid var(--color-white-a1);}



.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateY(0);}
.is-menu .allmenu::before {opacity: 0.05;transition: all 0.5s ease-in-out 0.5s;}
.is-menu .allmenu-cont { visibility: visible; opacity: 1; transition: .5s ease-out .3s; }



.all-depth1 {padding: calc(var(--header-height) + 4rem) 0 2rem 0 ; flex:1; position: relative; border-left:1px solid var(--color-white-a1);}

.all-depth1-btn { padding:3rem var(--allmenu-padding); margin-bottom: 2rem;  cursor: default; font-size:2.8rem; font-weight: 700; color:#fff; position: relative; width:100%;transition: all 0.3s ease-in-out; text-align: left;}
.all-depth1.direct .all-depth1-btn{cursor: pointer;}



.all-depth2 { font-size: max(1.7rem, 15px);}
.all-depth2-btn { padding: 1rem 1rem 1rem var(--allmenu-padding); font-weight: 600; color: #fff; position: relative; display: block; transition: all 0.3s ease-in-out;}
.all-depth2-btn::before {content: ''; display: block; width:0%; height:100%; background-color: var(--color-main); position: absolute; top:0; left:0; z-index: -1; transition: all 0.3s ease-in-out;}
.all-depth2-btn::after {content: ''; display: block; width:2rem; height:100%; background-color: var(--color-main); position: absolute; top:0; right:100%; z-index: -1; transition: all 0.3s ease-in-out; clip-path: polygon(0 0, 100% 100%, 0 100%); opacity: 0;}


@media (hover: hover) and (pointer: fine) {
	.all-depth1:hover {border-color:var(--color-main);}
	.all-depth1:hover .all-depth1-btn {color:#1c64bd;}
	.all-depth1.direct:hover .all-depth1-btn:hover {text-decoration: underline;}

	.all-depth1:hover .all-depth2-btn {color:#fff;}
	.all-depth1:hover .all-depth2-btn:hover {color:#fff; text-decoration-color: currentColor;}
	.all-depth1:hover .all-depth2-btn:hover::before {width: calc(100% - 2rem);}
	.all-depth1:hover .all-depth2-btn:hover::after {opacity: 1; right:0;}
}




/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 1000; transition: opacity .3s; pointer-events: none; -webkit-backdrop-filter: blur(8px);backdrop-filter: blur(8px); background-color: var(--color-black-a6);}
:is(.is-hover, .is-menu) .gnb-dim { opacity: 1; }
.is-menu .gnb-dim {background-color: var(--color-black-a8);}

/*
@media (hover: hover) and (pointer: fine) {
.is-menu .util-allmenu-btn:hover span { width: 18px; }
}
*/


@media (max-width: 1440px) {
	.allmenu {--allmenu-padding:2rem;}
	.all-depth1-btn { font-size:3rem;}

}


@media (max-width: 1024px) {
	.allmenu-wrap {padding-bottom:4rem;}
	.allmenu-cont::-webkit-scrollbar { width: 0;}
	.allmenu-list { display: block;  margin-top:calc(var(--header-height)); height:auto; border-top:1px solid var(--color-white-a2); border-right: 0;}
	.all-depth1 { padding: 0; border-left:0; transition:background-color 0.5s ease-in-out}
	.all-depth1::before {display: none;}

	.all-depth1.is-actvie {background-color: var(--color-main);}

	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 1.5rem max(3%, 12px); margin: 0; border-bottom: 1px solid var(--color-white-a2); cursor: pointer;  transition:all 0.3s ease-in-out; font-size:max(2.4rem, 18px)}

	.all-depth1-btn::after { flex-shrink: 0; width: 18px; height: 10px; background:#fff;  content: ''; transition: .3s; mask: url('../images/common/chevron_w18.svg') no-repeat right top/contain; -webkit-mask: url('../images/common/chevron_w18.svg') no-repeat right top/contain;}
	.all-depth1.direct .all-depth1-btn::after{ transform: rotate(-90deg);}


	.all-depth1-btn.on {background-color: var(--color-white-a2); color:var(--color-sub);}

	.all-depth1-btn.on::after { transform: rotate(180deg); background-color: var(--color-sub);}


	.all-depth2 { display: none; padding: 0.8em 0; background-color: var(--color-black-a1); }
	.all-depth2-btn { padding: 0.5em max(4%, 16px); color:var(--color-sub); }
	.all-depth2-btn::after {display: none;}


	.all-depth3 ul {display: flex; flex-wrap: wrap; background-color: var(--color-sub); margin:0 max(4%, 16px); padding:1rem; border-radius: 1rem;}
	.all-depth3 ul li {flex:1 1 50%;}
	.all-depth3 a {color:var(--color-white-a5); padding:0.4em 10px; font-size: 1.8rem; width: 100%;}
	.all-depth3 a::before {background-color: var(--color-white-a5);}
}


@media (hover: hover) and (pointer: fine) and (max-width: 1024px) {
	.all-depth1:hover .all-depth1-btn {color:var(--color-main);}
	.all-depth1.is-actvie:hover .all-depth1-btn {color:var(--color-sub);}

	.all-depth1:hover .all-depth2-btn {color:var(--color-sub);}
	.all-depth1:hover .all-depth2-btn:hover {color:var(--color-main); text-decoration-color: currentColor;}
	.all-depth1:hover .all-depth2-btn:hover::before {display: none;}

	.all-depth1:hover .all-depth3 a {color:var(--color-white-a5);}
	.all-depth1:hover .all-depth3 a::before {background-color: var(--color-white-a5);}
}




@media (max-width: 576px) {
	.allmenu { transform: none; }
	.is-menu .allmenu { transform: none;}
	.body-main .header-util {height:auto;}

	.all-depth3 ul li {flex:1 1 100%;}
}
@media (max-width: 480px) {
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 13rem 0 4rem; background: url('../images/common/footer_bg.png') no-repeat center bottom / cover; position: relative; z-index: 1;}
.footer-wrap {display: flex; justify-content: flex-end;}
.footer-box {display: flex; flex-direction: column; align-items: center; font-size:max(1.5rem, 13px); color: #fff; font-weight: 600; letter-spacing: 0.1em; max-width: 40rem;}

.footer-logo {max-width: 40%;}
.footer-contact { display: flex; flex-wrap: wrap; gap:1rem;}
.footer-contact .item { display: flex; width:100%;}
.footer-contact .item { display: flex; align-items: flex-start; gap:0.5rem;}
.footer-contact .item dt {flex-shrink: 0; width:4rem; position: relative; font-weight: 700; white-space: nowrap;}
.footer-contact .item dd {flex-grow: 1;}
.footer-contact a {transition: 0.3s;}
.footer-contact a:hover {color:#7cb7d9;}


.footer-contact.nth-1 {margin-top:4rem; border:solid rgba(255, 255, 255, 0.15); border-width: 1px 0; width:100%; text-align: center; padding:1rem 0; justify-content: center; font-size:max(1.6rem, 14px);}
.footer-contact.nth-1 .item {justify-content: center;}
.footer-contact.nth-1 .item.addr { width: 100%; }
.footer-contact.nth-1 .item.addr strong {color:#7cb7d9;}


.footer-inwrap {display: flex; padding:5rem 0; justify-content: space-between; gap:2rem;}


.footer-link {display: flex; gap:1rem; flex-shrink: 0;}
.footer-link .item {flex:1; width:7rem;}
.footer-link .item a {display: block; width:100%; height:100%; display: flex; align-items: center; justify-content: center; background-color: #fff; border-radius:1rem; font-size:0; transition: all 0.5s ease-in-out;}
.footer-link .item a span {width:1.8rem; height:1.8rem;  background-color: #000; mask: url('../images/common/ico_home.svg') no-repeat right top/contain; -webkit-mask: url('../images/common/ico_home.svg') no-repeat right top/contain; text-indent: -999999px; overflow: hidden; transition: background-color 0.5s ease-in-out;}

.footer-link .item:nth-child(2) a span {width:2.2rem; height:2.2rem; background-color: #c80000; mask-image: url('../images/common/ico_youtube.svg'); -webkit-mask-image: url('../images/common/ico_youtube.svg');}


.footer-menu { display: flex; column-gap:1px;  letter-spacing: 0em; width:100%;}
.footer-menu .item {height:4.5rem; flex:1;}
.footer-menu .item a { padding: 1rem; display: flex; align-items: center; justify-content: center; text-align: center; height:100%; background-color:#000; transition: 0.3s;}


.footer-copy {margin-top:3rem; font-size:max(1.3rem, 11px); text-transform: uppercase; letter-spacing: 0.2em; text-align: center;}

@media (hover: hover) and (pointer: fine) {
	.footer-link .item a:hover {background-color: var(--color-main);}
	.footer-link .item a:hover span {background-color: #fff;}
	.footer-menu .item a:hover {background-color: var(--color-main);}
}


@media (max-width: 768px) {
	.footer-wrap {justify-content: center;}
	.footer-box {max-width: 100%;}
	.footer-copy {letter-spacing: 0.1em;}
}



/* 탑버튼 */
.top-btn { display: flex; width:11.2rem; height: 11.6rem; position:absolute; top:0; right:var(--inner-padding); transform: translate(50%, -50%);}
.top-btn::before {content:''; display: block; width:90%; height:90%; border-radius: 50%;  position:absolute; top:50%; left:50%; transform: translate(-50%, -50%); filter: blur(3rem); background: rgba(0, 0, 0, 0.25); mix-blend-mode: multiply;}
.top-btn::after {content:''; display: block; width:100%; height:100%;  background-color: #000; mask: url('../images/common/ico_top_bg.svg') no-repeat right top/contain; -webkit-mask: url('../images/common/ico_top_bg.svg') no-repeat right top/contain; position:absolute; top:0; left:0; z-index:1; transition: background-color 0.5s ease-in-out;}

.top-btn span {display: flex; position: relative; z-index: 2; width:100%; height:100%; font-size: 0; align-items: center; justify-content: center;}
.top-btn span::before { content: ''; display: block; width: 1.4rem; height: 2.6rem; 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::after {background-color:var(--color-main);}
	.top-btn:hover span::before { animation: top-btn 1.5s infinite linear; }
}
@media (max-width: 1520px) {
	.top-btn {right:0; transform: translate(0%, -50%);}
}
@media (max-width: 1024px) { }
@media (max-width: 768px) { }
@media (max-width: 480px) { }
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 70px; --sub-tab-padding:6rem;}
/* SUV-VISUAL */
.sub-visual {position: relative; height: 48rem; }
.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 {position: relative; display: flex; flex-direction: column; justify-content: center; align-items: flex-end; height: 100%; padding-right:var(--sub-tab-padding); color:#fff; text-align: right;}
.sub-visual-tit { margin-bottom: 1rem; font-weight: 700; font-size: 5rem; letter-spacing: 0.02em; }
.sub-visual-slogan {font-size:max(1.5rem, 13px); font-weight: 600; opacity: 0.5;}



@media (max-width: 768px) {
	.sub-visual.nth-1 .sub-visual-bg::after {display: block; background-color: var(--color-black-a4);}

	.sub-visual-txt {padding-right:0; align-items: center; text-align: center;}
	.sub-visual-slogan { opacity: 0.6;}
}


/*Sub Navigation Bar*/
.snb {position: absolute; bottom:0; left:var(--inner-padding); z-index: 2; width:calc(100% - var(--inner-padding) * 2); border-bottom:1px solid #e9e9e9; padding-right:calc(var(--sub-tab-padding) * 2 - 1px);}

.snb::before,
.snb::after {content:''; display: block; width:var(--sub-tab-padding); height:calc(100% + 0px); background-color:var(--color-main); clip-path: var(--clip-path-1); position: absolute; ; transform: rotateY(180deg);}
.snb::before {width:calc(var(--sub-tab-padding) * 2); clip-path: polygon(40% 0, 100% 0, 100% 100%, 0 100%); right:0; top:0;}
.snb::after {background-color: #fff;  right:var(--sub-tab-padding); top:0;}


.snb-wrap {display: flex; width: 100%;  position: relative;}
.snb-wrap::before {content:''; display: block; width:calc(100% - var(--sub-tab-height) + 2px); height:100%; background-color: #fff; position: absolute; top:0; left:calc(var(--sub-tab-height) - 1px);}


.snb-home {display: flex; width:var(--sub-tab-height); height:var(--sub-tab-height); align-items: center; justify-content: flex-end; padding-right:1.5rem; position: relative; z-index: 1; transition: all 0.3s ease-in-out; flex-shrink: 0; font-size:0; text-indent: -99999px;}
.snb-home span { display: block; position: relative; height:1.8rem; width:1.8rem;  background-color: var(--color-main); mask: url('../images/common/ico_home.svg') no-repeat right top/contain; -webkit-mask: url('../images/common/ico_home.svg') no-repeat right top/contain; transition: all 0.3s ease-in-out; }
.snb-home:hover span {background-color: var(--color-main);}

.snb-home::before {content:''; display: block; width:100%; height:calc(var(--sub-tab-height) + 2.5rem); background-color:#fff; clip-path: var(--clip-path-1); position: absolute; left:0; bottom:0;}
.snb-home::after { position: absolute; top: 50%; left: 100%; width: 13px; height: 8px; background-color: #222; mask-image: url(../images/common/chevron_w13.svg); -webkit-mask-image: url(../images/common/chevron_w13.svg); content: ''; transform: translate(-50%, -50%) rotate(-90deg); transition: .3s;}


.snb-dep {position: relative; height: var(--sub-tab-height); max-width:calc(50% - var(--sub-tab-height) / 2); z-index: 1;}


.snb-btn { display: block; font-size:max(1.7rem, 14px); font-weight: 700; color:#222; padding:0 4rem 0 2rem; min-width:17rem; height: 100%;   text-align: left; transition: all 0.5s ease-in-out; max-width:100%; overflow:hidden; white-space:nowrap; text-overflow:ellipsis;}

.snb-btn::before { position: absolute; top: 50%; right: 1rem; width: 13px; height: 8px; background-color: #222; mask-image: url(../images/common/chevron_w13.svg); -webkit-mask-image: url(../images/common/chevron_w13.svg); content: ''; transform: translateY(-50%) rotate(-90deg); transition: .3s;}

.snb-2dep .snb-btn::before { transform: translateY(-50%) rotate(0deg);}

.snb-btn:hover {opacity: 1;}

.snb-btn.is-active {color:var(--color-main);}
.snb-btn.is-active::before {background-color:var(--color-main); transform: translateY(-50%) rotate(180deg); }


.snb-list { display: none; position: absolute; top: 100%; left: 0; height: auto; box-shadow: 0 0 4rem var(--color-black-a2); background-color: #fff;border-radius:1.5rem; overflow: hidden; width:100%; padding:2rem 0 ; z-index: -1;}





.snb-list ul {  height: auto; padding:0 2rem;}
.snb-list li a { display: block; padding: 0.7rem 0rem; color:#666; font-size:max(1.7rem, 14px); font-weight: 500; transition: all 0.3s ease-in-out;}
.snb-list li.on a {  font-weight: 700; border-radius: 0; color:var(--color-main)}



.snb-list li a span{display: inline; padding:0.2rem 0.5rem;}
.snb-list li.on a span{background: linear-gradient(to bottom, transparent 60%, rgba(0, 123, 195, 0.3) 60%);display: inline;}

.snb-list li a:hover {color:var(--color-main);}




@media screen and (min-width:1025px){
	.snb-dep.snb-2dep {max-width: none; flex-grow: 1;}
	.snb-dep.snb-2dep .snb-list {position: static; height:100%;  box-shadow: none; background-color: transparent; border-radius: 0; overflow: visible; max-width: 100%; padding:0}
	.snb-dep.snb-2dep .snb-list ul {display: flex; height:100%; padding:0; }
	.snb-dep.snb-2dep .snb-list ul li a {display: flex; align-items: center; height: 100%; padding:0 2rem; font-weight: 600; position: relative; color:#666; border:none; transition: all 0.5s ease-in-out;}
	.snb-dep.snb-2dep .snb-list ul li.on a{color:var(--color-main);}

	.snb-dep.snb-2dep .snb-list ul li a::after{content:''; display: block; position: absolute; transition: all 0.3s ease-in-out;}
	.snb-dep.snb-2dep .snb-list ul li a::after {width:0; height:0.5rem; bottom:-1px; left:50%; background-color: var(--color-main); transform: translate(-50%, 0);}
	.snb-dep.snb-2dep .snb-list ul li span {position: relative; background:none;}

	.snb-dep.snb-2dep .snb-list ul li a:hover {color:var(--color-main);}
	.snb-dep.snb-2dep .snb-list ul li.on a::after,
	.snb-dep.snb-2dep .snb-list ul li a:hover::after {width:calc(100% - 4rem);}
}


@media (max-width: 1440px) {

}


@media (max-width: 1280px) {
	.body-sub { --sub-tab-height: 6.5rem; --sub-tab-padding:5rem;}
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 6rem; --sub-tab-padding:4rem;}

	.snb{left:0; z-index: 2; width:100%;}
	.snb-home {padding-right:1rem;}
	.snb-home::after {display: none;}
	.snb-dep {flex-grow: 1; flex:1;  max-width:calc(100% - var(--sub-tab-height));}
	.snb-dep.snb-1dep {display: none;}

	.snb-btn::before {right:0;}
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-padding:3rem;}
	.snb { letter-spacing: -0.05em;}

}









/* SUB-TAB */
.sub-tab { position: relative;  z-index: 50; height: var(--sub-tab-height); margin: calc(-1 * var(--sub-tab-height)) var(--inner-padding) 0; display: flex; border-bottom:1px solid #e9e9e9; padding-right:calc(var(--sub-tab-padding) * 2);}
.sub-tab::before,
.sub-tab::after {content:''; display: block; width:var(--sub-tab-padding); height:calc(100% + 0px); background-color:var(--color-main); clip-path: var(--clip-path-1); position: absolute; ; transform: rotateY(180deg);}
.sub-tab::before {width:12rem; clip-path: polygon(40% 0, 100% 0, 100% 100%, 0 100%); right:0; top:0;}
.sub-tab::after {background-color: #fff;  right:var(--sub-tab-padding); top:0;}


.sub-tab-home {display: flex; width:8rem; height:100%; align-items: center; justify-content: flex-end; padding-right:2rem; position: relative; z-index: 1; transition: all 0.3s ease-in-out; flex-shrink: 0; font-size:0; text-indent: -99999px;}
.sub-tab-home span { display: block; position: relative; height:1.8rem; width:1.8rem;  background-color: var(--color-main); mask: url('../images/common/ico_home.svg') no-repeat right top/contain; -webkit-mask: url('../images/common/ico_home.svg') no-repeat right top/contain; transition: all 0.3s ease-in-out; }
.sub-tab-home:hover span {background-color: var(--color-main);}

.sub-tab-home::before {content:''; display: block; width:100%; height:10rem; background-color:#fff; clip-path: var(--clip-path-1); position: absolute; left:0; bottom:0;}




.sub-tab-btn { display: none; position: relative; z-index: 5; width: 100%;  background-color: #fff; }
.sub-tab-list { width: 100%; background-color: #fff; }
.sub-tab-list ul { display: flex; height: calc(var(--sub-tab-height) - 1px); }


.sub-tab-list li a { display: flex; justify-content: center; align-items: center; height: 100%; padding: 0 1em;  text-align: center;  }
.sub-tab-list li.on a { font-weight: 900; color: #222; }
@media (max-width: 1024px) { /* type2 안 쓸 땐 아래 미디어쿼리에 통합 */
	.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; }
	.sub-tab-list li a { padding: 1.2em 1em; }
}


/* SUB-CONTENT */

.sub-content {padding:10rem 0 0 0;}



.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; 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 { 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) {

}
@media (max-width: 768px) {

}
@media (max-width: 480px) {

	.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 =============================================== */
