section.panel {
	> div {
		max-width: 1920px;
		margin-inline: auto;
		display: grid;
		> picture {
			grid-area: 1/1/2/2;
			> img {
				max-width: 100%;
			}
		}
	}
}
section.title {
	padding: 60px 5% 0 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h1 {
			font-size: 2.0rem;
			line-height: 1.5;
			color: #db4f4a;
			text-align: center;
			font-weight: 600;
		}
		> p {
			font-size: 1.2rem;
			line-height: 1.0;
			color: #db4f4a;
			text-align: center;
			font-weight: 600;
		}
	}
}
section.category {
	padding: 40px 5% 0 5%;
	> div {
		max-width: 890px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: 38px 1fr 38px;
		column-gap: 15px;
		@media (width < 500px) {
			grid-template-columns: 18px 1fr 18px;
			column-gap: 10px;
		}
		> div.arrow {
			display: flex;
			align-items: center;
			cursor: pointer;
			padding-block: 5px;
			padding-inline: 10px;
			user-select: none;
			@media (width > 1000px) {
				visibility: hidden;
			}
			@media (width < 500px) {
				padding-inline: 0px;
			}
			&:hover {
				background-color: rgba(219,79,74,0.2);
			}
			> img {}
		}
		> div.category {
			display: flex;
			overflow-x: auto;
			scrollbar-color: #db4f4a #eee;
			scrollbar-width: thin;
			scroll-behavior: smooth;
			> label {
				justify-self: center;
				display: grid;
				cursor: pointer;
				user-select: none;
				width: 260px;
				min-width: 260px;
				@media (width < 900px) {
					width: 30vw;
					max-width: 30vw;
					min-width: 30vw;
				}
				@media (width < 500px) {
					width: 40vw;
					max-width: 40vw;
					min-width: 40vw;
				}
				> input[type="radio"] {
					display: none;
					&:checked + div.circle {
						display: block;
					}
				}
				> div.circle {
					display: none;
					grid-area: 1/1/2/2;
					background-color: rgba(219,79,74, 0.3);
					width: 210px;
					height: 210px;
					border-radius: 200px;
					justify-self: center;
					align-self: center;
					@media (width < 900px) {
						width: 90%;
						height: auto;
						aspect-ratio: 1/1;
					}
				}
				> figure {
					grid-area: 1/1/2/2;
					padding-top: 10px;
					display: flex;
					justify-content: center;
					max-width: 250px;
					margin-inline: auto;
					@media (width < 900px) {
						max-width: 30vw;
					}
					@media (width < 500px) {
						max-width: 40vw;
					}
					> img {
						max-width: 100%;
					}
				}
				> div.text {
					grid-area: 1/1/2/2;
					justify-items: center;
					margin-top: 60%;
					display: flex;
					align-self: center;
					justify-content: center;
					> h3 {
						align-self: start;
						background-color: #d9514f;
						color: #fff;
						font-size: min(1.0rem,5vw);
						padding-inline: 10px;
						white-space: nowrap;
						@media (width < 900px) {
							font-size: 0.8rem;
						}
					}
					> p {
						font-size: 1.1rem;
						color: #333;
						white-space: nowrap;
						background-color: rgba(255,255,255,0.6);
						padding-inline: 5px;
						@media (width < 900px) {
							font-size: 0.8rem;
						}
					}
				}
			}
		}
	}
}
section.type {
	padding: 60px 5% 60px 5%;
	&.hidden {
		display: none;
	}
	> div {
		max-width: 1600px;
		margin-inline: auto;
		> h2 {
			background-color: #db4f4a;
			padding-block: 10px;
			padding-inline: 20px;
			color: #fff;
			font-size: 1.5rem;
			line-height: 1.4;
			> b {	/*type名*/
				font-size: 2.0rem;
				font-weight: 900;
				font-style: italic;
				white-space: nowrap;
				> small {
					padding-left: 5px;
					font-size: 1.3rem;
					font-weight: 500;
				}
			}
		}
		> figure {
			padding-top: 60px;
			display: flex;
			justify-content: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			font-size: min(1.8rem,7vw);
			line-height: 1.3;
			color: #333;
			border-bottom: 3px solid #db4f4a;
			padding-top: 40px;
			margin-bottom: 20px;
			padding-bottom: 10px;
			> small {
				font-size: min(1.4rem,5.5vw);
			}
			> div {
				display: flex;
				column-gap: 5px;
				font-size: 1.3rem;
				@media (width < 800px) {
					flex-direction: column;
					margin-top: 5px;
					font-size: min(0.9rem,5vw);
				}
			}
		}
		> p {
			font-size: min(1.0rem,5vw);
			line-height: 1.5;
			color: #333;
		}
		> div.figure {
			padding-top: 40px;
			display: flex;
			flex-wrap: wrap;
			justify-content: center;
			> figure {
				display: flex;
				flex-direction: column;
				justify-content: center;
				align-items: center;
				max-width: 300px;
				@media (width < 1000px) {
					max-width: 200px;
				}
				@media (width < 500px) {
					max-width: 160px;
				}
				> figcaption {
					font-size: min(1.0rem, 5vw);
					line-height: 1.3;
					color: #333;
					text-align: center;
				}
				> img {
					margin-top: 5px;
					max-width: 100%;
				}
			}
		}
		> div.option {
			padding-top: 60px;
			display: grid;
			grid-template-columns: 1.2fr 1fr;
			column-gap: 40px;
			@media (width < 830px) {
			   grid-template-columns: 1fr;
			   row-gap: 20px;
			}
			> div.content {
				> h3 {
					background-color: #adadad;
					padding: 15px 30px;
					font-size: 1.3rem;
					line-height: 1.0;
					color: #fff;
					margin-bottom: 30px;
				}
				> p {
					text-indent: -1em;
					padding-left: 1em;
					font-size: min(1.0rem, 5vw);
					line-height: 1.5;
					color: #333;
				}
			}
			> figure {
				align-self: center;
				justify-self: end;
				padding: 40px;
				border: 3px solid #ccc;
				> img {
					max-width: 100%;
				}
			}
		}
		> div.table {
			> div.scrolltable {
				max-width: 90vw;
				&.on {
					> div.guidance {
						display: block;
					}
				}
				> div.guidance {
					display: none;
					background-color: #ddd;
					font-size: 0.9rem;
					line-height: 1;
					color: #777;
					border-radius: 50px;
					padding-block: 3px;
					padding-inline: 10px;
				}
				> div.table {
					overflow: auto;
					> table {
						margin-top: 3px;
						width: 100%;
						height: 100%;
						border-collapse: collapse;
						> thead {
							> tr {
								> th {
									padding-block: 10px;
									padding-inline: 5px;
									background-color: #db4f4a;
									color: #fff;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									font-weight: 400;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(255,255,255,0.5);
									&.on {
										background-color: #7483bc;
										color: #fff;
									}
								}
							}
						}
						> tbody {
							> tr {
								&.textleft {
									> td {
										text-align: left;
									}
								}
								> th {
									padding-block: 5px;
									padding-inline: 5px;
									background-color: #f2c1c0;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									font-weight: 400;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(255,255,255,0.5);
									> img {
										width: 60px;
									}
									&:nth-of-type(1) {
										background-color: #eda7a5;
									}
									&.notfirst {
										background-color: #f2c1c0;
									}
								}
								> td {
									padding-block: 5px;
									padding-inline: 5px;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(0,0,0,0.2);
									&:nth-of-type(odd) {
										background-color: #fae5e4;
									}
								}
							}
						}
					}
				}
			}
		}
	}
}
section.composition {
	padding: 60px 5% 60px 5%;
	&.hidden {
		display: none;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.8rem;
			line-height: 1.3;
			color: #333;
			border-bottom: 3px solid #d9514f;
			margin-bottom: 20px;
			padding-bottom: 10px;
			> small {
				font-size: min(0.9rem, 4.5vw);
			}
		}
		> h3 {
			font-size: min(1.2rem,5vw);
			line-height: 1.3;
			color: #333;
			> i {
				font-style: normal;
				color: #eba6a5;
				padding-right: 3px;
			}
		}
		> h4 {
			font-size: min(1.5rem,7vw);
			line-height: 1.3;
			color: #333;
			text-align: center;
		}
		> figure {
			max-width: 800px;
			margin-inline: auto;
			padding-block: 40px;
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> p {
			margin-block: 3px;
			max-width: 800px;
			margin-inline: auto;
			font-size: min(1rem,5vw);
			line-height: 1.2;
			color: #333;
		}
		> div.table {	
			max-width: 800px;
			margin-inline: auto;
			> div.scrolltable {
				max-width: 90vw;
				&.on {
					> div.guidance {
						display: block;
					}
				}
				> div.guidance {
					display: none;
					background-color: #ddd;
					font-size: 0.9rem;
					line-height: 1;
					color: #777;
					border-radius: 50px;
					padding-block: 3px;
					padding-inline: 10px;
				}
				> div.table {
					overflow: auto;
					> table {
						margin-top: 3px;
						width: 100%;
						height: 100%;
						border-collapse: collapse;
						> thead {
							> tr {
								> th {
									padding-block: 5px;
									padding-inline: 10px;
									background-color: #eda7a5;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									font-weight: normal;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(0,0,0,0.2);
								}
							}
						}
						> tbody {
							> tr {
								&:nth-of-type(odd) {
									> td {
										background-color: #fae5e4;
									}
								}
								> th {
									padding-block: 5px;
									padding-inline: 10px;
									background-color: #eda7a5;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									font-weight: normal;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(0,0,0,0.2);
								}
								> td {
									padding-block: 10px;
									padding-inline: 5px;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.6;
									text-align: left;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(0,0,0,0.2);
									background-color: #fff;
								}
							}
						}
					}
				}
			}
		}
	}
}
section.specification {
	padding: 60px 5% 60px 5%;
	background-color: #fdf6f6;
	&.hidden {
		display: none;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.title {
			background: url(./image/title_bg.svg) 75% / cover;
			min-height: 85px;
			display: flex;
			justify-content: center;
			align-items: center;
			> h2 {
				text-align: center;
				font-size: min(2.2rem, 7vw);
				line-height: 1;
				color: #fff;
			}
		}
		> article {
			padding-top: min(80px,12vw);
			display: grid;
			grid-template-columns: 1fr;
			column-gap: 40px;
			&.flex {
				grid-template-columns: 1fr 240px;
				@media (width < 610px) {
					grid-template-columns: 1fr;
					row-gap: 30px;
				}
			}
			> div.title {
				> div.point {
					display: grid;
					grid-template-columns: 30px 1fr;
					column-gap: 10px;
					> img {
						width: 30px;
					}
					> h3 {
						align-self: center;
						font-size: 1.3rem;
						line-height: 1;
						color: #db4f4a;
					}
				}
				> p {
					padding-top: 10px;
					font-size: min(1.0rem,5vw);
					line-height: 1.6;
					color: #333;
					text-align: justify;
					> span {
						color: #ff7d31;
					}
					> small {
						padding-top: 10px;
						font-size: 0.9rem;
					}
				}
				> picture {
					text-align: center;
					> img {
						width: 100%;
						padding-top: 10px;
						max-width: 100%;
					}
				}
			}
			> div.content {
				padding-top: 10px;
				> h4 {
					display: inline-block;
					color: #fff;
					font-size: min(1.2rem,5.5vw);
					line-height: 1.6;
					padding-inline: 10px;
					&:nth-of-type(1) {
						background-color: #db4f2e;
					}
					&:nth-of-type(2) {
						background-color: #afc347;
					}
					&:nth-of-type(3) {
						background-color: #5f9ecf;
					}
				}
				> p {
					padding-block: 5px 30px;
					font-size: min(1.0rem,5vw);
					line-height: 1.6;
					color: #333;
					text-align: justify;
				}
			}
			> div.fan {
				margin-top: 10px;
				display: grid;
				grid-template-columns: 1fr 1fr;
				max-width: 600px;
				margin-inline: auto;
				column-gap: 50px;
				row-gap: 30px;
				@media (width < 630px) {
					grid-template-columns: 1fr;
				}
				> div {
					> figure {
						@media (width < 630px) {
						   padding-inline: 10%;
						}
						> img {
							max-width: 100%;
						}
					}
					> p {
						font-size: min(1.0rem,5vw);
						line-height: 1.6;
						color: #333;
						text-align: justify;
					}
				}
			}
			> div.block {
				display: grid;
				grid-template-columns: 3fr 1.4fr;
				column-gap: 40px;
				@media (width < 700px) {
					grid-template-columns: 1fr;
					row-gap: 30px;
				}
				> div {
					> h4 {
						color: #db4f4a;
						font-size: min(1.3rem,5.5vw);
						line-height: 1.8;
					}
					> figure {
						padding-bottom: 10px;
						text-align: center;
						> img {
							max-width: 100%;
						}
					}
					> p {
						color: #333;
						font-size: min(1.0rem,5vw);
						line-height: 1.8;
						text-indent: -1em;
						padding-left: 1em;
						> span {
							color: #e50012;
							font-size: min(1.3rem,5.5vw);
							border-bottom: 1px solid #e50012;
						}
					}
					&:nth-of-type(1) {
						padding-top: 30px;
					}
					&:nth-of-type(2) {
						padding: 20px;
						background-color: #fff;
						border-radius: 5px;
						border: 1px solid #db4f4a;
						@media (width < 700px) {
							display: grid;
							grid-template-columns: 1fr 3fr;
							column-gap: 10px;
						}
						@media (width < 510px) {
							grid-template-columns: 1.5fr 3fr;
						}
						> div {
							@media (width < 700px) {
								display: grid;
							}
							> p {
								color: #333;
								font-size: min(1.0rem,5vw);
								line-height: 1.8;
								@media (width < 700px) {
									 font-size: min(1.4rem,5.5vw);
								}
							}
							> figure {
								justify-self: end;
								align-self: end;
								> img {
									display: none;
									@media (width < 700px) {
									   display: block;
									}
								}
							}
						}
					}
				}
			}
			> figure {
				margin-top: 10px;
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.order {
	padding: min(100px,15vw) 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> div {
				border-radius: 5px;
				display: grid;
				@media (width < 670px) {
					background: url(./image/link_bg.webp) 50% / cover;
					min-height: 170px;
				}
				> figure {
					grid-area: 1/1/2/2;
					@media (width < 670px) {
						display: none;
					}
					> img {
						border-radius: 5px;
						max-width: 100%;
					}
				}
				> div {
					grid-area: 1/1/2/2;
					display: grid;
					grid-template-columns: auto 1fr;
					column-gap: 30px;
					@media (width < 530px) {
						grid-template-columns: auto 40px;
					}
					@media (width < 450px) {
						grid-template-columns: 1fr;
						background-image: url(./image/link_mark.svg);
						background-position: 95% 50%;
						background-size: 20px;
						background-repeat: no-repeat;
					}
					> div.text {
						padding-left: 50px;
						align-content: center;
						@media (width < 820px) {
							padding-inline: 5vw;
							padding-block: 10px;
						}
						> h2 {
							padding-bottom: 10px;
							font-size: 2.2rem;
							line-height: 1;
							color: #fff;
							letter-spacing: 3px;
							@media (width < 450px) {
								line-height: 1.3;
							}
						}
						> p {
							font-size: min(1.0rem,5vw);
							line-height: 1.6;
							color: #fff;
						}
					}
					> figure {
						align-content: center;
						@media (width < 450px) {
							display: none;
						}
						> img {
							max-width: 100%;
						}
					}
				}
			}
		}
		> h3 {
			margin-top: 20px;
			text-align: center;
			font-size: 1.4rem;
			line-height: 1.3;
			color: #333;
		}
	}
}
section.bottom {
	padding-top: min(120px,17vw);
	border-bottom: solid 1px #f66;
}
