@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;500;600;700;800&display=swap');
html {
	scroll-behavior: smooth;
	scroll-padding-top: 5rem;
}
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	line-height: 1.75;
	color: #000;
	background: #fff;
	margin: 0;
	padding: 0;
	position: relative;
}

* {
	font-size: 1em;
	box-sizing: border-box;
	background-size: contain;
}

html, body, p, h1, h2, h3, h4, h5, ul, ol, li, dd, dl, dt, div {
	padding: 0;
	margin: 0;
	font-weight: 500;
}

img {
	border: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	vertical-align:top;
	max-width: 100%;
}

html { height: 100%; }
li { list-style-type: none; }
a {
	color: inherit;
	text-decoration: none;
}
a.underline,
.underline a { text-decoration: underline; }
.none { display: none; }
.sp { display: none; }
.pc { display: block; }

/* for modern brouser */
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	line-height: 0;
	font-size: 0;
	visibility: hidden;
}

/* IE7,MacIE5 */
.clearfix { display: inline-block; }

/* WinIE6 below, Exclude MacIE5 \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
.tcenter { text-align: center; }
.tright { text-align: right; }

/* 選択色 */
::selection {
	background: #000;
	color: #fff;
}

::-moz-selection {
	background: #000;
	color: #fff;
}

/* YouTube 埋め込み */
.YT {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}
.YT iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

/* header */
header {
	background: #000 url(../images/line.gif) top center no-repeat;
	background-size: 100% 5px;
	padding: 1.5em 1.5em 1em;
	width: 100%;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 100;
	text-align: center;
}
header ul.menu li {
	display: inline-block;
	padding: 0 1.25em;
	color: #fff;
}
header ul.menu li a { cursor: pointer; }
header ul.menu li img { height: 1.5em; }

/* SLIDE MENU */
#slidemenu {
	display: none;
	position: fixed;
	width: 100%;
	height: 100vh;
	z-index: 98;
	top: 0;
	left: 0;
	padding: 1.5em;
	box-sizing: border-box;
	background: rgba(0,0,0,0.8);
	backdrop-filter: blur(0.5em);
	text-align: center;
}
#slidemenu .centerBox {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100vh;
}
#slidemenu ul.Gmenu li { padding: 1.25em 1em; }
#slidemenu ul.Gmenu a { cursor: pointer; }
#slidemenu ul.Gmenu img { height: 2rem; }

/* main */
main {
	position: relative;
	margin-top: 3.7rem;
	z-index: -1;
}
main img { width: 100%; }

/* contentsBox */
.contentsBox {
	position: relative;
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 1em;
	padding: 0 0 1em;
	margin-top: -25vw;
	z-index: 2;
}

/* NEWS LIST */
ul.news {
	width: 100%;
	max-width: 1000px;
	background: rgba(199,199,199,0.5);
	border-radius: 1.5em;
	padding: 0 1em;
	margin: 2em auto 0;
	z-index: 2;
}
ul.news li {
	padding: 1em 1em 1em 0;
	border-bottom: #777 dashed 1px;
	color: #000;
	font-size: 1.25em;
}
ul.news li:last-child { border: 0; }
ul.news li p {
	display: inline-block;
	vertical-align: middle;
	width: 5em;
	text-align: center;
}
ul.news li p:last-child {
	width: calc(100% - 5em);
	text-align: left;
}
ul.news li p:first-child {
	text-align: left;
	color: #000;
	padding: 0 1em;
	font-weight: 700;
	line-height: 1.2;
}
ul.news li p:first-child span {
	display: block;
	width: 100%;
	font-size: 0.75em;
}
ul.news li a {
	color: #000;
	text-decoration: underline;
}
ul.news li.newsHD p:first-child {
	width: 30%;
	text-align: left;
	padding: 0 0.5em;
}
ul.news li.newsHD p:last-child {
	width: 70%;
	text-align: right;
}
ul.news li.newsHD {
	padding: 1em 0 1em 0;
}
ul.news li.newsHD p:last-child span {
	background: #000;
	color: #fff;
	padding: 0.25em 1em;
	margin-right: -0.9rem;
	font-weight: 700;
	font-size: 1.25em;
}
ul.news li:first-child p:last-child span small { font-size: 0.8em; }

/* TTL */
img.ttl { height: 2rem; }

/* LIVE TEXT */
.live_txt {
	text-align: center;
	padding: 2em;
}
.live_txt img {
	width: 90%;
	max-width: 800px;
}

/* TICKET */
.ticketBox {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 1em;
	padding: 2em;
	background: #fff url(../images/line.gif) top center no-repeat;
	background-size: 100% 5px;
	border: #000 solid 1px;
	border-top: none;
}

