/* intro */
#intro{ width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 1000; animation: intro 1s 2.9s both; }
#intro .box{ display: flex; justify-content: center; align-items: center; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
#intro .box h1{ animation: textClip 1s 0.3s both; }
#intro .box svg{ width: auto; height: auto; }

#intro .box1{ background: linear-gradient(to right, var(--mainColor), #408DC9); z-index: 10; animation: bgClip 0.7s 1.8s reverse both; }
#intro .box1 svg path{ fill: #FFF; }
#intro .box2{ background: #FFF; }

@media screen and (max-width: 1600px){
	#intro .box svg{ height: 85px; }
}

@media screen and (max-width: 1280px){
	#intro .box svg{ height: 60px; }
}

@media screen and (max-width: 900px){
	#intro .box svg{ height: 50px; }
}



/* 메인 비주얼 이미지 */
#visual .visual .bg01{ background: url("/img/main/visual01.jpg") no-repeat center center / cover; }
#visual .visual .bg02{ background: url("/img/main/visual02.jpg") no-repeat center center / cover; }
#visual .visual .bg03{ background: url("/img/main/visual03.jpg") no-repeat center center / cover; }


/* common */
#main{ background: var(--blueBg); padding-top: var(--headerH); position: relative; overflow-x: clip; }
#main .overflow{ overflow: hidden; }

#main .deco{ position: absolute; overflow: hidden; padding: 1px 0; }
#main .deco::before{ content: ""; width: 100%; display: block; border: 1px dashed var(--mainColor); border-radius: 50%; padding-bottom: 100%; opacity: 0.25; box-sizing: border-box; position: relative; animation-name: rotate360; animation-timing-function: linear; animation-iteration-count: infinite; }

@media screen and (max-width: 1650px){
	#main .pl{ padding-left: 60px !important; }
}

@media screen and (max-width: 1200px){
	#main .pl{ padding-left: 20px !important; }
}


/* nav */
#nav{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 100; pointer-events: none; }
#nav .sticky{ position: sticky; top: 100px; left: 0; }
#nav ul{ max-width: max-content; display: flex; flex-direction: column; align-items: center; }
#nav ul li{ display: flex; align-items: center; font-family: var(--engFont); font-size: 16px; font-weight: 700; color: var(--mainColor); letter-spacing: -0.02em; cursor: pointer; pointer-events: auto; }
#nav ul li{ writing-mode: vertical-lr; }
#nav ul li::before{ content: ""; display: inline-block; width: 10px; height: 10px; background: #CCC; border-radius: 50%; margin-bottom: 20px; }
#nav ul li span{ padding-bottom: 40px; display: none; }

#nav ul li.active span{ display: block; }
#nav ul li.active::before{ background: var(--mainColor); }

#nav.white ul li{ color: #FFF; }
#nav.white ul li::before{ background: rgba(255, 255, 255, 0.3); }
#nav.white ul li.active::before{ background: #FFF; }

@media screen and (max-width: 1600px){
	#nav ul li::before{ margin-bottom: 15px; }
	#nav ul li span{ padding-bottom: 25px; }
}

@media screen and (max-width: 1280px){
	#nav ul li{ font-size: 15px; }
	#nav ul li::before{ width: 5px; height: 5px; }
}

@media screen and (max-width: 1200px){
	#nav{ display: none; }
}


