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: #3bb094;
			}
		}
	}
}
section.about {
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
		}
		> h3 {
			padding-block: 40px 10px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #333;
		}	
	}
}
section.lamp {
	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.0;
			color: #fff;
		}
		> p {
			padding-top: 60px;
			font-size: 1.1rem;
			line-height: 1.7;
			color: #333;	
		}
		> div {
			max-width: 800px;
			margin-inline: auto;
			> figure {
				padding-block: 30px 50px;
				> img {
					max-width: 100%;
				}
			}
			> div.table {
				max-width: 100%;
				> div.scrolltable {
					max-width: 90vw;
					&:nth-of-type(1) {
						> div.table {
							> table {
								> tbody {
									> tr {
										> th {
											border: 1px solid #bbb;
											border-right: 1px solid #333;
											&:last-of-type {
												border-right: 1px solid #bbb;
											}
										}
										> td {
											border: 1px solid #bbb;
											border-right: 1px solid #333;
											&:nth-of-type(1) {
												border-left: 1px solid #bbb;
											}
											&:last-of-type {
												 border-right:  1px solid #bbb;
											}
										}
									}
								}
							}
						}
					}
					&.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: #e7e6e6;
										padding-block: 5px;
										padding-inline: 5px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										font-weight: 500;
										text-align: center;
										white-space: nowrap;
									}
									&: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;
										> small {
											font-size: min(0.9rem,4.0vw);
										}
									}
								}
							}
						}
					}
				}
			}
		}
	}
}
section.mechanism {
	background-color: #f5fbfa;
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			&.virustext {
				padding-top: 40px;
			}
		}
		> h3 {
			margin-top: 60px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.5;
			color: #fff;
		}
		> div.item {
			padding-top: 20px;
			> p {
				font-size: 1.0rem;
				line-height: 1.8;
				color: #333;
				text-align: justify;
			}
		}
		> div.destruction {
			margin-top: 50px;
			max-width: 800px;
			margin-inline: auto;
			background-color: #fff;
			> h4 {
				background-color: #858585;
				padding: 10px 20px;
				text-align: center;
				font-size: 1.3rem;
				line-height: 1.4;
				color: #fff;
			}
			> figure {
				padding-top: 30px;
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
		}
		> div.virus {
			margin-top: 50px;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 30px;
			max-width: 800px;
			margin-inline: auto;
			@media (width < 700px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 30px;
			}
			> div {
				background-color: #fff;
				display: grid;
				grid-template-rows: auto 300px auto;
				> h4 {
					background-color: #858585;
					padding: 10px 20px;
					text-align: center;
					font-size: 1.3rem;
					line-height: 1.4;
					color: #fff;
				}
				> figure {
					align-self: center;
					padding-bottom: 10px;
					text-align: center;
					> img {
						max-width: 100%;
					}
				}
				> p {
					justify-self: center;
					align-self: end;
					padding: 5px 15px;
					text-align: center;
					font-size: 1.1rem;
					line-height: 1.4;
					color: #333;
					border: 1px solid #333;
					margin-bottom: 10px;
				}
			}
		}	
	}
}
section.effect {
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.4;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			&.virustext {
				padding-top: 40px;
			}
		}
		> h3 {
			margin-top: 60px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.4;
			color: #fff;
		}
		> div {
			padding-top: 50px;
			max-width: 800px;
			margin-inline: auto;
			> div.table {
				padding-top: 30px;
				width: 100%;
				&:nth-of-type(1) {
					> div.scrolltable {
						> div.table {
							> table {
								> tbody {
									> tr {
										> td {
											padding-block: 10px;
											padding-inline: 10px;
											&:last-of-type {
												text-align: justify;
												white-space: unset;
											}
										}
									}
								}
							}
						}
					}
				}
				> 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;
							min-width: 800px;
							> tbody {
								> tr {
									> th {
										border: 1px solid #bbb;
										background-color: #9dd7ca;
										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%;
										}
									}
									> td {
										border: 1px solid #bbb;
										padding-block: 5px;
										padding-inline: 5px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										text-align: center;
										white-space: nowrap;
										&.vertical {
											writing-mode: vertical-rl;
											text-orientation: upright;
										}
										> img {
											height: 146px;
										}
									}
								}
							}
						}
					}
				}
			}
		}
	}
}
section.virus {
	padding: 0px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			margin-top: 60px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #fff;
		}
		> div {
			padding-top: 50px;
			max-width: 800px;
			margin-inline: auto;
			> div.table {
				padding-top: 30px;
				max-width: 100%;
				&:nth-of-type(1) {
					> div.scrolltable {
						> div.table {
							> table {
								> tbody {
									> tr {
										> td {
											padding-block: 10px;
											padding-inline: 10px;
											&:last-of-type {
												text-align: justify;
												white-space: unset;
											}
										}
										&:last-of-type {
											> td {
												padding-left: 120px;
												white-space: nowrap;
											}
										}
									}
								}
							}
						}
					}
				}
				> 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;
							min-width: 800px;
							> tbody {
								> tr {
									> th {
										border: 1px solid #bbb;
										background-color: #9dd7ca;
										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%;
										}
									}
									> td {
										border: 1px solid #bbb;
										padding-block: 5px;
										padding-inline: 5px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										text-align: center;
										white-space: nowrap;
										&.vertical {
											writing-mode: vertical-rl;
											text-orientation: upright;
										}
										> img {
											height: 146px;
										}
									}
								}
							}
						}
					}
				}
			}
			> div.graph {
				padding-top: 60px;
				> p {
					padding-left: 7%;
					font-size: 1.2rem;
					line-height: 1.0;
					color: #333;
					@media (width < 420px) {
						padding-left: 0%;
					}
					> small {
						padding-left: 11%;
						font-size: min(1.0rem, 4.5vw);
						@media (width < 420px) {
  							padding-left: 0;
						}
					}
				}
				> figure {
					margin-top: 20px;
					padding-bottom: 40px;
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.guideline {
	background-color: #f5fbfa;
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			&:nth-of-type(2) {
				padding-top: 40px;
			}
		}
		> h3 {
			margin-top: 60px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #fff;
		}
		> figure {
			padding-top: 50px;
			max-width: 800px;
			margin-inline: auto;
			> img {
				max-width: 100%;
			}
		}
		> div.graph {
			padding-top: 60px;
			max-width: 800px;
			margin-inline: auto;
			> p {
				padding-bottom: 20px;
				padding-left: 11%;
				font-size: 1.2rem;
				line-height: 1.0;
				color: #333;
			}
			> figure {
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.resistance {
	padding: 60px 5% 60px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 20px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			&:nth-of-type(2) {
				padding-top: 40px;
			}
			&.example {
				display: none;
				font-size: 0.9rem;
				line-height: 1.4;
				text-align: right;
				@media (width < 850px) {
					display: block;
				}
			}
		}
		> h3 {
			margin-top: 60px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #fff;
		}
		> div.table {
			padding-top: 30px;
			max-width: 100%;
			&:nth-of-type(1) {
				> div.scrolltable {
					> div.table {
						> table {
							> tbody {
								> tr {
									&:nth-of-type(2n + 2) {
										background-color: #e2f3ef;
									}
								}
							}
						}
					}
				}
			}
			> 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 {
								> th {
									border: 1px solid #bbb;
									background-color: #9dd7ca;
									color: #222;
									font-size: min(1.0rem,5vw);
									line-height: 2;
									font-weight: 500;
									text-align: center;
									white-space: nowrap;
									&.vertical {
										writing-mode: vertical-rl;
										text-orientation: upright;
									}
								}
								&:nth-of-type(1) {
									> th {
										&:nth-of-type(2n) {
											border-right: 2px dotted #bbb;
										}
									}
								}
								&:nth-of-type(6) {
									> th {
										&:nth-of-type(1) {
											border-right: 2px dotted #bbb;
										}
									}
								}
								> td {
									border: 1px solid #bbb;
									padding-block: 10px;
									padding-inline: 10px;
									color: #222;
									font-size: min(1.0rem,5vw);
									line-height: 1.6;
									text-align: center;
									white-space: nowrap;
									&:nth-of-type(2n + 1) {
										border-right: 2px dotted #bbb;
									}
									&.emptycell {
										background-image: linear-gradient(to right top, transparent calc(50% - 0.5px), #bbb 50%, #bbb calc(50% + 0.5px), transparent calc(50% + 1px))
									}
								}
							}
						}
					}
				}
			}
		}
		> div.deterioration {
			padding-top: 20px;
			display: grid;
			grid-template-columns: 3fr 1fr;
			column-gap: 20px;
			@media (width < 850px) {
				grid-template-columns: 1fr;
				row-gap: 20px;
			}
			> div {
				display: grid;
				> p {
					font-size: 1.0rem;
					line-height: 1.9;
					color: #333;
					text-align: justify;
					&:nth-of-type(2) {
						text-align: right;
						align-self: end;
						line-height: 1.5;
						@media (width < 850px) {
							display: none;
						}
					}
					> small {
						font-size: 0.9rem;
						line-height: 1.0;
					}
				}
			}
			> figure {
				border: 2px solid #333;
				@media (width < 850px) {
					text-align: center;
					justify-self: center;
					> img {
						width: 300px;
					}
				}
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.influence {
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			font-size: 1.6rem;
			line-height: 1.0;
			color: #333;
			padding-bottom: 10px;
			margin-bottom: 30px;
			border-bottom: 2px solid #3bb094;
		}
		> p {
			font-size: 1.0rem;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			&:nth-of-type(2) {
				padding-top: 40px;
			}
		}
		> h3 {
			margin-bottom: 30px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #fff;
		}
		> div {
			padding-top: 30px;
			> div.table {
				max-width: 100%;
				&:nth-of-type(1) {
					> div.scrolltable {
						> div.table {
							> table {
								> tbody {
									> tr {
										&:nth-of-type(odd) {
											> td:nth-of-type(1) {
												background-color: #e2f3ef;
											}
										}
									}
								}
							}
						}
					}
				}
				> 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 {
						margin-top: 3px;
						overflow: auto;
						> table {
							margin-top: 3px;
							width: 100%;
							height: 100%;
							border-collapse: collapse;
							@media (width < 840px) {
								grid-area: 1/1/2/4;
							}
							> tbody {
								> tr {
									height: 90px;
									> th {
										padding-inline: 10px;
										border: 1px solid #bbb;
										background-color: #9dd7ca;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 2;
										font-weight: 500;
										text-align: center;
										white-space: nowrap;
									}
									> td {
										padding-block: 10px;
										padding-inline: 10px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										white-space: nowrap;
										&:nth-of-type(1) {
											border: 1px solid #bbb;
										}
										&:nth-of-type(2) {
											width: 190px;
											> figure {
												transform: translateX(-40px);
												> img {
													width: 190px;
												}
											}
										}
									}
								}
							}
						}
					}
				}
			}
		}
	}
}
section.safety {
	padding: 60px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			margin-bottom: 30px;
			background-color: #adadad;
			padding: 20px 30px;
			font-size: 1.3rem;
			line-height: 1.0;
			color: #fff;
		}
		> div {
			padding-block: 10px 80px;
			max-width: 800px;
			margin-inline: auto;
			> div.table {
				max-width: 100%;
				&:nth-of-type(1) {
					> div.scrolltable {
						> div.table {
							> table {
								> tbody {
									> tr {
										&:nth-of-type(1) {
											> th {
												&:nth-of-type(2) {
													min-width: 330px;
												}
											}
										}
									}
								}
							}
						}
					}
				}
				> 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 {
						margin-top: 3px;
						overflow: auto;
						> table {
							margin-top: 3px;
							width: 100%;
							height: 100%;
							border-collapse: collapse;
							> tbody {
								> tr {
									> th {
										border: 1px solid #333;
										background-color: #e7e6e6;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 2;
										font-weight: 500;
										text-align: center;
										white-space: nowrap;
									}
									> td {
										border: 1px solid #333;
										padding-block: 10px;
										padding-inline: 10px;
										color: #222;
										font-size: min(1.0rem,5vw);
										line-height: 1.6;
										text-align: left;
										white-space: nowrap;
										&.space_unset {
											white-space: unset;
										}
										&.center {
											text-align: center;
										}
									}
								}
							}
						}
					}
				}
			}
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> div {
				background-color: #3bb094;
					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(../../common/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 #3bb094;
}
