@charset "UTF-8";

.pc { display: block !important; }
.sp { display: none !important; }

@media screen and (max-width: 768px)  {
.pc { display: none !important; }
.sp { display: block !important; }
}
/*-----------------------------------------------------------
	main visual
-----------------------------------------------------------*/

#main-visual {
	position: relative;
	height: auto;
}
#main-visual .mv {
	text-align: center;
}
#main-visual .mv img {
	max-width: 1920px;
	width: 100%;
	height: auto;
}
#main-visual .wrap {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	overflow: hidden;
}
#main-visual .title {
	float: left;
	padding: 60px 0;
	margin: 0;
}

@media screen and (max-width: 1260px) {
	#main-visual .title img {
		width: 280px;
		height: auto;
	}
}

#main-visual .info {
	float: right;
}

#main-visual .info .buttons {
	padding-top: 102px;
}
#main-visual .info .buttons .button-x {
	display: block;
}
#main-visual .info .buttons .button-x a span {
	line-height: 42px;
	padding: 0 40px;
}
#main-visual .info .buttons .button-x a:after {
	left: 24px;
}
#main-visual .info .buttons .button-x + .button-x {
	margin-top: 15px
}

#main-visual .share {
	display: block;
	position: absolute;
	right: 0;
	top: 30px;
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
}
#main-visual .share li {
	display: inline-block;
	vertical-align: middle;
}
#main-visual .share li + li {
	margin-left: 12px;
}
#main-visual .share li a {
	display: block;
	width: 56px;
	height: 56px;
	line-height: 56px;
	background-color: #efefef;
	border-radius: 100%;
	transition: opacity .3s ease-out;
}
#main-visual .share li a:hover {
	opacity: 0.6;
}
#main-visual .share li a img {
	width: 24px;
	height: auto;
}

#main-visual .wave {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 130px;
}
#main-visual .wave span {
	display: block;
}
#main-visual .wave .wave1 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 130px;
	background: url('../images/wave1.png') repeat-x;
	background-position: 0 0;
	background-size: 4000px 130px;
	animation: wave-slider1 9s linear infinite;
	opacity: 1;
}
@keyframes wave-slider1 {
	from { background-position: 0 0; }
    to { background-position: -4000px 0; } /* 1518pxとは使用した背景画像の長さ */
}

#main-visual .wave .wave2 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 106px;
	background: url('../images/wave2.png') repeat-x;
	background-position: 0 0;
	background-size: 4000px 116px;
	animation: wave-slider2 25s linear infinite;
	opacity: .7;
}
@keyframes wave-slider2 {
	from { background-position: 0 0; }
    to { background-position: -4000px 0; } /* 1518pxとは使用した背景画像の長さ */
}
#main-visual .wave .wave3 {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	height: 45px;
	background: url('../images/wave_w.png') repeat-x;
	background-size: 2800px 45px;
	animation: wave-slider3 18s linear infinite;
}
@keyframes wave-slider3 {
	from { background-position: 0 0; }
    to { background-position: 2800px 0; } /* 1518pxとは使用した背景画像の長さ */
}



#main-visual .scroll {
	position: absolute;
	right: 30px;
	bottom: 13%;
}
#main-visual .scroll a {
	transition: opacity .3s ease-out;
}
#main-visual .scroll a:hover {
	opacity: 0.6;
}


