section.movie {
	background-color: #eee;
	overflow: hidden;
	max-height: 1257px;
	&.off {
		max-height: 0;
	}
	> div {
		max-width: 1920px;
		margin-inline: auto;
		> video {
			max-width: 100%;
			display: block;
		}
	}
}
section.switchpanel {
	background-color: #555;
	overflow: hidden;
	max-height: 1400px;
	&.off {
		max-height: 0;
	}
	> div {
		max-width: 1920px;
		margin-inline: auto;
		overflow: hidden;
		> #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: end;
					align-self: end;
					display: flex;
					justify-content: center;
					align-items: center;
					column-gap: 5px;
					padding: 0 20px 17px 0;
					@media (width < 670px) {
						column-gap: 3px;
						padding: 0 4px 4px 0;
						justify-self: center;
						> 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 {
					> div.pc {
						display: grid;
						@media (width < 670px) {
							display: none;
						}
						> picture {
							grid-area: 1/1/2/2;
							> img {
								width: 100%;
							}
						}
						> a {
							grid-area: 1/1/2/2;
							text-decoration: none;
							&:hover {
								opacity: 0.7;
							}
							> img {
							}
						}
					}
					> div.sp {
						display: none;
						@media (width < 670px) {
							display: grid;
						}
						> picture {
							grid-area: 1/1/2/2;
							> img {
								width: 100%;
							}
						}
						> a {
							grid-area: 1/1/2/2;
							text-decoration: none;
							&:hover {
								opacity: 0.7;
							}
							> img {
							}
						}
					}
				}
			}
		}
		> #switchPanelThums {
			padding: 0 5px 10px 5px;
			display: flex;
			justify-content: center;
			user-select: none;
			overflow-x: auto;
			/* パネルの枚数で調整。JavaScriptで制御に切り替えた
			@media (width < calc(6 * 150px + 10px)) {
				justify-content: left;
			}
			*/
			> div {
				width: 150px;
				min-width: 150px;
				&.on {
					> div {
						opacity: 1;
					}
					> img {
						border: solid 2px #fff;
					}
				}
				> div {
					opacity: 0;
					> img {
						display: block;
						margin-inline: auto;
						@media (width < 700px) {
							width: min(30px,4vw);
						}
					}
				}
				> img {
					border: solid 2px #333;
					width: 100%;
					cursor: pointer;
				}
			}
		}
	}
}
section.fujico {
	background-color: #fff;
	> div {
		display: grid;
		> div {
			grid-area: 1/1/2/2;
		}
		> div.bg {
			@media (width < 900px) {
				display: none;
			}
			> figure {
				> img {
					max-height: 600px;
					width: 60%;
					object-fit: cover;
					object-position: 0% 0%;
					@media (width < 900px) {
						width: 100vw;
						height: 100%;
						max-height: unset;
					}
				}
			}
		}
		> div.content {
			display: grid;
			grid-template-columns: 1fr 1fr;
			padding: 50px 0% 50px 10%;
			align-self: center;
			@media (width < 1000px) {
				padding: 50px 0% 50px 5%;
			}
			@media (width < 900px) {
				grid-template-columns: 1fr;
				padding: 30px 5% 30px 5%;
				row-gap: 30px;
				background: url(./image/item01_bg01.webp);
				background-size: calc(100% + (250px - 25vw)) 100%;
				background-repeat: no-repeat;
				background-position: 0 0;
			}
			> article {
				padding-right: 30px;
				max-width: 800px;
				margin-inline: auto 0;
				@media (width < 900px) {
					margin-inline: auto;
					padding-right: 0px;
				}
				> h3 {
					font-size: min(2.0rem, 7vw);
					line-height: 1.4;
					color: #fff;
					font-weight: 600;
					letter-spacing: 4px;
				}
				> h4 {
					margin-top: 20px;
					font-size: min(1.0rem, 5vw);
					line-height: 1.4;
					font-weight: 600;
					color: #ffff00;
				}
				> p {
					margin-block: 20px 8%;
					font-size: min(1.0rem, 5vw);
					line-height: 2.2;
					font-weight: 600;
					color: #fff;
					text-align: justify;
				}
				> a {
					text-decoration: underline;
					color: #fff;
					font-size: min(1.0rem, 5vw);
					font-weight: 600;
					&:hover {
						opacity: 0.8;
					}
				}
			}
			> figure {
				max-width: 700px;
				margin-inline: 0 auto;
				text-align: center;
				@media (width < 900px) {
					margin-inline: auto;
				}
				> img {
					box-shadow: 20px 20px 0 rgba(0, 0, 0, 0.4);
					max-width: 100%;
				}
			}
		}
	}
}
section.future {
	background-color: #000;
	@media (width < 900px) {
		background: url(./image/item02_bg.webp);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: 0 0;
	}
	> div {
		display: grid;
		> div {
			grid-area: 1/1/2/2;
		}
		> div.bg {
			@media (width < 900px) {
				display: none;
			}
			> figure {
				> img {
					max-height: 700px;
					width: 100%;
					object-fit: cover;
					object-position: center center;
					@media (width < 900px) {
						width: 100vw;
						height: 100%;
						max-height: unset;
					}
				}
			}
		}
		> div.content {
			display: grid;
			grid-template-columns: 1fr 1fr;
			padding: 50px 10% 50px 0%;
			align-self: center;
			@media (width < 1000px) {
				padding: 50px 5% 50px 0%;
			}
			@media (width < 900px) {
				grid-template-columns: 1fr;
				padding: 30px 5% 30px 5%;
				row-gap: 30px;
			}
			> article {
				padding-left: 30px;
				align-self: center;
				max-width: 800px;
				margin-inline: 0 auto;
				@media (width < 900px) {
					margin-inline: auto;
					order: 1;
					padding-left: 0px;
				}
				> h3 {
					font-size: min(2.0rem, 7vw);
					line-height: 1.4;
					color: #fff;
					font-weight: 600;
					letter-spacing: 4px;
				}
				> h4 {
					margin-top: 20px;
					font-size: min(1.0rem, 5vw);
					line-height: 1.4;
					font-weight: 600;
					color: #ffff00;
				}
				> p {
					margin-block: 20px 8%;
					font-size: min(1.0rem, 5vw);
					line-height: 2.2;
					font-weight: 600;
					color: #fff;
					text-align: justify;
				}
			}
			> figure {
				max-width: 700px;
				margin-inline: auto 0;
				text-align: center;
				@media (width < 900px) {
					margin-inline: auto;
					order: 2;
				}
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.block_links01 {
	background: url(./image/item03_bg.svg);
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: 0 0;
	padding: 100px 5% 50px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div {
			margin-bottom: 40px;
			display: grid;
			grid-template-columns: 1fr 1fr;
			column-gap: 60px;
			@media (width < 900px) {
				grid-template-columns: 1fr;
				row-gap: 40px;
			}
			> article {
				> h3 {
					font-size: min(2.0rem, 7vw);
					line-height: 1.4;
					color: #222;
					font-weight: 600;
					letter-spacing: 4px;
				}
				> p {
					font-size: min(1.0rem, 5vw);
					line-height: 1.4;
					font-weight: 600;
					color: var(--color-accent2);
				}
				> figure {
					margin-top: 30px;
					> img {
						max-width: 100%;
					}
				}
				> a {
					display: flex;
					justify-content: center;
					margin-top: 30px;
					text-decoration: none;
					&:hover {
						opacity: 0.7;
					}
					> div {
						border: 1px solid #002060;
						padding: 20px 100px;
						background: url(./image/link_002060.svg), #fff;
						background-size: 15px;
						background-repeat: no-repeat;
						background-position: calc(100% - 10px) 50%;
						@media (width < 900px) {
							padding: 20px 80px;
						}
						> p {
							color: #002060;
							font-size: min(1.1rem, 5vw);
							line-height: 1.4;
							font-weight: 600;
						}
					}
				}
			}
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> div {
				display: grid;
				> figure {
					grid-area: 1/1/2/2;
					> img {
						height: 120px;
						max-width: 100%;
						object-fit: cover;
						object-position: 50% 50%;
					}
				}
				> p {
					padding-inline: 60px;
					background-image: url(./image/link.svg);
					background-position: calc(100% - 20px) 50%;
					background-repeat: no-repeat;
					background-size: 40px;
					align-self: center;
					grid-area: 1/1/2/2;
					text-align: center;
					font-size: min(2.0rem, 6vw);
					color: #fff;
					font-weight: 700;
					line-height: 1.4;
					@media (width < 560px) {
						padding-inline: 30px;
						background-position: calc(100% - 5px) 50%;
						background-repeat: no-repeat;
						background-size: 30px;
						line-height: 1.6;
					}
				}
			}
		}
	}
}
section.block_links02 {
	background: url(./image/item03_bg01.webp), url(./image/item03_bg02.webp);
	background-size: 60% 100%, 40% 100%;
	background-repeat: no-repeat;
	background-position: 0 0, 100% 0;
	@media (width < 1020px) {
		background: url(./image/item03_bg01.webp);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: 0 0;
	}
	> div {
		padding-inline: 5%;
		> div {
			padding-block: 80px;
			max-width: 1000px;
			margin-inline: auto;
			display: grid;
			grid-template-columns: 1fr 1fr 1fr;
			column-gap: 30px;
			@media (width < 1020px) {
				grid-template-columns: 1fr;
				row-gap: 50px;
			}
			> article {
				> h3 {
					font-size: min(2.0rem, 7vw);
					line-height: 1.4;
					color: #222;
					font-weight: 600;
					letter-spacing: 4px;
				}
				> p {
					font-size: min(1.0rem, 5vw);
					line-height: 1.4;
					font-weight: 600;
					color: var(--color-accent2);
				}
				> figure {
					text-align: center;
					> img {
						max-width: 100%;
					}
				}
				> a {
					display: grid;
					justify-self: center;
					margin-top: 30px;
					text-decoration: none;
					@media (width < 1020px) {
						min-width: 290px;
						
					}
					&:hover {
						opacity: 0.7;
					}
					> div {
						border-radius: 30px;
						border: 1px solid var(--color-accent2);
						padding: 15px 80px;
						background: url(./image/link_0068b7.svg), #fff;
						background-size: 20px;
						background-repeat: no-repeat;
						background-position: calc(100% - 20px) 50%;
						@media (width < 980px) {
							padding: 20px 60px;
						}
						> p {
							text-align: center;
							color: var(--color-accent2);
							font-size: min(1.1rem, 5vw);
							line-height: 1.4;
							font-weight: 600;
						}
					}
				}
			}
		}
	}
}
section.inform {
	padding: 60px 5% 100px 5%;
	background-image: url(./image/inform_back01.webp);
	background-size: 60% 100%;
	background-repeat: no-repeat;
	background-position: left top;
	padding-block: 80px;
	> div {
		max-width: 1200px;
		margin-inline: auto;
		background-image: url(./image/inform_back02.webp);
		background-repeat: no-repeat;
		background-position: 50% 50%;
		box-shadow: 20px 20px 0 rgba(0,0,0,0.4);
		padding-block: 50px;
		padding-inline: 50px;
		@media (width < 500px) {
			box-shadow: 8px 8px 0 rgba(0,0,0,0.4);
			padding-inline: 20px;
		}
		> h2 {
			> div {
				font-size: 2rem;
				line-height: 1;
				color: #000;
				font-weight: 600;
			}
			> p {
				margin-top: 10px;
				font-size: 1rem;
				line-height: 1;
				color: #05a;
				font-weight: 600;
			}
		}
		> 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: 10px;
					&:hover {
						opacity: 0.7;
					}
					> dl {
						display: grid;
						grid-template-columns: 120px 1fr;
						@media (width < 1300px) {
							grid-template-columns: 1fr;
						}
						> dt {
							font-size: min(1rem,5vw);
							line-height: 1.5;
							color: #aaa;
						}
						> dd {
							font-size: min(1rem,5vw);
							line-height: 1.5;
							color: #222;
						}
					}
				}
			}
			> .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;
				}
			}
		}
	}
}
