/*===============================================================================
共通
================================================================================*/
.front__title-sub{
	margin-bottom: 1.5rem;
	font-weight: var(--fw-lg);
	line-height: var(--lh-sm);
	color: var(--c-main);
	font-size: clamp(2.25rem, 2.072rem + 0.48vw, 2.5rem); /* 32px～40px */
}

/*===============================================================================
***MV
================================================================================*/
.f-mv{
	margin-bottom: var(--g-sec--md);
}
.f-mv__container{
	display: flex;
	gap: clamp(0rem, -0.712rem + 1.9vw, 1rem);
	padding-left: clamp(0.5rem, -0.924rem + 3.8vw, 2.5rem);
}

/*===============================
* スライダー
* =================================*/
.f-mv__swiper-wrap{
	position: relative;
	flex-grow: 1;
	padding-left: clamp(1rem, 0.644rem + 0.95vw, 1.5rem);
	overflow: hidden;
}

/* テキスト部分 */
.f-mv__content{
	--c-current: #E4F8CD;
	--position: 1px;
	--blur: 1.5px;
	text-shadow: var(--position) var(--position) var(--blur) var(--c-current), 
		calc( var(--position) * -1 ) calc( var(--position) * -1 ) var(--blur) var(--c-current), 
		calc( var(--position) * -1 ) var(--position) var(--blur) var(--c-current), 
		var(--position) calc( var(--position) * -1 ) var(--blur) var(--c-current), 
		0 var(--position) var(--blur) var(--c-current), 
		0 calc( var(--position) * -1 ) var(--blur) var(--c-current), 
		calc( var(--position) * -1 ) 0 var(--blur) var(--c-current), 
		var(--position) 0 var(--blur) var(--c-current);
	position: absolute;
	z-index: 2;
	top: 50%;
	left: 0;
	transform: translate(0%,20%);
	max-width: 14em;
	font-size: clamp(2rem, -2.167rem + 11.11vw, 4.5rem);
}
@media (min-width: 960px){
	.f-mv__content{
		top: var(--g-sec--md);
		font-size: 2.5rem;
	}
}

.f-mv__title{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: .5rem;
}
.f-mv__lead{
	font-size: .35em;
}

/* swiper */
.f-mv__swiper {
	border-top-left-radius: var(--bd-r--xl);
	border-bottom-left-radius: var(--bd-r--xl);
}
.f-mv__swiper img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}

.f-mv__swiper::after{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	content: "";
	width: 100%;
	height: 100%;
	background: linear-gradient(100.5deg, rgba(140, 223, 126, 0) 0%, rgba(30, 176, 176, 0.3) 100.46%);
}

/* dot */
.swiper-pagination{
	display: flex;
	align-items: center;
	justify-content: center;
}
.swiper-pagination-bullet{
	flex-grow: 1;
	max-width: 5rem;
	height: 4px;
	background: var(--c-light);
	border-radius: 0;
	opacity: 1;
}
.swiper-pagination-bullet-active{
	background: #E3D69E;
}

/*===============================
* スクロールテキスト
* =================================*/
.f-mv__scroll{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-end;
	gap: .5rem;
	font-size: .75rem;
	transform: translateY(clamp(1.375rem, -0.139rem + 4.04vw, 3.5rem));
}
.f-mv__scroll-text{
	display: inline-block;
	white-space: pre;
	writing-mode: vertical-rl;
	animation: scrollSideTxt 3s ease infinite;
}
/* 矢印 */
.f-mv__scroll::after{
	content: "";
	width: 1px;
	height: clamp(8.5rem, 6.719rem + 4.76vw, 11rem);
	background: var(--c-dark);
	animation: scrollSide 3s ease infinite;
}

@keyframes scrollSide{
	0%{
		transform-origin: top;
		transform: scaleY(0);
	}
	45%{
		transform-origin: top;
		transform: scaleY(1);
	}
	55%{
		transform-origin: bottom;
		transform: scaleY(1);
	}
	95%{
		opacity: 0;
	}
	100%{
		transform-origin: bottom;
		transform: scaleY(0);
	}
}
@keyframes scrollSideTxt{
	0%{opacity: 0;}
	25%{opacity: 1;}
	95%{opacity: 0;}
	100%{opacity: 0;}
}