/* title-box */
.title-box span{ display: inline-block; font-family: var(--engFont); font-size: 20px; font-weight: 800; color: var(--mainColor); letter-spacing: -0.02em; margin-bottom: 10px; }
.title-box h3{ font-size: 6.4rem; font-weight: 600; color: #111; letter-spacing: -0.02em; }
.title-box p{ font-size: 20px; font-weight: 300; color: #222; letter-spacing: -0.02em; line-height: 1.7; margin-top: 50px; }

@media screen and (max-width: 1600px){
	.title-box span{ font-size: 18px; }
	.title-box p{ font-size: 18px; }
}

@media screen and (max-width: 1280px){
	.title-box span{ font-size: 16px; margin-bottom: 5px; }
	.title-box p{ font-size: 17px; margin-top: 30px; }
}

@media screen and (max-width: 900px){
	.title-box h3{ font-size: 6rem; }
}


/* flex-layout */
.flex-layout{ display: flex; }
.flex-layout .title{ width: 490px; }
.flex-layout .content{ width: calc(100% - 490px); }

@media screen and (max-width: 1600px){
	.flex-layout .title{ width: 380px; }
	.flex-layout .content{ width: calc(100% - 380px); }
}

@media screen and (max-width: 1000px){
	.flex-layout{ flex-direction: column; }
	.flex-layout .title,
	.flex-layout .content{ width: 100%; }
}


/* visual */
#visual{
	--clip: 70%;
	--height: 300px;
}

#visual{ background: #FFF; position: relative; z-index: 200; overflow: hidden; }
#visual .visual{ outline: none; opacity: 1 !important; }
#visual .visual .inner{ width: var(--clip); margin-left: auto; overflow: hidden; clip-path: inset(0 0 0 100%); -webkit-clip-path: inset(0 0 0 100%); }
#visual .visual .bg{ height: calc(100vh - var(--headerH)); }

#visual .visual.slick-active .inner{ animation: bgClip 1s both; }
#visual .visual.slick-active .bg{ animation: bgScale 3.2s 2s both; }


#visual .text-box{ position: absolute; top: 13%; left: 0; right: 0; z-index: 10; }
#visual .text-box ul li:not(.active){ display: none; }
#visual .text-box h2{ font-family: var(--engFont); font-size: 9.8rem; font-weight: 800; letter-spacing: -0.03em; margin-bottom: 20px; }
#visual .text-box p{ font-size: 5.8rem; font-weight: 600; letter-spacing: -0.03em; }
#visual .text-box span{ display: inline-block; }

#visual .text-box .black{ color: #111; position: absolute; top: 0; left: 0; right: 0; -webkit-clip-path: inset(0 var(--clip) 0 0); }
#visual .text-box .white{ color: #FFF; clip-path: inset(0 var(--clip) 0 0);  clip-path: inset(0 0 0 calc(100% - var(--clip))); -webkit-clip-path: inset(0 0 0 calc(100% - var(--clip))); }

#visual .text-box ul li.active > *{ animation: textClip 1s both; }
#visual .text-box ul li.active span{ animation: innerLeft 1s 1s both; }

#visual.start .text-box ul li.active > *{ animation: textClip 1s 1s both; }
#visual.start .text-box ul li.active span{ animation: innerLeft 1s 2s both; }


#visual .dots{ position: absolute; bottom: 70px; left: 0; right: 0; }
#visual .dots ul{ display: flex !important; }
#visual .dots ul li{ width: 15px; height: 15px; border: 1px solid #DDD; cursor: pointer; }
#visual .dots ul li:not(:last-of-type){ margin-right: 10px; }
#visual .dots ul li.slick-active{ background: var(--mainColor); border-color: var(--mainColor); }
#visual .dots button{ display: none; }

#visual .scrollDown{ position: absolute; bottom: 70px; left: 0; right: 0; pointer-events: none; }
#visual .scrollDown .flex{ display: flex; justify-content: flex-end; align-items: flex-end; }
#visual .scrollDown .flex > div{ position: relative; }
#visual .scrollDown .img{ margin-right: 15px; }
#visual .scrollDown .img svg{ animation: scrollDown 2.5s linear infinite alternate; }
#visual .scrollDown .img svg path{ animation: scrollDownSvg 2.5s linear infinite alternate; }
#visual .scrollDown .text{ font-family: var(--engFont); font-size: 17px; font-weight: 700; color: #BBB; letter-spacing: -0.03em; line-height: 1; }
#visual .scrollDown .text span{ display: inline-block; animation: scrollDownText 2.5s linear infinite alternate; }

@media screen and (max-width: 1800px){
	#visual .scrollDown{ padding-right: 50px; }
}

@media screen and (max-width: 1600px){
	#visual .scrollDown .text{ font-size: 16px; }
}

@media screen and (max-width: 1280px){
	#visual .dots{ bottom: 30px; }
	#visual .dots ul li{ width: 12px; height: 12px; }

	#visual .scrollDown{ bottom: 30px; }
	#visual .scrollDown .img{ margin-right: 10px; }
	#visual .scrollDown .text{ font-size: 15px; }
}

@media screen and (max-width: 1000px){
	#visual{
		--clip: 100%;
	}

	#visual .visual .inner{ height: calc(100vh - var(--headerH) - var(--height)); margin-top: var(--height); }

	#visual .text-box{ display: flex; align-items: center; top: 0; }
	#visual .text-box h2{ margin-bottom: 10px; }
	#visual .text-box .black{ display: flex; align-items: center; height: var(--height); z-index: 10; clip-path: unset; -webkit-clip-path: unset; }

	#visual .text-box ul li.active span,
	#visual.start .text-box ul li.active span{ animation: unset; }
}

