/* common */
.ptH{ padding-top: var(--headerH); }

/* title-box */
.title-box.mb40{ margin-bottom: 40px; }
.title-box p{ font-size: var(--engFont); font-size: 3.5rem; font-weight: 400; color: #222; margin-bottom: 4px; }
.title-box h3{ font-family: var(--engFont); font-size: 6rem; font-weight: 800; color: #222; }
.title-box h4{ font-family: var(--engFont); font-size: 5rem; font-weight: 800; color: #222; }

/* btns */
.btns{ display: flex; padding-top: 30px; }
.btns button:not(:first-of-type){ margin-left: 10px; }
.btns button{ width: 55px; height: 55px; border-radius: 10px; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }

/* radius-btn */
.radius-btn{ display: inline-block; font-family: var(--Roboto); font-size: 1.7rem; font-weight: 500; color: #000 !important; padding: 14px 23px; background: transparent; border: 1px solid #000; border-radius: 10px; transition: background 0.5s, border 0.5s, color 0.5s; }

/* moreview */
.moreview{ width: max-content; height: 45px; display: flex; align-items: center; position: relative; font-size: 1.7rem; font-weight: 600; color: #C0C0C0; transition: color 0.5s; }
.moreview span{ display: inline-block; }
.moreview span:not(.icon){ padding-right: 20px; }
.moreview .icon{ display: inline-block; width: 34px; height: 34px; background: #BBB;  border-radius: 6px; transform: rotate(0); position: relative; transition: background 0.5s, transform 0.5s; }
.moreview .icon::before{ content: ""; width: 14px; height: 14px; background: url("/img/main/moreview.svg") no-repeat center center / contain; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(0); transition: transform 0.5s; }

@media screen and (hover: hover){
	/* radius-btn */
	.radius-btn:hover{ background: var(--blue); border: 1px solid var(--blue); color: #fff !important; }

	/* moreview */
	.moreview:hover{ color: #111; }
	.moreview:hover .icon{ transform: rotate(45deg); }
	.moreview:hover .icon::before{ transform: translate(-50%, -50%) rotate(-45deg); background: var(--blue); }
}

@media screen and (max-width: 1820px){
	#main .w1720{ padding-left: 60px; }
}

@media screen and (max-width: 1740px){
	#main .w1600{ padding-left: 60px; }
}

@media screen and (max-width: 1600px){
	/* title-box */
	.title-box p{ font-size: 3rem; }
	.title-box h3{ font-size: 5rem;; }
	.title-box h4{ font-size: 4rem; }

	/* btns */
	.btns button{ width: 50px; height: 50px; }
}

@media screen and (max-height: 800px){
	.ptH{ padding-top: 0; }
	#fullpage .section:not(:first-of-type, :last-of-type){ padding: 60px 0 100px; }
	#main .w1720{ padding-left: 20px; }
	#main .w1600{ padding-left: 20px; }
}

@media screen and (max-width: 1280px){
	/* title-box */
	.title-box.mb40{ margin-bottom: 20px; }
	.title-box p{ font-size: 2.5rem; }
	.title-box h3{ font-size: 4rem;; }
	.title-box h4{ font-size: 3.5rem; }

	/* radius-btn */
	.radius-btn{ font-size: 1.6rem; padding: 12px 18px; }

	/* moreview */
	.moreview{  height: 45px; font-size: 1.6rem; }
	.moreview span:not(.icon){ padding-right: 15px; }
	.moreview .icon{ width: 30px; height: 30px; }
	
}

@media screen and (max-width: 1200px){
	.ptH{ padding-top: 0; }
	#fullpage .section:not(:first-of-type, :last-of-type){ padding: 60px 0 100px; }
	#main .w1720{ padding-left: 20px; }
	#main .w1600{ padding-left: 20px; }
}

@media screen and (max-width: 900px){
	.title-box p{ font-size: 2.2rem; }
	.title-box h3{ font-size: 3.5rem;; }
	.title-box h4{ font-size: 3rem; }
}


/* fullpage nav */
#fp-nav.right{ right: unset; left: 45px; opacity: 1; transition: opacity 0.5s; }
#fp-nav.opacity{ opacity: 0; pointer-events: none; }
#fp-nav ul{ display: flex; flex-direction: column; align-items: center; }
#fp-nav ul li, .fp-slidesNav ul li{ width: 8px; height: 8px; margin: 0; }
#fp-nav ul li:not(:last-of-type), .fp-slidesNav ul li:not(:last-of-type){ margin-bottom: 40px; }
#fp-nav ul li:last-of-type{ display: none; }
#fp-nav ul li a, .fp-slidesNav ul li a{ width: 8px; height: 8px; }
#fp-nav ul li a span, .fp-slidesNav ul li a span{ display: inline-block; width: 8px; height: 8px; background: #CCC; position: relative; top: 0; left: 0; margin: 0; transition: background 0.5s; }
#fp-nav ul li a span::before, .fp-slidesNav ul li a span::before{ content: ""; width: 25px; height: 25px; border: 1px solid #52B254; border-radius: 50%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0); transition: transform 0.5s; }

#fp-nav.scroll ul li a span, .fp-slidesNav.scroll ul li a span{ background: #DDD; }

#fp-nav ul li a.active span, .fp-slidesNav ul li a.active span, #fp-nav ul li:hover a.active span, .fp-slidesNav ul li:hover a.active span{ width: 8px; height: 8px; margin: 0; background: #52B254 !important; }
#fp-nav ul li:hover a span, .fp-slidesNav ul li:hover a span{ width: 8px; height: 8px; margin: 0; }
#fp-nav ul li a.active span::before, .fp-slidesNav ul li a.active span::before, #fp-nav ul li:hover a.active span::before, .fp-slidesNav ul li:hover a.active span::before{ transform: translate(-50%, -50%) scale(1); }

@media screen and (max-width: 1900px){
	#fp-nav.right{ left: 25px; }
}


/* visual */
#visual{ width: 100%; position: relative; overflow: hidden; }
#visual .visual{ height: var(--vh); position: relative; }
#visual .visual::before{ content: ""; width: 100%; height: 100%; mask: linear-gradient(to right,  rgba(0, 0, 0, 1) 0%,  rgba(0, 0, 0, 1) 12.5%, rgba(0, 0, 0, 1) 25%,  rgba(0, 0, 0, 0) 37.5%); -webkit-mask: linear-gradient(to right,  rgba(0, 0, 0, 1) 0%,  rgba(0, 0, 0, 1) 12.5%, rgba(0, 0, 0, 1) 25%,  rgba(0, 0, 0, 0) 37.5%); backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); position: absolute; top: 0; left: 0; z-index: 10; opacity: 0; }
#visual .visual.blur::before{ opacity: 1; }
#visual .visual::after{ content: ""; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.4); position: absolute; top: 0; left: 0; }
#visual .visual video{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#visual .visual video.mobile{ display: none; }

#visual .text-box{ position: absolute; bottom: 23%; left: 0; right: 0; }
#visual .text-box *{ color: #fff; }
#visual .text-box ul li:not(.on){ display: none; }
#visual .text-box ul li > span{ display: block; font-family: var(--engFont); font-size: 1.8rem; font-weight: 600; margin-bottom: 30px; }
#visual .text-box h2{ font-family: var(--engFont); font-size: 8rem; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 10px; }
#visual .text-box h2 span{ display: inline-block; --translate: 100px;  }
#visual .text-box p{ font-size: 2rem; font-weight: 400; line-height: 1.5; }

#visual .text-box ul li.on > span{ animation: textClip2 1s both; }
#visual .text-box ul li.on h2 span{ animation: textTranslate 1s both; }
#visual .text-box ul li.on p{ animation: textClip 1s both; }
#visual .btns button img{ opacity: 0.5; transition: opacity 0.5s; }
#visual .btns button{ background: rgba(255, 255, 255, 0.1); border: 1px solid #BBB; transition: background 0.5s, border 0.5s; }

#visual .dots{ position: absolute; bottom: 40px; left: 0; right: 0; }
#visual .dots *{ font-family: var(--Noto); font-size: 1.7rem; font-weight: 400; color: rgba(255, 255, 255, 0.4); }
#visual .dots ul{ display: flex !important; }
#visual .dots ul li{ width: calc(100% / 4); cursor: pointer; }
#visual .dots ul li span{ transition: font-weight 0.5s, color 0.5s; }
#visual .dots ul li span:first-of-type{ margin-right: 15px; }
#visual .dots ul li .bar{ height: 2px; background: rgba(255, 255, 255, 0.2); margin-top: 17px; }
#visual .dots ul li .bar div{ width: 0; height: 100%; background: #D9D9D9; }
#visual .dots button{ display: none; }
#visual .dots ul li.slick-active span{ font-weight: 500; color: #fff; }

@media screen and (hover: hover){
	#visual .btns button:hover{ background: rgba(255, 255, 255, 0.56); border: 1px solid #fff; }
	#visual .btns button:hover img{ opacity: 1; }
}

@media screen and (max-width: 1600px){
	#visual .text-box h2{ font-size: 6.5rem; }
	#visual .text-box p{ font-size: 1.8rem; }
}

@media screen and (max-width: 1280px){
	#visual .text-box ul li > span{ font-size: 1.6rem; margin-bottom: 10px; }
	#visual .text-box h2{ font-size: 5rem; }
	#visual .text-box p{ font-size: 1.7rem; }
	#visual .dots *{ font-size: 1.6rem; }
}

@media screen and (max-width: 900px){
	#visual .text-box h2{ font-size: 4rem; }
	#visual .dots *{ font-size: 1.5rem; }
	#visual .dots ul li span:first-of-type{ margin-right: 7px; }
}

@media screen and (max-width: 800px){
	#visual .visual.blur::before{ opacity: 0; }
}

@media screen and (max-width: 650px){
	#visual .visual video.pc{ display: none; }
	#visual .visual video.mobile{ display: block; }

	#visual .text-box br{ display: none; }
}


/* product */
#product{ background: url("/img/main/product_bg.jpg") no-repeat center center / cover; overflow: hidden; }
#product .relative{ position: relative; bottom: -40px; }
#product .left{ width: calc(50% - 100px); position: absolute; left: 0; bottom: 40px; z-index: 10; }
#product .right{ width: 50%; margin-left: 50%; }

#product .title-box{  }
#product .title-box .flex-box{ display: flex; justify-content: space-between; align-items: flex-end; }
#product .btns button{ background: rgba(255, 255, 255, 0.2); border: 1px solid #CCC; transition: background 0.5s, border 0.5s; }
#product .btns button img{ filter: invert(0); -webkit-filter: invert(0); transition: filter 0.5s; }

#product .slick-slide{ padding: 40px; position: relative; }
#product .slick-slide figure{ width: 100%; position: relative; overflow: hidden; padding-bottom: 60%; }
#product .slick-slide figure img{ max-width: 100%; max-height: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
/* 이미지 흐림 잡기 */
#product .slick-slide figure img{ 
	image-rendering: -moz-crisp-edges; /* firefox */
	image-rendering: -o-crisp-edges; /* opera */
	image-rendering: -webkit-optimize-contrast; /* chrome(비표준) */
	image-rendering: crisp-edges;
	backface-visibility:hidden; 
}
#product .slick-slide .text span{ display: inline-block; background: var(--blue); padding: 5px 15px; border-radius: 10px; font-weight: 600; color: #fff; letter-spacing: -0.02em; }
#product .slick-slide .text span.none{ opacity: 0; }
#product .slick-slide .text h5{ font-weight: 600; color: #111; letter-spacing: -0.02em; margin: 10px 0; transition: color 0.5s; }
#product .slick-slide .text p{ height: 3em; font-weight: 300; color: #888; line-height: 1.5; letter-spacing: -0.02em; text-overflow: ellipsis; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
#product .slick-slide a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

#product .big-wrap{ background: linear-gradient(135deg, #E8EBF2 0%, rgba(242, 243, 247, 0.00) 100%); border: 2px solid rgba(255, 255, 255, 0.5); border-radius: 30px; box-shadow: 30px 30px 45px 0px rgba(15, 41, 107, 0.12); position: relative; }
#product .big-wrap::before{ content: ""; width: calc(100% + 4px); height: calc(100% + 4px); border: 2px solid var(--blue); border-radius: inherit; position: absolute; top: -1px; left: -1px; box-sizing: border-box; opacity: 0; transition: opacity 0.5s; }
#product .big .text{ margin-top: 60px; }
#product .big .text span{ font-size: 1.8rem; }
#product .big .text h5{ font-size: 3.2rem; }
#product .big .text p{ font-size: 2rem; }


#product .small-wrap{ width: calc(100% + ((100vw - 100%) / 2)); position: relative; }
#product .small-wrap .slick-list{ margin-right: -40px; }
#product .small{ width: 400px; background: linear-gradient(135deg, #E8EBF2 0%, rgba(242, 243, 247, 0.00) 100%); border: 2px solid rgba(255, 255, 255, 0.5); border-radius: 30px; box-shadow: 20px 20px 30px 0px rgba(15, 41, 107, 0.12); margin: 40px 20px; position: relative; transform: translateY(0); transition: transform 0.5s; }
#product .small::before{ content: ""; width: calc(100% + 4px); height: calc(100% + 4px); border: 2px solid var(--blue); border-radius: inherit; position: absolute; top: -1px; left: -1px; box-sizing: border-box; opacity: 0; transition: opacity 0.5s; }
#product .small .text{ margin-top: 15px; }
#product .small .text span{ font-size: 1.4rem; }
#product .small .text h5{ font-size: 2.6rem; }
#product .small .text p{ font-size: 1.8rem; }

@media screen and (hover: hover){
	#product .btns button:hover{ background: rgba(204, 204, 204, 0.2); border: 1px solid #323232; }
	#product .btns button:hover img{ filter: invert(1); -webkit-filter: invert(1); }

	#product .slick-slide:hover .text h5{ color: var(--mainColor); }
	#product .big-wrap:hover::before{ opacity: 1; }
	#product .small:hover{ transform: translateY(-20px); }
	#product .small:hover::before{ opacity: 1; }
}

@media screen and (max-width: 1600px){
	#product .left{ width: calc(50% - 50px); }

	#product .big .text span{ font-size: 1.7rem; }
	#product .big .text h5{ font-size: 2.8rem; }
	#product .big .text p{ font-size: 1.8rem; }

	#product .small{ width: 300px; padding: 25px 30px; }
	#product .small .text h5{ font-size: 2.2rem; }
	#product .small .text p{ font-size: 1.6rem; }
}

@media screen and (max-width: 1280px){
	#product .big .text span{ font-size: 1.6rem; }
	#product .big .text h5{ font-size: 2.2rem; }
	#product .big .text p{ font-size: 1.7rem; }

	#product .small .text h5{ font-size: 2rem; }
	#product .small .text p{ font-size: 1.5rem; }
}

@media screen and (max-width: 1200px){
	#product .relative{ bottom: 0; }
	#product .left{ width: calc(50% - 30px); position: relative; left: 0; bottom: 0; }
	#product .right{ width: 100%; margin-left: 0; }
	#product  .btns{ position: absolute; bottom: 0; right: 0; transform: translateY(100%); }

	#product .flex{ display: flex; justify-content: space-between; align-items: flex-end; margin-top: 30px; }
	#product .flex .right{ width: 50%; position: relative; bottom: -40px; }

	#product .big{ padding: 30px; }
	#product .big .text{ margin-top: 30px; }

	#product .small{ margin: 40px 15px; }
}

@media screen and (max-width: 800px){
	#product .left{ width: 300px; }
	#product .flex .right{ width: calc(100% - 330px); }

	#product .big{ padding: 20px 25px; }
	#product .small{ width: 200px; padding: 20px 25px; }
}


/* video */
#video{ overflow: hidden; }
#video .title-box{ display: flex; justify-content: space-between; align-items: center; }
#video .video-wrap .slick-list{ margin-right: -20px; }
#video .video-wrap .slick-track{ margin: 0; }
#video .video{ margin-right: 20px; position: relative; }
#video .video figure{ width: 100%; position: relative; overflow: hidden; padding-bottom: 54%; border-radius: 20px 20px 0 0; }
#video .video figure::after{ content: ""; width: 60px; height: 60px; background: url("/img/main/video_play.svg") no-repeat center center / contain; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#video .video figure img{ width: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(1); transition: transform 0.5s; }
#video .video .text{ padding: 25px 0; }
#video .video .text h6{ height: 2.5em; font-size: 2.4rem; font-weight: 600; color: #111; line-height: 1.25; text-overflow: ellipsis; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
#video .video .text p{ height: 3em; font-size: 1.8rem; font-weight: 300; color: #666; line-height: 1.5; text-overflow: ellipsis; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; margin: 15px 0 25px; }
#video .video .text .moreview{ margin-left: auto; }
#video .video .bar{ height: 1px; background: #DDD; }
#video .video .bar::before{ content: ""; display: block; width: 0; height: 100%; background: var(--blue); transition: width 0.5s; }
#video .video a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

@media screen and (hover: hover){
	#video .video:hover figure img{ transform: translate(-50%, -50%) scale(1.1); }
	#video .video:hover .moreview{ color: #111; }
	#video .video:hover .moreview .icon{ background: var(--blue); transform: rotate(45deg); }
	#video .video:hover .moreview .icon::before{ transform: translate(-50%, -50%) rotate(-45deg); }
	#video .video:hover .bar::before{ width: 100%; }
}

@media screen and (max-height: 800px){
	#video{ padding-top: 40px !important; }
}

@media screen and (max-width: 1600px){
	#video .video .text h6{ font-size: 2.2rem; }
	#video .video .text p{  font-size: 1.7rem; }
}

@media screen and (max-width: 1280px){
	#video .video .text h6{ font-size: 2rem; }
	#video .video .text p{  font-size: 1.6rem; margin: 10px 0 15px; }
	#video .video .text{ padding: 15px 0; }
}

@media screen and (max-width: 1200px){
	#video{ padding-top: 40px !important; }
	#video .video-wrap{ width: calc(100% + 20px); } 
	#video .video{ width: 350px; }
}


/* news */
#news{ background: url("/img/main/news_bg.jpg") no-repeat center center / cover; overflow: hidden; }
#news .relative{ position: relative; }
#news .left{ width: 565px; padding-right: 65px; position: absolute; top: 50%; left: 0; transform: translateY(-50%); }
#news .right{ width: calc(100% - 565px); margin-left: auto; }
#news .title-box{ display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 50px; }
#news figure{ width: 100%; position: relative; overflow: hidden; padding-bottom: 100%; }
#news figure img{ width: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(1); }

#news .first{ position: relative; }
#news .first figure{ border-radius: 10px; }
#news .first figure::after{ content: ""; width: 100%; height: 100%; border: 2px solid var(--blue); border-radius: inherit; position: absolute; top: 0; left: 0; box-sizing: border-box; opacity: 0; transition: opacity 0.5s; }
#news .first figure img{ transition: transform 0.5s; }
#news .first .text{ margin-top: 20px; }
#news .first .text h6{ display: -webkit-box; height: 2.6em; font-size: 2.2rem; font-weight: 700; color: #111; margin-bottom: 10px; text-overflow: ellipsis; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
#news .first .text span{ font-size: 1.4rem; font-weight: 400; color: #888; }
#news .first a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

#news ul li{ display: flex; align-items: center; padding: 32px 0; border-bottom: 1px solid rgba(0, 0, 0, 0.2); position: relative; }
#news ul li:first-of-type{ border-top: 2px solid #333; }
#news ul li::after{ content: ""; width: 0; height: 1px; background: var(--blue); position: absolute; bottom: -1px; left: 0; transition: width 0.5s; }
#news ul li .figure{ width: 100px; }
#news ul li figure{ border-radius: 5px; }
#news ul li .text{ width: calc(100% - 175px); padding: 0 25px; }
#news ul li .text h6, #news ul li .text p{ width: 100%; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
#news ul li .text .tit{ position: relative; }
#news ul li .text h6{ font-size: 2rem; font-weight: 700; color: rgba(17, 17, 17, 0.8); opacity: 0; }
#news ul li .text h6.float{ font-size: 1.8rem; position: absolute; top: 50%; left: 0; transform: translateY(-50%); opacity: 1; transition: font-size 0.5s; }
#news ul li .text p{ font-size: 1.6rem; font-weight: 400; color: #666; margin: 8px 0 20px; }
#news ul li .text span{ font-size: 1.4rem; font-weight: 400; color: #888; }
#news ul li .btn{ width: 75px; }
#news ul li .btn .moreview{ margin: 0 auto; }
#news ul li a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

@media screen and (hover: hover){
	#news .first:hover figure::after{ opacity: 1; }
	#news .first:hover figure img{ transform: translate(-50%, -50%) scale(1.1); }

	#news ul li:hover::after{ width: 100%; }
	#news ul li:hover h6.float{ font-size: 2rem; }
	#news ul li:hover .moreview{ color: #111; }
	#news ul li:hover .moreview .icon{ background: var(--blue); transform: rotate(45deg); }
	#news ul li:hover .moreview .icon::before{ transform: translate(-50%, -50%) rotate(-45deg); }
}

@media screen and (max-width: 1600px){
	#news .first .text h6{ font-size: 2rem; }
}

@media screen and (max-width: 1280px){
	#news .title-box{ margin-bottom: 30px; }
	#news .left{ width: 500px; }
	#news .right{ width: calc(100% - 500px); }

	#news ul li{ padding: 20px 0; }
	#news ul li .text h6{ font-size: 1.8rem; }
	#news ul li .text h6.float{ font-size: 1.6rem; }
	#news ul li .text p{ font-size: 1.5rem; }
}

@media screen and (max-width: 1280px) and (hover: hover){
	#news ul li:hover h6.float{ font-size: 1.8rem; }
}

@media screen and (max-width: 1200px){
	#news .left{ width: 430px; padding-right: 30px; }
	#news .right{ width: calc(100% - 430px); }

	#news ul li .text{ width: calc(100% - 160px); padding: 0 15px; }
	#news ul li .text p{ margin: 8px 0 10px; }
	#news ul li .btn{ width: 60px; }
}

@media screen and (max-width: 900px){
	#news .left{ width: 100%; position: relative; top: 0; transform: translateY(0); padding-right: 0; margin-bottom: 30px; }
	#news .left .first{ display: flex; align-items: center; }
	#news .left .figure{ width: 150px; }
	#news .left .first .text{ width: calc(100% - 150px); padding-left: 20px; margin-top: 0; }
	#news .right{ width: 100%; }
}