section.panel {
	> div {
		max-width: 1920px;
		margin-inline: auto;
		display: grid;
		> picture {
			grid-area: 1/1/2/2;
			> img {
				max-width: 100%;
			}
		}
		> div {
			grid-area: 1/1/2/2;
			justify-self: start;
			align-self: end;
			margin-left: 10.4%;
			margin-bottom: 7%;
			width: 25%;
			@media (width < 700px) {
				margin-left: 10%;
				margin-bottom: 6%;
				width: 80%;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					> 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: #7484c1;
			text-align: center;
			font-weight: 600;
		}
		> p {
			font-size: 1.2rem;
			line-height: 1.0;
			color: #7484c1;
			text-align: center;
			font-weight: 600;
		}
	}
}
section.category {
	padding: 40px 5% 0 5%;
	> div {
		max-width: 800px;
		margin-inline: auto;
		> div.category {
			display: flex;
			> label {
				justify-self: center;
				display: grid;
				cursor: pointer;
				user-select: none;
				width: 400px;
				min-width: 400px;
				@media (width < 900px) {
					width: 40vw;
					max-width: 45vw;
					min-width: 45vw;
				}
				> input[type="radio"] {
					display: none;
					&:checked + div.circle {
						display: block;
					}
				}
				> div.circle {
					display: none;
					grid-area: 1/1/2/2;
					background-color: rgba(116, 132, 193, 0.3);
					width: 210px;
					height: 210px;
					border-radius: 200px;
					justify-self: center;
					@media (width < 900px) {
						width: 30vw;
						height: 30vw;
					}
				}
				> 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;
					}
					> 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 {
						background-color: #7484c1;
						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;
	}
	&[data-type="table"] {
		> div {
			background-image: url(./image/type02_bg.webp);
			background-repeat: no-repeat;
			background-position: 100% 60px;
			background-size: min(508px,50%);
		}
	}
	> div {
		max-width: 1600px;
		margin-inline: auto;
		> h2 {
			background-color: #7484c1;
			color: #fff;
			font-size: min(2.2rem,8vw);
			padding-block: 10px;
			padding-inline: 20px;
			font-style: italic;
			font-weight: 600;
			> small {
				font-size: min(1.1rem,5vw);
			}
		}
		> 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 #7484c1;
			margin-bottom: 20px;
			padding-bottom: 10px;
			> small {
				font-size: min(1.4rem,5.5vw);
			}
		}
		> p {
			font-size: min(1.0rem,5vw);
			line-height: 1.5;
			color: #333;
		}
		> h4 {
			margin-top: 10px;
			font-size: 1.2rem;
			line-height: 1.5;
			color: #7484c1;
			@media (width < 700px) {
				font-size: min(0.9rem,4.5vw);
			}
		}
		> 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: #9da9d4;
									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);
									&.on {
										background-color: #7483bc;
										color: #fff;
									}
								}
							}
						}
						> tbody {
							> tr {
								> th {
									padding-block: 5px;
									padding-inline: 5px;
									background-color: #cdd3e7;
									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);
								}
								> 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);
									&[data-td="100"],
									&[data-td="101"],
									&[data-td="118"],
									&[data-td="108"],
									&[data-td="103"],
									&[data-td="114b"],
									&[data-td="114d"],
									&[data-td="115at"],
									&[data-td="120"],
									&[data-td="tk90"],
									&[data-td="tk150"],
									&[data-td="tr75"],
									&[data-td="tr120"],
									&[data-td="tr180"] {
										background-color: #e9ecf5;
									}
								}
							}
						}
					}
				}
			}
		}
		> div.note {
			display: flex;
			justify-content: space-between;
			@media (width < 960px) {
				flex-direction: column;
			}
			> p {
				padding-top: 10px;
				font-size: 0.9rem;
				line-height: 1.5;
				color: #333;
				text-indent: -1em;
				padding-left: 1em;
			}
			> div.notice {
				margin-top: 10px;
				border: 1px solid #d00;
				border-radius: 5px;
				display: flex;
				justify-self: end;
				> p {
					padding: 5px 10px;
					font-size: min(1.0rem,5vw);
					line-height: 1.2;
					color: #d00;
				}
			}
		}
		> div.notice {
			margin-top: 10px;
			display: flex;
			justify-content: end;
			> p {
				border: 1px solid #d00;
				border-radius: 5px;
				padding: 5px 10px;
				font-size: min(1.0rem,5vw);
				line-height: 1.2;
				color: #d00;
			}
		}
	}
}
section.model {
	padding: 60px 5% 60px 5%;
	background-color: #f1f3f8;
	&.hidden {
		display: none;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			background-color: #7484c1;
			padding-block: 8px;
			padding-inline: 20px;
			color: #fff;
			font-size: 1.5rem;
			line-height: 1.4;
			> b {	/*model名*/
				font-size: 2.0rem;
				font-weight: 900;
				font-style: italic;
				white-space: nowrap;
				> small {
					padding-left: 5px;
					font-size: 1.3rem;
					font-weight: 500;
				}
			}
		}
		> picture.pc {
			display: block;
			padding-block: 40px;
			text-align: center;
			max-width: 80%;
			margin-inline: auto;
			&:empty {
				padding-block: 10px;
			}
			> img {
				max-width: 100%;
			}
			> figcaption {
				text-align: left;
				color: #222;
				font-size: min(0.9rem, 4.5vw);
				line-height: 1.3;
			}
		}
		> picture.sp {
			display: block;
			padding-block: 0 40px;
			text-align: center;
			max-width: 80%;
			margin-inline: auto;
			&:empty {
				padding-block: 10px;
			}
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			font-size: 1.6rem;
			line-height: 1.3;
			color: #333;
			border-bottom: 3px solid #7484c1;
			padding-bottom: 10px;
			> small {
				font-size: min(0.9rem, 4.5vw);
			}
		}
		> div.table {
			margin-top: 20px;
			max-width: 100%;
			> 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: 10px;
									background-color: #211a61;
									color: #fff;
									font-size: min(1rem,5vw);
									line-height: 1.6;
									font-weight: normal;
									text-align: center;
									white-space: nowrap;
									border: solid 1px #211a61;
								}
							}
						}
						> tbody {
							> tr {
								&:nth-of-type(odd) {
									> td {
										background-color: #dcdbe7;
									}
								}
								> th {
									padding-block: 10px;
									padding-inline: 10px;
									background-color: #8c88ad;
									color: #fff;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.4;
									font-weight: normal;
									text-align: center;
									white-space: nowrap;
									border: solid 1px rgba(255,255,255,0.5);
								}
								> td {
									padding-block: 5px;
									padding-inline: 10px;
									color: #222;
									font-size: min(0.9rem,4.5vw);
									line-height: 1.4;
									white-space: nowrap;
									border: solid 1px rgba(0,0,0,0.2);
									background-color: #fff;
								}
							}
						}
					}
				}
			}
		}
		> div.tabledouble {
			display: grid;
			grid-template-columns: 1fr 1fr;
			column-gap: 20px;
			@media (width < 1100px) {
				grid-template-columns: 1fr;
			}
			> div.table.first {
				margin-top: 20px;
				max-width: 100%;
				> 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: 10px;
										background-color: #9ca7d0;
										color: #222;
										font-size: min(1rem,5vw);
										line-height: 1.6;
										font-weight: normal;
										text-align: center;
										white-space: nowrap;
										border-right: solid 1px #9ca7d0;
										border-bottom: solid 1px #9ca7d0;
									}
								}
							}
							> tbody {
								> tr {
									&:nth-of-type(odd) {
										> td {
											background-color: #dcdbe7;
										}
									}
									> th {
										padding-block: 10px;
										padding-inline: 10px;
										background-color: #b8c1dd;
										color: #222;
										font-size: min(0.9rem,4.5vw);
										line-height: 1.4;
										font-weight: normal;
										text-align: center;
										white-space: nowrap;
										border: solid 1px rgba(255,255,255,0.5);
									}
									> td {
										padding-block: 5px;
										padding-inline: 10px;
										color: #222;
										font-size: min(0.9rem,4.5vw);
										line-height: 1.4;
										white-space: nowrap;
										border: solid 1px rgba(0,0,0,0.2);
										background-color: #fff;
									}
								}
							}
						}
					}
				}
			}
			> div.table.second {
				margin-top: 20px;
				max-width: 100%;
				> 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: 10px;
										background-color: #211a61;
										color: #fff;
										font-size: min(1rem,5vw);
										line-height: 1.6;
										font-weight: normal;
										text-align: center;
										white-space: nowrap;
										border-right: solid 1px #211a61;
										border-bottom: solid 1px #211a61;
									}
								}
							}
							> tbody {
								> tr {
									&:nth-of-type(odd) {
										> td {
											background-color: #dcdbe7;
										}
									}
									> th {
										padding-block: 10px;
										padding-inline: 10px;
										background-color: #8c88ad;
										color: #fff;
										font-size: min(0.9rem,4.5vw);
										line-height: 1.4;
										font-weight: normal;
										text-align: center;
										white-space: nowrap;
										border: solid 1px rgba(255,255,255,0.5);
									}
									> td {
										padding-block: 5px;
										padding-inline: 10px;
										color: #222;
										font-size: min(0.9rem,4.5vw);
										line-height: 1.4;
										white-space: nowrap;
										border: solid 1px rgba(0,0,0,0.2);
										background-color: #fff;
									}
								}
							}
						}
					}
				}
			}
		}
		> div.notice {
			margin-top: 10px;
			display: flex;
			justify-content: end;
			> p {
				background-color: #fff;
				border: 1px solid #d00;
				border-radius: 5px;
				padding: 5px 10px;
				font-size: min(1.0rem,5vw);
				line-height: 1.2;
				color: #d00;
				text-align: justify;
			}
		}
		> h4 {
			margin-top: 80px;
			background-color: #aaa;
			color: #fff;
			font-size: 1.6rem;
			padding-block: 10px;
			padding-inline: 20px;
		}
		> div.about {
			padding-top: 30px;
			display: grid;
			grid-template-columns: 2fr 3fr;
			column-gap: 20px;
			@media (width < 900px) {
				grid-template-columns: 1fr;
				row-gap: 20px;
			}
			> figure {
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
			> div {
				> p {
					font-size: min(1.0rem,5vw);
					line-height: 1.8;
					color: #333;
					text-align: justify;
					text-indent: -1em;
					padding-left: 1em;
				}
				> div.example {
					margin-bottom: 20px;
					display: flex;
					align-items: center;
					column-gap: 5px;
					> h4 {
						clip-path: polygon(90% 0, 100% 50%, 90% 100%, 0 100%, 0 0);
						padding: 5px 15px 5px 10px;
						background-color: #7484c1;
						font-size: 1.1rem;
						line-height: 1.0;
						color: #fff;
					}
					> p {
						font-size: min(1.0rem,5vw);
						line-height: 1.8;
						color: #333;
					}
				}
			}
		}
	}
}
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 #7484c1;
			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;
			> span {
				color: #b9c2e0;
				padding-right: 3px;
			}
		}
		> figure {
			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: #9DA9D4;
									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: #e9ecf5;
									}
								}
								> th {
									padding-block: 5px;
									padding-inline: 10px;
									background-color: #9DA9D4;
									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: #f1f3f8;
	&.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 240px;
			column-gap: 40px;
			&.noimage_right {
				grid-template-columns: 1fr;
			}
			&:last-of-type {
				padding-bottom: 50px;
			}
			@media (width < 610px) {
				grid-template-columns: 1fr;
				row-gap: 20px;
			}
			> div {
				> 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: #7484c1;
					}
				}
				> 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;
					}
				}
				> figure {
					padding-top: 50px;
					text-align: center;
					> img {
						max-width: 100%;
					}
				}
			}
			> figure {
				padding-top: 10px;
				text-align: center;
				> img {
					max-width: 100%;
				}
				> figcaption {
					font-size: 0.9rem;
					line-height: 1.5;
					color: #333;
				}
			}
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> div {
				border-radius: 10px;
				background-color: #7484c1;
				background-image: url(./image/link_mark.svg);
				background-position: 60% 50%;
				background-size: 20px;
				background-repeat: no-repeat;
				@media (width < 1000px) {
					background-position: calc(50% + 100px) 50%;
				}
				> p {
					text-align: center;
					padding-block: 15px;
					font-size: 1.2rem;
					line-height: 1;
					color: #fff;
				}
			}
		}
	}
}
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.6;
			color: #333;
		}
	}
}
section.bottom {
	padding-top: min(120px,17vw);
	border-bottom: solid 1px #7484c1;
}
