@charset "utf-8";

.free-seminar{ margin-top: 70px; padding: 50px; }

/* -------------------------------------------------------- fv */
#fv { width: 100%; }
#fv .flex { display: flex; align-items: stretch; justify-content: center; flex-wrap: wrap; }
#fv .fv-wrapper { background: var(--main-color); color: #fff; width: 50%; min-width: 320px; padding: 60px 45px; box-sizing: border-box; display: flex; flex-direction: column; justify-content: center; }
#fv .fv-wrapper .catchphrase { font-size: clamp(29px,4vw,65px); font-weight: bold; line-height: 1.4; margin-bottom: 30px; }
#fv .fv-wrapper .enphrase { font-family: 'Gilroy-Bold'; font-size: clamp(16px,2vw,41px); line-height: 1.3; margin-bottom: 30px; }
#fv .fv-wrapper .w-box { display: flex; align-items: flex-start; width: clamp(300px,88%,550px); background: #fff;  padding: 25px 15px; border-radius: 8px; margin-bottom: 30px; }
#fv .fv-wrapper .w-box img { width: 76px; height: auto; margin-right: 16px; flex-shrink: 0; }
#fv .fv-wrapper .w-box .text { font-size: 11px; line-height: 1.6; color: #000; }
#fv .fv-wrapper .w-box .text p{ margin: 0; }
#fv .fv-wrapper .w-box .text strong { display: block; font-size: clamp(16px,1.6vw,21px); color: #000; margin-bottom: 8px; }
#fv .fv-wrapper > img:last-of-type { width: 100%; height: auto; margin-top: auto; }
#fv .kv { width: 50%; min-width: 320px; object-fit: cover; }


/* -------------------------------------------------------- about */
#about { position: relative; margin: 25px 0 0; padding: 140px 0; }
#about .s-ttl{ font-size: 39px; }
#about .flex { display: flex; align-items: flex-end; justify-content: flex-start; flex-wrap: wrap; }
#about .txt-content { width: clamp(320px,48%,480px); padding-bottom: 50px; }

#about .sv{ padding-bottom: 85px; }
#about .scroll-infinity{ width: calc(100% - 200px); margin: 0; }

#about .flex-item { width: min(390px,38%); margin-left: 20px; }
#about .flex-item img { width: 100%; height: auto; display: block; }
#about .fix-item { position: absolute; top: calc(50% - 32rem); right: 0; width: clamp(400px,50%,800px); height: auto; z-index: -1; pointer-events: none; }
#about .btn-B{ width: 230px; }

