/* fullpage navi */
#fp-nav.right{ right: 20px; }
#fp-nav ul li a span, .fp-slidesNav ul li a span{ background: #fff; opacity: 0.4; margin: -2px; }
#fp-nav ul li, .fp-slidesNav ul li{ width: 30px; height: 30px; }
#fp-nav ul li:last-of-type, .fp-slidesNav ul li:last-of-type{ display: none; }
#fp-nav ul li a, .fp-slidesNav ul li a{ position: relative; }
#fp-nav ul li a::before, .fp-slidesNav ul li a:before{ content: ""; width: 100%; height: 100%; border-radius: 50%; background: #fff; opacity: 0.06; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0); transition: all 0.5s; }
#fp-nav ul li a, .fp-slidesNav ul li a{ display: flex; justify-content: center; align-items: center; }
#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: 4px; height: 4px; margin: -2px; opacity: 1; }
#fp-nav ul li a.active::before, .fp-slidesNav ul li a.active:before{ transform: translate(-50%, -50%) scale(1); }
#fp-nav ul li:not(:last-of-type){ margin-bottom: 15px; }  
#fp-nav ul li:hover a span, .fp-slidesNav ul li:hover a span{ width: 4px; height: 4px; margin: -2px; }

#fp-nav.color ul li a span, .fp-slidesNav.color ul li a span{ background: rgba(0, 0, 0, 0.4); } 
#fp-nav.color ul li a.active span, .fp-slidesNav.color ul li a.active span, #fp-nav.color ul li:hover a.active span, .fp-slidesNav.color ul li:hover a.active span{ background: var(--mainColor); }
#fp-nav.color ul li a::before, .fp-slidesNav.color ul li a:before{ background: rgba(191, 30, 46, 0.6); }

/* common */
.section.active::before{ transform: scale(1); transition-delay: 0.5s; }  

