@charset "utf-8";
section.policy {
	padding: 95px 140px 50px;
	max-width:1440px;
	margin:0 auto;
}

/* add 20250427 */
.policy-bg {
	background-image: url('../images/treatment_policy/chiryohoshin_top.jpg');
}

.policy-catch {
	text-align: center;
	margin-bottom: 60px;
	font: bold 24px/33px 'Noto Serif', serif;
	letter-spacing: 2.4px;
	color: #080402;
}

section.policy h3 {
	font: 400 22px/30px 'Noto Sans JP', sans-serif;
	color: #080402;
}

section.flow {
	padding: 50px 140px 140px;
	max-width:1440px;
	margin:0 auto;
	text-align: center;
}

section.flow h2 {
	font: 400 34px/40px 'Noto Serif', serif;
	letter-spacing: 3.4px;
	color: #080402;
	margin-bottom: 75px;
}

.flow-content {
	position: relative;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 210px;
	color: #FFFFFF;
}

.flow-content:not(:last-child) {
	margin-bottom: 100px;
}

.flow-content:not(:last-child)::after {
	position: absolute;
	right: 0;
	bottom: -74px;
	left: 0;
	content: "";
	display: block;
	width: 0;
	height: 0;
	margin: 0 auto;
	border-style: solid;
	border-width: 44px 44px 0 44px;
	border-color: #EDEDED transparent;
}

.flow-content .flow-label {
	font: bold 40px 'Noto Serif', serif;
	letter-spacing: 4px;
	margin-bottom: 30px;
}

.flow-content .flow-detail {
	font: 400 20px/26px 'Noto Sans JP', sans-serif;
	letter-spacing: 2px;
}

@media screen and (max-width:1200px) {
	section.policy {
		padding: 40px 25px 50px;
	}
	.policy-catch {
		text-align: left;
		margin-bottom: 40px;
		font: bold 18px/30px 'Noto Serif', serif;
		letter-spacing: 1.8px;
	}
	.policy-catch br{
		display: none;
	}
	section.policy h3 {
		font: 400 16px/30px 'Noto Sans JP', sans-serif;
	}
	section.flow {
		padding: 40px 25px 50px;
		text-align: center;
	}
	section.flow h2 {
		font: 400 24px/24px 'Noto Serif', serif;
		letter-spacing: 2.4px;
		margin-bottom: 18px;
	}
	.flow-content {
		width: 100%;
		height: auto;
		padding: 20px;
	}
	.flow-content:not(:last-child) {
		margin-bottom: 80px;
	}
	.flow-content:not(:last-child)::after {
		bottom: -58px;
		border-width: 24px 24px 0 24px;
	}
	.flow-content .flow-label {
		font: bold 22px 'Noto Serif', serif;
		letter-spacing: 2.2px;
		margin-bottom: 18px;
	}
	.flow-content .flow-detail {
		font: 400 16px/30px 'Noto Sans JP', sans-serif;
		letter-spacing: 1.6px;
		text-align: left;
	}
}