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;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		column-gap: 20px;
		row-gap: 20px;
		@media (width < 730px) {
			grid-template-columns: repeat(1, 1fr);
		}
		> a {
			text-decoration: none;
			background-color: #999;
			font-size: 1.5rem;
			line-height: 1.0;
			color: #fff;
			text-align: center;
			padding: 20px 30px;
			background-image: url(./image/link_mark.svg);
			background-position: 90% 52%;
			background-size: 20px;
			background-repeat: no-repeat;
			&:hover {
				background-color: #7484c1;
			}
		}
	}
}
section.about {
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.4rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #7484c1;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			> span {
				color: #ff7d31;
			}
			> small {
				font-size: 0.9rem;
			}
		}
		> h3 {
			padding-block: 40px 10px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #333;
		}
		> div.table {
			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;
						> tbody {
							> tr {
								> td {
									> img {
										height: 342px;
									}
								}
							}
						}
					}
				}
			}
		}
	}
}
section.mechanism {
	background-color: #f1f3f9;
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.4rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #7484c1;
		}
		> div {
			display: grid;
			grid-template-columns: 1.1fr 1fr;
			column-gap: 30px;
			@media (width < 660px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 30px;
			}
			> p {
				font-size: 1.0rem;
				line-height: 1.7;
				color: #333;
				text-align: justify;
			}
			> figure {
				margin-right: 10%;
				justify-self: end;
				@media (width < 660px) {
					margin-right: 0%;
					justify-self: center;
				}
				> img {
					max-width: 100%;
				}
			}	
		}
	}
}
section.test {
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.4rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #7484c1;
		}
		> div {
			display: grid;
			grid-template-columns: 1.1fr 1fr;
			column-gap: 30px;
			@media (width < 660px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 30px;
			}
			> p {
				font-size: 1.0rem;
				line-height: 1.7;
				color: #333;
				text-align: justify;
			}
			> figure {
				margin-right: 10%;
				justify-self: end;
				@media (width < 660px) {
					margin-right: 0%;
					justify-self: center;
				}
				> img {
					max-width: 100%;
				}
			}	
		}
	}
}
section.point01 {
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.4;
			color: #fff;
		}
		> div {
			padding-top: 60px;
			max-width: 800px;
			margin-inline: auto;
			> p {
				font-size: 0.9rem;
				line-height: 1.7;
				color: #333;	
			}
			> div.table {
				max-width: 100%;
				> div.scrolltable {
					max-width: 90vw;
					&:nth-of-type(1) {
						> div.table {
							> table {
								> tbody {
									> tr {
										&:nth-of-type(1) {
											> th {
												border-top: none;
											}
										}
										&:nth-of-type(2n + 1) {
											> td {
												background-color: #eaedf6;
											}
										}
										> th {
											border-top: 1px solid #eee;
										}
										> td {
											border: 1px solid #b3b3b3;
											&:nth-of-type(1) {
												border-left: 1px solid #b3b3b3;
											}
										}
									}
								}
							}
						}
					}
					&.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;
							> tbody {
								> tr {
									> th {
										background-color: #b9c2e0;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										font-weight: 500;
										text-align: center;
										white-space: nowrap;
										> label {
											padding-block: 15px;
											padding-inline: 5px;
											display: inline-block;
											cursor: pointer;
											width: 100%;
											height: 100%;
										}
									}
									&:nth-of-type(n + 3) {
										> th {
											padding-block: 15px;
											padding-inline: 5px;
										}
									}
									> td {
										padding-block: 5px;
										padding-inline: 5px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										text-align: left;
										text-align: center;
										white-space: nowrap;
										&.text {
											writing-mode: vertical-rl;
											text-orientation: upright;
											text-align: start;
											font-size: min(0.9rem,4.0vw);
											line-height: 1.1;
										}
										> small {
											font-size: min(0.9rem,4.0vw);
										}
									}
								}
							}
						}
					}
				}
			}
			> div.care {
				padding-top: 10px;
				display: grid;
				grid-template-columns: auto 1fr;
				column-gap: 10px;
				> h4 {
					padding-inline: 15px;
					align-self: start;
					background-color: #e50012;
					font-size: 1.0rem;
					line-height: 1.7;
					color: #fff;
				}
				> p {
					font-size: 0.9rem;
					line-height: 1.7;
					color: #333;	
				}
			}
		}
	}
}
section.point02 {
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.4;
			color: #fff;
		}
		> p {
			padding-top: 30px;
			font-size: 1.1rem;
			line-height: 1.7;
			color: #333;
			> b {
				font-weight: 600;
			}
			&.test {
				padding-top: 0px;
				padding-bottom: 80px;
				text-align: right;
				font-size: 0.9rem;
				line-height: 1.7;
				color: #333;
			}
		}
		> div.item {
			> article {
				display: grid;
				grid-template-columns: 100px 1fr;
				&:nth-of-type(2) {
					> p {
						&:nth-of-type(1) {
							letter-spacing: 1.7px;
						}
					}
				}
				> p {
					font-size: 1.1rem;
					line-height: 1.7;
					color: #333;
				}
			}
		}
		> div.list {
			max-width: 800px;
			margin-inline: auto;
			> p {
				text-align: right;
				font-size: 0.9rem;
				line-height: 1.7;
				color: #333;	
			}
			> div.table {
				margin-top: 5px;
				max-width: 100%;
				> div.scrolltable {
					max-width: 90vw;
					&:nth-of-type(1) {
						> div.table {
							> table {
								> tbody {
									> tr {
										&:nth-of-type(1), &:nth-of-type(2) {
											background-color: #eaedf6;
										}
										&:nth-of-type(2n + 4) {
											background-color: #eaedf6;
										}
										> th {
											border: 1px solid #eee;
										}
										> td {
											border: 1px solid #b3b3b3;
											&:nth-of-type(1) {
												border-left: 1px solid #b3b3b3;
											}
										}
									}
								}
							}
						}
					}
					&.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;
							> tbody {
								> tr {
									> th {
										background-color: #b9c2e0;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										font-weight: 500;
										text-align: center;
										white-space: nowrap;
										> label {
											padding-block: 15px;
											padding-inline: 5px;
											display: inline-block;
											cursor: pointer;
											width: 100%;
											height: 100%;
										}
									}
									&:nth-of-type(n + 3) {
										> th {
											padding-block: 15px;
											padding-inline: 5px;
										}
									}
									> td {
										padding-block: 5px;
										padding-inline: 5px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										text-align: left;
										text-align: center;
										white-space: nowrap;
										&.text {
											writing-mode: vertical-rl;
											text-orientation: upright;
											text-align: start;
											font-size: min(0.9rem,4.0vw);
											line-height: 1.1;
										}
										> small {
											font-size: min(0.9rem,4.0vw);
										}
									}
								}
							}
						}
					}
				}
			}
		}
		> h2 {
			padding-top: 40px;
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
		}
		> figure {
			max-width: 700px;
			margin-inline: auto;
			> img {
				max-width: 100%;
			}
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> div {
				background-color: #7484c1;
					border-radius: 10px;
				text-align: center;
				> p {
					display: inline-block;
					padding-block: 15px;
					font-size: 1.2rem;
					line-height: 1;
					color: #fff;
					background-image: url(./image/link_mark.svg);
					background-position: 100% 52%;
					background-size: 20px;
					background-repeat: no-repeat;
					padding-right: 30px;
				}
			}
		}
	}
}
section.bottom {
	padding-top: min(120px,17vw);
	border-bottom: solid 1px #7484c1;
}