.slider-about{ display: flex; align-items: center; margin-left: 14%; background: var(--bg-color); }
.slider-about p{ width: 200px; margin: 0; padding: 10px; background: #000; color: #fff; font-size: 20px; text-align: center; line-height: 1.8; }
.slider-about .slider{ display: flex; align-items: center; width: calc(100% - 200px); }
.slider-about .slider .item{ width: 176px; }
.slider-about .slider .item img{ display: inline; }


/* -------------------------------------------------------- service */
#service { position: relative; padding: 0 0 90px; }
#service:before,
#service:after{ position: absolute; content: ""; left: 50%; transform: translate(-50%, 0); width: 100%; }
#service:before{ clip-path: polygon(0 0, 100% 70%, 100% 100%, 0 30%); z-index: -1; top: 120px; height: 300px; background: var(--main-color); }
#service:after{ clip-path: polygon(0 0, 100% 15%, 100% 100%, 0 100%); z-index: -2; bottom: 0; height: calc(100% - 170px); background: var(--bg-color); }

#service .btn-content .btn{ width: 290px; }

.step-list { display: flex; justify-content: space-between; align-items: center; gap: 30px; margin: 0 0 180px; }
.step-item { background: #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.1); border-radius: 8px; padding: 30px 20px; flex: 1; min-width: 300px; display: flex; flex-direction: column; align-items: center; }
.step-item:nth-of-type(2){ transform: translateY(70px); }
.step-item:nth-of-type(3){ transform: translateY(140px); }

.step-list-num { font-family: 'Gilroy-Bold'; color: var(--main-color); font-size: 27px; margin-bottom: 0; }
.step-list-ttl { font-size: clamp(17px,2vw,23px); font-weight: bold; margin-bottom: 20px; }
.step-item img { margin-bottom: 30px; }
.step-item .txt { text-align: left; width: 100%; }
.step-item .step-list-sub { font-family: 'Noto-Sans-JP-Medium'; font-size: 18px; font-weight: bold; margin-bottom: 15px; text-align: center; font-feature-settings: 'palt'; }
.step-item .check-list { margin-bottom: 0; }


/* -------------------------------------------------------- ranking */
#ranking { padding: 70px 0 80px; }
#ranking .txt{ padding: 0 0 45px; }
#ranking .flex { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 3rem; }
#ranking img {width: 37%; height: auto; display: block; }

.txt-content { width: 55%; }
.txt-content .latest { display: inline-block; width: 110px; background: var(--main-color); color: #fff; font-size: 16px; font-family: 'Noto-Sans-JP-Medium'; padding: 10px 15px; margin-bottom: 15px; text-align: center; }


/* -------------------------------------------------------- bland */
#bland{ padding: 0 0 55px; }

.bland-ttl { font-size: 42px; font-weight: bold; line-height: 1.5; margin-bottom: 30px; }
.bland-ttl small { display: block; font-size: 14px; font-weight: normal; margin-bottom: 10px; }
.bland-tags span{ display: inline-block; margin: 0 3px 5px 0; padding: 5px 10px; font-size: 11px; background: #fff; color: #EA3836; }

.accent-content { position: relative; color: #fff; }
.accent-content:before,
.accent-content:after,
.accent-content .txt-wrapper:before{ z-index: -1; position: absolute; content: ""; left: 0; top: 0; height: 100%; background: #FF1628; }
.accent-content:before{ width: 50%; }
.accent-content .txt-wrapper:before{ clip-path: polygon(0 0, 100% 0%, 70% 100%, 0% 100%); width: 100%; height: 102%; }

.accent-content .txt-wrapper{ overflow: hidden; position: relative; padding: 90px 0; }
.accent-content .txt { width: 390px; }
.accent-content .txt { color: #fff; }
.accent-content .picture { position: absolute; left: calc(50% - 50px); top: 50%; transform: translate(0, -50%); width: min(760px,45%); }
.accent-content .picture img{ width: 100%; height: auto; }
.accent-content .iframe-wrapper{ position: relative; border-radius: 20px; border: 2px solid red; }
.accent-content .iframe-wrapper svg{ width: 100px; height: auto; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 10; }

.accent-content .btn-B-content{ text-align: right; }
.accent-content .btn-B{ color: #fff!important; border-color: #fff; background: transparent; }
.accent-content .btn-B:after{ border-color: #fff; }
.accent-content .btn-B:hover{ color: #FF1628!important; background: #fff; }
.accent-content .btn-B:hover:after{ border-color: #FF1628; }

.accent-content-r:before{ left: initial; right: 0; }
.accent-content-r .txt-wrapper:before{ clip-path: polygon(30% 0, 100% 0%, 100% 100%, 0% 100%); left: initial; right: 0; }
.accent-content-r .txt{ float: right; width: 46%; }
.accent-content-r .picture { left: min(40 / 1100 * 100vw, 40px);  }
.accent-content-r .btn-B-B{ margin: 0 0 0 auto; }


/* -------------------------------------------------------- refelense */
#refelense { padding: 100px 0; background: #fff; }
#refelense .s-ttl{ margin-bottom: 60px }
#refelense .btn-content{ margin: 35px 0 0;}

.refelense-list { padding: 0 0 20px; }
.refelense-list .slider{ display: flex; align-items:  center; }
.refelense-list .slider-item { width: 340px!important; margin: 0 20px; flex-shrink: 0; display: flex; flex-direction: column; align-items: center; }
.refelense-list .slider-item:hover { transform: scale(1.03); transition: transform 0.3s ease; cursor: pointer; }
.refelense-list img { width: 100%; height: auto; display: block; }
.refelense-list .txt { padding: 10px 0; text-align: center; }
.refelense-list .refelense-list-ttl { font-size: 16px; text-align: left; color: #000; line-height: 1.5; font-family: 'Noto-Sans-JP-Medium'; }

#refelense .slick-arrow{ z-index: 10; top: 40%; width: 20px; height: 20px; border-color: var(--main-color); border-style: solid; }
#refelense .slick-prev{ border-width: 2px 0 0 2px; transform: rotate(-45deg); left: calc(50% - 36rem); }
#refelense .slick-next{ border-width: 2px 2px 0 0; transform: rotate(45deg); left: calc(50% + 36rem); }

#refelense .slick-dots{ bottom: -60px; }
#refelense .slick-dots li button::before{ content: ""; background: #CCCCCC; border-radius: 100px; width: 10px; height: 10px; }
#refelense .slick-dots li.slick-active button::before{ background: var(--main-color); }

.slick-prev::before,
.slick-next::before{ content: ""!important; }


/* -------------------------------------------------------- works */
#works .bland-ttl{ font-size: clamp(25px,2vw,36px); margin-bottom: 25px; }
#works .bland-ttl small{ font-size: 18px; margin-bottom: 20px; }
#works .btn-content{ padding: 40px 0 0; text-align: center; }

#works .accent-content .txt-wrapper{ padding: 40px 0; }

.top-section__inner{ padding-bottom: 80px; }


/* -------------------------------------------------------- news */
#news{ padding: 90px 0 70px; background: var(--bg-color); }
#news .btn-content{ padding: 40px 0 0; text-align: center; }

.top-news-list{ padding: 30px; background: #fff; }



@media only screen and (max-width: 1200px) {
	#refelense .slick-prev{ left: -3%; }
	#refelense .slick-next{ left: initial; }
}


/* ------------------------------------- mobile --------------------------------------- */
@media only screen and (max-width: 960px) {
	
	.free-seminar{ margin-top: 40px; padding: 25px 5%; }
	.btn-B{ margin: 0 auto; }
	
/* -------------------------------------------------------- fv */
	#fv .flex { flex-direction: column; }
	#fv .kv.sp { max-width: initial; width: 100vw; margin: 0 calc(50% - 50vw) 20px; }
	#fv .fv-wrapper { width: 100%; padding: 40px 20px; }
	#fv .fv-wrapper .w-box{ width: 100%; padding: 25px 5%; margin-bottom: 20px; }
	#fv .fv-wrapper .catchphrase { font-size: 32px; margin-bottom: 15px; }
	#fv .fv-wrapper .enphrase { margin-bottom: 30px; font-size: 21px; }
	
	#fv .fv-wrapper .w-box img{ width: max(60px,16%); height: auto; }
	#fv .fv-wrapper .w-box .text strong{ font-size: 14px; }
  
/* -------------------------------------------------------- fv */
	#about { margin: 0; padding: 0; margin: 40px 0 0; }
	#about .s-ttl{ font-size: 28px; }
	#about .btn-B{ width: 70%; }
	
	#about .sv{ padding-bottom: 40px; }
	#about .flex { flex-direction: column-reverse; }
	#about .txt-content{ width: 100%;  margin: 35px 0 0; padding-bottom: 30px; }
	#about .flex-item { display: block; width: 55%; margin: 100px auto 0 0; }
	#about .fix-item { top: 0; width: 100%; }
	
	#about .scroll-infinity{ width: 100%; }
	
	.slider-about{ display: block; width: 90%; margin: 0 auto; }
	.slider-about p{ width: 100%; font-size: 16px; }
	.slider-about .slider{ width: 100%; padding: 10px; }
	.slider-about .slider .item{ width: 140px!important; }
	
	
/* -------------------------------------------------------- service */
	#service { padding: 40px 0; }
	
	.step-list { flex-direction: column; gap: 20px; margin: 30px 0; }
	.step-item { width: 100%; padding: 25px 5%; }
	.step-list-num{ font-size: 27px; }
	.step-list-ttl{ font-size: 24px; margin-bottom: 15px; text-align: center; }
	
	.step-item img{ margin-bottom: 25px; width: 50%; height: auto; }
	.step-item02 img{ width: 20%; }
	
	.step-item .step-list-sub{ font-size: 20px; margin-bottom: 10px; }
	
	.step-item:nth-of-type(2),
	.step-item:nth-of-type(3){ transform: none; }


/* -------------------------------------------------------- ranking */
	#ranking { padding: 40px 0; }
	#ranking .txt{ padding: 0; }
	
	#ranking .flex { flex-direction: column-reverse; gap: 30px; }
	#ranking .txt-content{ width: 100%; }
	#ranking img { display: block; width: 100%; margin: 0 auto; }
	
	.txt-content .latest{ width: 75px; font-size: 12px; padding: 5px; }


/* -------------------------------------------------------- bland */
	#bland { padding: 0 0 40px; }
	#bland .txt,
	#bland .youtube { width: 100%; font-size: 17px; }

	.accent-content::before{ width: 100%; height: 85%; }
	.accent-content .txt-wrapper{ padding: 40px 0 10px; }
	.accent-content .txt-wrapper::before{ display: none; }
	.accent-content .picture{ position: initial; transform: none; width: 90%; margin: 0 auto; }
	
	.accent-content .iframe-wrapper{ width: 90%; margin: 0 auto; }

	.bland-ttl{ font-size: 27px; margin-bottom: 15px;}
	.bland-ttl small{ font-size: 12px; margin-bottom: 6px; }


/* -------------------------------------------------------- refelense */
	#refelense { padding: 40px 0; }
	#refelense .s-ttl{ margin-bottom: 30px; }
	#refelense .btn-content{ margin: 45px 0 0; }
	
	.refelense-list{ padding: 0;  }
	.refelense-list .slider { display: block; }
	.refelense-list .slider-item { width: 100%!important; margin: 0; }
	.refelense-list .slider-item img{ width: 100%; height: auto; }
	.refelense-list .refelense-list-ttl{ font-size: 17px; }
		
	#refelense .slick-next { left: initial; right: 17%; }
	#refelense .slick-arrow {  top: 32%; }
	#refelense .slick-prev { left: 17%; }
	#refelense .slick-dots { bottom: -35px; }


/* -------------------------------------------------------- works */	
	#works .bland-ttl { font-size: 24px; margin-bottom: 17px; }
	#works .bland-ttl small { font-size: 14px; margin-bottom: 15px; }
	#works .btn-content { padding: 20px 0 0; }
	
	#works .accent-content{ display: flex; flex-direction: column-reverse; }
	#works .accent-content:before{ clip-path: polygon(0 40%, 100% 0, 100% 100%, 0% 100%); left: 0; top: 0; width: 100%; height: 30%; }
	#works .accent-content:after{ left: 0; top: initial; bottom: 0; width: 100%; height: 75%; clip-path: none; }
	#works .accent-content .txt-wrapper{ padding-bottom: 0; }
	
	.bland-tags span { margin: 0 0 3px 0; padding: 4px 8px; font-size: 10px; }
	
	.accent-content-r .txt { float: none; width: 100%; padding: 0 0 20px; }
	.accent-content-r .btn-B-B { margin: 0 auto; }
	.accent-content-r::after{ clip-path: polygon(0 0, 100% 0, 100% 50%, 0 100%); }

	.top-section__inner{ padding-bottom: 40px; }


/* -------------------------------------------------------- news */
	#news{ padding: 40px 0; }




  
}
