/* Scroll Animation */
@media (prefers-reduced-motion: no-preference){
	section:has(:where([data-scroll_effect="slide_left"], [data-scroll_effect="slide_right"])){ overflow: hidden; }
	span[data-scroll_effect]{ display: inline-block; }
	[data-scroll_effect="clip_right"]{ clip-path: inset(0 100% 0 0); transition: .8s; }
	[data-scroll_effect="clip_left"]{ clip-path: inset(0 0 0 100%); transition: .8s; }
	[data-scroll_effect="slide_up"]{ transform: translateY(40rem); opacity: 0; transition: .6s; }
	[data-scroll_effect="slide_left"]{ transform: translateX(40rem); opacity: 0; transition: .6s; }
	[data-scroll_effect="slide_right"]{ transform: translateX(-40rem); opacity: 0; transition: .6s; }
	[data-scroll_effect*="flip_"]{ backface-visibility: hidden; }
	[data-scroll_effect="flip_up"]{ transform: perspective(2500rem) rotateX(-100deg); transition: .6s; }
	[data-scroll_effect="clip_right"].effect_active{ clip-path: inset(0); }
	[data-scroll_effect*="slide_"].effect_active{ transform: translate(0); opacity: 1; }
	[data-scroll_effect*="flip_"].effect_active{ transform: perspective(2500rem) rotateX(0deg); }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="50"]{ transition-delay: .05s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="100"]{ transition-delay: .1s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="150"]{ transition-delay: .15s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="200"]{ transition-delay: .2s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="250"]{ transition-delay: .25s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="300"]{ transition-delay: .3s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="350"]{ transition-delay: .35s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="400"]{ transition-delay: .4s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="450"]{ transition-delay: .45s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="500"]{ transition-delay: .5s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="600"]{ transition-delay: .6s; }
	:where([data-scroll_effect].effect_active) [data-scroll_effect_delay="700"]{ transition-delay: .7s; }
	[data-scroll_effect_delay="50"].effect_active{ transition-delay: .05s; }
	[data-scroll_effect_delay="100"].effect_active{ transition-delay: .1s; }
	[data-scroll_effect_delay="150"].effect_active{ transition-delay: .15s; }
	[data-scroll_effect_delay="200"].effect_active{ transition-delay: .2s; }
	[data-scroll_effect_delay="250"].effect_active{ transition-delay: .25s; }
	[data-scroll_effect_delay="300"].effect_active{ transition-delay: .3s; }
	[data-scroll_effect_delay="350"].effect_active{ transition-delay: .35s; }
	[data-scroll_effect_delay="400"].effect_active{ transition-delay: .4s; }
	[data-scroll_effect_delay="450"].effect_active{ transition-delay: .45s; }
	[data-scroll_effect_delay="500"].effect_active{ transition-delay: .5s; }
	[data-scroll_effect_delay="600"].effect_active{ transition-delay: .6s; }
	[data-scroll_effect_delay="700"].effect_active{ transition-delay: .7s; }
	[data-scroll_effect_column] [data-scroll_effect].effect_active{ transition-delay: calc(var(--index) * calc(var(--delay) * 1ms)); }

	/* data-scroll_effect_delay */
	@media (min-width: 768px){
		[data-scroll_effect].effect_active [data-scroll_effect]{ transform: translate(0); opacity: 1; }
	}
	@media (max-width: 1279px){
		[data-scroll_effect_column] [data-scroll_effect*="slide_"]{ transform: translateY(40rem); }
		[data-scroll_effect_column] [data-scroll_effect*="slide_"].effect_active{ transform: translate(0); }
	}
	@media (max-width: 1279px) and (min-width: 768px){
		:is([data-scroll_effect_column="3"], [data-scroll_effect_column="4"]) > *:nth-child(odd){ transition-delay: 0s; }
		:is([data-scroll_effect_column="3"], [data-scroll_effect_column="4"]) > *:nth-child(even){ transition-delay: calc(var(--delay) * 1ms); }
		:is([data-scroll_effect_column="5"], [data-scroll_effect_column="6"]) > *:nth-child(4){ transition-delay: calc((var(--index) - 1 ) * calc(var(--delay) * 1ms)); }
		:is([data-scroll_effect_column="5"], [data-scroll_effect_column="6"]) > *:nth-child(5){ transition-delay: calc((var(--index) - 2 ) * calc(var(--delay) * 1ms)); }
		:is([data-scroll_effect_column="5"], [data-scroll_effect_column="6"]) > *:nth-child(6){ transition-delay: calc((var(--index) - 3 ) * calc(var(--delay) * 1ms)); }
	}
	@media (max-width: 767px){
		#wrap [data-scroll_effect_delay]{ transition-delay: 0s; }
		[data-scroll_effect_column] > *:nth-child(odd){ transition-delay: 0s; }
		[data-scroll_effect_column] > *:nth-child(even){ transition-delay: calc(var(--delay) * 1ms); }
	}
	@keyframes svgAni{
		0%{ stroke-dasharray: var(--total_length); stroke-dashoffset: var(--total_length); }
		100%{ stroke-dasharray: var(--total_length); stroke-dashoffset: 0; }
	}
	svg.scroll_effect{ opacity: 1; transform: translate(0); }
	svg.active{ animation: svgAni 1s linear both; }

	/* stroke-dasharray 최대값 */
	svg *{ stroke-dasharray: var(--total_length); stroke-dashoffset: var(--total_length); opacity: 1; transform: translate(0); }
	svg.effect_active *{ animation: svgAni 1s linear both; }
}