/*===============================================================================
***About us
================================================================================*/
.f-about{
	margin-bottom: var(--g-sec--md);
}
/*===============================
* TOP
* =================================*/
.f-about-top{
	position: relative;
	padding-bottom: var(--g-sec--md);
}
/* 装飾画像 */
.f-about-top__deco{
	position: absolute;
	bottom: 0;
	left: calc( 50% - 50vw );
	transform: translate(-47%, 75%);
	z-index: -1;
	max-width: 25rem;
	width: 100%;
}
@media (min-width: 600px){
	.f-about-top__deco{
		transform: translate(-37%, 60%);
	}
}
.f-about-top__deco img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}

.f-about-top__cols{
	display: flex;
	flex-direction: column;
}
@media (min-width: 768px){
	.f-about-top__cols{
		position: relative;
		display: block;
	}
}
.f-about-top__contents{
	display: contents;
	width: 100%;
}
@media (min-width: 768px){
	.f-about-top__contents{
		display: block;
		position: absolute;
		top: 0;
		left: 0;
	}
}

.f-about-top__title-wrap{
	max-width: 43rem;
	margin-bottom: 1.5rem;
	order: 1;
}
@media (min-width: 768px){
	.f-about-top__title-wrap{
		margin-bottom: var(--g-sec--xs);
	}
}
.f-about-top__head{
	margin-bottom: var(--g-sec--xs);
}

.f-about-top__textArea{
	max-width: 36rem;
	order: 3;
}

.f-about-top__image{
	margin-left: auto;
	margin-right: calc(50% - 50vw);
	margin-bottom: 1rem;
	border-top-left-radius: var(--bd-r--lg);
	border-bottom-left-radius: var(--bd-r--lg);
	overflow: hidden;
	order: 2;
}
@media (min-width: 768px){
	.f-about-top__image{
		width: 60%;
		margin-bottom: 0;
	}
}

/*===============================
* BOTTOM
* =================================*/
.f-about-bottom__mv{
	display: block;
}
.f-about-bottom__mv img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}
.f-about-bottom__container{
	position: relative;
}
.f-about-bottom__bgi{
	position: absolute;
	top: 0;
	left: calc( 50% - 50vw );
	z-index: -1;
	width: 100vw;
	height: 100%;
}
.f-about-bottom__bgi img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*===============================
* CARD
* =================================*/
.f-about-bottom__cards{
	--gap: 2rem;
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 1.5rem var(--gap);
	max-width: 960px;
	margin-inline: auto;
	transform: translateY(calc(var(--g-sec--md) * -1));
}
@media (min-width: 768px){
	.f-about-bottom__cards{
		grid-template-columns: repeat(3, 1fr);
	}
}

.f-about-bottom__card{
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 4;
	gap: 0rem;
	padding: 1.5rem 1.5rem 3rem 1.5rem;
	background: var(--c-gray--light);
	border-radius: var(--bd-r--xl);
	box-shadow: var(--shdw);
	overflow: hidden;
}
.f-about-bottom__picture{
	width: 100%;
	margin-bottom: .5rem;
}
.f-about-bottom__picture img{
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 248 / 120;
	object-fit: cover;
	object-position: 50% 50%;
}
.f-about-bottom__title{
	margin-bottom: .5rem;
	text-align: center;
	font-size: 1.25rem;
	font-weight: var(--fw-lg);
}
.f-about-bottom__text{
	margin-bottom: var(--g-sec--xs);
}
.f-about-bottom__btn{
	margin-top: auto;
	text-align: center;
}



/*===============================================================================
***With us
================================================================================*/
.f-with{
	margin-bottom: var(--g-sec--md);
}

/* カラム要素 */
.f-with__cols{
	position: relative;
	display: flex;
	flex-direction: column;
}
@media (min-width: 768px){
	.f-with__cols{
		position: relative;
		display: block;
	}
}
.f-with__contents{
	display: contents;
	width: 100%;
}
@media (min-width: 768px){
	.f-with__contents{
		display: block;
		position: absolute;
		top: 0;
		left: 0;
	}
}

