section.panel {
	> div {
		max-width: 1920px;
		margin-inline: auto;
		> figure {
			> img {
				max-width: 100%;
			}
		}
	}
}
section.business {
	padding: 80px 5% 0px 5%;
	background: url(./image/crane_bg.webp);
	background-color: #D6F4D6;
	background-repeat: no-repeat;
	background-position: 100% 0%;
	background-size: auto 70%;
	@media (width < 850px) {
		background-size: 70% auto;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #32c832;
			font-weight: 700;
			text-align: center;
		}
		> p {
			font-size: min(1.1rem,5vw);
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
		> div {
			padding-top: 80px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 30px;
			@media (width < 850px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 50px;
			}
			> article {
				display: grid;
				grid-template-rows: auto auto auto 1fr;
				> h2 {
					padding-bottom: 15px;
					font-size: 1.2rem;
					line-height: 1.4;
					color: #000;
					font-weight: 700;
					border-bottom: 1px solid #333;
				}
				> h3 {
					padding-block: 15px 5px;
					font-size: 1.2rem;
					line-height: 1.4;
					color: #000;
					font-weight: 700;
				}
				> p {
					font-size: 1.0rem;
					line-height: 1.7;
					color: #000;
					text-align: justify;
				}
				> figure {
					align-self: end;
					padding-top: 30px;
					@media (width < 850px) {
						justify-self: center;
					}
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.crane {
	padding: 80px 5% 0px 5%;
	background: url(./image/crane.svg);
	background-color: #D6F4D6;
	background-repeat: no-repeat;
	background-position: 100% 200px;
	background-size: auto 180px;
	@media (width < 610px) {
		background-position: 100% 280px;
		background-size: auto 100px;
	}
	@media (width < 430px) {
		background-position: 100% 310px;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #32c832;
			font-weight: 700;
			text-align: center;
		}
		> p {
			font-size: min(1.1rem,5vw);
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
		> h2 {
			padding-block: 100px 20px;
			font-size: 1.4rem;
			line-height: 1.5;
			color: #000;
			font-weight: 700;
			text-align: center;
			border-bottom: 1px solid #333;
		}
		> div.block01 {
			> article {
				padding-top: 50px;
				display: grid;
				grid-template-columns: 1fr 1.1fr;
				column-gap: 30px;
				@media (width < 680px) {
					grid-template-columns: 1fr;
					row-gap: 40px;
				}
				> div {
					> h3 {
						font-size: 1.2rem;
						line-height: 1.4;
						color: var(--color-accent);
						font-weight: 700;
					}
					> p {
						padding-top: 20px;
						font-size: 1.0rem;
						line-height: 1.7;
						color: #000;
						text-align: justify;
					}
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
			}
		}
		> h3 {
			padding-top: 40px;
			font-size: 1.2rem;
			line-height: 1.4;
			color: var(--color-accent);
			font-weight: 700;
		}
		> div.block02 {
			padding-top: 10px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 30px;
			@media (width < 630px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 30px;
			}
			> article {
				> p {
					padding-block: 10px;
					font-size: 1.0rem;
					line-height: 1.7;
					color: #000;
					text-align: justify;
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.hoist {
	padding: 80px 5% 0px 5%;
	background: url(./image/hoist.svg);
	background-color: #D6F4D6;
	background-repeat: no-repeat;
	background-position: 100% 160px;
	background-size: auto 180px;
	@media (width < 610px) {
		background-position: 100% 210px;
		background-size: auto 100px;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #32c832;
			font-weight: 700;
			text-align: center;
		}
		> p {
			font-size: min(1.1rem,5vw);
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
		> h2 {
			padding-block: 100px 20px;
			font-size: 1.4rem;
			line-height: 1.5;
			color: #000;
			font-weight: 700;
			text-align: center;
			border-bottom: 1px solid #333;
		}
		> div.block01 {
			> article {
				padding-top: 50px;
				display: grid;
				grid-template-columns: 1fr 1.1fr;
				column-gap: 30px;
				@media (width < 680px) {
					grid-template-columns: 1fr;
					row-gap: 40px;
				}
				> div {
					> h3 {
						font-size: 1.2rem;
						line-height: 1.4;
						color: var(--color-accent);
						font-weight: 700;
					}
					> p {
						padding-top: 20px;
						font-size: 1.0rem;
						line-height: 1.7;
						color: #000;
						text-align: justify;
					}
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.peripheral_equipment {
	position: relative;
	overflow: hidden;
	padding: 80px 5% 300px 5%;
	background: url(./image/peripheral_equipment.svg);
	background-color: #D6F4D6;
	background-repeat: no-repeat;
	background-position: 100% 18%;
	background-size: auto 100px;
	@media (width < 1030px) {
		background-position: 100% 210px;
		background-size: 80% auto;
	}
	@media (width < 600px) {
		background: url(./image/peripheral_equipment_sp.svg);
		background-color: #D6F4D6;
		background-repeat: no-repeat;
		background-position: 100% 210px;
		background-size: 70% auto;
		padding: 80px 5% 150px 5%;
	}
	> figure.bottombg {
		position: absolute;
		z-index: 0;
		bottom: 0;
		left: 0%;
		width: 100vw;
		height: auto;
		max-height: 950px;
		margin-top: auto;
		> img {
			margin-inline: auto;
			width: 100%;
		}
	}
	> div {
		position: relative;
		z-index: 2;
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #32c832;
			font-weight: 700;
			text-align: center;
		}
		> p {
			font-size: min(1.1rem,5vw);
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
		> h2 {
			padding-block: 100px 20px;
			font-size: 1.4rem;
			line-height: 1.5;
			color: #000;
			font-weight: 700;
			text-align: center;
			border-bottom: 1px solid #333;
		}
		> div.block01 {
			padding-top: 50px;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 80px;
			@media (width < 680px) {
				grid-template-columns: 1fr;
			}
			> article {
				margin-bottom: 20px;
				display: grid;
				grid-template-rows: auto 1fr auto;
				> div {
					> h3 {
						font-size: 1.2rem;
						line-height: 1.4;
						color: var(--color-accent);
						font-weight: 700;
					}
					> p {
						padding-top: 20px;
						font-size: 1.0rem;
						line-height: 1.7;
						color: #000;
						text-align: justify;
					}
				}
				> figure {
					padding-top: 20px;
					align-self: end;
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.results {
	margin-block: 40px 100px;
	padding: 80px 5% 0px 5%;
	background: url(./image/shapes.svg);
	background-repeat: no-repeat;
	background-position: 100% 0%;
	background-size: auto 100%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #32c832;
			font-weight: 700;
			text-align: center;
		}
		> p {
			font-size: min(1.1rem,5vw);
			line-height: 1.0;
			color: #333;
			text-align: center;
		}
		> div {
			padding-block: 50px;
			> figure {
				> img {
					max-width: 100%;
				}
			}
			> video {
				max-width: 100%;
				display: block;
			}
		}
	}
}