/* inner */
.inr{ position: relative; margin: 0 auto; max-width: calc(var(--inner) * 1rem); width: calc(var(--inner_width) * 100%); height: 100%; box-sizing: border-box; z-index: 2; }
.inr.wide{ max-width: 1760rem; }
.inr.narrow{ max-width: 1280rem; }
.wrapper{ margin: 0 auto; max-width: calc(var(--inner2) * 1rem); width: calc(var(--inner_width) * 100%); }

/* header */
:root{
	--header_height: 80rem;
}
.header{ height: var(--header_height); }
#header{  width: 100%; border-bottom: 1px solid rgba(255, 255, 255, 0.3); color: #444; z-index: 100; background: #fff; position: relative;}
.header__inr{ display: flex; justify-content: space-between; align-items: center; height: 100%; z-index: unset; height: 80rem;}
.logo{ display: inline-block; position: relative; z-index: 1; }
.logo__a{ display: block; font-size: 0; }

#header nav{ position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
#header .gnb{ display: flex; position: relative; height: 100%; }
#header .gnb > li{ display: inline-block; position: relative; height: 100%; pointer-events: auto; }
#header .gnb [data-gnb="1"]{ display: flex; align-items: center; height: 100%; padding: 0 40rem; font-size: 18rem; font-weight: 700; }
#header .gnb .sub_menu{ visibility: hidden; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); min-width: 120px; width: max-content; background: #fff; border: 1px solid #ddd; opacity: 0; }
#header .gnb li:hover .sub_menu{ visibility: visible; top: 100%; opacity: 1; }
#header .gnb .sub_menu li a{ display: block; padding: 14px; color: #333; border-top: 1px solid #ddd; font-size: 14px; text-align: center; }
#header .gnb .sub_menu li a:hover{ background: var(--primary); color: #fff; }
#header .gnb .sub_menu li:first-child a{ border-top: 0; }

/* mobile-menu */
.btn_menu{ position: relative; display: flex; flex-direction: column; gap: 7rem; box-sizing: border-box;  z-index: 1; }
.btn_menu span{ display: block; width: 30rem; height: 3px; background: currentcolor; }
@media(prefers-reduced-motion:no-preference){
	#header,
	.logo__img,
	.gnb .sub_menu,
	.btn_menu span{ transition: .4s; }
}
@media (max-width: 1279px){
	#header .gnb{ display: none; }
	#header .gnb .sub_menu li:first-child a{ position: relative;}
}
@media (max-width: 480px){
	.logo__img {width: 140px;}

}




