@charset "UTF-8";

.hero {
	margin-bottom: 170px;
	padding-top: 110px;
}

.hero .inner {
	max-width: 1450px;
}

.hero_cnt {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	padding: 27px 176px;
	border-radius: 23px;
	background-color: #f5fbff;
}

.hero_cnt_ttl {
	color: #007edf;
	font-weight: bold;
	font-size: 40px;
}

.cost {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
	position: absolute;
	bottom: 0;
	width: 550px;
	padding: 20px;
	border-radius: 12px;
	background: linear-gradient(to right bottom, #3dc0ff, #007edf);
	transform: translateY(50%);
}

.cost p {
	color: #ffffff;
	font-weight: bold;
	font-size: 15px;
	line-height: 20px;
}

.cost a {
	position: relative;
	width: 60%;
	padding: 12px 33px 12px 11px;
	border-radius: 7px;
	background-color: #ffffff;
	color: #007edf;
	font-weight: bold;
	font-size: 15px;
	line-height: 20px;
}

.cost a::after {
	content: "";
	position: absolute;
	right: 3%;
	bottom: 23%;
	width: 25px;
	height: 25px;
	background-image: url(/img/cmn/icon-arrow_cost.svg);
	background-size: cover;
	background-repeat: no-repeat;

	shape-image-threshold: 5%;
}

.flow_body {
	font-weight: 500;
	font-size: 16px;
}

.flow_body .inner {
	max-width: 1240px;
}

.flow_sec {
	padding: 25px 60px 25px 0;
	border-bottom: #d5d5d5 1px solid;
}

.flow_sec:last-child {
	border-bottom: none;
}

.flow_sec_wrap {
	display: flex;
	align-items: center;
	gap: 25px;
}

.flow_sec_hd {
	display: flex;
	flex-flow: column;
	justify-content: center;
	align-items: center;
	gap: 0;
	position: relative;
	z-index: 2;
	width: 117px;
	padding: 10px 0 13px;
	background: #ffffff;
	color: #007edf;
	line-height: 1;
	font-family: "Montserrat";
}

.flow_sec_hd::before {
	content: "";
	display: block;
	position: absolute;
	right: 50%;
	bottom: 100%;
	width: 3px;
	height: 130px;
	background: #007edf;
	transform: translateX(50%);
}

.flow_sec:first-child .flow_sec_hd::before {
	display: none;
}

.flow_sec_hd span {
	font-weight: bold;
	font-size: 26px;
}

.flow_sec_hd p {
	font-weight: bold;
	font-size: 69px;
}

.flow_sec_cnt {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: -webkit-fill-available;
}

.flow_sec_dy {
	width: 600px;
}

.flow_sec_ttl {
	margin-bottom: 5px;
	font-weight: bold;
	font-size: 30px;
}

.flow_sec_txt {
}

.flow_sec_txt a {
	color: #007edf;
	text-decoration: underline;
	transition: all 0.4s;
}

.flow_sec_txt a:hover {
	opacity: 0.6;
}

.flow_sec_img {
	flex-shrink: 0;
}

.flow_sec_plan {
	position: relative;
	margin-top: 100px;
	padding: 0 60px;
}

.flow_sec_plan_hd {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	right: 50%;
	width: calc(100% - 40px);
	max-width: 540px;
	height: 85px;
	border-radius: 9999px;
	background: #007edf;
	color: #ffffff;
	font-size: 30px;
	transform: translate(50%, -50%);
}

.flow_sec_plan_hd::before {
	content: "";
	display: block;
	position: absolute;
	top: 100%;
	right: 50%;
	border-top: 20px solid #007edf;
	border-right: 13px solid transparent;
	border-left: 13px solid transparent;
	transform: translateX(50%);
}

.flow_sec_plan_wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	margin-bottom: 60px;
	padding: 100px;
	border-radius: 20px;
	background: #f5fbff;
}

.flow_sec_plan_cnt {
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 0 15px #00000006;
	max-height: 524px;
}

.flow_sec_plan_cnt_top {
	padding: 23px 30px 30px;
	background: #ffffff;
}

.flow_sec_plan_ttl {
	margin-bottom: 15px;
	font-weight: bold;
	font-size: 30px;
	text-align: center;
}

.sw .flow_sec_plan_ttl {
	color: #fa529d;
}

.sw .flow_sec_plan_ttl .small_font {
	font-size: 25px;

}

.sm .flow_sec_plan_ttl {
	color: #077edf;
}

.flow_sec_plan_worries {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 24px;
}

.flow_sec_plan_worries_img {
}

.flow_sec_plan_worries_balloon {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 195px;
	height: 100px;
	padding: 0 14px;
	border: 1px solid;
	border-radius: 6px;
}

.flow_sec_plan_worries_balloon::before,
.flow_sec_plan_worries_balloon::after {
	content: "";
	display: block;
	position: absolute;
	right: 100%;
	bottom: 50%;
	border-top: 7px solid transparent;
	border-right: 8px solid;
	border-bottom: 7px solid transparent;
	transform: translateY(50%);
}

.sw .flow_sec_plan_worries_balloon {
	border-color: #fa529d;
}

.sm .flow_sec_plan_worries_balloon {
	border-color: #077edf;
}

.flow_sec_plan_worries_balloon::after {
	right: calc(100% - 2px);
	border-right-color: #ffffff;
}

.sw .flow_sec_plan_worries_balloon::before {
	border-right-color: #fa529d;
}

.sm .flow_sec_plan_worries_balloon::before {
	border-right-color: #077edf;
}

.flow_sec_plan_cnt_btm {
	position: relative;
	padding: 23px 12px 30px;
	color: #ffffff;
}