@media screen and (max-width: 768px) {
	#main-visual {
		height: auto;
		background: none transparent;
	}
	#main-visual .wrap {
		position: relative;
		top: 0;
		left: 0;
		transform: translateX(0);
		overflow: hidden;
	}
	#main-visual .title {
		float: none;
		height: 390px;
		margin: 0;
		padding: 0 3.25%;
		padding-top: 20px;
		background: url('../images/main_visual_sp.jpg') center top no-repeat transparent;
		background-size: cover;
	}
	#main-visual .title img {
		width: 44.57%;
		height: auto;
	}
	#main-visual .info {
		float: none;
		position: relative;
	}

	#main-visual .info .buttons {
		padding: 10px 2.7% 0;
		margin-top:-30px; 
	}
	#main-visual .info .buttons .button-x a span {
		line-height: 50px;
		padding: 0 40px;
	}
	#main-visual .info .buttons .button + .button {
		margin-top: 10px
	}

	#main-visual .share {
		position: relative;
		right: auto;
		top: auto;
		padding: 10px 0;
		background-size: 100% auto;
	}
	#main-visual .share li + li {
		margin-left: 0.5em;
	}
	#main-visual .share li a {
		display: block;
		width: 45px;
		height: 45px;
		line-height: 45px;
		background-color: #f3f3f3;
	}
	#main-visual .share li a img {
		width: 22px;
		height: auto;
	}

	#main-visual .wave {
		position: relative;
		bottom: -20px;
		left: 0;
		width: 100%;
		height: 57px;
	}
	#main-visual .wave span {
		display: block;
	}
	#main-visual .wave .wave1 {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 85px;
		background: url('../images/wave1.png') repeat-x;
		background-position: 0 0;
		background-size: 2000px 85px;
		animation: wave-slider1s 12s linear infinite;
		opacity: 1;
	}
	@keyframes wave-slider1s {
		from { background-position: 0 0; }
			to { background-position: -2000px 0; } /* 1518pxとは使用した背景画像の長さ */
	}

	#main-visual .wave .wave2 {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 80px;
		background: url('../images/wave2.png') repeat-x;
		background-position: 0 0;
		background-size: 2000px 60px;
		animation: wave-slider2s 18s linear infinite;
		opacity: .7;
	}
	@keyframes wave-slider2s {
		from { background-position: 0 0; }
			to { background-position: -2000px 0; } /* 1518pxとは使用した背景画像の長さ */
	}
	#main-visual .wave .wave3 {
		position: absolute;
		bottom: -2px;
		left: 0;
		width: 100%;
		height: 34px;
		background: url('../images/wave_w.png') repeat-x;
		background-size: 1400px 34px;
		animation: wave-slider3s 25s linear infinite;
	}
	@keyframes wave-slider3s {
		from { background-position: 0 0; }
			to { background-position: -1400px 0; } /* 1518pxとは使用した背景画像の長さ */
	}
}



/*-----------------------------------------------------------
	navi
-----------------------------------------------------------*/

.navi-link {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	max-width: 1200px;
	margin: 0 auto;
	padding: 55px 0;
	list-style: none;
	text-align: center;
	letter-spacing: -0.5em;
	border-bottom: 1px solid #e5e5e5;
}

.navi-link li {
	display: inline-block;
	letter-spacing: 0.1em;
	text-align: left;
	vertical-align: top;
	margin: 10px;
}

.navi-link li a {
	display: flex;
	width: 100%;
	align-items: center;
	padding: 0 32px;
	width: 540px;
	height: 155px;
	color: #fff;
	font-size: 1.625em;
	line-height: 1.25;
	text-decoration: none;
	background: center center no-repeat transparent;
	transition: opacity .3s ease-out;
}
.navi-link li.timetable a {
	font-size: 1.5em;
}
.navi-link li.performance a {background-image: url('../images/bg_link_performance.png')}
.navi-link li.flyer a {background-image: url('../images/bg_link_flyer.png')}
.navi-link li.journal a {background-image: url('../images/bg_link_journal.png')}
.navi-link li.timetable a {background-image: url('../images/bg_link_timetable.png')}

.navi-link li a:hover {
	opacity: 0.6;
}
.navi-link li a span {
	display: block;
	text-align: left;
	padding-right: 52px;
	background: url('../shared/images/arrow.svg') right center no-repeat transparent;
}