.f-with__title-wrap{
	max-width: 43rem;
	margin-bottom: 1.5rem;
	order: 1;
}
@media (min-width: 768px){
	.f-with__title-wrap{
		margin-bottom: var(--g-sec--xs);
	}
}
.f-with__head{
	margin-bottom: var(--g-sec--xs);
}

.f-with__textArea{
	max-width: 36rem;
	order: 3;
}

.f-with__image{
	margin-left: auto;
	margin-right: calc(50% - 50vw);
	margin-bottom: 1rem;
	border-top-left-radius: var(--bd-r--lg);
	border-bottom-left-radius: var(--bd-r--lg);
	overflow: hidden;
	order: 2;
}
@media (min-width: 768px){
	.f-with__image{
		width: 60%;
		margin-bottom: 0;
	}
}
/* 装飾画像 */
.f-with__deco{
	position: absolute;
	top: 100%;
	right: calc(50% - 50vw);
	transform: translate(45%, -70%);
	z-index: -1;
	max-width: 44rem;
	width: 71%;
}
@media (min-width: 600px){
	.f-with__deco{
		transform: translate(45%, -50%);
		width: 100%;
	}
}


/*===============================================================================
***Reason
================================================================================*/
.f-reason{
	margin-bottom: var(--g-sec--md);
}
/*===============================
* ヘッド
* =================================*/
.f-reason__head{
	margin-bottom: 1.75rem;
}

/*===============================
* ボディ
* =================================*/
.f-reason__body{
	--count: 1;
	--overlap: 0rem;
	--gap: 0rem;
	--media-width: 100%;
	--body-width: calc( 200% - var(--media-width) );
	display: flex;
	flex-wrap: wrap;
	gap: var(--gap);
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-bottom: var(--g-sec--xs);
}
@media (min-width: 960px){
	.f-reason__body{
		--count: 2;
		--overlap: -3rem;
	}
}

.f-reason__image{
	width: calc( ( var(--media-width) - var(--gap) * (var(--count) - 1) ) / var(--count) ); 
	margin-right: var(--overlap);
}
.f-reason__list{
	max-width: 704px;
	margin-top: -1rem;
	margin-inline: auto;
	width: calc( ( var(--body-width) - var(--gap) * (var(--count) - 1) ) / var(--count) );
}
@media (min-width: 960px){
	.f-reason__list{
		margin-top: 0;
		margin-inline: 0;
	}
}

.f-reason__item{
	--icon-size: clamp(3rem, 1.576rem + 3.8vw, 5rem);
	position: relative;
	padding-left: calc( var(--icon-size) - 1rem );
}
.f-reason__item:not(:last-of-type){
	margin-bottom: 1.5rem;
}
.f-reason__content{
	max-width: 40rem;
	padding: 1rem 2rem;
	box-shadow: var(--shdw);
	background: var(--c-gray--light);
	border-radius: var(--bd-r--lg);
	overflow: hidden;
}
.f-reason__secondary-title{
	margin-bottom: .5rem;
	padding-bottom: .25rem;
	border-bottom: 1px solid var(--c-gray);
	font-size: 1.5rem;
	font-weight: var(--fw-lg);
}

/*===============================
* 数字
* =================================*/
/* 数字の親要素 */
.f-reason__number-wrap {
	position: absolute;
	top: 20%;
	left: 0;
	transform: translate(0%,0%);
	width: var(--icon-size);
	aspect-ratio: 1;
	background-image: var(--c-gradient--light);
	box-shadow: 3px 3px 0 #D9D9D9;
}
@media (min-width: 600px){
	.f-reason__number-wrap {
		top: 50%;
		transform: translate(0%,-50%);
	}
}

/* 数字部分 */
.f-reason__number {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(.75, 1.25);
	font-size: calc( var(--icon-size) / 2 );
	font-weight: var(--fw-lg);
	background-image: var(--c-gradient);
	-webkit-text-fill-color: transparent;
	background-clip: text;
	z-index: 10;
}

