section.panel {
	> div {
		max-width: 1920px;
		margin-inline: auto;
		> figure {
			> img {
				max-width: 100%;
			}
		}
	}
}
section.title {
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #333;
			text-align: center;
			font-weight: 600;
		}
		> p {
			padding-top: 30px;
			font-size: 1.1rem;
			line-height: 1.8;
			color: #333;
			text-align: justify;
		}
	}
}
section.company {
	padding: min(100px,15vw) 5% 0px 5%;
	background-color: #fff;
	> div {
		position: relative;
		z-index: 1;
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			padding-top: 40px;
			font-size: 1.6rem;
			line-height: 1.5;
			color: #333;
			font-weight: 600;
			text-align: center;
		}
		> dl {
			padding-top: 50px;
			> div {
				display: grid;
				grid-template-columns: 200px 1fr;
				&:first-child {
					> dt {
						border-top: 1px solid #b3b3b3;
					}
					> dd {
						border-top: 1px solid #b3b3b3;
						@media (width < 630px) {
							border-top: none;
						}
					}
				}
				@media (width < 630px) {
					grid-template-columns: 1fr;
					height: auto;
				}
				> dt {
					background-color: #e7e6e6;
					align-content: center;
					font-size: min(1.1rem,4.5vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
					padding: 10px 40px 10px 40px;
					border-bottom: 1px solid #b3b3b3;
					@media (width < 630px) {
						border-top: 1px solid #b3b3b3;
						line-height: 1.1;
						&:empty {
							border-top: 1px solid #b3b3b3;
							border-bottom: none;
							padding: 0px 40px 0px 40px;
						}
					}
				}
				> dd {
					align-content: center;
					border-bottom: 1px solid #b3b3b3;
					color: #333;
					font-size: min(1.1rem,5vw);
					line-height: 1.8;
					padding: 10px 40px 10px 40px;
					> span {
						padding-left: -1em;
					}
					@media (width < 630px) {
						border: none;
						padding: 10px 0px 40px 0px;
					}
				}
				&.next_noborder {
					> dt {
						border-bottom: none;
					}
				}
			}
		}
	}
}
section.history {
	padding: 50px 5% 0px 5%;
	background-color: #fff;
	> div {
		position: relative;
		z-index: 1;
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			padding-top: 40px;
			font-size: 1.6rem;
			line-height: 1.5;
			color: #333;
			font-weight: 600;
			text-align: center;
		}
		> dl {
			padding-top: 50px;
			> div {
				display: grid;
				grid-template-columns: 200px 1fr;
				&:first-child {
					> dt {
						border-top: 1px solid #b3b3b3;
					}
					> dd {
						border-top: 1px solid #b3b3b3;
						@media (width < 630px) {
							border-top: none;
						}
					}
				}
				@media (width < 630px) {
					grid-template-columns: 1fr;
					height: auto;
				}
				> dt {
					background-color: #dce0ec;
					align-content: center;
					font-size: min(1.1rem,4.5vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
					padding: 10px 40px 10px 40px;
					border-bottom: 1px solid #b3b3b3;
					@media (width < 630px) {
						border-top: 1px solid #b3b3b3;
						line-height: 1.1;
						&:empty {
							border-top: 1px solid #b3b3b3;
							border-bottom: none;
							padding: 0px 40px 0px 40px;
						}
					}
				}
				> dd {
					align-content: center;
					border-bottom: 1px solid #b3b3b3;
					color: #333;
					font-size: min(1.1rem,5vw);
					line-height: 1.8;
					padding: 10px 40px 10px 40px;
					> span {
						padding-left: -1em;
					}
					@media (width < 630px) {
						border: none;
						padding: 10px 0px 40px 0px;
					}
				}
				&.next_noborder {
					> dt {
						border-bottom: none;
					}
				}
			}
		}
	}
}
section.access {
	padding: min(100px,17vw) 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.5;
			color: #333;
			font-weight: 600;
			text-align: center;
		}
		> iframe {
			padding-top: 40px;
			border: 0;
			width: 100%;
			height: 550px;
		}
		> p {
			border-bottom: 1px solid #b3b3b3;
			padding-block: 20px;
			font-size: 1.1rem;
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
	}
}
section.train {
	padding: 80px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.top {
			padding-bottom: 20px;
			display: flex;
			align-items: center;
			justify-content: center;
			column-gap: 10px;
			> figure {
				> img {
					width: 55px;
				}
			}
			> h3 {
				font-size: 1.3rem;
				line-height: 1.5;
				color: #009fe8;
				> small {
					font-size: 1.1rem;
				}
			}
		}
		> div.map {
			max-width: 800px;
			margin-inline: auto;
			display: grid;
			grid-template-columns: 2fr 1.1fr;
			column-gap: 10px;
			row-gap: 20px;
			@media (width < 520px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> figure {
				justify-self: end;
				> img {
					max-width: 100%;
				}
			}
			> div {
				align-self: end;
				@media (width < 520px) {
					justify-self: center;
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
				> p {
					padding-top: 5px;
					font-size: 1.0rem;
					line-height: 1.0;
					color: #333;
					@media (width < 520px) {
						text-align: center;
					}
				}
			}
		}
		> div.step {
			padding-top: 20px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 20px;
			row-gap: 20px;
			@media (width < 580px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.car {
	margin-top: 60px;
	border-top: 1px solid #b3b3b3;
	padding: 50px 5% 0px 5%;
	> div {
		max-width: 1200px;
		margin-inline: auto;
		> div.top {
			padding-bottom: 20px;
			display: flex;
			align-items: center;
			justify-content: center;
			column-gap: 10px;
			> figure {
				> img {
					width: 55px;
				}
			}
			> h3 {
				font-size: 1.3rem;
				line-height: 1.5;
				color: #009fe8;
				> small {
					font-size: 1.1rem;
				}
			}
		}
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> div.step {
			padding-top: 20px;
			display: grid;
			grid-template-columns: repeat(4, 1fr);
			column-gap: 20px;
			row-gap: 20px;
			@media (width < 850px) {
				grid-template-columns: repeat(2, 1fr);
			}
			@media (width < 580px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.image {
	margin-top: 80px;
	background-color: #f2f2f2;
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		@media (width < 600px) {
			grid-template-columns: repeat(1, 1fr);
			padding-bottom: 60px;
		}
		> div {
			> h3 {
				font-size: 1.3rem;
				line-height: 1.5;
				color: #333;
				text-align: center;
			}
			> figure {
				padding-top: 40px;
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
			> p {
				padding-block: 20px 60px;
				text-align: center;
				font-size: 1.1rem;
				line-height: 1.0;
				color: #333;
			}
			> div {
				padding-top: 100px;
				align-self: center;
				max-width: 300px;
				margin-inline: auto;
				@media (width < 600px) {
					padding-top: 60px;
				}
				> figure {
					text-align: center;
					> img {
						max-width: 100%;
					}
				}
				> p {
					padding-top: 40px;
					font-size: 1.1rem;
					line-height: 1.4;
					color: #333;
					text-align: justify;
				}
			}
		}
	}
}