@media screen and (max-width: 768px) {
	.navi-link {
		display: block;
		padding: 20px 4%;
	}
	.navi-link li {
		display: block;
		width: 100%;
		max-width: 345px;
		margin-right: auto;
		margin-left: auto;
	}
	.navi-link li img {
		max-width: 100%;
		height: auto;
	}
	.navi-link li + li {
		margin-top: 15px;
	}
	.navi-link li a {
		display: block;
		padding: 0;
		padding-top: 28.69565%;
		width: 100%;
		height: auto;
		line-height: 1;
		font-size: 1em;
		background-size: cover;
		position: relative;
	}
	.navi-link li.timetable a {
		font-size: 1em;
	}
	.navi-link li a:hover {
		opacity: 0.6;
	}
	.navi-link li a span {
		display: block;
		position: absolute;
		left: 20px;
		top: 50%;
		transform: translateY(-50%);
	}
}



/*-----------------------------------------------------------
	movie
-----------------------------------------------------------*/
.movie {
	padding: 50px 0 60px;
	text-align: center;
	background: url('../images/bg_movie.jpg') center top transparent;
}
.movie .movie-hdg {
	margin-bottom: 2em;
	font-size: 1.25rem;
	font-weight: bold;
	color: #0f55a5;
}
.movie .youtube {
	max-width: 730px;
	margin: 0 auto 40px;
}
.movie .youtube .youtube-wrap {
	padding-top: 56.25%;
	position: relative;
}
.movie .youtube iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 768px) {
	.movie {
		padding: 25px 4% 30px;
		background-size: 198px auto;
	}
	.movie .movie-hdg {
		margin-bottom: 1.6em;
		font-size: 1rem;
	}
	.movie .youtube {
		margin: 0 auto 25px;
	}
}



/*-----------------------------------------------------------
	navi link panel
-----------------------------------------------------------*/

.navi-link-panel {
	padding: 40px 0;
	background-color: #f3f3f3;
}
.navi-link-panel ul {
	display: flex;
	justify-content: space-evenly;
	margin: 0;
	padding: 0;
	list-style: none;
}
.navi-link-panel ul li {
	display: flex;
}
.navi-link-panel ul li a {
	display: block;
	width: 100%;
	color: #000;
	font-size: 1.25em;
	text-decoration: none;
	background-color: #fff;
	border-radius: 10px;
	transition: opacity .3s ease-out;
}
.navi-link-panel ul li a:hover {
	opacity: 0.6;
}
.navi-link-panel ul li.close {
	position: relative;
}
.navi-link-panel ul li.close::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .75);
	border-radius: 10px;
	content: '';
}
.navi-link-panel ul li.close::after {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
	font-size: 2rem;
	color: #fff;
	text-align: center;
	content: 'coming soon';
}

.navi-link-panel ul.link li {
	width: 350px;
}
.navi-link-panel ul.link li a {
	padding-bottom: 32px;
	text-align: center;
}
.navi-link-panel ul.link figure {
	display: table;
	width: 100%;
	height: 135px;
}
.navi-link-panel ul.link figure span {
	display: table-cell;
	text-align: center;
	vertical-align: middle;
}
.navi-link-panel ul.link .text {
	display: inline-block;
	margin: 0;
	padding-right: 38px;
	background: url('../shared/images/arrow_b.svg') right center no-repeat transparent;
}

.navi-link-panel .other-ticket .title {
	margin: 30px 0;
	font-size: 1.25em;
	line-height: 1;
	text-align: center;
}
.navi-link-panel .other-ticket ul li {
	width: 540px;
}
.navi-link-panel .other-ticket ul li a {
	padding: 30px;
	overflow: hidden;
}
.navi-link-panel .other-ticket ul li figure {
	float: left;
	margin-right: 26px;
}
.navi-link-panel .other-ticket ul li .text {
	margin: 0;
	padding-right: 38px;
	background: url('../shared/images/arrow_b.svg') right center no-repeat transparent;
}




