@charset 'utf-8';

/* ���� */
:root{
    --baseFont: 'Open Sans', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;

	--mainColor: #E30413;
	--mainRGB: 227, 4, 19;
	--green: #80BA27;
	--greenRGB: 128, 186, 39;

	--headerH: 100px;

	--vh: 100%;
	--resizeVH: 100vh;

	--aosP: 100px;
	--aosM: -100px;
	--aosT: 700ms;
}

*{ box-sizing: border-box; word-break: keep-all; }
body.lock{ overflow: hidden; }
body{ font-family: var(--baseFont); font-size: 16px; letter-spacing: -0.02em; line-height: 1.3; }
body *{ font-family: inherit; font-size: inherit; line-height: inherit; }

/* inner */
.w1820{ max-width: 1860px; 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; }

/* scroll-y */
.scroll-y{ overflow-x: clip; overflow-y: auto; }
.scroll-y::-webkit-scrollbar{ width: 45px; height: 45px; }
.scroll-y::-webkit-scrollbar-thumb{ min-height: 100px; background: #222; background-clip: padding-box; border: 20px solid transparent; border-radius: 100px; }
.scroll-y::-webkit-scrollbar-track{ background: #EEE; background-clip: padding-box; border: 20px solid transparent; border-radius: 100px; }

/* aos */
[data-aos]{ transition-duration: var(--aosT); }

@media (hover: hover) and (pointer: fine) {
	:root{
		--resizeVH: var(--vh);
	}
}

@media screen and (max-width: 1700px){
	:root{
		--headerH: 90px;
	}
	html{ font-size: 50%; }
}

@media screen and (max-width: 1550px){
	:root{
		--headerH: 80px;
	}
}

@media screen and (max-width: 1280px){
	:root{
		--aosP: 50px;
		--aosM: -50px;
	}

	html{ font-size: 40%; }
}

@media screen and (max-width: 900px){
	html{ font-size: 35%; }
}


/* header */
header{
	--before: 150px;
	--after: 200px;
	--snsH: 40px;
	--radiusH: 60px;
}
header{ width: 100%; text-align: center; position: absolute; top: 0; left: 0; z-index: 1000; }
header::after{ content: ""; width: 100%; height: 1px; background: #E6E6E6; position: absolute; bottom: 0; left: 0; opacity: 0; z-index: -1; transition: opacity 0.4s; pointer-events: none; }
header .blackBg{ width: 100%; height: 100vh; background: rgba(0, 0, 0, 0.6); position: fixed; top: 0; left: 0; z-index: -2; opacity: 0; transition: opacity 0.4s; pointer-events: none; }
header .navBg{ height: var(--navH); background: #FFF; position: absolute; top: 0; left: 0; right: 0; z-index: -1; opacity: 0; transition: opacity 0.4s; pointer-events: none; }
header .flex-box{ height: var(--headerH); display: flex; justify-content: space-between; align-items: center; }
header .flex-box > *{ display: flex; align-items: center; }

header nav{ margin-left: 65px; opacity: 1; transition: opacity var(--aosT); }
header nav .all,
header nav .hidden{ display: none; }
header .depth01{ display: flex; }
header .depth01 > li{ width: var(--before); position: relative; z-index: 10; transition: width 0.4s; }
header .depth01 > li > a{ height: var(--headerH); display: flex; justify-content: center; align-items: center; font-size: 18px; font-weight: 600; color: #FFF; text-stroke: 0.012em transparent; -webkit-text-stroke: 0.012em transparent; position: relative; transition: color 0.4s, text-stroke-color 0.4s; }
header .depth01 > li > a::after{ content: ""; width: 100%; height: 1px; background: var(--mainColor); position: absolute; bottom: 0; left: 0; transform: scaleX(0); transition: transform 0.4s; }
header .depth01 > li > div{ width: var(--after); height: var(--navH); position: absolute; top: 0; left: 50%; z-index: -1; transform: translateX(-50%); opacity: 0; transition: opacity 0.4s; pointer-events: none; }

header .depth02{ padding: calc(var(--headerH) + 12px) 0 15px; }
header .depth02 > li > a{ display: block; font-size: 17px; font-weight: 600; color: #AAA; line-height: 1.3; padding: 8px 0; transition: color 0.4s; }

header .sns{ display: flex; align-items: center; }
header .sns > *:not(:last-child){ margin-right: 5px; }
header .sns button{ width: var(--snsH); height: var(--snsH); background: #FFF; border: none; border-radius: 50%; padding: 0; transition: background 0.4s; }
header .sns > a{ height: var(--snsH); display: inline-flex; align-items: center; background: rgba(255, 255, 255, 0.2); border-radius: 99px; font-size: 14px; font-weight: 600; color: #FFF; padding: 0 20px; transition: background 0.4s, color 0.4s; }

header .lang{ position: relative; }
header .lang > div{ padding-top: 10px; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); pointer-events: none; }
header .lang.active > div{ pointer-events: auto; }
header .lang ul{ background: var(--mainColor); border-radius: 5px; padding: 7px 0; display: none; }
header .lang ul li a{ display: block; font-size: 16px; font-weight: 600; color: rgba(255, 255, 255, 0.4); line-height: 1.3; padding: 3px 15px; }
header .lang ul li.on a{ color: #FFF; }

header .radius{ display: flex; margin-left: 10px; }
header .radius a{ height: var(--radiusH); display: inline-flex; align-items: center; background: var(--green); border-radius: 99px 0 0 99px; font-size: 16px; font-weight: 500; color: #FFF; padding: 0 20px; }
header .radius a i{ display: inline-block; width: 14px; height: 16px; background: url("/img/common/icon_marker.svg") no-repeat center center / contain; margin-right: 10px; }
header .radius button{ height: var(--radiusH); display: inline-flex; flex-direction: column; justify-content: center; background: var(--mainColor); border: 1px solid rgba(255, 255, 255, 0.3); border-left-width: 0; border-radius: 0 99px 99px 0; padding: 0 21px; }

header .menu span{ display: inline-block; width: 18px; height: 2px; background: #FFF; vertical-align: middle; position: relative; top: 0; left: 0; transform: rotate(0); opacity: 1; transition: top 0.4s, transform 0.4s, opacity 0.4s; will-change: top, transform, opacity; }
header .menu span:not(:last-of-type){ margin-bottom: 3px; }


/* header - scroll */
header.scroll::after{ opacity: 1; }
header.scroll .depth01 > li > a{ color: #111; text-stroke-color: #111; -webkit-text-stroke-color: #111; }
header.scroll .sns button{ background: #F8F8F8; }
header.scroll .sns > a{ background: #F8F8F8; color: #CCC; }

/* header - hover */
header.hover::after{ opacity: 1; }
header.hover .blackBg{ opacity: 1; }
header.hover .navBg{ opacity: 1; }
header.hover .sns button{ background: #F8F8F8; }
header.hover .sns > a{ background: #F8F8F8; color: #CCC; }


@media screen and (hover: hover) and (pointer: fine){
	header .depth01:hover > li{ width: var(--after); }
	header .depth01:hover > li > a{ color: #111; text-stroke-color: #111; -webkit-text-stroke-color: #111; }
	header .depth01:hover > li > div{ opacity: 1; pointer-events: unset; }

	header .depth01 > li:hover > a{ color: var(--mainColor); text-stroke-color: var(--mainColor); -webkit-text-stroke-color: var(--mainColor); }
	header .depth01 > li:hover > a::after{ transform: scaleX(1); }
	header .depth02 > li:hover > a{ color: var(--mainColor); }
}

@media screen and (max-width: 1750px){
	header{
		--before: 150px;
		--after: 180px;
		--radiusH: 55px;
	}
	header nav{ margin-left: 40px; }
}

@media screen and (max-width: 1650px){
	header{
		--before: 145px;
		--snsH: 37px;
		--radiusH: 50px;
	}
	header h1 img{ width: auto; height: 50px; }

	header nav{ margin-left: 20px; }

	header .radius a{ font-size: 15px; padding: 0 13px; }
	header .radius a i{ width: 12px; height: 14px; margin-right: 7px; }
	header .radius button{ padding: 0 18px; }
}

@media screen and (max-width: 1550px){
	header{
		--before: 140px;
		--after: 160px;
	}
	header nav{ margin-left: 5px; }
	header .depth01 > li > a{ font-size: 16px; }
	header .depth02 > li > a{ font-size: 16px; }
}

@media screen and (max-width: 1420px){
	header nav{ display: none; }
}

@media screen and (max-width: 700px){
	header .clone{ display: none !important; }

	header .radius a{ display: none; }
	header .radius button{ width: var(--radiusH); align-items: center; border-radius: 50%; border-left-width: 1px; padding: 0; }
}


/* menu */
#menu{
	--left: 680px;
	--ptb: 80px;
	--delay: var(--aosT);
}
#menu{ width: 100%; height: 100%; background: linear-gradient(103deg, #E30413 0%, #AE000C 100%); position: fixed; top: 0; left: 0; z-index: 999; clip-path: circle(0% at 100% 0); -webkit-clip-path: circle(0% at 100% 0); clip-path: circle(0 at calc(var(--vw) - ((var(--vw) - 1820px) / 2) - 30px) calc(var(--headerH) / 2)); -webkit-clip-path: circle(0 at calc(var(--vw) - ((var(--vw) - 1820px) / 2) - 30px) calc(var(--headerH) / 2)); opacity: 0; transition: clip-path var(--aosT) 0.1s, opacity 0.1s var(--delay); }
#menu .mobile{ display: none; }
#menu > div,
#menu nav{ height: 100%; }
#menu nav .all,
#menu nav .hidden{ display: none; }
#menu nav a{ font-weight: 700; color: rgba(255, 255, 255, 0.3); line-height: 1.3; transition: color 0.4s; }
#menu nav{ display: flex; flex-direction: column; justify-content: center; transform: translateY(var(--aosP)); opacity: 0; transition: transform 0.5s var(--aosT), opacity 0.5s var(--aosT); }
#menu .depth01{ position: relative; padding: calc(var(--ptb) - 10px) 0; }
#menu .depth01::after{ content: ""; width: 1px; height: 100%; background: rgba(255, 255, 255, 0.3); position: absolute; top: 0; left: var(--left); }
#menu .depth01 > li{ width: var(--left); }
#menu .depth01 > li > a{ display: block; font-size: 7.8rem; padding: 10px 0; }
#menu .depth01 > li > div{ width: calc(100% - var(--left)); padding: 0 100px; position: absolute; top: var(--ptb); right: 0; transition: opacity 0.4s; }
#menu .depth01 > li:not(.on) > div{ opacity: 0; pointer-events: none; }
#menu .depth02 > li > a{ display: block; font-size: 24px; padding: 15px 0; }

#menu .depth01 > li.on > a{ color: #FFF; }

#menu .link{ display: none; text-align: right; padding-top: var(--headerH); position: absolute; top: 0; left: 0; right: 0; }
#menu .link > div{ display: flex; justify-content: flex-end; align-items: center; }
#menu .link > div > *:not(:last-child){ margin-right: 10px; }
#menu .link a, 
#menu .link button{ height: 40px; }
#menu .link a{ display: inline-flex; justy-content: center; align-items: center; background: rgba(255, 255, 255, 0.2); border-radius: 99px; font-size: 15px; font-weight: 500; color: #FFF; padding: 0 21px; }
#menu .link a:not(:last-of-type){ margin-right: 7px; }
#menu .link button{ width: 40px; background: rgba(255, 255, 255, 0.2); border: none; border-radius: 50%; padding: 0; }
#menu .link button img{ filter: grayscale(1) brightness(5); -webkit-filter: grayscale(1) brightness(5); }

/* body - open */
body.open{ overflow: hidden; }
body.open header::after{ opacity: 0; }
body.open header nav{ opacity: 0; pointer-events: none; }
body.open header .menu span:nth-of-type(1){ top: 5px; transform: rotate(45deg); }
body.open header .menu span:nth-of-type(2){ opacity: 0; }
body.open header .menu span:nth-of-type(3){ top: -5px; transform: rotate(-45deg); }
body.open #menu{ --delay: 0.1s; opacity: 1; clip-path: circle(250vh at 100% 0); -webkit-clip-path: circle(250vh at 100% 0); }
body.open #menu nav{ 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; }
}

@media screen and (max-width: 1760px){
	body #menu{ clip-path: circle(0 at calc(var(--vw) - 50px) calc(var(--headerH) / 2)); -webkit-clip-path: circle(0 at calc(var(--vw) - 50px) calc(var(--headerH) / 2)); }
}

@media screen and (max-width: 1700px){
	#menu{
		--left: 550px;
	}
	#menu .depth01 > li > div{ padding: 0 70px; }
	#menu .depth02 > li > a{ font-size: 22px; }
}

@media screen and (max-width: 1280px){
	#menu{
		--left: 450px;
	}
	#menu .depth01 > li > div{ padding: 0 50px; }
	#menu .depth02 > li > a{ font-size: 20px; }
}

@media screen and (max-width: 1000px){
	#menu{
		--left: 400px;
	}
	#menu .depth01 > li > a{ font-size: 7rem; }
}

@media screen and (max-width: 900px){
	#menu > div{ padding-top: var(--headerH); }
	#menu .pc{ display: none; }
	#menu .mobile{ display: block; }

	#menu nav{ height: 100%; overflow-x: clip; overflow-y: auto; -ms-overflow-style: none; justify-content: unset; }
	#menu nav::-webkit-scrollbar{ display: none; }
	#menu nav .all{ display: block; }
	#menu .depth01{ padding: 0; border-top: 1px solid rgba(255, 255, 255, 0.3); }
	#menu .depth01::after{ display: none; }
	#menu .depth01 > li{ width: 100%; border-bottom: 1px solid rgba(255, 255, 255, 0.3); }
	#menu .depth01 > li > a{ font-size: 6rem; color: #FFF; padding: 15px; }
	#menu .depth01 > li > div{ width: 100%; background: #FFF; border-radius: 20px; position: static; padding: 10px 0; margin-bottom: 20px; opacity: 1 !important; pointer-events: unset !important; display: none; }
	#menu .depth02 > li > a{ color: rgba(17, 17, 17, 0.5); padding: 10px 20px; }
}

@media screen and (max-width: 900px) and (hover: hover) and (pointer: fine){
	#menu .depth02 > li:hover > a{ color: #111; }
}

@media screen and (max-width: 700px){
	#menu > div{ padding-top: calc(var(--headerH) + 60px); }
	#menu .link{ display: block; }
	#menu nav .hidden{ display: block; }
}



/* footer */
footer{ font-size: 18px; padding-bottom: 40px; position: relative; }
footer h1 img{ width: auto; height: 70px; }
footer .bottom{ display: flex; justify-content: space-between; align-items: flex-end; }

footer .left a,
footer .left .copyright{ font-weight: 600; color: #111; }
footer .left a{ display: inline-block; line-height: 1.3; padding: 10px; margin-top: -10px; margin-left: -10px; }
footer .left .copyright{ margin-top: 10px; }
footer .left address p{ font-weight: 400; color: #333; }

footer .right{ display: flex; align-items: flex-end; }
footer .sns{ margin-right: 20px; }
footer .sns ul{ display: flex; }
footer .sns ul li:not(:last-of-type){ margin-right: 10px; }
footer .sns ul li a{ display: inline-block; background: #F8F8F8; border-radius: 50%; }
footer .sns ul li svg{ width: 50px; height: auto; }


/* top */
#top{ width: 110px; height: 110px; background: transparent; border: 2px solid var(--mainColor); border-radius: 15px; font-size: 32px; font-weight: 800; color: var(--mainColor); padding: 0; position: relative; overflow: hidden; transition: background 0.4s; }
#top span{ width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; transform: translateY(0); transition: transform 0.4s; }
#top span i{ display: block; height: 8px; background: url("/img/common/icon_top.svg") no-repeat center center / contain; margin-bottom: 5px; }
#top span:last-of-type{ font-weight: 700; color: #FFF; }
#top span:last-of-type i{ filter: grayscale(1) brightness(5); -webkit-filter: grayscale(1) brightness(5); } 

@media screen and (hover: hover) and (pointer: fine){
	#top:hover{ background: var(--mainColor); }
	#top:hover span{ transform: translateY(-100%); }
}

@media screen and (max-width: 1700px){
	footer h1 img{ height: 60px; }

	/* top */
	#top{ width: 95px; height: 95px; font-size: 28px; }
}

@media screen and (max-width: 1280px){
	footer{ font-size: 17px; padding-bottom: 30px; }
	footer h1 img{ height: 55px; }
	footer .sns ul li img{ width: 45px; }

	/* top */
	#top{ width: 80px; height: 80px; font-size: 24px; }
}

@media screen and (max-width: 700px){
	footer .bottom{ flex-direction: column-reverse; align-items: flex-start; }
	footer .sns{ margin: 12px 0; }

	/* top */
	#top{ width: 75px; height: 75px; font-size: 21px; position: absolute; top: 0; right: 20px; }
}