@charset "utf-8";

/* common */
* {
	margin: 0;
	padding: 0;
}
html, body {
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	background: #4e1422;
}
img { vertical-align: bottom; }
a {
	color: #1e090e;
	font-size: 18px;
	text-decoration: none;
}
a:hover { opacity: 0.7; }
h3 {
	padding: 0.2em 0;
	color: #fff;
	font-size: 36px;
	font-weight: normal;
	text-align: center;
	position: relative;
	z-index: 1;
}
.titlewrap {
	width: 96.5%;
	margin: auto;
	position: relative;
	text-align: center;
}
.titlewrap:before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: #723642;
	transform: skew(-30deg);
}
.cont2 .titlewrap:before { background: #5f2b37; }
.spbr { display: none; }
.pc_img { display: inline-block; }
.sp_img { display: none; }
.pc_blk { display: block; }
.sp_blk { display: none; }


/* header */
header {
	width: 100%;
	position: relative;
}
header img.background {
	width: 100%;
	height: auto;
}

header #headline {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	box-sizing: border-box;
	padding: 20px 60px 0;
}
header #headline h1 {
	color: #fff;
	font-size: 16px;
	font-weight: normal;
	text-shadow: 0 0 6px #000;
}
header #headline h1 img {
	margin-right: 1.0em;
	vertical-align: middle;
}

header #main_visual {
	width: 100%;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
header #main_visual .lead {
	width: 100%;
	text-align: center;
}
header #main_visual h2 {
	margin-top: 1.0em;
	color: #fff;
	font-size: 20px;
	font-weight: normal;
	text-align: center;
}

header .header_btn {
	position: absolute;
	top: 20px;
	right: 60px;
}
header .header_btn a {
	display: inline-block;
	padding: 0.75em 2.0em 0.75em 2.5em;
	background: rgba(255, 255, 255, 0.8);
	position: relative;
}
header .header_btn a:before {
	display: block;
	content: '';
	width: 18px;
	height: 18px;
	background: url('../img/scope.png') no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	left: 1.0em;
	transform: translateY(-50%);
}
header .header_btn a:after {
	display: block;
	content: '';
	width: 7px;
	height: 11px;
	background: url('../img/arrow.png') no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 1.0em;
	transform: translateY(-50%);
}

/* main */
main {
	overflow: hidden;
}
main .contentwrap {
	/* margin-bottom: 110px; */
	padding: 45px 0 65px;
	background-color: #611c2e;
	background-image: url('../img/background.png');
	background-size: 100%;
}
main .contentwrap.cont2 {
	background-color: #4d1321;
}

/* content1 & content2 */
#content1,
#content2 {
	max-width: 1200px;
	width: 100%;
	margin: auto;
}
#content1 p,
#content2 p {
	text-align: center;
}
#content1 p.english,
#content2 p.english {
	margin-top: 1.0em;
}
#content1 .content,
#content2 .content {
	display: flex;
	margin-top: 3.0em;
	margin-bottom: 27px;
}
#content1 .content .left,
#content1 .content .right,
#content2 .content .left,
#content2 .content .right {
	width: 50%;
	color: #fff;
}
#content1 .content .left h4,
#content2 .content .left h4 {
	margin-top: 55px;
	margin-left: 70px;
	font-size: 30px;
	font-weight: normal;
}
#content1 .content .left .listwrap,
#content2 .content .left .listwrap {
	margin-top: -1.5em;
	padding: 45px 70px;
	background: rgba(37, 20, 24, 0.5);
	box-sizing: border-box;
}
#content1 .content .left ul,
#content2 .content .left ul {
	margin-left: 1.5em;
	list-style-image: url('../img/check.png');
	font-size: 20px;
}
#content1 .content .left ul li,
#content2 .content .left ul li {
	padding-left: 0.5em;
	line-height: 2.0;
}
#content1 .content .right img,
#content2 .content .right img {
	width: 100%;
}
#content1 p.triangle,
#content2 p.triangle {
	margin-bottom: 27px;
}
#content1 p.message,
#content2 p.message {
	margin-bottom: 40px;
	color: #fff;
	font-size: 28px;
}
#content1 .contact_btn,
#content2 .contact_btn {
	position: relative;
}
#content1 .contact_btn a,
#content2 .contact_btn a {
	display: inline-block;
	width: 100%;
	padding: 1.0em 0;
	background: #fff;
	font-size: 30px;
}
#content1 .contact_btn a:before,
#content2 .contact_btn a:before {
	display: block;
	content: '';
	width: 41px;
	height: 40px;
	background: url('../img/scope.png') no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	left: 6.0em;
	transform: translateY(-50%);
}
#content1 .contact_btn a:after,
#content2 .contact_btn a:after {
	display: block;
	content: '';
	width: 15px;
	height: 22px;
	background: url('../img/arrow.png') no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 6.75em;
	transform: translateY(-50%);
}