@media screen and (max-width: 900px){
	#visual{
		--height: 200px;
	}

	#visual .text-box h2{ font-size: 8rem; }
	#visual .text-box p{ font-weight: 4rem; }
}


/* slogan */
#slogan{ height: 100vh; background: #FFF; font-family: var(--engFont); text-align: center; position: relative; transition: background 1s; }
#slogan.bg{ background: var(--blueBg); }
#slogan .motion{ position: absolute; top: 50%; left: 0; right: 0; transform: translateY(-50%); }
#slogan .motion *{ font-size: 7rem; font-weight: 800; letter-spacing: -0.02em; }

#slogan .motion1{ color: #000; }
#slogan .motion1 .flex{ display: flex; justify-content: center; }
#slogan .motion1 h2{ position: relative; }
#slogan .motion1 span{ display: inline-block; position: relative; }
#slogan .motion1 em{ display: inline-block; opacity: 0; transform: translateY(100%); }
#slogan .motion1 i{ display: inline-block; font-style: normal; margin: 0; clip-path: circle(0 at 50% 50%); -webkit-clip-path: circle(0 at 50% 50%); transition: clip-path 1s, margin 1s; }
#slogan .motion1.start i{ margin: 0 30px; clip-path: circle(50% at 50% 50%); -webkit-clip-path: circle(50% at 50% 50%); }

#slogan .word1 span{ left: 100%; transform: translateX(-100%); }

#slogan .motion2{ z-index: 10; opacity: 0; }
#slogan .motion2 h2{ color: var(--mainColor); }

#slogan .cover{ width: 100%; height: 100%; background: var(--blueBg); clip-path: circle(17% at 50% 140%); }

@media screen and (max-width: 1280px){
	#slogan .motion1 h2:first-of-type{ margin-right: -5px; }
	#slogan .motion1 h2:last-of-type{ margin-left: -5px; }
}


/* about */
#about{ position: relative; z-index: 10; }
#about .about{ padding-top: 180px; position: relative; z-index: 10; }
#about .about .deco{ max-width: 590px; width: 32%; top: 50%; left: 0; z-index: -1; transform: translateY(-44%); }
#about .about .deco::before{ left: -45%; animation-duration: 60s; }

#about .content{ margin-top: 36px; padding-right: 150px; position: relative; }
#about .content h5{ font-size: 36px; font-weight: 600; color: #111; letter-spacing: -0.02em; line-height: 1.5; margin-bottom: 50px; }
#about .content p{ font-size: 20px; font-weight: 300; color: #222; letter-spacing: -0.02em; line-height: 1.7;  }
#about .content ul{ display: flex; flex-wrap: wrap; margin-top: 80px; margin-bottom: -10px; }
#about .content ul li{ width: 180px; height: 60px; display: flex; justify-content: center; align-items: center; border: 1px solid var(--mainColor); font-size: 17px; font-weight: 300; color: var(--mainColor); letter-spacing: -0.02em; line-height: 1; text-align: center; margin-right: 15px; margin-bottom: 10px; }
#about .content ul li:last-of-type{ margin-right: 0; }

#about .more{ position: absolute; top: 0; right: 0; }
#about .more svg{ width: auto; height: auto; }
#about .more svg path{ transition: stroke 0.3s; }

@media screen and (hover: hover){
	#about .more a:hover svg path{ stroke: var(--mainColor); }
}

@media screen and (max-width: 1600px){
	#about .about{ padding-top: 130px; }
	#about .content h5{ font-size: 30px; margin-bottom: 40px; }
	#about .content p{ font-size: 18px; }
	#about .content ul{ margin-top: 50px; }
	#about .content ul li{ width: 160px; height: 55px; font-size: 16px; }

	#about .content{ padding-right: 120px; }
	#about .more svg{ width: 80px; }
}