/*===============================
* フット
* =================================*/
.f-reason__foot{
	text-align: center;
}
@media (min-width: 960px){
	.f-reason__foot{
		text-align: right;
	}
}



/*===============================================================================
***Company
================================================================================*/
.f-company__inner{
	position: relative;
	padding-bottom: var(--g-sec--lg);
}

/*===============================
* 外観写真
* =================================*/
.f-company__gaikan{
	position: absolute;
	top: 7rem;
	right: calc( 50% - 50vw );
	z-index: -1;
	width: 65%;
}
@media (min-width: 768px){
	.f-company__gaikan{
		top: auto;
		bottom: 0;
	}
}
.f-company__gaikan img{
	width: 100%;
	height: 100%;
}

/*===============================
* MV
* =================================*/
.f-company__mv{
	position: relative;
	z-index: -2;
	display: block;
	margin-bottom: var(--g-sec--md);
}
.f-company__mv img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}

/*===============================
* ヘッド
* =================================*/
.f-company__head{
	max-width: 40rem;
	margin-bottom: var(--g-sec--xs);
}

/*===============================
* ボディ
* =================================*/
.f-company__body{
	--count: 1;
	--gap: 1.5rem;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gap);
	max-width: 904px;
}
@media (min-width: 768px){
	.f-company__body{
		--count: 2;
	}
}

/*===============================
* カード
* =================================*/
.f-company__card{
	display: flex;
	gap: 1rem;
	width: calc( ( 100% - var(--gap) * (var(--count) - 1) ) / var(--count) );
	padding: 1rem;
	background: var(--c-gray--light);
	box-shadow: var(--shdw);
	border: 1px solid var(--c-gray--dark);
	border-radius: var(--bd-r--md);
	overflow: hidden;
}
.f-company__card-image{
	width: 25%;
	min-width: 10rem;
}
.f-company__card-image img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.f-company__card-content{
	flex-grow: 1;
}
.f-company__card-title{
	margin-bottom: 1rem;
	font-size: 1.5rem;
	font-weight: var(--fw-lg);
}
.f-company__card-text{
	margin-bottom: 1rem;
}
@media (min-width: 768px){
	.f-company__card-btn{
		text-align: right;
	}
}



/*===============================================================================
***Infomation
================================================================================*/
.f-infomation{
	margin-bottom: var(--g-sec--md);
}
.f-infomation__inner{
	position: relative;
	padding: var(--g-sec--md) 0;
}

/* 背景色 */
.f-infomation__inner::before{
	position: absolute;
	top: 0;
	left: calc( 50% - 50vw );
	z-index: -1;
	content: "";
	width: 100vw;
	height: 100%;
	background: var(--c-light);
	border-top: 1px solid var(--c-gray--dark);
	border-bottom: 1px solid var(--c-gray--dark);
}

/* カラム要素 */
.f-infomation__cols{
	display: flex;
	flex-wrap: wrap;
	gap: 0 var(--g-sec--xs);
}
@media (min-width: 600px){
	.f-infomation__cols{
		flex-wrap: nowrap;
	}
}

/* カラム：コンテンツ */
.f-infomation__content{
	display: contents;
}
@media (min-width: 600px){
	.f-infomation__content{
		display: flex;
		flex-direction: column;
		width: fit-content;
	}
}

.f-infomation__title-wrap{
	width: 100%;
	order: 1;
}
.f-infomation__btn{
	width: 100%;
	margin-top: auto;
	text-align: right;
	order: 3;
}
@media (min-width: 600px){
	.f-infomation__btn{
		text-align: left;
	}
}

/* カラム：記事一覧 */
.f-infomation__post{
	flex-grow: 1;
	margin-bottom: var(--g-sec--md);
	padding-top: var(--g-sec--sm);
	order: 2;
}
@media (min-width: 600px){
	.f-infomation__post{
		margin-bottom: 0;
	}
}



/*===============================================================================
***Insurance company
================================================================================*/
.f-insurance{
	margin-bottom: var(--g-sec--md);
}
.f-insurance__head{
	margin-bottom: .75rem;
}

