@charset 'utf-8';

/* ���� */
:root{
    --baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--engFont: 'Roboto Condensed', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;

	--mainColor: #C30813;
	--orange: #EA7537;

	--vh: 100%;
	--headerH: 80px;

	--aosPlus: 100px;
	--aosMinus: -100px;
}

*{ box-sizing: border-box; word-break: keep-all; line-height: 1.3; }
body.lock{ overflow: hidden; }
body{ font-size: 16px; }
body *{ font-size: inherit; }

sup,
sub{ font-size: small; }

/* inner size */
.w1720{ max-width: 1760px; width: 100%; margin: 0 auto; padding: 0 20px; }
.w1600{ max-width: 1640px; width: 100%; margin: 0 auto; padding: 0 20px; }
.w1500{ max-width: 1540px; width: 100%; margin: 0 auto; padding: 0 20px; }

/* slick */
.slick-slide{ outline: none !important; }

@media screen and (max-width: 1700px){
	html{ font-size: 50%; }
}

@media screen and (max-width: 1280px){
	:root{
		--headerH: 65px;
	
		--aosPlus: 50px;
		--aosMinus: -50px;
	}

	html{ font-size: 40%; }
}

@media screen and (max-width: 900px){
	html{ font-size: 30%; }
}

/* privacy */
.privacy * { font-size: 18px; line-height: 1.6666; }
.privacy h4{ font-size: 22px; font-weight: 600; margin-bottom: 20px; }
.privacy dl dt { font-size: 20px; font-weight: 500; margin-bottom: 5px; }
.privacy dl dd p { margin: 5px 0; }
.privacy dl dd ul:only-child{ margin-top: 5px; }

.privacy .textBox,
.privacy .pBox,
.privacy .dlBox,
.privacy .subTextBox { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }

.privacy .textBox > *:not(:last-child){ margin-bottom: 100px; }

.privacy .dlBox > *:not(:last-child){ margin-bottom: 50px; }

.privacy .square { position: relative; padding-left: 12px; }
.privacy .square::before { content: "-"; position: absolute; top: 0; left: 0; }

.privacy .subTextBox > *:not(:last-child){ margin-bottom: 25px; }

.privacy .pBox > *:not(:last-child){ margin-bottom: 10px; }

@media screen and (max-width: 1600px){
	.privacy h4{ font-size: 20px; }
	.privacy .textBox > *:not(:last-child){ margin-bottom: 80px; }
}

@media screen and (max-width: 1280px){
	.privacy * { font-size: 16px; }
	.privacy h4{ font-size: 18px; margin-bottom: 5px; }
	.privacy dl dt { font-size: 18px; margin-bottom: 0; }

	.privacy .textBox > *:not(:last-child){ margin-bottom: 60px; }
	.privacy .dlBox > *:not(:last-child){ margin-bottom: 30px; }
	.privacy .subTextBox > *:not(:last-child){ margin-bottom: 15px; }
}



/* header */
#header{ width: 100%; background: transparent; position: fixed; top: 0; left: 0; z-index: 999; transition: background 0.3s; }
#header::before{ content: ""; width: 100%; height: 1px; background: #EEE; position: absolute; bottom: 0; left: 0; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
#header .navBg{ width: 100%; height: 0; background: #FFF; box-shadow: 0 0 30px rgba(0, 0, 0, 0.1); position: absolute; top: 0; left: 0; z-index: -1; transition: height 0.5s; will-change: height; }
#header .flex-box{ height: var(--headerH); display: flex; justify-content: space-between; align-items: center; }
#header .logo{ position: relative; z-index: 10; }
#header .logo svg{ width: auto; height: auto; }
#header .logo svg .fill{ transition: fill 0.5s; }
#header .logo svg .stroke{ transition: stroke 0.5s; }

#header nav{ width: 100%; position: absolute; top: 0; left: 50%; z-index: 5; transform: translateX(-50%); }
#header a{ display: block; }
#header .depth01{ display: flex; justify-content: center; }
#header .depth01 > li{ position: relative; }
#header .depth01 > li > a{ height: var(--headerH); display: flex; justify-content: center; align-items: center; font-size: 20px; font-weight: 400; color: #FFF; letter-spacing: -0.03em; padding: 0 40px; text-align: center; position: relative; z-index: 10; transition: color 0.5s; }
#header .depth01 > li > a::after{ content: ""; width: calc(100% - 80px); height: 3px; background: vaR(--mainColor); position: absolute; bottom: 0; left: 50%; transform: translateX(-50%) scaleX(0); transition: transform 0.5s; }