.flow_sec_plan_cnt_btm::before {
	content: "";
	display: block;
	display: block;
	position: absolute;
	top: 0;
	right: 50%;
	border-top: 14px solid;
	border-right: 17px solid transparent;
	border-left: 17px solid transparent;
	transform: translateX(50%);
}

.sw .flow_sec_plan_cnt_btm {
	background: #fa529d;
}

.sm .flow_sec_plan_cnt_btm {
	background: #077edf;
}

.flow_sec_plan_recommend {
}

.flow_sec_plan_recommend_hd {
	margin-bottom: 15px;
	padding-bottom: 14px;
	border-bottom: 1px solid;
	font-weight: bold;
	font-size: 19px;
	text-align: center;
}

.flow_sec_plan_recommend_hd p {
	font-weight: bold;
}

.flow_sec_plan_recommend_list {
	padding: 0 15px;
}

.flow_sec_plan_recommend_list li {
	position: relative;
	padding-left: 22px;
}

.flow_sec_plan_recommend_list li::before {
	content: "";
	position: absolute;
	top: 0.45em;
	left: 0;
	width: 17px;
	height: 16px;
	background: url(../img/flow/icon-check.svg) center / 100% 100%;
}

.flow_bg_img {
	position: relative;
	right: -12%;
}
.flow_bg_img::before {
	content: "";
    display: block;
    position: absolute;
    right: 107.3%;
    bottom: -20%;
    width: 3px;
    height: 462px;
    background: #007edf;
    transform: translateX(50%);
}
.flow_bg_img img {}

@media screen and (max-width:767px) {
	.hero {
		padding-top: 100px;
	}

	.hero .inner {
	}

	.hero_cnt {
		align-items: start;
		padding: 20px;
	}

	.hero_cnt_ttl {
		flex-shrink: 0;
		margin-bottom: 0;
		font-size: 20px;
		line-height: 30px;
	}

	.hero_cnt img {
		width: 128px;
	}

	.cost {
		flex-flow: column;
		bottom: -97px;
		left: 0;
		width: 100%;
	}

	.cost p {
	}

	.cost a {
		width: 100%;
	}

	.cost a::after {
	}

	.flow_body {
	}

	.flow_body .inner {
	}

	.flow_sec {
		position: relative;
		height: fit-content;
		padding: 30px 0;
	}

	.flow_sec:last-child {
	}

	.flow_sec_wrap {
		align-items: start;
		gap: 4px;
	}

	.flow_sec_hd {
		position: static;
		z-index: -1;
		width: unset;
		padding: 0;
		background: unset;
	}

	.flow_sec_hd::before {
		right: calc(100% - 29px);
		bottom: -18px;
		z-index: -1;
		height: calc(100% - 92px);
	}

	.flow_sec:first-child .flow_sec_hd::before {
		display: block;
	}

	.flow_sec:last-child .flow_sec_hd::before {
		display: none;
	}

	.flow_sec_hd span {
		font-size: 18px;
	}

	.flow_sec_hd p {
		font-size: 48px;
	}

	.flow_sec_cnt {
		flex-flow: column;
		padding-top: 18px;
	}

	.flow_sec_dy {
		width: 100%;
	}

	.flow_sec_ttl {
		font-size: 26px;
	}

	.flow_sec_txt {
	}

	.flow_sec_img {
	}

	.flow_sec_plan {
		padding: 0;
		margin-top: 70px;
	}

	.flow_sec_plan_hd {
		height: 57px;
		font-size: 24px;
	}

	.flow_sec_plan_hd::before {
	}

	.flow_sec_plan_wrap {
		grid-template-columns: 1fr;
		padding: 80px 20px;
	}

	.flow_sec_plan_cnt {
		max-height: none;
	}

	.flow_sec_plan_cnt_top {
		padding: 23px 10px 30px;
	}

	.flow_sec_plan_ttl {
		font-size: 24px;
	}

	.sw .flow_sec_plan_ttl {
	}

	.sm .flow_sec_plan_ttl {
	}

	.flow_sec_plan_worries {
	}

	.flow_sec_plan_worries_img {
	}

	.flow_sec_plan_worries_balloon {
		height: auto;
		padding: 20px 6px 20px 9px;
		font-size: 14px;
	}

	.flow_sec_plan_worries_balloon::before,
	.flow_sec_plan_worries_balloon::after {
	}

	.sw .flow_sec_plan_worries_balloon {
	}

	.sm .flow_sec_plan_worries_balloon {
	}

	.flow_sec_plan_worries_balloon::after {
	}

	.sw .flow_sec_plan_worries_balloon::before {
	}

	.sm .flow_sec_plan_worries_balloon::before {
	}

	.flow_sec_plan_cnt_btm {
		padding: 23px 11px 23px;
	}

	.flow_sec_plan_cnt_btm::before {
	}

	.sw .flow_sec_plan_cnt_btm {
	}

	.sm .flow_sec_plan_cnt_btm {
	}

	.flow_sec_plan_recommend {
	}

	.flow_sec_plan_recommend_hd {
	}

	.flow_sec_plan_recommend_hd p {
	}

	.flow_sec_plan_recommend_list {
		padding: 0 0;
	}

	.flow_sec_plan_recommend_list li {
		padding-left: 18px;
	}

	.flow_sec_plan_recommend_list li::before {
		width: 14px;
		height: 13px;
	}

	.flow_bg_img {
		position: relative;
        right: -70px;
        top: 15px;
        width: 80%;
	}
	.flow_bg_img::before {
		display: none;
	}
	.flow_bg_img img {
		width: 100%;
	}
}
