@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+KR:100,300,400,500,700,900');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");


/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #0c4da2;
	--color-sub: #00acff;
	--color-sub1: #06263d;
	--color-white-a05: rgba(255, 255, 255, 0.05);
	--color-white-a1: rgba(255, 255, 255, 0.1);
	--color-white-a2: rgba(255, 255, 255, 0.2);
	--color-white-a3: rgba(255, 255, 255, 0.3);
	--color-white-a4: rgba(255, 255, 255, 0.4);
	--color-white-a5: rgba(255, 255, 255, 0.5);
	--color-white-a6: rgba(255, 255, 255, 0.6);
	--color-white-a8: rgba(255, 255, 255, 0.8);
	--color-white-a9: rgba(255, 255, 255, 0.9);
	--color-black-a05: rgba(0, 0, 0, 0.05);
	--color-black-a1: rgba(0, 0, 0, 0.1);
	--color-black-a2: rgba(0, 0, 0, 0.2);
	--color-black-a3: rgba(0, 0, 0, 0.35);
	--color-black-a4: rgba(0, 0, 0, 0.4);
	--color-black-a5: rgba(0, 0, 0, 0.5);
	--color-black-a6: rgba(0, 0, 0, 0.6);
	--color-black-a7: rgba(0, 0, 0, 0.7);
	--color-black-a8: rgba(0, 0, 0, 0.8);
	--color-black-a9: rgba(0, 0, 0, 0.9);
	--scroll-width: 0px;
	--inner-width: calc(100vw - var(--scroll-width));
	--inner-padding: max(20px, calc(((var(--inner-width)) - 1400px) / 2));
	--outer-padding: min(var(--inner-padding), 45px);

	--font-base: 'Paperlogy', 'Pretendard', 'Roboto', 'Noto Sans KR', 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-noto: 'Noto Sans KR', 'Roboto','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: 120px; font: 16px/1.2 var(--font-base); color: #666; background-color: #fff;}

html, body, main {
  width: 100%;
  max-width: 100%;
}
::selection {background: var(--color-main); color: #fff;}


body:where(.is-fix) {--header-height: 100px;}
.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: 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 var(--outer-padding); transition: .3s, padding 0s; gap:2rem; background-color: rgba(255, 255, 255, 0); transition: all 0.5s ease-in-out;} 
.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 { padding-right:calc(var(--outer-padding) + var(--scroll-width)); background-color: rgba(255, 255, 255, 0);  }
:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .header-inner {background-color:  rgba(255, 255, 255, 1);}

: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:12.2rem; transition: all .3s; flex-shrink: 0;}
body:where(.is-fix) .header-logo {width:10rem;}
:is(.is-hover, .is-fix, .is-menu, .is-hover-header) #header-logo-white { opacity: 0; transition: opacity .5s;} 
.header-logo #header-logo { opacity: 0; position: absolute; inset: 0; object-fit: contain; transition: opacity .5s;} 
:is(.is-hover, .is-fix, .is-menu, .is-hover-header) #header-logo { opacity: 1; } 
.is-menu .header-logo {left: calc(var(--allmenu-img-width) + var(--allmenu-gap)); visibility: hidden; opacity: 0;}





@media (max-width: 1280px) {
	.header-inner {gap:1rem;}
	.header-logo { width:10rem;}
	body:where(.is-fix) .header-logo {width:9rem;}
}
@media (max-width: 1024px) {
}
@media (max-width: 768px) {
	.header-logo,
	body:where(.is-fix) .header-logo {width:9rem;}
}

@media (max-width: 480px) {
}



@media (hover: hover) and (pointer: fine) {
	
}