#header .depthBox{ position: absolute; top: 0; left: 50%; transform: translateX(-50%); opacity: 0; transition: opacity 0.3s; pointer-events: none; }
#header .depth02{ padding-top: var(--headerH); display: flex; }
#header .depth02 > li > a{ font-size: 19px; font-weight: 400; color: #333; white-space: nowrap; letter-spacing: -0.03em; padding: 30px 20px; }
#header .depth02 .icon{ width: 60px; height: 60px; background: var(--mainColor); border-radius: 20px; }
#header .depth02 dl dt{ font-family: var(--engFont); font-size: 24px; font-weight: 500; color: #222; transition: color 0.3s; }
#header .depth02 dl dt p{ margin: 30px 0 15px; }
#header .depth02 dl dd{ font-size: 20px; font-weight: 300; color: #444; letter-spacing: -0.03em; line-height: 1.6; }

#header .right{ display: flex; align-items: center; position: relative; z-index: 10; margin-right: -15px; }
#header .right button{ background: none; border: none; padding: 15px; }
#header .right button svg{ width: auto; height: auto; }
#header .right button svg path{ transition: fill 0.5s, stroke 0.5s; }

#header .lang{ margin-right: 5px; }
#header .lang ul{ display: flex; }
#header .lang ul li a{ display: inline-block; font-family: var(--engFont); font-size: 19px; font-weight: 500; color: #FFF; padding: 10px; opacity: 0.3; transition: color 0.5s; }
#header .lang ul li.on a{ opacity: 1; }

#header .menu{
	--width: 40px;
}
#header .menu{ display: flex; flex-direction: column; justify-content: center; }
#header .menu span{ display: inline-block; width: 40px; height: 3px; background: #FFF; vertical-align: middle; transition: width 0.5s, background 0.5s, transform 0.5s; }
#header .menu span:not(:last-of-type){ margin-bottom: 10px; }
#header .menu span:nth-of-type(1){ width: var(--width); }
#header .menu span:nth-of-type(2){ width: calc(var(--width) - 10px); }
#header .menu span:nth-of-type(3){ width: 10px; }


/* header - wide */
#header .depth01 > li.wide{ position: static; }
#header .depth01 > li.wide .depthBox{ max-width: 1560px; width: 100%; padding: 0 20px; }
#header .depth01 > li.wide .depth02{ margin: 0 -10px; }
#header .depth01 > li.wide .depth02 > li{ width: calc(100% / 4); }
#header .depth01 > li.wide .depth02 > li > a{ padding: 30px 10px 80px; }

/* header - scroll */
#header.scroll{ background: #FFF; }
#header.scroll::before{ opacity: 1; transition-delay: 0.2s; }
#header.scroll .logo svg .fill{ fill: #3E3A39; }
#header.scroll .logo svg .stroke{ stroke: #3E3A39; }
#header.scroll .depth01 > li > a{ color: #111; }
#header.scroll .right button svg path{ fill: #000; stroke: #000; }
#header.scroll .lang ul li a{ color: #000; }
#header.scroll .menu span{ background: #000; }

/* header - hover */
#header.hover::before{ opacity: 1; transition-delay: 0.2s; }
#header.hover .logo svg .fill{ fill: #3E3A39; }
#header.hover .logo svg .stroke{ stroke: #3E3A39; }
#header.hover .depth01 > li > a{ color: #111; }
#header.hover .right button svg path{ fill: #000; stroke: #000; }
#header.hover .lang ul li a{ color: #000; }
#header.hover .menu span{ background: #000; }

@media screen and (hover: hover){
	#header .depth01 > li:hover > a{ color: var(--mainColor); }
	#header .depth01 > li:hover > a::after{ transform: translateX(-50%) scaleX(1); }
	#header .depth01 > li:hover .depthBox{ opacity: 1; pointer-events: auto; transition-delay: 0.3s; }
	#header .depth02 > li:hover dt{ color: var(--mainColor); }

	#header .menu:hover span{ width: var(--width) !important; }
}

@media screen and (max-width: 1700px){
	#header .depth01 > li > a{ font-size: 18px; padding: 0 30px; }
	#header .depth02 > li > a{ font-size: 18px; padding: 20px; }
	#header .depth02 dl dt{ font-size: 21px; }
	#header .depth02 dl dt p{ margin: 30px 0 15px; }
	#header .depth02 dl dd{ font-size: 18px; }
	
	#header .lang ul li a{ font-size: 18px; }
	
	/* header - wide */
	#header .depth01 > li.wide .depth02 > li > a{ padding: 30px 10px 60px; }
}

