@charset "UTF-8";
/*
	about
-----------------------------------------------------------------------------------------------*/
#about{
	position: relative;
}
#about > .ctsArea{
	padding-bottom: 0;
	padding-top: 70px;
}
.about__head{
	color: var(--blue);
	font-size: 2.6rem;
	font-weight: var(--bold);
	line-height: 1.6;
	position: relative;
	text-align: center;
	z-index: 1;
}
.about__head--bold{
	display: inline-block;
	font-size: 7.4rem;
	line-height: 1.1;
	margin: 6px 0 14px;
}
.about__container{
	margin-top: -35px;
}
.about__img{
	margin: -120px 0 0 0;
}
.about__item{
	width: calc((100% - 40px)/3);
}
.about__list{
	align-items: end;
	display: flex;
	gap: 0 20px;
	margin-top: -110px;
}
[class^="about__item--img"]{
	margin: 0 auto;
}
.about__item--img01{
	width: 57px;
}
.about__item--img02{
	width: 98px;
}
.about__item--img03{
	width: 114px;
}
.about__body{
	background: #edf3f6;
	border-radius: 15px;
	color: var(--blue);
	margin: -50px 0 0;
	padding: 60px 0 30px;
	text-align: center;
}
.about__tit{
	border-bottom: 1px solid var(--blue);
	font-size: 2.1rem;
	font-weight: var(--bold);
	margin-bottom: 18px;
	padding-bottom: 14px;
	text-align: center;
}
.about__tit--sub{
	font-size: 1.6rem;
}
.about__body--list{
	display: inline-block;
	padding-right: 10px;
	text-align: left;
}
.about__body--item::before{
	content: '・';
}
.about__body--txt{
	font-size: 1.7rem;
	font-weight: var(--bold);
	margin-top: 6px;
	text-align: center;
}
a.radius{
	width: 345px;
}
/*
	forte
-----------------------------------------------------------------------------------------------*/
#forte-wrapper{
	margin-top: -100px;
	padding-top: 100px;
}
#forte{
	background: #edf6ff;
}
.forte__head{
	color: var(--blue);
	font-size: 4.3rem;
	font-weight: var(--bold);
	line-height: 1.5;
	text-align: center;
}
.forte__lead{
	color: var(--blue);
	font-size: 1.8rem;
	font-weight: var(--bold);
	line-height: 1.8;
	margin: 19px 0 40px;
	text-align: center;
}
.forte__list{
	display: flex;
	flex-wrap: wrap;
	gap: 22px 25px;
	justify-content: center;
	margin: 0 auto;
	max-width: 780px;
}
.forte__item{
	background: #FFF;
	border-radius: 22px;
	filter: drop-shadow(0 0 10px #cfdfe5);
	overflow: hidden;
	max-width: calc((100% - 45px)/ 2);
}
.forte__item--img{
	overflow: hidden;
	max-width: 100%;
}
.forte__item--body{
	padding: 25px 20px 28px;
}
.forte__number{
	background: var(--blue);
	color: #FFF;
	display: inline-block;
	font-size: 1.5rem;
	font-weight: var(--bold);
	padding: 2px 10px;
}
.forte__title{
	border-bottom: 1px solid #83acc0;
	font-size: 2.1rem;
	font-weight: var(--bold);
	margin: 12px 0 17px;
	padding: 0 0 17px;
}
.forte__txt{
	font-size: 1.5rem;
	line-height: 1.7;
}
/*
	future
-----------------------------------------------------------------------------------------------*/
#future{
	position: relative;
	text-align: center;
}
#future::before,
#future::after{
	background: url(../img/bg_pattern01.png) no-repeat center center/ cover;
	content: '';
	height: 380px;
	position: absolute;
	width: 650px;
}
#future::before{
	right: 0;
	top: 0;
	transform: rotate(180deg);
}
#future::after{
	bottom: 0;
	left: 0;
}
.future__head{
	color: var(--blue);
	display: inline-block;
	font-size: 4.2rem;
	line-height: 1.0;
	margin: 0 0 15px;
	padding: 30px 55px;
	position: relative;
}
.future__head::before,
.future__head::after{
	border-left: 1px solid var(--blue);
	border-top: 1px solid var(--blue);
	content: '';
	height: 110px;
	position: absolute;
	width: 60px;
}
.future__head::before{
	left: 0;
	top: 0;
}
.future__head::after{
	bottom: 0;
	right: 0;
}
.future__head::after{
	transform: rotate(180deg);
}
.future__head--title{
	display: inline-block;
	max-width: 350px;
}
.future__head--bold{
	font-size: 7.0rem;
	font-weight: var(--bold);
}
.future__list{
	margin: 0 auto;
	max-width: 780px;
}
.future__item{
	align-items: center;
	display: flex;
	gap: 0 30px;
	justify-content: center;
	margin-bottom: 20px;
}
.future__item:nth-child(even){
	flex-direction: row-reverse;
}
.future__img--01{
	max-width: 270px;
}
.future__img--02{
	max-width: 350px;
}
.future__img--03{
	max-width: 385px;
}
.future__body{
	text-align: left;
	max-width: 430px;
}
.future__title{
	border-bottom: 1px solid var(--blue);
	color: var(--blue);
	font-size: 3.0rem;
	font-weight: var(--bold);
	letter-spacing: .1rem;
	margin-bottom: 20px;
	padding-bottom: 20px;
}
.future__txt{
	font-size: 1.7rem;
	line-height: 1.8;
}
/*
	flow
-----------------------------------------------------------------------------------------------*/
#flow{
	background: #edf6ff;
}
#flow .ctsArea{
	max-width: 1400px;
	width: 100%;
}
.termbar{
	display: flex;
	font-weight: var(--bold);
	margin-bottom: 10px;
}
[class^="termbar__"]{
	color: #fff;
	padding: 5px 13px;
	position: relative;
}
.termbar__01{
	background: #fcae4b;
	width: 60%;
}
.termbar__02{
	background: #29a67b;
	width: 40%;
}
[class^="termbar__"]::before{
	bottom: 0;
	content: '';
	height: 47px;
	position: absolute;
	right: 0;
	width: 47px;
}
.termbar__01::before{
	background:linear-gradient(-135deg,#edf6ff 0%,#edf6ff 50%,#fcae4b 50%,#fcae4b 100%);
}
.termbar__02::before{
	background:linear-gradient(-135deg,#edf6ff 0%,#edf6ff 50%,#29a67b 50%,#29a67b 100%);
}
.flow__list{
	display: flex;
}
[class^="flow__item"]{
	color: var(--blue);
	font-weight: var(--bold);
	margin: 0 auto;
	padding: 40px 20px;
	position: relative;
	text-align: center;
	width: calc(100% / 5);
}
[class^="flow__item"]::before{
	border-bottom: 15px solid transparent;
	border-left: 20px solid var(--blue);
	border-top: 15px solid transparent;
	content: '';
	position: absolute;
	right: -12px;
	top: 50%;
	transform: translate(0, -50%);
	z-index: 1;
}
[class^="flow__item"]:last-child:before{
	content: none;
}
.flow__item--01{
	background: #FFF;
}
.flow__item--02{
	background: #effaff;
}
.flow__item--03{
	background: #e5f7ff;
}
.flow__item--04{
	background: #dbf4ff;
}
.flow__item--05{
	background: #ceefff;
}
.flow__step{
	align-items: center;
	display: inline-flex;
	font-size: 2.1rem;
	height: 55px;
	justify-content: center;
	width: 55px;
}
.flow__item--01 .flow__step{
	background: url(../img/flow_step_bg01.png) no-repeat center center/cover;
}
.flow__item--02 .flow__step{
	background: url(../img/flow_step_bg02.png) no-repeat center center/cover;
}
.flow__item--03 .flow__step{
	background: url(../img/flow_step_bg03.png) no-repeat center center/cover;
}
.flow__item--04 .flow__step{
	background: url(../img/flow_step_bg04.png) no-repeat center center/cover;
}
.flow__item--05 .flow__step{
	background: url(../img/flow_step_bg05.png) no-repeat center center/cover;
}
.flow__tit{
	align-items: center;
	display: flex;
	font-size: 2.5rem;
	justify-content: center;
	line-height: 1.3;
	margin: 17px 0 15px;
	height: 60px;
}
.flow__img{
	align-items: center;
	display: flex;
	height: 195px;
	justify-content: center;
	margin: 0 auto;
	width: 72%;
}
.flow__txt{
	font-size: 1.6rem;
	font-weight: var(--medium);
	line-height: 1.7;
	margin-top: 20px;
	text-align: left;
}
/*
	footerlink
-----------------------------------------------------------------------------------------------*/
#footerlink .header__list{
	background: #fff;
}
@media screen and (max-width:897px){
	/*
		about
	-----------------------------------------------------------------------------------------------*/
	#about{
		position: relative;
	}
	#about > .ctsArea{
		padding-bottom: 0;
		padding-top: 50px;
	}
	.about__head{
		font-size: 1.7rem;
		line-height: 1.6;
	}
	.about__head--bold{
		font-size: 4.2rem;
		line-height: 1.1;
		margin: 8px 0 12px;
	}
	.about__container{
		margin-top: -60px;
		padding: 70px 0px;
	}
	.about__img{
		margin: -20px auto 20px;
		max-width: 500px;
	}
	.about__list{
		flex-wrap: wrap;
		gap: 12px 0;
		margin: 0 auto;
		max-width: 500px;
		width: 90%;
	}
	.about__item{
		width: 100%;
	}
	[class^="about__item--img"]{
		margin: 0 auto;
	}
	.about__item--img01{
		width: 57px;
	}
	.about__item--img02{
		width: 98px;
	}
	.about__item--img03{
		width: 114px;
	}
	.about__body{
		border-radius: 10px;
		margin: -32px 0 0;
		padding: 35px 0 20px;
		text-align: center;
	}
	.about__tit{
		font-size: 1.8rem;
		margin-bottom: 10px;
		padding-bottom: 10px;
	}
	.about__tit--sub{
		font-size: 1.5rem;
	}
	.about__body--list{
		padding-right: 10px;
	}
	.about__body--txt{
		font-size: 1.6rem;
		margin-top: 3px;
	}
	a.radius{
		max-width: 500px;
		width: 100%;
	}	
	/*
		forte
	-----------------------------------------------------------------------------------------------*/
	#forte-wrapper{
		margin-top: -70px;
		padding-top: 70px;
	}
	.forte__head{
		font-size: 2.6rem;
		line-height: 1.6;
		margin-bottom: 25px;
	}
	.forte__head--txt{
		padding: 0 10px;
	}
	.forte__lead{
		font-size: 1.5rem;
		line-height: 1.8;
		margin: 20px 0 35px;
		text-align: left;
	}
	.forte__list{
		gap: 20px 0;
		max-width: 500px;
	}
	.forte__item{
		border-radius: 18px;
		max-width: 100%;
	}
	.forte__item--img{
		height: auto;
		max-width: 100%;
	}
	.forte__item--body{
		padding: 20px 15px;
	}
	.forte__number{
		font-size: 1.3rem;
		padding: 2px 7px;
	}
	.forte__title{
		font-size: 1.8rem;
		margin: 10px 0 15px;
		padding: 0 0 15px;
	}
	.forte__txt{
		font-size: 1.4rem;
		line-height: 1.7;
	}
	/*
		future
	-----------------------------------------------------------------------------------------------*/
	#future::before,
	#future::after{
		height: 150px;
		width: 300px;
	}
	.future__head{
		background: url(../img/future_txt01_sp.png) no-repeat center center/ 100%;
		color: transparent;
		display: flex;
		margin: 0 auto 30px;
		max-width: 500px;
		min-height: 35vw;
		text-indent: -9999px;
		width: 100%;
	}
	.future__head::before,
	.future__head::after{
		content: none;
		width: 60px;
	}
	.future__head--title{
		max-width: 200px;
		vertical-align: bottom;
	}
	.future__head--bold{
		font-size: 4.2rem;
	}
	.future__list{
		max-width: 500px;
	}
	.future__item{
		display: flex;
		flex-wrap: wrap;
		gap: 0;
		margin-bottom: 35px;
	}
	.future__img--01,
	.future__img--02,
	.future__img--03{
		margin-bottom: 15px;
		max-width: 55%;
	}
	.future__body{
		max-width: 100%;
	}
	.future__title{
		font-size: 2.2rem;
		margin-bottom: 15px;
		padding-bottom: 15px;
		text-align: center;
	}
	.future__txt{
		font-size: 1.5rem;
		line-height: 1.7;
	}
	/*
		flow
	-----------------------------------------------------------------------------------------------*/
	#flow{
		background: #edf6ff;
	}
	#flow .ctsArea{
		max-width: 1400px;
		width: 100%;
	}
	.anmScroll.jsAnmStart{
		animation: anmScroll 2s ease 0.9s forwards;
	}
	.forte__container{
		overflow: scroll;
	}
	.termbar{
		display: flex;
		font-weight: var(--bold);
		margin-bottom: 10px;
		width: 1300px;
	}
	[class^="termbar__"]{
		color: #fff;
		padding: 5px 13px;
		position: relative;
	}
	.termbar__01{
		background: #fcae4b;
		width: 60%;
	}
	.termbar__02{
		background: #29a67b;
		width: 40%;
	}
	[class^="termbar__"]::before{
		bottom: 0;
		content: '';
		height: 47px;
		position: absolute;
		right: 0;
		width: 47px;
	}
	.termbar__01::before{
		background:linear-gradient(-135deg,#edf6ff 0%,#edf6ff 50%,#fcae4b 50%,#fcae4b 100%);
	}
	.termbar__02::before{
		background:linear-gradient(-135deg,#edf6ff 0%,#edf6ff 50%,#29a67b 50%,#29a67b 100%);
	}
	.flow__list{
		width: 1300px;
	}
	[class^="flow__item"]{
		padding: 25px 15px;
	}
	[class^="flow__item"]::before{
		border-bottom: 15px solid transparent;
		border-left: 20px solid var(--blue);
		border-top: 15px solid transparent;
		content: '';
		position: absolute;
		right: -12px;
		top: 50%;
		transform: translate(0, -50%);
		z-index: 1;
	}
	[class^="flow__item"]:last-child:before{
		content: none;
	}
	.flow__step{
		font-size: 2.1rem;
		height: 50px;
		width: 50px;
	}
	.flow__tit{
		align-items: center;
		display: flex;
		font-size: 2.0rem;
		justify-content: center;
		line-height: 1.3;
		margin: 0;
		height: 60px;
	}
	.flow__img{
		height: 160px;
		width: 55%;
	}
	.flow__txt{
		font-size: 1.5rem;
		line-height: 1.6;
		margin-top: 10px;
	}
	#footerlink .btnHbg{
		background: #fff;
	}
}