@charset "UTF-8";
#wrapper {
	height: auto;
}

body {
	transition: 400ms;
	z-index: -9999;
}

#main {
	z-index: -3;
}

#main-white {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.7);
	z-index: -2;
	transition: 400ms;
}

/* product */
#product {
	padding-top: 60px;
	padding-bottom: 180px;
}

#product .wrapper {
	width: 1000px;
	margin-left: auto;
	margin-right: auto;
}

#product h1 {
	width: 209px;
	height: 36px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
}

#product img {
	width: 100%;
	height: auto;
}

#product .product-intro {
	text-align: center;
	line-height: 1.875;
	margin-bottom: 100px;
}

#product .product-intro br.pc-none {
	display: none;
}

#product .product-local-nav {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 50px;
	margin-bottom: 120px;
}

#product .product-local-nav-btn {
	display: grid;
	place-items: center;
	width: 362px;
	min-height: 80px;
	background-color: #ed276e;
	border-radius: 4px;
	font-size: 1.4375em;
	color: #fff;
	text-decoration: none;
	transition: opacity 0.2s;
}

#product .product-local-nav-btn:hover {
	opacity: 0.6;
}

#product .product-list-heading {
	font-size: 30px;
	font-weight: 600;
	text-align: center;
	margin-bottom: 60px;
}

#product #product-charged-ul {
	padding-top: 50px;
}

#product .product-ul {
	position: relative;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	z-index: auto;
}

#product .product-li {
	position: relative;
	width: 460px;
	padding-top: 60px;
	padding-left: 140px;
	margin-bottom: 100px;
	box-sizing: border-box;
	z-index: auto;
}

#product #product-charged-ul .product-li:nth-child(2n) {
	margin-top: 150px;
	margin-bottom: 0;
}

#product #product-charged-ul .product-li:nth-child(2n + 1) {
	margin-top: -50px;
}

#product .product-li canvas {
	position: absolute;
}

#product .product-li canvas.product-li-bg {
	width: 650px;
	top: 0;
	left: -60px;
	bottom: 0;
	margin: auto 0;
	z-index: -1;
}

#product #product-charged-ul .product-li:nth-child(2n + 1) .product-li-bg {
	top: -120px;
}

#product .product-li canvas.product-thumb {
	width: 200px;
	top: -20px;
	left: -20px;
}

#product .product-li h2 {
	font-size: 20px;
	font-weight: 600;
	margin-bottom: 20px;
}

#product .product-li-text {
	font-size: 14px;
	margin-bottom: 20px;
	line-height: 1.5;
}

#product .product-li-text .pb-1 {
	display: block;
	padding-bottom: 1em;
}

#product .product-li-text .fw−600 {
	font-weight: 600;
}

#product .product-li-price {
	font-weight: 600;
	margin-bottom: 30px;
}

#product .product-li-empty {
	position: relative;
	width: 100%;
	text-align: center;
	padding-top: 60px;
	margin-bottom: 100px;
	box-sizing: border-box;
	z-index: auto;
}

#product a {
	text-decoration: underline;
}

#product a.product-li-apply {
	display: inline-block;
	width: 162px;
	height: 42px;
	background: #ed276e;
	color: #fff;
	line-height: 42px;
	text-align: center;
	transition: 0.25s;
	text-decoration: none;
}

#product a:hover {
	opacity: 0.7;
}

#product-charged button {
	width: 455px;
	border: #ada4a4 1px solid;
	text-align: center;
	display: block;
	margin: 80px auto 0;
	position: relative;
	transition: 0.2s;
	font-size: 16px;
	padding: 25px 0;
	outline: none;
	background: #fff;
}

#product-charged button:hover {
	opacity: 0.6;
	cursor: pointer;
}

/* contact */
#product-bottom {
	clear: both;
	margin: 0 auto;
	min-height: 99vh;
	box-sizing: border-box;
	margin-bottom: 0;
}

#contact {
	z-index: 1;
}

#overview .wrapper {
	background: rgba(255, 255, 255, 0.2);
}

#product-bottom .box-cts {
	position: relative;
}

#overview {
	background: none;
	margin-top: 0;
	width: auto;
	position: relative;
}

#overview table {
	margin: 0 auto;
	width: auto;
}

#overview:before {
	content: "";
	width: 100%;
	height: 0;
	padding: 20% 0 0;
	position: absolute;
	left: 0;
	bottom: 100%;
	background: linear-gradient(
		to bottom,
		rgba(255, 255, 255, 0) 0%,
		rgba(255, 255, 255, 0.2) 100%
	);
}

#overview .bnr-foot img {
	display: block;
	width: 100%;
	height: auto;
}

.cover-bg-main {
	background: none;
	display: block;
	height: 100%;
	transition: 400ms;
	overflow-y: scroll;
}

#bg-main-top {
	width: 100%;
	min-width: 1600px;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	transition: 400ms;
}

#bg-main-top.is-hidden {
	opacity: 0;
}

#bg-main-bottom {
	opacity: 0;
	transition: opacity 400ms;
}

#bg-main-box.is-show #bg-main-bottom {
	opacity: 1;
}

#bg-main-bottom {
	position: fixed;
	bottom: -50px;
	left: 50%;
	z-index: -1;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100%;
	min-width: 1600px;
}

