@charset "utf-8";
body {
	font-family: 'Noto Sans JP', sans-serif;
	color: #2F2F2F;
	margin: 0;
	padding: 0;
	letter-spacing: 0.02em;
	font-feature-settings: "palt";
}
.pc{ display: block; }
.sp{ display: none; }

#main {
	background-color: #000;
}
#kv {
	width: 100%;
	text-align: center;
}
	#kv h1 {
		margin: 0 auto;
        width: 100%;
        font-size: 0;
	}
	#kv h1 picture {
        width: 100%;
        position: relative;
	}
	#kv h1 img {
		width: 100%;
		height: auto;
	}

.adcopy {
	background-color: #DC732A;
	width: 100%;
	margin: 50px 0 0 0;
}
	.adcopy h2 {
		padding: 20px 30px;
		max-width: 1000px;
		margin: 0 auto;
	}

.content {
	background: -webkit-linear-gradient(left, #080808 0%, #313131 50%, #080808 100%);
	background: -o-linear-gradient(left, #080808 0%, #313131 50%, #080808 100%);
	background: linear-gradient(to right, #080808 0%, #313131 50%, #080808 100%);
	color: #fff;
	text-align: center;
}

	.content .contents__digest {
		position: relative;
		max-width: 100%;
		margin: 0 auto;
		padding: 0;
	}
		.content .contents__digest::before {
			position: absolute;
			content:"";
			background-repeat:no-repeat;
			background-size:100% 100%;
			z-index: 0;
			top:20rem; left:0;
			width:clamp(900px, 60vw, 2050px);
			aspect-ratio:2050/900;
			background-image:url(../_images/content_bg_l_main.png);
		}
		.content .contents__digest::after {
			position: absolute;
			content:"";
			background-repeat:no-repeat;
			background-size:100% 100%;
			z-index: 0;
			bottom:0; right:0;
			width:clamp(800px, 76vw, 1900px);
			aspect-ratio:1900/980;
			background-image:url(../_images/content_bg_r.png);
		}
		.content .contents__digest .sale {
			max-width: 1200px;
			margin: 0 auto;
			padding: 60px 40px 0 40px;
			position: relative;
		}
			.content .contents__digest .sale .img {
				line-height: 0;
			}
			.content .contents__digest .sale img {
				width: 100%;
			}
		.content .contents__digest h3 {
			padding: 60px 0 35px 0;
		}
			.content .contents__digest h3 img {
				max-width: 610px;
			}
		.content .contents__digest p.period {
			max-width: 700px;
			margin: 0 auto;
			padding: 30px;
			background-color: #FF9622;
		}
			.content .contents__digest p.period img {
				width: 100%;
			}
		.content .contents__digest p.txt {
			font-size: 22px;
			line-height: 44px;
			padding: 25px 0 80px 0;
			font-weight: bold;
		}

	.contents__announce {
		width: 100%;
		background-image: url(../_images/announce_bg.jpg);
		background-position: top center;
		background-repeat: no-repeat;
		background-size: cover;
		text-align: center;
		padding: 20px 0;
	}
		.contents__announce img {
			max-width: 620px;
			margin: 0 auto;
		}
	.content .contents__inner {
		position: relative;
		max-width: 100%;
		margin: 0 auto;
		padding: 60px 0;
	}
	.content .contents__inner:last-child {
		padding: 60px 0 100px 0;
	}
		.content .contents__inner::before {
			position: absolute;
			content:"";
			background-repeat:no-repeat;
			background-size:100% 100%;
			z-index: 0;
			top:0; left:0;
			width:clamp(600px, 60vw, 1500px);
			aspect-ratio:1500/480;
			background-image:url(../_images/content_bg_l.png);
		}
		.content .contents__inner::after {
			position: absolute;
			content:"";
			background-repeat:no-repeat;
			background-size:100% 100%;
			z-index: 0;
			bottom:0; right:0;
			width:clamp(800px, 76vw, 1900px);
			aspect-ratio:1900/980;
			background-image:url(../_images/content_bg_r.png);
		}
		.content .contents__inner .bnr {
			position: relative;
			max-width: 900px;
			margin: 0 auto 10px auto;
			line-height: 0;
			z-index: 1;
		}
			.content .contents__inner .bnr img {
				width: 100%;
			}
		.content .contents__inner .box {
			position: relative;
			max-width: 820px;
			margin: 0 auto;
			background-color: #fff;
			padding: 40px;
			z-index: 1;
		}
			.content .contents__inner .box::before {
				position: absolute;
				content:"";
				background-repeat:no-repeat;
				background-size:100% 100%;
				z-index: -1;
				top:0; left:0;
				width:clamp(600px, 40vw, 1800px);
				aspect-ratio:1800/630;
				background-image:url(../_images/content_bg_l_inner.png);
			}
			.content .contents__inner .box::after {
				position: absolute;
				content:"";
				background-repeat:no-repeat;
				background-size:100% 100%;
				z-index: -1;
				bottom:0; right:0;
				width: clamp(680px, 40vw, 1660px);
				aspect-ratio: 1660 / 680;
				background-image:url(../_images/content_bg_r_inner.png);
			}
			.content .contents__inner .box .box__inner {
				position: relative;
				z-index: 1;
			}
				.content .contents__inner .box .box__inner h3.head01 {
					max-width: 670px;
					margin: 0 auto;
				}
				.content .contents__inner .box .box__inner h3.head02 {
					max-width: 820px;
					margin: 0 auto;
				}
				.content .contents__inner .box .box__inner .period {
					background-color: #000;
					max-width: 550px;
					padding: 30px;
					margin: 30px auto;
				}
				.content .contents__inner .box .box__inner .txt {
					color: #000;
					font-size: 20px;
					line-height: 38px;
					font-weight: bold;
				}
					.content .contents__inner .box .box__inner .txt .em {
						color: #004682;
						font-size: 24px;
						line-height: 40px;
						font-weight: bold;
					}

	.content .separator {
		width: 100%;
		background-image: url(../_images/announce_bg.jpg);
		background-position: top center;
		background-repeat: no-repeat;
		background-size: cover;
		text-align: center;
		padding: 5px 0;
	}

	.captionTx {
		font-size: 18px;
		text-align: left;
		color: #fff;
		margin: 1em auto;
        width:900px;
	}

@media only screen and (max-width: 1160px) {
	.adcopy {
		margin: 2.5rem 0 0 0;
	}
	.content .contents__sale {
		padding: 3rem 2rem 0 2rem;
	}
	.content .contents__digest {
		padding: 1.5rem 0 0 0;
	}
		.content .contents__digest h3 {
			padding: 1.5rem 0 1.7rem 0;
		}
		.content .contents__digest p.period {
			width: 80%;
			padding: 1.5rem;
		}
		.content .contents__digest p.txt {
			font-size: 1.3rem;
			line-height: 2.6rem;
			padding: 1.2rem 0 3rem 0;
		}
	.contents__announce {
		padding: 1rem 0;
	}
	.content .contents__inner {
		padding: 3rem 2rem;
	}
	.content .contents__inner:last-child {
		padding: 3rem 2rem 4rem 2rem;
	}
		.content .contents__inner .bnr {
			margin: 0 auto 0.5rem auto;
		}
		.content .contents__inner .box {
			padding: 2rem;
		}
			.content .contents__inner .box .box__inner h3.head01,
			.content .contents__inner .box .box__inner h3.head02 {
				width: 98%;
			}
			.content .contents__inner .box .box__inner .period {
				padding: 1.5rem;
				margin: 1.5rem auto;
			}
			.content .contents__inner .box .box__inner .txt {
				font-size: 1.1rem;
				line-height: 2.2rem;
			}
	
	.content .separator {
		padding: 0.25rem 0;
	}
}

@media only screen and (max-width: 768px) {
	.pc{
		display: none;
	}
	.sp{
		display: block;
	}
	
	.adcopy {
		margin: 1.0rem 0 0 0;
	}
		.adcopy h2 {
			padding: 0.8rem 1.2rem;
		}
	
	.content .contents__digest {
		padding: 0;
	}
		.content .contents__digest .sale {
			padding: 1.5rem 1rem 0 1rem;
		}
		.content .contents__digest::before {
			top: 20%;
			width: clamp(350px, 60vw, 800px);
		}
		.content .contents__digest::after {
			width: clamp(340px, 76vw, 800px);
		}
		.content .contents__digest h3 {
			padding: 1.4rem 0 1rem 0;
		}
			.content .contents__digest h3 img {
				width: 85%;
			}
		.content .contents__digest p.period {
			width: 80%;
			padding: 1rem;
		}
		.content .contents__digest p.txt {
			font-size: 0.9rem;
			line-height: 2.0rem;
			padding: 0.6rem 0 1.5rem 0;
		}
	
	.content .contents__inner {
		padding: 1.5rem 1rem;
	}
		.content .contents__inner::before {
			width: clamp(320px, 60vw, 800px);
		}
		.content .contents__inner::after {
			width: clamp(340px, 60vw, 800px);
		}
		.content .contents__inner .box {
			padding: 1.5rem 1rem;
		}
		.content .contents__inner .box::before {
			width: clamp(260px, 40vw, 800px);
		}
		.content .contents__inner .box::after {
			width: clamp(330px, 40vw, 800px);
		}
		.content .contents__inner:last-child {
			padding: 1.5rem 1rem 5rem 1rem;
		}
			.content .contents__inner .box .box__inner .period {
				width: 88%;
				padding: 1rem;
				margin: 0.8rem auto;
			}
			.content .contents__inner .box .box__inner .txt {
				font-size: 0.86rem;
				line-height: 1.7rem;
			}
				.content .contents__inner .box .box__inner .txt .em {
					font-size: 0.92rem;
					line-height: 2rem;
				}
	
	.captionTx {
        width:92vw;
		font-size: 3.4vw;
		padding: 0;
		margin: 1em auto;
        overflow:hidden;
	}
}
