/*
section.switchpanel {
	background-color: #eee;
	overflow: hidden;
	max-height: 1400px;
	&.off {
		max-height: 0;
	}
	> div {
		max-width: 1920px;
		margin-inline: auto;
		overflow: hidden;
		> #switchPanelStage {
			user-select: none;
			display: grid;
			grid-template-rows: 1fr;
			grid-template-columns: 1fr;
			> div {
				grid-row: 1/2;
				grid-column: 1/2;
				&:nth-of-type(1) {
					z-index: 0;
				}
				&:nth-of-type(2) {
					z-index: 1;
					transition: 0.5s;
					cursor: ew-resize;
				}
				&:nth-of-type(3) {
					z-index: 2;
					justify-self: end;
					align-self: end;
					display: flex;
					justify-content: center;
					align-items: center;
					column-gap: 5px;
					padding: 0 20px 17px 0;
					@media (width < 670px) {
						column-gap: 3px;
						padding: 0 4px 4px 0;
						justify-self: center;
						> span {
							> img {
								width: 14px;
							}
						}
					}
					> span {
						transition: 0.3s;
						cursor: pointer;
						> img:nth-of-type(1) {
							display: block;
						}
						> img:nth-of-type(2) {
							display: none;
						}
						&.on {
							> img:nth-of-type(1) {
								display: none;
							}
							> img:nth-of-type(2) {
								display: block;
							}
						}
					}
				}
				> div {
					> div.pc {
						display: grid;
						@media (width < 670px) {
							display: none;
						}
						> picture {
							grid-area: 1/1/2/2;
							> img {
								width: 100%;
							}
						}
						> a {
							grid-area: 1/1/2/2;
							text-decoration: none;
							&:hover {
								opacity: 0.7;
							}
							> img {
							}
						}
					}
					> div.sp {
						display: none;
						@media (width < 670px) {
							display: grid;
						}
						> picture {
							grid-area: 1/1/2/2;
							> img {
								width: 100%;
							}
						}
						> a {
							grid-area: 1/1/2/2;
							text-decoration: none;
							&:hover {
								opacity: 0.7;
							}
							> img {
							}
						}
					}
				}
			}
		}
	}
}
*/
section.panel01 {
	background-color: #eee;
	> div {
		max-width: 1920px;
		margin-inline: auto;
		> img {
			max-width: 100%;
		}
	}
}
section.top {
	padding: 50px 5% 80px 5%;
	background-image: url(./image/top_bg.svg);
	background-repeat: no-repeat;
	background-size: auto;
	background-position: 50% 10%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: #333333;
			font-weight: 700;
			letter-spacing: 1px;
			text-align: center;
		}
		> div {
			padding-block: 20px 50px;
			display: grid;
			grid-template-columns: 300px 1fr 300px;
			@media (width < 1100px) {
				grid-template-columns: 1fr 1.1fr;
				row-gap: 40px;
			}
			@media (width < 850px) {
				padding-block: 20px 100px;
				grid-template-columns: 1fr;
				row-gap: 80px;
			}
			> article {
				position: relative;
				display: grid;
				&:nth-of-type(1) {
					@media (width < 1100px) {
						order: 2;
					}
					> figure {
						> img {
							margin-left: -30%;
							width: 135%;
							@media (width < 1100px) {
								margin-left: 0%;
								width: 100%;
							}
						}
					}
				}
				&:nth-of-type(2) {
					@media (width < 1100px) {
						order: 1;
						grid-area: 1/1/2/3;
					}
					@media (width < 850px) {
						grid-area: unset;
					}
					> figure {
						padding: 20px;
						text-align: center;
						> img {
							max-width: 100%;
						}
					}
				}
				&:nth-of-type(3) {
					@media (width < 1100px) {
						order: 3;
					}
					> figure {
						margin-left: 10%;
						@media (width < 1100px) {
							margin-left: 0%;
						}
						> img {
							max-width: 290px;
							@media (width < 850px) {
								max-width: unset;
								width: 100%;
							}
						}
					}
				}
				&:nth-of-type(1),&:nth-of-type(3) {
					> figure {
						@media (width < 1100px) {
							justify-self: center;
							align-self: center;
						}
						@media (width < 850px) {
							padding-bottom: 20px;
						}
					}
					> a {
						position: absolute;
						bottom: 5%;
						@media (width < 1100px) {
							bottom: -5%;
						}
					}
				}
				> a {
					margin-top: -10%;
					justify-self: center;
					text-decoration: none;
					align-self: start;
					@media (width < 1100px) {
						margin-top: 0%;
					}
					&:hover {
						opacity: 0.8;
					}
					> div {
						display: grid;
						justify-self: center;
						align-self: center;
						> img {
							max-width: 100%;
						}
					}
				}
				> h4 {
					font-size: min(1.7rem, 6vw);
					line-height: 1.5;
					color: #333333;
					font-weight: 700;
					letter-spacing: 1px;
					text-align: center;
					&:nth-of-type(2) {
						padding: 10px;
					}
				}
				> p {
					font-size: min(1.0rem, 5vw);
					line-height: 2.0;
					color: #333333;
					font-weight: 600;
					text-align: center;
				}
			}
		}
		> a {
			text-decoration: none;
			@media (width < 1100px) {
				margin-top: 0%;
			}
			&:hover {
				opacity: 0.8;
			}
			> div {
				box-shadow: 5px 5px #f28088;
				background-image: url(./image/link_button_red_down.svg);
				background-repeat: no-repeat;
				background-size: 40px;
				background-position: right 20px top 50%;
				padding: 10px 80px;
				display: grid;
				justify-self: center;
				border: 1px solid var(--color-accent);
				@media (width < 590px) {
					padding: 10px 30px;
					background-size: 30px;
					background-position: right 10px top 50%;
				}
				@media (width < 350px) {
					background-size: 25px;
				}
				> p {
					font-size: min(1.6rem, 5vw);
					line-height: 1.5;
					color: #333333;
					font-weight: 600;
					letter-spacing: 1px;
					text-align: center;
					> b {
						color: var(--color-accent);
					}
				}
			}
		}
	}
}
section.inform {
	padding: 100px 5% 100px 5%;
	background-image: url(./image/inform_back.svg);
	background-position: 50% 100%;
	background-repeat: no-repeat;
	background-size: cover;
	> div {
		max-width: 1100px;
		margin-inline: auto;
		background-color: #fff;
		border: solid 1px #dbe2e5;
		border-radius: 10px;
		padding-block: 50px;
		padding-inline: 50px;
		@media (width < 800px) {
			padding-inline: 10px;
		}
		> h2 {
			font-size: min(2.5rem, 7.0vw);
			line-height: 1.3;
			color: #000;
			font-weight: 600;
			letter-spacing: 2px;
			text-align: center;
			font-family: var(--font-serif);
		}
		> p {
			font-size: min(1.2rem, 5.0vw);
			line-height: 1.8;
			color: #d00;
			font-weight: 600;
			text-align: center;
			padding-bottom: 40px;
		}
		> div.news {
			> div.content {
				> article {
					border-left: solid 1px #ccc;
					padding-left: 20px;
					&:last-of-type > a {
						border-bottom: 1px solid #ccc;
					}
					> a {
						display: block;
						text-decoration: none;
						user-select: none;
						border-top: 1px solid #ccc;
						padding-block: 20px;
						padding-inline: 10px 40px;
						background-image: url(./image/link_about.svg);
						background-repeat: no-repeat;
						background-position: right 5px top 50%;
						&:hover {
							opacity: 0.8;
						}
						> dl {
							display: grid;
							grid-template-columns: 2px 100px 115px 1fr;
							row-gap: 5px;
							> dt:nth-of-type(1) {
								border-left: solid 3px #d00;
								margin-left: -32px;
							}
							> dt:nth-of-type(2) {
								font-size: min(1.0rem, 5.0vw);
								line-height: 1.4;
								color: #111;
							}
							> dt:nth-of-type(3) {
								> ce-inform-category {
									display: block;
								}
							}
							> dd {
								font-size: min(1rem, 5.0vw);
								line-height: 1.4;
								color: #111;
								@media (width < 800px) {
									grid-row: 2/3;
									grid-column: 2/5;
								}
							}
						}
					}
				}
			}
			> div.empty {
				background-color: #eee;
				font-size: 1rem;
				line-height: 1;
				color: #666;
				padding-block: 20px;
				text-align: center;
			}
		}
		> div.link {
			margin-top: 50px;
			text-align: center;
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					border: 2px solid var(--color-accent);
					display: inline-flex;
					align-items: center;
					column-gap: 20px;
					padding: 15px 25px;
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 1.8;
						color: var(--color-accent);
						font-weight: 600;
					}
					> img {
						width: 6px;
					}
				}
			}
		}
	}
}
section.about {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			padding-bottom: 30px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: var(--color-accent);
			font-weight: 700;
			letter-spacing: 1px;
			text-align: center;
		}
		> p {
			font-size: min(1.0rem, 5vw);
			line-height: 2.0;
			color: #333333;
			font-weight: 600;
			text-align: center;
			@media (width < 900px) {
				text-align: left;
			}
		}
	}
}
section.limited {
	padding: 80px 5% 80px 5%;
	background: url(./image/limited_bg.webp) #282d36;
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: 0% 0%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: #fff;
			font-weight: 700;
			letter-spacing: 1px;
			text-align: center;
		}
		> div {
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 30px;
			row-gap: 30px;
			@media (width < 780px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> article {
				display: grid;
				background-color: #fff;
				border-radius: 20px;
				padding: 30px;
				@media (width < 830px) {
					padding: 20px;
				}
				&:nth-of-type(6) {
					> figure {
						padding-left: 10%;
						background: url(./image/circle.svg);
						background-repeat: no-repeat;
						background-size: 100px;
						background-position: 0% 100%;
						@media (width < 930px) {
							padding-left: 30%;
						}
						@media (width < 780px) {
							padding-left: 10%;
							background-position: calc(50% - 25vw) 100%;
						}
						@media (width < 500px) {
							padding-left: unset;
							background: unset;
						}
						> img {
							max-width: 210px;
						}
					}
				}
				&:nth-of-type(7) {
					grid-column: 1/3;
					@media (width < 780px) {
						grid-column: unset;
						> p {
							text-align: justify;
							padding-left:1em;
							text-indent:-1em;
						}
					}
				}
				> figure {
					margin-bottom: 10px;
					text-align: center;
					align-self: center;
					> img {
						max-width: 100%;
					}
				}
				> h3 {
					font-size: min(1.6rem, 6vw);
					line-height: 1.5;
					color: #333;
					font-weight: 700;
					letter-spacing: 1px;
					text-align: center;
					> span {
						padding-left: 5px;
						font-size: min(2.5rem, 8vw);
					}
				}
				> h4 {
					font-size: min(1.6rem, 6vw);
					line-height: 1.5;
					color: #333;
					font-weight: 700;
					letter-spacing: 1px;
					text-align: center;
					> b {
						font-size: min(2.5rem, 8vw);
					}
				}
				> p {
					padding-top: 5px;
					font-size: min(1.2rem, 5vw);
					line-height: 1.4;
					color: #333;
					font-weight: 700;
					text-align: center;
				}
				> div.salon {
					margin-top: 10px;
					background-color: var(--color-accent);
					border-radius: 10px;
					justify-self: center;
					align-self: center;
					padding: 10px 30px;
					> p {
						text-align: center;
						font-size: min(1.3rem, 5vw);
						line-height: 1.0;
						color: #fff;
						font-weight: 700;
						letter-spacing: 1px;
					}
				}
				> div.free {
					display: flex;
					justify-content: center;
					align-items: center;
					column-gap: 5px;
					> h4 {
						font-size: min(1.6rem, 6vw);
						line-height: 1.0;
						color: #333;
						font-weight: 700;
						letter-spacing: 1px;
						text-align: center;
					}
					> h3 {
						font-size: min(2.5rem, 8vw);
						line-height: 1.2;
						color: #333;
						font-weight: 700;
						letter-spacing: 1px;
						text-align: center;
						border-bottom: double 6px #333;
					}
				}
				> div.service {
					padding-block: 30px;
					display: grid;
					grid-template-columns: repeat(3, 1fr);
					column-gap: 30px;
					row-gap: 30px;
					@media (width < 730px) {
						grid-template-columns: repeat(1, 1fr);
					}
					> article {
						display: grid;
						grid-template-rows: subgrid;
  						grid-row: span 2;
						row-gap: 5px;
						@media (width < 730px) {
							padding-bottom: 40px;
						}
						> a {
							text-decoration: none;
							&:hover {
								> figure > img {
									transform: scale(1.1);
								}
							}
							> figure {
								overflow: hidden;
								text-align: center;
								> img {
									transition: transform 0.5s;
									max-width: 100%;
								}
							}
							> h5 {
								align-self: center;
								text-align: center;
								font-size: min(1.1rem, 5.5vw);
								line-height: 1.3;
								color: #333;
								font-weight: 700;
								font-family: var(--font-serif);
							}
						}
						> p {
							text-align: justify;
							font-size: min(0.9rem, 4.5vw);
							line-height: 1.5;
							color: #333;
						}
					}
				}
			}
		}
	}
}
section.president {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		column-gap: 50px;
		@media (width < 680px) {
			grid-template-columns: repeat(1, 1fr);
			row-gap: 40px;
		}
		> figure {
			text-align: center;
			> img {
				border-radius: 10px;
				max-width: 100%;
			}
		}
		> article {
			@media (width < 680px) {
				text-align: center;
			}
			> img {
				width: 140px;
			}
			> h4 {
				padding-top: 20px;
				font-size: min(1.4rem, 6vw);
				line-height: 1.5;
				color: #333;
				font-weight: 700;
				font-family: var(--font-serif);
			}
			> h3 {
				padding-top: 20px;
				font-size: min(2.6rem, 10vw);
				line-height: 1.5;
				color: #333;
				font-weight: 500;
				font-family: var(--font-serif);
			}
			> div.link {
				padding-block: 20px;
				display: flex;
				column-gap: 30px;
				@media (width < 680px) {
					justify-content: center;
				}
				> a {
					&:hover {
						opacity: 0.8;
					}
					> figure {
						> img {
							max-width: 100%;
						}
					}
				}
			}
			> p {
				padding-bottom: 20px;
				text-align: justify;
				font-size: min(1.0rem, 5vw);
				line-height: 1.8;
				color: #333;
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					border: 2px solid var(--color-accent);
					display: inline-flex;
					align-items: center;
					column-gap: 20px;
					padding: 15px 25px;
					> p {
						font-size: min(1.0rem, 5vw);
						line-height: 1.8;
						color: var(--color-accent);
						font-weight: 600;
					}
					> img {
					}
				}
			}
		}
	}
}
section.book {
	background-color: #edf0f2;
	border-top: 1px solid #333;
	border-bottom: 1px solid #333;
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: #333;
			font-weight: 700;
			letter-spacing: 3px;
			text-align: center;
			font-family: var(--font-serif);
		}
		> div {
			padding-top: 40px;
			display: grid;
			grid-template-columns: repeat(2, 1fr);
			column-gap: 140px;
			row-gap: 50px;
			@media (width < 820px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> article {
				display: grid;
				row-gap: 10px;
				grid-template-rows: subgrid;
				grid-row: span 2;
				> figure {
					margin-inline: auto;
					max-width: 430px;
					> img {
						max-width: 100%;
					}
				}
				> div {
					display: grid;
					row-gap: 10px;
					@media (width < 820px) {
						justify-content: center;
					}
					> h3 {
						margin-top: 10px;
						font-size: min(1.6rem, 8vw);
						line-height: 1.5;
						color: #333;
						font-weight: 700;
						@media (width < 380px) {
							> br {
								display: none;
							}
						}
					}
					> h4 {
						font-size: min(1.3rem, 6vw);
						line-height: 1.5;
						color: #333;
						font-weight: 500;
						&.empty {
							@media (width < 820px) {
								display: none;
							}
						}
					}
					> p {
						align-self: end;
						font-size: min(1.0rem, 5vw);
						line-height: 1.8;
						color: #333;
						margin-bottom: 10px;
					}
					> a {
						text-decoration: none;
						align-self: end;
						@media (width < 820px) {
							justify-self: center;
						}
						&:hover {
							opacity: 0.8;
						}
						> div {
							border: 2px solid var(--color-accent);
							display: inline-flex;
							align-items: center;
							column-gap: 30px;
							padding: 15px 30px 15px 66px;
							background-color: #fff;
							> p {
								font-size: min(1.0rem, 5vw);
								line-height: 1.8;
								color: var(--color-accent);
								font-weight: 600;
							}
							> img {
							}
						}
					}
				}
			}
		}
	}
}
section.lecture {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		padding-bottom: 80px;
		border-bottom: 1px solid #808080;
		margin-inline: auto;
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: var(--color-accent);
			font-weight: 700;
			letter-spacing: 3px;
			text-align: center;
		}
		> div {
			padding-top: 40px;
			display: grid;
			grid-template-columns: 3fr 1fr;
			column-gap: 50px;
			@media (width < 900px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 50px;
			}
			> article {
				@media (width < 900px) {
					order: 2;
				}
				> p {
					text-align: justify;
					font-size: min(1.0rem, 5vw);
					line-height: 1.8;
					color: #333;
					margin-bottom: 30px;
				}
				> div {
					display: flex;
					justify-content: end;
					align-items: end;
					column-gap: 15px;
					@media (width < 410px) {
						column-gap: 5px;
					}
					> p {
						font-family: var(--font-serif);
						font-size: min(1.6rem, 6vw);
						line-height: 1.8;
						color: #333;
						font-weight: 700;
						> small {
							font-size: min(0.9rem, 5vw);
						}
					}
					> img {
						width: 60px;
						@media (width < 410px) {
							width: 40px;
						}
					}
				}
			}
			> figure {
				text-align: center;
				@media (width < 900px) {
					order: 1;
				}
				> img {
					max-width: 100%;
				}
			}
		}
	}
}
section.join01 {
	padding: 80px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: var(--color-accent);
			font-weight: 700;
			letter-spacing: 3px;
			text-align: center;
		}
		> div {
			padding-top: 40px;
			display: grid;
			grid-template-columns: 1fr 1fr;
			column-gap: 50px;
			@media (width < 900px) {
				grid-template-columns: repeat(1, 1fr);
				row-gap: 50px;
			}
			> article {
				display: grid;
				&:nth-of-type(1) {
					> h4 {
						color: #0a9e46;
						border-bottom: 1px solid #0a9e46;
					}
					> div {
						border: 1px solid #0a9e46;
						> h5 {
							color: #0a9e46;
						}
						> a {
							text-decoration: underline var(--color-accent);
							&:hover {
								opacity: 0.8;
							}
							> p {
								color: var(--color-accent);
								text-align: center;
								font-size: min(1.0rem, 5vw);
								line-height: 1.0;
							}
						}
					}
				}
				&:nth-of-type(2) {
					> h4 {
						color: var(--color-accent);
						border-bottom: 1px solid var(--color-accent);
					}
					> div {
						display: grid;
						border: 1px solid var(--color-accent);
						> h5 {
							color: var(--color-accent);
						}
						> a {
							justify-self: center;
							text-decoration: none;
							&[target="_blank"] > div {
								background: url(./common/image/mark_external_d00.svg) #fff;
								background-repeat: no-repeat;
								background-position: right 25px top 50%;
								&:hover {
									background: url(./common/image/mark_external_fff.svg) var(--color-accent);
									background-repeat: no-repeat;
									background-position: right 25px top 50%;
									> p {
										color: #fff;
									}
								}
							}
							&:hover {
								opacity: 0.8;
								> div {
									background: url(./image/link_about_fff.svg) var(--color-accent);
									background-repeat: no-repeat;
									background-size: 5px;
									background-position: calc(100% - 25px) 50%;
									> p {
										color: #fff;
									}
								}
							}
							> div {
								margin-bottom: 10px;
								min-width: 260px;
								border: 2px solid var(--color-accent);
								align-items: center;
								column-gap: 30px;
								padding: 15px 60px;
								background: url(./image/link_about.svg) #fff;
								background-repeat: no-repeat;
								background-position: right 25px top 50%;
								@media (width < 400px) {
									min-width: unset;
									padding: 15px 40px;
									min-width: 220px;
								}
								> p {
									font-size: min(1.0rem, 5vw);
									line-height: 1.8;
									color: var(--color-accent);
									font-weight: 600;
									text-align: center;
								}
							}
						}
					}
				}
				> h4 {
					position: relative;
					z-index: 2;
					justify-self: center;
					align-self: start;
					padding: 10px 20px;
					background-color: #fff;
					font-size: min(1.6rem, 7vw);
					line-height: 1.3;
					font-weight: 700;
					letter-spacing: 1px;
					text-align: center;
				}
				> div {
					position: relative;
					z-index: 1;
					margin-top: -25px;
					border-radius: 20px;
					padding: 30px;
					> h5 {
						padding-block: 10px;
						font-size: min(1.3rem, 6vw);
						line-height: 1.5;
						font-weight: 700;
						text-align: center;
					}
					> p {
						text-align: center;
						font-size: min(1.0rem, 5vw);
						line-height: 1.8;
						color: #333;
						padding-bottom: 20px;
						@media (width < 400px) {
							text-align: justify;
							> br {
								display: none;
							}
						}
					}
					> figure {
						padding-top: 20px;
						text-align: center;
						> img {
							width: 130px;
						}
					}
				}
			}
		}
	}
}
section.join02 {
	padding: 0px 5% 80px 5%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: #333;
			font-weight: 700;
			letter-spacing: 3px;
			text-align: center;
		}
		> dl {
			padding-top: 50px;
			> div {
				display: grid;
				grid-template-columns: 120px 1fr;
				&:first-child {
					> dt {
						border-top: 1px solid #808080;
					}
					> dd {
						border-top: 1px solid #808080;
						@media (width < 770px) {
							border-top: none;
						}
					}
				}
				&:nth-of-type(2) {
					> dd {
						padding: unset;
						> div {
							padding: 5px 0px 10px 0px;
							margin-left: 40px;
							@media (width < 770px) {
								margin-left: 0px;
								padding: 20px 0px 20px 0px;
								&:last-of-type {
									padding: 20px 0px 90px 0px;
								}
							}
						}
					}
				}
				@media (width < 770px) {
					grid-template-columns: 1fr;
					height: auto;
				}
				> dt {
					align-content: center;
					font-size: min(1.3rem, 6vw);
					line-height: 1.3;
					color: #333;
					font-weight: 600;
					padding: 10px 0px 10px 0px;
					border-bottom: 1px solid #808080;
					@media (width < 770px) {
						border-top: 1px solid #808080;
						line-height: 1.1;
						text-align: center;e
						&:empty {
							border-top: 1px solid #808080;
							border-bottom: none;
							padding: 0px 40px 0px 40px;
						}
					}
				}
				> dd {
					position: relative;
					align-content: center;
					border-bottom: 1px solid #808080;
					color: #333;
					font-size: min(1.2rem, 6vw);
					font-weight: 600;
					line-height: 1.8;
					padding: 10px 40px 10px 40px;
					> span {
						color: var(--color-accent);
						font-size: min(1.6rem, 6vw);
						> b {
							font-size: min(1.1rem, 5vw);
						}
					}
					> b {
						font-size: min(1.1rem, 5vw);
					}
					> div {
						display: flex;
						align-items: end;
						column-gap: 5px;
						&:nth-of-type(1) {
							border-bottom: 1px dotted #808080;
						}
						> h6 {
							background-color: var(--color-accent);
							padding: 3px 14px;
							border-radius: 30px;
							color: #fff;
							font-size: min(1.2rem, 5.5vw);
						}
						> p {
							color: #333;
							font-size: min(1.6rem, 6vw);
							font-weight: 600;
							line-height: 1.8;
							> span {
								color: var(--color-accent);
								> b {
									font-size: min(1.1rem, 5vw);
								}
							}
							> b {
								font-size: min(1.1rem, 5vw);
							}
						}
					}
					> picture {
						position: absolute;
						top: 20%;
						right: 0;
						@media (width < 770px) {
							top: unset;
							right: unset;
							bottom: 15px;
							left: 50%;
							transform: translateX(-50%);
						}
						> img {
							width: 210px;
						}
					}
					@media (width < 770px) {
						border: none;
						padding: 30px 0px 30px 0px;
					}
				}
			}
		}
	}
}
section.application {
	padding: 80px 5% 80px 5%;
	background: url(./image/application_bg.webp);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-position: 0% 0%;
	> div {
		padding: 50px;
		max-width: 1000px;
		margin-inline: auto;
		background-color: rgba(255,255,255, 0.85);
		border-radius: 30px;
		@media (width < 550px) {
			padding: 20px 20px 40px 20px;
		}
		> figure {
			text-align: center;
			> img {
				max-width: 100%;
			}
		}
		> h3 {
			padding-block: 20px;
			font-size: min(2.0rem, 8vw);
			line-height: 1.5;
			color: var(--color-accent);
			font-weight: 700;
			letter-spacing: 3px;
			text-align: center;
		}
		> div.link {
			max-width: 600px;
			margin-inline: auto;
			> figure {
				> img {
					max-width: 100%;
				}
			}
			> a {
				text-decoration: none;
				&:hover {
					opacity: 0.8;
				}
				> div {
					margin-top: 25px;
					background: url(./image/link_button_fff.svg) var(--color-accent);
					background-repeat: no-repeat;
					background-size: 40px;
					background-position: calc(100% - 20px) 50%;
					padding: 20px 80px;
					border-radius: 30px;
					@media (width < 550px) {
						padding: 20px 50px;
						background-size: 30px;
					}
					> p {
						font-size: min(1.6rem, 5vw);
						line-height: 1.2;
						color: #fff;
						font-weight: 600;
						letter-spacing: 1px;
						text-align: center;
						> b {
							color: var(--color-accent);
						}
					}
				}
			}
		}
		> div.flow {
			margin-top: 40px;
			padding-top: 30px;
			border-top: 1px solid #808080;
			max-width: 700px;
			margin-inline: auto;
			> h4 {
				padding-bottom: 10px;
				font-size: min(1.6rem, 7vw);
				line-height: 1.5;
				color: #333;
				font-weight: 700;
				letter-spacing: 3px;
				text-align: center;
			}
			> div.list {
				display: grid;
				justify-content: center;
				> p {
					font-size: 1.2rem;
					line-height: 1.4;
					color: #333333;
					font-weight: 600;
					padding-left: 2.5em;
					text-indent: -2.5em;
					> span {
						font-size: 2.0rem;
						color: var(--color-accent);
					}
				}
			}
			> div.link {
				margin-top: 25px;
				text-align: center;
				> a {
					text-decoration: none;
					display: inline-block;
					background-image: url(./common/image/mark_external.svg);
					background-repeat: no-repeat;
					background-position: 100% 50%;
					padding-right: 20px;
					font-size: 1rem;
					line-height: 1.3;
					color: #222;
					&:hover {
						text-decoration: underline;
					}
				}
			}
		}
	}
}


