@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; margin: 0; padding: 0; }

/* =====================================================================
*	TOPページ
* =================================================================== */
body {
	position:relative;
	background: #000;
	color:#fff;
	font-size:16px;
	font-size:1.6rem;
     font-family: "M PLUS 1p", sans-serif;
    font-weight: 500;
	background-image: url("../img/sub-bg.jpg");
}
html, body {
height: 100%;
min-height: 100%;
}

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


body > .bg_subtitle_obi {
  height: auto;
 }
 

a:link { color:#ff3333; text-decoration:none;  }
a:visited { color:#ff3333; text-decoration:none; }
a:hover { color: #ff3333; text-decoration:none; }
a:active {ccolor:#ff3333; text-decoration:none; }
a:focus {color:#ff3333; 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: 37px;
  margin-top: -18px;
  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 0;
	margin: 0 auto;
	position: relative;
}


.btm-menu { position: absolute; position: fixed; padding:0; bottom:0; left:0; width:100%; z-index:500; background-image: url("../img/menu-bg.jpg"); background-size: 100% 100%; line-height: 1; color:#fff; display: flex; justify-content:center; transition: all .5s;}
.btm-menu a.icon { height:40px; width:auto; display:inline-block; position: relative; }
.btm-menu a:hover { opacity:0.6; }
.btm-menu a.icon img { height:100%; width:auto; }

@media screen and (max-width: 768px) {
.btm-menu a.icon { height:50px; width:auto; display:inline-block; position: relative; }	
}


#main { display: block; background: #000; line-height: 0; margin: 0; padding:0; height:auto; text-align: center; background-image: url("../img/bg.jpg");background-size: auto 100%; background-position: center 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%;   }
.main4 { display:block; position: absolute; top:0; left:0; z-index: 8; width:100%;   }
.logo { display:block; position: absolute; bottom:12.5%; left:0; z-index: 9; width:100%; height:auto; }
.logo img { width:100%; height:auto; }
.logo-sp { display:none; position: absolute; bottom:12.5%; left:0; z-index: 9; width:100%; height:auto; }
.logo-sp img { width:100%; height:auto; }

@media screen and (max-width: 768px) {
#main { display: block; background: #000; background-image: none;  }

.logo { display:none; position: absolute; bottom:12.5%; left:0; z-index: 9; width:100%; height:auto; }
.logo img { width:100%; height:auto; }
.logo-sp { display:block; position: absolute; bottom:12.5%; left:0; z-index: 9; width:100%; height:auto; }
.logo-sp img { width:100%; height:auto; }
}


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

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

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


.v01 {animation-delay: 1s;}
.v02 {animation-delay: 2s;}
.v03 {animation-delay: 3s;}
.v04 {animation-delay: 4s;}
.v05 {animation-delay: 5s;}



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


.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; }

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

.catch { display:block; width:100%; max-width:600px; margin: 1em auto 0.5em; line-height: 1; padding:0; font-size:1.3em; font-weight:800; color:#ff0000; text-align: center; }
.catch img { width:100%; height:auto; }
rt { translate: 0 .3em; }

.texarea { display:block; font-weight:400; position: relative; width:100%; max-width:1200px; margin:0 auto; line-height: 1.8; padding:0.5em; color:#fff;  }
.texarea p { display:block; font-weight:400; position: relative; width:100%; max-width:1200px; margin:0 0 1em; line-height: 1.8; padding:0; color:#fff;  }
.texarea p span { display:inline-block; padding-left:0.5em; }
.texarea p font { font-size:0.9em; }

.texareas { display:block; font-weight:400; position: relative; width:100%; max-width:1200px; margin:0 auto; line-height: 1.8; padding:0.5em; color:#fff;  }
.texareas p { display:block; font-weight:500; position: relative; width:100%; max-width:1200px; margin:0 0 0.5em; line-height: 1.6em; padding:0; color:#fff;  }
.texareas p span { display:inline-block; padding-left:0.5em; }
.texareas p font { font-size:0.9em; }


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

.pict { margin: 0 0 1em; line-height: 1em;}
.pict img { width:100%; }


.castname { display:block;  font-weight:400;  position: relative; width:100%; max-width:1000px; margin:0 auto 0.75em; line-height: 1.7em; padding: 0.15em; color:#fafaf1; font-size:1.2em; text-align: center; border-top:1px solid #891e20; border-bottom:1px solid #891e20; background-image: url("../img/name-bg.jpg"); background-size: 100% 100%; text-shadow: 0 0 10px #c00; }
.castname span { font-size:1.2em; }
.castp { display:block; position: relative; width:100%; max-width:1000px; margin:0 auto; line-height: 0; padding: 1em 0 0.5em; text-align: center;}
.castp img { width:100%; }

.casttex { display:block;  font-weight:400;  position: relative; width:100%; max-width:1000px; margin:0 auto 5em; line-height: 1.8em; padding: 0; color:#fff; }
.casttex p { display:block;  font-weight:400;  position: relative;  margin:0 0 0.75em; line-height: 1.8em; padding: 0; text-align: justify; }

p.prof { padding:1em; background-color: rgba(54,35,35,0.50); display: block; margin-top:1.5em; }


.title { display:block;  font-weight:500;  position: relative; width:100%; max-width:1000px; margin:0 auto 1em; line-height: 1.8; padding:0 1em; color:#fff; text-align: center; font-size:1.2em;}

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

.billing {  width: 100%; text-align: center; margin:0; padding:1em 0; line-height: 1.8em; }
.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 .dan2 { font-size: clamp(1.2em, 1.8vw, 1.4em); display: block; padding:0.5em 0; line-height: 1.6em; }
.billing .dan1 { font-size: 0.8em; display: block; padding:0.5em 0; line-height: 1.6em; }
.billing span { display:inline-block; padding:0 0.5em; font-size: 0.7em;}
.billing font { font-size:0.8em;}

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






.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 2.5em; 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; } 

.video { width: 100%; max-width: 1100px; margin:1em auto;padding: 0.5em;}
video { width: 100%; border: 1px solid rgba(120,20,22,0.70);  }


.tharea { width:100%; height: auto; margin:0 auto 2em; max-width:1000px; position:relative; padding:0 1em; }
.theatable {  width:100%;  margin: 0 auto 1.6em;  border-bottom:1px solid #990000; }
.theatable th {  border-top:1px solid #990000;  color: #fff; font-size:0.9em; text-align:center; padding:0.6em 0em;   background: #16151d; }
.theatable td { border-top:1px solid #990000; 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:#ff9999; line-height:1.2em; border-bottom: 1px dashed rgba(177,100,102,0.50); }
.theatable a:hover { color:#cc6666; line-height:1.2em; text-decoration: none; }
.col1 { width:45%;}
.col2 { width:15%;}
.col3 { width:40%;}
.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;
}

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

@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.95);
  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;
  background-color: #cc2980;
  transition: all .5s;
}
.menu-trigger.active span {
  background-color: #cc2980;
}
.menu-trigger span:nth-of-type(1) {
  top: 15px;
}
.menu-trigger.active span:nth-of-type(1) {
  transform: translateY(13px) rotate(-45deg);
}
.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(45deg);
}

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 #e077af;
}

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


nav.smn div a { color: #f371b7; 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:#e077af;}


.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: 4px;
  background-color: #660000;
  transition: all .5s;
}
.menu-trigger.active span {
  background-color: #990000;
}
.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);
}

    
}


