section.switchpanel {
	background-color: #faf0c8;
	padding-top: 20px;
	padding-bottom: 40px;
	@media (width < 550px) {
		padding-top: 0px;
	}
	> div {
		max-width: 1160px;
		margin-inline: auto;
		padding-inline: 10px;
		@media (width < 550px) {
			padding-inline: 0px;
		}
		> #switchPanelStage {
			user-select: none;
			display: grid;
			grid-template-rows: 1fr;
			grid-template-columns: 1fr;
			> div {
				grid-row: 1/2;
				grid-column: 1/2;
				&:nth-of-type(1) {
					z-index: 0;
				}
				&:nth-of-type(2) {
					z-index: 1;
					transition: 0.5s;
					cursor: ew-resize;
				}
				&:nth-of-type(3) {
					z-index: 2;
					justify-self: center;
					margin-bottom: -30px;
					align-self: end;
					display: flex;
					justify-content: center;
					align-items: center;
					column-gap: 10px;
					@media (width < 670px) {
						column-gap: 3px;
						margin-bottom: -20px;
						> span {
							> img {
								width: 14px;
							}
						}
					}
					> span {
						transition: 0.3s;
						cursor: pointer;
						> img:nth-of-type(1) {
							display: block;
						}
						> img:nth-of-type(2) {
							display: none;
						}
						&.on {
							> img:nth-of-type(1) {
								display: none;
							}
							> img:nth-of-type(2) {
								display: block;
							}
						}
					}
				}
				> div {
					display: grid;
					> picture {
						grid-area: 1/1/2/2;
						> img {
							width: 100%;
							border-radius: 20px;
							@media (width < 550px) {
								border-radius: 0px;
							}
						}
					}
					> div {
						grid-area: 1/1/2/2;
						align-self: end;
						margin-bottom: 9%;
						margin-left: 6.5%;
						> a {
							&:hover {
								opacity: 0.8;
							}
							> img {
								width: 20%;
							}
						}
					}
				}
			}
		}
	}
}
section.top {
	background-color: #faf0c8;
	padding: 100px 5% 50px 5%;
	> div {
		max-width: 900px;
		margin-inline: auto;
		> div {
			display: grid;
			justify-content: center;
			> h2 {
				font-size: min(4.5rem, 8vw);
				line-height: 1.4;
				color: var(--color-accent);
				font-weight: 600;
				letter-spacing: 4px;
				> small {
					font-size: min(4.0rem, 7vw);
				}
			}
			> div {
				padding-block: 20px;
				display: grid;
				grid-template-columns: auto 1fr;
				column-gap: 40px;
				@media (width < 550px) {
					column-gap: 20px;
				}
				> figure {
					> img {
						max-width: 100%;
						@media (width < 1020px) {
							width: 26vw;
						}
					}
				}
				> h3 {
					align-self: center;
					font-size: min(4.0rem, 7.5vw);
					line-height: 1.3;
					color: var(--color-accent);
					font-weight: 800;
					letter-spacing: 8px;
					> small {
						font-size: min(2.7rem, 6.5vw);
						@media (width < 1020px) {
							font-size: 5vw;
						}
					}
					@media (width < 1020px) {
						font-size: 5.5vw;
						letter-spacing: 4px;
					}
				}
			}
			> h4 {
				font-size: min(4.0rem, 7vw);
				line-height: 1.4;
				color: var(--color-accent);
				font-weight: 600;
				letter-spacing: 8px;
				@media (width < 1020px) {
					letter-spacing: 4px;
				}
			}
		}
	}
}
section.about {
	background-color: #faf0c8;
	padding: 50px 5% 200px 5%;
	> div {
		max-width: 700px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: 1fr auto;
		column-gap: 20px;
		@media (width < 750px) {
			grid-template-columns: 1fr;
			row-gap: 20px;
		}
		> p {
			font-size: min(1.4rem, 5.5vw);
			line-height: 2.2;
			color: #333333;
			letter-spacing: 2px;
			font-weight: 600;
		}
		> div {
			align-self: end;
			@media (width < 750px) {
				justify-self: end;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					> img {
						width: 120px;
					}
				}
			}
		}
	}
}
section.inform {
	margin-top: -80px;
	padding: 80px 5% 160px 5%;
	background-color: #fff;
	> div {
		max-width: 1200px;
		margin-inline: auto;
		padding-block: 50px;
		padding-inline: 50px;
		@media (width < 500px) {
			padding-inline: 20px;
		}
		> h2 {
			padding-bottom: 40px;
			display: flex;
			align-items: baseline;
			column-gap: 20px;
			> div {
				font-size: 3rem;
				line-height: 1;
				color: #00ac9a;
				font-weight: 700;
				font-family: var(--font-en);
			}
			> p {
				margin-top: 10px;
				font-size: 1.1rem;
				line-height: 1.3;
				color: #00ac9a;
				font-weight: 600;
				letter-spacing: 0.1em;
			}
		}
		> div#informListArea {
			margin-top: 20px;
			padding-block: 20px;
			border-top: solid 1px #ccc;
			border-bottom: solid 1px #ccc;
			> article {
				> a {
					text-decoration: none;
					display: block;
					padding-block: 15px;
					padding-right: 120px;
					background-image: url(./image/readmore.svg);
					background-repeat: no-repeat;
					background-position: 100% 50%;
					@media (width < 1300px) {
						padding-right: 90px;
						background-size: 70px;
					}
					&:hover {
						opacity: 0.7;
					}
					> dl {
						display: grid;
						grid-template-columns: 110px 110px 1fr;
						row-gap: 5px;
						@media (width < 1300px) {
							grid-template-columns: 110px 1fr;
						}
						> dt:nth-of-type(1) {
							font-size: min(1rem,5vw);
							line-height: 1.5;
							color: #222;
						}
						> dt:nth-of-type(3) {
							> ce_inform_category {
							}
						}
						> dd {
							font-size: min(1rem,4.5vw);
							line-height: 1.5;
							color: #222;
							@media (width < 1300px) {
								grid-column: 1/3;
							}
						}
					}
				}
			}
			> .empty {
				background-color: #eee;
				text-align: center;
				font-size: 0.9;
				line-height: 1.3;
				color: #888;
				padding: 20px;
			}
		}
		> div.more {
			margin-top: 20px;
			text-align: right;
			> a {
				text-decoration: underline;
				font-size: 1rem;
				line-height: 1;
				color: #05a;
				font-weight: 600;
				display: flex;
				justify-content: end;
				align-items: center;
				column-gap: 10px;
				&:hover {
					opacity: 0.7;
				}
			}
		}
		> div.link {
			margin-top: 50px;
			display: flex;
			justify-content: center;
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					background: url(./image/arrow_fff.svg)var(--color-accent);
					background-size: 16px;
					background-repeat: no-repeat;
					background-position: top 51% right 45px;
					border-radius: 10px;
					padding: 5px 80px 5px 30px;
					@media (width < 710px) {
						padding: 5px 40px 5px 20px;
						background-position: top 51% right 15px;
					}
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 2.0;
						color: #fff;
						font-weight: 500;
						letter-spacing: 3px;
					}
				}
			}
		}
	}
}
section.consultation {
	position: relative;
	z-index: 3;
	margin-top: -80px;
	padding: 120px 5% 120px 5%;
	background: url(./image/mark01.svg) #846c28;
	background-size: min(30vw, 500px);
	background-repeat: no-repeat;
	background-position: top 25% left 95%;
	border-radius: 80px;
	@media (width < 660px) {
		background-size: 45%;
		background-position: top 5% left 95%;
		border-radius: 40px;
		padding: 60px 5% 60px 5%;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			padding-bottom: 60px;
			display: flex;
			align-items: baseline;
			column-gap: 20px;
			@media (width < 540px) {
				display: block;
			}
			> div {
				font-size: min(3rem, 10vw);
				line-height: 1;
				color: #fff;
				font-weight: 800;
				font-family: var(--font-en);
			}
			> p {
				margin-top: 10px;
				font-size: 1.1rem;
				line-height: 1.3;
				color: #fff;
				font-weight: 600;
				letter-spacing: 0.1em;
			}
		}
		> div.content {
			display: grid;
			grid-template-columns: 65% auto;
			column-gap: 60px;
			@media (width < 710px) {
				grid-template-columns: 1fr;
			}
			> article {
				padding-bottom: 30px;
				> p {
					padding-bottom: 60px;
					font-size: min(1.1rem, 4vw);
					line-height: 2.0;
					color: #fff;
					font-weight: 500;
					letter-spacing: 3px;
					@media (width < 470px) {
						text-align: center;
						letter-spacing: 0.1em;
					}
				}
				> figure {
					> img {
						border-radius: 20px;
						max-width: 100%;
					}
				}
			}
			> figure {
				align-self: end;
				justify-self: end;
				@media (width < 710px) {
					display: none;
				}
				> img {
					max-width: 100%;
				}
			}
		}
		> div.link {
			display: flex;
			@media (width < 710px) {
				justify-content: end;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					background: url(./image/arrow_5a4600.svg)#fff;
					background-size: 16px;
					background-repeat: no-repeat;
					background-position: top 51% right 45px;
					border-radius: 10px;
					padding: 5px 80px 5px 30px;
					@media (width < 710px) {
						padding: 5px 40px 5px 20px;
						background-position: top 51% right 15px;
					}
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 2.0;
						color: var(--color-accent);
						font-weight: 500;
						letter-spacing: 3px;
					}
				}
			}
		}
	}
}
section.examples {
	position: relative;
	z-index: 2;
	background-color: #fff;
	margin-top: -90px;
	padding: 180px 5% 180px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.content01 {
			margin-bottom: 40px;
			display: grid;
			grid-template-columns: 1fr 1.3fr;
			column-gap: 8%;
			@media (width < 920px) {
				grid-template-columns: 1fr;
				row-gap: 60px;
			}
			> figure {
				text-align: start;
				@media (width < 920px) {
					text-align: center;
				}
				> img {
					border-radius: 20px;
					max-width: min(100%, 340px);
				}
			}
			> article {
				> h2 {
					text-align: right;
					@media (width < 920px) {
						text-align: unset;
					}
					> div {
						font-size: min(2.7rem, 9vw);
						line-height: 1.1;
						color: #333;
						font-weight: 900;
						font-family: var(--font-en);
						letter-spacing: 2px;
					}
					> p {
						margin-top: 20px;
						font-size: 1.1rem;
						line-height: 1.3;
						color: #00ac9a;
						font-weight: 600;
						letter-spacing: 0.1em;
					}
				}
				> h3 {
					margin-bottom: 25px;
					font-size: min(1.3rem, 6vw);
					line-height: 1.6;
					color: #333;
					font-weight: 800;
					letter-spacing: 0.1em;
					text-indent: -0.7rem;
  					padding-left: 0.7rem;
					&:nth-of-type(1) {
						margin-top: 40px;
					}
					&:nth-of-type(2) {
						margin-bottom: 0px;
						text-indent: -0.8rem;
  						padding-left: 0.8rem;
					}
				}
				> p {
					margin-bottom: 25px;
					font-size: min(1.0rem, 5vw);
					line-height: 1.8;
					color: #333;
					font-weight: 600;
					letter-spacing: 0.1em;
				}
			}
		}
		> div.link01 {
			display: flex;
			justify-content: end;
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					background: url(./image/arrow_fff.svg)var(--color-accent);
					background-size: 16px;
					background-repeat: no-repeat;
					background-position: top 51% right 25px;
					border-radius: 10px;
					padding: 5px 60px 5px 30px;
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 2.0;
						color: #fff;
						font-weight: 500;
						letter-spacing: 3px;
					}
				}
			}
		}
		> div.content02 {
			margin-top: 150px;
			margin-bottom: 40px;
			display: grid;
			grid-template-columns: 1fr 1.2fr;
			column-gap: 8%;
			@media (width < 920px) {
				grid-template-columns: 1fr;
				row-gap: 60px;
			}
			> figure {
				text-align: center;
				> img {
					border-radius: 20px;
					max-width: 100%;
					@media (width < 920px) {
						max-width: min(100%, 500px);
					}
				}
			}
			> article {
				> h4 {
					font-size: min(2.2rem, 7vw);
					line-height: 1.1;
					color: var(--color-accent);
					font-weight: 900;
					font-family: var(--font-en);
					letter-spacing: 4px;
				}
				> p {
					text-align: justify;
					margin-top: 25px;
					font-size: min(1.0rem, 5vw);
					line-height: 2.2;
					color: #333;
					font-weight: 600;
					letter-spacing: 0.1em;
				}
			}
		}
		> div.link02 {
			display: flex;
			justify-content: end;
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					background: url(./image/arrow_fff.svg)var(--color-accent);
					background-size: 16px;
					background-repeat: no-repeat;
					background-position: top 51% right 30px;
					border-radius: 10px;
					padding: 5px 60px 5px 30px;
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 2.0;
						color: #fff;
						font-weight: 500;
						letter-spacing: 3px;
					}
				}
			}
		}
	}
}
section.tech {
	position: relative;
	z-index: 3;
	margin-top: -80px;
	padding: 100px 5% 100px 5%;
	background: url(./image/mark02.svg) #faf0c8;
	background-size: min(30vw, 500px);
	background-repeat: no-repeat;
	background-position: top 0% left 100%;
	border-radius: 80px 80px 0px 0px;
	@media (width < 700px) {
		background-size: 45%;
		background-position: top 0% left 100%;
		border-radius: 40px;
		padding: 60px 5% 60px 5%;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			padding-bottom: 40px;
			display: flex;
			align-items: baseline;
			column-gap: 20px;
			@media (width < 540px) {
				display: block;
			}
			> div {
				font-size: min(3rem, 10vw);
				line-height: 1;
				color: var(--color-accent);
				font-weight: 800;
				font-family: var(--font-en);
			}
			> p {
				margin-top: 10px;
				font-size: 1.1rem;
				line-height: 1.3;
				color: var(--color-accent);
				font-weight: 600;
				letter-spacing: 0.1em;
			}
		}
		> h3 {
			font-size: min(4rem, 9vw);
			line-height: 1.6;
			color: var(--color-accent);
			font-weight: 800;
			font-family: var(--font-en);
			letter-spacing: 4px;
			> span {
				> small {
					font-size: min(1.6rem, 6.5vw);
					padding-inline: 10px;
				}
			}
		}
		> p {
			text-align: justify;
			margin-top: 40px;
			font-size: min(1.1rem, 5vw);
			line-height: 2.2;
			color: #333;
			font-weight: 800;
			letter-spacing: 2px;
		}
	}
}
section.links {
	background-color: #fff;
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		column-gap: 30px;
		@media (width < 650px) {
			grid-template-columns: repeat(3, 1fr);
			row-gap: 30px;
		}
		@media (width < 500px) {
			grid-template-columns: repeat(1, 1fr);
			row-gap: 30px;
		}
		> article {
			display: grid;
			justify-content: center;
			@media (width < 650px) {
				grid-area: 1/1/2/4;
			}
			@media (width < 500px) {
				grid-area: unset;
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
			> p {
				padding-top: 10px;
				text-align: center;
				font-size: min(1.2rem, 5vw);
				line-height: 1.0;
				color: #333;
				font-weight: 800;
				letter-spacing: 0.1em;
			}
		}
		> a {
			text-decoration: none;
			align-self: center;
			&:hover {
				opacity: 0.8;
			}
			> figure {
				text-align: center;
				> img {
					max-width: 100%;
					@media (width < 500px) {
						width: 200px;
					}
				}
			}
		}
	}
}
