@charset "utf-8";
/* CSS Document */
body { background: #21170f; }
body#page { background: #17100a; }

/* =========================================================
 main_img
========================================================= */
#main_img {
	width: 100%;
}

#main_img section {
	width: 100%;
	height: 400px;
	background-image: url('../images/main_img.jpg');
	background-size: cover;
	background-position: bottom center;
	display: flex;
	justify-content: center;
	align-items: center;
}

#main_img section h1 {
	width: 100%;
}

#main_img section img {
	width: 55%;
	max-width: 550px;
}

/* =========================================================
contents
========================================================= */
#contents {
	width: 100%;
	min-width: 920px;
	max-width: 1000px;
	margin: 0 auto 4rem;
	padding: 0 30px 0;
	box-sizing: border-box;
}

#contents section {
	position: relative;
}

#contents section h2 {
	margin: 3rem 0;
	color: #d3bd98;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 1.8rem;
	letter-spacing: 1.5rem;
	text-indent: 1.5rem;
	text-align: center;
}

.contents_box {
	width: 100%;
	display: flex;
	justify-content: space-between;
}

#contents_premium,
#contents_cafe_lounge {
	width: 100%;
	max-width: 420px;
	margin: 0 0 3rem;
}

.contents_box h3 {
	margin: 0 0 1.1rem;
	display: flex;
	align-items: center;
}

.contents_box h3 img {
	width: 80%;
	max-width: 280px;
}

.contents_box h3:before,
.contents_box h3:after {
	content: "";
	height: 1px;
	display: block;
	background: linear-gradient(to right, #534926, #ffeac7, #534926);
	flex: 1;
}

.contents_box a {
	width: 90%;
	margin: 0 auto;
	background: #fff;
	display: block;
}

.contents_box a img {
	width: 100%;
}

.contents_box a:hover img {
	opacity: 0.8;
}

/* SmartPhone */
@media screen and (max-width: 900px) {

	article#main_img section {
		width: 100%;
		height: 150px;
		background-image: url('../images/main_img.jpg');
		background-size: cover;
		background-position: bottom center;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	article#main_img section img {
		width: 50%;
	}

	#contents {
		width: 100%;
		min-width: 100%;
		max-width: 100%;
		margin: 0 auto 1rem;
		padding: 0 30px 0;
		box-sizing: border-box;
	}

	#contents section h2 {
		margin: 1.5rem 0;
		font-size: 1.3rem;
	}

	.contents_box {
		display: block;
	}

	.contents_box h3 img {
		width: 60%;
		max-width: 280px;
	}

	#contents_premium,
	#contents_cafe_lounge {
		width: 100%;
		max-width: 600px;
		margin: 0 auto 1.7rem;
	}

}


/* =========================================================
page
========================================================= */
header {
	width: 100%;
	background: linear-gradient(to right, #0a0904, #ffeac7, #0a0904);
}

header #hd_logo {
	width: 50%;
	padding: 0.7rem 0;
	max-width: 300px;
}

h1#page_tit {
	width: 100%;
	padding: 2rem 0;
}

h1#page_tit img {
	width: 70%;
	max-width: 480px;
}

#page #contents section h2 {
	margin: 1rem 0;
	letter-spacing: 0.5rem;
	text-indent: 0.5rem;
}

#info_area {
	margin: 2rem 0 0;
}

#info_area .last_updated {
	color: #fff;
	font-size: 1.1rem;
	letter-spacing: 0.1rem;
	text-indent: 0.1rem;
}

#info_area #info {
	width: 70%;
	max-width: 550px;
	margin: 2rem auto;
}

.floor_map {
	position: relative;
}

#guide {
	width: 100%;
	height: 1.1rem;
	margin: 0 0 0.6rem;
	text-align: left;
	color: #fff;
	display: flex;
	align-items: center;
}

#guide p {
	margin: 0 1.2rem 0 0;
	font-size: 0.9rem;
	display: flex;
	align-items: center;
}

#guide_blue:before {
	content: "";
	width: 1.5rem;
	height: 1rem;
	margin: 0 0.5rem 0 0;
	background: #55aaff;
	display: inline-block;
}
#guide_red:before {
	content: "";
	width: 1.5rem;
	height: 1rem;
	margin: 0 0.5rem 0 0;
	background: #ff5a5a;
	display: inline-block;
}

.floor_map #map_area {
	position: relative;
}

.floor_map #map_area div {
	position: absolute;
}

