section.panel {
	> div {
		max-width: 1920px;
		margin-inline: auto;
		display: grid;
		> figure {
			grid-area: 1/1/2/2;
			> img {
				max-width: 100%;
			}
		}
		> div {
			padding-block: 30px;
			padding-inline: 5%;
			max-width: 870px;
			background-color: rgba(255, 255, 255, 0.85);
			grid-area: 1/1/2/2;
			justify-self: center;
			align-self: center;
			margin-inline: 5%;
			text-align: center;
			@media (width < 750px) {
				padding-block: 10px;
			}
			> h1 {
				font-size:  min(1.8rem, 5.5vw);
				line-height: 1.3;
				color: #143282;
				font-weight: 500;
			}
			> p {
				padding-top: 7px;
				font-size: min(1.1rem, 5vw);
				line-height: 1.6;
				color: #000;
				@media (width < 750px) {
					font-size: min(0.8rem, 4.5vw);
				}
			}
		}
	}
}
section.title {
	padding: 70px 5% 0px 5%;
	&.second {
		padding-top: 140px;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #333;
			text-align: center;
			font-weight: 600;
		}
		> div.line {
			margin-block: 10px;
			margin-inline: auto;
			background-color: #009fe8;
			width: 50px;
			height: 5px;
			&.order {
				background-color: #143282;
			}
		}
		> h2 {
			padding-top: 20px;
			font-size: 1.4rem;
			line-height: 1.5;
			color: #143282;
			text-align: center;
			font-weight: 600;
		}
		> p {
			padding-top: 40px;
			font-size: 1.1rem;
			line-height: 1.8;
			color: #333;
			text-align: justify;
		}
	}
}
section.equipment01 {
	padding: 80px 5% 80px 5%;
	&.bgcolor {
		background-color: #e5f5fd;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.top {
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 20px;
			@media (width < 850px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 20px;
			}
			> article {
				&:nth-of-type(1) {
					max-width: 92%;
					@media (width < 850px) {
						max-width: unset;
					}
				}
				> h3 {
					padding: 15px 30px;
					align-self: center;
					text-align: center;
					background: linear-gradient(to bottom, #009fe8, #0061e3);
					font-size: 1.3rem;
					line-height: 1.3;
					color: #fff;
					@media (width < 770px) {
						justify-self: start;
					}
				}
				> p {
					padding-block: 20px 30px;
					font-size: 1.3rem;
					line-height: 1.5;
					color: #333;
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
				> div {
					border: 1px solid #143282;
					padding: 10px 20px 20px 20px;
					> h4 {
						text-align: center;
						font-size: 1.2rem;
						line-height: 1.8;
						color: #143282;
						border-bottom: 1px solid #a1adcd;
					}
					> p {
						font-size: 1.1rem;
						line-height: 1.8;
						color: #333;
						> small {
							font-size: 0.9rem;
						}
						&:nth-of-type(2) {
							text-indent: -0.9em;
  							padding-left: 0.9em;
							line-height: 1.2;
						}
					}
				}
			}
		}
		> p {
			padding-top: 10px;
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			letter-spacing: 1px;
		}
		> div.block {
			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);
				row-gap: 20px;
			}
			@media (width <460px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
		} 
	}
}
section.equipment02 {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.top {
			> h3 {
				max-width: 450px;
				padding: 15px 30px;
				align-self: center;
				text-align: center;
				background: linear-gradient(to bottom, #009fe8, #0061e3);
				font-size: 1.3rem;
				line-height: 1.0;
				color: #fff;
				@media (width < 770px) {
					justify-self: start;
				}
			}
			> h2 {
				padding-block: 10px;
				font-size: 1.6rem;
				line-height: 1.5;
				color: #143282;
			}
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			letter-spacing: 1px;
		}
		> div.block {
			padding-top: 15px;
			display: grid;
			grid-template-columns: 2fr 0.935fr;
			column-gap: 13px;
			row-gap: 13px;
			@media (width < 660px) {
				grid-template-columns: 1fr;
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
			> div {
				display: grid;
				grid-template-columns: 1fr 1fr;
				column-gap: 13px;
				row-gap: 13px;
				@media (width < 520px) {
					grid-template-columns: 1fr;
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
			}
		} 
	}
}
section.list {
	padding: 0px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		background-color: #e5f5fd;
		> div {
			padding: 0px 20px 20px 25px;
			@media (width < 430px) {
				padding: 0px 10px 10px 10px;
			}
			> h2 {
				font-size: 1.5rem;
				line-height: 2;
				color: #143282;
				font-weight: 500;
				text-align: center;
				padding-block: 30px;
			}
			> div {
				display: grid;
				grid-template-columns: 1fr 0.95fr 1.05fr;
				@media (width < 1110px) {
					grid-template-columns: repeat(2, 1fr);
				}
				@media (width < 780px) {
					grid-template-columns: repeat(1, 1fr);
				}
				> div {
					> p {
						padding-block: 5px;
						font-size: 0.9rem;
						line-height: 1.4;
						color: #333;
						text-indent: -1.2rem;
  						padding-left: 1.2rem;
						> span {
							padding-right: 5px;
							color: #009fe8
						}
					}
				}
			}
		}
	}
}
section.link {
	padding: 30px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> a {
			margin-top: 10px;
			justify-self: center;
			display: grid;
			text-decoration: none;
			@media (width < 580px) {
				justify-self: unset;
			}
			&:hover {
				opacity: 0.7;
			}
			> div.link {
				background-color: var(--color-accent);
				background-image: url(../common/image/link_mark.svg);
				background-repeat: no-repeat;
				background-size: 20px 20px;
				background-position: 82% 55%;
				width: 520px;
				height: 80px;
				margin-inline: auto;
				display: flex;
				align-items: center;
				justify-content: center;
				> p {
					font-size: 1.0rem;
					line-height: 1.3;
					color: #fff;
				}
				&.order {
					background-color: #143282;
				}
				@media (width < 580px) {
					text-align: center;
					padding-inline: 40px;
					width: 100%;
					background-position: 95% 50%;
				}
			}
		}
	}
}
section.bottom {
	padding-top: min(120px,17vw);
	border-bottom: solid 1px #7484c1;
}