@media screen and (max-width: 768px) {
	.navi-link-panel {
		padding: 15px 4% 25px;
	}
	.navi-link-panel ul {
		display: block;
	}
	.navi-link-panel ul li {
		display: block;
	}
	.navi-link-panel ul li + li {
		margin-top: 10px;
	}
	.navi-link-panel ul li a {
		display: block;
		font-size: 0.875em;
		border-radius: 5px;
	}


	.navi-link-panel ul.link li {
		width: auto;
	}
	.navi-link-panel ul.link li a {
		overflow: hidden;
		padding: 0;
		padding-right: 20px;
		text-align: left;
	}
	.navi-link-panel ul.link figure {
		width: 70px;
		height: 60px;
		float: left;
	}
	.navi-link-panel ul.link figure span {
		text-align: center;
	}
	.navi-link-panel ul.link figure img {
		width: auto;
		height: auto;
		max-width: 40px;
		max-height: 40px;
	}
	.navi-link-panel ul.link .text {
		display: block;
		margin: 0;
		line-height: 60px;
		padding-right: 35px;
		background-size: 25px auto;
	}

	.navi-link-panel .other-ticket .title {
		margin: 25px 0;
		font-size: 1em;
	}
	.navi-link-panel .other-ticket ul li {
		width: auto;
	}
	.navi-link-panel .other-ticket ul li a {
		line-height: 60px;
		padding: 0;
		padding-right: 20px;
	}
	.navi-link-panel .other-ticket ul li figure {
		float: left;
		width: 70px;
		margin: 0;
		text-align: center;
	}
	.navi-link-panel .other-ticket ul li figure img {
		width: 40px;
		height: auto;;
	}
	.navi-link-panel .other-ticket ul li .text {
		margin: 0;
		padding-right: 35px;
		background-size: 25px auto;
	}

}




/*-----------------------------------------------------------
	pre news
-----------------------------------------------------------*/
#pre-news ul {
	margin: 0;
	padding: 0 0 60px;
}
#pre-news ul li {
	display: block;
	padding: 20px 0;
	border-bottom: 1px solid #eee;
}
#pre-news ul li dl {
	margin: 0;
	width: 100%;
	position: relative;
	cursor: pointer;
}
#pre-news ul li dl:after {
	display: block;
	content: '';
	width: 24px;
	height: 24px;
	background: url('../shared/images/arrow_down.svg') center center / contain no-repeat transparent;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%) rotate(0deg);
	transition: transform .1s;
}
#pre-news ul li.open dl:after {
	transform: translateY(-50%) rotate(180deg);
}
#pre-news ul li dl > div {
	display: flex;
	padding-right: 40px;
}
#pre-news ul li dl dt,
#pre-news ul li dl dd {
	display: inline-block;
	margin: 0;
	padding: 20px 0;
	font-size: 1.125rem;
	line-height: 1;
}
#pre-news ul li dl dt {
	width: 15%;
	font-weight: normal;
}
#pre-news ul li dl dd {
	font-weight: bold;
}
#pre-news ul li .content {
	display: none;
	padding: 20px 0;
	font-size: 1rem;
	line-height: 2;
}
#pre-news ul li .content p {
	margin: 0;
}
#pre-news ul li .content p + p {
	margin-top: 1em;
}


@media screen and (max-width: 768px) {
	#pre-news {
		padding: 0 4% 30px;
	}
	#pre-news ul li {
		padding: 10px 0;
	}
	#pre-news ul li dl:after {
		width: 24px;
		height: 24px;
	}
	#pre-news ul li dl > div {
		display: block;
		padding: 10px 0;
		padding-right: 40px;
	}
	#pre-news ul li dl dt,
	#pre-news ul li dl dd {
		display: block;
		padding: 0;
		font-size: 1rem;
		line-height: 1.5;
	}
	#pre-news ul li dl dt {
		width: auto;
		font-size: 0.75em;
		margin-bottom: 0.5em;
	}
	#pre-news ul li .content {
		padding: 10px 0;
		font-size: 0.875rem;
	}
}