@media screen and (max-width: 1280px){
	#header .logo svg{ height: 50px; }
	
	#header .depth01 > li > a{ font-size: 17px; }
	#header .depth02 > li > a{ font-size: 17px; }
	#header .depth02 dl dt{ font-size: 19px; }
	#header .depth02 dl dt p{ margin: 20px 0 10px; }
	#header .depth02 dl dd{ font-size: 17px; }
	
	#header .right{ margin-right: -10px; }
	#header .right button{ padding: 10px; }
	
	#header .lang ul li a{ font-size: 17px; }
	
	#header .menu{
		--width: 35px;
	}
	#header .menu span:not(:last-of-type){ margin-bottom: 7px; }
	
	/* header - wide */
	#header .depth01 > li.wide .depth02 > li > a{ padding: 20px 10px 40px; }
}

@media screen and (max-width: 1200px){
	#header .logo svg{ height: 45px; }
	#header nav{ display: none; }
}


/* popupH */
.popupH{ width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); position: fixed; top: 0; left: 0; z-index: 1000; padding: 75px; overflow: hidden; display: none; }
.popupH .blank{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.popupH .inner{ width: 100%; height: 100%; background: #FFF; border-radius: 30px; }


/* search */
#search{
	--height: 80px;
}
#search .inner{ max-width: 90%; width: 1200px; height: unset; padding: 80px 60px 120px; opacity: 0; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(1.05); transition: transform 0.7s 0.3s, opacity 0.7s 0.3s; }
#search .cc{ max-width: 800px; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; margin: 0 auto; }
#search h3{ font-family: var(--engFont); font-size: 8rem; font-weight: 500; color: #111; text-align: center; margin-bottom: 30px; }
#search form{ position: relative; }
#search input{ width: 100%; height: var(--height); background: #EEE; border: none; border-radius: 80px; -webkit-border-radius: 80px; font-size: 20px; font-weight: 500; color: #111; letter-spacing: -0.03em; padding: 0 50px; padding-right: calc(10px + var(--height)) !important; outline: none; }
#search input::placeholder{ font-weight: 400; color: #AAA; }
#search button{ width: calc(var(--height) - 20px); height: calc(var(--height) - 20px); background: var(--mainColor); border: none; border-radius: 50%; padding: 10px; position: absolute; top: 50%; right: 10px; transform: translateY(-50%); }
#search button svg{ width: auto; height: auto; }

#search.on .inner{ transform: translate(-50%, -50%) scale(1); opacity: 1; }


/* menu */
#menu .inner{ padding: 90px 120px; transform: scale(1.05); opacity: 0; transition: transform 0.7s 0.3s, opacity 0.7s 0.3s; }
#menu .inner > div{ height: 100%; }
#menu .mobile{ display: none; }
#menu .eng{ font-family: var(--engFont); letter-spacing: 0 !important; }
#menu a{ transition: color 0.3s; }

#menu .depth01{ height: 100%; }
#menu .depth01 > li{ height: calc(100% / 6); display: flex; justify-content: space-between; align-items: center; }
#menu .depth01 > li:not(:last-of-type){ border-bottom: 1px solid #EEE; }
#menu .depth01 > li > a{ font-size: 5.5rem; font-weight: 600; color: #CCC; white-space: nowrap; }
#menu .depth01 > li > a::after{ content: ""; display: inline-block; width: 25px; height: 25px; background: url("/img/common/menu_icon.svg") no-repeat center center / contain; vertical-align: middle; transform: translateY(-5px); margin-left: 20px; filter: grayscale(1) brightness(4.4); -webkit-filter: grayscale(1) brightness(4.4); }

#menu .depth02{ display: flex; justify-content: flex-end; margin: -5px -25px; }
#menu .depth02 > li{ position: relative; }
#menu .depth02 > li::after{ content: ""; width: 1px; height: 16px; background: #DDD; position: absolute; top: 50%; right: 0; transform: translate(-50%, -50%) rotate(45deg); }
#menu .depth02 > li:last-of-type::after{ display: none; }
#menu .depth02 > li > a{ display: inline-block; font-size: 20px; font-weight: 400; color: #999; letter-spacing: -0.03em; padding: 5px 25px; }

#menu.on .inner{ transform: scale(1); opacity: 1; }

#menu .mobile .depth01 > li.on > a{ color: #111; }
#menu .mobile .depth01 > li.on > a::after{ filter: unset; -webkit-filter: unset; }
#menu .mobile .depth01 > li.on .depth02 > li > a{ color: #333; }

@media screen and (hover: hover){
	#menu .depth01 > li:hover > a{ color: #111; }
	#menu .depth01 > li:hover > a::after{ filter: unset; -webkit-filter: unset; }
	#menu .depth01 > li:hover .depth02 > li > a{ color: #333; }
}

@media screen and (max-width: 1700px){
	/* popupH */
	.popupH{ padding: 50px; }
	
	/* search */
	#search{
		--height: 70px;
	}
	#search{ padding: 100px 50px; }
	#search .inner{ padding: 60px 40px 100px; }
	#search input{ font-size: 18px; padding: 0 30px; }
	
	/* menu */
	#menu .inner{ padding: 60px 90px; }
	#menu .depth02{ margin: -5px -20px; }
	#menu .depth02 > li > a{ padding: 5px 20px; }
}

