@charset "UTF-8";
body {
	overflow-x:visible;
}
/*-----------------------------------

	mainvisual_lower_block

-----------------------------------*/
#mainvisual_lower_block::before {
	background: url(../img/flow/img_mv_bg.jpg) no-repeat center / cover;
}
/*-----------------------------------

	flow_block

-----------------------------------*/
#flow_block {
	padding-bottom: 105px;
	position: relative;
}
#flow_block .flow_container {
	align-items: flex-start;
	margin-bottom: 94px;
}
#flow_block .img_box {
	width: 42.67vw;
	height: calc(100vh - 100px);
	margin: 0 calc(50% - 50vw);
	position: sticky;
	top: 100px;
	left: 0;
	z-index: 1;
}
#flow_block .img_box img {
	height: 100%;
	object-fit: cover;
}
#flow_block .flow_wrap {
	width: 51.67%;
	margin: 0 14px 58px auto;
	position: relative;
}
#flow_block .flow_wrap::before {
	content: '';
	display: block;
	background: rgba(42, 71, 113, 0.37);
	width: 8px;
	height: 100%;
	margin: auto;
	position: absolute;
	inset: 0;
	z-index: 0;
}
#flow_block .flow_box {
	background: #ffffff;
	padding: 16px 19px 27px;
	border: 1px solid rgba(42, 71, 113, 0.37);
	border-radius: 3px;
	position: relative;
	z-index: 1;
}
#flow_block .flow_box:not(:last-of-type) {
	margin-bottom: 50px;
}
#flow_block .flow_box h3 {
	font-size: 28px;
	font-weight: 700;
	line-height: 1.75;
	letter-spacing: 0.05em;
	padding: 1px 0 1px 69px;
	margin-bottom: 7px;
}
#flow_block .flow01 h3 {
	background: url(../img/flow/icon_flow01.svg) no-repeat center left / 50px;
}
#flow_block .flow02 h3 {
	background: url(../img/flow/icon_flow02.svg) no-repeat center left / 50px;
}
#flow_block .flow03 h3 {
	background: url(../img/flow/icon_flow03.svg) no-repeat center left / 50px;
}
#flow_block .flow04 h3 {
	background: url(../img/flow/icon_flow04.svg) no-repeat center left / 50px;
}
#flow_block .flow05 h3 {
	background: url(../img/flow/icon_flow05.svg) no-repeat center left / 50px;
}
#flow_block .flow06 h3 {
	background: url(../img/flow/icon_flow06.svg) no-repeat center left / 50px;
}
#flow_block .flow07 h3 {
	background: url(../img/flow/icon_flow07.svg) no-repeat center left / 50px;
}
#flow_block .flow08 h3 {
	background: url(../img/flow/icon_flow08.svg) no-repeat center left / 50px;
}
#flow_block .flow09 h3 {
	background: url(../img/flow/icon_flow09.svg) no-repeat center left / 50px;
}
#flow_block .flow10 h3 {
	background: url(../img/flow/icon_flow10.svg) no-repeat center left / 50px;
}
#flow_block .flow_box p {
	line-height: 1.79;
	padding-left: 69px;
}
#flow_block .end_txt {
	font-size: 20px;
	font-weight: 900;
	line-height: 2;
	text-align: center;
}
@media screen and (max-width: 840px) {
	#flow_block .flow_container {
		flex-direction: column-reverse;
	}
	#flow_block .flow_wrap {
		width: 100%;
		margin: 0 0 58px auto;
	}
	#flow_block .img_box {
		width: 100vw;
		height: 400px;
		margin: 0 calc(50% - 50vw);
		position: static;
	}
	#flow_block .img_box .pc {
		display: none;
	}
	#flow_block .img_box .sp {
		display: block;
	}
}
@media screen and (max-width: 640px) {
	#flow_block {
		padding-bottom: 55px;
	}
	#flow_block .flow_container {
		margin-bottom: 54px;
	}
	#flow_block .img_box {
		height: 240px;
	}
	#flow_block .flow_wrap {
        margin: 0 0 44px;
	}
	#flow_block .flow_wrap::before {
		width: 6px;
	}
	#flow_block .flow_box {
		padding: 16px 14px;
	}
	#flow_block .flow_box:not(:last-of-type) {
		margin-bottom: 30px;
	}
	#flow_block .flow_box h3 {
		font-size: 20px;
		background-size: 36px;
		padding: 1px 0 1px 49px;
	}
	#flow_block .flow_box p {
		padding-left: 49px;
	}
	#flow_block .end_txt {
		font-size: 16px;
		font-weight: 700;
	}
}