#movie {
	max-width: 1200px;
	width: 100%;
	margin: auto;
}
#movie .movie_box {
	width: 65%;
	margin: 0 auto;
}
#movie .movie_box video {
	width: 100%;
}


/* footer */
footer {
	background: #62202e;
}
footer .footerwrap {
	display: flex;
	justify-content: space-between;
	max-width: 1200px;
	width: 100%;
	margin: auto;
	padding: 40px 0;
	color: #b6b8b7;
}
footer .footerwrap .left img {
	margin-bottom: 1.0em;
}
footer .footerwrap .right {
	padding-top: 2.5em;
}
footer .footerwrap .right a {
	margin-right: 2.0em;
	color: #b6b8b7;
}



/* responsive */
@media screen and (max-width: 1200px) {
	#content1 .contact_btn a:before,
	#content2 .contact_btn a:before {
		left: 1.5em;
	}
	#content1 .contact_btn a:after,
	#content2 .contact_btn a:after {
		right: 1.5em;
	}
	footer .footerwrap {
		padding: 40px 2.0em;
		box-sizing: border-box;
	}
}

@media screen and (max-width: 960px) {
	#content1 .contact_btn a,
	#content2 .contact_btn a {
		font-size: 3vw;
	}
	footer .footerwrap {
		display: block;
	}
}

@media screen and (max-width: 768px) {
	.spbr { display: inline; }
	.pc_img { display: none; }
	.sp_img { display: inline-block; }
	.pc_blk { display: none; }
	.sp_blk { display: block; }

	h3 {
		font-size: 5vw;
	}
	header #main_visual .lead img {
		width: 60%;
	}
	header #main_visual h2 {
		font-size: 5vw;
	}
	header #headline {
		padding: 0;
	}
	header #headline h1 {
		padding: 3%;
		font-size: 4.25vw;
	}
	header #headline h1 img {
		width: 35%;
	}

	#header_btnbox {
		background: #fff;
		margin-top: 40px;
		padding: 2% 5%;
	}
	#header_btnbox .header_btn {
		background: #4c1320;
	}
	#header_btnbox .header_btn a {
		display: inline-block;
		padding: 3% 0 3% 3.5em;
		color: #fff;
		position: relative;
		font-size: 4.5vw;
	}
	#header_btnbox .header_btn a:before {
		display: block;
		content: '';
		width: 4.5vw;
		height: 4.5vw;
		background: url('../img/scope_w.png') no-repeat;
		background-size: contain;
		position: absolute;
		top: 50%;
		left: 1.5em;
		transform: translateY(-50%);
	}

	#content1 .content,
	#content2 .content {
		display: block;
	}
	#content1 .content .left,
	#content1 .content .right,
	#content2 .content .left,
	#content2 .content .right {
		width: 100%;
	}
	#content1 .content .left h4,
	#content2 .content .left h4 {
		font-size: 4.25vw;
	}
	#content1 .content .left ul li,
	#content2 .content .left ul li {
		font-size: 2.95vw;
	}
	#content1 .content .right img,
	#content2 .content .right img {
		width: 100%;
	}
	#content1 p.message,
	#content2 p.message {
		font-size: 3.25vw;
	}
	#content1 .contact_btn a:before,
	#content2 .contact_btn a:before {
		width: 20px;
		height: 20px;
	}
	#content1 .contact_btn a:after,
	#content2 .contact_btn a:after {
		width: 8px;
		height: 11px;
	}

	footer .footerwrap .left img {
		width: 100%;
	}
	footer .footerwrap .right a {
		display: inline-block;
		margin-right: 0;
		margin-bottom: 2.0em;
	}

	main .contentwrap.movie {
		padding-bottom: 0;
	}

	#movie .movie_box {
		width: 90%;
		margin: 0 auto;
	}
}