/*===============================
* スライダー
* =================================*/
.f-insurance__body{
	position: relative;
	padding: var(--g-sec--sm) 0;
}
.f-insurance__body::before{
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	content: "";
	width: 100vw;
	height: 100%;
	background: var(--c-gray);
}

.f-insurance__swiper{
	padding: 4px 0 12px;
}
.f-insurance__swiper>.swiper-wrapper{
	transition-timing-function: linear;
}
.f-insurance__swiper .swiper-slide img{
	box-shadow: 0 4px 8px 0 #00000025;
	border-radius: var(--bd-r--lg);
	overflow: hidden;
}


/*===============================================================================
***Links
================================================================================*/
.f-links{
	margin-bottom: var(--g-sec--md);
}
.f-links__head{
	margin-bottom: .75rem;
}


/*===============================================================================
***FAQ
================================================================================*/
.f-faq__head{
	margin-bottom: 1.5rem;
}
.f-faq__body{
	margin-bottom: var(--g-sec--xs);
}
.f-faq__foot{
	text-align: right;
}

/*===============================
アコーディオン
=================================*/
.f-faq-accodion {
	--side-pad: var(--g-sec--xs);
	--vertical-pad: 1.125rem;
	--gap: 0rem;
	--this-color: var(--c-dark);
	display: block;
	padding: var(--vertical-pad) var(--side-pad);
	background: var(--c-light);
	border: 1px solid var(--c-gray--dark);
	box-shadow: var(--shdw);
	border-radius: var(--bd-r--sm);
	overflow: hidden;
	color: var(--this-color);
	font-family: var(--ff-g);
}

.f-faq-accodion:not(:last-of-type) {
	margin-bottom: 1rem;
}

/**********************************
* ***質問
* **********************************/
.f-faq-accodion__head {
	display: flex;
	gap: var(--gap);
	align-items: center;
	cursor: pointer;
	transition: var(--ani-t--normal) ease-out;
}

/* アニメーション */
.f-faq-accodion[open] .f-faq-accodion__head {
	margin-bottom: 1rem;
}

.f-faq-accodion__head:hover,
.f-faq-accodion__head:focus {
	opacity: 0.8;
}

.f-faq-accodion__headInner {
	position: relative;
	flex-grow: 1;
}

/**********************************
* ***回答
* **********************************/
.f-faq-accodion__body {
	display: flex;
	gap: var(--gap);
}

/* アニメーション */
.f-faq-accodion[open] .f-faq-accodion__body {
	animation: fadein 0.5s ease;
}

@keyframes fadein {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

.f-faq-accodion__bodyInner {
	flex-grow: 1;
}

/**********************************
* ***QA文字
* **********************************/
/* QA文字　共通 */
.f-faq-accodion__icon {
	display: inline-block;
	align-self: baseline;
}

/* Q.文字 */
.f-faq-accodion__icon.--q::before {
	content: "Q.";
}

/* A.文字 */
.f-faq-accodion__icon.--a::before {
	content: "A.";
}

/**********************************
* ***開閉アイコン
* **********************************/
.f-faq-accodion__toggle {
	--toggle-size: 1.25em;
	position: relative;
	display: inline-block;
	width: var(--toggle-size);
	aspect-ratio: 1;
}

.f-faq-accodion__toggle::before,
.f-faq-accodion__toggle::after {
	position: absolute;
	top: 25%;
	left: 50%;
	content: "";
	width: var(--toggle-size);
	height: 2px;
	background: var(--this-color);
	transition: var(--ani-t--normal) ease-out;
}

.f-faq-accodion__toggle::before {
	transform: translate(-50%, -50%) rotate(90deg);
}

.f-faq-accodion__toggle::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

/* アニメーション */
.f-faq-accodion[open] .f-faq-accodion__toggle::before {
	transform: translate(-50%, -50%) rotate(180deg);
}

.f-faq-accodion[open] .f-faq-accodion__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

/* 既存のマーカー */
.f-faq-accodion__head {
	list-style: none;
}

.f-faq-accodion__head::-webkit-details-marker {
	display: none;
}