/* PRICE */
.priceBox { margin: 1em auto; }
.priceBox div {
	margin: 0;
	padding: 0;
	font-size: 0.75rem;
}
.priceBox li {
	position: relative;
	display: grid;
	grid-gap: 1rem;
	grid-template-columns: 1fr 3fr;
	padding: 1em 0;
	border-bottom: #000 dashed 1px;
}
.priceBox li.noLine { border-bottom: none; padding-bottom: 0; }
.priceBox li:last-child { border-bottom: none; padding: 0; }
.priceBox li div.c2 {
	display: grid;
	grid-gap: 1rem;
	grid-template-columns: 1fr 1fr;
}
.priceBox li h3 {
	text-align: center;
	background: #000;
	color: #fff;
	padding: 0.25em 1em;
	margin-bottom: 0.5rem;
	font-weight: 800;
	font-size: 1.25rem;
}
.priceBox li h3.nobk {
	text-align: right;
	background: #fff;
	color: #000;
	padding: 0.25em 0;
}
.priceBox li strong {
	position: relative;
	display: block;
	width: 19rem;
	height: 5rem;
	margin-top: -1.5rem;
	font-weight: 800;
	font-size: 3rem;
	text-align: right;
}
.priceBox li strong span { font-size: 0.6em; }

/* TICKET AREA */
.ticketArea {
	padding: 2em;
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 1em;
	font-size: 1rem;
}
.ticketArea.blue {
	background: #003bed;
	color: #fff;
}
.ticketArea.grey {
	background: #999999;
	color: #fff;
}
.ticketTTL { margin-bottom: 0.5em; }
.ticketTTL li {
	display: grid;
	grid-gap: 1rem;
	grid-template-columns: 5fr 3fr;
	border-bottom: #fff dashed 1px;
	padding: 0 0 0.5em;
}
.ticketTTL li h3 {
	font-size: 1.35em;
	display: flex;
	justify-content: start;
	align-items: flex-end;
}
.ticketTTL li p {
	text-align: right;
	display: flex;
	justify-content: end;
	align-items: flex-end;
}
.btnBox {
	text-align: center;
	padding: 2em 0 1em;
}
a.btn {
	display: block;
	width: 50%;
	margin: 0 auto;
	text-align: center;
	-webkit-flex-grow: 1;
	flex-grow: 1;
	color: #000;
	background: #fff;
	padding: 0.5em 1.5em;
	border-radius: 0.5em;
	font-size: 1.5rem;
	font-weight: 800;
}
.ticketArea.blue a.btn { color: #003bed; }
.ticketArea.grey a.btn { color: #666; }
hr.wLine {
	border: none;
	border-bottom: #fff dashed 1px;
	margin: 1em auto;
}
.yellow { color: #ff0; }

/* lineBox */
.lineBox {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 1em;
	padding: 2em;
	background: #fff url(../images/line.gif) bottom center no-repeat;
	background-size: 100% 5px;
}
.lineBox h2 { text-align: center; }
.lineBox .p10 { padding: 5em 0; }
img.soon { height: 1.5rem; }

/* 注意事項 */
.notice {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 2em;
	padding-left: 1em;
}
.notice li:before {
	content: '※';
	margin-left: -1em;
}
.notice li.disc:before {
	content: '・';
	margin-left: -1em;
}
.notice li.no:before {
	content: '　';
	margin-left: -1em;
}
.notice li.no h3 {
	font-size: 1.25rem;
	font-weight: 800;
	margin-left: -1em;
}

/* footer */
footer {
	background: #000;
	font-size: 0.75em;
	color: #fff;
	text-align: center;
	padding: 2em;
}
footer p { font-size: 1.35em; }

@media all and (max-width: 736px) {
	img { max-width: 100%; }
	.sp { display: block; }
	.pc { display: none; }

	body {
		font-size: 3vw;
	}
	header { padding: 2em 1em 1.5em; }
	header ul.menu.sp {
		width: 100%;
		padding: 0;
		display: grid;
		grid-gap: 1rem;
		grid-template-columns: 1fr 1fr;
	}
	header ul.menu.sp li { padding: 0; }
	header ul.menu.sp li img { height: 3em; }
	header ul.menu.sp li:first-child { text-align: left; }
	header ul.menu.sp li:last-child { text-align: right; }

	main { margin-top: 4.5rem; }
	.contentsBox { margin-top: -45vw; }

	ul.news li { font-size: 1em; }
	ul.news li.newsHD p:first-child {
		width: 100%;
		text-align: center;
		padding: 0 0.5em 1em;
	}
	ul.news li.newsHD p:last-child {
		width: 100%;
		text-align: right;
	}

	.priceBox li,
	.priceBox li div.c2 { grid-template-columns: 1fr; }
	.priceBox li strong { width: 100%; text-align: center; }
	.priceBox li h3.nobk { text-align: center; }
	.priceBox li strong.t3 { margin-top: -3rem; }

	a.btn { width: 100%; font-size: 1.5em; }
	.ticketArea { font-size: 1em; }
	.ticketTTL li {
		grid-gap: 0.25rem;
		grid-template-columns: 1fr;
		border-bottom: none;
		padding: 0;
	}
	.ticketTTL li p {
		border-top: #fff dashed 1px;
		justify-content: start;
	}

}
::-webkit-full-page-media, :future, :root main { height: auto; }