@media screen and (max-width: 1280px){
	/* popupH */
	.popupH{ padding: 25px; }
	
	/* search */
	#search{
		--height: 60px;
	}
	#search .inner{ padding: 50px 25px 70px; }
	#search .cc{ padding-bottom: 30px; }
	#search{ padding: 200px 25px; }
	#search input{ font-size: 17px; padding: 0 20px; }
	
	/* menu */
	#menu{ padding: 50px 20px; }
	#menu .inner{ padding: 30px 60px; }
	#menu .depth02 > li > a{ font-size: 18px; }
}

@media screen and (max-width: 1000px){
	/* menu */
	#menu{ padding: 0; padding-left: 100px; }
	#menu .inner{ max-width: 500px; border-radius: 30px 0 0 30px; padding: var(--headerH) 25px; margin-left: auto; transform: translateX(100%); }
	#menu .inner > div{ overflow-x: clip; overflow-y: auto; }
	#menu .pc{ display: none; }
	#menu .mobile{ display: block; }
	
	#menu .depth01{ height: auto; border-top: 1px solid #EEE; border-bottom: 1px solid #EEE; }
	#menu .depth01 > li{ height: auto; display: block; }
	#menu .depth01 > li > a{ display: block; font-size: 6rem; padding: 10px; }
	#menu .depth01 > li > a::after{ width: 20px; height: 20px; margin-left: 10px; transform: translateY(-2px); }
	#menu .depthBox{ display: none; }
	#menu .depth02{ display: block; border-top: 1px solid #EEE; margin: 0; padding: 7px 0; }
	#menu .depth02 > li::after{ display: none; }
	#menu .depth02 > li > a{ display: block; font-size: 20px; padding: 7px 10px; }
	
	#menu.on .inner{ transform: translateX(1); }
}


/* footer */
#footer{ background: #FFF; padding: 100px 0 30px; }
#footer .logo svg{ width: auto; height: auto; }
#footer .grid-box{ display: grid; grid-template-columns: 305px 285px auto 250px; }

#footer .link li > *{ background: none; border: none; display: inline-block; font-family: var(--baseFont); font-size: 20px; font-weight: 300; color: #222; letter-spacing: -0.03em; padding: 12px 15px; }
#footer .link li.bold > *{ font-weight: 500; }
#footer .link li button{ background: #D9D9D9; border-radius: 15px; }
#footer .link li button::after{ content: ""; width: 20px; height: 20px; display: inline-block; background: url("/img/common/btn_arrow.svg") no-repeat center center / contain; vertical-align: middle; margin-left: 10px; transform: translateY(-2px); }

#footer address{ font-family: var(--engFont); font-size: 18px; font-weight: 300; color: #666; }
#footer address p:not(:last-of-type){ margin-bottom: 15px; }

#footer .sns{ display: flex; justify-content: flex-end; margin: -7px; }
#footer .sns li a{ display: inline-block; padding: 7px; }
#footer .copyright{ font-family: var(--engFont); font-size: 18px; font-weight: 300; color: #999; margin-top: 30px; text-align: right; }

#footer .top{ max-width: max-content; margin-left: auto; }

/* top */
#top{ width: 60px; height: 60px; background: #000; border: none; border-radius: 50%; font-family: var(--engFont); font-size: 20px; font-weight: 700; color: #FFF; margin-top: 10px; padding: 0;  }

@media screen and (max-width: 1700px){
	#footer{ padding-top: 70px; }
	#footer .logo svg{ height: 70px; }
	#footer .link li > *{ font-size: 18px; }
	#footer address{ font-size: 17px; }
	#footer .copyright{ font-size: 17px; }
	
	/* top */
	#top{ width: 55px; height: 55px; font-size: 18px; }
}

@media screen and (max-width: 1500px){
	#footer{ padding-top: 40px; }
	#footer .logo svg{ height: 60px; }
	#footer .grid-box{ display: block; }
	#footer .link{ display: flex; margin: 15px 0; }
	#footer address p:not(:last-of-type){ margin-bottom: 7px; }
	#footer .copyright{ margin-top: 10px; }
	#footer .sns{ margin-top: -70px; }
	
	/* top */
	#top{ margin-top: 20px; }
}

@media screen and (max-width: 1280px){
	#footer{ padding-top: 30px; }
	#footer .link li > *{ font-size: 17px; padding: 10px 12px; }
	#footer .link li button::after{ width: 17px; height: 17px; margin-left: 7px; }
	#footer address{ font-size: 16px; }
	#footer .sns{ margin-top: -50px; }
	#footer .copyright{ font-size: 16px; }
}