section.panel {
	> div {
		margin-inline: auto;
		max-width: 1920px;
		> figure {
			> img {
				max-width: 100%;
			}
		}
	}
}
section.top {
	padding: 60px 5% 100px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: min(3.5rem, 8.0vw);
			line-height: 1.3;
			color: #fff;
			font-weight: 600;
			letter-spacing: 2px;
			text-align: center;
		}
		> div {
			padding-top: 120px;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 60px;
			@media (width < 700px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 30px;
			}
			> figure {
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
			> div {
				display: grid;
				> figure {
					align-self: end;
					margin-left: -20%;
					margin-top: -10%;
					@media (width < 700px) {
						margin-left: 0%;
						margin-top: -30%;
						justify-self: end;
						padding-left: 5%;
					}
					> img {
						max-width: 100%;
					}
				}
				> div {
					align-self: end;
					> h3 {
						font-size: min(2.4rem, 7.0vw);
						line-height: 1.4;
						color: #fff;
						font-weight: 600;
						font-family: var(--font-en);
					}
					> h4 {
						font-size: min(1.4rem, 5.5vw);
						line-height: 1.4;
						color: #fff;
						font-weight: 400;
						border-bottom: 1px solid #a70000;
						padding-bottom: 20px;
					}
					> p {
						padding-top: 20px;
						font-size: min(1.1rem, 5.0vw);
						line-height: 1.8;
						color: #fff;
						text-align: justify;
						&:nth-of-type(2) {
							padding-top: 40px;
						}
					}
				}
			}
		}
		> figure {
			padding-top: 30px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			text-align: center;
			font-size: min(1.3rem, 6.0vw);
			line-height: 3.0;
			color: #fff;
		}
	}
}
section.block {
	padding: 0px 5% 100px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div {
			display: grid;
			column-gap: 10px;
			&:nth-of-type(1) {
				grid-template-columns: repeat(2, 1fr);
				@media (width < 480px) {
					grid-template-columns: repeat(1, 1fr);
					row-gap: 10px;
				}
			}
			&:nth-of-type(2) {
				grid-template-columns: repeat(3, 1fr);
				@media (width < 410px) {
					grid-template-columns: repeat(1, 1fr);
					row-gap: 10px;
				}
			}
			> figure {
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
		}
		> figure {
			padding-block: 10px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}	
		> p {
			padding-top: 40px;
			font-size: min(1.1rem, 5.0vw);
			line-height: 1.8;
			color: #fff;
			text-align: justify;
		}
	}
}
