@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
html, body, div, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
color: #FFF;
font-family: serif,source-han-serif-tc;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
  font-family: serif,source-han-serif-tc;
  font-family: serif,Noto Serif JP;
  line-height: 1;
  background-color: #161139;
  overflow-x: hidden;
}
ol, ul {
list-style: none;
}
li{ margin-bottom: 10px;}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
a,a:hover{ text-decoration: none;}
a:hover,a:hover span{ color: #FFF;}
p{margin-bottom: 20px; line-height: 1.5;font-size: 1.1rem;}
img{ max-width: 100%; }

h3{font-size: 1.3rem;}

.has-text-align-left {
    text-align: left
}

/* SP */
body{ font-size: 0.7rem;}
header{
   min-height: 100vh;
   display: block;
   position: relative;
 }

 .drawer-hamburger,.drawer-hamburger-icon:hover{
 z-index: 999999;
}
.toggle-circle{
  background-color: #FFFFFF99!important;
  border-radius: 5px;
}
.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before{
  background-color: #FFFFFF99;
  z-index: 999999;
}
.toggle-circle{
  display: block;
  position: absolute;
  border: 1px solid #FFF;
  height: 50px;
  width: 50px;
  top: 5px;
  right: 3px;
  z-index: 999999;
}
.drawer-nav{
  background-color: rgba(0,0,0,0.7);
  z-index: 9999;
}
.drawer-menu{
  text-align: center;
  font-size: 1rem;
  line-height: 2rem;
  margin: 50px auto;
}
.drawer-menu a,.drawer-menu a i{
  z-index: 999999;
  color: #FFF;
  font-size: 1.5rem;
}

.nav,.menu,.scroll{ display: none;}

.wrapper{
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
  padding: 50px 0;
  text-align: center;
}

.titleA,.titleB{
  display: inline-block;
  position: relative;
  max-width: 80%;
  margin-bottom: 30px;
}
.titleA:before{
  content: "";
  background-image: url('../img/typeA_left.png');
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
  width: 84px;
  height: 15px
}
.titleA:after{
  content: "";
  background-image: url('../img/typeA_right.png');
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
  width: 84px;
  height: 15px
}
.titleB:before{
  content: "";
  background-image: url('../img/typeB_left.png');
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
  width: 84px;
  height: 15px
}
.titleB:after{
  content: "";
  background-image: url('../img/typeB_right.png');
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
  width: 84px;
  height: 15px
}
.s_title_img{ max-width: 30%;}




.titleC,.titleD{ font-size: 1.4em; margin: 40px auto;line-height: 1.6em;}
.titleD{ color: #FFF; margin:15px;}
.text0{ font-size: 1.2em; white-space: nowrap;}
.text1{ font-size: 1em;}
.text2{ font-size: .9em;}
.text3{ font-size: 0.9em; color:#FFF;}
h5{ font-size: 1em;}
.tegaki{
  font-family: 'Shadows Into Light', cursive;
  letter-spacing: 1.3px;
}
.indent{text-indent:1.5rem;}

.sm-slider {
  margin-top: 0!important;
}

/* header */
header {color:#FFFFFF;text-align: center;}
.fv_copy{
  display: block;
  position: absolute;
  top: 20px;
  left: 20px;
  max-width: 16%;
}

.title_img{
  margin: 5px auto 10px;
  max-width: 70%;
}
.title_description{
  position: absolute;
  top: 3%;
  left: 5%;
  width: 5%
}

.head_title{
  padding-top: 20px;
}
.head_place1{
  margin-top: 20px;
  font-size: 1.8em;
  margin-bottom: 0;
}
.head_place2{
  font-size: 1.6em;
}
.head_place5{
  font-size: 12.5px;
  display: inline-block;
  position: absolute;
  top: 5px;
  right: 5px;
}

.scr_btn{
  display: block;
  position: absolute;
  bottom: 10px;
  width: 100%;
  text-align: center;
}
.scr_btn img{
  width: 66px;
}

.slider{
  min-height:400px;
}

/* intro */
.intro{
  background-image: url('../img/bg_intro.jpg');
  background-position: center;
  background-color: #161139;
  background-size: cover;
}
.intro p{margin: 0 7% 20px 7%; line-height: 1.5; font-size: 0.7rem;}
.intro_img{
  margin: 0 auto;
  width: 100%;
}

.youtube iframe{
  width: 100%;
}

.intro_img p{margin: 0 8% 10px 8%;}
/* news */
.news{
  background: #fff;
  padding: 50px 0;
}

.news_warp{
  flex-wrap: nowrap;
  justify-content: space-between;
}
.news_wrapper{
  display: block;
  position: relative;
  max-width: 1000px;
  margin: auto;
}
.title_news{
  display: inline-block;
  position: relative;
}

.news-list li{
  line-height: 1.8;
  text-align: left;
  margin: 0;
  padding: 0 5%;
}
.news .titleB,.news-list li a,.news-list li a span{
  color: #000;
}

.news-list li a:hover{
  color: #fff;
}
/* story */
.story{
  background-color: #161139;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top;
  padding-bottom: 80px;
}
.story h2{
  color: #fff;
}
.story p{
  font-size: 0.7rem;
}
.story_img{
  width: 80%;
}

/* chara */
#chara{
  background-image: url('../img/chara_sp.jpg');
  background-color: #fff;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top;
  color: #000;
}

.chara-wapper{
  margin-top: 30vh;
  font-size: .9em;
}

.chara-box{ display: none;}
.chara-box p{color: #000; margin: 5px 20px 20px;}
.chara-open{
	padding: 15px;
	color: #000;
	position: relative;
}
.chara-open{
  font-size: 1.5rem;
  font-weight: bold;
}
.chara-open::after{
content: "";
width: 100%;
height: 5px;
display: block;
position: relative;
background: rgb(0,0,185);
background: linear-gradient(90deg, rgba(0,0,185,1) 0%, rgba(137,0,57,1) 100%, rgba(0,212,255,1) 100%);
}
.chara-open::before{/* 閉じている時 */
	content: url("../img/chara_icon.png");
	position: relative;
  display: inline-block;
  position: relative;
  margin-right: 10px;
  bottom: -0.7rem;
}


/* cast */
.cast{padding:50px;text-align: center;
  background-image: url("../img/bg_cast.png");
  background-color: #151D34;
  background-repeat: no-repeat;
  background-size: cover;
}

#cast_list{
  display: none;
}
.cast_wrapper{
  display: flex;
}

.cast_boxA{
  padding: 2%;
  width: 50%;
}

.cast_boxB{
  padding: 5%;
  width: 50%;
}
.cast_img{
}
.cast_link:hover{ cursor: pointer;}
.cast_box p{
  font-size: 1.1rem;
  margin-bottom: 0;
}
.cast_box p a i.fa-twitter{
  color:#1DA1F2;
}
.cast_box p a i.fa-facebook{
  color:#4D60AB;
}
.select{
  background-color: #000;
  color: #fff;
}
.select h2{ color: #fff;}

.cast_name{
  font-size: 1.2rem;
  font-weight: bold;
}


#cast_list,#creator_list{
  display:none;
  clear:both;
}

/* creator */

.creator{
  background-image: url("../img/bg_staff.jpg");
  background-position: center;
  background-color: #000;
  background-size: cover;
}

.creator h2,.creator h3{color: #000;}
.creator p{
  margin-bottom: 1.2rem;
  line-height: 1.5rem;
  color: #000;

}
creator_btn{
  display: block;
}

/* goods */

.goods{
  background-color: #003DA6;
  background-position: bottom;
}

.goods .card-img-overlay{
  background-color: #00000066;
  padding: 0;
}

/* comments */

.comments{
  background-color: #161139;
  background-position: bottom;
}

.com_box{
  margin-bottom: 50px;
}

.com_mov{
  display: block;
  margin: 10px;
  color:#813F00;
}



/* schedule */
.schedule{
  background: #A9BFE5;
  background: rgb(128,181,205);
  background: -moz-linear-gradient( rgba(128,181,205,1) 0%, rgba(36,51,84,1) 50%, rgba(137,0,57,1) 100%);
  background: -webkit-linear-gradient( rgba(128,181,205,1) 0%, rgba(36,51,84,1) 50%, rgba(137,0,57,1) 100%);
  background: -o-linear-gradient( rgba(128,181,205,1) 0%, rgba(36,51,84,1) 50%, rgba(137,0,57,1) 100%);
  background: linear-gradient(180deg, rgba(128,181,205,1) 0%, rgba(36,51,84,1) 50%, rgba(137,0,57,1) 100%, rgba(97,0,91,1) 100%);
}

.schedule img{max-width: 80%;}
.schedule h2{color: #000}
.schedule p{ font-size: 1.3rem;}

/* ticket */
.ticket{background-color: #fff;}
.ticket h2,.ticket h3,.ticket p{color: #000;}


.ticket_box{
  margin: 0 7%;
  border-collapse:separate;
  border-spacing: 0;
}
.ticket_box_left{
  border-right:2px solid #FFF;
  border-top:2px solid #243354;
  border-bottom:2px solid #fff;
  background-color: #243354;
  color: #fff;
  text-align: left;
  padding: 10px;
  max-width: calc(75% - 4px);
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.ticket_box_right{
  border-top:2px solid #243354;
  border-right:2px solid #243354;
  border-bottom:2px solid #243354;
  color: #000;
  padding: 20px 0;
  vertical-align: middle;
  max-width: calc(25% - 4px);
}
.ticket_box_left span,.ticket_box_right span{
  display: inline-block;
  white-space: nowrap;
  color: #FFF;
}

.ticket h3{
  margin: 40px auto;
  font-size: 1.3rem;
  font-weight: bold;
}

.ticket_box dl{
  background-color: #8c0001;
  margin: 0 2%;
}

.ticket_box dd{
  padding: 5px;
  width: 100%
}
.ticket_box dt{
  background-color: #540000;
  padding: 5px;
  width: 100%
}

/* staff */
.zuu_logo{ width: 66px;}
.akarenga_logo{width:300px;}

/* butuun */
.btn{
  font-size: 0.8rem;
}

.btnA {
  color: #fff!important;
    background-color: #003DA6;
    border-color: #003DA6;
    padding: .3rem 3rem;
}
.btnB {
  color: #4EC1F0!important;
  font-weight: bold;
  background: linear-gradient(90deg, rgba(0,0,185,1) 0%, rgba(137,0,57,1) 100%, rgba(0,212,255,1) 100%);
    padding: .3rem .6rem;
    margin: 8px;
}
.btnC{
  color: #003DA6!important;
  font-weight: bold;
    background-color: #AFCBFF;
    border-color: #AFCBFF;
    padding: .3rem .6rem;
    margin: 8px;
    border-radius: 0;
}
.btnC:hover{
  color: #003DA6!important;
  background-color: #FFF;
  border-color: #003DA6;
}

.eplus{
    width: 88px;
    vertical-align: bottom;
    margin: 8px;
}
/* Page_top */
#page_top{
  width: 52px;
  height: 52px;
  position: fixed;
  right: 3%;
  bottom: 3%;
  /*border: 2px solid #c58864;*/
  opacity: 0.6;
/*border-radius: 50%;*/
}
#page_top:hover{
  /*border: 2px solid #FFF;*/
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before{
  font-family: "Font Awesome 5 Free";
  content: "\f106";
  font-weight: bold;
  font-size: 32px;
  color: #c58864;
  position: absolute;
  width: 40px;
  height: 40px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
#page_top a:hover::before {
  color: #FFF;
}

/* theater */

.theater{
  background-image: url("../img/bg_access.jpg");
  background-color: #003DA6;
  background-size: cover;
  background-position: bottom;
}
.theater .titleB{
  color: #000;
}
.theater_info{
  width: 60%;
  min-width: 300px;
  margin: 20px auto;
  padding: 50px;
}
.theater_info h3,.theater_info p{
  color: #FFF;
}

/* footer */
.map{
  width: 100%;
  height: 300px;
}
.sns{
  background-image: url("../img/bg_sns.jpg");
  background-color: #161139;
}

/* sns-box ---------- */
.sns-box {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-justify-content: space-around;
	justify-content: center;
	align-items: flex-start;
}

.sns-inner {
	margin: 0 8px;
  min-width: 280px;
}

.button-showy{
  background: rgb(137,0,57,1);
  background: linear-gradient(90deg, rgba(0,0,185,1) 0%, rgba(137,0,57,1) 100%, rgba(0,212,255,1) 100%);
  color: #4EC1F0;
  border-radius: 0;
  padding: 5px 80px;
}
.button-showy a:hover,a.button-showy:hover{
  background: linear-gradient(90deg, rgba(137,0,57,1) 0%, rgba(0,0,185,1) 100%, rgba(0,212,255,1) 100%);
  color: #fff;
}


.mail_info{
  background: rgb(36,51,84);
  background: linear-gradient(90deg, rgba(36,51,84,1) 10%, rgba(128,181,205,1) 50%, rgba(36,51,84,1) 90%);
  color:#FFF;
  line-height: 2rem;
}
.mail_info span{font-size: .6em;}
.mail_info a{ color:#fff; }
.copyright{ background-color: #202042; color:#fff; line-height: 2rem;}

.text_big{font-size: 1.3rem;}



/* tb */
@media screen and (min-width:768px){
  .title_img{
    margin: 10%;
  }
}

/* PC */
@media screen and (min-width:1025px){
  body{ font-size: 1.4rem;}
  header{
      min-height: calc(100vh - 50px);
  }
  /*
  .header_wrap{
    display: flex;
  }
  */
  .head_title{
  }
  .head_place1{
    display: none;
  }
  .head_place3{
    display: block;
    font-size: 2.3vh;
  }
  .head_place2{
    font-size: 4vh;
  }
  .slider{
    min-height: 0;
  }

  .sm-slider li span {
    width: 100%;
   }

   .scr_btn{
     display: none;
   }
  a.btnA:hover,a.btnB:hover {
    background: linear-gradient(90deg, rgba(137,0,57,1) 0%, rgba(0,0,185,1) 100%, rgba(0,212,255,1) 100%);
    border-color: rgba(137,0,57,1);
  }
  .head_th{
    text-align: center;
    bottom: 15%;
    left: 15%;
    position: inherit;
    display: inline-block;
    margin: 0 auto;
  }

  .titleA,.titleB{
    font-size: 1.8rem;
    padding: 0 10px;
  }

  .titleA:before{
    position: relative;
    width: 106px;
    height: 19px;
    margin-right: 5px;
  }
  .titleA:after{
    position: relative;
    width: 106px;
    height: 19px;
    margin-left: 10px;
    margin-bottom: 5px;
  }


  .titleB:before{
    content: "";
    background-image: url('../img/typeB_left.png');
    position: relative;
    width: 106px;
    height: 19px;
    margin-right: 5px;
  }
  .titleB:after{
    content: "";
    background-image: url('../img/typeB_right.png');
    position: relative;
    width: 106px;
    height: 19px;
    margin-left: 10px;
    margin-bottom: 5px;
  }
  .titleA,.titleB{ margin: 80px auto; }
  .s_title_img{ max-width: 100%;}

  .titleC{ margin: 60px auto;}
  .titleD{ margin: 60px auto; font-size: 1.2em; color: #FFF}

  .fv_copy{
    position: relative;
    top: auto;
    left: auto;
    margin: auto;
    height: 40vh;
  }
  .title_img{
    max-height: 45vh;
    margin: auto;
  }
  .title_description{
    left: 5%;
    top: 5%;
    width: auto;
  }
  .btn {
    font-size: 1.1rem;
}
  .news-list li{
    padding: 0 10%;
  }

.drawer-toggle,.drawer-nav,.tel-btn{ display: none;}

.menu{
  display: block;
  position: absolute;
  top: 10%;
  right: 3%;
  font-family: 'Yu Mincho','Hiragino Mincho ProN','Hiragino Mincho Pro',serif;
  /*letter-spacing: .5rem;*/
  line-height: 1.4;
  -webkit-font-feature-settings: 'pkna';
  font-feature-settings: 'pkna';
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.menu_list_bottom{
  border-top: 2px solid #FFF;
  padding-top: 50px;
  display: block;
  height: 300px;
  position: absolute;
  top: 300px;
  right: 5%;
  width: 100%;
}

.menu_list a{
  display: block;
  position: relative;
  margin: auto 5px;
  transition: .3s all;
}
.menu_list a i{
  padding-top: 50px;
}
.menu_list a:hover,.menu_list a:hover i{
  /*margin-top: -20px;*/
  color: #00235F;
}
  .scroll{
    display: block;
    position: absolute;
    left: calc(50% - 25px);
    bottom: 20px;
    height: 50px;
    width: 50px;
/*    border: solid 1px #fff;
    border-radius: 50%; */
    color: #FFF;
    text-align: center;
    z-index: 99999;
  }
  .scroll i{
    line-height: 50px;
    font-size: 2.5rem;
  }

.nav{
    display: block;
    position: sticky;
    top: 0;
    left: 0;
    background-color: #000;
    width: 100%;
    z-index: 9999;
  }
.fixed {
  position: fixed;
  top: 20px;
}


  .navigation{
    display: flex;
    position: relative;
    justify-content: space-between;
    padding: 10px 0;
   }
   .navigation li{
     margin: 0;
   }
   .navigation li a{
     color: #FFF;
     margin: 5px auto;
     font-size: 1rem;
     vertical-align: sub;
   }
   .navigation li a i{
     color: #FFF;
   }
   .navigation li::after{
     color: #FFF;
     content: '|';
     margin: 0 .5em;
     vertical-align: sub;
   }
   .navigation li:last-child::after{
     content: none;
   }
   .navigation li a:hover,.navigation li a:hover i{
     color: #FFF;
   }
   .navigation li a img{
     width: 1em;
     margin-right: .5em;
   }
   .intro_img{
     margin: 0 auto;
     width: 45%;
   }
   .intro{
     background-attachment: fixed;
     padding: 50px 0;
     min-height: 100vh;

   }
   .intro p{margin: 5% 5% 20px 5%; font-size: 1.4rem;}
   .story{
    background-attachment: fixed;
    min-height: 100vh;
  }


   .story p{font-size: .9em;}


   /* chara */
   #chara{
     background-image: url('../img/chara_pc.jpg');
     background-size: 100% auto;
   }

   .chara-wapper{
     margin-top: calc(100vh - 50px);
   }

   /* cast */
   .cast_boxA{
     padding: 2%;
     width: 25%;
   }


   .com_box{
     display: flex;
   }


   .eplus {
       width: 105px;
   }

   .schedule p{font-size: 2rem;}

   .schedule_table{
     margin: 0 auto;
     white-space: nowrap;
   }

   .schedule_table th, .schedule_table td {
    padding: 25px 40px;
  }

  .schedule_table caption{
    font-size: 0.8em;
    line-height: 1.2em;
  }

  .ticket_box dd,.ticket_box dt{
    margin: auto;
      width: auto;
      height: 100%;
  }

  .goods .card-img-overlay{
    padding: 1.25rem;
  }

  .theater{
    /*
    background-attachment: fixed;
    */
  }

  .mail_info span{font-size: .6em;}
  .mail_info a{ font-size: 1.2rem;}


  .text_big{font-size: 1.8rem;}

}


.text_blue{color:#003DA6!important;}


/* トレーラー */
#first_view{
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1000;
  background-color: rgba(0, 0, 0, 0.5);
}
#first_view .inner{
  position: relative;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: calc(100% - 5px);
  max-width: 100%;
  height: 100vh;
  text-align: center;
}
#first_view .inner iframe{
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  height: 50%;
  margin: auto;
  width: 900px;
  max-width: 100%;
}


.text-black{color: #000000;}
