@import url("https://use.typekit.net/ygc1jpe.css");
@charset "UTF-8";
< !--#include virtual="/um/v7/css/reset.css"-- > 
/*/////////////////////////////////////////////////////////////////////////
default_CSS
/////////////////////////////////////////////////////////////////////////*/
@font-face {
  font-family: 'Playfair Display';
  src: url('/um/library/fonts/Playfair_Display/PlayfairDisplay-SemiBold.ttf') format("truetype");
  font-style: normal;
  font-weight: 400;
}
body {
  font-family: "YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  -webkit-text-size-adjust: 100%;
  line-height: 1;
}
body, h1, h2, h3, h4, h5, div, p, dl, dt, dd, ol, ul, li, form, table, caption, tbody, tfoot, thead, tr, th, td, article, figure {
  margin: 0;
  padding: 0;
  font-weight: normal;
  font-size: 100%;
  box-sizing: border-box;
}
p {
  background-color: rgba(255, 255, 255, 0);
}
img, iframe {
  border: none;
}
ol, ul {
  list-style: none;
  list-style-type: none;
}
.relative {
  position: relative;
}
.hid {
  visibility: hidden;
}
.cover {
  width: 100%;
  height: 100%;
}
@media print {
  .noprint {
    display: none !important;
  }
}
/*font*/
.tCenter {
  text-align: center !important
}
.tRight {
  text-align: right !important
}
.tLeft {
  text-align: left !important
}
/*font-size*/
html {
  font-size: 62.5%;
} /* = 10px */
body {
  font-size: 1.6rem;
} /* = 16px */
h1 {
  font-size: 3.2rem;
}
h2 {
  font-size: 2.3rem;
}
h3 {
  font-size: 2.1rem;
}
h4 {
  font-size: 2.0rem;
}
p {
  font-size: 1.6rem;
}
.f160 {
  font-size: 160%;
}
.f140 {
  font-size: 140%;
}
.f130 {
  font-size: 130%;
}
.f120 {
  font-size: 120%;
}
.f110 {
  font-size: 110%;
}
.f95 {
  font-size: 95%;
}
.f90 {
  font-size: 90%;
}
.f85 {
  font-size: 85% !important;
}
.f80 {
  font-size: 80% !important;
}
.f75 {
  font-size: 75% !important;
}
.stgrn {
  color: #6D1300;
}
.stgrn2 {
  color: #6D1300;
}
.ffsp {
  font-feature-settings: "palt";
}
/*link*/
a {
  text-decoration: none;
  color: #68524c;
}
a:hover {
  text-decoration: none;
  color: #68524c;
}
#menu {
  background-image: url("../img/menu.png");
  background-size: contain;
}
#menu li, header #logo a, a.btn_prev, a.btn_s, a.btn_i, #prevnext ul li a, .update li a, .bnarea ul li a, .bn_prev a, #gotop a, a.btn_df, ul.bnr li a, .btnitem, #snsarea #sns a, .paraviorg {
  text-decoration: none;
  -webkit-transition: 0.2s ease-in-out;
  -moz-transition: 0.2s ease-in-out;
  -o-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
