@charset 'utf-8';

/* ���� */
:root{
    --baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--engFont: 'Satoshi', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;

	--vh: 100%;
	--resizeVH: 100vh;
	--headerH: 120px;
	--footerT: 80px;
	--footerB: 1px solid rgba(255, 255, 255, 0.3);

	--baseBg: #050505;
	--orange: #F9A819;

	--aosP: 100px;
	--aosM: -100px;
	--aosT: 700ms;
}

*{ box-sizing: border-box; word-break: keep-all; line-height: 1.3; }
html,
body{ background: var(--baseBg); -ms-overflow-style: none; overflow-x: clip; }
html{ scroll-behavior: smooth; }
html.lock{ overflow: hidden; }
body::-webkit-scrollbar{ display: none; }
body{ font-size: 16px; }
body *{ font-size: inherit; }

.w1920{ max-width: 1920px; width: 100%; margin: 0 auto; }
.w1800{ max-width: 1840px; width: 100%; margin: 0 auto; padding: 0 20px; }
.w1760{ max-width: 1800px; width: 100%; margin: 0 auto; padding: 0 20px; }
.w1600{ max-width: 1640px; width: 100%; margin: 0 auto; padding: 0 20px; }
.w1200{ max-width: 1240px; width: 100%; margin: 0 auto; padding: 0 20px; }

/* slick */
.slick-slider{ overflow: hidden; }
.slick-track{ margin: 0; }
.slick-slide{ outline: none; }

/* aos */
[data-aos]{ transition-duration: var(--aosT); }

@media (hover: hover) and (pointer: fine) {
	:root{
		--resizeVH: var(--vh);
	}
}

@media screen and (max-width: 1600px){
	:root{
		--headerH: 90px;
		--footerT: 50px;
	}
	html{ font-size: 50%; }
}

@media screen and (max-width: 1280px){
	:root{
		--headerH: 70px;
		--footerT: 30px;

		--aosPlus: 50px;
		--aosMinus: -50px;
	}

	html{ font-size: 40%; }
}

@media screen and (max-width: 900px){
	html{ font-size: 30%; }
}

/* privacy */
.privacy * { font-size: 19px; font-weight: 300; color: rgba(255, 255, 255, 0.6); line-height: 1.5; }
.privacy > *:not(:last-child){ margin-bottom: 100px; }
.privacy h4{ font-size: 30px; font-weight: 600; margin-bottom: 30px; }
.privacy h5{ font-weight: 600; margin-bottom: 10px; }
.privacy ul{ margin-top: 10px; }
.privacy ul li:not(:last-of-type){ margin-bottom: 5px; }

.privacy dl dt{ font-size: 21px; font-weight: 600; color: rgba(255, 255, 255, 0.9); }
.privacy dl dd{ margin-top: 10px; }
.privacy .textBox{ margin-top: 40px; }
.privacy .textBox dl dt{ font-size: 19px; font-weight: 500; color: rgba(255, 255, 255, 0.6); }
.privacy .textBox dl dd{ margin-top: 5px; }

.privacy .textBox > *:not(:last-child){ margin-bottom: 40px; }
.privacy .pBox > *{ margin-top: 10px; }
.privacy .dlBox > *{ margin-top: 20px; }

