section.panel {
	background-color: #eaf3f9;
	> div {
		max-width: 1920px;
		margin-inline: auto;
		background-image:	url(./image/anima_dot_blue.svg),
							url(./image/anima_dot_blue_blur.svg),
							url(./image/anima_dot_green.svg),
							url(./image/anima_dot_green_blur.svg),
							url(./image/anima_dot_orange.svg),
							url(./image/anima_dot_orange_blur.svg),
							url(./image/anima_dot_pink.svg),
							url(./image/anima_dot_white.svg),
							url(./image/anima_dot_blue.svg),
							url(./image/anima_dot_green.svg),
							url(./image/anima_dot_pink.svg),
							url(./image/anima_dot_blue_blur.svg),
							url(./image/anima_dot_orange_blur.svg);
		background-repeat: no-repeat;
		background-size: min(100px, 10vw) min(100px, 10vw);
		background-position: 	0% 0%,
								100% 5%,
								0% 40%,
								90% 45%,
								50% 44%,
								40% 10%,
								20% 26%,
								22% 10%,
								48% 42%,
								45% 43%,
								98% 44%,
								2% 42%,
								32% 41%;
		> div {
			padding-inline: 5%;
			max-width: 1920px;
			margin-inline: auto;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 3%;
			> div {
				display: grid;
				grid-template-rows: 1fr min(14vw,269px);
				row-gap: 5px;
				> div {
					display: grid;
					> figure {
						grid-area: 1/1/2/2;
						> img {
							max-width: 100%;
						}
						&:nth-of-type(1) {
							align-self: start;
							justify-self: end;
							margin-right: 10%;
							> img {
								width: min(9vw,173px);
							}
						}
						&:nth-of-type(2) {
							align-self: end;
							justify-self: end;
							margin-right: 2%;
							> img {
								width: min(14vw,269px);
							}
						}
						&:nth-of-type(3) {
							align-self: center;
							justify-self: center;
							> img {
								width: min(10vw,192px);
							}
						}
						&:nth-of-type(4) {
							align-self: start;
							justify-self: start;
							margin-left: -5%;
							> img {
								width: min(17vw,326px);
							}
						}
						&:nth-of-type(5) {
							align-self: end;
							justify-self: start;
							> img {
								width: min(10vw,192px);
							}
						}
					}
				}
				> h1 {
					grid-area: 2/1/3/2;
					font-size: min(3.2rem, 5.5vw);
					line-height: 1.2;
					color: var(--color-accent);
					font-weight: 600;
				}
			}
			> figure {
				> img {
					max-width: 100%;
					width: 50vw;
				}
			}
		}
		> figure {
			> img {
				max-width: 100%;
				width: 100%;
			}
		}
	}
}
section.top {
	padding: 0px 5% 100px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> div {
			padding-top: 80px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 40px;
			row-gap: 40px;
			@media (width < 940px) {
				grid-template-columns: repeat(2, 1fr);
			}
			@media (width < 530px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> figure {
				text-align: center;
				> img {
					height: 240px;
					@media (width < 630px) {
						height: 200px;
					}
					@media (width < 530px) {
						height: unset;
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.sns {
	padding: 0px 5% 0px 5%;
	> div {
		max-width: 700px;
		margin-inline: auto;
		> h2 {
			font-size: 2.2rem;
			line-height: 1.3;
			color: var(--color-accent);
			font-weight: 600;
			text-align: center;
		}
		> div.link {
			border-radius: 50px;
			padding: 20px;
			border: 3px solid #0e357f;
			display: grid;
			grid-template-columns: repeat(2, auto);
			column-gap: 10px;
			justify-self: center;
			align-content: center;
			text-align: center;
			@media (width < 450px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 10px;
				padding: 20px 40px;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.news {
	padding: 120px 5% 0px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.title {
			display: flex;
			justify-content: space-between;
			align-items: end;
			row-gap: 15px;
			@media (width < 500px) {
				flex-direction: column;
				align-items: center;
			}
			> h2 {
				> div {
					font-size: 4.0rem;
					line-height: 1;
					color: #0e4bae;
					font-weight: 600;
				}
				> p {
					font-size: min(1.4rem, 6.0vw);
					line-height: 1.4;
					color: #222;
					font-weight: 500;
				}
			}
			> a {
				text-decoration: none;
				> img {
					max-width: 100%;
					box-shadow: 0 0 5px rgba(14,75,174,0.5);
					border-radius: 50px;
				}
			}
		}
		> div#informArea {
			margin-top: 40px;
			> .content {
				border-top: solid 1px #aaa;
				> div {
					> a {
						text-decoration: none;
						display: block;
						background-image: url(./image/circle_link.svg);
						background-repeat: no-repeat;
						background-position: right 5px top 50%;
						border-bottom: solid 1px #aaa;
						padding-block: 30px;
						&:hover {
							opacity: 0.7;
						}
						> dl {
							display: grid;
							grid-template-columns: 110px 1fr;
							@media (width < 920px) {
								grid-template-columns: 1fr;
							}
							> dt {
								@media (width < 920px) {
									grid-row: 1/2;
									grid-column: 1/2;
								}
							}
							> dd {
								font-size: min(1rem,5vw);
								line-height: 1.5;
								color: #222;
								padding-right: 60px;
							}
						}
					}
				}
			}
			> .empty {
				background-color: #eee;
				text-align: center;
				font-size: 0.9;
				line-height: 1.3;
				color: #888;
				padding: 20px;
			}
		}
	}
}
section.school {
	padding: 120px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> p {
			margin-bottom: 5px;
			font-size: min(1.0rem, 5.0vw);
			line-height: 1.5;
			color: #222;
			font-weight: 500;
			text-align: center;
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> figure {
				text-align: center;
				> img {
					max-width: 100%;
				}
			}
		}
		> div {
			padding-top: 50px;
			max-width: 700px;
			margin-inline: auto;
			display: grid;
			grid-template-columns: repeat(2, auto);
			column-gap: 60px;
			align-items: center;
			@media (width < 930px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 20px;
			}
			> a {
				justify-self: center;
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					text-align: center;
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.service {
	background-color: #ecefef;
	padding: 100px 5% 120px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			> div {
				font-size: 4.0rem;
				line-height: 1;
				color: #0e4bae;
				font-weight: 600;
			}
			> p {
				font-size: min(1.4rem, 6.0vw);
				line-height: 1.4;
				color: #222;
				font-weight: 500;
			}
		}
		> p {
			padding-block: 30px;
			font-size: min(1.0rem, 5.0vw);
			line-height: 1.8;
			color: #222;
			font-weight: 500;
		}
		> a {
			text-decoration: none;
			&:hover {
				opacity: 0.8;
			}
			> figure {
				display: grid;
				> img {
					grid-area: 1/1/2/2;
					max-width: 100%;
					border-radius: 10px;
					&:nth-of-type(2) {
						width: min(45px, 8vw);
						height: min(45px, 8vw);
						margin-bottom: 2%;
						margin-right: 2%;
						justify-self: end;
						align-self: end;
					}
				}
				> p {
					margin-top: 5%;
					margin-left: 5%;
					grid-area: 1/1/2/2;
					font-size: min(1.4rem, 5.0vw);
					line-height: 1.0;
					color: #fff;
					font-weight: 500;
				}
			}
		}
		> div {
			padding-top: 30px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 30px;
			row-gap: 30px;
			@media (width < 1040px) {
				grid-template-columns: repeat(2, 1fr);
			}
			@media (width < 650px) {
				grid-template-columns: repeat(1, 1fr);
				padding-top: 60px;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					display: grid;
					> img {
						grid-area: 1/1/2/2;
						max-width: 100%;
						border-radius: 10px;
						&:nth-of-type(2) {
							width: min(45px, 8vw);
							height: min(45px, 8vw);
							margin-bottom: 1%;
							margin-right: 1%;
							justify-self: end;
							align-self: end;
						}
					}
					> p {
						margin-top: 6%;
						margin-left: 6%;
						grid-area: 1/1/2/2;
						font-size: min(1.0rem, 4.5vw);
						line-height: 1.4;
						color: #fff;
						font-weight: 500;
						@media (width < 1100px) {
							font-size: min(0.9rem, 4.5vw);
							margin-top: 4%;
							margin-left: 4%;
						}
					}
				}
			}
		}
	}
}
section.company {
	margin: 80px 0px 0px 60px;
	border-top-left-radius: 50px;
	background-color: #eaf3f9;
	padding: 80px 5% 80px 5%;
	@media (width < 1080px) {
		margin: 80px 0px 60px 2.5%;
		padding: 80px 5% 80px 2.5%;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		transform: translateX(-30px);
		@media (width < 1080px) {
			transform: unset;
		}
		> h2 {
			> div {
				font-size: 4.0rem;
				line-height: 1;
				color: #0e4bae;
				font-weight: 600;
			}
			> p {
				font-size: min(1.4rem, 6.0vw);
				line-height: 1.4;
				color: #222;
				font-weight: 500;
			}
		}
		> p {
			padding-block: 30px;
			font-size: min(1.0rem, 5.0vw);
			line-height: 1.8;
			color: #222;
			font-weight: 500;
		}
		> div {
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 30px;
			row-gap: 30px;
			@media (width < 650px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 50px;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					display: grid;
					> img {
						grid-area: 1/1/2/2;
						max-width: 100%;
						border-radius: 10px;
					}
					> p {
						grid-area: 1/1/2/2;
						font-size: min(1.4rem, 5vw);
						line-height: 1.4;
						color: #222;
						font-weight: 600;
						justify-self: center;
						align-self: top;
						margin-top: 5%;
					}
				}
				> div {
					margin-top: 10px;
					display: grid;
					grid-template-columns: 110px 1fr;
					align-items: center;
					column-gap: 10px;
					> p {
						font-size: min(1.1rem, 5vw);
						line-height: 1.4;
						color: #222;
						font-weight: 500;
					}
					> img {
						width: 45px;
					}
				}
			}
		}
	}
}
section.recruit {
	margin: 80px 60px 50px 0px;
	border-top-right-radius: 50px;
	background-color: #eaf3f9;
	padding: 80px 5% 80px 5%;
	@media (width < 1080px) {
		margin: 80px 2.5% 60px 0px;
		padding: 80px 2.5% 80px 5%;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		transform: translateX(30px);
		@media (width < 1080px) {
			transform: unset;
		}
		> h2 {
			> div {
				font-size: 4.0rem;
				line-height: 1;
				color: #0e4bae;
				font-weight: 600;
			}
			> p {
				font-size: min(1.4rem, 6.0vw);
				line-height: 1.4;
				color: #222;
				font-weight: 500;
			}
		}
		> div {
			padding-top: 30px;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 30px;
			row-gap: 30px;
			@media (width < 650px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 50px;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> figure {
					display: grid;
					> img {
						grid-area: 1/1/2/2;
						max-width: 100%;
						border-radius: 10px;
					}
					> p {
						grid-area: 1/1/2/2;
						font-size: min(1.4rem, 5vw);
						line-height: 1.4;
						color: #222;
						font-weight: 600;
						justify-self: center;
						align-self: top;
						margin-top: 5%;
					}
				}
				> div {
					margin-top: 10px;
					display: grid;
					grid-template-columns: 110px 1fr;
					align-items: center;
					column-gap: 10px;
					> p {
						font-size: min(1.1rem, 5vw);
						line-height: 1.4;
						color: #222;
						font-weight: 500;
					}
					> img {
						width: 45px;
					}
				}
			}
		}
	}
}
section.businesspartner {
	padding: 80px 5% 80px 5%;
	background-color: #ecefef;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h2 {
			> div {
				font-size: 4.0rem;
				line-height: 1.2;
				color: #0e4bae;
				font-weight: 600;
				@media (width < 550px) {
					font-size: 2.0rem;
				}
			}
			> p {
				font-size: min(1.4rem, 6.0vw);
				line-height: 1.4;
				color: #222;
				font-weight: 500;
			}
		}
		> article {
			margin-top: 40px;
			> h3 {
				font-size: min(1.2rem, 6.0vw);
				line-height: 1.2;
				color: var(--color-accent);
				font-weight: 600;
			}
			> h4 {
				margin-top: 35px;
				font-size: min(0.9rem, 4.5vw);
				line-height: 1.5;
				color: var(--color-accent);
			}
			> ul {
				margin-top: 30px;
				display: grid;
				grid-template-columns: repeat(4,auto);
				column-gap: 50px;
				row-gap: 30px;
				@media (width < 1080px) {
					grid-template-columns: repeat(3,auto);
				}
				@media (width < 800px) {
					grid-template-columns: repeat(2,auto);
				}
				@media (width < 550px) {
					grid-template-columns: repeat(1,auto);
					row-gap: 10px;
				}
				> li {
					font-size: min(0.9rem,5vw);
					line-height: 1.3;
					color: #222;
				}
			}
		}
	}
}