#footer {
	background: rgba(255, 255, 255, 0.2);
	position: relative;
}

#footer .copyright-footer {
	font-size: 10px;
	text-align: center;
	display: block;
	width: 100%;
	letter-spacing: 0.04em;
	padding: 0 0 2.2em;
	position: relative;
}

@media screen and (max-width: 767px) {
	#main {
		position: absolute;
		top: 0;
	}
	/* product */
	#product {
		padding-top: 16vw;
		padding-bottom: 180px;
	}
	#product .wrapper {
		width: 100%;
	}
	#product .product-bg {
		position: relative;
		background: url(../images/product-bg_sp.png) repeat-y;
		background-size: 100% auto;
		background-position: top 42.666vw center;
		z-index: 0;
	}
	#product h1 {
		width: 38.533vw;
		height: 6.533vw;
		margin-bottom: 12vw;
	}
	#product .product-intro {
		font-size: 3.733vw;
		margin-bottom: 16vw;
		width: 77.333vw;
		margin-left: auto;
		margin-right: auto;
	}
	#product .product-intro br.sp-none {
		display: none;
	}
	#product .product-local-nav {
		flex-direction: column;
		gap: 3.733vw;
		margin-bottom: 16vw;
	}
	#product .product-local-nav-btn {
		width: 73.6vw;
		min-height: 13.333vw;
		font-size: 4.2666vw;
	}
	#product .product-list-heading {
		font-size: 5.333vw;
		margin-bottom: 13.333vw;
	}
	#product #product-charged-ul {
		padding-top: 0;
	}
	#product .product-ul {
		display: block;
		padding-bottom: 8vw;
	}
	#product .product-li {
		width: 85.333vw;
		padding-top: 8vw;
		padding-left: 30.666vw;
		margin-bottom: 8vw;
		margin-left: auto;
		margin-right: auto;
	}
	#product #product-charged-ul .product-li:nth-child(2n) {
		margin-top: 0;
		margin-bottom: 8vw;
	}
	#product #product-charged-ul .product-li:nth-child(2n + 1) {
		margin-top: 0;
	}
	#product .product-li canvas.product-li-bg {
		width: 120vw;
		left: -10vw;
	}
	#product #product-charged-ul .product-li:nth-child(2n + 1) .product-li-bg {
		top: 0;
	}
	#product .product-li canvas.product-thumb {
		width: 45vw;
		top: -10vw;
		left: -7vw;
	}
	#product .product-li h2 {
		font-size: 3.2vw;
		margin-bottom: 4vw;
	}
	#product .product-li-text {
		font-size: 2vw;
		margin-bottom: 4vw;
	}
	#product .product-li-price {
		font-size: 2.933vw;
		margin-bottom: 5.333vw;
	}
	#product .product-li-empty {
		font-size: 3.2vw;
		padding-top: 5vw;
		margin-bottom: 8vw;
		margin-left: auto;
		margin-right: auto;
	}
	#product a.product-li-apply {
		font-size: 3.733vw;
		width: 36vw;
		height: 9.333vw;
		line-height: 9.333vw;
		transition: none;
	}
	#product a:hover {
		opacity: 1;
	}
	#product-charged button {
		border: #ada4a4 1px solid;
		outline: none;
		background: #fff;
		line-height: 1em;
		position: relative;
		right: auto;
		bottom: auto;
		padding: 0;
		margin: 0 auto;
		transition: 0.2s;
		display: block;
		justify-content: center;
		align-items: center;
		width: 80vw;
		height: 13.3vw;
		font-size: 0.56em;
		box-sizing: border-box;
		z-index: 2;
	}
	#product-charged button:hover {
		opacity: 1;
	}
	/* contact */
	#contact {
		width: 100%;
		padding: 0 0 18.666vw;
		min-height: 0;
		z-index: 1;
	}
	#contact h2 {
		padding: 13.333vw 0 5.6%;
		width: 37.9%;
	}
	#product-bottom {
		clear: both;
		width: 100%;
		margin: 0 auto;
		min-height: 99vh;
		box-sizing: border-box;
		margin-bottom: 0;
	}
	#product-bottom .box-cts {
		position: relative;
		display: block;
		width: 100%;
		height: auto;
		padding: 0 !important;
	}
	#overview {
		background: none;
		margin-top: 0;
		padding-top: 14.666vw;
	}
	#overview .wrapper {
		background: rgba(255, 255, 255, 0);
	}
	#overview .box-cts h2 {
		padding-top: 0;
	}
	#overview table {
		margin: 0 auto;
		width: 81%;
	}
	#overview:before {
		content: "";
		width: 100%;
		height: 0;
		padding: 20% 0 0;
		background: none;
		position: absolute;
		left: 0;
		bottom: 100%;
		z-index: 0;
	}
	.cover-bg-main {
		background: none;
		display: none;
		height: 100%;
		transition: 400ms;
		overflow-y: scroll;
	}
	#bg-main-top {
		width: 100%;
		min-width: 100%;
		position: absolute;
		top: 50%;
		left: 50%;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		z-index: -1;
	}
	#bg-main-bottom {
		min-width: 0;
		bottom: 0;
	}
}