/* 모바일 메뉴 */
.area_util_m { color: #fff; }
.area_util_m .logo {padding: 20rem;}
.area_util_m div {display: flex; gap: 20rem; background: var(--primary); align-items: center;}
.area_util_m div div {padding: 20rem;}
.area_util_m span {background: #fff; border-radius: 50%; padding: 10rem;}
.area_util_m a {font-size: 42rem; font-weight: 600;}
.m_gnb{ overflow: hidden auto; position: fixed; top: 0; right: 0; transform: translateX(100%); max-width: 30%; width: 100%; height: 100%; background: var(--white); transition-timing-function: ease-out; z-index: 3; }
.m_gnb .header{ display: flex; align-items: center; justify-content: flex-end; }
.m_gnb > ul > li > a{ display: block; position: relative; padding: 15rem 25rem; border-bottom: 1rem solid #eaeaea; color: #424242; transition: all .3s ease 0s; }
.m_gnb > ul > li:first-child > a{ border-top: 1rem solid #eaeaea; }
.m_gnb > ul > li > a.open::before{ content: ''; display: block; position: absolute; top: 50%; transform: translateY(-50%); right: 10rem; width: 11rem; height: 7rem; background: url('../images/common/menu_button.svg') no-repeat 50% 0; transition: all .4s ease 0s; background-size: 100%; }
.m_gnb > ul > li > a.active::before{ transform: translateY(-50%) rotate(180deg); }
.m_gnb .sub_menu{ display: none; background: #efefef; }
.m_gnb .sub_menu > li{ border-bottom: 1rem solid #dedede; }
.m_gnb .sub_menu > li > a{ position: relative; display: block; padding: 15rem 25rem; font-size: 14rem; color: var(--black); }

.m_gnb .btn_close{ opacity: 0; flex: 0 0 25rem; display: block; position: relative; margin-right: -100vw; width: 22rem; height: 22rem; background: 0; font-size: 0; }
.m_gnb.active{ transform: translateX(0); }
.m_gnb.active .btn_close{ opacity: 1; margin: 20rem 20rem auto auto;}

.m_gnb .btn_close::before,
.m_gnb .btn_close::after{ content: ''; display: block; position: absolute; top: 50%; left: 0; width: 100%; height: 1rem; background: var(--black); transform: translateY(-50%) rotate(45deg); }
.m_gnb .btn_close::after{ transform: translateY(-50%) rotate(-45deg); }

.cover{ position: fixed; width: 100%; height: 100%; left: 0; top: 0; background: rgba(0, 0, 0, .4); visibility: hidden; opacity: 0; z-index: 2; }
.cover.active{ visibility: visible; opacity: 1; }

@media (prefers-reduced-motion: no-preference){
	.m_gnb{ transition-duration: .5s; }
	.m_gnb .btn_close{ transition: .8s; }
	.cover{ transition: .4s; }
}

@media (max-width: 1279px){
	.area_util_m a {font-size: 32rem; }
	.m_gnb {max-width:40%;}


}
@media (max-width: 767px){
	.area_util_m a {font-size: 22rem;}
	.area_util_m span img {width: 22rem; margin-top: 1rem;}
	.m_gnb {max-width: 60%;}

}


/* footer */
.address {display: flex; flex-direction: column; gap: 20rem;}
.address h2 {margin-bottom: 6rem; font-size: 18rem;} 
#footer{ padding: 70rem 0; background: #fff; color: #000; }
#footer .inr {display: flex; justify-content: space-between;}
.logo_wrap {display: flex; flex-direction: column; justify-content: space-between;}
.footer__logo{ margin-right: 19rem; font-size: 24rem; font-weight: 900; }
.footer__address{ font-weight: 500;  display: flex; flex-wrap: wrap; gap: 0rem 29rem; max-width: 920rem; }
.footer__address b{ margin-left: 10rem; font-weight: 500;  opacity: 0.6;}
.footer__copyright{ margin-top: 22rem; text-transform: uppercase; font-size: 15rem; font-weight: 500; }
@media(max-width:1279px){
	#footer .inr {display: flex; flex-direction: column; gap: 15rem;}

}
@media(max-width:767px){
	.footer_links{ flex-wrap: wrap; justify-content: space-between; }
	.footer_links li:first-child{ flex: 1 100%; }
	.footer__address{ flex-direction: column; }
}