@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: #080404;
	color:#fff;
	font-size:16px;
	font-size:1.6rem;
     font-family: "Shippori Mincho B1", serif;
  font-weight: 400;
  font-style: normal;
}
html, body {
height: 100%;
min-height: 100%;
}

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


body > .bg_subtitle_obi {
  height: auto;
 }
 

a:link { color:#c8b26d; text-decoration:none;  }
a:visited { color:#ecc87c; text-decoration:none; }
a:hover { color: #ecc87c; text-decoration:none; }
a:active {ccolor:#c8b26d; text-decoration:none; }
a:focus {color:#c8b26d; 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: #fff; background-image: url("../img/bg.jpg"); background-size: 100% 100%; background-repeat: no-repeat; background-attachment: fixed;
}
#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 400px;
  height: 200px;
  margin-top: -100px;
  margin-left: -200px;
  text-align: center;
  color: #000;
  z-index: 1002;
  font-size:0.7em;
}
 

#wrapper { display: none;
	width: 100%;
	min-height: 100%;
	min-width: none;
	height: 100%;
	padding: 0 0 0 3px;
	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%;   }

.titles { display:block; position: relative; width:100%; max-width:1200px; margin:0 auto 3em; line-height: 1; padding:0; overflow: hidden; text-align: left; }
.titles img { width:50%; max-width:700px; height:auto; }

.roadshow { width: 100%; text-align: center; max-width: 1100px; margin:0 auto 2em; line-height:1; padding:0.5em 0;}
.roadshow img { 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;}

.p5 { display: flex; width:100%; max-width:1200px; margin:0 auto; }
.p5 img { width:25%;}




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

.intro { width: 100%; text-align: justify; max-width: 1200px; margin:0 auto; padding:1.5em 1.5em 0; line-height: 1.8em; background-image: url("../img/intro_01.jpg"); background-position: bottom center; background-size: 100% auto; background-repeat: no-repeat; }
.intro .texarea { width: 100%; text-align: justify; margin:0 auto; line-height:1.8em; padding-bottom:1em;}
.intro .texarea .title { margin:0 0 1em; line-height:1em;}
.intro .texarea .title img { width:50%; max-width:400px; height: auto; }
.intro2 { width: 100%; max-width: 1200px; margin:0 auto; line-height:0; }
.intro2 img { width:100%; height: auto; }

.intro .texarea .title2 { margin:0 0 1em; line-height:1em;}
.intro .texarea .title2 img { width:100%; max-width:700px; height: auto; }

.in-line { width: 100%; max-width: 1200px; margin:1em auto 2em; line-height:0; }
.in-line img { width:100%; height: auto; }


.lineupbox { display:flex; margin:1em auto 2em; width:100%; height: auto;}
.lineupbox .photo { display:block; width:40%; padding:0 0 1em 0; font-size:0.8em; text-align: left; line-height: 0.7em; }
.lineupbox .photo img { width:100%; height: auto; margin-bottom:8px; }
.lineupbox .story { display:block; width:60%; padding:0 0 0 1.5em; text-align: justify; line-height:1.8em; }
.lineupbox .story .tit { padding:0 0 0.25em; text-align: left; line-height:1em; color:#c9bc9c; font-size:2em; font-weight:300; }
.lineupbox .story .tit span { padding:0 0 0 0.5em; text-align: left; color:#fff; font-size:0.5em; font-style: italic; }
.first { display:inline-block; font-size:0.5em; color:#dfa98d; padding-left:0.5em;}

.lineupbox .story .data { font-size:0.9em; display:block; padding:0 0 0 0.6em; text-align: left; line-height:1.3em; border-left: 2px solid #f7e1bf; margin-bottom:1em;}

.zenpen { margin:-0.75em 0 1.5em; font-size:0.9em; color:#dfa98d; text-align: right;} 

.staff { width: 100%; text-align: justify; max-width: 1200px; margin:0 auto; padding:1.5em 1.5em; line-height: 1.8em; background: #fff; color:#222;}

.staff .title2 { margin:0 0 1em; line-height:1em;}
.staff .title2 img { width:100%; max-width:650px; height: auto; }

.tokusyu { width: 100%; text-align: justify; max-width: 1200px; margin:0 auto 1.5em; background: #fff; padding:1.5em 1.5em; }
.wtop { display: flex; justify-content: space-between; background-image: url("../img/tokusyu-wt.png"); background-repeat: repeat-x; background-position: top center; }
.wbottom { display: flex; justify-content: space-between; background-image: url("../img/tokusyu-wb.png"); background-repeat: repeat-x; background-position: bottom center; }
.wmid { padding:0 15px; background-image: url("../img/tokusyu-wl.png"), url("../img/tokusyu-wr.png"); background-repeat: repeat-y, repeat-y; background-position: center left, center right; line-height: 1.8em; }
.ttit { text-align: center; color:#8e0983; font-size:1.6em; font-weight:300; line-height: 1em; padding:0 1em 0.5em; }
.ttit span { display: inline-block; padding:0 0.25em; }
.ttit a { color:#8e0983; }

.kikan { background: #fce1ce; padding:0.5em; color:#333; text-align: center; line-height:1.2em; }
.kikan span { font-size:0.7em; }
.ttex { padding:0.75em 30px; color:#333; text-align: justify; line-height:1.6em; }
.ttex span { font-size:0.8em; }
.ttex a { color:#e69444; }
.ttex a img { height: 0.9em; padding-left:5px; }
.ttex font { color:#8e0983; font-weight:600; }

.subphoto { width:40%; height: auto; line-height: 0; float: right; padding:0 0 0 1.5em; }
.subphoto img { width: 100%; line-height:0;}

.tyuberu { padding:0.5em 30px; color:#8e0983; text-align: justify; line-height:1.6em; }
.tyuberu span { display: inline-block; }

.tokuphoto { padding:0 30px; }
.tokuphoto img { width: 100%; line-height:0;}


@media screen and (max-width: 768px) {
.intro {  padding:0.5em 0.75em 0; }
.lineupbox { display:block; margin:1em auto 2em; }
.lineupbox .photo { display:block; width:100%; font-size:0.7em; text-align: right; }
.lineupbox .story { display:block; width:100%; padding:0 0 0 0; }
	
.staff { padding:1.5em 0.75em; }
.tokusyu { padding:1.5em 0.75em; }

}




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


.billing { width:100%; max-width:1400px; text-align: center; margin:0 auto; padding:0; line-height: 1.8em; }
.billing .dan4 { font-size: 0.8em; 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; text-align: left; }
.billing .dan2 { font-size: 0.9em; display: block; padding:0.25em 0; line-height: 1.5em; }
.billing .dan2 a { vertical-align: bottom; font-size:1.1em; display: inline-block;}
.billing .dan2 a:hover { opacity:0.8; }
.billing .dan2 a img { height: 0.9em; }
.billing .dan2 span { font-size: 0.8em;}

.billing span { display:inline-block;}

.tw {display:block; padding:2em 0; line-height:1em; margin: 0;}
.tw img { width:auto; height:45px; margin: 0 10px;}

.fs9 { font-size:0.8em; }

.cr { width: 100%;  margin:0; padding:0em 0 1em; line-height: 1.2em; font-size:0.7em; font-weight:400;}




.story img { width:100%; height:auto; }

.st-tex { padding: 1em; width:100%; margin: 0 auto; max-width:1000px; text-align: left; line-height: 2em; color:#fff; }
.st-tex p { margin: 0 0 2.5em; text-align: left; line-height: 1.9em;}
.st-tex .photo { float: right; width:40%; max-width:400px; padding: 0 0 1.5em 1.5em;}
.st-tex .photo img {  width:100%; height:auto; }
	


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





.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:0 auto; 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; } 


.tharea { width:100%; height: auto; margin:0 auto 2em; max-width:1200px; position:relative; padding: 1.5em 0.5em; }
.theatable {  width:100%;  margin: 0 auto 1.6em;  border-bottom:1px solid #173c66; }
.theatable th {  border-top:1px solid #173c66;  color: #fff; text-align:center; padding:0.6em 0em;   background: #030c1e; }
.theatable td { border-top:1px solid #173c66; color:#fff; padding:1.6em 0.2em; text-align:center; vertical-align:middle; line-height:1.1em;  font-size:1.0em; background: #07132b;}
.theatable a { color:#fff2c7; line-height:1.2em; text-decoration: underline; }
.theatable a:hover { color:#ffffcc; 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: #0f1b35  !important; padding:0.75em 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;}

.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(11,34,66,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: 2px;
  background-color: #fff;
  transition: all .3s;
}
.menu-trigger.active span {
  background-color: #dbd5b4;
}
.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: 16px;
}
.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 #887b73;
}

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


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


.pconly { display:inherit; }
.pconly2 { display: inline-block;; }
.sponly { display:none; }
.dnon { display:none; }


@media screen and (max-width: 768px) {
body {
    font-weight: 400;
}
html { font-size: 84%;}
.pconly { display:none; }
.pconly2 { 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: 2px;
  background-color: #fff;
  transition: all .5s;
}
.menu-trigger.active span {
  background-color: #dbd5b4;
}
.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: 25px;
}
.menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-14px) rotate(45deg);
}

    
}


