section.panel {
	background: url(./image/panel01_bg_dot.svg),linear-gradient(to bottom,#eaf3f9 calc(100% - 100px), #fff 100%);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-position: 100% 100%;
	> div.top {
		max-width: 3840px;
		margin-inline: auto;
		> div {
			padding-top: min(100px, 12vw);
			max-width: 1350px;
			margin-inline: auto;
			> figure {
				display: flex;
				justify-content: center;
				> img {
					max-width: 100%;
					width: 75%;
					@media (width < 1000px) {
						width: 90%;
					}
				}
			}
		}
	}
}
section.info {
	padding: 0px 5% 100px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			font-size: min(3.0rem, 9.0vw);
			line-height: 1.0;
			color: #004ab4;
			font-weight: 600;
		}
		> h3 {
			padding-block: 100px 10px;
			text-align: center;
			font-size: min(2.5rem, 7.0vw);
			line-height: 1.0;
			color: #222;
			font-weight: 600;
		}
		> p {
			text-align: center;
			font-size: min(1.1rem, 5.0vw);
			line-height: 1.6;
			color: #222;
			font-weight: 500;
		}
		> figure {
			padding-top: 50px;
			margin-bottom: -35%;
			text-align: center;
			@media (width < 920px) {
				margin-bottom: -220px;
			}
			@media (width < 570px) {
				margin-bottom: 0px;
			}
			> img {
				max-width: 100%;
			}
		}
	}
}
section.challenger {
	background-color: #caeffa;
	border-top-left-radius: 50%;
	border-top-right-radius: 50%;
	padding: min(35%, 300px) 5% 0px 5%;
	@media (width < 920px) {
		padding: 150px 5% 0px 5%;
	}
	@media (width < 570px) {
		border-top-left-radius: 0;
		border-top-right-radius: 0;
		padding: 50px 5% 0px 5%;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> p {
			text-align: center;
			font-size: min(1.1rem, 5.0vw);
			line-height: 1.8;
			color: #222;
			font-weight: 600;
		}
		> h3 {
			text-align: center;
			font-size: min(2.2rem, 7.0vw);
			line-height: 1.0;
			color: #004ab4;
			font-weight: 600;
			> small {
				font-size: min(1.4rem, 6.0vw);
			}
		}
		> h2 {
			text-align: center;
			font-size: min(3.5rem, 9.0vw);
			line-height: 1.6;
			color: #004ab4;
			font-weight: 600;
		}
		> figure {
			padding-block: 20px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
	}
}
section.requirements {
	background-color: #caeffa;
	padding: 0px 5% 100px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		display: grid;
		> div.line {
			margin-block: 80px;
			width: 70px;
			height: 15px;
			display: flex;
			justify-self: center;
			background: linear-gradient(to right, #6dc8d9, #3f5fe4);
			border-radius: 10px;
		}
		> h2 {
			text-align: center;
			font-size: min(3.0rem, 9.0vw);
			line-height: 1.0;
			color: #004ab4;
			font-weight: 600;
		}
		> dl {
			padding-top: 50px;
			> div {
				display: grid;
				grid-template-columns: 150px 1fr;
				&:first-child {
					> dt {
						border-top: 2px solid #999;
					}
					> dd {
						border-top: 2px solid #999;
						@media (width < 630px) {
							border-top: none;
						}
					}
				}
				&:last-child {
					> dd {
						@media (width < 630px) {
							border-bottom: 2px solid #999;
						}
					}
				}
				@media (width < 630px) {
					grid-template-columns: 1fr;
					height: auto;
				}
				> dt {
					text-align: center;
					background-color: #e6e6e6;
					align-content: center;
					font-size: min(1.1rem,4.5vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
					padding: 10px;
					border-bottom: 2px solid #999;
					border-right: 2px solid #999;
					@media (width < 630px) {
						border-top: 2px solid #999;
						border-right: none;
						line-height: 1.1;
					}
				}
				> dd {
					background-color: #fff;
					align-content: center;
					border-bottom: 2px solid #999;
					color: #333;
					font-size: min(1.1rem,5vw);
					line-height: 1.8;
					padding: 10px;
					@media (width < 630px) {
						border: none;
						padding: 10px 10px 40px 10px;
					}
				}
			}
		}
	}
}
