section.panel {
	position: relative;
	> picture {
		max-width: 3840px;
		margin-inline: auto;
		> img {
			max-width: 100%;
			max-height: 100vh;
			width: 100%;
			object-fit: cover;
			object-position: 0 50%;
		}
	}
	> div {
		position: absolute;
		top: 50%;
		left: 50%;
		font-size: min(2.6rem, 6.5vw);
		line-height: 1.3;
		color: #111;
		font-weight: 600;
		white-space: nowrap;
		transform: translate(-50%, -50%);
		animation-name: panelTextMove;
		animation-duration: 1s;
		animation-fill-mode: forwards;
		animation-timing-function: ease-out;
	}
}
@keyframes panelTextMove {
	0% {
		margin-left: 50px;
		opacity: 0;
	}
	100% {
		margin-left: 0px;
		opacity: 1;
	}
}
section.top {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		display: grid;
		> h2 {
			padding-inline: 5px;
			display: inline-block;
			justify-self: center;
			text-align: center;
			font-size: min(2.5rem, 7vw);
			line-height: 1.6;
			color: #000;
			font-weight: 600;
		}
		> picture {
			margin-top: 30px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
	}
}
section.reason {
	background-color: #e5eef8;
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			font-size: min(2.5rem, 7vw);
			line-height: 1.6;
			color: #000;
			font-weight: 600;
			letter-spacing: 1px;
			> span {
				> b {
					color: #e74282;
				}
			}
		}
		> p {
			font-size: min(1.1rem, 5vw);
			line-height: 1.6;
			color: #111;
			font-weight: 600;
			letter-spacing: 1px;
			padding-top: 20px;
			text-align: justify;
		}
		> figure {
			padding-top: 10px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> div.item {
			margin-top: 40px;
			border-left: 6px solid #006ab4;
			padding-left: 20px;
			&.line {
				margin-top: 80px;
			}
			> h3 {
				font-size: min(1.8rem, 6vw);
				line-height: 1.3;
				color: #006ab4;
				font-weight: 600;
				letter-spacing: 1px;
			}
		}
		> div.block {
			display: grid;
			grid-template-columns: 2fr 1.1fr;
			@media (width < 950px) {
				grid-template-columns: 1fr;
				row-gap: 30px;
			}
			> div {
				> p {
					font-size: min(1.1rem, 5vw);
					line-height: 1.6;
					color: #111;
					font-weight: 600;
					letter-spacing: 1px;
					padding-top: 30px;
					text-align: justify;
				}
			}
			> figure {
				align-self: end;
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.faq {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			font-size: min(2.5rem, 7vw);
			line-height: 1.6;
			color: #000;
			font-weight: 600;
			letter-spacing: 1px;
		}
		> article {
			padding-top: 20px;
			display: grid;
			grid-template-columns: 65px 1fr;
			column-gap: 40px;
			@media (width < 600px) {
				column-gap: 20px;
				grid-template-columns: 50px 1fr;
			}
			> h3 {
				align-self: center;
				font-size: min(1.4rem, 6vw);
				line-height: 1.4;
				color: #111;
				font-weight: 600;
				text-align: justify;
			}
			> div {
				&.points {
					> p {
						&:nth-of-type(n + 2) {
							text-indent: -1em;
							padding-left: 1em;
						}
					}
				}
				> p {
					font-size: min(1.1rem, 5vw);
					line-height: 1.6;
					color: #111;
					font-weight: 600;
					text-align: justify;
				}
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
