@charset "utf-8";
/* CSS Document */


/* 全体への指示 */
body {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 15px;
	background-color: black;
	margin: 0;
	padding: 0;
	min-width: 960px;
}


h1 {
	font-size: 50px;
	color: red;
	letter-spacing: 15px;
}

h2 {
	font-size: 35px;
	color: white;
	line-height: 40px;
}


p {
	font-size: 20px;
	line-height: 27px;
	color: white;
	font-family: "Hiragino Mincho ProN";
}



.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}

div.wrapper {
	overflow: hidden;
}


/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.6.0
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2018 Daniel Eden
 */

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}




/* メイン領域*/

main.main {
	display: block;
	margin: 0 auto;
}


/*========= LoadingのためのCSS ===============*/

/* Loading背景画面設定　*/
#splash {
    /*fixedで全面に固定*/
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 999;
	background:#333;
	text-align:center;
	color:#fff;
}

/* Loading画像中央配置　*/
#splash_logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#splash_logo img {
	width: 800px;
}

/* fadeUpをするアイコンの動き */

.fadeUp{
animation-name: fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity: 0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}



/*========= レイアウトのためのCSS ===============*/

#splash {
    width:100%;
    height: 100vh;
    background-color: black;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
	z-index: 9999999;
}

/*========= LoadingのためのCSSここまで ===============*/



/*ナビ領域*/

.site-header{
    background: black;
    display: flex;
    padding: 10px 0 10px 0;
    position: fixed;
    justify-content: space-between;
    width: 100%;
	z-index: 995;
}

.gnav {
	margin: 0 auto;
	width: 100%;
}

.gnav__menu{
    display: flex;
}

.gnav__menu__item {
	margin-right: 25px;
}

.gnav__menu__item img {
	height: 30px;
}

.gnav__menu__item img:hover {
	opacity:0.6 ;
	transition:0.5s ;
}

.gnav__menu__item a {
	text-decoration: none; 
	color: white;
	font-size: 25px;
	font-family: "Arial Black", Gadget, "sans-serif","HGP明朝E", "HGP明朝B";
}

.gnav__menu__item a:hover {
	color: red;
	text-decoration: underline;
	transition:0.5s ;
}

/*ナビ領域ここまで*/




div.mainER {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
	position: relative;
	padding-top: 70px;
}

