section.panel {
	background: url(./image/panel01_bg_dot.svg),linear-gradient(to bottom,#eaf3f9 calc(100% - 100px), #ffffff 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.company {
	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;
		}
		> div {
			margin-top: 70px;
			max-width: 450px;
			margin-inline: auto;
			> article {
				display: grid;
				grid-template-columns: 80px auto;
				column-gap: 20px;
				@media (width < 530px) {
					grid-template-columns: 1fr;
					row-gap: 20px;
				}
				> h3 {
					font-size: min(1.8rem, 7.0vw);
					line-height: 1.0;
					color: #222;
					font-weight: 600;
					&:nth-of-type(1) {
						color: #004ab4;
					}
				}
				> div {
					> p {
						font-size: min(1.0rem, 4.5vw);
						line-height: 1.6;
						color: #222;
						font-weight: 500;
						letter-spacing: 0.05rem;
						&:nth-of-type(2) {
							padding-top: 40px;
						}
					}
				}
				&:nth-of-type(2) {
					padding-top: 40px;
					@media (width < 530px) {
						padding-top: 60px;
					}
				}
			}
		}
	}
}
section.about {
	padding: 0px 5% 120px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			font-size: min(1.5rem, 6.0vw);
			line-height: 1.0;
			color: #004ab4;
			font-weight: 600;
		}
		> dl {
			@media (width < 630px) {
				padding-top: 30px;
			}
			> div {
				display: grid;
				grid-template-columns: 150px 1fr;
				&:first-child {
					> dt {
						border-bottom: 1px solid #80a4d9;
						@media (width < 630px) {
							border-top: 1px solid #80a4d9;
						}
					}
					> dd {
						border-bottom: 1px solid #80a4d9;
						@media (width < 630px) {
							border-bottom: none;
						}
					}
				}
				@media (width < 630px) {
					grid-template-columns: 1fr;
					height: auto;
					margin-bottom: 40px;
				}
				> dt {
					font-size: min(1.1rem, 5.5vw);
					line-height: 1.8;
					color: #222;
					font-weight: 500;
					padding: 30px 30px 30px 0px;
					border-bottom: 2px dotted #80a4d9;
					@media (width < 630px) {
						text-align: center;
						border-bottom: 1px solid #80a4d9;
						border-top: 1px solid #80a4d9;
						padding: 20px 0;
					}
				}
				> dd {
					border-bottom: 2px dotted #80a4d9;
					color: #222;
					font-size: min(1.1rem, 5.5vw);
					line-height: 1.8;
					padding: 30px 30px 30px 0px;
					> p {
						padding-bottom: 0.8rem;
					}
					&.blue {
						> p {
							&:nth-of-type(odd) {
								color: #004ab4;
							}
						}
					}
					&.item {
						> p {
							padding-bottom: 5px;
							text-indent: -0.5em;
							padding-left: 0.5em;
						}
					}
					@media (width < 630px) {
						border: none;
						padding: 20px 0;
					}
				}
			}
			&:nth-of-type(2) {
				> div {
					grid-template-columns: 180px 1fr;
					@media (width < 630px) {
						grid-template-columns: 1fr;
						height: auto;
						margin-bottom: 40px;
					}
					&:last-of-type {
						> dt {
							border-bottom: 1px solid #004ab4;
							@media (width < 630px) {
								border-bottom: 1px solid #80a4d9;
								border-top: 1px solid #80a4d9;
							}
						}
						> dd {
							border-bottom: 1px solid #004ab4;
							@media (width < 630px) {
								border-bottom: none;
							}
						}
					}
				}
			}
		}
	}
}
section.access {
	background-color: #ecefef;
	padding: 60px 5% 200px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			font-size: min(1.5rem, 6.0vw);
			line-height: 1.0;
			color: #004ab4;
			font-weight: 600;
		}
		> h4 {
			font-size: min(1.2rem, 5.5vw);
			line-height: 1.0;
			color: #222;
			font-weight: 600;
			padding-block: 15px;
		}
		> p {
			font-size: min(1.1rem, 5.5vw);
			line-height: 1.5;
			color: #222;
			font-weight: 500;
		}
		> iframe {
			margin-top: 10px;
			border: none;
			width: 100%;
			height: 700px;
			@media (width < 600px) {
				height: 500px;
			}
		}
	}
}