#menu li:hover, header #logo a:hover, a.btn_i:hover, a.btn_df:hover, .bn_prev a:hover, #gotop a:hover, ul.bnr li a:hover, .btnitem:hover, #snsarea #sns a:hover {
  text-decoration: none;
  filter: alpha(opacity=70);
  -moz-opacity: 0.70;
  opacity: 0.70;
}
/*#menu li.menu7:hover{filter:alpha(opacity=100); -moz-opacity:1; opacity:1;}*/
.no-link {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
  filter: alpha(opacity=50);
  -moz-opacity: 0.5;
  opacity: 0.5;
}
.zomin {
  font-family: "YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  font-weight: 700;
  font-style: normal;
}
.longhand {
  font-family: "YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  font-weight: 700;
  font-style: normal;
}
/*/////////////////////////////////////////////////////////////////////////
コンテンツ用CSS／オリジナル設定
/////////////////////////////////////////////////////////////////////////*/
#con-body {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
}
#con-body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/bg_white.jpg") no-repeat top center;
  background-size: cover;
  z-index: -2;
  opacity: 1;
  animation: fadeWhite 16s infinite;
  background-attachment: fixed;
}
#con-body::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/bg_red.jpg") no-repeat top center;
  background-size: cover;
  z-index: -1;
  opacity: 0;
  animation: fadeRed 16s infinite;
  background-attachment: fixed;
}
#con-body > * {
  position: relative;
  z-index: 0;
}
@media all and (max-width: 767px) {
  #con-body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/bg_white_sp.jpg") no-repeat top center;
    background-size: cover;
    z-index: -2;
    opacity: 1;
    animation: fadeWhite 16s infinite;
    background-attachment: fixed;
  }
  #con-body::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/bg_red_sp.jpg") no-repeat top center;
    background-size: cover;
    z-index: -1;
    opacity: 0;
    animation: fadeRed 16s infinite;
    background-attachment: fixed;
  }
}
/* 見出し色キーフレーム（赤背景＝白文字、白背景＝黒文字） */
@keyframes headingColor {
  0% {
    color: #0D0D0D;
  } /* 白背景 → 黒文字 */
  40% {
    color: #FFFFFF;
  } /* 赤背景へフェード中 → 白文字に */
  60% {
    color: #FFFFFF;
  } /* 赤背景中 → 白文字維持 */
  100% {
    color: #0D0D0D;
  } /* 白背景に戻る → 黒文字 */
}
/* 背景フェードキーフレーム */
@keyframes fadeWhite {
  0% {
    opacity: 1;
  } /* 白初期表示 */
  40% {
    opacity: 0;
  } /* 白フェードアウト */
  60% {
    opacity: 0;
  } /* 赤表示中は白透明維持 */
  100% {
    opacity: 1;
  } /* 白に戻る */
}
@keyframes fadeRed {
  0% {
    opacity: 0;
  } /* 赤初期透明 */
  40% {
    opacity: 1;
  } /* フェードイン */
  60% {
    opacity: 1;
  } /* 赤を少し長めに表示 */
  100% {
    opacity: 0;
  } /* フェードアウト */
}
#con-body {
  background-color: transparent;
}
.inner:not(.slider-unit div.outer ul, .slider-pics div.outer ul) {
  max-width: 1200px;
  margin: 0 auto;
}
#top main {
  width: 1100px;
  margin: 0 auto;
}
@media all and (max-width: 1200px) {
  #top main {
    width: 100%;
  }
}
#top h1 {
  width: 100%;
  height: auto;
  padding: 70.8333333333% 0 0;
  position: relative;
  margin: 0 auto;
}
#top h1 .main1 {
  background: url(../img/top/main.jpg?1116) no-repeat left bottom;
  background-size: cover;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  position: absolute;
  bottom: 0;
  left: 0;
  animation: fadein 1.5s cubic-bezier(.4, 0, .2, 1) normal;
}
#top h1 .main2 {
  position: absolute;
  top: 32%;
  right: 3%;
  width: 29.5%;
  opacity: 0;
  animation: fadein .8s ease-in .5s 1 forwards;
}
#top h1 .main3 {
  position: absolute;
  left: 10%; /*right:0; margin:auto;*/ top: 6%;
  width: 8.9%;
  opacity: 0;
  animation: fadein 1.25s ease 1s 1 forwards;
}
#top h1 .main4 {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  bottom: 2%;
  width: 26%;
  opacity: 0;
  animation: fadein 1.25s ease 1.5s 1 forwards;
}
#top h1 .main1 img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes slide-in {
  0% {
    opacity: 0;
    transform: translateX(-25%);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.topbnr {
  padding: .5em 0;
  background-image: linear-gradient(135deg, rgba(8, 79, 4, .5) 0%, rgba(8, 98, 0, .6) 40%, rgba(9, 108, 0, .6) 100%), url(../img/bg2.jpg);
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, center center;
  background-size: auto, cover;
}
.topbnr2 {
  padding: 2.5em 0;
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: 0 0, center center, center bottom;
  background-size: auto, cover, cover;
  background: url(../img/top/bg1.jpg) no-repeat center center;
  background-size: cover;
}
.bn_recruit {
  margin: 1em auto;
  width: 500px;
  height: 150px;
  position: relative;
  box-shadow: 8px 8px 20px rgba(8, 98, 0, 0.8);
}
.bn_box {
  position: relative;
}
.bn_box::after {
  content: "";
  position: absolute;
  width: 100%;
  left: 0;
  border-bottom: 1px solid rgba(255, 255, 255, .8);
}
.bn_top {
  margin: 1em auto;
  width: 700px;
  height: 137px;
  position: relative;
  background-color: rgba(255, 255, 255, .5);
  border: 1px solid rgba(13, 13, 13, .8);
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
}
.bn_recruit a, .bn_top a {
  display: block;
  width: 100%;
  height: 100%;
  background: url() no-repeat left bottom;
  background-size: cover;
  transition: 0.5s;
}
.bn_top a {
  background-image: url();
}
.bn_recruit a:hover, .bn_top, .bn_bottom a:hover {
  opacity: 0.5;
}
.bn_bottom {
  margin: 1em auto;
  width: 700px;
  height: 137px;
  position: relative;
  background-color: rgba(255, 255, 255, .5);
  border: 1px solid rgba(13, 13, 13, .8);
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
}
.bn_bottom a {
  display: block;
  width: 100%;
  height: 100%;
  background: url() no-repeat left bottom;
  background-size: cover;
  transition: 0.5s;
}
.bn_bottom a {
  background-image: url();
}
#top_container {
  width: 100%;
  margin: 0 auto;
  position: relative;
  padding: 0;
}
/*menu*/
#menu {
  margin: 0 auto;
  position: relative;
  padding: 1.2em 0;
  background-color: #0D0D0D;
}
#menu:before, #menu:after, #toplink:before, #toplink:after, #tbstopics:before, .topbnr2:before, .topbnr2:after, #share:before, #share:after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
}
#menu:before, #toplink:before {
  top: 4px;
  border-top: 1px solid rgba(255, 255, 255, .7);
}
#menu:after {
  left: 0;
  bottom: 4px;
  border-bottom: 1px solid rgba(255, 255, 255, .7);
}
#toplink:before {
  top: 4px;
  border-top: 1px solid rgba(255, 255, 255, .8);
}
.bg_menu {
  position: absolute;
  inset: 0;
  background: url("../img/bg5.png") no-repeat center center;
  background-size: cover;
  opacity: 0.25;
  pointer-events: none;
  z-index: -1;
}
#tbstopics:before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
}
.topbnr2:before {
  top: 4px;
  border-top: 1px solid rgba(13, 13, 13, .8);
}
.topbnr2:after {
  left: 0;
  bottom: 4px;
  border-bottom: 1px solid rgba(13, 13, 13, .6);
}
#top #share:before {
  /*  top: 4px;*/
  /*  border-top: 1px solid rgba(255, 255, 255, .7);*/
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(to left, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
}
#share:after {
  left: 0;
  bottom: 4px;
  border-bottom: 1px solid rgba(255, 255, 255, .7);
}
#menu ul {
  max-width: 1080px;
  margin: 0 auto;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
}
#menu li {
  text-align: center;
  padding: 0;
  vertical-align: middle;
  position: relative;
  margin: 0;
  width: 14%;
  height: 75px;
  width: calc(95% / 7);
  padding-top: .5em;
}
#menu li:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  border-right: 1px solid rgba(255, 255, 255, .8);
  transform: rotate(21deg);
  height: 60px
}
#menu li.menu7:after {
  border: none;
}
#menu li a {
  width: 100%;
  height: 100%;
  display: block;
  text-decoration: none;
  vertical-align: middle;
  color: #97bde5;
  position: relative;
  left: 2px;
  z-index: 5;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  transition-duration: .5s;
}
#menu li p {
  line-height: 100%;
}
#menu li span.sub {
  color: #fff;
  font-size: 180%;
  text-shadow: 1px 1px 20px rgba(255, 255, 255, 0.3);
  font-family: "Playfair Display", serif;
  font-weight: bold;
  font-style: normal;
}
#menu li span.ttlruby {
  color: #fff;
  display: inline-block;
  padding: .5em .2em 0;
  font-size: 94%;
  font-style: normal;
  margin: .1em 0 0;
}
#menu li.menu3 {
  width: 200px
}
#menu li.menu5 span.sub {
  /*  letter-spacing: .25em;*/
}
#menu li.menu4 span.sub, #menu li.menu6 span.sub {
  /*  letter-spacing: -.15em;*/
}
@media all and (max-width: 991px) {
  #menu {
    padding: 4px 0;
    background-image: url("../img/menu_sp.png");
  }
  #menu ul {
    width: 100%;
  }
  #menu li {
    height: 100px;
    margin: 0;
    /*    width: -webkit-calc(100% / 4);*/
    /*    width: calc(100% / 4);*/
    width: 24%
  }
  #menu li:nth-child(-n+3) {
    border-bottom: 1px solid rgba(255, 255, 255, .7);
  }
  #menu li a {
    position: absolute;
    top: 0;
    left: 0;
    padding: 0;
  }
  #menu li.menu1, #menu li.menu2, #menu li.menu3 {
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3);
  }
  #menu li.menu4, #menu li.menu5, #menu li.menu6, #menu li.menu7 {
    width: -webkit-calc(100% / 4);
    width: calc(100% / 4);
  }
  #menu li.menu3:after, #menu li.menu7:after {
    border: none;
  }
}
/*sns*/
#toplink {
  position: relative;
  width: 100%;
  margin: 4em auto 0;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  padding: 2em 0;
  background: url(../img/top/bg4.png) no-repeat center top;
  background-size: cover;
}
#toplink .bnr {
  width: 35%;
  text-align: right;
  color: #fff;
  padding: 0 6vw 0 0;
  border-right: 1px solid rgba(255, 255, 255, .5);
}
#toplink .bnr span {
  font-size: 115%;
  display: inline-block;
  width: 100%;
  margin: .5em 0 0;
}
#toplink .bnr a {
  display: block;
  width: 220px;
  height: 50px;
  margin: 0 0 0 auto;
  position: relative;
  background: url(../img/top/tbsfree.svg) no-repeat center center;
  background-size: contain;
}
#toplink .bnr a img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.slash {
  width: 25px;
}
#snslink {
  width: 50%;
  margin: 0 0 0 3%;
  text-align: left;
  padding: 0;
  position: relative;
}
#snslink p {
  vertical-align: middle;
  display: inline-block;
  padding: 0;
  font-size: 180%;
  text-align: center;
  color: #fff;
  text-shadow: 3px 3px 10px rgba(11, 46, 123, .8);
}
#snslink p span {
  display: block;
  font-size: 1.25rem !important;
  padding: .6em 0 0;
}
#snslink #sns {
  text-align: center;
  margin: 0 0 0 1em;
  display: inline-block;
  vertical-align: middle;
}
#snslink #sns a {
  width: 70px;
  height: 70px;
  margin: 0 5px 0;
  position: relative;
  display: inline-block;
  border-radius: 50%;
  transition: .3s;
  border: 1px solid #fff;
}
#snslink #sns a:hover {
  opacity: 0.5;
}
#snslink #sns a img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 40%;
}
@media all and (max-width: 991px) {
  #snslink p {
    font-size: 3.4vw;
  }
  #snslink {
    width: 55%;
    margin: 0 0 0 4%;
  }
  #snslink #sns a {
    width: 60px;
    height: 60px;
    margin: 0 2px 0;
  }
}
.notice {
  background-color: rgba(255, 255, 255, 0.6);
}
.notice p {
  text-align: center;
  color: #003586;
  font-weight: 500;
  font-size: 120%;
  padding: 1.8em .5em 1.8em;
  line-height: 140%;
  text-shadow: 0px 0px 5px rgba(255, 255, 255, 1), 0 0 1px rgba(255, 255, 255, 1);
}
#next {
  margin: 0 auto;
  /*  background-image: url(../img/top/stripe1.svg), url(../img/top/bg1.jpg);*/
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: right top, center top;
  background-size: 50vw, cover;
}
#next h2, #topics h2, #whatsnew h2, #stream h2 {
  font-size: 750%;
  font-weight: 600;
  /*  position: relative;*/
  display: block;
  /*  padding: 0 .4em .45em 0;*/
  text-align: center;
  animation: headingColor 16s infinite;
  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;
  text-indent: -9999px;
  position: relative;
  display: block;
  width: 100%;
  margin-bottom: 32px
}
#next h2 {
  position: relative;
  overflow: hidden;
}
#next h2::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/next2.png") no-repeat center / contain;
  opacity: 1;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#next h2::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/next1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#topics h2 {
  position: relative;
  overflow: hidden;
}
#topics h2::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/topics1.png") no-repeat center / contain;
  opacity: 1;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#topics h2::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/topics1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#whatsnew h2 {
  position: relative;
  overflow: hidden;
}
#whatsnew h2::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/whatsnew2.png") no-repeat center / contain;
  opacity: 1;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#whatsnew h2::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/whatsnew1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#stream h2 {
  position: relative;
  overflow: hidden;
}
#stream h2::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/stream2.png") no-repeat center / contain;
  opacity: 1;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#stream h2::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/top/stream1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#next .inner {
  padding: 3em 0 7em;
}
#newep {
  max-width: 980px;
  margin: 0 auto; /*padding:0 0 150px;*/ position: relative;
}
#newep h3.tagline {
  text-align: center;
  font-size: 300%;
  font-weight: 600;
  padding: .1em 0 .2em;
  color: #fff;
  line-height: 130%;
  text-shadow: 0px 0px 6px #086200, 0px 0px 10px #086200;
  border-top: 1px solid rgba(234, 223, 174, .7);
  border-bottom: 1px solid rgba(234, 223, 174, .7);
  margin: -.2em 0 .4em;
  background: linear-gradient(to right, rgba(8, 98, 0, 0) 0%, rgba(8, 98, 0, 0.8) 25%, rgba(8, 98, 0, 0.8) 50%, rgba(8, 98, 0, 0.8) 75%, rgba(8, 98, 0, 0) 100%);
}
#next .nextmov {
  width: 95%;
  width: 100%;
  margin: -.5em 0 0;
  position: relative;
}
div.mov-inner {
  position: relative;
  height: 0;
  padding-top: 53.4375%;
  padding-top: 56.25%;
  background-color: #000;
}
div.mov-inner iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
#storyline {
  position: relative;
  width: 100%;
  padding: .25em 0 2.5em 0;
  margin: 0 auto;
  /*  background: rgba(255, 255, 255, .7);*/
  background: #F5F5F5;
  outline: 1px solid #4A080A;
  outline-offset: -8px;
  display: flex;
  flex-flow: row wrap;
  justify-content: center; /*position:absolute; right:0; bottom:0;*/ margin: 1em auto 0;
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
}
#newep h3.epnum {
  padding: 12px 80px;
  font-size: 200%;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  line-height: 100%;
  display: block;
  font-family: "Playfair Display", serif;
  font-style: normal;
  background-color: #4A080A;
  clip-path: polygon(0 0, 100% 0, calc(100% - 21px) 100%, 0 100%);
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
  letter-spacing: .05em;
}
#newep h3.epnum span {
  font-size: 100%;
  letter-spacing: -.025em;
}
#storyline p.text {
  font-size: 105%;
  word-break: break-all;
  color: #0D0D0D;
  width: 85%;
  padding: 5em 0 0;
  line-height: 1.6;
  font-weight: 500;
}
#next .oadate {
  position: absolute;
  right: 5%;
  right: 0;
  top: 20px;
  width: 41%;
}
#next .oadate::after {
  content: "";
  position: absolute;
  left: -40%;
  bottom: 0;
  top: 45px;
  width: 120%; /* 線の長さ */
  height: 1px;
  background: #4A080A;
}
#next .oadate img {
  width: 100%;
}
#next .date {
  color: #4A080A;
  font-size: 350%;
  font-family: minion-pro, serif;
  font-weight: 600
}
#next .onair {
  color: #4A080A;
  font-size: 250%;
  font-family: minion-pro, serif;
  font-weight: 600
}
#next .small {
  font-size: 80%;
}
.marker {
  width: 275px;
  position: absolute;
  right: 0;
  left: 0;
  /*  bottom: -5%;*/
  margin: 1em 0 0 auto;
}
.marker a {
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
}
.marker a, a.btn_df {
  position: relative;
  left: -4%;
  font-size: 150%;
  display: block;
  width: 100%;
  text-align: center;
  color: #fff;
  background: linear-gradient(11deg, #252525 0 50%, #0D0D0D 50% 100%);
  padding: .7em 0;
  transform: skewX(-21deg);
}
#highlight label {
  position: relative;
  left: 0;
  font-size: 150%;
  display: block;
  width: 100%;
  text-align: center;
  color: #fff;
  background: linear-gradient(11deg, #252525 0 50%, #0D0D0D 50% 100%);
  padding: .7em 0;
  transform: skewX(-21deg);
}
.marker a span, a.btn_df span, #highlight label span {
  display: inline-block;
  transform: skewX(21deg);
}
#topics a.tolist {
  position: relative;
  left: -23%;
  font-size: 150%;
  display: block;
  width: 100%;
  text-align: center;
  color: #fff;
  background: linear-gradient(11deg, #6D1300 0 50%, #4A080A 50% 100%);
  padding: .7em 0;
  transform: skewX(-21deg);
}
#topics a.tolist span {
  display: inline-block;
  transform: skewX(21deg);
}
@media all and (max-width: 991px) {
  #newep {
    width: 96%;
    margin: 0 auto;
  }
  #storyline {
    width: 100%;
    margin: 2% auto 5%;
  }
  #next .oadate {
    position: absolute;
    right: 6%;
    width: unset;
  }
}
/*tbsfree*/
#mov_tbsfree {
  width: 100%;
  margin: 0 auto;
  padding: 2em 0;
  background-image: linear-gradient(to top, rgba(8, 79, 4, .4) 0%, rgba(8, 98, 0, .75) 50%, rgba(9, 108, 0, .9) 100%), url(../img/top/bg45.png), url(../img/top/bg5.jpg);
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: 0 0, center center, center center;
  background-size: auto, cover, cover;
  border-bottom: 1px solid rgba(234, 223, 174, .7);
}
/*topics*/
#tbstopics {
  padding: 0 0 7em;
  margin: 0 auto;
  position: relative;
  background: url("../img/top/bg6.jpg") no-repeat center center;
  background-color: #0d0d0d;
  background-size: 100%;
  background-size: cover;
}
#tbstopics h2 {
  letter-spacing: -.1em;
  color: #fff;
}
#topics {
  position: relative;
  padding: 0;
  background-size: 140px;
  padding: 3em 0 0;
}
#topics a.tolist {
  margin: 0 auto;
}
@media all and (min-width: 768px) {
  #topics {
    max-width: 1080px;
    margin: 0 auto;
  }
}
/*whatsnew*/
#whatsnew {
  margin: 0 auto;
  position: relative;
  background-repeat: no-repeat, no-repeat;
  background-position: left -5vw top 0, center bottom;
  background-size: 50vw, cover;
}
#update {
  max-width: 1080px;
  position: relative;
  margin: 0 auto;
  padding: 3em 0 2em;
  z-index: 11;
}
/*
#update h2 {
  z-index: 11;
  padding: .5em;
  font-size: 360%;
  color: #fff;
  font-weight: 600;
  letter-spacing: .05em;
}
*/
#update ul#topicslist {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  height: auto;
  /*  height: 350px;*/
  overflow-y: scroll;
  padding: .5em 0 0 0;
  margin: 0 auto;
}
#update ul::-webkit-scrollbar {
  width: 1px;
}
#update ul::-webkit-scrollbar-track {
  background: none;
}
#update ul::-webkit-scrollbar-corner {
  display: none;
}
#update ul::-webkit-scrollbar-thumb {
  background: rgba(225, 225, 225, .8);
}
#update ul#topicslist li {
  width: 44.8%;
  height: auto;
  position: relative;
  margin: 0 0 1.5em 2.5em;
  z-index: 1;
  background-color: #F5F5F5;
  border-bottom: 4px solid #4A080A;
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
}
#update ul#topicslist li a span.thum {
  width: 185px;
  height: 135px;
  display: inline-block;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center top;
  vertical-align: top;
  margin: 0 2.5% 0 0;
  vertical-align: middle;
  background-color: #fff
}
#update ul#topicslist li p {
  display: inline-block;
  line-height: 1.4;
  padding: 0;
  width: auto;
  vertical-align: middle;
  font-weight: 500;
  font-size: 100%;
  width: -webkit-calc(100% - 210px);
  width: calc(100% - 210px);
}
#update ul#topicslist li a {
  display: block;
  width: 100%;
  color: #0d0d0d;
}
#update ul#topicslist li a:hover {
  opacity: 0.5;
  transition: 0.4s;
}
#update ul#topicslist li span.tag {
  color: #fff;
  font-size: 80%;
  display: inline-block;
  position: absolute;
  bottom: 70%;
  text-align: right;
  line-height: 100%;
  padding: .3em .6em;
  background: #4A080A;
  width: 12%;
  text-align: center;
  font-family: "Playfair Display", serif;
}
#update ul#topicslist li span.ymd {
  color: #6D1300;
  font-size: 100%;
  display: inline-block;
  position: absolute;
  bottom: 6%;
  right: 1.5%;
  text-align: right;
  line-height: 100%;
  padding: 0 .2em 0;
  font-family: minion-pro, serif;
}
/*#update ul#topicslist li:last-child a{pointer-events: none; cursor: default;}*/
#update .ytbthum {
  background-position: center center !important;
  background-size: contain !important;
}
#update .thum_90 {
  background-position: center center !important;
  background-size: 90% !important;
}
#update .thum_80 {
  background-position: center center !important;
  background-size: 80% !important;
  background-color: rgba(245, 242, 238, .9) !important;
}
@media all and (min-width: 768px) {
  #update ul#topicslist {
    justify-content: start;
    align-items: start;
  }
}
@media all and (max-width: 991px) {
  #update ul#topicslist {
    height: auto;
    width: 96%;
  }
  #update ul#topicslist li {
    width: 48%;
    margin: 0 1% 2% 1%;
  }
  #update ul#topicslist li p {
    width: 60%;
    font-size: 90%;
    padding: 4% 0 2%;
  }
  #update ul#topicslist li span.ymd {
    font-size: 85%;
  }
  #update ul#topicslist li a span.thum {
    width: 35%;
    height: auto;
    margin: 0 3% 0 0;
    position: relative;
    padding: 28% 0 0;
  }
}
/*bnr*/
.bnarea {
  padding: 2em 0 .5em;
  margin: 0 auto;
  position: relative;
  background: url(../img/top/bg2.jpg) no-repeat center center;
  background-size: cover;
}
ul.bnr, ul.streambnr {
  display: flex;
  flex-flow: row wrap;
  max-width: 1000px;
  margin: 0 auto;
  justify-content: center;
  position: relative;
  z-index: 1;
}
ul.bnr li {
  width: 450px;
  height: 135px;
  margin: 0 1.5em 1.5em 1.5em;
}
ul.bnr li a {
  display: block;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  position: relative;
  background-size: cover;
  border: 1px solid #0d0d0d;
}
ul.bnr li.bn_goods a {
  background-image: url(../img/top/bn_goods.jpg);
}
#sns_str {
  /*  background: url(../img/top/bg3.jpg) no-repeat center top;*/
  background-size: 120%;
}
/*post*/
#snspost {
  margin: 0 auto;
  text-align: center;
  padding: 0;
  position: relative;
  padding: 2.5em 0;
  /*  background: rgba(237, 220, 191, 0.3);*/
  background: url(../img/top/bg3.jpg) no-repeat center center;
  background-size: cover;
}
#snspost p {
  vertical-align: middle;
  display: inline-block;
  font-size: 220%;
  text-align: center;
  color: #fff;
  /*  font-weight: 700;*/
}
#snspost p span.outgo {
  display: block;
  font-size: 1.25rem !important;
  padding: .6em 0 0;
}
#snspost #sns {
  text-align: center;
  margin: 0 0 0 1em;
  display: inline-block;
  vertical-align: middle;
}
#snspost #sns a {
  width: 80px;
  height: 80px;
  margin: 0 5px 0;
  position: relative;
  display: inline-block;
  border-radius: 50%;
  transition: .3s;
  background: #fff;
}
#snspost #sns a:hover {
  opacity: 0.5;
}
#snspost #sns a img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 50%;
}
#snspost p.htag {
  font-size: 165%;
  display: block;
  padding: 1em 0 .5em;
  line-height: 100% !important;
  font-weight: 700;
}
#snspost p.htag:not(span) {
  text-shadow: 0px 0px 6px rgba(240, 232, 215, 1), 0px 0px 8px rgba(240, 232, 215, 1);
}
#snspost p.htag span {
  color: #fff;
  background: #126c0a;
  padding: 0 !important;
  display: inline-block;
  text-shadow: none;
}
#snspost a.postbtn {
  width: 320px;
  color: #fff;
  padding: .7em 0;
  font-size: 160%;
  margin: .5em auto 0;
  display: block;
  border-radius: 50px;
  transition: .3s;
  background: rgba(8, 98, 0, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 8px 8px 10px rgba(240, 232, 215, 0.5);
}
/*footer*/
footer {
  text-align: center;
  padding: 2.5em 0 0;
  /*background-image:linear-gradient(to top, rgba(165,194,224,0.4) 0%,rgba(138,176,213,0.6) 30%,rgba(15,52,122,0.3) 100%);*/
}
footer p.copy {
  text-align: center;
  padding: 2.5em 0;
  font-size: 80%;
  line-height: 140%;
  color: #fff;
  background: url("../img/top/bg5.png");
  background-size: contain;
  margin-top: 40px
}
footer p.copy a {
  color: #fff;
}
/*f2*/
footer.dir2 {
  margin: 0;
}
/*------------------　2nd　------------------ */
header {
  background: url("../img/bg_main.jpg") no-repeat center center;
  background-size: cover;
}
header#dir {
  padding: 0;
  margin: 0 auto;
  position: relative;
}
header#dir #logo {
  margin: 0 auto;
  padding: 2em 0 2em;
  animation: fadein 1.5s ease 0s 1 normal;
  -webkit-animation: fadein 2s ease 0s 1 normal;
}
header#dir #logo a {
  max-width: 800px;
  height: 160px;
  display: block;
  margin: 0 auto;
  background: url("../img/title.png") no-repeat center center;
  background-size: contain;
}
.wrap {
  position: relative;
  padding: 3em 0 0;
}
.wrap .bn_top {
  margin: 1em auto 2em;
  box-shadow: 8px 8px 20px rgba(84, 67, 37, 0.3);
}
.wrap .bn_bottom, {
  margin: 1em auto 2em;
  box-shadow: 8px 8px 20px rgba(84, 67, 37, 0.3);
}
h1#ttl {
  position: relative;
  z-index: 11;
  margin: 0 auto 32px;
  font-weight: 600;
  max-width: 1000px;
  padding: 0;
  position: relative;
  font-size: 750%;
  overflow: hidden;
}
#info h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/news1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#info h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/news2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#about h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/about1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#about h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/about2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#caststaff h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/caststaff1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#caststaff h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/caststaff2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#story h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/story1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#story h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/story2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#chart h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/chart1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#chart h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/chart2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
#articles h1#ttl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/title/topics1.png") no-repeat center / contain;
  opacity: 0;
  animation: fadeRed 16s infinite;
  margin: 0 auto;
}
#articles h1#ttl::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/title/topics2.png) no-repeat center / contain;
  opacity: 0;
  animation: fadeWhite 16s infinite;
  margin: 0 auto;
}
h1#ttl span.hdl {
  opacity: 0;
}
h1#ttl span.subtxt {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 3.5rem;
  letter-spacing: .05em;
  color: #fff;
  margin: 0 0 .5em .25em;
  font-family: "longhand-lp", sans-serif;
  font-weight: 600;
  font-style: normal;
  display: inline-block;
  padding: 0;
  text-shadow: 0px 0px 6px #d6aa56, 0px 0px 8px #d6aa56;
  transform: rotate(-5deg);
}
#contents {
  max-width: 1000px;
  background: #F5F5F5;
  padding: 4em 0 4em;
  margin: 0 auto 3em;
  position: relative;
  box-shadow: 4px 4px 16px rgba(13, 13, 13, 0.25);
  border-top-width: 6px;
  border-bottom-width: 6px;
  outline: 1px solid #4A080A;
  outline-offset: -8px;
}
#special #contents {
  padding: 0 !important;
}
#contents .inner {
  width: 90%;
}
#contents .inner p {
  font-size: 105%;
  padding: 1em 0 .5em;
  line-height: 1.7;
  font-weight: 500;
}
.ph_cut {
  width: 700px;
  height: 467px;
  margin: 1.5em auto;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  position: relative;
}
.ph_cut_l {
  width: 400px;
  height: 600px;
  margin: 1.5em auto;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center top;
  position: relative;
}
.lazy {
  position: relative;
  display: block;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.lazy img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.line1 {
  background: linear-gradient(transparent 70%, rgba(255, 242, 77, 0.4) 70%);
  padding: 0 .2em .1em;
}
.line2 {
  background: linear-gradient(transparent 80%, rgba(253, 245, 140, 0.6) 80%);
  padding: 0 .2em .1em;
}
.bdr {
  padding: .8em 1.5em;
  margin: 1.5em auto;
  font-size: 95%;
  background-color: rgba(255, 251, 244, 0.8);
}
.bdr2 {
  padding: .8em 1.5em;
  margin: 1.5em auto .5em;
  font-size: 95%;
  border: 1px solid #dabd64;
  box-shadow: 10px 10px 20px rgba(197, 152, 97, 0.2);
}
.fuchidori {
  font-weight: bold;
  color: rgba(0, 0, 0, 0);
  text-shadow: 2px 2px 0 #fef900;
  -webkit-text-stroke: 1px #fd52ba;
  text-stroke: 1px #fd52ba;
}
a.btn_df {
  font-size: 180%;
  width: 40%;
  margin: 1.25em auto;
  padding: 1em 0;
}
#highlight label {
  font-size: 150%;
  width: 40%;
  margin: 1.25em auto;
  padding: 1em 0;
}
@media all and (max-width: 991px) {
  header#dir {
    padding: 5% 0 0;
  }
  header#dir #logo {
    width: 88%;
    height: auto;
    padding: 18% 0 0;
    position: relative;
    margin: 0 auto 5%;
  }
  header#dir #logo a {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 4%;
    top: 0;
  }
  h1#ttl {
    width: 75%;
    height: 90px;
  }
  #contents {
    width: 96%;
    margin: 0 auto 5%;
    padding: 5% 0;
    box-sizing: border-box;
  }
  .ph_cut {
    width: 95%;
    height: 0;
    padding: 63% 0 0;
    position: relative;
    margin: 1em auto;
  }
  .ph_cut_l {
    width: 60%;
    height: 0;
    padding: 90% 0 0;
    position: relative;
    margin: 1em auto .5em;
  }
}
/*about*/
#highlight h2 {
  font-weight: 600;
  line-height: 180%;
  font-size: 160%;
  margin: .5em 0 .5em;
  text-align: center;
}
#highlight h3 {
  font-weight: 600;
  line-height: 150%;
  font-size: 140%;
  margin: 1em 0 0;
  color: #1d9a12;
}
#highlight h3 span {
  border-bottom: 3px double #1d9a12;
  padding: 0 0 .1em;
  display: inline-block;
}
#highlight h3 + p {
  padding: .5em 0 !important;
}
#highlight h4 {
  font-weight: 500;
  line-height: 160%;
  font-size: 130%;
  padding: 1em 0 .5em;
  text-align: center;
}
#highlight .ph1 {
  width: 600px;
  height: 424.5px;
}
#highlight .ph1 span {
  width: 100%;
  height: 100%;
  background-image: url(../img/about.jpg);
  background-position: center center;
  position: absolute;
  z-index: auto;
  display: block;
  background-size: cover;
}
#highlight .ph1:before, #cast table td {
  padding: .5em .5em .5em 1em;
  font-size: 90%;
}
#highlight p.cap {
  font-size: 85%;
  text-align: center;
  padding: 0 !important;
  margin: 0 !important;
}
#highlight .hidden_show {
  height: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.8s;
}
#highlight input:checked ~ .hidden_show {
  padding: 0;
  height: auto;
  opacity: 1;
}
#highlight label {
  cursor: pointer;
}
#highlight input {
  display: none;
}
#highlight .comment {
  padding: .8em 1.5em;
  margin: 1.5em 0;
  position: relative;
  background: rgba(210, 190, 188, .15);
  border: 1px solid rgba(225, 225, 225, .6);
}
#highlight .comment h3 {
  line-height: 140%;
  font-size: 120%;
  margin: .2em 0 0;
  color: #fff;
  background-color: #4A080A;
  padding: .2em .8em;
}
#highlight .comment h3 span {
  border: none;
}
#highlight .comment h4 {
  padding: 0 0 0 2.5em;
  margin: .8em 0 .2em;
  font-size: 115%;
  font-weight: 500;
  text-align: left;
  position: relative;
  color: #ff8f9f;
}
#highlight .comment h4 + p {
  padding: 0 0 .5em !important;
}
#highlight .comment h4:before {
  content: "";
  width: 40px;
  height: 1px;
  background-color: #ff8f9f;
  position: absolute;
  left: 0;
  top: 50%;
}
#highlight .comment p {
  padding: .5em;
}
.emphasis {
  text-emphasis: filled dot black;
  -webkit-text-emphasis: filled dot black;
}
@media all and (max-width: 991px) {
  #highlight .ph1 {
    width: 90%;
    height: 0;
  }
  #highlight .ph1 span {
    position: absolute;
    top: 0;
    left: 0;
  }
}
/*caststaff*/
#caststaff h1#ttl span.hdl {
  letter-spacing: -.2em;
  padding: 0 .4em .6em 0;
}
#caststaff .slash {
  z-index: 1;
  display: inline-block;
  vertical-align: middle;
}
#caststaff h2 {
  color: #fff;
  font-size: 160%;
  position: relative;
  display: inline-block;
  position: relative;
  margin: 0 auto 1.3em;
  font-style: normal;
  padding: .2em 4em;
  background: #4A080A;
  width: 40%;
  font-family: "Playfair Display", serif;
  letter-spacing: .05em;
}
#caststaff h2.staff {
  margin: 1em auto 0;
  padding: .2em 4em;
  background: #4A080A;
}
#caststaff h3 {
  margin: 1.3em auto .4em;
  font-size: 105%;
  font-weight: 600;
  position: relative;
  line-height: 170%;
  color: #6D1300;
}
#caststaff .credit {
  text-align: center;
  width: 80%;
  margin: 0 auto;
  font-size: 140%;
  line-height: 1.8;
  color: #0d0d0d
}
#caststaff .credit span.f80 {
  font-size: 80% !important;
}
#caststaff .credit span.f80_2 {
  font-size: 85%;
  line-height: 130%;
  display: block;
}
#caststaff .credit span.f80_3 {
  font-size: 1.5rem;
  line-height: 100%;
  display: block;
  line-height: 130% !important;
  margin: -.2em 0 .25em;
}
#caststaff table {
  width: 98%;
  margin: 0 auto;
  font-size: 140%;
}
#caststaff table td {
  text-align: center;
  padding: 2% 0;
  line-height: 1;
  font-weight: 500;
}
#caststaff table td.cname {
  text-align: left;
  width: 48%;
  vertical-align: middle;
  color: #0d0d0d
}
span.group {
  font-size: 80%;
}
#caststaff table td.chara {
  text-align: right;
  width: 48%;
  vertical-align: middle;
  color: #6D1300;
  line-height: 100%;
  font-weight: 600;
}
#caststaff table td.naka {
  padding: 0;
  font-size: 80%;
  vertical-align: middle;
  line-height: 0;
  color: rgba(210, 190, 188, 1);
  font-weight: 400;
}
#caststaff table td.maru {
  font-size: 80%;
  color: #6D1300;
  padding: .5% 0;
  font-weight: 400;
}
#caststaff table tr.shohei1 td {
  padding: 2% 0 1%;
}
#caststaff table tr.shohei2 td {
  padding: 0 0 2%;
}
#caststaff ruby[data-ruby] {
  position: relative;
}
#caststaff ruby[data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  left: -2em;
  top: -1.8em;
  right: -2em;
  text-align: center;
  font-size: .5em;
}
/*share*/
#share {
  width: 100%;
  text-align: center;
  margin: 0% auto 0;
  vertical-align: middle;
  padding: 2.5em 0;
}
#top #share {
  /*  margin: 5% auto;*/
  background: url(../img/top/bg4.jpg) no-repeat center center;
  background-size: cover;
}
#share span {
  position: relative;
  color: #fff;
  font-weight: 600;
}
#info #share span, #about #share span, #caststaff #share span, #story #share span, #chart #share span {
  animation: headingColor 16s infinite;
}
#share ul {
  display: inline-block;
  margin: 0 0 0 .5em;
  vertical-align: middle;
}
#share ul li {
  display: inline-block;
  border-radius: 50%;
  margin: 0 .4em 0;
}
#share ul li img {
  width: 50px;
}
#share ul li a {
  display: block;
}
/*//////pc//////*/
@media all and (min-width: 992px) {
  .nobr {
    display: none;
  }
}
@media all and (max-width: 991px) {
  .pcbr {
    display: none;
  }
}
/*//////smp//////*/
@media all and (max-width: 767px) {
  body, p {
    font-size: 1.3rem;
  }
  h1 {
    font-size: 2.6rem;
  }
  h2 {
    font-size: 2rem;
    line-height: 1.5em;
  }
  h3 {
    font-size: 1.6rem;
  }
  h4 {
    font-size: 1.4rem;
  }
  .f90 {
    font-size: 1.2rem;
  }
  .hidtxt {
    visibility: visible;
  }
  .hid_sp {
    display: none;
  }
  .ph_cut img, .ph_cut_l img, #spot #trailer img, #update ul#topicslist li span.thum img, #newep figure#mainph span img, header#dir #logo a img, .bn_recruit a, .bn_tdc a, .bn_top a, .bn_bottom a {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
  header {
    background-size: contain;
  }
  /*menu*/
  #menu li {
    height: 0;
    padding: 18% 0 0;
  }
  #menu li:after {
    height: 32px
  }
  #menu li a {
    position: absolute;
    top: 2px;
    left: 2px;
    padding: 0;
  }
  #menu li span.sub {
    font-size: 5vw;
    font-weight: 700;
  }
  #menu li span.ttlruby {
    font-size: 2.6vw;
    /*    margin: 4% 0 0;*/
  }
  #menu li.menu3 {
    width: 150px
  }
  #menu li.menu1, #menu li.menu2 {
    width: 30%;
  }
  #menu li.menu3 {
    width: 40%;
  }
  #menu li.menu4, #menu li.menu5, #menu li.menu6 {
    width: -webkit-calc(72% / 3);
    width: calc(72% / 3);
  }
  #menu li.menu7 {
    width: 28%;
  }
  #menu li.menu3:after {
    border: none;
  }
  .topbnr {
    padding: 4% 0;
  }
  .topbnr2 {
    padding: 3% 0;
  }
  .topbnr2:before {
    top: 4px;
    border-top: .5px solid rgba(13, 13, 13, .8);
  }
  .topbnr2:after {
    left: 0;
    bottom: 4px;
    border-bottom: .5px solid rgba(13, 13, 13, .6);
  }
  .bn_recruit {
    margin: 0 auto;
    width: 80%;
    height: 0;
    padding: 24% 0 0;
  }
  .bn_box {
    position: relative;
    padding: 4% 0;
  }
  .bn_box::after {
    bottom: -2%;
  }
  .bn_top {
    margin: 0 auto;
    width: 96%;
    height: 0;
    padding: 18.359375% 0 0;
  }
  .bn_bottom {
    margin: 0 auto;
    width: 96%;
    height: 0;
    padding: 18.359375% 0 0;
  }
  #toplink {
    padding: 4.5% 0 4%;
    margin: 5% auto 0;
    text-align: center;
  }
  #toplink .bnr {
    width: 95%;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
    padding: 0;
    border: none;
  }
  #toplink .bnr a {
    width: 40%;
    height: 0;
    padding: 10% 0 0;
    margin: 0 2% 0 0;
  }
  #toplink .bnr span {
    font-size: 4.1vw;
    margin: 0;
    width: 55%;
    display: inline-block;
    padding: 0;
  }
  #snslink {
    width: 95%;
    text-align: center;
    margin: 2.5% auto 0;
  }
  #snslink p {
    font-size: 5vw;
    padding: 0 !important;
    width: 35%;
    letter-spacing: -.05em;
  }
  #snslink p span {
    display: block;
    font-size: 2vw !important;
    padding: 5% 0 0;
    letter-spacing: 0 !important;
  }
  #snslink #sns {
    margin: 0 0 0 .5%;
    width: 56%;
  }
  #snslink #sns a {
    width: 13.5vw;
    height: 13.5vw;
    margin: 0 .9% 0;
  }
  .slash {
    display: none;
  }
  .notice p {
    font-size: 3vw;
    padding: 3.5% 1%;
    line-height: 160%;
  }
  #next h2, #topics h2, #whatsnew h2, #stream h2 {
    font-size: 10vw;
    padding: 0 3.5vw 2.5vw 2vw;
    margin-bottom: 5vw
  }
  #next h2 span, #topics h2 span, #whatsnew h2 span, #stream h2 span {
    font-size: 5.5vw;
  }
  /*next*/
  #next {
    background-position: right -8vw top, center top;
    background-size: 68vw, cover;
  }
  #next .inner {
    padding: 5vw 0 20vw;
  }
  #next .date {
    font-size: 4rem;
  }
  #next .onair {
    font-size: 2.5rem;
  }
  #next .small {
    font-size: 2.5rem;
  }
  #newep {
    margin: 0 auto;
    width: 94%;
  }
  #newep h3.tagline {
    font-size: 7vw;
  }
  #next .nextmov {
    width: 100%;
    width: 100%;
  }
  #storyline {
    width: 100%;
    padding: 2vw 1.5vw 6vw;
    outline-offset: -5px;
  }
  #newep h3.epnum {
    font-size: 5vw;
    padding: 5px 32px;
  }
  #storyline p.text {
    font-size: 3.4vw;
    padding: 16% 0 0 0;
    width: 90%;
  }
  #next .oadate {
    right: 6vw;
    top: 4vw;
    width: unset;
  }
  #next .oadate::after {
    content: "";
    position: absolute;
    left: -23px;
    bottom: 0;
    top: 32px;
    width: 110%; /* 線の長さ */
  }
  #storyline .marker {
    width: 48%;
    margin: 5% auto 0;
  }
  #newep .marker a {
    width: 100%;
    font-size: 5vw;
    position: relative;
    left: 0;
  }
  .marker {
    margin: 0 auto;
    width: 235px
  }
  /*tbsfree
  #mov_tbsfree {
    padding: 5% 0;
  }
  /*topics*/
  #tbstopics {
    padding: 0 0;
    margin: 0 auto;
    background: url(../img/top/bg6.jpg);
    background-size: cover;
  }
  #topics {
    background-size: 20%;
    padding: 5vw 0 20vw;
    background-position: left 1% top 0;
  }
  #topics a.tolist {
    width: 100%;
    font-size: 5vw;
    position: relative;
    left: 0;
  }
  /*whatsnew*/
  #whatsnew {
    margin: 0 auto;
    padding: 0 0 5vw;
    background-position: left -12vw top 0, center bottom;
    background-size: 60vw, cover;
  }
  #update {
    padding: 5vw 0 2%;
    width: 100%;
  }
  #update h2 {
    padding: 0 4vw 2.6vw 4vw;
  }
  #update ul#topicslist {
    height: auto;
    margin: 1% auto 0;
    width: 94%;
    overflow-y: scroll;
    /*    height: 460px;*/
    padding: 0;
    overflow-scrolling: touch;
    -webkit-overflow-scrolling: touch;
    /*    height: 50vh;*/
    padding: 0 2% 0 0;
  }
  #update ul#topicslist li {
    width: 100%;
    height: auto;
    margin: 0 2.5% 3.5% auto;
  }
  #update ul#topicslist li p {
    line-height: 130% !important;
    font-size: 3.4vw;
    padding: 4% 0 2%;
    width: 58%;
  }
  #update ul#topicslist li span.ymd {
    font-size: 3.5vw;
  }
  .bnarea {
    padding: 3% 0 3%;
  }
  ul.bnr {
    width: 100%;
    align-items: center;
  }
  ul.bnr li {
    width: 94%;
    height: auto;
    margin: 2% auto;
  }
  ul.bnr li a {
    height: 0;
    padding: 30% 0 0;
  }
  #sns_str {
    background-position: left 25% top 0;
    background-size: cover;
  }
  /*post*/
  #snspost {
    padding: 6% 0;
  }
  #snspost p {
    font-size: 5.6vw;
  }
  #snspost p span.outgo {
    display: block;
    font-size: 2vw !important;
    padding: 5% 0 0;
    letter-spacing: 0 !important;
  }
  #snspost #sns {
    margin: 0 0 0 1%;
    width: 52%;
  }
  #snspost #sns a {
    width: 15vw;
    height: 15vw;
    margin: 0 .5% 0;
  }
  #snspost p.htag {
    font-size: 4.5vw;
    line-height: 130% !important;
    padding: 4.5% 0 2.5%;
  }
  #snspost a.postbtn {
    width: 60%;
    font-size: 4.5vw;
  }
  footer p.copy {
    width: 100%;
    padding: 5%;
    margin-top: 5vw
  }
  footer {
    padding: 0;
  }
  #gotop {
    bottom: 0;
    right: 0;
    z-index: 11;
  }
  #gotop a {
    width: 60px;
    height: 60px;
  }
  /*------------------　2nd　------------------ */
  h1#ttl {
    font-size: 8.5vw;
    margin-bottom: 5vw;
  }
  h1#ttl span.subtxt {
    font-size: 5.5vw;
  }
  .wrap {
    padding: 5vw 0 0;
  }
  /*
  .wrap:before {
    height: 250px;
  }
*/
  .wrap .bn_top {
    margin: 0 auto 5%;
  }
  .wrap .bn_bottom {
    margin: 0 auto 5%;
  }
  #contents {
    padding: 8% 0;
    border-top-width: 4px;
    border-bottom-width: 4px;
    outline-offset: -5px;
  }
  #contents .inner {
    width: 98%;
  }
  #contents .inner p {
    padding: .5em 0 1em;
    line-height: 160%;
  }
  #contents .inner p.f85, #contents .inner p.f80 {
    line-height: normal !important;
  }
  .bdr {
    width: 92%;
    padding: .4em 0;
  }
  /*about*/
  #highlight h2 {
    font-size: 3.9vw;
    padding: 0 1% 2.5%;
    line-height: 170%;
  }
  #about #contents p, #story #contents p {
    padding: 1em 4% .5em;
  }
  #highlight h3 {
    font-size: 4.5vw;
    padding: 0 4%;
    margin: 5% auto 1.5%;
    line-height: 140%;
  }
  #highlight h3 span {
    padding: 0 0 .25em;
  }
  #highlight h3 + p {
    padding: .5em 4% .5em !important;
  }
  #highlight h4 {
    font-size: 4vw;
    padding: 2% 1% 0;
  }
  #highlight .ph1 {
    margin: 0 auto;
  }
  #highlight .comment h3 {
    margin: 0;
  }
  #highlight .comment {
    width: 94%;
    margin: .8em auto 1em;
    padding: 4% 5%;
    background-size: 50%;
  }
  #highlight .comment p {
    padding: 1% 0 0 !important;
  }
  /*caststaff*/
  #caststaff .slash {
    width: 3.5vw;
  }
  #caststaff h2 {
    margin: 0 auto 5%;
    font-size: 160%;
    padding: 0
  }
  #caststaff h2.staff {
    margin: 8% auto 0;
    padding: 0
  }
  #caststaff h3 {
    margin: 5% auto 1.5%;
  }
  #caststaff h3:first-of-type {
    margin: 5% auto 1.5%;
  }
  #caststaff table {
    width: 100%;
    margin: 0 auto;
  }
  #caststaff table td {
    padding: 3.5% 0;
  }
  #caststaff table td.cname {
    font-size: 4.3vw;
    width: 49%;
  }
  span.group {
    font-size: 2.7vw;
  }
  #caststaff table td.chara {
    font-size: 4.3vw;
    width: 46%;
  }
  #caststaff table td.naka {
    font-size: 3.5vw;
    vertical-align: middle;
  }
  #caststaff .credit {
    font-size: 4.3vw;
    margin: 0 auto;
    width: 100%;
  }
  #caststaff table td.cname span.f90 {
    font-size: 3vw;
  }
  #caststaff table td.maru {
    font-size: 75%;
    padding: 2% 0 !important;
    line-height: 100% !important;
  }
  #caststaff table td.blank {
    padding: 1.8% 0;
  }
  #caststaff table td.cname span.f75 {
    font-size: 2.5vw !important;
  }
  #caststaff .credit span.f80_2 {
    font-size: 90%;
  }
  #caststaff .credit span.f80_3 {
    font-size: 2.8vw;
    margin: -.2em 0 3%;
  }
  #caststaff table tr.shohei1 td {
    padding: 2.5% 0 1%;
  }
  #caststaff table tr.shohei2 td {
    padding: 0 0 2.5%;
  }
  a.btn_df, #highlight label {
    width: 70%;
    margin: 5% auto;
    padding: 5% 0;
    font-size: 5vw;
    letter-spacing: .05em;
  }
  /*share*/
  #share {
    width: 100%;
    margin: 2% auto 4%;
    padding: 6% 0
  }
  #top #share {
    /*    margin: 5vw 0;*/
    margin: 0 0 5vw;
  }
  #share span:before {
    content: "";
    width: 40%;
    left: -50%;
  }
  #share ul li {
    margin: 0 .2em 0;
  }
  #share ul li img {
    width: 40px;
  }
}
@media all and (max-width: 320px) {
  a.btn_ap {
    width: 70%;
  }
}
.md-inner {
  box-shadow: none !important;
}
.md-caption {
  color: #222 !important;
}
.fadedown {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1s;
  -ms-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-name: fadedown;
  -ms-animation-name: fadedown;
  animation-name: fadedown;
  visibility: visible !important;
}
@-webkit-keyframes fadedown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
  }
}
@keyframes fadedown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
.nocontxt {
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -webkit-touch-callout: none;
  text-align: center;
}
.nocontxt img {
  pointer-events: none;
}
/*#countdown*/
.countdown {
  color: #F5F5F5;
  display: flex;
  justify-content: center;
  height: 110px;
  align-items: center;
}
.countdown p {
  margin-right: 8%;
  font-size: 3rem;
  position: relative
}
.countdown p::after {
  content: "";
  width: 20%;
  height: 1px;
  background-color: #F5F5F5;
  position: absolute;
  top: 50%;
  right: -25%;
  z-index: 1;
}
.countdown span {
  letter-spacing: 0.2rem;
}
#countdown {
  font-weight: normal;
  font-size: 3rem;
  color: #F5F5F5;
  font-family: minion-pro, serif;
}
#countdown .num {
  font-size: 5.7rem;
  color: #F5F5F5;
  margin-right: 2px;
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .countdown {
    height: 5.5rem;
    margin: 0 auto;
    width: 94%
  }
  .countdown p {
    margin-right: 8%;
    font-size: 3.3vw;
  }
  .countdown p::after {
    content: "";
    width: 15%;
    height: 1px;
    top: 50%;
    right: -18%;
    z-index: 1;
  }
  #countdown {
    font-size: 3.3vw;
  }
  #countdown .num {
    font-size: 6.6vw;
    margin-right: 2px;
    margin-left: 5px
  }
}
@media all and (max-width: 330px) {
  .countdown p {
    font-size: 3.2vw;
  }
  #countdown {
    font-size: 3.2vw;
  }
  #countdown .num {
    font-size: 6.4vw;
  }
}
.soon {
  pointer-events: none;
  text-decoration: none;
  cursor: default;
}
#menu li.soon span.sub, #menu li.soon span.ttlruby {
  opacity: .4
}