div.mainimg {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-image: url("../images/main.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: calc(100%*1978/1500);
}





div.date {
	width: 1000px;
	min-width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding: 50px 0 0 0;
}

div.date img {
	width: 800px;
}



div.topbox {
	width: 1000px;
	height: 30px;
	margin: 0 auto;
	padding: 50px 0 50px 0;
}

div.topbox ul { 
	position: relative;
	left: 50%; 
	float: left;
}

div.topbox ul li{ 
	position: relative; 
	left: -50%; 
	float: left;
	list-style: none; 
	margin-right: 40px;
}

.topbox ul li:last-child {
	margin-right: 0;
}


div.tw {
	float: left;
	margin-right: 10px;
}

div.eigacom {
	float: left;
}


div.button {
	margin: 0 auto;
	width: 1000px;
	text-align: center;
	position: relative; 
	overflow: hidden;
	padding: 50px 0 50px 0;
}


div.button a img { 
	width: 200px;
}


div.button a:hover {
	opacity:0.6 ;
	transition:1.0s ;
}


div.twitter {
	position: absolute;
	top: 15px;
	right: 15px;
	text-align: center;
	display: block;
}
	
div.twitter img {
	width: 100px		
}


div.twitter img:hover {
	opacity:0.6 ;
	transition:1.0s ;
}	


.spotify {
	margin: 0 auto;
	width: 1000px;
	text-align: center;
	position: relative; 
	overflow: hidden;
	padding: 50px 0 50px 0;
}



/*予告ここから*/

.trailerBOX {
	width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding: 50px 0 20px 0;
}

.trailerBOX iframe {
	width: 900px;
	height: 506.25px;
}

/*予告ここまで*/



/*イントロここから*/



.infoER {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
}

.read {
	width: 1000px;
	min-width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding-top: 50px;
}

.read img {
	width: 900px;
}


.infoimg {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-image: url("../images/info001.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: calc(100%*975/1500);
}


.Intro {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
}


.IntroText {
	width: 900px;
	margin: 0 auto;
	padding: 0 0 50px 0;
}

.IntroText p {
	width: 900px;
	font-size: 20px;
	line-height: 32px;
	color: white;
}

.IntroText h1 {
	text-align: center;
	color: white;
}




/*ストーリーここから*/

#Story {
	background-color: black;
}

.storyER {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
}

.storyimg {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-image: url("../images/info002.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: calc(100%*733/1500);
}

.storyCOPY {
	width: 900px;
	margin: 0 auto;
}

.storyCOPY img {
	width: 900px;
}


.StoryText {
	padding: 30px 0;
	width: 900px;
	margin: 0 auto;
}

.StoryText p {
	width: 900px;
	font-size: 20px;
	line-height: 28px;
	color: white;
}


.StoryText h1 {
	text-align: center;
}




.storyER02 {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
	padding-bottom: 25px;
}

.storyimg02 {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-image: url("../images/info003.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: calc(100%*794/1500);
}





/*ループスライダーここから*/

	.jp_slide_img_wrapper {
    position: relative;
	width: 100%;
    height: 200px;
    background-image: url('../images/photo01.png');
    background-repeat: repeat-x;
    background-size: cover;
    background-position: 0 0;
    animation-name: slide_img;
    animation-duration: 200s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@keyframes slide_img {
    100% {
        background-position: -10000px 0;
        }
}

.jp_slide_img_overlay{
    position: absolute;
    top: 0%;
    right: 0%;
    left: 0%;
    bottom: 0%;
    width: 100%;
    height: 100%;
}

.main_catch {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    text-align: center;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
}


/*ループスライダーここまで*/



/*キャスト・スタッフここから*/

.CastBOX {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
}

.CastBOX h1 {
	padding-top: 30px;
	text-align: center;
}

.CastBOX h3 {
	font-size: 25px;
	color: red;
	line-height: 30px;
}

.castIND {
	width: 900px;
	margin: 0 auto;
	padding: 30px 0;
}



.castER {
	width: 100vw;
	min-width: 1000px;
	margin: 0 auto;
}

.castimg {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-image: url("../images/info004.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: calc(100%*794/1500);
}















.theater_BT {
	width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding: 20px 0 50px 0;
}

.theater_BT a {
	width: 600px;
	padding: 15px 25px;
	background-color: red;
	font-size: 35px;
	font-weight: bold;
	border-radius: 10px;
	letter-spacing: 10px;
	color:white;
}

.theater_BT a:link {
	color: black;
	text-decoration: none;
}

.theater_BT a:visited {
	color: black;
	text-decoration: none;
}

.theater_BT a:active {
	color: black;
	text-decoration: none;
}
	
.theater_BT a:hover {
	background-color: darkred;
	color: white;
	transition:0.9s ;
}	







footer {
	width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding-bottom: 75px;
}

footer img {
	width: 800px;
	padding: 35px 0 0 0;
}



/* メイン領域ここまで*/




/*劇場情報*/

	
main.theatermain {
	display: block;
	margin: 0 auto;
	text-align: center;
	background-size: cover;
}

table { width: 100%; }

div.eigakan { padding-top: 20px;}

.THlogo {
	width: 100%;
}

.THlogo img { 
	width: 750px;
}


.THlogo img:hover {
	opacity:0.6 ;
	transition:1.0s ;
}

.top {
	width: 100%;
	padding-top: 50px;
}

.top a { 
	font-size: 30px;
	font-weight: bold;
	border-radius: 10px;
	letter-spacing: 10px;
	color:white;
}


.top a:link {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.top a:visited {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.top a:active {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.top a:hover {
	color: red;
	
}


#theater {
	color: white; 
	display: block;	
	overflow: hidden;
	text-align: center;
	margin: 0 auto;
	padding: 50px 0 50px 0;
}

.maeuri_button {
	padding: 30px 0 40px 0;
	width: 100%;
}

.maeuri_button a {
	width: 800px;
	padding: 25px 75px;
	background: linear-gradient(-135deg, #ff0000, #990000);
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 10px;
	text-decoration: none;
	color: white;
	border-radius: 15px;
	box-shadow: 2px 2px 4px grey;
}

.maeuri_button a:hover {
	background: linear-gradient(-135deg, #990000, #ff0000);
}


.tokuten {
	width: 1000px;
	padding: 50px 0;
	margin: 0 auto;
}

.tokuten img { 
	width: 750px;
	border: 1px red solid;
}

.majorBT {
	margin: 0 auto;
	width: 750px;
	border: 1px red solid;
	margin-top: -5px;
}

.majorBT a {
	font-size: 30px;
	font-weight: bold;
	display: block;
	background-color: red;
	width: 750px;
	margin: 0 auto;
	padding: 20px 0;
	letter-spacing: 10px;
}

.majorBT a:link {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:visited {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:active {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:hover {
	color: yellow;
	text-decoration: underline;
	background-color: darkred;
	transition:0.4s ;
	
}



.muvichike img {
	width: 300px;
	padding-top: 50px;
}

.muvichike img:hover {
	opacity:0.6 ;
	transition:1.0s ;
}




div.theaterTEXT {
	margin-bottom: 25px;
}


.theaterBIGBOX {
	width: 80%;
	min-width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding-bottom: 50px;
}
	
th.todofuken {width: 15%;}
th.gekijou {width: 50%;}
th.koukaibi {width: 35%;}


table {
	margin: 0 auto;
	border-collapse: collapse;
	width: 90%;
}

td, th {
	padding: 30px 15px;
	text-align: center;
	font-size: 23px;
}

.th00 {
	text-align: center;
}

thead tr {
	background-color: dimgrey;
}

tr.theaterBox {
	color: white;
	border-bottom: 1px dashed white;
}




tr.theaterBox td a:link {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

tr.theaterBox td a:visited {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

tr.theaterBox td a:active {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

tr.theaterBox td a:hover {
	color: red;
	text-decoration: underline;
	
}



#theater div.theaterCT {
	margin: 0 auto;
}

div.CR {
	width: 1000px;
	padding-bottom: 75px;
	margin: 0 auto;
}

div.CR img {
	width: 800px;
}

.areaNAV {
	width: 1000px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
	text-align: center;
	padding-top: 50px;
}



.areaNAV ul {
	position: relative;
	left: 50%; 
	float: left;
	list-style: none;
}

.areaNAV ul li {
	position: relative; 
	left: -55%; 
	float: left;
	list-style: none; 
	margin-right: 40px;
}

.areaNAV ul li:last-child {
	margin-right: 0;
}

.areaNAV ul li a {
	text-decoration: none;
}

.areaNAV ul li a p {
	color: white;
	font-size: 22px;
	font-weight: bold;
	text-decoration: none;
}

.areaNAV ul li a p:hover {
	color: red;
}



.tokuten {
	width: 1000px;
	padding: 50px 0;
	margin: 0 auto;
}

.tokuten img { 
	width: 750px;
	border: 1px red solid;
}

.majorBT {
	margin: 0 auto;
	width: 750px;
	border: 1px red solid;
	margin-top: -5px;
}

.majorBT a {
	font-size: 30px;
	font-weight: bold;
	display: block;
	background-color: red;
	width: 750px;
	margin: 0 auto;
	padding: 20px 0;
	letter-spacing: 10px;
}

.majorBT a:link {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:visited {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:active {
	color: white;
	text-decoration: none;
	font-weight: bold;
}

.majorBT a:hover {
	color: yellow;
	text-decoration: underline;
	background-color: darkred;
	transition:0.4s ;
	
}

.mvol {
	margin: 0 auto;
	padding: 20px 0;
	width: 300px;
}

.mvol a img {
	width: 300px;
}

.mvol a:hover {
	opacity:0.6 ;
	transition:1.0s ;
}







/*劇場情報ここまで*/


