/* common */
.grayBg{ background: #F2F2F2; }

/* 간격 */
.pt150{ padding-top: 150px; }
.pb150{ padding-bottom: 150px; }


/* title-box */
.title-box{ margin-bottom: 70px; }
.title-box h3{ font-size: 7.6rem; font-weight: 700; color: #111; }
.title-box p{ font-size: 21px; font-weight: 400; color: #555; line-height: 1.7; margin-top: 30px; }

@media screen and (max-width: 1700px){
	/* 간격 */
	.pt150{ padding-top: 120px; }
	.pb150{ padding-bottom: 120px; }

	/* title-box */
	.title-box{ margin-bottom: 50px; }
	.title-box p{ font-size: 19px; }
}

@media screen and (max-width: 1280px){
	/* 간격 */
	.pt150{ padding-top: 90px; }
	.pb150{ padding-bottom: 90px; }

	/* title-box */
	.title-box{ margin-bottom: 30px; }
	.title-box h3{ font-size: 7rem; }
	.title-box p{ font-size: 17px; margin-top: 15px; }
}

@media screen and (max-width: 900px){
	/* title-box */
	.title-box h3{ font-size: 6.6rem; }
}

@media screen and (max-width: 800px){
	/* header */
	header .sns button{ background: #F8F8F8; }
	header .sns > a{ background: #F8F8F8; color: #CCC; }
	
	/* common */
	main{ padding-top: var(--headerH); }
}


/* visual */
#visual{ position: relative; }
#visual .video{ aspect-ratio: 16 / 9; position: relative; overflow: hidden; }
#visual .video::after{ content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: none; }
#visual .video iframe{ width: 100%; height: 150%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }

#visual .text { text-align: center; position: absolute; bottom: 0; left: 0; right: 0; padding-bottom: 40px; }
#visual .text h2{ font-size: 5.4rem; font-weight: 700; color: #FFF; }
#visual .text .scrollDown{ margin-top: 60px; }

#visual .scrollDown{ font-size: 18px; font-weight: 700; color: #FFF; }
#visual .scrollDown p span{ display: inline-block; transform: translateY(0); opacity: 0.3; }
#visual .scrollDown.on p span{ animation: scrollDown var(--duration) var(--delay) both; }

#visual .cover{ width: 100%; height: 100%; background: #000; position: absolute; top: 0; left: 0; z-index: 10; opacity: 0; pointer-events: none; }
#visual .cover i{ width: 45px; height: 45px; border: 6px solid rgba(255, 255, 255, 0.5); border-radius: 50%; border-top-color: #FFF; position: absolute; top: 50%; left: 50%; z-index: 100; transform: translate(-50%, -50%); animation: loading 1s linear infinite; display: none; }
#visual .cover button{ width: 75px; height: 75px; background: none; border: 2px solid var(--mainColor); border-radius: 50%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#visual .cover button::before{ content: ""; width: 12px; height: 15px; display: inline-block; background: var(--mainColor); clip-path: polygon(100% 50%, 0 0, 0 100%); -webkit-clip-path: polygon(100% 50%, 0 0, 0 100%); transform: translate(1px, 1px); }

@media screen and (hover: hover) and (pointer: fine){
	#visual .video::after{ display: block; }
	#visual .video iframe{ pointer-events: none; }

	#visual .cover{  opacity: 1; pointer-events: unset; }
	#visual .cover i{ display: block; }
	#visual .cover button{ display: none; }
}

@media screen and (max-width: 1700px){
	#visual .scrollDown{ font-size: 17px; }
}

@media screen and (max-width: 1280px){
	#visual .text .scrollDown{ margin-top: 40px; }
	#visual .scrollDown{ font-size: 16px; }
}

@media screen and (max-width: 800px){
	#visual .text{ padding-bottom: 30px; }
	#visual .text h2{ font-size: 4rem; }
	#visual .text h2 span{ display: block; }
	#visual .text .scrollDown{ margin-top: 20px; }
	#visual .scrollDown{ font-size: 15px; }
}


/* product */
#product{
	--min: 50px;
}
#product{ background: linear-gradient(to bottom, #FFF 63%, #F2F2F2 63%); }
#product .menu-box{ display: flex; }
#product .depth{ border-radius: 99px; padding: 10px; }
#product .depth button{ letter-spacing: -0.02em; }
#product .menu-box .tab-content01{ flex: 1 1 auto; min-width: 0; }
/* #product .tab-content01 .tab{ display: none; }
#product .tab-content01 > .tab:first-of-type,
#product .tab-content02 > .tab:first-of-type,
#product .tab-content03 > .tab:first-of-type{ display: block; } */


#product .depth2{ background: var(--mainColor); border: 2px solid var(--mainColor); margin-right: 50px; }
#product .depth2 ul{ display: flex; position: relative; z-index: 10; }
#product .depth2 ul::before{ content: ""; width: 160px; height: 100%; background: #FFF; border-radius: 99px; position: absolute; top: 0; left: 0; z-index: -1; transform: translateX(calc(var(--idx) * 100%)); transition: transform 0.4s; }
#product .depth2 ul li button{ width: 160px; height: var(--min); background: none; border: none; font-size: 17px; font-weight: 500; color: #FFF; text-stroke: 0.012em transparent; -webkit-text-stroke: 0.012em transparent; transition: color 0.4s, text-stroke-color 0.4s; } 
#product .depth2 ul li.on button{ color: var(--mainColor); text-stroke-color: var(--mainColor); -webkit-text-stroke-color: var(--mainColor); }


#product .depth3{ border: 2px solid #E5E5E5; }
#product .depth3 .swiper{ border-radius: 99px; }
#product .depth3 .swiper-wrapper::before{ content: ""; width: var(--width); height: 100%; background: #F2F2F2; border-radius: 99px; position: absolute; top: 0; left: 0; transform: translateX(var(--x)); transition: width 0.4s, transform 0.4s; }
#product .depth3 .swiper-slide{ width: auto; }
#product .depth3 button{ min-width: 103px; height: var(--min); background: none; border: none; padding: 4px 20px; } 
#product .depth3 button img{ max-height: 100%; }


#product .depth4{ min-height: 90px; display: flex; flex-direction: column; justify-content: center; margin-bottom: -90px; position: relative; z-index: 10; overflow: hidden; }
#product .depth4 ul{ display: flex; flex-wrap: wrap; margin: 0 -15px; }
#product .depth4 ul li{ position: relative; }
#product .depth4 ul li::before{ content: ""; width: 1px; height: 15px; background: #E5E5E5; position: absolute; top: 50%; left: 0; transform: translateY(-50%); }
#product .depth4 ul li button{ background: none; border: none; font-size: 19px; font-weight: 700; color: #CCC; padding: 5px 0; padding-inline: 16px 14px; }
#product .depth4 ul li.on button{ color: var(--mainColor); }

#product{ overflow: hidden; }
#product .overflow{ margin: 40px 0 -50px; margin-right: -50px; }
#product .product-wrap .slick-list{ padding: 50px 0; margin-top: -20px; }
#product .product{ padding-top: 20px; margin-right: 50px; }
#product .product a{ display: block; background: #FFF; box-shadow: 20px 20px 20px rgba(0, 0, 0, 0.1); border-radius: 20px; transform: translateY(0); transition: transform 0.4s, background 0.4s; }
#product .product .box{ border-radius: 20px; overflow: hidden; padding: 30px; margin: -1px; margin-bottom: 0; }
#product .product .img{ position: relative; }
#product .product .img::before{ content: ""; width: 150%; height: 150%; background: #F8F8F8; border-radius: 50%; position: absolute; bottom: 5%; left: 50%; transform: translateX(-50%); transition: background 0.4s; }
#product .product .img figure{ display: block; padding-bottom: 81.82%; position: relative; overflow: hidden; }
#product .product .img figure img{ width: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#product .product .mark{ position: absolute; top: 0; left: 0; right: 0; }
#product .product .mark ul{ display: grid; grid-template-columns: repeat(6, calc(100% / 6)); margin: -2px; }
#product .product .mark ul li{ margin: 2px; }
#product .product .txt{ position: relative; z-index: 10; margin-top: -55px; }
#product .product .txt h6{ display: flex; flex-direction: column; justify-content: flex-end; height: 4.5em; font-size: 28px; font-weight: 700; color: #111; line-height: 1.5; transition: color 0.4s; }
#product .product .txt h6 span{ display: -webkit-box; max-height: 4.5em; line-height: 1.5; white-space: normal; text-overflow: ellipsis; overflow: hidden; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
#product .product .txt div{ max-width: 100%; display: inline-flex; font-size: 18px; font-weight: 400; color: #111; transition: color 0.4s; margin-top: 5px; }
#product .product .txt p{ flex: 1 1 auto; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }


#product .btns{ display: flex; justify-content: center; margin-top: 70px; }
#product .btns button{ width: 70px; height: 70px; background: transparent; border: 2px solid var(--mainColor); border-radius: 50%; transition: background 0.4s; }
#product .btns button:not(:last-of-type){ margin-right: 10px; }
#product .btns button i{ display: block; height: 12px; background: url("/img/main/icon_arrow.svg") no-repeat center center / contain; transition: filter 0.4s; }
#product .btns .next i{ transform: rotate(180deg); }

@media screen and (hover: hover) and (pointer: fine){
	#product .depth2 ul:hover::before{ transform: translateX(calc(var(--idx2) * 100%)); }
	#product .depth2 ul:hover li.on button{ color: #FFF; text-stroke-color: transparent; -webkit-text-stroke-color: transparent; }
	#product .depth2 ul li:hover button{ color: var(--mainColor) !important; text-stroke-color: var(--mainColor) !important; -webkit-text-stroke-color: var(--mainColor) !important; }

	#product .depth3 .swiper-wrapper:hover::before{ width: var(--width2); transform: translateX(var(--x2)); }

	#product .product:hover a{ background: var(--mainColor); transform: translateY(-20px); }
	#product .product:hover .img::before{ background: #FFF; }
	#product .product:hover h6,
	#product .product:hover div{ color: #FFF; }

	#product .btns button:hover{ background: var(--mainColor); }
	#product .btns button:hover i{ filter: grayscale(1) brightness(5); -webkit-filter: grayscale(1) brightness(5); }
}

@media screen and (max-width: 1700px){
	#product .depth2{ margin-right: 40px; }
	#product .depth2 ul::before{ width: 140px; }
	#product .depth2 ul li button{ width: 140px; }

	#product .depth4 ul li button{ font-size: 18px; }

	#product .product .box{ padding: 25px; }
	#product .product .txt{ margin-top: -40px; }
	#product .product .txt h6{ font-size: 25px; }

	#product .btns{ margin-top: 50px; }
	#product .btns button{ width: 60px; height: 60px; }
}

@media screen and (max-width: 1280px){
	#product .depth{ padding: 5px; }

	#product .depth2{ margin-right: 30px; }
	#product .depth2 ul::before{ width: 120px; }
	#product .depth2 ul li button{ width: 120px; font-size: 16px; }

	#product .depth4{ min-height: 80px; margin-bottom: -35px; }
	#product .depth4 ul{ margin: 0 -10px; }
	#product .depth4 ul li button{ font-size: 17px; padding-inline: 11px 9px; }

	#product .overflow{ margin-top: -10px; margin-right: -30px; }
	#product .product{ margin-right: 30px; }
	#product .product .box{ padding: 20px; }
	#product .product .txt{ margin-top: -30px; }
	#product .product .txt h6{ font-size: 22px; }
	#product .product .txt div{ font-size: 17px; }

	#product .btns{ margin-top: 30px; }
	#product .btns button{ width: 55px; height: 55px; }
}

@media screen and (max-width: 1200px){
	#product .menu-box{ flex-direction: column; }
	#product .menu-box .tab-content01{ width: 100%; }
	
	#product .depth2{ margin-right: 0; margin-bottom: 10px; }
	#product .depth2 ul::before{ width: calc(100% / 3); }
	#product .depth2 ul li{ width: calc(100% / 3); }
	#product .depth2 ul li button{ width: 100%; height: 40px; } 
}

@media screen and (max-width: 1000px){
	#product .overflow{ margin-right: -20px; }
	#product .product{ margin-right: 20px; }
	#product .product .txt{ margin-top: -25px; }
}

@media screen and (max-width: 900px){
	#product .product .txt h6{ font-size: 21px; }
}

@media screen and (max-width: 650px){
	/* #product .product{ width: 300px; } */

	#product .product .txt h6{ font-size: 19px; }
	#product .product .txt div{ font-size: 16px; }
} 


/* company */
#company{ background: url("/img/main/company_bg.jpg") no-repeat center left 53% / cover; overflow: hidden; }
#company .relative{ height: 100vh; display: flex; flex-direction: column; justify-content: flex-end;  padding: 120px 0; position: relative; opacity: 1 !important; }

#company .left h2{ display: inline-block; font-size: 9.2rem; font-weight: 700; color: rgba(255, 255, 255, 0.3); margin-bottom: 60px; padding-right: 100px; position: relative; }
#company .left p{ font-size: 24px; font-weight: 500; color: rgba(255, 255, 255, 0.3); line-height: 1.7; }
#company .left span{ background: linear-gradient(to right, #fff, #fff, #fff, #fff 50%, transparent 50%); background-clip: text; -webkit-background-clip: text; background-size: 200% 100%; background-position: 100%; }
#company .left h2 span{ transition: background-position 1s linear; }
#company .left p span{ transition: background-position 2s 1s linear; }
#company .left .plus{ width: 80px; height: 80px; display: inline-flex; flex-direction: column; justify-content: center; position: absolute; bottom: calc(1.2em / 2); right: 0; z-index: 10; transform: translateY(50%); }
#company .left .plus::before,
#company .left .plus::after{ content: ""; position: absolute; top: 50%; left: 50%; z-index: -1; box-sizing: border-box; transition: transform 0.4s, opacity 0.4s; }
#company .left .plus::before{ width: 100%; height: 100%; background: var(--mainColor); border-radius: 50%; transform: translate(-50%, -50%) scale(0); opacity: 1; }
#company .left .plus::after{ width: 50%; height: 50%; border: 2px solid #FFF; border-radius: 50%; transform: translate(-50%, -50%) scale(1); opacity: 1; }
#company .left .plus i{ display: block; height: 12px; background: url("/img/main/icon_plus.svg") no-repeat center center / contain; }

#company .right{ width: 46%; position: absolute; top: 50%; right: 0; transform: translateY(-50%); text-align: right; }

#company .aos-animate span{ background-position: 0; }

@media screen and (hover: hover) and (pointer: fine){
	#company .left .plus:hover::before{ opacity: 1; transform: translate(-50%, -50%) scale(1); }
	#company .left .plus:hover::after{ opacity: 0; transform: translate(-50%, -50%) scale(0); }
}

@media screen and (max-width: 1700px){
	#company .left h2{ margin-bottom: 40px; padding-right: 90px; }
	#company .left p{ font-size: 21px; }
	#company .left .plus{ width: 70px; height: 70px; }
}

@media screen and (max-width: 1280px){
	#company .relative{ padding: 80px 0; }
	#company .left h2{ margin-bottom: 25px; padding-right: 75px; }
	#company .left p{ font-size: 19px; }
	#company .left .plus{ width: 60px; height: 60px; }

	#company .right{ top: 50%; }
}

@media screen and (max-width: 900px){
	#company .relative{ height: auto; flex-direction: column-reverse; justify-content: center; text-align: center; }
	#company .left{ position: relative; padding-bottom: 80px; }
	#company .left h2{ font-size: 8rem; position: static; padding-right: 0; }
	#company .left p br{ display: none; }
	#company .left .plus{ bottom: 0; right: 50%; transform: translateX(50%); }

	#company .right{ width: 80%; position: static; transform: unset; margin: 0 auto; }
	#company .right figure{ transform: unset !important; }
}


/* network */
#network .map{ position: relative; }
#network .map .bg{ display: flex; position: relative; }
#network .map .bg::after{ content: ""; width: 100%; height: 100%; display: none; position: absolute; top: 0; left: 0; }
#network .map svg{ width: 100%; height: auto; overflow: visible; pointer-events: none; }
#network .map svg .circle circle{ transform: scale(0); transform-box: content-box; transform-origin: center; opacity: 0; animation: mapCircle 2.5s linear infinite; }
#network .map svg .area{ pointer-events: bounding-box; cursor: pointer; }

#network .item{ width: 300px; background: #FFF; border-radius: 10px; box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.1); padding: 30px; position: absolute; opacity: 0; transform: translateY(20px); pointer-events: none; transition: opacity 0.4s, transform 0.4s; }
#network .item.on{ opacity: 1; transform: translateY(0); pointer-events: auto; }
#network .item dl dt{ position: relative; font-size: 24px; font-weight: 700; color: #111; padding-block: calc((35px - 1.3em) / 2); padding-left: 50px; }
#network .item dl dt .flag{ width: 35px; position: absolute; top: 0; left: 0; }
#network .item dl dd{ font-size: 17px; font-weight: 400; color: #555; line-height: 1.5; margin-top: 25px; }
#network .item dl dd p{ padding-left: 22px; position: relative; }
#network .item dl dd p:not(:last-of-type){ margin-bottom: 15px; }
#network .item dl dd p::before{ content: ""; width: 12px; height: 15px; position: absolute; top: calc(1.5em / 2); left: 0; transform: translateY(-50%); }
#network .item dl dd p.add::before{ background: url("/img/main/icon_marker.svg") no-repeat center center / contain; }
#network .item dl dd p.tel::before{ background: url("/img/main/icon_tel.svg") no-repeat center center / contain; }

#network .item01{ top: 42%; left: 71.5%; }
#network .item02{ top: 72%; left: 34%; }
#network .item03{ top: 64%; left: 35%; }
#network .item04{ top: 57.5%; left: 18%; }
#network .item05{ top: 48.5%; left: 37%; }

#network .slick-dots{ display: flex; justify-content: center; }
#network .slick-dots li{ width: 10px; height: 10px; background: transparent; border: 2px solid var(--mainColor); border-radius: 99px; transition: width 0.4s, background 0.4s; cursor: pointer; will-change: width, background; }
#network .slick-dots li:not(:last-of-type){ margin-right: 5px; }
#network .slick-dots li.slick-active{ width: 30px; background: var(--mainColor); }
#network .slick-dots button{ display: none; }

@media screen and (max-width: 1280px){
	#network .item{ padding: 25px; }
	#network .item dl dt{ font-size: 21px; }
	#network .item dl dd{ margin-top: 15px; }
	#network .item dl dd p:not(:last-of-type){ margin-bottom: 10px; }
}

@media screen and (max-width: 1100px){
	#network .map .bg::after{ display: block; }
	#network .item-wrap{ width: calc(100% + 40px); margin-left: -20px; }
	#network .item-wrap .slick-list{ padding-block: 20px !important; }
	#network .item-wrap .slick-track{ display: flex; }
	#network .item{ width: 350px; height: auto; float: unset !important; position: relative; top: 0 !important; left: 0 !important; opacity: 1; transform: unset; pointer-events: auto; padding: 20px; margin-right: 20px; }
}

@media screen and (max-width: 900px){
	#network .item dl dt{ font-size: 19px; }
}

@media screen and (max-width: 670px){
	#network .title-box br{ display: none; }
}




/* sns */
#sns .title-box{ position: relative; z-index: 10; }
#sns .title-box .flex{ display: flex; justify-content: space-between; align-items: flex-end; }
#sns .select{ display: flex; margin: -10px 0; }
#sns .select > div{ position: relative; }
#sns .select > div:not(:last-child){ margin-right: 20px; }
#sns .select button{ display: inline-flex; justify-content: center; align-items: center; background: none; border: none; font-size: 17px; font-weight: 600; color: #111; padding: 10px 0; padding-right: 35px; position: relative; }
#sns .select button::after{ content: ""; width: 10px; height: 6px; background: url("/img/main/icon_select.svg") no-repeat center center / contain; position: absolute; top: 50%; right: 0; transform: translateY(-50%) scaleY(1); transition: transform 0.4s; }
#sns .select button i{ width: 40px; height: 40px; display: inline-block; border: 2px solid var(--mainColor); border-radius: 50%; margin-right: 15px; overflow: hidden; }
#sns .select button i::before{ content: ""; width: 100%; height: 100%; display: block; }
#sns .select .youtube button i::before{ background: url("/img/main/icon_youtube.svg") no-repeat center center / contain; }
#sns .select .insta button i::before{ background: url("/img/main/icon_insta.svg") no-repeat center center / contain; }
#sns .select ul{ background: #FFF; border-radius: 10px; position: absolute; top: 100%; left: calc(50% + 20px); transform: translateX(-50%); padding: 23px; opacity: 0; margin-top: 20px; pointer-events: none; transition: opacity 0.4s, margin 0.4s; }
#sns .select ul li a{ display: block; font-size: 17px; font-weight: 600; color: #CCC; line-height: 1.3; padding: 7px; transition: color 0.4s; }

#sns .select .on button::after{ transform: translateY(-50%) scaleY(-1); }
#sns .select .on ul{ opacity: 1; margin-top: 0; pointer-events: auto; }


#sns .overflow{ overflow: hidden; }
#sns .overflow .slide{ display: flex; }
#sns .overflow .slide:not(:last-of-type){ margin-bottom: 20px; }
#sns .overflow .slide .box, 
#sns .overflow .slide ul{ width: max-content; display: flex; }
#sns .overflow .slide ul li{ padding-right: 20px; }
#sns .overflow .slide ul li a{ display: block; width: 300px; }
#sns .overflow .slide ul li figure{ display: block; position: relative; padding-bottom: 100%; overflow: hidden; }
#sns .overflow .slide ul li figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }


/* 왼쪽으로 롤링 */
#sns .overflow .slide01 .origin{ animation: calc(var(--length) * 4s) linear 0s infinite normal forwards running origin_left; }
#sns .overflow .slide01 .clone{ animation: calc(var(--length) * 4s) linear 0s infinite normal none running clone_left; }

/* 오른쪽으로 롤링 */
#sns .overflow .slide02 .origin{ animation: calc(var(--length) * 4s) linear 0s infinite normal forwards running origin_right; }
#sns .overflow .slide02 .clone{ animation: calc(var(--length) * 4s) linear 0s infinite normal none running clone_right; }

#sns .contact{ text-align: center; }
#sns .contact h4{ font-size: 5.4rem; font-weight: 300; color: #111; line-height: 1.4; }
#sns .contact h4 strong{ font-weight: 700; }
#sns .contact a{ display: inline-flex; justify-content: center; align-items: center; font-size: 19px; font-weight: 700; color: var(--mainColor); padding: 24px 48px; position: relative; z-index: 10; transition: color 0.6s; }
#sns .contact a::before,
#sns .contact a::after{ content: ""; width: 100%; height: 100%; border-radius: 99px; position: absolute; top: 0; left: 0; z-index: -1; box-sizing: border-box; }
#sns .contact a::before{ border: 2px solid var(--mainColor); opacity: 1; transition: opacity 0.4s; }
#sns .contact a::after{ background: var(--mainColor); clip-path: inset(0 100% 0 0 round 99px); -webkit-clip-path: inset(0 100% 0 0 round 99px); transition: clip-path 0.6s; }

@media screen and (hover: hover) and (pointer: fine){
	#sns .select ul li:hover a{ color: var(--mainColor); }

	#sns .contact a:hover{ color: #FFF; }
	#sns .contact a:hover::before{ opacity: 0; }
	#sns .contact a:hover::after{ clip-path: inset(0 0 0 0 round 99px); -webkit-clip-path: inset(0 0 0 0 round 99px); }
} 

@media screen and (max-width: 1700px){
	#sns .contact a{ font-size: 18px; padding: 20px 40px; }
}

@media screen and (max-width: 1280px){
	#sns .select button i{ width: 35px; height: 35px; }
	#sns .select ul{ padding: 18px; left: calc(50% + 17px); }

	#sns .overflow .slide ul li a{ width: 250px; }

	#sns .contact a{ font-size: 17px; padding: 17px 30px; }
}

@media screen and (max-width: 1000px){
	#sns .title-box .flex{ flex-direction: column; align-items: center; }
	#sns .title-box h3{ margin-bottom: 30px; }

	#sns .select button{ padding-right: 20px; }
	#sns .select button i{ width: 30px; height: 30px; margin-right: 10px; }
	#sns .select button i::before{ width: 34px; height: 34px; transform: translate(-4px, -4px); }
	#sns .select ul{ padding: 13px; left: calc(50% + 15px); }
}

@media screen and (max-width: 900px){
	#sns .overflow .slide ul li a{ width: 200px; }
}

@media screen and (max-width: 650px){ 
	#sns .contact span{ display: block; }
}


/* group */
#group .flex-box{ display: flex; text-align: center; }
#group .flex-box .item{ width: calc((100% + 200px) / 6); background: #F2F2F2; border-radius: 50%; margin-right: -40px; position: relative; }
#group .flex-box .item:last-of-type{ margin-right: 0 !important; }
#group .flex-box .item::before,
#group .flex-box .item::after{ content: ""; width: 40px; height: 40px; background: #F2F2F2; mask: radial-gradient(circle 40px at 35px 35px, transparent 0, transparent 35px, black 36px); -webkit-mask: radial-gradient(circle 40px at 35px 35px, transparent 0, transparent 35px, black 36px); position: absolute; right: 0; }
#group .flex-box .item::before{ top: 9.5%; transform: rotate(-135deg); }
#group .flex-box .item::after{ bottom: 9.5%; transform: rotate(45deg); }
#group .flex-box .item:last-of-type::before,
#group .flex-box .item:last-of-type::after{ display: none; }
#group .flex-box .item .circle{ padding-bottom: 100%; }
#group .flex-box .item dl{ width: 100%; height: 100%; display: flex; flex-direction: column; padding: 60px; position: absolute; top: 0; left: 0; }
#group .flex-box .item dl dt{ background: var(--mainColor); border-radius: 99px; font-size: 18px; font-weight: 500; color: #FFF; padding: 8px; margin-bottom: 10px; }
#group .flex-box .item dl.green dt{ background: var(--green); }
#group .flex-box .item dd{ flex: 1 0 auto; display: flex; flex-direction: column; justify-content: center; margin: 0 -20px; }
#group .flex-box .item dd ul{ display: flex; flex-wrap: wrap; justify-content: center; align-items: center; margin: -7px -10px; }
#group .flex-box .item dd ul li a{ display: block; padding: 7px 10px; }

@media screen and (max-width: 1700px){
	#group .flex-box .item dl{ padding-block: 50px; }
	#group .flex-box .item dl dt{ font-size: 16px;}
}

@media screen and (max-width: 1450px){
	#group .flex-box .item{ width: calc((100% + 150px) / 6); margin-right: -30px; }
	#group .flex-box .item::before,
	#group .flex-box .item::after{ width: 30px; height: 30px; }
	#group .flex-box .item::before{ top: 12%; }
	#group .flex-box .item::after{ bottom: 12%; }
	#group .flex-box .item dl{ padding: 40px 50px; }
}

@media screen and (max-width: 1350px){
	#group .flex-box{ max-width: 800px; flex-wrap: wrap; margin: 0 auto; }
	#group .flex-box .item{ width: calc((100% + 60px) / 3); margin-bottom: -20px; }
	#group .flex-box .item::before{ top: 15%; }
	#group .flex-box .item::after{ bottom: 15%; }

	#group .flex-box .item:nth-of-type(3n){ margin-right: 0; }
	#group .flex-box .item:nth-of-type(3n)::before,
	#group .flex-box .item:nth-of-type(3n)::after{ display: none; }

	#group .flex-box .item .circle::before,
	#group .flex-box .item .circle::after{ content: ""; width: 30px; height: 30px; background: #F2F2F2;  mask: radial-gradient(circle 40px at 35px 35px, transparent 0, transparent 35px, black 36px); -webkit-mask: radial-gradient(circle 40px at 35px 35px, transparent 0, transparent 35px, black 36px); position: absolute; top: 0; }
	#group .flex-box .item .circle::before{ left: 20%; transform: rotate(125deg); }
	#group .flex-box .item .circle::after{ right: 20%; transform: rotate(-35deg); }

	#group .flex-box .item:nth-of-type(1) .circle::before,
	#group .flex-box .item:nth-of-type(2) .circle::before,
	#group .flex-box .item:nth-of-type(3) .circle::before,
	#group .flex-box .item:nth-of-type(1) .circle::after,
	#group .flex-box .item:nth-of-type(2) .circle::after,
	#group .flex-box .item:nth-of-type(3) .circle::after{ display: none; }
}

@media screen and (max-width: 750px){
	#group .flex-box{ max-width: 500px; }
	#group .flex-box .item{ width: calc((100% + 20px) / 2); margin-right: -20px; }
	#group .flex-box .item::before,
	#group .flex-box .item::after{ right: -5px; }
	#group .flex-box .item::before{ top: 17%; }
	#group .flex-box .item::after{ bottom: 17%; }
	#group .flex-box .item .circle::before,
	#group .flex-box .item .circle::after{ top: -1%; }
	#group .flex-box .item .circle::before{ left: 17%; }
	#group .flex-box .item .circle::after{ right: 17%; }
	#group .flex-box .item dl{ padding: 35px; }
	#group .flex-box .item dl dt{ width: 90%; margin-inline: auto; }

	#group .flex-box .item:nth-of-type(3n){ margin-right: -20px; }
	#group .flex-box .item:nth-of-type(3n)::before,
	#group .flex-box .item:nth-of-type(3n)::after{ display: block; }

	#group .flex-box .item:nth-of-type(2n){ margin-right: 0; }
	#group .flex-box .item:nth-of-type(2n)::before,
	#group .flex-box .item:nth-of-type(2n)::after{ display: none; }


	#group .flex-box .item:nth-of-type(3) .circle::before,
	#group .flex-box .item:nth-of-type(3) .circle::after{ display: block; }
}


/* noodles */
.noodles{ padding-bottom: 70px; }
.noodles .overflow{ overflow: hidden; }
.noodles .overflow *{ width: max-content; }
.noodles .overflow img{ width: auto !important; }
.noodles .overflow > div{ display: flex; }
.noodles .overflow .origin{ animation: 120s linear 0s infinite normal forwards running origin_right; }
.noodles .overflow .clone{ animation: 120s linear 0s infinite normal none running clone_right; }

@media screen and (max-width: 1700px){
	.noodles img{ height: 150px; }
}

@media screen and (max-width: 1280px){
	.noodles{ padding-top: 30px; }
	.noodles img{ height: 120px; }
}

@media screen and (max-width: 900px){
	.noodles img{ height: 100px; }
}

@media screen and (max-width: 600px){
	.noodles img{ height: 80px; }
}