@media screen and (max-width: 1280px){
	#about .about{ padding-top: 80px; }
	#about .content{ margin-top: 25px; padding-right: 100px; }
	#about .content h5{ font-size: 26px; margin-bottom: 20px; }
	#about .content p{ font-size: 17px; }
	#about .content ul{ margin-top: 30px; margin-right: -10px; }
	#about .content ul li{ width: 140px; height: 50px; font-size: 15px; margin-right: 10px; }

	#about .more svg{ width: 60px; }
}

@media screen and (max-width: 1000px){
	#about .content{ margin-top: 15px; padding-right: 0; }
	#about .content h5{ margin-bottom: 10px; }
	#about .more{ top: -17%; }
}

@media screen and (max-width: 900px){
	#about .content h5{ font-size: 22px; }
	#about .more{ top: -23%; }
}

@media screen and (max-width: 650px){
	#about .about br{ display: none; }
}


/* sevice */
#service{
	--gapR: 50px;
	--gapB: 80px;
}

#service{ padding: 200px 0 180px; }
#service .service-box{ position: relative; }

#service .deco1{ max-width: 1090px; width: 60%; top: 0; left: 0; transform: translateY(-70%); }
#service .deco1::before{ left: -39%; animation-duration: 100s; animation-direction: reverse; }
#service .deco2{ max-width: 830px; width: 45%; top: 0; right: 0; transform: translateY(-54%); }
#service .deco2::before{ right: -40%; animation-duration: 100s; }

#service .left{ position: absolute; top: 0; right: 0; left: 0; bottom: 0; }
#service .left .sticky{ position: sticky; top: 100px; left: 0; }
#service .left .title-box{ width: 490px; }
#service .left .text-flow{ display: flex; margin-top: 135px; }
#service .left .text-flow h4{ font-family: var(--engFont); font-size: 15rem; font-weight: 800; color: var(--navy); opacity: 0.04; white-space: nowrap; padding-right: 40px; }
#service .left .text-flow .origin{ animation: origin_left 40s linear infinite; }
#service .left .text-flow .clone{ animation: clone_left 40s linear infinite; }

#service .item-box{ width: calc(100% - 490px); display: flex; flex-wrap: wrap; margin-left: auto; margin-bottom: calc(var(--gapB) * -1); }
#service .item-box .item{ width: calc((100% - var(--gapR)) / 2); position: relative; margin-right: var(--gapR); margin-bottom: var(--gapB); overflow: hidden; }
#service .item-box .item:nth-of-type(even){ margin-right: 0; top: var(--gapB); }
#service .item-box .item::before{ content: ""; background: linear-gradient(to right, var(--mainColor), transparent); position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 5; transform: translateX(-100%); transform-origin: left; transition: transform 0.5s; }
#service .item-box .item .bg{ position: relative; padding-bottom: 100%; }
#service .item-box .item .bg img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }

#service .item-box .item .text{ display: flex; flex-direction: column; justify-content: flex-end; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; padding: 60px 50px; }
#service .item-box .item .text dl dt{ font-size: 28px; font-weight: 600; color: #FFF; letter-spacing: -0.02em; }
#service .item-box .item .text dl dd{ font-size: 19px; font-weight: 300; color: #FFF; letter-spacing: -0.02em; padding-left: 15px; position: relative; opacity: 0; transition: opacity 0.5s; }
#service .item-box .item .text dl dd:first-of-type{ margin-top: 35px; }
#service .item-box .item .text dl dd:not(:last-of-type){ margin-bottom: 10px; }
#service .item-box .item .text dl dd::before{ content: ""; width: 4px; height: 4px; background: #FFF; border-radius: 50%; position: absolute; top: calc(1.3em / 2); left: 0; transform: translateY(-50%); }

#service .item-box .item .relative{ position: relative; }
#service .item-box .item .opacity{ opacity: 0; }
#service .item-box .item .absolute{ position: absolute; top: 0; left: 0; right: 0; transform: translateY(0); transition: top 0.5s, transform 0.5s; }


