/* **********************
 * flow 固定ページ
********************** */

.sub-ttl {
    font-family: "Ryumin Regular KL", serif;
    font-size: clamp(1.75rem, 1.324rem + 1.89vw, 2.625rem);
    font-weight: 400;
	line-height: 1.5;
}
.ttl-flow-content {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 70px 30px 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.flow-box_content > *:first-child {
	margin-top: 0;
}
.ttl-flow-content_en {
	display: block;
	position: relative;
	padding-bottom: 24px;
	font-family: "Outfit", sans-serif;
	font-size: 20px;
	line-height: 1;
	color: #d67392;
    text-align: center;
}
.ttl-flow-content_en::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 8px;
	width: 24px;
	height: 1px;
	background: #222;
	transform: translateX(-50%);
}
.ttl-flow-content_jp {
	display: block;
	font-size: 28px;
	font-weight: 500;
	line-height: 1.4;
    text-align: center;
}
.ttl-flow-content p {
    font-family: "Ryumin Regular KL", serif;
    font-size: clamp(1.5rem, 1.014rem + 2.16vw, 2.5rem);
	font-weight: 500;
    line-height: 1.6;
    margin: 80px 0 40px;
}

.flow-list {
	width: 100%;
	max-width: 1100px;
	margin: 60px auto 0;
	display: flex;
	flex-direction: column;
	gap: 54px;
}

.flow-box {
	display: grid;
	grid-template-columns: 310px 1fr;
	gap: 60px;
	align-items: start;
}

.flow-box_img img {
	display: block;
	width: 100%;
	height: auto;
}

.flow-box_step {
	display: flex;
	align-items: center;
	gap: 10px;
    margin-top: 0;
	margin-bottom: 24px;
	line-height: 1;
}

.flow-box_step-en {
	position: relative;
	padding-bottom: 6px;
	font-family: "Outfit", sans-serif;
	font-size: 22px;
	color: #d67392;
}
.flow-box_step-en::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 44px;
	height: 1px;
	background: #d67392;
}
.flow-box_step-no {
	font-family: "Outfit", sans-serif;
	font-size: 35px;
	font-weight: 500;
	line-height: 1;
	color: #d67392;
}
.flow-box_ttl {
    margin: 0 0 12px;
	font-size: 26px;
	font-weight: 500;
    line-height: 1;
}
.flow-box_text {
	margin-top: 0;
	font-size: 16px;
	line-height: 1.6;
}

@media screen and (max-width: 900px) {
	.flow-box {
		grid-template-columns: 260px 1fr;
		gap: 40px;
	}
}

@media screen and (max-width: 767px) {
    .ttl-flow-content p {
        margin: 50px 0 10px;
    }
	.flow-list {
		margin-top: 60px;
		gap: 40px;
	}

	.flow-box {
		grid-template-columns: 1fr;
		gap: 15px;
	}
    .flow-box_step {
        gap: 6px;
        margin-bottom: 18px;
    }
    .flow-box_step-en {
        font-size: 20px;
    }
    .flow-box_step-en::after {
        width: 40px;
        height: 1px;
    }
    .flow-box_step-no {
		font-size: 37px;
	}
	.flow-box_ttl {
		font-size: 20px;
	}
    .flow-box_text {
        font-size: 15px;
    }
}

.flow-service {
    width: 100%;
	max-width: 1100px;
    margin: 150px auto 0;
}
.flow-service_head {
	max-width: 820px;
	margin: 0 auto;
}
.flow-service_illust {
	width: 110px;
	height: auto;
	margin: 40px auto 0;
}
.flow-service_illust img {
	display: block;
	width: 100%;
	height: auto;
}
.flow-service h3 {
	margin: 0;
	font-family: "Ryumin Regular KL", serif;
	font-size: clamp(1.375rem, 0.949rem + 1.89vw, 2.25rem);
	font-weight: 500;
	line-height: 1.6;
	text-align: left;
}
.flow-service_head span {
	display: block;
	font-size: 13px;
	text-align: left;
}
.flow-service-content {
    margin: 40px 0 0;
    border: 1px solid #888;
    padding: 40px;
}
.flow-service-content h4 {
	margin: 0 0 7px;
    font-size: 18px;
}
.flow-service-content p:first-of-type {
    margin-bottom: 1.5em;
}
.flow-service-content ul li {
	position: relative;
	padding-left: 1em;
}
.flow-service-content ul li::before {
	content: "・";
	position: absolute;
	left: 0;
	top: 0;
}

@media screen and (max-width: 767px) {
    .flow-service {
        margin: 90px auto 0;
    }
    .flow-service-content {
        padding: 25px;
    }
    .flow-service-content p,
    .flow-service-content li {
        font-size: 14px;
        line-height: 1.6;
    }
}


/*ファーストビューイメージ変更*/
.page-slug-flow .l-pageHead__en {
	color: #d67392;
}
.page-slug-flow h1,
.page-slug-flow .sub-ttl,
.page-slug-flow .l-pageHead__note {
    color: #fff;
}
.page-slug-flow .l-pageHead {
	position: relative;
	background-image: url("/wp-content/themes/proporse-child/assets/images/header/page_flow-03.png");
}
.page-slug-flow .l-pageHead::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.35);
}
.page-slug-flow .l-pageHead .l-pageHead__inner {
	position: relative;
	z-index: 1;
}