.privacy .dot{ padding-left: 12px; position: relative; }
.privacy .dot::before{ content: ""; width: 3px; height: 3px; background: #000; border-radius: 50%; position: absolute; top: calc(1.4em / 2); left: 0; transform: translateY(-50%); }

.privacy .hyphen{ padding-left: 12px; position: relative; }
.privacy .hyphen::before{ content: "-"; position: absolute; top: 0; left: 0; }

@media screen and (max-width: 1600px){
	.privacy * { font-size: 18px; }
	.privacy > *:not(:last-child){ margin-bottom: 80px; }
	.privacy dl dt{ font-size: 20px; }
	.privacy .textBox dl dt{ font-size: 18px; }
}

@media screen and (max-width: 1280px){
	.privacy * { font-size: 17px; }
	.privacy > *:not(:last-child){ margin-bottom: 60px; }
	.privacy dl dt{ font-size: 19px; }
	.privacy .textBox{ margin-top: 25px; }
	.privacy .textBox dl dt{ font-size: 17px; }

	.privacy .textBox > *:not(:last-child){ margin-bottom: 25px; }
}


/* header */
#header{ width: 100%; position: absolute; top: 0; left: 0; z-index: 999; transform: translateY(0); transition: transform 0.7s; }
#header .flex-box{ height: var(--headerH); display: flex; justify-content: space-between; align-items: center; }
#header .logo img{ width: auto; height: auto; }

#header nav{ text-align: center; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#header nav a{ display: block; font-family: var(--engFont); line-height: 1.3; }
#header nav div{ padding-top: 14px; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); clip-path: inset(0 0 100% 0); -webkit-clip-path: inset(0 0 100% 0); transition: clip-path 0.5s; }

#header .depth01{ display: flex; }
#header .depth01 > li{ position: relative; }
#header .depth01 > li > a{ display: flex; font-size: 17px; font-weight: 500; color: transparent; white-space: nowrap; padding: 10px 30px; position: relative; }
#header .depth01 > li > a::after{ content: ""; width: calc(100% - 60px); height: 2px; background: #FFF; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%) scaleX(0); transition: transform 0.3s; }
#header .depth01 > li > a span{ display: inline-block; padding: 0 3px; position: relative; overflow: hidden; }
#header .depth01 > li > a span::before, 
#header .depth01 > li > a span::after{ content: attr(data-txt); display: block; color: #FFF; position: absolute; }
#header .depth01 > li > a span::before{ top: 0; left: 0; right: 0; transform: translateY(0); }
#header .depth01 > li > a span::after{ top: 0; left: 0; right: 0; transform: translateY(100%); }

#header .depth02{ min-width: 170px; background: rgba(33, 33, 33, 0.7); backdrop-filter: blur(3px); padding: 22px 0; }
#header .depth02 > li{ transform: translateY(100%); clip-path: polygon(0 0, 100% 0, 100% 0, 0 0); -webkit-clip-path: polygon(0 0, 100% 0, 100% 0, 0 0); transition: transform 0.3s 0.1s, clip-path 0.3s 0.1s; }
#header .depth02 > li > a{ font-size: 16px; font-weight: 500; color: rgba(255, 255, 255, 0.4); padding: 8px; transition: color 0.3s; }

#header .right{ display: flex; position: relative; }
#header .right button{ width: 40px; height: 40px; background: none; border: none; padding: 0; transition: opacity 0.5s; will-change: opacity; }
#header .right button div{ height: 100%; display: flex; flex-direction: column; justify-content: space-between; padding: 8px 0; }
#header .right button span{ display: block; height: 2px; background: #FFF; }

#header .menu{ position: relative; overflow: hidden; opacity: 1; transition-delay: 0.2s; }
#header .menu div{ width: calc(100% + 8px); position: relative; left: 0; transform: translateX(0); }
#header .menu div:last-of-type{ position: absolute; top: 0; left: -17px; transform: translateX(-100%); }
#header .menu div span{ position: relative; }
#header .menu div span:nth-of-type(1){ left: 0; }
#header .menu div span:nth-of-type(2){ left: -6px; }
#header .menu div span:nth-of-type(3){ left: -17px; }

#header .close{ opacity: 0; position: absolute; top: 0; left: 0; z-index: 10; pointer-events: none; }
#header .close span{ width: 34px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: transform 0.5s; will-change: transform; }

/* header - up */
#header.up{ transform: translateY(-100%); }

@media screen and (hover: hover) and (pointer: fine){
	#header .depth01 > li:hover > a::after{ transform: translateX(-50%) scale(1); }
	#header .depth01 > li:hover > a span::before{ animation: depth01_before 0.4s both; }
	#header .depth01 > li:hover > a span::after{ animation: depth01_after 0.4s both; }

	#header .depth01 > li:hover div{ clip-path: inset(0 0 0 0); -webkit-clip-path: inset(0 0 0 0); }
	#header .depth01 > li:hover .depth02 > li{ transform: translateY(0); clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); }

	#header .depth02 > li:hover > a{ color: #FFF; }

	#header .menu:hover div{ animation: menu01 1s linear infinite; }
	#header .menu:hover div:last-of-type{ animation: menu02 1s linear infinite; }
}

@media screen and (max-width: 1800px){
	#header .logo img{ height: 45px; }
}

@media screen and (max-width: 1400px){
	#header .depth01 > li > a{ padding-inline: 25px; }
	#header .depth02{ min-width: 150px; padding: 12px 0; }
}

@media screen and (max-width: 1280px){
	#header .logo img{ height: 40px; }

	#header .right button{ width: 35px; height: 35px; }
	#header .right button div{ padding: 6px 0; }
}

@media screen and (max-width: 1000px){
	#header nav{ display: none; }
}


/* menu */
#menu{
	--plr: 80px;
}
#menu{ width: 100%; height: 100%; background: #000; position: fixed; top: 0; left: 0; z-index: 950; overflow: hidden; display: none; }
#menu::before{ content: ""; max-width: 100%; width: 100%; height: 100%; background: url("/img/common/menu_bg.png") no-repeat center right 15% / cover; position: absolute; top: 0; right: 0; transform: translateX(var(--aosP)); opacity: 0; transition: transform var(--aosT) 0.5s, opacity var(--aosT) 0.5s; }
#menu > div,
#menu nav{ height: 100%; }
#menu > div{ padding-top: var(--headerH); position: relative; z-index: 100; }
#menu nav{ display: flex; flex-direction: column; justify-content: center; padding: 0 var(--plr); opacity: 1; transition: opacity 0.5s; }
#menu nav a{ display: block; font-family: var(--engFont); line-height: 1.3; }
#menu .mobile{ display: none; }