.border-btn{ display: inline-block; font-size: 1.8rem; font-weight: 300; color: #fff; padding: 20px 30px; position: relative; }
.border-btn::before{ content: ""; width: 55px; height: 55px; position: absolute; top: 50%; left: 0; transform: translateY(-50%); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 100px; transition: all 0.5s; } 
.border-btn:active{ color: #fff; }
.border-btn:visited{ color: #fff; }
.border-btn:link{ color:#fff; }
.border-btn i{ margin-left: 10px; transition: all 0.8s; }

.border-btn:hover::before{ width: 100%; border: 1px solid #fff; }  
.border-btn:hover i{ margin-left: 25px; }

.title h3{ font-size: 7rem; font-weight: 600; color: #222; line-height: 1.1; transform: translateX(-100px); opacity: 0; transition: all 1s; }
.title p{ font-size: 2rem; font-weight: 300; color: #222; line-height: 1.6; margin-top: 15px; transform: translateX(-100px); opacity: 0; transition: all 1s; }

.active .title h3{ transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
.active .title p{ transform: translateX(0); opacity: 1; transition-delay: 0.7s; }
.on .title h3{ transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
.on .title p{ transform: translateX(0); opacity: 1; transition-delay: 0.7s; }

@media screen and (max-height: 800px){
	#main{ overflow: hidden; }
}

@media screen and (max-width: 1500px){
	#fp-nav.right{ right: 10px; }
	.title h3{ font-size: 6rem; }
}

@media screen and (max-width: 1350px){
	.title h3{ font-size: 5rem; }
}

@media screen and (max-width: 1250px){
	.border-btn{ font-size: 1.7rem; }
	.border-btn::before{ width: 50px; height: 50px; }
	.title p{ font-size: 1.8rem; }
}


/* visual */
#visual{ position: relative; overflow: hidden; }
#visual .visual .bg{ height: 100vh; transform: scale(1.25); }  
#visual .visual .bg01{ background: url("/img/main/main_slide01.jpg") no-repeat center center / cover; }
#visual .visual .bg02{ background: url("/img/main/main_slide02.jpg") no-repeat center center / cover; }
#visual .visual .bg03{ background: url("/img/main/main_slide03.jpg") no-repeat center center / cover; }

#visual .content-box{ max-width: 1660px; width: 100%; position: absolute; top: 58%; left: 50%; transform: translate(-50%, -50%); text-align: center; color: #fff; pointer-events: none; }
#visual .text-box h2{ font-size: 8rem; font-weight: 600; letter-spacing: -0.01em; line-height: 1.05; }
#visual .text-box h2 span{ display: inline-block; line-height: 1.05; transform: translateY(50px); opacity: 0; filter: blur(10px); animation: blurText 2s forwards; }
#visual .text-box p{ font-size: 2.2rem; font-weight: 300; color: #fff; line-height: 1.35; margin-top: 10px; }
#visual .text-box p span{ display: inline-block; }
#visual .text-box p span.overflow{ width: 100%; overflow: hidden; } 
#visual .text-box p span.overflow span{ transform: translateY(100%); animation: upText 1s forwards; }
#visual .text-box button{ width: 140px; height: 140px; background: none; border: none; font-size: 2.2rem; color: #fff; position: relative; margin-top: 50px; pointer-events: auto; }
#visual .text-box button::before{ content: ""; width: 100%; height: 100%; background: url("/img/main/circle_button.svg") no-repeat center center / contain; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); animation: rotate 7s linear infinite; }
#visual .text-box button.stop .xi-pause{ display: none; }
#visual .text-box button.play .xi-play{ display: none; }
#visual .text-box button:hover::before{ animation-play-state: paused; }

#visual .button-box button{ font-family: var(--Outfit); background: none; border: none; font-size: 1.5rem; font-weight: 300; color: #fff; padding: 10px; position: absolute; top: 28%; transform: translateY(-50%); pointer-events: auto; }
#visual .button-box button.prev{ left: 0; padding-left: 120px; }
#visual .button-box button.next{ right: 0; padding-right: 120px; }
#visual .button-box button::before, #visual .button-box button::after{ content: ""; width: 110px; height: 1px; background: #fff; position: absolute; top: 54%; transform: translateY(-50%); }
#visual .button-box button.prev::before, #visual .button-box button.prev::after{ left: 0; transform-origin: right; }
#visual .button-box button.next::before, #visual .button-box button.next::after{ right: 0; transform-origin: left; }
#visual .button-box button.prev::before, #visual .button-box button.next::before{ opacity: 0.2; }
#visual .button-box button.prev::after, #visual .button-box button.next::after{ top: 50%; transform: scaleX(0.37); transition: transform 0.8s; }
#visual .button-box button:hover::after{ transform: scaleX(1); }

#visual .scroll{ display: flex; flex-direction: column; align-items: center; position: absolute; bottom: 0; right: 50px; }
#visual .scroll span{ display: inline-block; font-size: 1rem; font-weight: 400; color: #fff; letter-spacing: 0.2em; line-height: 1.35; opacity: 0.8; writing-mode: vertical-rl; margin-bottom: 15px; }
#visual .scroll .bar{ width: 1px; height: 50px; background: rgba(255, 255, 255, 0.2); overflow: hidden; }
#visual .scroll .bar div{ width: 100%; height: 16px; background: #fff; animation: scroll 1.5s linear infinite; }

#visual .visual.slick-active .bg{ animation: bgScale 5s 0.5s forwards; }
#visual .text-box.animated h2 span{ } 
#visual .text-box.animated p span.overflow span{  }

@media screen and (max-width: 1770px){
	#visual .content-box{ padding: 0 220px; }
	#visual .content-box br{ display: none; }
	#visual .button-box button.prev{ left: 80px; padding-left: 90px; }
	#visual .button-box button.next{ right: 80px; padding-right: 90px; }
	#visual .button-box button::before, #visual .button-box button::after{ width: 80px; }
}

@media screen and (max-width: 1500px){
	#visual .text-box h2{ font-size: 6rem; } 

	#visual .text-box p span{ display: inline; }
	#visual .text-box p span.overflow span{ opacity: 0; transform: translateY(0); animation: opacity 1s forwards; }
}

@media screen and (max-width: 1250px){
	#visual .text-box p{ font-size: 2rem; }  
}

@media screen and (max-width: 1200px){
	#visual .content-box{ padding: 0 20px; }
	#visual .button-box button{ display: none; }  
	#visual .text-box button{ width: 120px; height: 120px; }
}

@media screen and (max-width: 850px){
	#visual .content-box{ top: 50%; }
	#visual .text-box h2{ font-size: 5.5rem; }  
	#visual .text-box button{ width: 100px; height: 100px; }
}

@keyframes bgScale{
	0%{ transform: scale(1.25); }
	100%{ transform: scale(1); }
}

@keyframes blurText{
	0%{ transform: translateY(50px); opacity: 0; filter: blur(10px); }
	100%{ transform: translateY(0); opacity: 1; filter: blur(0); }
}

@keyframes upText{
	0%{ transform: translateY(100%); }
	100%{ transform: translateY(0); }
}

@keyframes rotate{
	0%{ transform: translate(-50%, -50%) rotate(0deg); }
	100%{ transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes scroll{
	0%{ transform: translateY(0); opacity: 1; }
	100%{ transform: translateY(50px); opacity: 0; }
}

@keyframes opacity{
	0%{ opacity: 0; }
	100%{ opacity: 1; }
}


/* product */
#product{ background: url("/img/main/product_bg.jpg") no-repeat center center / cover; position: relative; }
#product .bg{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; display: none; }
#product .bg1{ background: url("/img/main/product_bg01.jpg") no-repeat center center / cover; }
#product .bg2{ background: url("/img/main/product_bg02.jpg") no-repeat center center / cover; }

#product .flex-box{ display: flex; height: 100vh; }
#product .flex-box::before{ content: ""; width: 1px; height: 100%; background: rgba(255, 255, 255, 0.2); position: absolute; top: 0; left: 50%; transform: translateX(-50%); }
#product .half{ width: 50%; height: 100%; display: flex; justify-content: center; align-items: center; position: relative; z-index: 10; }
#product .half::before{ content: ""; width: 100%; height: 100vh; background: rgba(0, 0, 0, 0.4); position: absolute; top: 0; left: 0; z-index: -5; transform: scaleX(0); transition: all 0.8s; }
#product .half.left::before{ transform-origin: right; }
#product .half.right::before{ transform-origin: left; }

#product .half .text-box{ width: 70%; }
#product .half .text-box h3{ font-size: 7rem; font-weight: 600; color: #fff; }
#product .half .text-box h3 span{ display: inline-block; position: relative; left: 50%; transform: translateX(-50%); }  
#product .half .text-box .overflow{ padding-top: 15px; overflow: hidden; opacity: 0; transition: all 1.5s; }
#product .half .text-box .wrap{ display: none; }
#product .half .text-box p{ font-size: 1.8rem; font-weight: 400; color: #fff; line-height: 1.35; }
#product .half .text-box a{ margin-top: 40px; } 
#product .half.hover .text-box h3 span{ left: 0; transform: translateX(0); }

#product .half:hover::before{ transform: scaleX(1); }
#product .half:hover .text-box .overflow{ opacity: 1; }


#product.active::before{ transform: scale(1); transition-delay: 0.5s; }

@media screen and (max-width: 1500px){
	#product .half .text-box h3{ font-size: 6rem; }
}

@media screen and (max-width: 1250px){
	#product .half .text-box h3{ font-size: 5rem; }
	#product .half .text-box p{ font-size: 1.7rem; }
}

@media screen and (max-width: 900px){
	#product .flex-box{ height: auto; flex-direction: column; }
	#product .flex-box::before{ width: 100%; height: 1px; top: 50%; left: 0; transform: translateY(-50%); }

	#product .half{ width: 100%; min-height: 50vh; height: auto; padding: 40px 0; }
	#product .half::before{ height: 100%; transform: scaleY(0); }
	#product .half.left::before{ transform-origin: bottom; }
	#product .half.right::before{ transform-origin: top; }
	#product .half:hover::before{ transform: scaleY(1); }
}

@media screen and (max-width: 850px){
	#product .half .text-box h3{ font-size: 4rem; }
}


/* about */
#about{ background: url("/img/main/about_bg.jpg") no-repeat center left / cover; }
#about .flex-box{ display: flex; justify-content: space-between; align-items: flex-start; padding-top: 86px; }
#about .text-box{ position: relative; z-index: 10; padding-top: 95px; }
#about .text-box::before{ content: "About"; position: absolute; top: 0; left: 0; z-index: -5; font-size: 20rem; font-weight: 700; color: #fff; line-height: 1; letter-spacing: -0.02em; text-shadow: 2px 2px 30px rgba(0, 0, 0, 0.05); opacity: 0; transition: all 1s; }

#about .figure-box{ width: calc(100% - 635px); }
#about ul{ display: flex; justify-content: space-between; opacity: 0; transition: all 1s; }
#about ul li:first-of-type{ width: 38%; }
#about ul li:last-of-type{ width: calc(62% - 20px); display: flex; flex-direction: column; justify-content: space-between; }

#about .box{ position: relative; border-radius: 10px; overflow: hidden; } 
#about .box figure{ width: 100%; position: relative; overflow: hidden; }
#about .box.company figure{ padding-bottom: 159%; margin-bottom: -5px; }
#about .box.leadership figure{ padding-bottom: 58%; margin-bottom: -3px; }
#about .box.contact figure{ padding-bottom: 39%; margin-bottom: -4px; }
#about .box figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(1.3); transition: all 1.5s; }

#about .hover{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 50px; transition: all 1s; }
#about .box.contact .hover{ justify-content: center; padding: 0 50px; }
#about .hover::before, #about .hover::after{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); pointer-events: none; transition: all 1s; }
#about .hover::after{ opacity: 0; }

#about .company .hover::before{ content: url("/img/main/about_default01.png"); }
#about .leadership .hover::before{ content: url("/img/main/about_default02.png"); }
#about .contact .hover::before{ content: url("/img/main/about_default03.png");  }

#about .company .hover::after{ content: url("/img/main/about_hover01.png"); margin-left: 40%; }
#about .leadership .hover::after{ content: url("/img/main/about_hover02.png"); margin-left: -30%; }
#about .contact .hover::after{ content: url("/img/main/about_hover03.png"); margin-top: 10%; }

#about .hover h4{ font-size: 3.5rem; font-weight: 500; color: #000; transition: all 0.8s; }
#about .hover .opacity{ opacity: 0; transition: all 0.8s; }
#about .hover a{ width: fit-content; }
#about .hover dl{ display: flex; font-size: 2rem; }
#about .hover dl:first-of-type{ margin-top: 20px; }
#about .hover dl:not(:last-of-type){ margin-bottom: 10px; }
#about .hover dt{ width: 220px; font-weight: 500; color: #fff; }
#about .hover dd{ width: calc(100% - 220px); font-weight: 300; color: #aaa; }

#about .hover:hover{ background: #000; }
#about .hover:hover::before{ opacity: 0; }
#about .hover:hover::after{ opacity: 1; margin: 0; }
#about .hover:hover h4{ color: #fff; }
#about .hover:hover .opacity{ opacity: 1; }

#about.active .text-box::before{ left: -60px; opacity: 1; transition-delay: 0.5s; }
#about.active ul{ opacity: 1; transition-delay: 0.5s; }
#about.active .box figure img{ transform: translate(-50%, -50%) scale(1); }

@media screen and (max-width: 1900px){
	#about{ padding: 0 60px; }
	#about .text-box::before{ font-size: 15rem; }

	#about.active .text-box::before{ left: -40px; }
}

@media screen and (max-height: 800px){
	#about{ padding-top: 100px; padding-bottom: 100px; }
	#about .flex-box{ padding-top: 0; }
}

@media screen and (max-width: 1700px){
	#about .title p br{ display: none; }
	#about .text-box{ width: 450px; }
	#about .figure-box{ width: calc(100% - 550px); }
	#about .hover dl:first-of-type{ margin-top: 10px; }
	#about .hover dl:not(:last-of-type){ margin-bottom: 5px; }
}

@media screen and (max-width: 1600px){
	#about .hover h4{ font-size: 3.2rem; }
	#about .hover dl{ font-size: 1.8rem; }
	#about .hover dt{ width: 200px; }
}

@media screen and (max-width: 1500px){
	#about{ padding-left: 30px; padding-right: 50px; }
	#about .text-box{ width: 400px; padding-top: 55px; }
	#about .text-box::before{ font-size: 12rem; }
	#about .figure-box{ width: calc(100% - 450px); }
	#about .hover{ padding: 30px 40px; }
	#about .box.contact .hover{ padding: 30px; }

	#about.active .text-box::before{ left: -30px; }
}

@media screen and (max-width: 1250px){
	#about .hover h4{ font-size: 2.8rem; }
	#about .hover dl{ font-size: 1.6rem; }
	#about .hover dt{ width: 180px; }
}

@media screen and (max-width: 1200px){
	#about{ padding: 40px 0 80px; overflow: hidden; }
	#about .flex-box{ flex-direction: column; padding-top: 0; } 
	#about .text-box{ width: 100%; margin-bottom: 40px; padding-left: 30px; }
	#about .figure-box{ width: 100%; }

	#about.active .text-box::before{ left: 0; transition-delay: unset; }
	#about.active ul{ transition-delay: unset; }
} 

@media screen and (max-width: 750px){
	#about .text-box{ padding-left: 0; }
	#about.active .text-box::before{ left: 100%; transform: translateX(0); }

	#about ul{ flex-direction: column; }
	#about ul li:first-of-type{ width: 100%; }
	#about ul li:last-of-type{ width: 100%; margin-bottom: -20px; }
	#about .box{ margin-bottom: 20px; }
	#about .box.company figure{ padding-bottom: 90%; }

	#about.active .text-box::before{ left: 100%; transform: translateX(-100%); text-shadow: 2px 2px 30px rgba(0, 0, 0, 0.1); }
}


/* news */
#news{ position: relative; }
#news.section::before{ content: ""; width: 100%; height: calc(100% + 125px); background: url("/img/main/news_bg2.jpg") no-repeat center right / cover; position: absolute; top: 0; left: 0; } 
#news .border-btn{ color: #222; position: relative; z-index: 20; }
#news .border-btn::before{ border: 1px solid rgba(34, 34, 34, 0.2); }
#news .border-btn:hover::before{ border: 1px solid rgba(34, 34, 34, 1); }
#news .flex{ display: flex; align-items: center; }
#news .flex ul{ display: flex; align-items: center; margin-top: 10px; margin-left: 30px; }
#news .flex ul li{ opacity: 0; transform: translateX(50px); transition: all 1s; }
#news .flex ul li:not(:last-of-type){ margin-right: 20px; }
#news .flex ul li a{ display: inline-block; font-size: 1.8rem; font-weight: 300; color: #222; border: 1px solid rgba(34, 34, 34, 0.1); border-radius: 100px; padding: 12px 20px; padding-left: 35px; position: relative; overflow: hidden; transition: color 0.3s; transition-delay: 0.3s; }
#news .flex ul li a::before{ content: ""; width: 6px; height: 6px; background: var(--mainColor); border-radius: 50%; position: absolute; top: 50%; left: 20px; z-index: -1; transform: translateY(-50%); transition: all 1s; }
#news .flex ul li a span{ position: relative; left: 0; transition: all 0.3s; }

#news .flex ul li a:hover{ color: #fff; transition-delay: unset; } 
#news .flex ul li a:hover::before{ transform: translateY(-50%) scale(50); }
#news .flex ul li a:hover span{ left: -7.5px; }

#news .flex .border-btn{ color: #222; transform: translateX(100px); opacity: 0; transition: all 1s; }
#news .flex .border-btn::before{ border: 1px solid rgba(34, 34, 34, 0.2); }
#news .flex .border-btn:hover::before{ border: 1px solid #222; }
#news .flex-box{ display: flex; justify-content: space-between; margin-top: 35px; }
#news .box{ width: 590px; border-radius: 10px; overflow: hidden; position: relative; padding: 1px; opacity: 0; transition: all 1s; text-align: right; }
#news .box .text p, #news .box .text-box .text span, #news .box .text-box .text p.date{ text-align: left; }
#news .box::after{ content: ""; position: absolute; top: 0; left: 0; width: calc(100% - 2px); height: calc(100% - 2px); z-index: 10; border-radius: 10px; border: 1px solid var(--mainColor); transition: all 0.5s; opacity: 0; pointer-events: none; }
#news .box:hover::after{ opacity: 1; }
#news .box figure{ width: 100%; margin: 0; position: relative; overflow: hidden; padding-bottom: 58%; margin-bottom: -4px; } 
#news .box figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(1.2); transition: all 1s; }
#news .box .text p{ width: 100%; }

#news .text-box{ display: flex; justify-content: space-between; align-items: center; background: rgba(255, 255, 255, 0.7); padding: 35px; }
#news .text-box .num{ text-align: center; }
#news .text-box .num span{ font-size: 4.2rem; font-weight: 700; color: #222; }
#news .text-box .num p{ font-size: 1.6rem; font-weight: 300; color: #555; }
#news .text-box .text{ width: 100%; }
#news .text-box .text span{ display: inline-block; width: 100%; font-size: 1.6rem; font-weight: 400; color: #989898; }
#news .text-box .text p{ font-size: 2rem; font-weight: 600; color: #222; margin-top: 10px; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
#news .text-box .text p.date{ font-size: 1.6rem; font-weight: 300; color: #989898; }

#news .flex-box ul{ display: flex; flex-direction: column; justify-content: space-between; width: calc(100% - 610px); }
#news .flex-box ul li{ border-radius: 10px; overflow: hidden; position: relative; border: 1px solid transparent; padding: 1px; transition: all 1s; opacity: 0; transform: translateX(100px); }
#news .flex-box ul li::after{ content: ""; width: calc(100% - 2px); height: calc(100% - 2px); position: absolute; top: 0; left: 0; z-index: 10; border-radius: 10px; border: 1px solid var(--mainColor); opacity: 0; transition: all 0.5s; }
#news .flex-box ul li .text-box{ height: 100%; }
#news .flex-box ul li .text{ height: 100%; display: flex; flex-direction: column; justify-content: center; padding-right: 200px; }
#news .flex-box ul li:hover::after{ opacity: 1; }
#news .flex-box ul li .text p{ width: 90%; white-space: nowrap; }
#news .flex-box ul li .text p.date{ font-size: 1.6rem; font-weight: 300; color: #989898; }
#news .flex-box ul li .border-btn{ position: absolute; top: 50%; right: 5px; transform: translateY(-50%); z-index: 20; transition: all 0.5s; }
#news .flex-box ul li .border-btn:hover{ right: 35px; }

#news.active .box{ opacity: 1; transition-delay: 0.5s; }  
#news.active .flex .border-btn{ transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
#news.active .box figure img{ width: 100%; transform: translate(-50%, -50%) scale(1); transition-delay: 0.5s; }  
#news.active ul li{ height: calc((100% - 40px) / 3); transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
#news.active ul li:nth-of-type(2){ transition-delay: 0.7s; }
#news.active ul li:nth-of-type(3){ transition-delay: 0.9s; }

 
#news.on .box{ opacity: 1; transition-delay: 0.5s; }  
#news.on .flex .border-btn{ transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
#news.on .box figure img{ transform: translate(-50%, -50%) scale(1); transition-delay: 0.5s; }  
#news.on ul li{ transform: translateX(0); opacity: 1; transition-delay: 0.5s; }
#news.on ul li:nth-of-type(2){ transition-delay: 0.7s; }
#news.on ul li:nth-of-type(3){ transition-delay: 0.9s; }

@media screen and (max-width: 1800px){
	#news{ padding: 0 60px; }
}

@media screen and (max-height: 800px){
	#news{ padding-top: 100px; padding-bottom: 100px; padding-right: 0; }
}

@media screen and (max-width: 1650px){
	#news .flex-box ul li .text p{ width: 100%; }
}

@media screen and (max-width: 1500px){
	#news{ padding-right: 50px; padding-left: 30px; }
	#news .text-box{ padding: 20px 30px; }
	#news .text-box .num span{ font-size: 3.5rem; }
	#news .flex-box ul li .text{ padding-right: 180px; }
	#news .text-box .text p{ font-size: 1.8rem; }
	#news .border-btn{ font-size: 1.7rem; right: 0; padding: 15px 20px; }
	#news .border-btn::before{ width: 45px; height: 45px; }
	#news .flex-box ul li .border-btn:hover{ right: 30px; }
	#news .border-btn:hover::before{ width: 100%; }
}

@media screen and (max-width: 1400px){
	#news .box, #news .flex-box ul{ width: calc((100% - 20px) / 2); }
}

@media screen and (max-width: 1200px){
	#news{ padding: 80px 0; }
	#news .w1700{ overflow: hidden; padding-right: 20px; }
	
	#news.active .box{ transition-delay: unset; }  
	#news.active .flex .border-btn{ transition-delay: unset; }
	#news.active .box figure img{ transition-delay: unset; }  
	#news.on ul li{ transition-delay: 0.2s; }
	#news.on ul li:nth-of-type(2){ transition-delay: 0.4s; }
	#news.on ul li:nth-of-type(3){ transition-delay: 0.6s; }
}

@media screen and (max-width: 1100px){
	#news .flex{ flex-direction: column; }
	#news .flex .title{ width: 100%; }
	
	#news .flex-box{ flex-direction: column; margin-top: 10px; }
	#news .flex ul{ width: 100%; justify-content: flex-end; margin: 20px 0 0; }
	#news .box, #news .flex-box ul{ width: 100%; }
	#news .box{ margin-bottom: 20px; }
	#news .flex-box ul li:not(:last-of-type){ margin-bottom: 20px; }
}

@media screen and (max-width: 900px){
	#news.section::before{ height: calc(100% + 133px); }
}

@media screen and (max-width: 800px){
	#news .text-box .num span{ font-size: 3rem; }
	#news .text-box .text p{ margin-top: 5px; }
	#news .flex ul a{ font-size: 1.6rem; }
}