@charset 'utf-8';

/* °ψΕλ */
:root{
	--baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--Space: 'Space Grotesk', sans-serif;
	--Poppins: 'Poppins', sans-serif;
	--Noto: 'Noto Sans KR', sans-serif;
	--mainColor: #00ACCC;
}

.w1720{ max-width: 1720px; width: 100%; margin: 0 auto; }

@media screen and (max-width: 1760px){
	.w1720{ padding: 0 20px; }
}

/* privacy */
.privacy { color:#666; width: 100%; overflow: hidden; box-sizing:border-box; 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: 2rem;color:var(--mainColor);font-weight:700;padding-bottom:5px;}
.privacy > dl > dd{ padding-bottom:10px;text-align:justify; font-size: 1.8rem; 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; }

@media screen and (max-width: 1600px){
	#policy br{ display: none; }
}

@media screen and (max-width: 1200px){
	.privacy > dl > dt{ font-size: 2rem; }
	.privacy > dl > dd{ font-size: 1.6rem; }
}


/* header */
#header{ width: 100%; position: fixed; top: 0; left: 0; z-index: 100; background: #fff; transition: transform 0.5s ease; }
#header .flex-box{ display: flex; justify-content: space-between; align-items: center; padding: 57px 0; position: relative; } 

#header .logo{ display: inline-block; position: relative; }
#header .logo img{ transition: opacity 0.5s; }
#header .logo::after{ content: url("/img/common/scroll_logo_white_en.png"); position: absolute; top: 55%; left: 50%; transform: translate(-50%, -50%); opacity: 0; transition: opacity 0.5s; }
#header .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

#header nav{ width: max-content; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#header .depth01{ display: flex; }
#header .depth01 > li{ position: relative; }
#header .depth01 > li > a{ display: inline-block; font-family: var(--No); font-size: 2rem; font-weight: 500; color: #111; padding: 25px 50px; letter-spacing: -0.02em; }
#header .depth02{ width: 180px; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); padding: 22.5px 0 20px; background: #fff; border-radius: 20px; box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15); display: none; overflow: hidden; }
#header .depth02 > li > a{ display: inline-block; width: 100%; text-align: center; font-family: var(--Poppins); font-size: 1.6rem; font-weight: 400; color: #aaa; letter-spacing: -0.02em; padding: 10.5px 16px; }
#header .depth02 > li > a:hover{ color: var(--mainColor); }

#header .sub-menu{ display: flex; align-items: center; }
#header .sub-menu > div{ position: relative; margin-right: 10px; }
#header .sub-menu > div::before{ content: ""; width: 100%; height: 0; border-radius: 100px; background: var(--mainColor); position: absolute; top: -10px; left: 50%; transform: translateX(-50%); transition: all 0.5s cubic-bezier(0.175, 0.885, 0.320, 1.275); }
#header .sub-menu button{ border: none; background: none; position: relative; }
#header .sub-menu button::after{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: opacity 0.3s; opacity: 0; }
#header .sub-menu button.lang::after{ content: url("/img/common/lang_icon_white.png"); }
#header .sub-menu button.sitemap::after{ content: url("/img/common/menu_icon_white.png"); }
#header .sub-menu button img{ transition: opacity 0.3s; transition-delay: 0.3s; }
#header .sub-menu a{ width: 100%; position: absolute; top: calc(100% + 10px); left: 0; font-size: 1.3rem; font-weight: 700; color: #fff; text-align: center; visibility: hidden; transition: opacity 0.5s; opacity: 0; }

#header .sub-menu > div:hover::before{ height: 75px; }
#header .sub-menu > div:hover button::after{ opacity: 1; }
#header .sub-menu > div:hover button img{ opacity: 0; transition-delay: unset; }
#header .sub-menu > div:hover a{ visibility: visible; opacity: 1; }

#header.down{ transform: translateY(-100%); }

#header.black{ background: #000; }
#header.black .logo img{ opacity: 0; }
#header.black .logo::after{ opacity: 1; }
#header.black .sub-menu button::after{ opacity: 1; }
#header.black .sub-menu button img{ opacity: 0; }
#header.black .depth01 > li > a{ color: #fff; }

@media screen and (max-width: 1500px){
	#header .flex-box{ padding: 30px 0; }
	#header .depth01 > li > a{ padding: 25px 40px; }
}

@media screen and (max-width: 1300px){
	#header nav{ display: none; }
	#header .flex-box{ padding: 15px 0; }
}


/* footer */
#footer{ background: #000; padding-top: 88px; padding-bottom: 120px; position: relative; z-index: 10; }
#footer *{ color: #fff; }
#footer .logo{ display: inline-block; position: relative; margin-top: 11px; }
#footer .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }

#footer .flex-box{ display: flex; justify-content: space-between; }
#footer .first{ margin-bottom: 45px; }
#footer .depth01 > li > a{ display: inline-block; font-family: var(--Space); font-size: 2.2rem; font-weight: 500; letter-spacing: -0.01em; text-transform: uppercase; padding: 9px 0; }
#footer .slogan{ text-align: right; }
#footer .slogan h3{ font-family: var(--Space); font-size: 5.4rem; font-weight: 600; letter-spacing: -0.02em; margin-top: 20px; text-transform: uppercase; }

#footer .family-site{ text-align: right; }  
#footer .select{ display: inline-block; width: 200px; border: 1px solid rgba(255, 255, 255, 0.2); padding: 18px 30px; position: relative; cursor: pointer; }
#footer .select p{ font-size: 1.5rem; font-weight: 400; letter-spacing: -0.01em; color: rgba(255, 255, 255, 0.8); text-transform: uppercase; text-align: left; position: relative; }
#footer .select p::after{ content: url("/img/common/select_icon.png"); position: absolute; top: 50%; right: 0; transform: translateY(-50%); transition: 0.3s ease-out; }
#footer .select ul{ width: calc(100% + 2px); position: absolute; bottom: calc(100% + 1px); left: -1px; z-index: 10; padding: 10px 0; background: #000; border: 1px solid rgba(255, 255, 255, 0.2); border-bottom: none; display: none; }
#footer .select ul li a{ display: inline-block; width: 100%; font-size: 1.5rem; font-weight: 400; letter-spacing: -0.01em; text-align: left; padding: 10px 30px; opacity: 0.8; transition: 0.3s; }

#footer .select ul li:hover a{ opacity: 1; }
#footer .select.on p::after{ transform: translateY(-50%) rotate(-180deg); }

@media screen and (max-width: 1500px){
	#footer .slogan h3{ font-size: 4.5rem; }
}

@media screen and (max-width: 1250px){ 
	#footer{ padding-top: 20px; padding-bottom: 100px; }
	#footer .slogan h3{ font-size: 3.5rem; }
	#footer .select{ width: 180px; padding: 15px 20px; }
	#footer .select ul li a{ padding: 10px 20px; }
}

@media screen and (max-width: 800px){
	#footer .footer-nav{ display: none; }
	#footer .first{ justify-content: center; margin-bottom: 20px; }  
	#footer .slogan h3{ display: none; }
	#footer .flex-box{ flex-direction: column; align-items: center; }
	#footer .family-site{ text-align: center; }
	#footer .select{ width: 170px; padding: 10px 20px; }
	#footer .select ul{ padding: 5px 0; }
	#footer .select ul li a{ padding: 10px 20px; }
	#footer .info p{ margin-top: 20px; }
}


#footer .info{ margin-top: 35px; }
#footer .info ul{ display: flex; margin-left: -20px; }
#footer .info ul li{ position: relative; }
#footer .info ul li::after{ content: ""; width: 1px; height: 14px; background: #888; position: absolute; top: 48%; right: 0; transform: translateY(-50%); }
#footer .info ul li:last-of-type::after{ display: none; }
#footer .info ul li a{ display: inline-block; font-size: 1.6rem; font-weight: 400; letter-spacing: -0.02em; opacity: 0.6; padding: 0 20px; }
#footer .info ul li:first-of-type a{ opacity: 0.8; }
#footer .info p{ font-size: 1.6rem; font-weight: 400; letter-spacing: -0.02em; }

#sitemap{ width: 100%; height: 100vh; position: fixed; top: 0; left: 0; z-index: 100; background: #000; display: none; }
#sitemap .header{ padding: 55px 0; margin-bottom: 70px; }
#sitemap .flex-box{ display: flex; justify-content: space-between; align-items: center; }
#sitemap .logo{ display: inline-block; position: relative; }
#sitemap .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
#sitemap .close{ width: 35px; height: 35px; background: none; border: none; margin-right: -8px; }

#sitemap .moblie{ display: none; }

#sitemap .depth01 *{ color: #fff; }
#sitemap .depth01{ display: flex; } 
#sitemap .depth01 > li{ width: calc(100% / 6); height: calc(100vh - 285px); padding: 0 40px 60px; border-right: 1px solid rgba(255, 255, 255, 0.15); }  
#sitemap .depth01 > li:first-of-type{ border-left: 1px solid rgba(255, 255, 255, 0.15); }
#sitemap .depth01 > li > a{ display: inline-block; width: 100%; font-family: var(--Space); font-size: 3rem; font-weight: 500; letter-spacing: -0.01em; text-transform: uppercase; padding: 60px 0 50px; }

#sitemap .depth02 > li > a{ display: inline-block; width: 100%; font-family: var(--Poppins); font-size: 2rem; font-weight: 400; opacity: 0.35; padding: 10px 0; }

@media screen and (max-width: 1600px){
	#sitemap .depth01 > li{ padding: 0 20px 40px; } 
}

@media screen and (max-width: 1580px){
	#sitemap .header{ margin-bottom: 100px; }
	#sitemap .depth01 > li > a{ font-size: 2.8rem; padding: 40px 0 30px; }
}

@media screen and (max-width: 1500px){
	#sitemap .header{ padding: 30px 0; }
}

@media screen and (max-width: 1300px){
	#sitemap .header{ padding: 15px 0; }
	#sitemap .depth01 > li > a{ font-size: 2.5rem; }
	#sitemap .depth02 > li > a{ font-size: 1.8rem; }
}

@media screen and (max-width: 1200px){
	#sitemap .header{ margin: 0; }
	#sitemap .nav{ height: calc(100% - 66px); }
	#sitemap .nav > div{ height: 100%; }
	#sitemap .pc{ display: none; }
	#sitemap .moblie{ display: block; height: 100%; }
	#sitemap .depth01{ height: 100%; flex-direction: column; justify-content: center; align-items: center; text-align: center; } 
	#sitemap .depth01 > li{ width: 100%; height: auto; border: none; padding: 0; position: relative; }
	#sitemap .depth01 > li::after{ content: ""; width: 100%; height: 62.5px; position: absolute; top: 0; left: 0; cursor: pointer; }
	#sitemap .depth01 > li.none::after{ display: none; }
	#sitemap .depth01 > li:first-of-type{ border: none; }
	#sitemap .depth01 > li > a{ font-size: 3rem; padding: 15px 0; margin-bottom: -10px; }
	#sitemap .depth02{ display: none; }
	#sitemap .depth02{ padding: 0; position: relative; z-index: 10;}
	#sitemap .depth02 > li > a{ font-size: 2rem; }
}

/* top */
#top{ width: 60px; height: 60px; position: fixed; bottom: 20px; right: 20px; z-index: 50; background: none; border: 1px solid #000; border-radius: 50%; transition: border 0.3s; backdrop-filter: blur(4px); }
#top::after{ content: url("/img/common/top_button_white.svg"); display: inline-block; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: opacity 0.3s; opacity: 0; }
#top img{ transition: opacity 0.3s; }

#top.white{ border: 1px solid #fff; }
#top.white::after{ opacity: 1; }
#top.white img{ opacity: 0; }
  

@media screen and (max-width: 800px){
	#top{ width: 50px; height: 50px; }
}