@charset 'utf-8';

:root{
	--mainColor: #C6004D;
	--baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--Poppins: 'Poppins', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
}

/* 공통 */
*{ box-sizing: border-box; letter-spacing: -0.025em; word-break: keep-all; line-height: 1.3; }
.w1700{ max-width: 1700px; width: 100%; margin: 0 auto; }
.w1600{ max-width: 1600px; width: 100%; margin: 0 auto; }
.w1500{ max-width: 1500px; width: 100%; margin: 0 auto; }
html{ font-size: 62.5%; }
button, input[type="submit"]{ cursor: pointer; }


/* privacy */
.privacy { color:#666; width: 100%; overflow: hidden; box-sizing:border-box; padding:20px; font-size:15px;	line-height: 140%; word-break:break-all; }
.privacy h2 { font-size:18px; font-weight:bold; color:#000; text-align: left; margin:50px 0 30px; }
.privacy h2:first-child { margin-top: 0; }
.privacy > p { margin:15px 0; }
.privacy > p+dl { margin-top: 30px; }
.privacy > dl { padding-bottom:20px;}
.privacy > dl > dt{ font-size:15px;color:#3680b9;font-weight:700;padding-bottom:5px;}
.privacy > dl > dd{ padding-bottom:10px;text-align:justify; font-size:15px; line-height:140%;}
.privacy > dl > dd ul{ padding:10px; }
.privacy > dl > dd ul li{ line-height:120%; margin-top: 10px; }
.privacy > dl > dd ul li:first-child { margin-top: 0; }
.privacy > dl > dd ul li p { margin:0 10px 5px; line-height: 140%; }
.sTxt h3 { font-size:16px; color: #333; font-weight: 700; margin: 20px 0 10px; }
.sTxt p { margin-top: 10px; }
.sTxt dt { margin-top: 10px; }
.sTxt dd { margin:0 8px; }


/* header */
#header{ width: 100%; background: #fff; border-bottom: 1px solid #ddd; position: relative; z-index: 100; }
#header .bg{ width: 100%; height: 375px; background-color: #fff; position: absolute; top: calc(100% + 1px); left: 0; z-index: -1; box-shadow: 0px 15px 15px rgba(0, 0, 0, 0.05); display: none; }
#header .inner{ max-width: 1775px; width: 100%; margin: 0 auto; }
#header .logo{ display: inline-block; position: relative; }
#header .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
#header .lgLink{ font-size: 1.5rem; font-weight: 400; color: #777; padding: 5px 38.5px; }
#header .lgLink i{ margin-left: 10px; }

#header .line{ display: flex; justify-content: space-between; align-items: center; }
#header .line01{ padding: 30px 0 10px; padding-left: 40px; }
#header .line02{ padding-right: 38.5px; }

#header nav .depth01{ display: flex; position: relative; }
#header nav .depth01 > li:last-of-type{ display: none; }
#header nav .depth01 > li > a{ display: inline-block; font-size: 1.8rem; font-weight: 600; color: #000; padding: 25px 38.5px; transition: all 0.5s; }
#header nav .depth01 > li > a i{ font-size: 1.6rem; }

#header nav .depth02{ position: absolute; top: calc(100% + 1px); left: 0; display: flex; min-width: 100%; max-height: 310px; background: #fff; padding-top: 25px; display: none; }
#header nav .depth02 > li:not(:last-of-type){ margin-right: 23px; }
#header nav .depth02 > li > a{ display: inline-block; font-size: 1.6rem; font-weight: 600; color: #222; padding: 12.5px 38.5px; white-space: nowrap; }
#header nav .depth02 > li > a::after{ content: url("/img/common/depth02.png"); display: inline-block; margin-left: 13px; }

#header nav .depth03{ height: 165px; display: flex; flex-direction: column; flex-wrap: wrap; }
#header nav .depth03 > li > a{ display: inline-block; font-size: 1.6rem; font-weight: 300; color: #777; padding: 7px 38.5px; position: relative; transition: all 0.5s; }
#header nav .depth03 > li > a::after{ content:"\e90b"; font-family: 'xeicon'; font-weight: normal; font-style: normal; position: absolute; top: 45%; right: 15px; transform: translateY(-50%); opacity: 0; transition: all 0.5s; }

#header nav .wide{ margin-right: 0 !important; }
#header nav .wide1{ /* width: 560px; */ width: 372px; }
#header nav .wide1 .depth03{ height: 240px; }
#header nav .wide2{ width: 400px; }
#header nav .depth-wide{ width: 150px; }

#header nav .depth01 > li:hover > a{ color: var(--mainColor); }
#header nav .depth03 > li:hover a{ font-weight: 500; color: #333; }
#header nav .depth03 > li:hover a::after{ opacity: 1; }

#header .subMenu > ul{ display: flex; }
#header .subMenu > ul > li{ position: relative; }
#header .subMenu > ul > li:not(:last-of-type){ margin-right: 10px; }
#header .subMenu li button{ height: 35px; background: none; border: none; padding: 8px 20px; border-radius: 100px; font-family: var(--baseFont); font-size: 1.5rem; font-weight: 400; }
#header .subMenu li button img{ position: relative; top: 5px; margin-right: 10px; }
#header .subMenu li.solution button{ background: #F6F6F6; color: #222; }
#header .subMenu li.solution ul{ display: none; }
#header .subMenu li.fullMenu button{ background: var(--mainColor); color: #fff; }

#header .subMenu .depth02{ position: absolute; top: calc(100% + 5px); width: 100%; background: #fff; border: 1px solid #ddd; border-radius: 15px; }
#header .subMenu .depth02 li{ position: relative; }
#header .subMenu .depth02 li::after{ content: ""; width: calc(100% - 30px); height: 1px; background: #D9D9D9; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
#header .subMenu .depth02 li:last-of-type::after{ display: none; }
#header .subMenu .depth02 li a{ display: inline-block; width: 100%; text-align: center; font-size: 1.4rem; font-weight: 300; color: #888; letter-spacing: -0.02em; padding: 15px 0; }

/* footer */
#footer{ background-color: #f1f1f1; padding: 60px 0 70px; }
#footer .logo{ display: inline-block; position: relative; margin-bottom: 45px; }
#footer .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }

#footer .flex-box{ display: flex; justify-content: space-between; align-items: flex-start; }
/* #footer .half:last-of-type{ margin-top: -81px; } */
#footer .half{ display: flex; flex-direction: column; justify-content: flex-end; }
#footer .half span.bold{ font-size: 1.6rem; font-weight: 700; color: #333; }
#footer .half ul li a{ font-size: 1.7rem; font-weight: 300; color: #777; }
#footer .half ul li a:hover{ font-weight: 500; color: #333; }

#footer .half .policy{ display: flex; flex-wrap: wrap; gap: 10px 0; } 
#footer .half .policy li a{ display: inline-block; font-size: 1.7rem; font-weight: 500; padding: 0 30px 0 0; position: relative; }
#footer .half .policy li:first-of-type a{ font-size: 1.9rem; font-weight: 600; color: #333; }
#footer .half .policy li:not(:last-of-type) a::after{ content: ""; width: 1px; height: 12px; background-color: #aaa; position: absolute; top: 50%; right: 15px; transform: translateY(-50%); }

#footer .half .info{ margin: 40px 0; }
#footer .half .info li:not(:last-of-type){ margin-bottom: 10px; }
#footer .half .info li p, #footer .half .info li span{ display: inline-block; font-size: 1.6rem; font-weight: 300; color: #777; padding-right: 7px; }
#footer .half .info li.bold p{ font-size: 1.7rem; font-weight: 500; }

#footer .half .copyright li:first-of-type{ font-size: 1.6rem; font-weight: 300; color: #777; margin-bottom: 20px; }
#footer .half .copyright li:last-of-type{ font-size: 1.6rem; font-weight: 300; color: #aaa; }

#footer .half .customer{ margin-bottom: 60px; }
#footer .half .customer ul{ display: flex; }
#footer .half .customer ul li a{ display: inline-block; padding-top: 20px; }
#footer .half .customer ul li:not(:last-of-type) a{ padding-right: 40px; }

#footer .half .number:not(:last-of-type){ margin-bottom: 55px; }
#footer .half .number p{ font-size: 1.6rem; font-weight: 300; color: #777; }
#footer .half .number p.phone{ font-size: 3rem; font-weight: 700; color: #c6004d; margin: 10px 0 5px; }


/* 전체메뉴 */
#menu{ width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 300; background: rgba(0, 0, 0, 0.8); display: none; }
#menu .blank{ position: absolute; top: 0; left: 0; bottom: 0; right: 0; }
#menu .menu-box{ max-width: 1720px; width: 100%; background: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); border-radius: 20px; padding: 50px 110px; }
#menu .close{ width: 60px; height: 60px; border-radius: 50%; background: var(--mainColor); border: none; position: absolute; top: 0; right: -30px; }
#menu .menu-box .mobile{ display: none; }
#menu .lgLink{ font-size: 1.5rem; font-weight: 400; color: #777; }
#menu .lgLink a{ width: 100%; display: inline-block; padding: 15px 20px; text-align: right;}
#menu .lgLink i{ margin-left: 10px; }

#menu .menu-box .depth01 > li{ display: flex; padding: 10px 0 45px; }
#menu .menu-box .depth01 > li:not(:last-of-type){ border-bottom: 1px solid #E8E8E8; }
#menu .menu-box .depth01 > li:last-of-type{ padding-bottom: 20px; }
#menu .menu-box .depth01 > li > a{ display: inline-block; width: 14%; font-size: 2rem; font-weight: 500; color: #111; letter-spacing: -0.02em; }

#menu .menu-box .depth02{ display: flex; }
#menu .menu-box .depth02 > li{ width: 150px;}
#menu .menu-box .depth02 > li > a{ display: inline-block; font-size: 1.7rem; font-weight: 500; color: #333; letter-spacing: -0.02em; padding: 5px 0;  transition: all 0.5s; }
#menu .menu-box .depth02 > li:hover > a{ color: var(--mainColor); }

#menu .menu-box .depth03{ display: flex; flex-direction: column; flex-wrap: wrap; }
#menu .menu-box .depth03 > li > a{ display: inline-block; width: 100%; font-size: 1.5rem; font-weight: 300; color: #888; padding: 5px 0; padding-right: 20px; }

#menu .menu-box .depth02 > li.wide1{ width: 430px; }
#menu .menu-box .wide1 .depth03{ /* height: 75px; */ height: 100px;}
#menu .menu-box .depth02 > li.wide2{ width: 600px; }
#menu .menu-box .wide2 .depth03{ height: 50px; }


/* top */
#floating{ max-width: max-content; position: fixed; bottom: 30px; right: 30px; z-index: 500; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 10px; }
#top{ width: 70px; height: 70px; background: #333; border: none; }

/* subVisual */
.subVisual .lnb ul{ display: flex; padding: 100px 0 20px; }
.subVisual .lnb ul li a{ display: inline-block; font-size: 1.5rem; font-weight: 400; color: #666; position: relative; }
.subVisual .lnb ul li:not(:last-of-type) a{ padding-right: 30px; }
.subVisual .lnb ul li:not(:last-of-type) a::after{ content: ""; width: 1px; height: 10px; background-color: #ccc; position: absolute; top: 48%; right: 15px; transform: translateY(-50%); }
.subVisual .subTitle{ font-size: 6rem; font-weight: 700; color: #222;  line-height: 1.7894; }
.subVisual .subText{ font-size: 1.9rem; font-weight: 400; color: #666; line-height: 1.6842; margin-bottom: 45px; }


 /* 반응형 */
@media screen and (min-width: 1920px){
	/* header */
	#header .inner{ max-width: calc(100% - 125px); }

	/* footer */
	#footer .w1600{ max-width: calc(100% - 220px); }
}

@media screen and (max-width: 1820px){
	/* 전체메뉴 */
	#menu .menu-box{ max-width: calc(100% - 100px); }
}

@media screen and (max-width: 1740px){
	/* 공통 css */
	.w1700{ padding: 0 20px; }
}

@media screen and (max-width: 1640px){
	.w1600{ padding: 0 20px; }
}

@media screen and (max-width: 1640px){ 
	/* header */
	#header .lgLink{ padding: 5px 20px; }
	#header .line01{ padding-left: 20px; }
	#header .line02{ padding-right: 20px; }

	/* 전체메뉴 */
	#menu .menu-box .depth01 > li:last-of-type{ padding-bottom: 10px; }
	#menu .menu-box{ padding: 30px 70px; }
}

@media screen and (max-width: 1550px){
	/* 전체메뉴 */
	#menu .menu-box .depth01 > li{ padding: 10px 0 30px;}
	#menu .menu-box .depth02 > li{ width: 150px;}
	#menu .menu-box .depth03 > li > a{ padding-right: 30px; }
}

@media screen and (max-width: 1540px){
	/* 공통 css */
	.w1500{ padding: 0 20px; }
}

@media screen and (max-width: 1400px){ 
	/* top */
	#top{ width: 60px; height: 60px; }

	/* 전체메뉴 */
	#menu .menu-box .depth02 > li.wide1{ width: 545px; }
	#menu .menu-box .depth02 > li.wide2{ width: 435px; }
}

@media(max-width: 1200px){
	/* subVisual */
	.subVisual .lnb ul{ padding: 70px 0 50px; }
	.subVisual .subTitle{ font-size: 5rem; margin-bottom: 15px; }
	.subVisual .subText{ font-size: 1.6rem; margin-bottom: 30px; }

	/* 전체메뉴 */
	#menu .menu-box{ max-width: 450px; width: 100%; height: 100vh; top: 0; left: 100%; transform: translateX(-100%); border-radius: 20px 0 0 20px; padding: 30px; /* padding-top: 60px; */ padding-top: 70px; }
	#menu .menu-box .pc{ display: none; }
	#menu .menu-box .mobile{ display: block; }
	#menu .close{ width: 40px; height: 40px; top: 15px; right: 30px; }
	#menu .menu-box .depth01{ height: calc(100vh - 150px); border-top: 1px solid #E8E8E8; overflow-y: scroll; }
	#menu .menu-box .depth01 > li{ display: block; padding: 0; position: relative; border-bottom: 1px solid #E8E8E8; }
	#menu .menu-box .depth01 > li:last-of-type{ padding-bottom: 0; }
	#menu .menu-box .depth01 > li::after{ content: ""; width: 100%; height: 60px; position: absolute; top: 0; left: 0; z-index: 10; cursor: pointer; }
	#menu .menu-box .depth01 > li.none::after{ display: none; }
	/*	#menu .menu-box .depth01 > li.solution::after{ display: none; }*/
	#menu .menu-box .depth01 > li > a{ width: 100%; padding: 20px; position: relative; }
	#menu .menu-box .depth01 > li > a::after{ content: "\e941"; font-family: "xeicon"; font-size: 1.5rem; font-style: normal; position: absolute; top: 50%; right: 20px; transform: translateY(-50%); transition: transform 0.5s; }
	#menu .menu-box .depth01 > li.none > a::after{ display: none; }
	/*	#menu .menu-box .depth01 > li.solution > a::after{ display: none; }*/
	#menu .menu-box .depth02{ display: none; flex-direction: column; background: #f1f1f1; padding: 10px 0; }
	#menu .menu-box .depth02 > li{ width: 100%; }
	#menu .menu-box .depth02 > li > a{ width: 100%; padding: 10px 20px; }
	#menu .menu-box .depth03 > li > a{ padding: 10px 40px; position: relative; }
	#menu .menu-box .depth03 > li > a::before{ content: "-"; /* width: 3px; height: 3px; background: #888; */ border-radius: 50%; position: absolute; top: 48%; left: 25px; transform: translateY(-50%); }

	#menu .menu-box .wide{ display: block; }
	#menu .menu-box .depth02 > li.wide1, #menu .menu-box .depth02 > li.wide2{ width: 100%; }
	#menu .menu-box .wide1 .depth03{ height: auto; }
	#menu .menu-box .wide2 .depth03{ height: auto; }

	#menu .menu-box .depth01 > li.on > a::after{ transform: translateY(-50%) rotate(-180deg); }
}

@media screen and (max-width: 1100px){
	/* header */
	#header .inner{ display: flex; justify-content: space-between; align-items: center; }
	#header .line01{ padding: 20px; }
	#header .line02{ justify-content: flex-end; }
	#header .lgLink{ display: none; }
	#header nav{ display: none; }
	#header .subMenu > ul > li.solution{ display: none; }
}

@media screen and (max-width: 900px){
	/* header */

	/* footer */
	#footer{ padding: 30px 0 60px; }
	#footer .w1500{ padding: 0 15px; }
	#footer .flex-box{ flex-direction: column-reverse;}
	#footer .half:first-of-type{ margin-top: 20px;}
	/* #footer .half:last-of-type{ flex-direction: row; margin-top: 0; margin-bottom: 20px; } */
	#footer .half .number:not(:last-of-type){ margin-bottom: 0; margin-right: 50px; }
	#footer .half .customer{ margin-bottom: 20px; }
	#footer .half .customer ul li:not(:last-of-type) a{ padding-right: 20px; }
	#footer .half .info{ margin: 20px 0; }
	#footer .half .number p.phone{ font-size: 25px; margin: 20px 0 10px; }
	#footer .half .info li{ display: flex; }
	#footer .half .copyright li:first-of-type{ margin-bottom: 10px; }

	/* top */
	#floating{ right: 20px; bottom: 20px; }
	#top{ width: 50px; height: 50px; }

	/* subVisual */
	.subVisual .lnb ul{ padding: 40px 0 20px; }
}

@media screen and (max-width: 700px){
	.subVisual .subTitle{ font-size: 3.5rem; line-height: 1.2; }
}

@media screen and (max-width: 580px){ 
	#footer .half .policy li:nth-of-type(2) a::after{ display: none; }
}

@media screen and (max-width: 650px){ 
	#footer .half .info li{ display: flex; flex-direction: column; }
	#footer .half .info li:not(:last-of-type){ margin-bottom: 5px; }
	#footer .half .info li span{ display: none; }
	#footer .half .info li p:not(:last-of-type){ margin-bottom: 5px; }
	#footer .half .copyright li:last-of-type{ line-height: 1.3; }
}





/* 팝업 */
.popup{ width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 999; }
.popup .blank{ width: 100%; height: 100%; }


/* 메인 페이지 팝업 */
.popup .main-popup{ max-width: 100%; width: max-content; position: absolute; z-index: 50; }
.popup .main-popup .btn-box{ width: 100%; display: flex; justify-content: space-between; align-items: center; background: #111; }
.popup .main-popup .btn-box *{ font-size: 1.7rem; font-weight: 400; color: #fff; }
.popup .main-popup .btn-box .today input{ display: none; }
.popup .main-popup .btn-box .today label{ display: inline-block; padding: 10px 0; padding-left: 40px; position: relative; cursor: pointer; }
.popup .main-popup .btn-box .today label::before{ content: ""; width: 15px; height: 15px; border: 1px solid #fff; position: absolute; top: calc((1.3em / 2) + 10px); left: 15px; transform: translateY(-50%); }
.popup .main-popup .btn-box .today input:checked + label::before{ border: 1px solid var(--mainColor); background: var(--mainColor); }
.popup .main-popup .btn-box .today input:checked + label::after{ content: "\e928"; font-family: "xeicon"; font-size: 1.2rem; font-weight: normal; font-style: normal; position: absolute; top: 14px; left: 16px; }
.popup .main-popup .btn-box .close button{ font-family: var(--baseFont); background: none; border: none; padding: 10px 15px; margin-left: 30px; }

@media screen and (max-width: 1280px){
	.popup .main-popup .btn-box *{ font-size: 1.6rem; }
	.popup .main-popup .btn-box .today input:checked + label::after{ top: 13px; }
}