/*------- ▼ 座席区分け ▼ -------*/
#map_area #seat_A {
	width: 24%;
	height: 36%;
	top: 1%;
	left: 1%;
}
#map_area #seat_B {
	width: 24%;
	height: 36%;
	top: 37.5%;
	left: 1%;
}
#map_area #seat_C {
	width: 6%;
	height: 8%;
	top: 80%;
	left: 7%;
}
#map_area #seat_D {
	width: 6%;
	height: 8%;
	top: 86.5%;
	left: 14.3%;
}
#map_area #seat_P {
	width: 6%;
	height: 8%;
	top: 80%;
	left: 32%;
}
#map_area #seat_Q {
	width: 6%;
	height: 8%;
	top: 86.5%;
	left: 25%;
}
#map_area #seat_E {
	width: 25%;
	height: 36%;
	top: 37.5%;
	left: 74%;
}
#map_area #seat_F {
	width: 25%;
	height: 36%;
	top: 1%;
	left: 74%;
}

#map_area #seat_G {
	width: 6%;
	height: 8%;
	top: 36.5%;
	left: 27.5%;
}
#map_area #seat_H {
	width: 6%;
	height: 8%;
	top: 44.5%;
	left: 27.5%;
}
#map_area #seat_I {
	width: 6%;
	height: 8%;
	top: 55%;
	left: 33.8%;
}
#map_area #seat_J {
	width: 6%;
	height: 8%;
	top: 55%;
	left: 40%;
}
#map_area #seat_K {
    width: 6%;
	height: 8%;
    top: 55%;
    left: 46.5%;
}
#map_area #seat_L {
    width: 6%;
	height: 8%;
    top: 55%;
    left: 53%;
}
#map_area #seat_M {
    width: 6%;
	height: 8%;
    top: 55%;
    left: 59.5%;
}
#map_area #seat_N {
    width: 6%;
	height: 8%;
    top: 44.5%;
    left: 66%;
}
#map_area #seat_O {
    width: 6%;
	height: 8%;
    top: 36.5%;
    left: 66%;
}

/* 空き */
.sitting_on {
	background: rgba(255, 90, 90, 0.5);
	border: solid 2px #ea0000;
	box-sizing: border-box;
	mix-blend-mode: multiply;
}
/* 使用中 */
.sitting_off {
	background: rgba(85, 170, 255, 0.5);
	border: solid 2px #0066f0;
	box-sizing: border-box;
	mix-blend-mode: multiply;
}
/*------- ▲ 座席区分け ▲ -------*/

#info_area #info img {
	width: 100%;
}

.btn_reload {
	width: 8rem;
	height: 3rem;
	margin: 0 auto 1rem;
	background: #fff;
	border-radius: 1.5rem;
	color: #2b2b2b;
	font-size: 1.4rem;
	letter-spacing: 0.5rem;
	text-indent: 0.5rem;
	display: flex;
	justify-content: start;
	align-items: center;
	cursor: pointer;
}

.btn_reload:before {
	margin: 0 0.7rem 0 0;
	content: url('../images/icon_reload.svg');
	width: 32px;
	height: 32px;
}

#info_area .caution {
	margin: 1.2rem 0;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	color: #d3bd98;
	font-size: 1rem;
	text-indent: -1.3rem;
	text-align: left;
	line-height: 1.8rem;
	letter-spacing: 0.3rem;
	display: inline-block;
}

.btn_area {
	width: 100%;
	text-align: left;
}

.btn_back {
	margin: 2rem 0;
	padding: 0.5rem 0;
	color: #fff;
	display: inline-flex;
}

.icon_back_arrow {
	margin: 0 0.5rem 0 0;
}

/* SmartPhone */
@media screen and (max-width: 900px) {

	h1#page_tit {
		width: 100%;
		padding: 1.2rem 0;
	}

	#page #contents section h2 {
		margin: 0;
		font-size: 1.5rem;
	}

	#info_area {
		margin: 1.4rem 0 0;
	}

	#info_area .last_updated {
		font-size: 0.85rem;
		letter-spacing: 0.1rem;
		text-indent: 0.1rem;
	}

	#info_area #info {
		width: 90%;
		margin: 1rem auto 1.5rem;
	}

	#info_area .caution {
		font-size: 0.8rem;
		letter-spacing: 0.1rem;
		text-indent: -1.1rem;
		line-height: 1.2rem;
	}

	.btn_reload {
		width: 8rem;
		height: 2.4rem;
		margin: 0 auto;
		background: #fff;
		border-radius: 1.2rem;
		color: #2b2b2b;
		font-size: 1.2rem;
		letter-spacing: 0.5rem;
		text-indent: 0.5rem;
		display: flex;
		justify-content: start;
		align-items: center;
		cursor: pointer;
	}

	.btn_reload:before {
		margin: 0 1rem 0 0;
		content: url('../images/icon_reload.svg');
		width: 32px;
		height: 32px;
	}

	.btn_back {
		margin: 0.5rem 0;
		padding: 0.5rem 0;
		color: #fff;
		display: inline-flex;
	}

}

@media screen and (max-width: 600px) {

	#page #contents section h2 {
		margin: 0;
		font-size: 1.1rem;
	}

}