section.switchpanel {
	background-color: #eee;
	> div {
		max-width: 1920px;
		margin: 0 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;
						> 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 {
					display: grid;
					> a {
						grid-area: 1/1/2/2;
						z-index: 2;
						margin-bottom: min(7vw,90px);
						text-decoration: none;
						text-align: center;
						&:hover {
							opacity: 0.7;
						}
						> img {
							width: 150%;
							@media (width < 700px) {
								width: 120%;
							}
						}
					}
					> picture {
						grid-area: 1/1/2/2;
						> img {
							width: 100%;
						}
					}
				}
			}
		}
		/*
		> #switchPanelThums {
			padding: 0 5px 10px 5px;
			display: flex;
			justify-content: center;
			user-select: none;
			overflow-x: auto;
			@media (width < calc(4 * 150px + 10px)) {	/ *パネルの枚数で調整* /
				justify-content: left;
			}
			> div {
				width: 300px;
				min-width: 150px;
				&.on {
					> div {
						opacity: 1;
					}
					> img {
						border: solid 2px #333;
					}
				}
				> div {
					opacity: 0;
					> img {
						display: block;
						margin-inline: auto;
						@media (width < 700px) {
							width: min(30px,4vw);
						}
					}
				}
				> img {
					border: solid 2px #fff;
					width: 100%;
					cursor: pointer;
				}
			}
		}
		*/
	}
}
/*
japanpride
*/
section.japanpride {
	height: 600px;
	text-align: center;
	background-image: url(./image/japanprideback.jpg);
	background-size: cover;
	background-position: 30% 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	@media (width < 450px) {
		height: 400px;
	}
	> div {
		> div {
			font-size: 30px;
			line-height: 1.2;
			color: #333;
		}
		> p {
			margin: 20px 0 80px 0;
			font-size: 16px;
			line-height: 2.5;
			color: #333;
			@media (width < 450px) {
				font-size: 14px;
			}
			@media (width < 390px) {
				font-size: 12px;
			}
			@media (width < 320px) {
				font-size: 11px;
			}
		}
	}
}
/*
news
*/
section.news {
	padding: 80px 5% 0 5%;
	> div {
		text-align: center;
		> h2 {
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div {
			display: inline-block;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			border-top: solid 4px #333;
			padding: 10px 0 0 0;
			margin: 10px 0 0 0;
		}
	}
}
/*
news02
*/
section.news02 {
	padding: 30px 5% 0 5%;
	> div {
		max-width: 960px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
		@media (width < 1010px) {
			flex-direction: column;
			align-items: center;
		}
		> a {
			max-width: 280px;
			text-decoration: none;
			margin: 0 0 30px 0;
			&:hover {
				opacity: 0.7;
			}
			> div {
				display: flex;
				justify-content: space-between;
				align-items: flex-end;
				&:nth-of-type(1) {
					font-size: 15px;
					line-height: 1;
					color: #333;
				}
				&:nth-of-type(2) {}
			}
			> figure {
				text-align: center;
				margin: 5px 0 0 0;
				> img {
					max-height: 210px;
					max-width: 100%;
				}
			}
			> p {
				font-size: 15px;
				line-height: 1.5;
				color: #333;
				margin: 5px 0 0 0;
			}
		}
	}
}
/*
product
*/
section.product {
	padding: 100px 5% 0 5%;
	> div {
		text-align: center;
		> h2 {
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div {
			display: inline-block;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			border-top: solid 4px #333;
			padding: 10px 0 0 0;
			margin: 10px 0 0 0;
		}
		> p {
			margin-top: 15px;
			font-size: min(1.1rem, 5vw);
			line-height:2.4;
			color: #000;
			letter-spacing: 1px;
		}
	}
}
/*
newpiano
*/
section.newpiano {
	padding: 50px 5% 0px 5%;
	> div {
		border-bottom: 1px solid #c9c7c5;
		max-width: 960px;
		padding-bottom: 100px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div.item {
			text-align: center;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			padding: 10px 0 0 0;
		}
		> div.content {
			> div {
				display: grid;
				grid-template-columns: 2.4fr 1fr;
				@media (width < 980px) {
					grid-template-columns: 1fr;
					row-gap: 40px;
				}
				> figure {
					margin: 0;
					justify-self: end;
					@media (width < 980px) {
						justify-self: center;
					}
					> img {
						max-width: 100%;
					}
					> div {
						display: grid;
						justify-content: center;
						@media (width < 600px) {
							justify-content: left;
						}
						> h3 {
							margin: 0;
							padding: 0px 20px;
							border-left: 5px solid #333;
							font-size: min(1.5rem, 6vw);
							line-height: 1.0;
							color: #333;
							font-weight: 500;
						}
						> h4 {
							margin: 8px 0 0 0;
							padding-inline: 25px;
							font-size: min(1.0rem, 5vw);
							line-height: 1.3;
							color: #333;
							font-weight: 500;
						}
					}
				}
				> div {
					justify-self: start;
					align-self: end;
					margin-bottom: 80px;
					@media (width < 980px) {
						justify-self: center;
					}
					@media (width < 600px) {
						justify-self: left;
					}
					> p {
						margin: 0;
						font-size: min(1rem,4.5vw);
						line-height: 1.8;
						color: #333;
						&:nth-of-type(1) {
							color: #000;
							font-weight: 600;
						}
					}
				}
			}
		}
	}
}
/*
pianochair01
*/
section.pianochair01 {
	padding: 100px 5% 0px 5%;
	> div {
		max-width: 960px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div.item {
			text-align: center;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			padding: 10px 0 0 0;
		}
		> div.content {
			padding-top: 60px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 20px;
			@media (width < 900px) {
				grid-template-columns: 1fr;
				row-gap: 80px;
			}
			> article {
				display: grid;
				justify-self: center;
				&:nth-of-type(3) {
					align-self: end;
					margin-bottom: 80px;
				}
				> figure {
					margin: 0;
					> img {
						max-width: 100%;
					}
				}
				> h3 {
					margin: 0;
					padding: 0px 20px;
					border-left: 5px solid #333;
					font-size: min(1.5rem, 6vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
				}
				> h4 {
					margin: 8px 0 0 0;
					padding-inline: 25px;
					font-size: min(1.0rem, 5vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
				}
				> p {
					margin: 0;
					font-size: min(1rem,4.5vw);
					line-height: 1.8;
					color: #333;
					&:nth-of-type(1),&:nth-of-type(3) {
						color: #000;
						font-weight: 600;
					}
				}
			}
		}
	}
}
/*
pianochair02
*/
section.pianochair02 {
	padding: 100px 5% 0px 5%;
	> div {
		border-bottom: 1px solid #c9c7c5;
		max-width: 960px;
		padding-bottom: 100px;
		margin-inline: auto;
		> div.content {
			padding-top: 40px;
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			column-gap: 50px;
			row-gap: 80px;
			@media (width < 840px) {
				grid-template-columns: repeat(2, 1fr);
			}
			@media (width < 550px) {
				grid-template-columns: repeat(1, 1fr);
			}
			> article {
				display: grid;
				justify-self: center;
				> figure {
					margin: 0;
					> img {
						max-width: 100%;
					}
				}
				> h3 {
					margin: 0;
					padding: 0px 20px;
					border-left: 5px solid #333;
					font-size: min(1.5rem, 6vw);
					line-height: 1.2;
					color: #333;
					font-weight: 500;
				}
				> h4 {
					margin: 4px 0 0 0;
					padding-inline: 25px;
					font-size: min(1.0rem, 5vw);
					line-height: 1.3;
					color: #333;
					font-weight: 500;
				}
				> p {
					margin: 0;
					font-size: min(0.9rem,4.5vw);
					line-height: 1.8;
					color: #333;
					&:nth-of-type(1),&:nth-of-type(3) {
						color: #000;
						font-weight: 600;
					}
				}
			}
		}
	}
}
/*
pianochair03
*/
section.pianochair03 {
	padding: 100px 5% 0px 5%;
	> div {
		border-bottom: 1px solid #c9c7c5;
		max-width: 1000px;
		padding-bottom: 100px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div.item {
			text-align: center;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			padding: 10px 0 0 0;
		}
		> div.content {
			padding-top: 80px;
			> div {
				display: grid;
				grid-template-columns: 1.4fr 1fr;
				column-gap: 40px;
				@media (width < 980px) {
					grid-template-columns: 1fr;
					row-gap: 40px;
				}
				> figure {
					margin: 0;
					justify-self: end;
					@media (width < 980px) {
						justify-self: center;
					}
					> img {
						max-width: 100%;
					}
					> div {
						padding-top: 20px;
						display: grid;
						justify-content: start;
						@media (width < 980px) {
							justify-content: center;
						}
						@media (width < 600px) {
							justify-content: start;
						}
						> h3 {
							margin: 0;
							padding: 0px 20px;
							border-left: 5px solid #333;
							font-size: min(1.5rem, 6vw);
							line-height: 1.3;
							color: #333;
							font-weight: 500;
						}
						> h4 {
							margin: 8px 0 0 0;
							padding-inline: 25px;
							font-size: min(1.0rem, 5vw);
							line-height: 1.3;
							color: #333;
							font-weight: 500;
						}
					}
				}
				> div {
					margin-bottom: 100px;
					justify-self: start;
					align-self: end;
					@media (width < 980px) {
						justify-self: center;
					}
					@media (width < 600px) {
						justify-self: start;
					}
					> p {
						margin: 0;
						font-size: min(1rem,4.5vw);
						line-height: 1.8;
						color: #333;
						&:nth-of-type(1) {
							color: #000;
							font-weight: 600;
						}
					}
				}
			}
		}
	}
}
/*
pianochair04
*/
section.pianochair04 {
	padding: 100px 5% 100px 5%;
	> div {
		max-width: 960px;
		margin-inline: auto;
		> h2 {
			text-align: center;
			margin: 0;
			font-size: 30px;
			line-height: 1.2;
			color: #333;
			letter-spacing: 0.1em;
		}
		> div.item {
			text-align: center;
			font-size: 18px;
			line-height: 1.2;
			color: #333;
			padding: 10px 0 0 0;
		}
		> div.content {
			> div {
				max-width: 700px;
				margin-inline: auto;
				> figure {
					margin: 0;
					padding-top: 60px;
					> img {
						max-width: 100%;
					}
				}
			}
			> article {
				padding-top: 40px;
				max-width: 700px;
				margin-inline: auto;
				> h3 {
					margin: 0;
					padding: 8px 20px;
					border-left: 5px solid #333;
					font-size: min(1.5rem, 6vw);
					line-height: 1.0;
					color: #333;
					font-weight: 500;
				}
			}
		}
	}
}
/*
ordermade
*/
section.ordermade {
	height: 700px;
	background-image: url(./image/ordermadeback.jpg);
	background-size: cover;
	background-position: 50% 50%;
	padding: 0 5%;
	> div {
		max-width: 1200px;
		margin: 0 auto;
		> div {
			text-align: center;
			padding: 100px 0 0 0;
			> h2 {
				margin: 0;
				font-size: 30px;
				line-height: 1.2;
				color: #fff;
				letter-spacing: 0.1em;
			}
			> div {
				display: inline-block;
				font-size: 18px;
				line-height: 1.2;
				color: #fff;
				border-top: solid 4px #fff;
				padding: 10px 0 0 0;
				margin: 10px 0 0 0;
			}
			> p {
				margin: 30px 0 0 0;
				font-size: 15px;
				line-height: 2.5;
				color: #fff;
			}
		}
	}
}
/*
access
*/
section.access {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div {
		display: inline-block;
		font-size: 18px;
		line-height: 1.2;
		color: #333;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
	}
}
/*
access02
*/
section.access02 {
	padding: 30px 0 0 0;
	> div {
		position: relative;
		height: 0;
		width: 100%;
		padding-bottom: 500px;
		> div {
			position: absolute;
			width: 100%;
			height: 100%;
		}
		> iframe {
			position: absolute;
			width: 100%;
			height: 100%;
		}
	}
}
/*
access03
*/
section.access03 {
	padding: 20px 5% 0 5%;
	text-align: center;
	> div {
		display: inline-block;
		text-align: left;
		> p {
			margin: 5px 0 0 0;
			font-size: 15px;
			line-height: 1.5;
			color: #333;
			margin-left: 1em;
			text-indent: -1em;
			@media (max-width:499px) {
				font-size: 13px;
			}
		}
	}
}
/*
access04
*/
section.access04 {
	padding: 30px 0 0 0;
	text-align: center;
	> a:hover {
		opacity: 0.7;
	}
}
/*
profile
*/
section.profile {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div {
		display: inline-block;
		font-size: 18px;
		line-height: 1.2;
		color: #333;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
	}
}
/*
profile02
*/
section.profile02 {
	height: 600px;
	background-image: url(./image/profileback.jpg);
	background-size: cover;
	background-position: 85% 50%;
	margin: 20px 0 0 0;
	@media (max-width:969px) {
		height: 300px;
	}
}
/*
profile03
*/
section.profile03 {
	padding: 0 5%;
	> div {
		max-width: 650px;
		margin: 0 auto;
		> table {
			border-collapse: collapse;
			margin: 30px 0 0 0;
			tr {
				th {
					font-weight: normal;
					font-size: 15px;
					line-height: 1.5;
					color: #333;
					padding: 4px 10px 4px 0;
					border-right: solid 1px #333;
					vertical-align: top;
					width: 6em;
					text-align-last: justify;
					text-align: justify;
					text-justify: inter-ideograph;
				}
				td {
					font-size: 15px;
					line-height: 1.5;
					color: #333;
					padding: 4px 0 4px 10px;
					vertical-align: top;
					> div:nth-of-type(2) {
						font-size: 10px;
					}
					a {
						text-decoration: underline;
						color: #333;
						&:hover {
							opacity: 0.6;
						}
						&[target="_blank"]:after {
							content: url(./common/image/icon_external_888.svg);
							margin: 0 3px;
						}
					}
				}
			}
		}
	}
}
@media (max-width:759px) {
	section.profile03 > div > table tr th {
		font-size: 13px;
	}
	section.profile03 > div > table tr td {
		font-size: 13px;
	}
}
@media (max-width:659px) {
	section.profile03 > div > table tr th {
		font-size: 12px;
	}
	section.profile03 > div > table tr td {
		font-size: 12px;
	}
	section.profile03 > div > table tr td > br {
		display: none;
	}
}
/*
history
*/
section.history {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div {
		display: inline-block;
		font-size: 18px;
		line-height: 1.2;
		color: #333;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
	}
}
/*
history02
*/
section.history02 {
	padding: 0 5%;
	> div {
		max-width: 650px;
		margin: 0 auto;
		> table {
			border-collapse: collapse;
			margin: 30px 0 0 0;
			tr {
				th {
					font-weight: normal;
					font-size: 15px;
					line-height: 1.5;
					color: #333;
					padding: 4px 10px 4px 0;
					border-right: solid 1px #333;
					vertical-align: top;
					width: 6em;
					text-align: left;
				}
				td {
					font-size: 15px;
					line-height: 1.5;
					color: #333;
					padding: 4px 0 4px 10px;
					vertical-align: top;
				}
			}
		}
	}
}
@media (max-width:759px) {
	section.history02 > div > table tr th {
		font-size: 13px;
	}
	section.history02 > div > table tr td {
		font-size: 13px;
	}
}
@media (max-width:659px) {
	section.history02 > div > table tr th {
		font-size: 12px;
	}
	section.history02 > div > table tr td {
		font-size: 12px;
	}
}
/*
contact
*/
section.contact {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div:nth-of-type(1) {
		display: inline-block;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
		width: 50px;
	}
	> div:nth-of-type(2) {
		font-size: 18px;
		line-height: 1.2;
		color: #333;
	}
}
/*
contact02
*/
section.contact02 {
	padding: 0 5%;
	margin: 50px 0 0 0;
	> div {
		max-width: 880px;
		margin: 0 auto;
		> p {
			font-size: 17px;
			line-height: 1.7;
			color: #333;
		}
		> div {
			display: flex;
			justify-content: space-between;
			> div {
				background-color: #eee;
				width: 420px;
				box-sizing: border-box;
				display: flex;
				flex-direction: column;
				align-items: center;
				padding: 30px 0;
				> div {
					font-size: 18px;
					line-height: 1;
					color: #333;
				}
				> h3 {
					margin: 15px 0 0 0;
					font-size: 30px;
					line-height: 1;
					color: #333;
					font-weight: 600;
				}
				> p {
					margin: 10px 0 0 0;
					font-size: 14px;
					line-height: 1.5;
					color: #333;
					text-align: center;
				}
			}
		}
	}
}
@media (max-width:969px) {
	section.contact02 > div > div {
		flex-direction: column;
		align-items: center;
	}
	section.contact02 > div > div > div {
		margin: 7px 0;
	}
}
@media (max-width:779px) {
	section.contact02 > div > p {
		font-size: 15px;
	}
}
@media (max-width:489px) {
	section.contact02 > div > p {
		font-size: 14px;
	}
	section.contact02 > div > div > div {
		width: 100%;
		padding: 20px 10px;
	}
	section.contact02 > div > div > div > div {
		font-size: 15px;
	}
	section.contact02 > div > div > div > h3 {
		font-size: 22px;
	}
	section.contact02 > div > div > div > p {
		font-size: 12px;
	}
}
/*
contactform
*/
section.contactform {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div:nth-of-type(1) {
		display: inline-block;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
		width: 50px;
	}
	> div:nth-of-type(2) {
		font-size: 18px;
		line-height: 1.2;
		color: #333;
	}
}
/*
contactform02
*/
section.contactform02 {
	padding: 20px 3% 0 3%;
	> div {
		max-width: 880px;
		margin: 0 auto;
	}
}
/*
privacy
*/
section.privacy {
	padding: 100px 0 0 0;
	text-align: center;
	> h2 {
		margin: 0;
		font-size: 30px;
		line-height: 1.2;
		color: #333;
		letter-spacing: 0.1em;
	}
	> div:nth-of-type(1) {
		display: inline-block;
		border-top: solid 4px #333;
		padding: 10px 0 0 0;
		margin: 10px 0 0 0;
		width: 50px;
	}
	> div:nth-of-type(2) {
		font-size: 18px;
		line-height: 1.2;
		color: #333;
	}
}
/*
privacy02
*/
section.privacy02 {
	padding: 0 5%;
	margin: 50px 0 0 0;
	> div {
		max-width: 880px;
		margin: 0 auto;
		> div {
			font-size: 20px;
			line-height: 1.3;
			color: #333;
			margin: 20px 0 0 0;
		}
		> p {
			margin: 7px 0 0 0;
			font-size: 15px;
			line-height: 1.7;
			color: #333;
			text-align: justify;
			@media (max-width:979px) {
				> br {
					display: none;
				}
			}
		}
	}
}
/*
note
*/
section.note {
	padding: 70px 5% 0 5%;
	> div {
		max-width: 880px;
		margin: 0 auto;
		> div {
			font-size: 13px;
			line-height: 1.4;
			color: #111;
		}
		> p {
			margin: 3px 0 0 0;
			font-size: 13px;
			line-height: 1.4;
			color: #333;
			&.indent {
				margin-left: 1em;
				text-indent: -1em;
			}
		}
	}
}
