section.switchpanel {
	overflow: hidden;
	&.off {
		max-height: 0;
	}
	> div {
		max-width: 1800px;
		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) {
					visibility: hidden;	/*---*/
					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 10px 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 {
								padding-inline: 5px;
								width: 100%;
								border-radius: 20px;
							}
						}
						> 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 {
								padding: 5px;
								width: 100%;
								border-radius: 20px;
							}
						}
						> a {
							grid-area: 1/1/2/2;
							text-decoration: none;
							&:hover {
								opacity: 0.7;
							}
							> img {
							}
						}
					}
				}
			}
		}
	}
}
section.about {
	padding: 80px 7% 80px 7%;
	background-image: url(./image/wave_bg02.svg);
	background-repeat: repeat-x;
	background-size: auto;
	background-position: 100% 100px;
	min-height: 933px;	
	@media (width < 1300px) {
		background-image: url(./image/wave_bg01.svg);
		background-repeat: no-repeat;
		background-size: 100% auto;
		background-position: 100% 100px;
		min-height: unset;
	}
	@media (width < 960px) {
		background-image: unset;
		background-color: #fff;
		padding: 0px 7% 0px 7%;
		margin-block: 80px;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.title {
			text-align: center;
			padding-bottom: 60px;
			> h1 {
				font-size: 2.8rem;
				line-height: 1.8;
				color: #333;
				font-family: var(--font-en);
				font-weight: 400;
			}
			> p {
				font-size: 1.1rem;
				line-height: 1;
				color: #333;
			}
		}
		> div.content {
			display: grid;
			grid-template-columns: 2fr 2.5fr;
			@media (width < 960px) {
				grid-template-columns: 1fr;
			}
			> div:nth-of-type(1) {
				position: relative;
				> div {
					position: relative;
					z-index: 3;
					> h2 {
						font-size: 1.6em;
						line-height: 1;
						color: #333;
					}
					> p {
						padding-top: 20px;
						font-size: 1.0rem;
						line-height: 1.8;
						color: #333;
						text-align: justify;
						letter-spacing: 0.05em;
					}
				}
				> picture {
					&:nth-of-type(1) {
						position: absolute;
						z-index: 2;
						top: 50%;
						left: 38%;
						width: 170px;
						@media (width < 1250px) {
							top: unset;
							left: -15%;
							bottom: -5%;
						}
						@media (width < 960px) {
							bottom: unset;
							top: -40%;
							left: unset;
							right: -8%;
						}
						@media (width < 460px) {
							display: none;
						}
					}
					&:nth-of-type(2) {
						position: absolute;
						z-index: 2;
						bottom: 10%;
						right: -20%;
						width: 130px;
						@media (width < 960px) {
							display: none;
						}
					}
					&:nth-of-type(3) {
						position: absolute;
						z-index: 1;
						top: -12%;
						left: -18%;
						width: min(15vw, 170px);
						@media (width < 960px) {
							top: -65px;
							left: -65px;
							width: 130px;
						}
					}
					> img {
						max-width: 100%;
					}
				}
			}
			> div:nth-of-type(2) {
				position: relative;
				justify-self: center;
				@media (width < 960px) {
					padding-block: 40px;
				}
				> picture {
					@media (width < 960px) {
						display: flex;
						justify-content: center;
					}
					> img {
						margin-left: 8%;
						max-width: 100%;
						@media (width < 960px) {
							margin-left: 0%;
						}
					}
				}
			}
		}
	}
}
section.news {
	padding: 10px 7% 30px 7%;
	> div {
		> div.title {
			text-align: center;
			> h1 {
				font-size: 2.8rem;
				line-height: 1.8;
				color: #333;
				font-family: var(--font-en);
				font-weight: 400;
			}
			> p {
				font-size: 1.1rem;
				line-height: 1;
				color: #333;
			}
		}
	}
}
section.inform {
	padding: 10px 7% 10px 7%;
	background-color: rgba(255,255,255,0.8);
	> div {
		max-width: 1200px;
		margin-inline: auto;
		> div#informArea {
			margin-top: 10px;
			> .content {
				margin-top: 15px;
				> div {
					> a {
						text-decoration: none;
						display: block;
						border-bottom: dotted 1px #aaa;
						padding-block: 10px;
						padding-right: 25px;
						&:hover {
							opacity: 0.7;
						}
						> dl {
							display: grid;
							grid-template-columns: 1fr 100px 60px;
							align-items: center;
							@media (width < 600px) {
								grid-template-columns: 1fr 100px;
							}
							@media (width < 400px) {
								grid-template-columns: 1fr 50px;
							}
							> dt {
								align-self: start;
								padding-right: 20px;
								> div.categorydate {
									display: flex;
									align-items: center;
									column-gap: 10px;
									> ce-inform-category {
									}
									> div {
										font-size: 0.9rem;
										line-height: 1.3;
										color: #111;
									}
								}
								> div.subject {
									margin-top: 5px;
									font-size: min(0.9rem,5vw);
									line-height: 1.6;
									color: #000;
								}
							}
							> dd:nth-of-type(1) {
								> img {
									max-width: 100%;
								}
							}
							> dd:nth-of-type(2) {
								text-align: right;
								@media (width < 600px) {
									display: none;
								}
								> img {
									max-width: 100%;
								}
							}
						}
					}
				}
			}
			> .empty {
				background-color: #eee;
				text-align: center;
				font-size: 0.9;
				line-height: 1.3;
				color: #888;
				padding: 20px;
			}
		}
	}
}
section.button {
	padding: 30px 7% 80px 7%;
	&.shoplist {
		padding: 80px 7% 80px 7%;
		background-color: #fff;
	}
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div {
			max-width: 400px;
			margin-inline: auto;
			> a {
				text-decoration: none;
				text-align: center;
				&:hover {
					opacity: 0.8;
				}
				> p {
					padding-block: 20px;
					border-radius: 60px;
					text-align: center;
					background: linear-gradient(to bottom,#9c626a, #9c626a 50%, #8F5960 50%, #8F5960);
					font-size: 1.8rem;
					line-height: 1;
					color: #fff;
					font-family: var(--font-en);
					font-weight: 400;
					@media (width < 500px) {
						padding-block: 20px;
						border-radius: 40px;
					}
				}
			}
		}
	}
}
section.menu {
	padding: 80px 7% 80px 7%;
	position: relative;
	width: 100%;
	height: 100%;
	> div.bg-rectangle {
		position: absolute;
		top: 350px;
		left: 0;
		width: 100%;
		height: calc(100% - 350px);
	}  
	> div.bg-ellipse {
		position: absolute;
		top: 0;
		left: 50%;
		width: 100%;
		height: 350px;
		border-radius: 50%;
		transform: translateX(-50%);
		border-top-left-radius: 950px 400px;
		border-top-right-radius: 950px 400px;
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
	}
	> div.bg-ellipse, div.bg-rectangle {
		background-color: #e2cecd;
		mix-blend-mode: multiply;
		opacity: 0.5;
		z-index: 1;
	}
	> div.main {
		position: relative;
		z-index: 2;
		max-width: 800px;
		margin-inline: auto;
		> div.title {
			text-align: center;
			padding-bottom: 60px;
			> h1 {
				font-size: 2.8rem;
				line-height: 1.8;
				color: #333;
				font-family: var(--font-en);
				font-weight: 400;
			}
			> p {
				font-size: 1.1rem;
				line-height: 1;
				color: #333;
			}
		}
		> div.content {
			> article {
				margin-bottom: 30px;
				background-color: #e6e6e6;
				padding: 10px;
				border-radius: 8px;
				display: grid;
				grid-template-columns: repeat(2, 1fr);
				overflow: hidden;
				@media (width < 760px) {
					grid-template-columns: repeat(1, 1fr);
				}
				> div {
					background-color: #fff;
					> h2 {
						padding: 15px;
						font-size: 1.8rem;
						line-height: 1.2;
						color: #333;
					}
					> h3 {
						padding-left: 15px;
						font-size: 1.6rem;
						line-height: 2.0;
						font-weight: 400;
						color: #333;
						font-family: var(--font-en);
						font-weight: 400;
						&.item01 {
							background-color: rgba(226, 206, 205, 0.6);
						}
						&.item02 {
							background-color: rgba(228, 207, 189, 0.6);
						}
						&.item03 {
							background-color: rgba(235, 224, 184, 0.6);
						}
					}
					> h4 {
						padding: 20px 15px 0px 15px;
						font-size: 1.1rem;
						line-height: 1.8;
						font-weight: 600;
						text-align: left;
						letter-spacing: 0.05em;
					}
					> p {
						padding: 5px 15px 15px 15px;
						font-size: 1.0rem;
						line-height: 1.8;
						color: #333;
						letter-spacing: 0.05em;
						@media (width < 760px) {
							padding: 20px;
							text-align: left;
						}
					}
					> figure {
						margin: 30px;
						justify-self: end;
						background-color: #ebe0e1;
						padding: 10px;
						border-radius: 14px;
						> img {
							background-color: #fff;
							padding: 10px;
							border-radius: 8px;
							max-width: 100%;
						}
						@media (width < 760px) {
							margin: 20px;
						}
					}
					&:nth-of-type(1) {
						@media (width < 760px) {
							order: 2;
						}
					}
					&:nth-of-type(2) {
						@media (width < 760px) {
							order: 1;
							display: flex;
							justify-content: center;
						}
					}
				}
			}
		}
	}
}
section.shoplist {
	padding: 80px 7% 0px 7%;
	background-color: #fff;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> div.title {
			text-align: center;
			padding-bottom: 60px;
			> h1 {
				font-size: 2.8rem;
				line-height: 1.8;
				color: #333;
				font-family: var(--font-en);
				font-weight: 400;
			}
			> p {
				font-size: 1.1rem;
				line-height: 1;
				color: #333;
			}
		}
		> div.content {
			> h2 {
				text-align: center;
				background-color: rgba(156, 98, 106, 0.3);
				font-size: 1.3rem;
				line-height: 2.4;
				color: #333;
			}
			> figure {
				padding-block: 20px;
				> img {
					margin-inline: auto;
					max-width: 520px;
					display: flex;
					justify-content: center;
					@media (width < 650px) {
						max-width: 100%;
					}
				}
			}
			> article {
				padding-top: 30px;
				> div {
					border-bottom: 2px dotted #666;
					display: grid;
					grid-template-columns: 110px 1fr;
					padding-block: 10px;
					> h3 {
						font-size: 1rem;
						line-height: 1.6;
						color: #333;
						font-weight: 500;
						@media (width < 650px) {
							text-align: center;
							border-top: 2px dotted #666;
							border-bottom: 2px dotted #666;
							padding-block: 5px;
						}
					}
					> p {
						padding-block: 5px;
						font-size: min(0.9rem,5vw);
						line-height: 1.6;
						color: #333;
					}
					&:nth-of-type(1) {
						border-top: 2px dotted #666;
						@media (width < 650px) {
							border-top: none;
						}
					}
					@media (width < 650px) {
						grid-template-columns: 1fr;
						border: none;
						padding-bottom: 30px;
					}
				}
			}
			> iframe {
				padding-top: 80px;
				width: 100%;
				height: 500px;
				border: none;
			}
		}
	}
}
section.link01 {
	padding: 80px 7% 20px 7%;
	> div {
		max-width: 1000px;
		margin-inline: auto;
		> article {
			display: grid;
			grid-template-columns: 1.5fr 1fr;
			> picture {
				grid-area: 1/1/2/3;
				> img {
					max-width: 100%;
				}
			}
			> div.button {
				grid-area: 1/1/2/2;
				max-width: 100%;
				width: 80%;
				margin-inline: auto;
				align-self: end;
				margin-bottom: 7%;
				@media (width < 480px) {
					grid-area: 1/1/2/3;
					padding-inline: 5%;
					width: 100%;
					margin-bottom: 10%;
				}
				> a {
					text-decoration: none;
					text-align: center;
					&:hover {
						opacity: 0.8;
					}
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
section.link02 {
	padding: 0px 0% 80px 0%;
	> div {
		max-width: 1100px;
		margin-inline: auto;
		> article {
			display: grid;
			> picture {
				grid-area: 1/1/2/2;
				> img {
					max-width: 100%;
				}
			}
			> div.button {
				grid-area: 1/1/2/2;
				align-self: end;
				margin-bottom: 8%;
				justify-self: center;
				width: 50%;
				text-align: center;
				@media (width < 480px) {
					padding-inline: 10%;
					width: 100%;
					margin-bottom: 10%;
				}
				> a {
					display: inline-block;
					text-decoration: none;
					max-width: 400px;
					&:hover {
						opacity: 0.8;
					}
					> img {
						max-width: 100%;
					}
				}
			}
		}
	}
}
