 /* CSS Document */

article{
	display: grid;
	grid-template-columns: 1fr var(--wrap) 1fr;
	grid-gap: clamp(24px, 4.8vw, 32px) 0;
	padding: clamp(24px, 4.8vw, 32px) 0;
	}
	article > *{
		grid-column: 2;
		}
	article h3{
		justify-self: center;
		padding: 0 clamp(24px, 4.8vw, 32px) clamp(16px, 3.6vw, 24px) clamp(24px, 4.8vw, 32px);
		border-bottom: 4px solid currentColor;
		font-size: clamp(18px, 3.6vw, 24px);
		font-weight: 700;
		z-index: 1;
		}
		article h3:before{
			content: "";
			margin: 0.3em 0;
			background: var(--color-point);
			transform: translateY(0.1em);
			}
	article h4{
		display: grid;
		grid-template-columns: 3px auto;
		grid-gap: 10px;
		font-size: clamp(20px, 3.6vw, 24px);
		font-weight: 700;
		line-height: 1.65;
		}
		article h4:before{
			content: "";
			margin: 0.3em 0;
			background: var(--color-point);
			transform: translateY(0.1em);
			}
	@media (min-width: 576px) {
			article h4{
				grid-template-columns: 4px auto;
			}
		}

#access{}
	#access h2{
		justify-self: center;
		}

#tabMenu{
	grid-column: 1 / 4;
	transform: translateY(24px);
	}
	@media (min-width: 576px) {
		#tabMenu{
			transform: translateY(32px);
			}
		}

#accessTo{
	grid-gap: clamp(48px, 9.6vw, 64px) 0;
	padding-bottom: clamp(64px, 14.4vw, 96px);
	background: #fff;
	}
	#accessTo h2{
		display: none;
		}
	#accessTo h2+div{
		display: grid;
		align-content: start;
		grid-gap: clamp(24px, 4.8vw, 32px) 0;
		}
	#accessTo section{
		display: grid;
		grid-gap: clamp(32px, 6vw, 40px) 0;
		}
		#accessTo section:before{
			content: "";
			grid-column: 1;
			grid-row: 1;
			width: 100%;
			border-bottom: 4px solid var(--color-border);
			}
	#accessTo h3{
		grid-column: 1;
		grid-row: 1;
		}
	#accessTo h4+div{
		display: grid;
		grid-gap: 24px;
		margin-top: 16px;
		}
	#accessTo figure{
		grid-row: 1;
		justify-self: center;
		margin-top: 24px;
		}

#accessIn{
	grid-gap: clamp(48px, 9.6vw, 64px) 0;
	padding-bottom: clamp(64px, 14.4vw, 96px);
	background: #fff;
	}
	#accessIn h2{
		display: none;
		}
	#accessIn h2+div{
		display: grid;
		align-content: start;
		grid-gap: clamp(24px, 4.8vw, 32px) 0;
		}
	#accessIn section{
		display: grid;
		grid-gap: clamp(32px, 6vw, 40px) 0;
		}
		#accessIn section:before{
			content: "";
			grid-column: 1;
			grid-row: 1;
			width: 100%;
			border-bottom: 4px solid var(--color-border);
			}
	#accessIn h3{
		grid-column: 1;
		grid-row: 1;
		}
	#accessIn h4+div{
		display: grid;
		grid-gap: 16px;
		margin-top: 16px;
		}
	#accessIn figure{
		grid-row: 1;
		justify-self: center;
		margin-top: 24px;
		}
	@media (min-width: 992px) {
		#accessIn figure{
			width: 50%;
			}
		}


.route{
	display: grid;
	}
	.route li:nth-child(odd){
		align-self: center;
		display: grid;
		align-items: center;
		min-height: 50px;
		padding: 4px 16px;
		background: #fff;
		border: 1px solid var(--color-border);
		color: var(--color);
		text-align: center;
		line-height: 1.65;
		text-decoration: none;
		}
		.route li:nth-child(odd):last-child{
			background: var(--color-theme);
			border-color: transparent;
			color: #fff;
			}
	.route li:nth-child(even){
		display: grid;
		line-height: 1.65;
		overflow: hidden;
		}
		.route li:nth-child(even):before,
		.route li:nth-child(even):after{
			content: "";
			}
		.route li:nth-child(even):before{
			background: var(--color-border);
			}
		.route li:nth-child(even):after{
			width: 8px;
			aspect-ratio: 1;
			border: 0 solid var(--color-border);
			}
	@media (max-width: 575.98px) {
		.route li:nth-child(even){
			grid-template-columns: 32px auto;
			grid-gap: 0 16px;
			padding: 16px 0;
			}
			.route li:nth-child(even):before,
			.route li:nth-child(even):after{
				grid-column: 1;
				grid-row: 1 / 3;
				justify-self: center;
				}
			.route li:nth-child(even):before{
				width: 1px;
				margin: -16px 0;
				}
			.route li:nth-child(even):after{
				align-self: end;
				border-width: 0 1px 1px 0;
				transform: translateY(15px) rotate(45deg);
				}
		}
	@media (min-width: 576px) {
		.route{
			grid-gap: 16px 0;
			align-items: center;
			}
			.route li:nth-child(even){
				display: grid;
				grid-template-rows: 1fr auto 1fr;
				grid-gap: 4px 0;
				padding: 0 16px;
				text-align: center;
				}
				.route li:nth-child(even):before,
				.route li:nth-child(even):after{
					grid-column: 1;
					grid-row: 2;
					align-self: center;
					}
				.route li:nth-child(even):before{
					margin: 0 -16px;
					height: 1px;
					}
				.route li:nth-child(even):after{
					justify-self: end;
					border-width: 1px 1px 0 0;
					transform: translateX(15px) rotate(45deg);
					}
			.route li:nth-child(even) span{}
				.route li:nth-child(even) span:first-child{
					align-self: end;
					}
		}
	@media (min-width: 576px) {
		.route{
			grid-template-columns: 1fr 1.5fr 1fr;
			}
		}

.contact{
	display: grid;
	grid-template-columns: auto auto;
	justify-content: start;
	grid-gap: 4px 16px;
	line-height: 1.65;
	}
	.contact dt{
		font-weight: 500;
		}


