@charset "utf-8";


.L {
	float:left;
}
.R {
	float:right;
}
a {
	outline:none;
}
a:focus{
	outline:none;
}
*{ box-sizing:border-box;}
html { -webkit-text-size-adjust: 100%; font-size: 62.5%;}
body, div, dl, dt, dd,  h1, h2, h3, h4, h5, h6, table, td, th, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td {
	margin: 0;
	padding: 0; font-weight:inherit;
}
h1 { text-indent: -9999px; line-height:0;}
ul { list-style:none;}

/* =====================================================================
*	TOPページ
* =================================================================== */
body {
	position:relative;
	background: #000;
	color:#fff;
	font-size:16px;
	font-size:1.6rem;
     font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
}
html, body {
height: 100%;
min-height: 100%;
}

body > #menu {
  height: 100%;
}
body > #wrapper {
  height: 100%;
}


body > .bg_subtitle_obi {
  height: auto;
 }
 

a:link { color:#ff3399; text-decoration:none;  }
a:visited { color:#cc0066; text-decoration:none; }
a:hover { color: #cc3399; text-decoration:none; }
a:active {ccolor:#cc3399; text-decoration:none; }
a:focus {color:#cc3399; text-decoration:none;}


/* ---------------------------------
*    clearfix
*/
.clearfix { min-height: 1%; }

.clear { clear:both; }

.clearfix:after {
    content: ".";
    display: block;
    height: 0px;
    clear: both;
    visibility: hidden;
}

.clearfix { display: inline-table; }

/* Hides from Mac IE ＼*/
* html .clearfix { height: 1px; }
.clearfix { display: block; }
/* Hides from Mac IE */



 /* =====================================================================
*	loader
* =================================================================== */

#loader-bg {
  display: block;
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  z-index: 10000;
  background: #000;
}
#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  margin-top: -100px;
  margin-left: -100px;
  text-align: center;
  color: #fff;
  z-index: 1002;
  font-size:0.7em;
}
 

#wrapper { display: none;
	width: 100%;
	min-height: 100%;
	min-width: none;
	height: 100%;
	padding: 0;
	margin: 0 auto;
	position: relative;
}


#main { display: block; line-height: 0; margin: 0; padding:0; height:auto; text-align: center; }
.main_area { display:block; position: relative; width:100%; max-width:1200px; margin:0 auto; line-height: 1; padding:0; overflow: hidden; }
.main_area img { width:100%; height:auto; }
.main1 { display:block; position: absolute; top:0; left:0; z-index: 5; width:100%;  }
.main2 { display:block; position: absolute; top:0; left:0; z-index: 7; width:100%;   }
.main3 { display:block; position: absolute; top:0; left:0; z-index: 6; width:100%;   }

.fadein {
    opacity: 0;
    animation: fadein 2s ease forwards;
}
@keyframes fadein {
    100% {  opacity: 1;}
}

.fadeins {
    opacity: 0;
    animation: fadeins 1.0s ease forwards;
}
@keyframes fadeins {
    0% { opacity: 0; transform: translateY(-30px); }
	100% { opacity: 1; transform: translateY(0); }
}

.fadeinl {
    opacity: 0;
    animation: fadeinl 3.0s ease forwards;
}
@keyframes fadeinl {
    0% { opacity: 0; transform: translateY(350px); }
	100% { opacity: 1; transform: translateY(0); }
}


.v01 {animation-delay: 1.5s;}
.v02 {animation-delay: 2s;}
.v03 {animation-delay: 4s;}



.roadshow { width: 100%; text-align: center; max-width: 1200px; margin:0 auto; line-height:1; }
.roadshow img { width: 100%; }

.movieticket { width: 100%; position: relative; text-align: center; padding: 0; line-height: 1em; margin: 1.5em auto 2em; }
#mvtk-widgets-container { margin: 0 auto;}

.pmain { display:block; position: relative; width:100%; max-width:1000px; margin:0 auto; line-height: 1; padding: 0 1em;}
.pmain img { width:100%; height:auto; }

.catch { display:block;  position: relative; width:100%; max-width:1100px; margin:0 auto; line-height: 1.4; padding:0 1em 0; color:#cc0000; text-align: center; font-size:1.7em; }
.catch img { width: 100%; }


.comic { display:block; width:100%; max-width:600px; margin:0 auto; line-height: 1; padding:1em; }
.comic img { width:48%; padding:0 1%; }

.billing { width: 100%; text-align: center; margin:0; padding:1em 0.5em; line-height: 1.8em; background-color: rgba(0,0,0,0.20); }
.billing .dan4 { font-size: clamp(1.4em, 1.8vw, 1.6em); display: block; padding:0.5em 0; line-height: 1.6em; margin:1em 0 0; }

.billing .dan1 { font-size: 1em;  display: block; padding:0.5em 0; line-height: 1.6em; }
.billing .dan2 { font-size: 0.9em;  display: block; padding:0.5em 0; line-height: 1.4em; }


.billing .dan2 span { display:inline-block;}
.billing .dan2 font { font-size:0.8em;}

.fs9 { display:inline-block; font-size:0.8em; }

.cr { width: 100%; text-align: center; margin:0; padding:1em 0; line-height: 1em; font-size:0.8em;  color:#fff; background: #000; }


.introduction, .story, .staff, .cast { margin:0em auto 2em; padding: 1em 0.5em; width:100%; max-width:1200px; overflow: hidden; line-height: 1.9em;}

.tit { margin: 1.5em auto 1em; width:100%; max-width:1100px; padding:0.3em; line-height: 1em; font-weight: 600; color:#fff; font-size:1.6em; letter-spacing: 0.1em; font-family: "Noto Serif JP", serif; text-align: center; background-image: url("../img/tit-bg.png"); background-size: 100% 100%;}

.midashi { margin: 1em auto; line-height: 1.4em; font-weight: 500; color:#fff; font-size:1.7em; text-align: center; font-family: "Noto Serif JP", serif; }
.midashi p { font-size:0.8em; line-height: 1.4em; margin: 0.6em 0;}
.midashi p span { display: inline-block; }


.pict { margin: 0 0 1em; line-height: 1em;}
.pict img { width:100%; }
.texarea { line-height: 1.9em; font-size: 1em;  text-align: justify; }
.texarea span { font-size: 0.9em; font-weight:700; }

.sub { display:block; position: relative; width:100%; margin:2em auto 0; line-height: 0; padding:0; }
.sub img { width:100%; height:auto; }

.sub2 { display:block; position: relative; width:100%; margin:0 auto 4em; line-height: 0; padding: 0 0; background-image: url("../img/su2.jpg"); background-size: 100% auto; background-repeat: no-repeat; background-position: top center; }
.sub2 .intro { padding: 1em; width:100%; margin: 0 auto; max-width:1000px; text-align: left; line-height: 2em; color:#fff; }
.sub2 .intro p { margin: 0 0 1.5em; text-align: left; line-height: 1.9em;}

.sub2 .intro .tit { width:100%; margin: 0 auto 1.5em; font-size: clamp(1.7em, 1.8vw, 2.1em); font-weight:900; text-align: center; line-height:1.4em; }

	
.bxsliderg { list-style: none; padding: 0; margin: 0; }
.bxsliderg img { width: 100%; padding:0; }

.st-tex h2 { font-size:1.1em; font-weight:600!important; color:#da0d89; margin: 1em 0 0.8em; line-height:1.1em; text-align: left; padding:0.2em 0; border-top:1px solid #da0d89; border-bottom:1px solid #da0d89;  }


.cas-tex { padding: 1em; width:100%; margin: 0 auto; max-width:1000px; text-align: left; line-height: 2em; color:#fff; overflow: hidden; }
.cas-tex p { margin: 0 0 1.5em; text-align: left; line-height: 1.9em;}

.cas-tex h2 { font-size:1.3em; font-weight:500!important; color:#ff63c1; margin: 1em 0 1.2em; line-height:1.1em; text-align: left; padding:0.2em 0; border-bottom:1px solid #ff63c1;  }
.cas-tex h2 span { font-size:0.8em;}

.cas-tex table { margin:0; padding:0; }
.cas-tex .photo { float: right; width:40%; max-width:400px; padding: 0 0 1.5em 1.5em;}
.cas-tex .photo img {  width:100%; height:auto; }

@media screen and (max-width: 768px) {
	
.cas-tex .photo { float: none; width:100%; max-width:600px; margin:auto; padding: 0 0 1.5em 0; text-align: center;}
	
}
	


.sttitle { margin: 1em 0 2.5em; text-align: center; letter-spacing: 0.3em; }
.sttitle img { margin: 0 auto; width:30%; max-width:180px;}

.staftitle { margin: 1em 0 2.5em; text-align: center; letter-spacing: 0.3em; }
.staftitle img { margin: 0 auto; width:40%; max-width:170px;}

.castitle { margin: 3em 0 1em; text-align: center; letter-spacing: 0.3em; }
.castitle img { margin: 0 auto; width:40%; max-width:170px;}

.protitle { margin: 1em 0 2.5em; text-align: center; letter-spacing: 0.3em; }
.protitle img { margin: 0 auto; width:60%; max-width:400px;}


.tw {display:block; text-align:center; padding:1em 0; line-height:1em; margin: 0;}
.tw img { width:40px; height:auto;}


.conts { background-size: cover; background-position: center center; background-image: url("../img/bgs.jpg"); padding:3em 0;; margin:0; line-height:0; overflow: hidden; }


.trailerwaku {position: relative; width: 100%; padding:2em 0 3em; background-image: url("../img/trail_bg.jpg"); background-size: 100% 100%; background-position: bottom center;}
.trailer { position: relative; width: 100%; margin:2em auto 2em; max-width: 1200px; height:auto; padding:0.5em;}
.youtube { position: relative; width: 100%; padding: 56.25% 10px 0; margin:0 auto;  }
.youtube iframe { position: absolute; top: 0; right: 0; width: 100%; height: 100%;}
.trailtitle { text-align: center; padding: 2em; line-height:1em; font-size:1.3em; color:#444; font-weight:400;　letter-spacing: inherit; letter-spacing:3px; }

.trtitle { margin: 1em 0 1.5em; text-align: center; letter-spacing: 0.3em; }
.trtitle img { margin: 0 auto; width:30%; max-width:220px;}

a.opa:hover img { opacity: 0.7; } 


div.vid_contents {
width: 100%; border: 1px solid rgba(112,104,63,0.50);
text-align: center;
padding: 0;
}
video.vid_main {
width: 100%;
}


.tharea { width:100%; height: auto; margin:0 auto 1em; max-width:1200px; position:relative; padding: 3em 1em 0; }
.theatable {  width:100%;  margin: 0 auto;  border-bottom:1px solid #ccc; }
.theatable th {  border-top:1px solid #ccc;  color: #ccc; text-align:center; padding:0.6em 0em;   background: #222; }
.theatable td { border-top:1px solid #ccc; color:#fff; padding:1.6em 0.2em; text-align:center; vertical-align:middle; line-height:1.1em;  font-size:1.0em; background: #16151d;}
.theatable a { color:#ff9933; line-height:1.2em; text-decoration: underline; }
.theatable a:hover { color:#ffcc66; line-height:1.2em; text-decoration: none; }
.col1 { width:25%;}
.col2 { width:20%;}
.col3 { width:55%;}
.t_left { text-align: left !important;}
.futol { border-top: 2px solid #fff !important; border-bottom: 2px solid #fff !important; }
.thetitle { font-size: clamp(1.4em, 1.8vw, 1.6em); margin: 1em 0 1.5em; text-align: center; letter-spacing: 0.3em; }
.bgthc { background: #151720; padding:1em 0.2em !important;}
.bgthb { background: #555; }




.fadeIn {
  opacity: 0;
  transition: 1s;
}
.fadeIn.is-show {
  opacity: 1;
}
.fadeIn_left {
  opacity: 0;
  transform: translate(-10%, 0);
  transition: 0.6s;
}
.fadeIn_left.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.fadeIn_up {
  opacity: 0;
  transform: translate(0, 5%);
  transition: 1s;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.fadeIn_down {
  opacity: 0;
  transform: translate(0, -15%);
  transition: 1s;
}
.fadeIn_down.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.fadeIn_right {
  opacity: 0;
  transform: translate(10%, 0);
  transition: 0.6s;
}
.fadeIn_right.is-show {
  transform: translate(0, 0);
  opacity: 1;
}


@media screen and (max-width: 768px) {
.fadeIn_left { transform: translate(0, 10px); }
.fadeIn_right { transform: translate(0, 10px); }
    

h2.titles2 { margin-bottom:1em; position: relative; z-index: 2; text-align:center; }
.theatable td { font-size:0.9em;}
.tw img { width:60px; height:auto;}
.roadshow img { width: 100%; }

.contents { padding:2em 2em; overflow: inherit; }
.contents .tex {  padding:1em 0;}    



}



.t_right { text-align:right;}
.right { margin: 0 0 0 auto;}
.center { margin: 0 auto; text-align: center;} 

footer { background: #000; text-align: center; padding: 1em 0; font-size: 0.8em; margin-top: 0em; color:#fff; }

/* =====================================================================
    NEWS
* =================================================================== */


.t_center { text-align:center !important;}
.t_center2 { text-align:center !important; padding:1em 0 0em;}
.t_center2 a:hover { opacity:0.6; }
.t_centerb { display: block; text-align:center !important; padding:1em 0.5em; }


/* page-top */
#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	display:block;
}
#page-top a {
	text-decoration: none;
	width: 80px;
	height:auto;
	padding: 0;
	text-align: center;
	display: block;
	
}



/*     */

.overlay {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.85);
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  opacity: 0;
 transition: all .5s;
}
.overlay.open { display: block;
  width: 100%;
  height: 100%;
    z-index: 5000;
    opacity: 1;
	position: fixed;
    transition: opacity 1s;
}


.menu-trigger {
  display: inline-block;
width: 60px;
  height: 60px;
  vertical-align: middle;
  cursor: pointer;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999; background: rgba(0,0,0,0.40); 
/*   transform: translateX(0);
  transition: transform .5s;
 */}
/* .menu-trigger.active {
  transform: translateX(-250px);
}
 */.menu-trigger span {
  display: inline-block;
  box-sizing: border-box;
  position: absolute;
  left: 12px;
  width: 36px;
  height: 4px; border-radius: 2px;
  background-color: #fff;
  transition: all .5s;
}
.menu-trigger.active span {
  background-color: #ed6d00;
}
.menu-trigger span:nth-of-type(1) {
  top: 15px;
}
.menu-trigger.active span:nth-of-type(1) {
  transform: translateY(13px) rotate(-225deg);
}
.menu-trigger span:nth-of-type(2) {
  top: 28px;
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 15px;
}
.menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-13px) rotate(225deg);
}

nav { display: flex; flex-direction: column; 
  width: 100%;
  height: 100%;
  padding: 40px;
  position: fixed; overflow-y: auto;
  top: 0;
  left: 0;
  z-index: 6000;
 opacity: 0;
    pointer-events: none;
  -webkit-transition: all 0.3s;
      -moz-transition: all 0.3s;
      -ms-transition: all 0.3s;
      -o-transition: all 0.3s;
      transition: all 0.3s;
    
}
nav.open { opacity: 1;
    transition: opacity 1s;
    pointer-events: auto;
}

nav.smn div { margin: 0 auto 0 !important; line-height:1em; 
  color: #fff;
  text-align: center;
  padding: 0.5em !important;
  width: 100%; max-width: 500px; display: inline-block; line-height: 1; border-bottom: 1px dashed #ffcc00;
}

nav.smn div:last-child { border-bottom: none;
}


nav.smn div a { color: #ed6d00; font-size: 1.7em;
  text-align: center; line-height: 1;
  padding: 10px 0 !important;
  width: 100%; display: block; 
}
nav.smn div a:hover { opacity:0.9; color:#ffcc00;}


.pconly { display:inherit; }
.sponly { display:none; }
.dnon { display:none; }


@media screen and (max-width: 768px) {
body {
    font-weight: 400;
}
html { font-size: 84%;}
.pconly { display:none; }
.sponly { display:inherit; }

nav.smn div { margin: 0.3em 0em 0.3em 1.7em;}
nav.smn div a { font-size: 1.5em;}

    
.menu-trigger {
  display: inline-block; 
width: 80px;
  height: 80px;
  }
/* .menu-trigger.active {
  transform: translateX(-250px);
}
 */.menu-trigger span {
  display: inline-block;
  box-sizing: border-box;
  position: absolute;
  left: 14px;
  width: 52px;
  height: 3px;
  background-color: #fff;
  transition: all .5s;
}
.menu-trigger.active span {
  background-color: #fff;
}
.menu-trigger span:nth-of-type(1) {
  top: 24px;
}
.menu-trigger.active span:nth-of-type(1) {
  transform: translateY(14px) rotate(-45deg);
}
.menu-trigger span:nth-of-type(2) {
  top: 38px;
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 24px;
}
.menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-14px) rotate(45deg);
}

    
}