#menu .depth01 > li{ display: flex; align-items: center; transform: translateY(var(--aosP)); opacity: 0; transition: transform var(--aosT), opacity var(--aosT); }
#menu .depth01 > li > a{ font-size: 6.5rem; font-weight: 900; color: rgba(255, 255, 255, 0.17); padding: 10px var(--plr); margin-left: calc(var(--plr) * -1); transition: color 0.3s; }

#menu .depth02{ display: flex; flex-wrap: wrap; align-items: center; margin: 0 -20px; }
#menu .depth02 > li{ transform: translateY(100%); clip-path: polygon(0 0, 100% 0, 100% 0, 0 0); -webkit-clip-path: polygon(0 0, 100% 0, 100% 0, 0 0); transition: transform 0.4s, clip-path 0.4s; }
#menu .depth02 > li > a{ font-size: 22px; font-weight: 400; color: rgba(255, 255, 255, 0.4); padding: 10px 20px; -webkit-text-stroke: 0.02em transparent; -webkit-text-stroke: 0.02em transparent; transition: color 0.3s, text-stroke-color 0.3s; }

#menu .depth01 > li.on > a{ color: #FFF; }
#menu .depth01 > li.on .depth02 > li{ transform: translateY(0); clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); }

/* body - open */
body.open #header nav{ opacity: 0; pointer-events: none; }
body.open #header .menu{ opacity: 0; transition-delay: unset; }
body.open #header .close{ opacity: 1; transition-delay: 0.2s; pointer-events: auto; }
body.open #header .close span{ transition-delay: 0.5s; }
body.open #header .close span:first-of-type{ transform: translate(-50%, -50%) rotate(45deg); }
body.open #header .close span:last-of-type{ transform: translate(-50%, -50%) rotate(-45deg); }

body.open #menu::before{ transform: translateX(0); opacity: 1; }
body.open #menu .depth01 > li{ transform: translateY(0); opacity: 1; }


@media screen and (hover: hover) and (pointer: fine){
	#menu .depth01 > li:hover > a{ color: #FFF; }
	#menu .depth02 > li:hover > a{ color: #FFF; text-stroke-color: #FFF; -webkit-text-stroke-color: #FFF; }
}

@media screen and (max-width: 1800px){
	#menu{
		--plr: 50px;
	}
}

@media screen and (max-width: 1280px){
	#menu{
		--plr: 30px;
	}
	#menu .depth02 > li > a{ font-size: 20px; }
}

@media screen and (max-width: 900px){
	#menu{
		--plr: 0;
	}
	#menu::before{ display: none; }
	#menu > div{ padding-block: calc(var(--headerH) + 20px) 20px; }
	#menu nav{ justify-content: flex-start; }
	#menu .pc{ display: none; }
	#menu .mobile{ display: block; }

	#menu .depth01 > li{ display: block; }
	#menu .depth01 > li > a{ font-size: 7.5rem; padding: 7px 15px; }

	#menu .depth01 div{ display: none; }
	#menu .depth02{ display: block; background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(10px); border-top: 1px solid rgba(255, 255, 255, 0.1); border-bottom: 1px solid rgba(255, 255, 255, 0.1); margin: 0; padding: 7px 15px; margin-bottom: 8px; }
	#menu .depth02 > li{ transform: unset; clip-path: unset; -webkit-clip-path: unset; }
	#menu .depth02 > li > a{ padding: 8px 0; }
}


/* footer */
#footer{ padding: var(--footerT) 0 calc(var(--footerT) - 5px); position: relative; z-index: 500; }
#footer .border{ width: calc(100% - 40px); height: 1px; border-top: var(--footerB); position: absolute; top: calc(var(--footerT) * -1); left: 50%; transform: translateX(-50%); }
#footer > div{ position: relative; }
#footer .logo{ position: absolute; top: 0; left: 50%; transform: translateX(-50%); }
#footer .logo img{ width: auto; height: auto; }