#service .slide-info{ display: none; padding: 18px 0 3px; }
#service .slide-info .flex{ display: flex; align-items: center; }
#service .bar{ flex: 1 0 auto; height: 3px; background: #DDD; }
#service .bar div{ width: 0; height: 100%; background: var(--mainColor); }
#service .num{ width: 100px; font-family: var(--engFont); font-size: 20px; font-weight: 800; color: #BBB; text-align: right; }
#service .num .index{ color: var(--mainColor); }
#service .num em{ display: inline-block; margin-left: 2px; }


@media screen and (hover: hover){
	#service .item-box .item:hover::before{ transform: translateX(0); }
	#service .item-box .item:hover .absolute{ top: 100%; transform: translateY(-100%); }
	#service .item-box .item:hover dl dd{ opacity: 1; }
}

@media screen and (max-width: 1600px){
	#service{ padding: 150px 0 180px; }
	#service .left .title-box{ width: 380px; }

	#service .item-box{ width: calc(100% - 380px); }
	#service .item-box .item .text{ padding: 35px; }
	#service .item-box .item .text dl dt{ font-size: 24px; }
	#service .item-box .item .text dl dd{ font-size: 18px; }
	#service .item-box .item .text dl dd:first-of-type{ margin-top: 20px; }
}

@media screen and (max-width: 1280px){
	#service{
		--gapR: 30px;
		--gapB: 50px;
	}

	#service{ padding: 100px 0 180px; }
	#service .item-box .item .text{ padding: 25px; }
	#service .item-box .item .text dl dt{ font-size: 20px; }
	#service .item-box .item .text dl dd{ font-size: 17px; }
	#service .item-box .item{ max-width: 350px; width: 100%; }
}

@media screen and (max-width: 1050px){
	#service br{ display: none; }
	#service .left{ position: static; }
	#service .left .sticky{ position: static; }
	#service .deco1{ transform: translateY(-95%); }
	#service .deco2{ transform: translateY(15%); }
	#service .left .title-box{ width: 100%; }
	#service .left .title-box p{ margin-top: 20px; }

	#service .left .text-flow{ width: 100%; margin-top: 0; position: absolute; bottom: 0; left: 0; transform: translateY(100%); overflow: hidden; }

	#service .slick-list{ margin-right: calc(var(--gapR) * -1); }
	#service .item-box{ width: calc(100% + 20px); display: block; margin-top: 30px; overflow: hidden; }
	#service .item-box .item:nth-of-type(even){ top: unset; margin-right: var(--gapR); }

	#service .item-box .item.slick-active::before{ transform: translateX(0); }
	#service .item-box .item.slick-active .absolute{ top: 100%; transform: translateY(-100%); }
	#service .item-box .item.slick-active dl dd{ opacity: 1; }

	#service .slide-info{ display: block; }
}

@media screen and (max-width: 900px){
	#service .left .text-flow h4{ font-size: 12rem; opacity: 0.05; padding-right: 20px; }
}


/* news */
#news{ background: var(--mainColor); padding: 180px 0 200px; position: relative; overflow: hidden; }
#news::before{ content: ""; background: url("/img/main/partner_bg.png") no-repeat center center / cover; mix-blend-mode: multiply; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
#news .title-box span{ font-weight: 700; color: rgba(255, 255, 255, 0.5); }
#news .title-box h3{ color: #FFF; }

#news .flex-box{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 60px; }
#news .btns{ display: flex; padding-top: 36px; margin-right: -15px; }
#news .btns button{ background: none; border: none; padding: 15px; }
#news .btns button svg{ width: auto; height: auto; }
#news .btns button svg path{ stroke: #FFF; transition: stroke 0.3s; }
#news .btns button.none svg path{ stroke: rgba(255, 255, 255, 0.5); }

#news .slick-track{ margin: 0; }
#news .slick-list{ margin-right: -50px; }
#news .news{ margin-right: 50px; outline: none; }
#news .news a{ display: block; padding-bottom: 55px; position: relative; }
#news .news figure{ width: 100%; position: relative; overflow: hidden; padding-bottom: 69%; }
#news .news figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }

#news .news .text{ position: absolute; bottom: 0; left: 0; right: 0; padding: 0 40px; }
#news .news .text .inner{ background: #FFF; box-shadow: 0 0 20px rgba(0, 0, 0, 0.05); padding: 40px 45px; }
#news .news .text h6,
#news .news .text p{ display: -webkit-box; height: 3.2em; letter-spacing: -0.02em; line-height: 1.6; text-overflow: ellipsis; overflow: hidden; word-wrap: break-word; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
#news .news .text h6{ font-size: 24px; font-weight: 500; color: #111; }
#news .news .text ul{ margin-left: -12px; margin-bottom: -5px; }
#news .news .text p{ font-size: 19px; font-weight: 300; color: #555; margin: 37px 0 30px; }
#news .news .text ul li{ display: inline-block; font-size: 18px; font-weight: 600; color: #BBB; letter-spacing: -0.02em; line-height: 1.5; padding: 0 12px; margin-bottom: 5px; }
#news .news .text ul li::before{ content: "#"; line-height: inherit; }

@media screen and (max-width: 1600px){
	#news{ padding: 130px 0 150px; }
	#news .flex-box{ margin-bottom: 40px; }
	
	#news .news .text{ padding: 0 30px; }
	#news .news .text .inner{ padding: 30px 35px; }
	#news .news .text h6{ font-size: 21px; }
	#news .news .text p{ font-size: 17px; margin: 30px 0 25px; }
	#news .news .text ul li{ font-size: 16px; }
}

@media screen and (max-width: 1280px){
	#news{ padding: 80px 0 100px; }
	#news .flex-box{ margin-bottom: 30px; }

	#news .btns{ margin-right: -10px; }
	#news .btns button{ padding: 10px; }
	#news .btns button svg{ width: 50px; }

	#news .news-wrap{ width: calc(100% + 20px); }
	#news .slick-list{ margin-right: -20px; }
	#news .news{ margin-right: 20px; }

	#news .news .text{ padding: 0 20px; }
	#news .news .text .inner{ padding: 20px 25px; }
	#news .news .text h6{ font-size: 19px; }
	#news .news .text p{ font-size: 16px; margin: 20px 0 15px; }
	#news .news .text ul{ margin-left: -7px; }
	#news .news .text ul li{ font-size: 15px; padding: 0 7px; }
}

@media screen and (max-width: 900px){
	#news .flex-box{ flex-direction: column; align-items: flex-end; margin-bottom: 10px; }
	#news .title-box{ width: 100%; }
	#news .btns{ padding-top: 0; }

	#news .news{ max-width: 370px; width: 100%; }
	#news .news .text .inner{ padding: 15px 20px; }
	#news .news .text h6{ font-size: 18px; }
}


/* partner */
#partner{ background: #FFF; padding: 235px 0; position: relative; overflow: hidden; }
#partner > div{ position: relative; z-index: 10; }
#partner .title-box{ margin-bottom: 110px; }


#partner .logo-flow > div, 
#partner .logo-flow > div > div{ width: max-content; display: flex; }
#partner .logo-flow > div:not(:last-of-type){ margin-bottom: 40px; }
#partner .logo-flow figure{ width: 260px; height: 100px; display: flex; justify-content: center; align-items: center; margin-right: 50px; }
#partner .logo-flow figure img{ max-width: calc(100% - 30px); max-height: calc(100% - 30px); }

#partner .logo-flow .origin,
#partner .logo-flow .clone{ animation-timing-function: linear; animation-iteration-count: infinite; }

#partner .logo-flow .left .origin{ animation-name: origin_left; }
#partner .logo-flow .left .clone{ animation-name: clone_left; }
#partner .logo-flow .right .origin{ animation-name: origin_right; }
#partner .logo-flow .right .clone{ animation-name: clone_right; }

@media screen and (max-width: 1600px){
	#partner{ padding: 180px 0; }
	#partner .title-box{ margin-bottom: 80px; }

	#partner .logo-flow figure{ width: 230px; height: 90px; }
}

@media screen and (max-width: 1280px){
	#partner{ padding: 140px 0; }
	#partner .title-box{ margin-bottom: 50px; }

	#partner .logo-flow > div:not(:last-of-type){ margin-bottom: 20px; }
	#partner .logo-flow figure{ width: 210px; height: 85px; }
}

@media screen and (max-width: 1000px){
	#partner .title-box{ margin-bottom: 30px; }
	#partner{ padding: 100px 0; }
}