/* GNB */
.gnb { transition: opacity .3s; flex-grow: 1; --gnb-padding : 2.5rem; --gnb-gap :0rem;} 
.gnb::before { position: absolute; inset:var(--header-height) 0 0; height: var(--gnb-2dep-h); content: '';transform: scaleY(0); transform-origin: top;transition: .3s; z-index: -1; border-radius: 2rem; background: #fff; opacity: 0; display: none; }



.gnb-wrap { display: flex; transition: 0.5s;  justify-content: center;}

.depth1 { position: relative; transition: all 0.5s; z-index: 1;}
.is-hover .depth1 { transition: all 1s ease-in-out;}

.depth1 > a { padding: 0 var(--gnb-padding); margin:0 var(--gnb-gap); position: relative; z-index: 2; transition: all 0.3s ease-in-out; display: flex; height: var(--header-height); align-items: center;}

.depth1 > a::before {content:''; display: block; width:2.4rem; height:2.4rem; background:url('../images/common/ico_gnb01.png') no-repeat center / contain; position: absolute; top:var(--header-height); left:100%; opacity: 0; transform: translate(0, calc(0px - 50% - 1px)); transition: all 0.3s ease-in-out;}
.depth1 > a::after {content:''; display: block; width:0; height:1px; background-color: var(--color-white-a3); position: absolute; top:var(--header-height); right:calc(0px - var(--gnb-gap)); transform: translate(0%, 0); transition: all 0.3s ease-in-out;}

.depth1 > a span { font-size:1.7rem; color: #fff; font-weight: 700;  letter-spacing: 0.025em; transition: all 0.3s ease-in-out; display: inline-block; line-height: 1.2; position: relative;  border-radius: 0.7rem; background-color: transparent;}





.depth2 {display: none; min-width:max(100%, 0rem); position: absolute; top:0; left:50%; transform: translate(-50%, 0);}

.depth2 > ul {z-index: 2; padding:calc(var(--header-height) + 3rem) 0 2rem 0 ;  background-color: var(--color-main); position: relative;}

.depth2 a { display: block; padding:0.7rem 2rem; transition: all 0.3s ease-in-out;  position: relative;}
.depth2 a span {font-size:1.6rem; font-weight: 700; color:#fff; transition: all 0.3s ease-in-out; position: relative; background: linear-gradient(to top, #fff, #fff) no-repeat left bottom / 0 1px; display: inline; line-height: 1.3; padding:0 0 0.2rem;}
.depth2 a em {font-size:1.5rem; color:#74d1ff;}
.depth2 a em::before {content:''; display: block;}


.depth3 {padding-bottom:2rem; max-height:50rem; transition: all 0.5s ease-in-out 0.5s;}
.depth3 a { display: block; padding:0.3rem 2rem; transition: all 0.3s ease-in-out;  position: relative;}
.depth3 a span {font-size:1.4rem; font-weight: 500; color:#1ba2e5; transition: all 0.3s ease-in-out; position: relative; background: linear-gradient(to top, #1ba2e5, #1ba2e5) no-repeat left bottom / 0 1px; display: inline; line-height: 1.3; padding:0 0 0.2rem;}






.is-menu .gnb { visibility: hidden; opacity: 0;}
.is-hover .gnb {--gnb-gap:2rem;}
.is-hover .gnb::before {transform: scaleY(1); opacity: 1;}

:where(.is-hover, .is-fix, .is-hover-header) .depth1 > a span { color: #222; }


.depth1:hover {z-index: 2;}
:is(.is-hover, .is-hover-header) .depth1:hover a::before {left:0; opacity: 1; transition-delay: 0.3s;}
:is(.is-hover, .is-hover-header) .depth1:hover a::after {width:calc(100% + var(--gnb-gap)); transition-delay: 0.3s;}
:is(.is-hover, .is-hover-header) .depth1:hover > a span { color: #fff;}

:is(.is-hover) .depth2 a:hover::before {opacity: 1; left:2rem;}
:is(.is-hover) .depth2 a:hover span {background-size: 100% 1px;}

.is-max-h .depth3 {max-height:0; opacity: 0; overflow: hidden; padding:0; transition-duration: 0.3s; transition-delay: 0s;}






@media (max-width: 1440px) {
	
}

@media (max-width: 1280px) {
	
}
@media (max-width: 1200px) {
	.gnb {--gnb-padding : 2.5rem;}
	.is-hover .gnb {--gnb-gap:0.8rem;}
}

@media (max-width: 1024px) {
	.gnb{display: none;}
	
}

@media (max-width: 768px) {
	
}






/* 유틸 */
.header-util { display: flex; align-items: center; gap:3.5rem; position: relative; flex-shrink: 0; transition: 0.5s ease-in-out;}
:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .header-util{padding-bottom:0;}
@media (max-width: 1280px) {
	.header-util {gap:2rem;}
}

/* 언어선택 버튼 */
.util-lang { position: relative; flex-grow:1;}
.util-lang-btn {display: flex; align-items:center; position: relative; font-size:0; transition: all .3s; }
.util-lang-btn::after {content:''; display: block; flex-shrink: 0; width:2.4rem; height:2.4rem; background-color: #fff; mask: url('../images/common/ico_lang.svg') no-repeat center / contain; -webkit-mask: url('../images/common/ico_lang.svg') no-repeat center / contain; transition: all .3s;}

:where(.is-hover, .is-fix, .is-hover-header) .util-lang-btn::after{background-color: #000;}

.is-menu .util-lang-btn{ visibility: hidden; opacity: 0;}

/*.util-lang.is-active .util-lang-btn {background-color: var(--color-main);} */
@media (hover: hover) and (pointer: fine) {
	.util-lang-btn:hover {color: var(--color-main);}
	.util-lang-btn:hover::after {background-color: var(--color-main);}
}
@media (max-width: 1024px) {
	.util-lang-btn::after{width:22px; height:22px;}
}



.util-lang-list { display: none; position: absolute; top: calc(100% + 2px); left: 50%; transform: translate(-50%, 0); padding: 1rem 0; background-color: var(--color-white-a9); box-shadow: 0 0 1.5rem var(--color-black-a2); text-align:center; border-radius: 1rem;} 
.util-lang-list a { padding: 0.6rem 1.5rem; } 
.util-lang-list a span { background: linear-gradient(to top, var(--color-main), var(--color-main)) no-repeat center bottom/0 1px; transition: all .3s; color: var(--color-black-a8);font-weight: 700; font-size:max(1.5rem, 13px);} 
.util-lang-list li.on a span { color: var(--color-main); } 
.util-lang-list li:not(.on) a:hover span { background-size: 100% 1px; color: var(--color-main); }
/*:is(.is-hover, .is-fix, .is-menu) .util-lang-btn { background-image: url(../images/common/ico_lang_on.svg); }*/



/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 24px; height: 24px; transition:all 0.5s ease-in-out;  font-size: 0; text-indent: -99999px;}
.util-allmenu-btn span {display: block; width:100%;  height: 2px;  background-color:#fff; transition: all 0.5s ease-in-out; position: relative;}
.util-allmenu-btn span::before{content:''; display: block; transition: all 0.5s ease-in-out; position: absolute; background-color: #fff;}


.util-allmenu-btn span:nth-child(1),
.util-allmenu-btn span:nth-child(3) {width:calc(100% - 5px);}
.util-allmenu-btn span:nth-child(1)::before {width:2px; height:2px; top:0; right:-5px;}

.util-allmenu-btn span:nth-child(2) {margin:5px 0;}

.util-allmenu-btn span:nth-child(3) {margin-left:5px;}
.util-allmenu-btn span:nth-child(3)::before {width:2px; height:2px; top:0; left:-5px;}



: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{ background-color: #000; } 

/*:is(.is-hover, .is-fix, .is-menu) .util-allmenu-btn span:not(:nth-child(4)) { background-color: #fff; } */


.is-menu .util-allmenu-btn {width:5rem; height:5rem;}
.is-menu .util-allmenu-btn span {background-color: #fff; width:5rem; transition-duration: 0s;}
.is-menu .util-allmenu-btn span::before{width:0;}

.is-menu .util-allmenu-btn span:nth-child(2) {background-color: transparent;}
.is-menu .util-allmenu-btn span:nth-child(1),
.is-menu .util-allmenu-btn span:nth-child(3) {position: absolute; top:50%; left:50%; margin:0;}
.is-menu .util-allmenu-btn span:nth-child(1) {transform: translate(-50%, -50%) rotate(45deg);}
.is-menu .util-allmenu-btn span:nth-child(3) {transform: translate(-50%, -50%) rotate(-45deg);}



@media (hover: hover) and (pointer: fine) {
	.util-allmenu-btn:hover span { background-color: var(--color-main);} 
	.util-allmenu-btn:hover span::before {background-color: var(--color-main);}

	.util-allmenu-btn:hover span:nth-child(1),
	.util-allmenu-btn:hover span:nth-child(3) {width:100%;}
	.util-allmenu-btn:hover span:nth-child(1)::before {width:0px; right:0;}

	.util-allmenu-btn:hover span:nth-child(2) {margin:0.8rem 0; width:0;}

	.util-allmenu-btn:hover span:nth-child(3) {margin-left:0;}
	.util-allmenu-btn:hover span:nth-child(3)::before {width:0; left:0;}


	.is-menu .util-allmenu-btn:hover {transform: rotate(360deg); transition-duration: 1s;}
	.is-menu .util-allmenu-btn:hover span {background-color: #fff;}
	.is-menu .util-allmenu-btn:hover span:nth-child(2) {background-color: transparent;}
}



@media (max-width: 1024px) {
	.util-allmenu-btn { width: 24px; height: 24px;}
	:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .util-allmenu-btn span,
	:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .util-allmenu-btn span::before,
	:is(.is-hover, .is-fix, .is-hover-header):not(.is-menu) .util-allmenu-btn span::after{ background-color: var(--color-sub); } 
}





/* 전체메뉴 */
.allmenu { display: flex; visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; padding-right: var(--scroll-width); background-blend-mode: normal; transform: translateY(-100%); transition: .5s, padding-right 0s, width 0s; z-index: 1001; background:#042b8a url('../images/common/allmenu_bg01.png') no-repeat center bottom / cover; overflow: hidden;} 

.allmenu::before {content: ''; display: block; width: 20%; max-width: 38.1rem; height:100%; background:url('../images/common/allmenu_bg02.png') no-repeat center 90% / contain; position: absolute; bottom:0; right:calc(var(--inner-padding) + 3%); z-index: -1; opacity: 0; transition: all 0.1s ease-in-out; }

.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; min-height: 100%; margin:0 var(--inner-padding); border-right: 1px solid rgba(255, 255, 255, 0.1);} 



.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateY(0);} 
.is-menu .allmenu::before {opacity: 1;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) + 2rem) 0 2rem 0 ; flex:1; position: relative; border-left: 1px solid rgba(255, 255, 255, 0.1);}
.all-depth1::before {content: ''; display: block; position: absolute; inset:0; width: 0%; background-color: #fff; transition: width 0.3s ease-in-out; z-index: -1;}


.all-depth1-btn { padding:0 3rem; margin-bottom: 3rem;  font-size:2.3rem; font-weight: 700; color:#fff; position: relative; width:100%;transition: all 0.3s ease-in-out; text-align: left;} 

.all-depth1-btn span {position: relative;}
.all-depth1-btn span::before {content:''; display: block; width:2.4rem; height:2.4rem; background-color:var(--color-main); mask: url('../images/common/ico_gnb01.png') no-repeat center / contain; -webkit-mask: url('../images/common/ico_gnb01.png') no-repeat center / contain; position: absolute; top:-2rem; right:100%; transform: translate(50%, 0); opacity: 0; transition: all 0.5s ease-in-out; }



.all-depth2 { font-size: max(1.5rem, 14px);} 
.all-depth2-btn { padding: 1rem 3rem; font-weight: 600; color: #fff; position: relative; display: block; transition: all 0.3s ease-in-out;}

.all-depth2-btn::after {content: ''; display: block; width:0%; height:100%; background-color: var(--color-main); position: absolute; top:0; left:2rem; z-index: -1; transition: all 0.3s ease-in-out;}



.all-depth3 {padding-bottom: 2.5rem;}
.all-depth3:not(:has(li)) {display: none;}
.all-depth3-btn {display: flex; padding: 0.65rem 0 0.65rem 3rem; font-size: max(1.4rem, 13px); font-weight: 600; color: var(--color-white-a6); transition: all 0.3s ease-in-out;}
.all-depth3-btn::before { margin:0.4em 0.5rem 0 0; content: ''; display: block; width:3px; height: 3px; background-color: var(--color-white-a6); border-radius: 50%; transition: all 0.3s ease-in-out;}

.all-depth3-btn span { background: linear-gradient(to top, var(--color-main), var(--color-main)) no-repeat left bottom / 0 1px; display: inline;  transition: all 0.3s ease-in-out;}






@media (hover: hover) and (pointer: fine) {
	.all-depth1:hover::before {width: 100%;}
	.all-depth1:hover::after {opacity: 1; transition-delay: 0.3s;}
	.all-depth1:hover .all-depth1-btn {color:var(--color-main);}
	.all-depth1:hover .all-depth1-btn span::before {right:0; opacity: 1; transform: translate(100%, 0) rotate(360deg);}
	.all-depth1:hover .all-depth2-btn {color:#222;}
	.all-depth1:hover .all-depth2-btn:hover {color:#fff; text-decoration-color: currentColor;}
	.all-depth1:hover .all-depth2-btn:hover::after {width: calc(100% - 4rem);}
	
	.all-depth1:hover .all-depth3-btn {color:#666;}
	.all-depth1:hover .all-depth3-btn::before {background-color: #666;}
	.all-depth1:hover .all-depth3-btn:hover span {background-size:100% 1px; color:var(--color-main);}
	.all-depth1:hover .all-depth3-btn:hover::before {background-color: var(--color-main);}

}

/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 1000; background-color: var(--color-black-a6); transition: opacity .3s; pointer-events: none; -webkit-backdrop-filter: blur(8px);backdrop-filter: blur(8px); background-color: var(--color-black-a7);} 
:is(.is-hover, .is-menu) .gnb-dim { opacity: 1; } 




@media (max-width: 1280px) {
	.all-depth1-btn {padding:0 2rem;}
	.all-depth2-btn { padding: 1rem 2rem;}
	.all-depth3-btn {display: flex; padding: 0.65rem 1rem 0.65rem 2rem;}
}

@media (max-width: 1024px) {
	
	.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-a3); border-right:0; padding-bottom:3rem;}
	.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: #fff;}
	
	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 1.8rem max(3%, 12px) 1.2rem; margin: 0; border-bottom: 1px solid var(--color-white-a3); cursor: pointer;  transition:all 0.3s ease-in-out; font-size:max(2.2rem, 17px)}
	
	.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-btn.on {background-color:var(--color-white-a1); color:var(--color-main);}
	.all-depth1-btn.on::after { transform: rotate(180deg); background-color: var(--color-main);}

	.all-depth1-btn span::before {width:1.8rem; height:1.8rem; top:-1rem;}
	.all-depth1-btn.on span::before {opacity: 1; right:0; transform: translate(100%, 0) rotate(360deg); transition-delay: 0.3s;}


	.all-depth2 { display: none; padding: 0.8em 0; background-color: var(--color-black-a2); } 
	.all-depth2-btn { padding: 0.5em max(4%, 16px); color: #222; font-size:max(1.8rem, 15px); } 
	.all-depth2-btn::after {display: none;}


	.all-depth3 ul {display: flex; flex-wrap: wrap; background-color: var(--color-black-a8); 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-a8); padding:0.4em 1rem; font-size:max(1.6rem, 14px); width: 100%;}
	.all-depth3 a::before {background-color: var(--color-white-a8); margin-top:0.5em; }
}


@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) { 
	.is-menu .allmenu { transform: none;} 
	.body-main .header-util {height:auto;}


	.all-depth1-btn::after {width: 16px; height: 8px;}

	.all-depth3 ul li {flex:1 1 100%;}

} 
@media (max-width: 480px) { 
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer {position: relative; border-top:1px solid #e1e1e1; padding-top:9rem;}
.footer-wrap {padding:0; overflow: hidden; display: flex; padding:0 var(--inner-padding); justify-content: space-between; gap:10rem;}

.footer-row {position: relative; display: flex;}
.footer-row.nth-1 {padding:0;  justify-content: space-between; gap:10rem; padding-bottom:9rem; }


.footer-logo {flex-shrink: 0;}


.footer-contact .item { display: flex; align-items: flex-start; width:100%; gap:1rem 2rem; font-size:max(1.6rem, 13px);}
.footer-contact .item + .item {margin-top:1rem;}
.footer-contact .item dt {flex-shrink: 0; color:var(--color-main); font-weight: 700; position: relative; padding-right:2rem; min-width: 12rem;}
.footer-contact .item dt::after {content:''; display: block; width:0.4rem; height:0.4rem; background-color: var(--color-main); border-radius: 50%; position: absolute; right:0; top:0.9rem;}
.footer-contact .item dd {color:#171717; font-weight: 500;}
.footer-contact a {transition: 0.3s;}
.footer-contact a:hover {color:var(--color-main);}


.footer-menu { display: flex; flex-direction: column;}
.footer-menu .item {flex:1;}
.footer-menu .item + .item {margin-top:-1px;}
.footer-menu .item a { padding: 2rem 2rem; font-size: max(1.4rem, 11px); color:#171717; font-weight: 700; display: flex; align-items: center; justify-content: center; text-align: center; background-color: transparent; transition: 0.3s; border:1px solid #2f2f2f; height:100%;}
.footer-menu .item a:hover {color:#fff; background-color: var(--color-main); border-color: var(--color-main);}


.footer-row.nth-2 {padding:0; align-items: center; gap:1rem 5rem;}
.footer-row.nth-2::before {content:''; display: block; width:200%; height:1px; background-color: #e1e1e1; position: absolute; top:0; left:0%;}



.footer-copy {font-size:max(1.4rem, 11px); color:#5c5c5c; padding:4rem 0; text-transform: uppercase; text-align: justify; line-height: 1.2;  width: 100%; transform:translateY(0.8rem);}
.footer-copy.mo {display: none; text-align: center;}
.footer-copy::after {content: '';display: inline-block; width: 100%;}
.footer-copy.mo::after {display: none;}

.footer-copy strong {font-weight: 700;}






.footer-slogan {position: relative; padding-top:9rem; background: url('../images/common/footer_bg01.png') no-repeat center / cover; overflow: hidden;}
.footer-slogan .item { font-size:12.5rem; color:var(--color-main); font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; line-height:1; transform: translate(0, 10%);}
.footer-slogan .item::before {content: attr(data-mtext) attr(data-mtext); display: inline-block; white-space: pre; animation: c_marquee 40s linear infinite;}
/*.mvod-slogan .item:hover::before {-webkit-animation-play-state: paused; animation-play-state: paused;}*/
@keyframes c_marquee {
	0% {transform: translate(0%, 0);}
	100% {transform: translate(-50%, 0);}
}



@media (max-width: 1440px) {
	
}

@media (max-width: 1280px) {
	.footer-wrap {gap:5rem;}
	.footer-row.nth-1 {gap:5rem;}
}

@media (max-width: 1024px) {
	.footer-wrap {flex-wrap: wrap; justify-content: center;}
	.footer-cols {width:100%;}
	.footer-logo {width: 100%; text-align: center;}
	.footer-logo img {display: inline-block; max-width: 20%;}


	.footer-row.nth-2::before {left:-50%;}


	.footer-slogan { padding-top:6rem;}
}

@media (max-width: 768px) {
	.footer-row {flex-wrap: wrap;}
	.footer-row.nth-1 {padding:5rem 0;}
	.footer-row.nth-1::before {content:''; display: block; width:200%; height:1px; background-color: #e1e1e1; position: absolute; top:0; left:-50%;}

	.footer-logo {width: 100%; text-align: center;}
	.footer-logo img {display: inline-block; max-width: 25%;}

	.footer-menu {width: 100%;}
	.footer-copy {display: none;}
	.footer-copy.mo {display: block;}

	.footer-slogan { padding-top:5rem;}
	.footer-slogan .item { font-size:10rem;letter-spacing: 0.15em;}
}


@media (max-width: 640px) {
	.footer-logo img {max-width: 30%;}
	.footer-contact {width: 100%;}
	
}

@media (max-width: 480px) {
	.footer-logo img {max-width: 40%;}
	.footer-contact .item { flex-wrap: wrap; row-gap: 0.6rem;}
	.footer-contact .item + .item {margin-top:2rem;}
	.footer-contact .item dt { padding-right:0rem; min-width: auto; width:100%;}
	.footer-contact .item dt::after {display: none;}


	
}




/* 탑버튼 */
.top-btn{ display: block;  width:6.8rem; height:6.8rem; position: absolute;  transition: all 0.3s ease-in-out; top:8rem; right:var(--outer-padding); z-index: 1; font-size: 0; overflow: hidden; text-indent: -99999px; background-color: #69c6b9; border-radius: 50%;}


.top-btn span{ display: block; width:100%; height:100%; background: url('../images/common/ico_top_bg.png') no-repeat center / contain;  z-index: 1;}


.top-btn::after {content: ''; display: block; width:1.5rem; height:2.1rem; background: url('../images/common/ico_top.png') no-repeat center top/contain; bottom:2.6rem; left:50%; transform:translate(-50%, 0); position: absolute;}


@keyframes top-btn {
	33% { transform: translate(-50%, 3px); } 
	66% { transform: translate(-50%, -6px); } 
}

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover {background-color: var(--color-main);}
	.top-btn:hover::after { animation: top-btn 1.5s infinite linear;}
}


@media (max-width: 1540px) {
}

@media (max-width: 768px) {
	.top-btn {top:3rem; right:1rem;}

}
@media (max-width: 480px) {

}


.copy-target {cursor: pointer;}
.copy-target:hover {color: var(--color-main);}

/* FOOTER ============================================== */
/* ===================================================== */






/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-visual-height:45rem; --snb-height : 6rem;}
main {position: relative;}

@media (max-width: 1024px) { 
	.body-sub {--sub-visual-height:38rem; }
}




/*Quick*/
.quick {position: fixed; transition: all 0.5s ease-in-out; z-index: 5;}
.body-sub .quick { right:0; bottom:calc(100% - var(--sub-visual-height));}
.body-sub.is-fix .quick {bottom:0; transform: translateY(0); }
.body-sub.is-fix .quick.is-hold {position: absolute; bottom:0;}



.quick-wrap {opacity: 0; background-color: #191919; box-shadow: 0 0 4rem var(--color-black-a3); padding:2rem;}
.quick-wrap.aos-animate {animation: fade-down 0.5s linear 1s both;}






.quick-wrap .item {position: relative; margin-top:0.8rem;}
.quick-wrap .item:first-child {margin:0;}

.quick-wrap .item .link {text-align: center; font-size:0; overflow: hidden; line-height: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap:0.8rem;  transition: all 0.5s ease-in-out;}

.quick-wrap .item.nth-4 .link { font-weight: 600; font-size:max(0.9rem, 9px); color:#fff; text-transform: uppercase; transition: all 0.5s ease-in-out; position: relative;}




.quick-wrap .item .link::before {content:''; display: block; width:4.5rem; height:4.5rem;transition: all 0.5s ease-in-out; background-color: transparent;}

/*
.quick-wrap .item.nth-1 .link::before {background-color: #feed0c;}
.quick-wrap .item.nth-2 .link::before {background-color: #000 ;background-color: #03ce5f;}
.quick-wrap .item.nth-3 .link::before {background-color: #be2520;}
*/


.quick-wrap .item .link::after {content:''; display: block; width:4.5rem; height:4.5rem; position: absolute; top:0; left:0; background-color: #fff; mask-repeat: no-repeat; mask-position: center center; mask-size: contain; -webkit-mask-repeat: no-repeat; -webkit-mask-position: center center; -webkit-mask-size: contain; transition: all 0.5s ease-in-out;}
.quick-wrap .item.nth-1 .link::after {mask-image: url('../images/common/ico_quick01.png'); -webkit-mask-image: url('../images/common/ico_quick01.png');}
.quick-wrap .item.nth-2 .link::after { mask-image: url('../images/common/ico_quick02.png'); -webkit-mask-image: url('../images/common/ico_quick02.png');}
.quick-wrap .item.nth-3 .link::after {mask-image: url('../images/common/ico_quick03.png'); -webkit-mask-image: url('../images/common/ico_quick03.png');}
.quick-wrap .item.nth-4 .link::after {mask-image: url('../images/common/ico_quick04.png'); -webkit-mask-image: url('../images/common/ico_quick04.png');}


.quick-wrap .item.q-scroll .link:hover::before {background-color: var(--color-main); opacity: 0.5;}
.quick-wrap .item .link:hover::after {background-color: #fff;}

.quick-wrap .item.nth-1 .link:hover::after {background-color: #feed0c;}
.quick-wrap .item.nth-2 .link:hover::after {background-color: #03ce5f;}
.quick-wrap .item.nth-3 .link:hover::after {background-color: #be2520;}


.quick-wrap .item.q-scroll .link::after {transform: rotate(0deg);}
.is-fix .quick-wrap .item.q-scroll .link::after {transform: rotate(180deg);}



@media (max-width: 1280px) {
	
}

@media (max-width: 1024px) { 
	
}

@media (max-width: 768px) { 
	.body-sub .quick {bottom:calc(100% - var(--sub-visual-height) + var(--snb-height));}
	.quick-wrap {box-shadow: 0 0 3rem var(--color-black-a3); padding:1rem;}
	.quick-wrap .item .link span {display: none;}
}



@media (max-width: 480px) { 
	
	
}







/* SUV-VISUAL */
.sub-visual {position: relative; transition: 0.5s ease-in-out; height:var(--sub-visual-height); display: flex; align-items: center; width:100%;}
.sub-visual-bg {overflow: hidden; width:100%;  height:100%; transition: 1s ease-in-out;  animation: sub-visual-wrap 1s ease-in-out both; opacity: 0;  position: absolute;}
@keyframes sub-visual-wrap { 
	to{ opacity: 1; width:100%;}
}

.sub-visual-bg span { position: absolute; inset: 0; background: #444 no-repeat center/cover; transform: scale(1.2); animation: sub-visual 8s linear both 0.5s; } 
@keyframes sub-visual { to { transform: scale(1); } } 


.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-txt {position:relative; width: calc(100% - var(--inner-padding) * 2); margin:0 var(--inner-padding); text-align: center; z-index:3; transition: all 0.5s ease-in-out;}
.sub-visual-tit { display: inline-block; font-weight: 700; font-size: 5rem; color:#fff; line-height: 1.1; position: relative;}
.sub-visual-tit span { animation: clip-center 0.5s linear both 0.5s;}

.sub-visual-tit::before {content:''; display: block; width:7.9rem; height:7.7rem; background: url('../images/common/ico_symbol01.png') no-repeat center bottom / contain; position: absolute; bottom:0.5rem; right:0; transform: translate(50%, 0); animation: zoomInLeft 2.5s ease-in-out 0.5s both;}



@media (max-width: 1440px) { 
}
@media (max-width: 1024px) { 
	.sub-visual-tit {font-size:4.5rem;}
}

@media (max-width: 768px) { 
	.sub-visual-txt {text-align: center;}
	.sub-visual-tit {animation-name: clip-center;}
}

@media (max-width: 480px) { 
}





/*Sub Navigation Bar*/
.snb {position: absolute; bottom:0;  z-index: 3; width:100%;  display: flex; }
.snb-wrap {display: inline-flex; align-items: center; position: relative; padding:0; height:var(--snb-height); margin:0 var(--inner-padding);}


.snb-home {display: flex; height:100%; align-items: center; justify-content: center; position: relative; z-index: 1; transition: all 0.3s ease-in-out; flex-shrink: 0; font-size:0; text-indent: -99999px; margin-right:2rem;}
.snb-home::before {content:''; display: block; width:0.4rem; height:0.4rem; background-color: #fff; border-radius: 50%; position: absolute; top:0; left:50%; transform: translate(-50%, 0);}
.snb-home span { display: block; position: relative; height:1.4rem; width:1.4rem; margin-top:-2px; background-color: #fff; mask: url('../images/common/ico_home.png') no-repeat right top/contain; -webkit-mask: url('../images/common/ico_home.png') no-repeat right top/contain; transition: all 0.3s ease-in-out; }
.snb-home:hover::before,
.snb-home:hover span {background-color: var(--color-main);}




.snb-dep {position: relative;  height:var(--snb-height); max-width: 100%; z-index: 1; display: inline-block;}


.snb-dep {max-width: 100%;}
.snb-dep + .snb-dep {margin-left:1rem;}

.snb-btn { display: block; font-size:max(1.4rem, 12px); font-weight: 700; color:#fff; padding:0 4rem 0 1.5rem; min-width:15rem; height: 100%; width:100%; text-align: left;  transition: all 0.5s ease-in-out; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; border-top:1px solid var(--color-white-a2);}
.snb-btn::before { position: absolute; top: 50%; right: 1.5rem; width: 11px; height: 7px; background-color: #fff; mask: url(../images/common/chevron_w13.svg) no-repeat center / contain; -webkit-mask: url(../images/common/chevron_w13.svg) no-repeat center / contain; content: ''; transform: translateY(-50%); transition: .3s; z-index: 2;} 




.snb-btn.is-active {opacity: 1; color:var(--color-main); border-color:#fff; background-color: #fff;}
.snb-btn.is-active::before { transform: translateY(-50%) rotate(180deg); background-color: var(--color-main); }


.snb-list { display: none; position: absolute; top: var(--snb-height); left: 0; height: auto; box-shadow: 0 0 3rem var(--color-black-a3); background-color: #fff; overflow: hidden; width:100%; padding:1rem 0; z-index: -1;}



.snb-list ul {  height: auto; padding:0;}
.snb-list li a { display: block; padding: 1rem 1.5rem; color:#666666; font-size:max(1.3rem, 12px); font-weight: 500; transition: all 0.3s ease-in-out;}
.snb-list li.on a {color:#222; font-weight: 700; background-color: #e7e9ec;}

/*
.snb-list li a span{display: inline;}
.snb-list li.on a span{background: linear-gradient(to left, var(--color-main) 0, var(--color-main) 100%) no-repeat right bottom; background-size:100% 1px;}
*/
.snb-list li a:hover {color:var(--color-main);}




@media screen and (min-width:769px){
	.snb-dep + .snb-dep {max-width: none;}
	.snb-dep.snb-2dep .snb-list {position: static; height:100%;  box-shadow: none; background-color: transparent; border-radius: 0; border-width: 0; overflow: visible; width:auto; padding:0}
	.snb-dep.snb-2dep .snb-list ul {display: flex; height:100%;}
	.snb-dep.snb-2dep .snb-list ul li a {display: flex; align-items: center; text-align: center; height: 100%; padding:0 2.5rem; font-size:max(1.5rem, 13px); font-weight: 500; position: relative; color:#fff; border:none; transition: all 0.5s ease-in-out; background-color: transparent;}
	.snb-dep.snb-2dep .snb-list ul li a::before {content: ''; display: block; width:100%; height:0; background-color: var(--color-main); position: absolute; bottom:0; left:50%;  transform: translate(-50%, 0); opacity: 0; transition: all 0.5s ease-in-out; z-index: -1;}


	.snb-dep.snb-2dep .snb-list ul li.on a{color:#222; font-weight: 700;}
	.snb-dep.snb-2dep .snb-list ul li.on a::before { background-color: #fff; height:100%; opacity: 1;}

	
	.snb-dep.snb-2dep .snb-list ul li a:hover::before {opacity: 1; height:100%;}

}


@media (max-width: 768px) {


	.snb-wrap {width: 100%;}
	.snb-dep {max-width: 50%; flex-grow: 1;}

	
	
}

@media (max-width: 480px) { 
	.snb-wrap {width: 100%; margin: 0 1rem;}
	.snb-home {display: none;}
}
@media (max-width: 360px) { 
	
	
}


/* SUB-CONTENT */
.sub-content {padding:8rem 0 0;}
.sub-content:has(.newBoard) {padding-bottom:1px;}

.sub-content-tit {margin-bottom:8rem;}
.sub-content-tit h3 { font-size: max(3.6rem); font-weight: 700; color: #222; text-align: center;}

/* 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; min-width:100rem;}
.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 2rem; font-size: max(1.7rem, 13px); 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-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-a6); 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-tit .stxt {font-weight: 400; font-size:max(1.6rem, 13px); letter-spacing: -0.05em; color:#666;}
.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;}


/* 개인정보처리방침 
.privacy {font-size: max(1.5rem, 12px); line-height: 1.5; letter-spacing: -0.025em; padding: 0 0 2em;}
.privacy a {display: inline;}
.privacy h4 {font-weight: 700; color:var(--color-main);}

.privacy-header {font-weight: 600; color: #222;}
.privacy-item {margin-top:4rem;}
.privacy-item:first-child {margin-top:0;}
.privacy-item .desc{margin-top:1rem;}
.privacy-item .list-type1 {margin-top:1rem; line-height: 1.3;}
.privacy-item .list-type1 > li {position: relative; padding-left:1.8rem; margin-top:0.8rem;}
.privacy-item .list-type1 > li:first-child {margin-top:0;} 
.privacy-item .list-type1 > li::before {content: attr(data-num); display: block; position: absolute; left:0; top:0;}

.privacy-item .list-type2 {margin-top:1rem; line-height: 1.3;}
.privacy-item .list-type1 .list-type2 {margin-top:0.5rem;}
.privacy-item .list-type2 > li {position: relative; padding-left:1.1rem; margin-top:0.5rem;}
.privacy-item .list-type2 > li:first-child {margin-top:0;} 
.privacy-item .list-type2 > li::before {content:''; display: block; width:0.5rem; height:1px; background-color: #666; position: absolute; left:0; top:0.8rem;}

.privacy-item .stxt {font-size:0.9em; color:#888; margin-top:0.5rem;}

.privacy-link {margin-top:1rem;}
.privacy-link a {text-decoration: underline; color:var(--color-main); text-underline-offset: 0.2em;}
.privacy-link a:hover {color:var(--color-sub);}


.privacy-table {margin-top:1rem;}
.privacy-table table{font-size:max(1.3rem, 11px);}
.privacy-table thead th{background-color:#444; padding:0.5rem 1rem; color:#fff; font-weight: 700; }
.privacy-table thead th + th {border-left:1px solid rgba(204, 204, 204, 0.5);}

.privacy-table tbody th,
.privacy-table tbody td { padding:1rem 1.5rem; border:solid rgba(204, 204, 204, 0.5); border-width: 0 1px 1px 0;} 
.privacy-table tbody th {color:#222; font-weight: 700; background-color: #f3f6f9;}

.privacy-table tbody td:last-child {border-right:0;}

@media (max-width: 1023px) {
	.privacy-table .tb__scroll {position: relative; padding-top:0px; margin-top:0rem;}
	.privacy-table .tb__scroll::after {display:none;}
}
@media (max-width: 640px) {
	.privacy-table table{width:max(100%, 500px);}
	.privacy-table .tb__scroll { padding-top:25px; margin-top:-2rem;}
	.privacy-table .tb__scroll::after {display: block;}
}
*/


/* 이메일무단수집거부 */
.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 =============================================== */







/*연계제품 Layer Popup*/
.pro__layerpop {position: fixed; width:100vw; height:100vh; inset:0; background-color: var(--color-black-a5); z-index: 9999; -webkit-backdrop-filter: blur(8px);backdrop-filter: blur(8px); --layer-padding:3rem;}
.pro__layerpop-wrap {background-color: #fff; width: calc(100% - var(--inner-padding) * 2); position: absolute; top:50%; left:50%; transform: translate(-50%, -50%); max-width: 56rem; max-height:calc(100% - 4rem); min-height:30rem; box-shadow: 0 0 8rem var(--color-black-a3); transition: all 0.3s ease-in-out;}



.pro__layerpop-header {position: relative; background-color: var(--color-main); display: flex; align-items: center; height:7rem; padding:1rem 6rem 1rem var(--layer-padding);}


.pro__layerpop-header .tit {font-size:max(2.1rem, 17px); color:#fff; font-weight: 600;}
.pro__layerpop-header .close {display: block; width:3rem; height:3rem; font-size: 0; text-indent: -888888px; overflow: hidden; position: absolute; right:2rem; top:50%; transform:translate(0, -50%); transition: all 0.5s ease-in-out;}
.pro__layerpop-header .close::before,
.pro__layerpop-header .close::after {content:''; display: block; width:100%; height:2px; background-color: #fff; border-radius: 2px; position: absolute; top:50%; left:50%;}
.pro__layerpop-header .close::before {transform: translate(-50%, -50%) rotate(45deg);}
.pro__layerpop-header .close::after {transform: translate(-50%, -50%) rotate(-45deg);}

.pro__layerpop-header .close:hover {transform:translate(0, -50%) rotate(360deg); transition-duration: 1s;}


.pro__layerpop-inner{overflow-y:auto; padding:var(--layer-padding) var(--layer-padding) 0;}

.pro__layerpop-footer {position: relative; padding:1.5rem var(--layer-padding);}







.pro__layerpop-con .tit-wrap {border-bottom:1px solid #ddd; margin-top:3rem;}
.pro__layerpop-con .tit-wrap:first-of-type {margin:0;}
.pro__layerpop-con .tit {display: inline-block; position: relative; padding-bottom:1.4rem; font-size:max(1.8rem, 14px); color:#222; font-weight: 600;}
.pro__layerpop-con .tit::before {content:''; display: block; width: 100%; height:1px; background-color: var(--color-main); position: absolute; left:0; bottom:-1px;}


.pro__check-list .list{display: flex; flex-wrap: wrap; gap:1.5rem 1rem; padding:2rem 0; border-bottom:1px solid #ddd;}
.pro__check-list .item { flex-basis: 31%;}



/*체크박스*/
.pro__layerpop .basecheck {display: inline-block; font-size:0;}
.pro__layerpop .basecheck .basecheck-check {display:none;}
.pro__layerpop .basecheck .basecheck-label {padding:0 0 0 20px; position:relative; font-size:max(1.5rem, 12px); font-weight: 500; display: inline-block; cursor: pointer; text-align:left; transition: all 0.3s ease-in-out;}
.pro__layerpop .basecheck .basecheck-label:last-of-type {margin-right:0;}
.pro__layerpop .basecheck .basecheck-label::before {content:''; display:block; width:15px; height:15px; background-color: #fff; border:1px solid #ccc; border-radius: 50%; position: absolute; top:50%; left:0; transform:translate(0, -50%); transition: all 0.2s ease-in-out;}

.pro__layerpop .basecheck .basecheck-check[type=checkbox]:checked + .basecheck-label {color:var(--color-main); font-weight: 600;}
.pro__layerpop .basecheck .basecheck-check[type=checkbox]:checked + .basecheck-label::before {border-color: var(--color-main); border-width: 4px;}



.pro__layerpop .btn-wrap {margin-top:3rem; display: flex; justify-content: center; gap:1rem 2rem;}
.pro__layerpop .layerbtn {display: inline-flex; align-items: center; justify-content: center; text-align: center; min-width: 9rem; padding:1rem 2rem; background-color: #fff; border:1px solid #222; border-radius: 0.7rem; font-size:max(1.5rem, 12px); color:#666; font-weight: 500; transition: all 0.5s ease-in-out; }
.pro__layerpop .layerbtn.ok {background-color: #222; color:#fff;}

.pro__layerpop .layerbtn:hover {background-color: var(--color-main); border-color: var(--color-main); color:#fff;}


@media (max-width: 1024px){
}



@media (max-width: 640px){
	.pro__check-list .item { flex-basis: 48%;}
}
@media (max-width: 480px){
	.pro__check-list .item { flex-basis: 100%;}
}