#footer .grid-box{ display: grid; grid-template-columns: repeat(2, 50%); }
#footer .grid-box > *{ padding-inline: 20px; }
#footer .grid-box > *:first-of-type{ padding-left: 0; }
#footer .grid-box > *:last-of-type{ padding-right: 0; }
#footer .right{ display: flex; flex-direction: column; justify-content: space-between; align-items: flex-end; padding-bottom: 12px; }

#footer address .flex{ display: flex; flex-wrap: wrap; margin: -22px; }
#footer address dl{ margin: 22px; }
#footer address dl *{ font-family: var(--engFont); font-size: 17px; }
#footer address dl dt{ font-weight: 600; text-transform: uppercase; margin-bottom: 15px; }
#footer address dl dd{ font-weight: 300; color: rgba(255, 255, 255, 0.5); letter-spacing: -0.02em; line-height: 1.4; letter-spacing: -0.02em; }
#footer address dl dd:not(:last-of-type){ margin-bottom: 10px; }
#footer address dl dd *{ line-height: inherit; }
#footer address ul{ display: flex; flex-wrap: wrap; margin: -5px -9px; }
#footer address ul li{ margin: 5px 9px; }

#footer .policy{ display: inline-block; background: #151515; font-size: 18px; font-weight: 400; color: rgba(255, 255, 255, 0.8); padding: 11px 18px; }
#footer .copyright{ font-family: var(--engFont); font-size: 16px; font-weight: 300; color: rgba(255, 255, 255, 0.5); margin-top: 15px; }

#footer .sns{ margin-bottom: 25px; }
#footer .sns ul{ display: flex; justify-content: flex-end; }
#footer .sns ul li:not(:last-of-type){ margin-right: 10px; }
#footer .sns ul li a{ display: block; }
#footer .sns img{ width: auto; height: auto; }

/* main - footer */
.section #footer{ display: flex; flex-direction: column; padding-top: 0; }
.section #footer .border{ display: none; }


/* topBtn */
.topBtn{ width: 70px; height: 70px; background: transparent; border: 1px solid rgba(255, 255, 255, 0.4); position: absolute; top: calc((var(--footerT) + 20px) * -1); right: 20px; transform: translateY(-100%); transition: background 0.3s, border-color 0.3s, opacity 0.3s; }	
.topBtn i{ display: block; height: 10px; background: url("/img/common/top_icon.svg") no-repeat center center / contain; }

@media screen and (hover: hover) and (pointer: fine){
	/* topBtn */
	.topBtn:hover{ background: #CA860D; border-color: #CA860D; }
}

@media screen and (max-width: 1800px){
	/* footer */
	#footer .logo img{ width: auto; height: 65px; }

	#footer .policy{ font-size: 17px; }

	/* topBtn */
	.topBtn{ width: 60px; height: 60px; }
}

@media screen and (max-width: 1500px){
	/* footer */
	#footer .logo img{ height: 50px; }
	#footer .grid-box{ grid-template-columns: calc(100% - 500px) 500px; }
	#footer .logo{ position: static; transform: unset; text-align: center; }
}

@media screen and (max-width: 1280px){
	/* footer */
	#footer address .flex{ margin: -15px; }
	#footer address dl{ margin: 15px; }
	#footer address dl *{ font-size: 16px; }
	#footer address dl dt{ margin-bottom: 10px; }
	#footer address dl dd:not(:last-of-type){ margin-bottom: 6px; }
	#footer address ul{ margin: -3px -7px; }
	#footer address ul li{ margin: 3px 7px; }

	#footer .sns{ margin-bottom: 10px; }
	#footer .sns img{ width: 35px; }

	#footer .policy{ font-size: 16px; padding-inline: 11px; }
	#footer .copyright{ font-size: 15px; }

	/* topBtn */
	.topBtn{ width: 50px; height: 50px; }
	.topBtn i{ height: 8px; }
}

@media screen and (max-width: 1200px){
	/* footer */
	#footer .logo{ margin-bottom: 30px; }
	#footer .grid-box{ grid-template-columns: repeat(1, 100%); }

	#footer .right{ align-items: flex-start; margin-top: 20px; }
	#footer .right .flex{ display: flex; align-items: center; }
	#footer .sns{ margin-bottom: 0; margin-right: 20px; }
}

@media screen and (max-width: 700px){
	/* footer */
	#footer .logo{ text-align: left; } 

	#footer .right .flex{ display: block; position: absolute; top: -10px; right: 0; }

	#footer .sns{ margin-bottom: 10px; }
	#footer .copyright{ margin-top: 0; }
}