@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=EB+Garamond:wght@500&display=swap);
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 100;
}

@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 200;
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

body {
  background-color: #fff;
  color: #000;
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 500;
  -webkit-font-smoothing: subpixel-antialiased;
  font-kerning: normal;
  margin: 0;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
body {
    font-family: "メイリオ", Meiryo, "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", sans-serif;
  }
  /* IE11 */
}

/**
 * ネストされたリストのマージンをリセットします。
 */
li > ul, li > ol {
  margin-bottom: 0;
}

/**
 * `dt`と`dd`の左端を揃えます。
 */
dd {
  margin-left: 0;
}

table {
  width: 100%;
}

th {
  text-align: left;
}

a {
  color: #000;
  transition: opacity 0.2s ease;
}

a:hover, a:active, a:focus {
  opacity: 0.8;
  text-decoration: none;
}

p {
  margin: 0;
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
}

p + p {
  margin-top: 1em;
}

/**
 * フルードイメージにします。
 */
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

/* svgのIEバグ回避 */
img[src$=".svg"] {
  width: 100%;
  height: auto;
}

code,
pre {
  font-family: Consolas, Menlo, Courier, monospace;
}

/* container
-------------------------------------------------------------------------- */
/* イージング設定
======================================================================== */
/* その他設定
======================================================================== */
/* =============================================================================
   WPエディタ用
========================================================================== */
.wp-block-image + .wp-block-image {
  margin-top: 20px !important;
}

.wp-block-image + * {
  margin-top: 28px;
}

@media (max-width: 768px) {
  .wp-block-image + * {
    margin-top: 21px;
  }
}

.wp-block-embed-facebook .fb_iframe_widget {
  width: 100%;
  max-width: 500px;
}

.wp-block-embed-facebook .fb_iframe_widget > span[style] {
  width: 100% !important;
  max-width: 500px;
}

.wp-block-embed-facebook .fb_iframe_widget iframe {
  width: 100% !important;
}

.wp-block-embed-youtube .mod-youtube {
  position: relative;
  width: 100%;
  padding-top: 61.684%;
}

.wp-block-embed-youtube .mod-youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.wp-block-embed-instagram .instagram-media {
  width: 100% !important;
  min-width: 0 !important;
}

.wp-block-embed-wordpress .wp-embedded-content {
  width: 100% !important;
}

/* =============================================================================
   bese
========================================================================== */
body {
  position: relative;
  letter-spacing: 0.02em;
}

.container {
  padding: 0 120px;
  max-width: 1440px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .container {
    padding: 0 20px;
  }
}

@media (max-width: 768px) {
  .pc {
    display: none;
  }
}

@media (min-width: 769px) {
  .sp {
    display: none;
  }
}

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  cursor: pointer;
  opacity: 0;
  transition: .3s;
}

.open .overlay {
  z-index: 1;
  opacity: 1;
}

.circle .wrap {
  position: relative;
  width: 100%;
  padding-top: 100%;
  transform: rotate(-90deg);
}

.circle svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.circle circle {
  fill: transparent;
}

table caption {
  caption-side: top;
  font-size: 18px;
  font-size: 1.125rem;
  color: #333;
  font-weight: bold;
}

table th, table td {
  border: 1px solid #ddd;
  padding: 9px 13px 8px;
  font-size: 14px;
  font-size: 0.875rem;
}

table th a, table td a {
  text-decoration: underline;
}

table th {
  text-align: center;
  font-weight: normal;
  background-color: #eee;
}

@media (max-width: 768px) {
  table caption {
    font-size: 14px;
    font-size: 0.875rem;
  }
  table th, table td {
    padding: 10px 13px 9px;
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

ul.u-asterisk {
  padding: 0 !important;
}

ul.u-asterisk li {
  position: relative;
  list-style: none !important;
  padding-left: 1em;
}

ul.u-asterisk li:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}

/* =============================================================================
    Btn
========================================================================== */
*[class*="btn-"] {
  cursor: pointer;
}

.btn-news {
  position: absolute;
  top: 60px;
  right: 120px;
  width: 19px;
  height: 11px;
  background-image: url(../img/icon_news_arrow.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: transform .3s;
}

.btn-news.active {
  transform: rotate(-180deg);
}

@media (max-width: 768px) {
  .btn-news {
    position: static;
    display: block;
    height: 10px;
    margin: 22px auto 0;
  }
}

.btn-cast {
  position: absolute;
  top: 24px;
  bottom: 0;
  right: 0;
  width: 40px;
  height: 40px;
  margin: auto 0;
  background-image: url(../img/icon_arrow.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
}

.btn-cast:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #ddd;
  border-radius: 50%;
}

.btn-cast .circle circle {
  stroke: transparent;
  stroke-width: 1;
}

@media (max-width: 600px) {
  .btn-cast {
    top: 0;
    width: 24px;
    height: 24px;
    background-size: 8px;
  }
}

.btn-close {
  position: absolute;
  top: 50.5px;
  right: 50px;
  z-index: 2;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background-color: #fff;
}

.btn-close .wrap {
  position: relative;
  width: 100%;
  height: 100%;
}

.btn-close .wrap:before, .btn-close .wrap:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 18px;
  height: 2px;
  margin: auto;
  background-color: #000;
}

.btn-close .wrap:before {
  transform: rotate(45deg);
}

.btn-close .wrap:after {
  transform: rotate(-45deg);
}

.btn-close .circle:before {
  content: '';
  display: block;
  position: absolute;
  top: .5;
  left: .5;
  right: .5;
  bottom: .5;
  width: 100%;
  height: 100%;
  border: 1px solid #ddd;
  border-radius: 50%;
}

.btn-close .circle circle {
  stroke: transparent;
  stroke-width: .5;
}

.btn-close:hover circle {
  stroke: #000;
}

.btn-close:hover svg {
  animation: circle-cast 1.5s infinite 0s linear;
}

@media (max-width: 768px) {
  .btn-close {
    top: 10px;
    right: 10px;
    width: 50px;
    height: 50px;
  }
  .btn-close .wrap:before, .btn-close .wrap:after {
    width: 12px;
    height: 1px;
  }
}

/* =============================================================================
   font-family
========================================================================== */
*[class*="ff-"] {
  font-display: swap;
}

.ff-ebg {
  font-family: "EB Garamond", serif;
}

/* =============================================================================
   common
========================================================================== */
.com-section .container {
  padding-top: 111px;
  padding-bottom: 116px;
}

@media (max-width: 768px) {
  .com-section .container {
    padding-top: 35px;
    padding-bottom: 46px;
  }
}

.com-title {
  font-size: 60px;
  font-size: 3.75rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1;
  writing-mode: tb-rl;
}

.com-title span {
  display: block;
  margin-right: 20px;
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  writing-mode: vertical-rl;
  transform: rotate(0);
}

.com-title.u-no_roll {
  writing-mode: inherit;
  -ms-writing-mode: lr-tb;
}

.com-title.u-no_roll span {
  margin-top: 19px;
  writing-mode: inherit;
  -ms-writing-mode: lr-tb;
}

@media (max-width: 768px) {
  .com-title {
    font-size: 30px;
    font-size: 1.875rem;
    writing-mode: inherit;
    -ms-writing-mode: lr-tb;
    text-align: center;
  }
  .com-title span {
    margin: 9px 0 0 0;
    font-size: 14px;
    font-size: 0.875rem;
    writing-mode: inherit;
    -ms-writing-mode: lr-tb;
  }
  .com-title.u-no_roll span {
    margin-top: 10px;
  }
}

/* =============================================================================
    Module
========================================================================== */
.mod-text * {
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
}

.mod-thumb {
  position: relative;
}

.mod-thumb > div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.mod-sns {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  margin: 0 -5px;
}

.mod-sns li {
  padding: 0 5px;
}

.mod-sns li a {
  width: 44px;
  height: 44px;
}

.mod-name span {
  display: inline-block;
  margin-right: 1em;
}

.mod-name span:last-child {
  margin-right: 0;
}

.mod-cast_name span {
  margin-right: 1em;
}

.mod-cast_name span:last-child {
  margin-right: 0;
}

.mod-staff_name > dl {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
}

.mod-staff_name dt {
  font-weight: normal;
}

.mod-staff_name dt:after {
  content: "：";
}

.mod-staff_name dd {
  margin-right: 1em;
}

.mod-staff_name dd:last-of-type {
  margin-right: 0;
}

* + .mod-staff_name {
  margin-top: 20px;
}

@media (max-width: 768px) {
  * + .mod-staff_name {
    margin-top: 14px;
  }
}

.mod-inline_content > * {
  display: inline-block;
}

.mod-inline_content > span {
  margin-right: 1em;
}

.mod-inline_content > span:last-child {
  margin-right: 0;
}

.mod-inline_content dl {
  display: -webkit-flex;
  display: flex;
}

.mod-list_nav li {
  color: #ccc;
  font-size: 46px;
  font-size: 2.875rem;
  line-height: 1;
}

.mod-list_nav li + li {
  margin-top: 19px;
}

.mod-list_nav li a {
  color: #000;
  line-height: 1;
}

@media (max-width: 768px) {
  .mod-list_nav li {
    font-size: 34px;
    font-size: 2.125rem;
  }
  .mod-list_nav li + li {
    margin-top: 14px;
  }
}

.mod-list_cast {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  width: calc(100% + 43px);
  margin: 0 -21.5px;
}

.mod-list_cast li {
  width: 33.3333%;
  padding: 0 21.5px;
}

.mod-list_cast li:nth-child(-n+4) {
  width: 50%;
}

.mod-list_cast li:nth-child(n+3) {
  margin-top: 41px;
}

.mod-list_cast li .wrap {
  cursor: pointer;
}

.mod-list_cast li .wrap:hover .btn-cast circle {
  stroke: #000;
}

.mod-list_cast li .wrap:hover .btn-cast svg {
  animation: circle-cast 1.5s infinite 0s linear;
}

.mod-list_cast li .wrap:hover .mod-thumb {
  opacity: .8;
}

.mod-list_cast li .wrap:hover .mod-thumb > div {
  transform: scale(1.1);
  transition: transform .8s 0s;
}

.mod-list_cast li .wrap:hover .name {
  opacity: .8;
}

.mod-list_cast .mod-thumb {
  padding-top: 53.85%;
  transition: opacity 0.2s ease;
}

.mod-list_cast .text {
  position: relative;
  padding: 19px 50px 0 0;
}

.mod-list_cast .name {
  font-size: 24px;
  font-size: 1.5rem;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  transition: opacity 0.2s ease;
}

.mod-list_cast .name-en {
  display: block;
  font-size: 18px;
  font-size: 1.125rem;
}

@media (max-width: 600px) {
  .mod-list_cast {
    width: 100%;
    margin: 0 auto;
  }
  .mod-list_cast li {
    width: 100%;
    padding: 0;
  }
  .mod-list_cast li:nth-child(-n+4) {
    width: 100%;
  }
  .mod-list_cast li:nth-child(n+2) {
    margin-top: 20px;
  }
  .mod-list_cast li .wrap {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
  }
  .mod-list_cast .mod-thumb {
    width: 44.7761%;
    padding-top: 23.88%;
  }
  .mod-list_cast .text {
    width: calc(100% - 44.7761%);
    padding: 0 34px 0 15px;
  }
  .mod-list_cast .name {
    font-size: 16px;
    font-size: 1rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .mod-list_cast .name-en {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

.mod-list_comment {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  margin: 60px -25px 0;
}

.mod-list_comment li {
  width: 50%;
  padding: 0 25px;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
}

.mod-list_comment li:nth-child(n+3) {
  margin-top: 46px;
}

.mod-list_comment li .wrap {
  padding: 25px 0 0 0;
  border-top: 1px solid #eee;
}

.mod-list_comment li .name {
  font-size: 20px;
  font-size: 1.25rem;
}

.mod-list_comment li .name span {
  display: block;
  margin-top: 7px;
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
}

.mod-list_comment li p {
  margin-top: 10px;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.75;
}

@media (max-width: 768px) {
  .mod-list_comment {
    margin: 30px 0 0;
  }
  .mod-list_comment li {
    width: 100%;
    padding: 0;
  }
  .mod-list_comment li:nth-child(n+2) {
    margin-top: 20px;
  }
  .mod-list_comment li .wrap {
    padding: 15px 0 0;
  }
  .mod-list_comment li .name {
    font-size: 16px;
    font-size: 1rem;
  }
  .mod-list_comment li .name span {
    margin-top: 4px;
    font-size: 12px;
    font-size: 0.75rem;
  }
  .mod-list_comment li p {
    margin-top: 8px;
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

@keyframes circle-cast {
  0% {
    stroke-dasharray: 0 126;
  }
  99.9%, to {
    stroke-dasharray: 126 126;
  }
}

.mod-link {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  color: #000;
}

.mod-link a {
  padding-right: 18px;
  background-image: url(../img/icon_arrow.svg);
  background-repeat: no-repeat;
  background-position: top 50% right 0;
  background-size: 12px;
}

@media (max-width: 768px) {
  .mod-link {
    font-size: 13px;
    font-size: 0.8125rem;
  }
  .mod-link a {
    padding-right: 14px;
    background-size: 10px;
  }
}

.mod-news {
  margin: 0;
}

.mod-news + .mod-news {
  margin-top: 12px;
}

.mod-news .wrap {
  display: -webkit-flex;
  display: flex;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.mod-news .wrap:hover {
  opacity: .8;
}

.mod-news time {
  margin-right: 1em;
}

@media (max-width: 768px) {
  .mod-news.u-hot_news {
    margin-top: 15px;
  }
  .mod-news .wrap {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.mod-content_flex {
  display: -webkit-flex;
  display: flex;
}

.mod-content_flex .mod-text {
  width: 75%;
  margin: 0 0 0 auto;
  transition-delay: .2s;
}

.mod-content_flex.u-right_title .com-title {
  order: 2;
}

.mod-content_flex.u-right_title .mod-text {
  margin: 0 auto 0 0;
}

@media (max-width: 768px) {
  .mod-content_flex {
    display: block;
  }
  .mod-content_flex .mod-text {
    width: 100%;
    margin-top: 23px;
  }
  .mod-content_flex.u-right_title .mod-text {
    margin: 23px 0 0 0;
  }
}

.mod-staff_item + .mod-staff_item {
  margin-top: 50px;
}

.mod-staff_item .article-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
}

.mod-staff_item .article-header .mod-thumb {
  width: 30%;
  padding-top: 18.555%;
}

.mod-staff_item .article-header .mod-thumb > div {
  transform: scale(1.1);
  transition: .8s 0s;
}

.mod-staff_item .article-header .text {
  width: 70%;
  padding-left: 30px;
}

.mod-staff_item .article-header .text .name {
  font-size: 24px;
  font-size: 1.5rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.mod-staff_item .article-header .text .name .position {
  font-size: 14px;
  font-size: 0.875rem;
}

.mod-staff_item .article-header .text .name-en {
  display: block;
  font-size: 18px;
  font-size: 1.125rem;
}

.mod-staff_item .article-body {
  margin-top: 35px;
}

.mod-staff_item .article-body * {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.mod-staff_item .article-body p {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.75;
}

.mod-staff_item .article-body dl {
  margin-top: 25px;
}

.mod-staff_item .article-body dl dt {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: normal;
}

.mod-staff_item .article-body dl dd {
  margin-top: 11px;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 2;
}

.mod-staff_item.u-popup .article-header .mod-thumb {
  width: 47.667%;
  padding-top: 25.667%;
}

.mod-staff_item.u-popup .article-header .text {
  width: calc(100% - 47.667%);
  padding: 0 0 0 40px;
}

.mod-staff_item.u-popup .article-header .text .name {
  font-size: 29px;
  font-size: 1.8125rem;
}

.mod-staff_item.u-popup .article-header .text .name-en {
  font-size: 21px;
  font-size: 1.3125rem;
}

.mod-staff_item.u-popup .article-body {
  margin-top: 33px;
}

.mod-staff_item.u-popup .article-body p {
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 2;
}

.mod-staff_item.u-popup .article-body dl dt {
  font-size: 21px;
  font-size: 1.3125rem;
}

.mod-staff_item.u-popup .article-body dl dd {
  font-size: 17px;
  font-size: 1.0625rem;
}

@media (max-width: 600px) {
  .mod-staff_item .article-header .mod-thumb {
    width: 44.7761%;
    padding-top: 23.88%;
  }
  .mod-staff_item .article-header .text {
    width: calc(100% - 44.7761%);
    padding: 0 34px 0 15px;
  }
  .mod-staff_item .article-header .text .name {
    font-size: 16px;
    font-size: 1rem;
  }
  .mod-staff_item .article-header .text .name .position {
    font-size: 10px;
    font-size: 0.625rem;
  }
  .mod-staff_item .article-header .text .name-en {
    font-size: 13px;
    font-size: 0.8125rem;
  }
  .mod-staff_item .article-body {
    margin-top: 16px;
  }
  .mod-staff_item .article-body * {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .mod-staff_item .article-body p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
  .mod-staff_item .article-body dl {
    margin-top: 15px;
  }
  .mod-staff_item .article-body dl dt {
    font-size: 16px;
    font-size: 1rem;
  }
  .mod-staff_item .article-body dl dd {
    margin-top: 7px;
    font-size: 14px;
    font-size: 0.875rem;
  }
  .mod-staff_item.u-popup .article-header {
    display: block;
  }
  .mod-staff_item.u-popup .article-header .mod-thumb {
    width: 100%;
    padding-top: 53.731%;
  }
  .mod-staff_item.u-popup .article-header .text {
    width: 100%;
    padding: 18px 0 0 0;
  }
  .mod-staff_item.u-popup .article-header .text .name {
    font-size: 20px;
    font-size: 1.25rem;
  }
  .mod-staff_item.u-popup .article-header .text .name-en {
    font-size: 18px;
    font-size: 1.125rem;
  }
  .mod-staff_item.u-popup .article-body {
    margin-top: 29px;
  }
  .mod-staff_item.u-popup .article-body p {
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: 1.7;
  }
  .mod-staff_item.u-popup .article-body dl dt {
    font-size: 16px;
    font-size: 1rem;
  }
  .mod-staff_item.u-popup .article-body dl dd {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.mod-popup_contents {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #fff;
  overflow: auto;
  opacity: 0;
}

.mod-popup_contents--container {
  position: relative;
  top: 50px;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 146px 140px 200px;
}

.mod-popup_contents .single-header time {
  display: block;
  font-size: 16px;
  font-size: 1rem;
}

.mod-popup_contents .single-body {
  margin-top: 33px;
}

.mod-popup_contents .single-body * {
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  word-break: break-all;
}

.mod-popup_contents .single-body p {
  line-height: 2;
  font-size: 17px;
  font-size: 1.0625rem;
}

.mod-popup_contents .single-body p + * {
  margin-top: 1em;
}

.mod-popup_contents .single-body p + h4, .mod-popup_contents .single-body p h5, .mod-popup_contents .single-body p h6 {
  margin-top: 2em;
}

.mod-popup_contents .single-body h4 {
  font-size: 26px;
  font-size: 1.625rem;
  line-height: 1.5;
}

.mod-popup_contents .single-body h5 {
  font-size: 23px;
  font-size: 1.4375rem;
  line-height: 1.5;
}

.mod-popup_contents .single-body h6 {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.5;
}

.mod-popup_contents .single-body h4 + *, .mod-popup_contents .single-body h5 + *, .mod-popup_contents .single-body h6 + * {
  margin-top: 1em;
}

.mod-popup_contents .single-body ul {
  padding-left: 1.25em;
}

.mod-popup_contents .single-body ul li {
  list-style: disc;
  font-size: 17px;
  font-size: 1.0625rem;
}

.mod-popup_contents .single-body ul + * {
  margin-top: 1em;
}

.mod-popup_contents .single-body ul + h4, .mod-popup_contents .single-body ul h5, .mod-popup_contents .single-body ul h6 {
  margin-top: 2em;
}

.mod-popup_contents .single-body table + * {
  margin-top: 1em;
}

.mod-popup_contents .single-body table + h4, .mod-popup_contents .single-body table h5, .mod-popup_contents .single-body table h6 {
  margin-top: 2em;
}

.mod-popup_contents .single-body a {
  color: #0e4bac;
  text-decoration: underline;
}

.mod-popup_contents .single-body dl dt, .mod-popup_contents .single-body dl dd {
  font-size: 17px;
  font-size: 1.0625rem;
}

.mod-popup_contents .single-body dl dt {
  font-weight: normal;
}

.mod-popup_contents .single-body dl dd + dt {
  margin-top: 1em;
}

.mod-popup_contents .single-body dl + * {
  margin-top: 1em;
}

.mod-popup_contents .single-body dl + dl {
  margin-top: 2em;
}

.mod-popup_contents .single-body dl + h4, .mod-popup_contents .single-body dl h5, .mod-popup_contents .single-body dl h6 {
  margin-top: 2em;
}

.mod-popup_contents .single-title {
  margin-top: 4px;
  font-size: 29px;
  font-size: 1.8125rem;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .mod-popup_contents--container {
    padding: 87px 20px 50px;
  }
  .mod-popup_contents .single-header time {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .mod-popup_contents .single-body {
    margin-top: 25px;
  }
  .mod-popup_contents .single-body p {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .mod-popup_contents .single-body h4 {
    font-size: 17px;
    font-size: 1.0625rem;
  }
  .mod-popup_contents .single-body h5 {
    font-size: 16px;
    font-size: 1rem;
  }
  .mod-popup_contents .single-body h6 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
  .mod-popup_contents .single-body ul li {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .mod-popup_contents .single-body dl dt, .mod-popup_contents .single-body dl dd {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .mod-popup_contents .single-title {
    margin-top: 2px;
    font-size: 18px;
    font-size: 1.125rem;
  }
}

.mod-scroll_wrap {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 768px) {
  .mod-scroll_wrap table {
    min-width: 728px;
  }
  .mod-scroll_wrap table th {
    white-space: nowrap;
    word-break: keep-all;
  }
}

.mod-slider {
  position: relative;
  width: 100%;
  padding-top: 26.944%;
}

.mod-slider ul {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media (max-width: 768px) {
  .mod-slider {
    padding-top: 42.933%;
  }
}

/* =============================================================================
   header
========================================================================== */
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
}

.l-header .mod-link {
  margin-top: 37px;
}

.l-header .mod-sns {
  margin-top: 47px;
}

@media (max-width: 768px) {
  .l-header .mod-link {
    margin-top: 33px;
  }
  .l-header .mod-sns {
    margin-top: 32px;
  }
}

.g-nav {
  position: fixed;
  top: 0;
  left: -100%;
  height: 100%;
  padding: 163px 120px 50px;
  background-color: #fff;
  overflow: auto;
  transition: left .5s;
}

@media (max-width: 768px) {
  .g-nav {
    padding: 85px 50px 50px;
  }
}

.nav-btn {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 3;
  width: 80px;
  height: 80px;
  background-color: #000;
}

.nav-btn .wrap {
  position: relative;
  width: 35px;
  height: 23px;
  overflow: hidden;
}

.nav-btn .wrap span {
  position: absolute;
  left: 0;
  display: block;
  width: 100%;
  height: 3px;
  background-color: #fff;
}

.nav-btn .wrap span:first-child {
  top: 0;
  width: 62.857%;
}

.nav-btn .wrap span:nth-child(2) {
  top: 50%;
  margin-top: -1.5px;
}

.nav-btn .wrap span:last-child {
  bottom: 0;
  width: 62.857%;
}

.nav-btn:hover .wrap span:first-child {
  animation: open-line .2s 0s linear;
}

.nav-btn:hover .wrap span:nth-child(2) {
  animation: open-line .2s .05s linear;
}

.nav-btn:hover .wrap span:last-child {
  animation: open-line .2s .1s linear;
}

@media (max-width: 768px) {
  .nav-btn {
    width: 50px;
    height: 50px;
  }
  .nav-btn .wrap {
    width: 22px;
    height: 14px;
  }
  .nav-btn .wrap span {
    height: 2px;
  }
}

.open .g-nav {
  left: 0;
}

.open .nav-btn .wrap {
  width: 41px;
  height: 41px;
  transform: rotate(135deg);
  transition: transform .3s;
}

.open .nav-btn .wrap span {
  transition: transform .3s;
}

.open .nav-btn .wrap span:first-child {
  display: none;
}

.open .nav-btn .wrap span:last-child {
  bottom: 50%;
  width: 100%;
  transform: rotate(-90deg);
}

@media (max-width: 768px) {
  .open .nav-btn .wrap {
    width: 25px;
    height: 25px;
  }
}

.open .nav-btn:hover .wrap span:nth-child(2) {
  animation: open-line .2s 0s linear;
}

.open .nav-btn:hover .wrap span:last-child {
  animation: close-line .2s .2s linear;
}

@keyframes open-line {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0px);
  }
}

@keyframes close-line {
  0% {
    transform: rotate(-90deg) translateX(-100%);
  }
  100% {
    transform: rotate(-90deg) translateX(0px);
  }
}

/* =============================================================================
   footer
========================================================================== */
.l-footer {
  background-color: #000;
  color: #fff;
  font-size: 14px;
  font-size: 0.875rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.l-footer .footer-inner {
  padding: 100px 70px 96px;
}

.l-footer .site-name {
  width: 100%;
  max-width: 277px;
  margin: 0 auto;
}

.l-footer .mod-sns {
  -webkit-justify-content: center;
  justify-content: center;
  margin: 30px -7px 0;
}

.l-footer .mod-sns li {
  padding: 0 7px;
}

.l-footer .date {
  margin: 25px 0 0;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
}

.l-footer .mod-cast_name {
  margin-top: 52px;
}

.l-footer .mod-staff_name dl {
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
}

@media (max-width: 768px) {
  .l-footer .footer-inner {
    padding: 75px 30px 75px;
  }
  .l-footer .site-name {
    max-width: 190px;
  }
  .l-footer .mod-sns {
    margin-top: 24px;
  }
  .l-footer .date {
    margin-top: 19px;
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 1.6;
  }
  .l-footer .mod-cast_name, .l-footer .mod-staff_name, .l-footer .copy {
    font-size: 11px;
    font-size: 0.6875rem;
    line-height: 1.7;
  }
  .l-footer .mod-cast_name {
    margin-top: 38px;
  }
}

/* =============================================================================
   main
========================================================================== */
body.fixed {
  position: fixed;
  top: 0;
  left: 0;
}

.kv {
  position: relative;
  width: 100%;
  padding-top: 53.8194%;
  overflow: hidden;
}

.kv-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
}

.kv-bg ul {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  height: 100%;
}

.kv-img {
  position: relative;
  width: 50%;
  height: 50%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 130%;
  overflow: hidden;
  transition: 2s 0.2s cubic-bezier(0.19, 1, 0.22, 1);
}

.kv-img:first-child {
  background-image: url(../img/bg_kv01.jpg);
}

.kv-img:nth-child(2) {
  background-image: url(../img/bg_kv02.jpg);
}

.kv-img:nth-child(3) {
  background-image: url(../img/bg_kv03.jpg);
}

.kv-img:last-child {
  background-image: url(../img/bg_kv04.jpg);
}

.kv-img:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  transition: 1s 0.1s cubic-bezier(0.19, 1, 0.22, 1);
  transform-origin: 0 0;
}

.kv-img:nth-child(1):before, .kv-img:nth-child(4):before {
  transition-delay: .2s;
}

.kv .container {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 100%;
  height: 100%;
}

.kv-main {
  width: 100%;
  margin-top: 8.75vw;
  font-weight: bold;
  text-align: center;
}

.kv-main .director {
  color: #fff;
  font-size: 20px;
  font-size: 1.3888888889vw;
  transform: translateY(30px);
  transition: 0.5s cubic-bezier(0.175, 0.39, 0.245, 1.01);
  transition-delay: .1s;
  opacity: 0;
}

.kv-main .director span + span {
  margin-left: 1em;
}

.kv-main .release {
  font-size: 25px;
  font-size: 1.7361111111vw;
  transform: translateY(30px);
  transition: 0.5s cubic-bezier(0.175, 0.39, 0.245, 1.01);
  transition-delay: .1s;
  opacity: 0;
}

.kv-main .release > span {
  background-color: #fff;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  line-height: 1em;
}

.kv-main .release > span + span {
  padding-left: .5em;
}

.kv-main .release01 {
  margin-top: 5.416vw;
}

.kv-main .release02 {
  margin-top: .3472vw;
}

.kv .slogan {
  position: absolute;
  transform: translateY(30px);
  transition: 0.5s cubic-bezier(0.175, 0.39, 0.245, 1.01);
  transition-delay: .1s;
  opacity: 0;
}

.kv .slogan01 {
  top: 13.14583vw;
  right: 6vw;
}

.kv .slogan01 img {
  width: 3.64166vw;
}

.kv .slogan02 {
  top: 15.3472vw;
  left: 6vw;
}

.kv .slogan02 img {
  width: 3.6473vw;
}

@media (max-width: 768px) {
  .kv {
    padding-top: 114.133%;
  }
  .kv-img:first-child {
    background-image: url(../img/bg_kv01_sp.jpg);
  }
  .kv-img:nth-child(2) {
    background-image: url(../img/bg_kv02_sp.jpg);
  }
  .kv-img:nth-child(3) {
    background-image: url(../img/bg_kv03_sp.jpg);
  }
  .kv-img:last-child {
    background-image: url(../img/bg_kv04_sp.jpg);
  }
  .kv-main {
    margin-top: 9.06vw;
  }
  .kv-main .director {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 12px;
    font-size: 3.2vw;
  }
  .kv-main .director span {
    display: block;
  }
  .kv-main .director span + span {
    margin: 0;
  }
  .kv-main .release {
    font-size: 12px;
    font-size: 3.2vw;
  }
  .kv-main .release > span {
    line-height: 1em;
  }
  .kv-main .release01 {
    margin-top: 10.66vw;
  }
  .kv-main .release01 > span + span {
    padding-left: 0;
  }
  .kv-main .release01 > span:nth-child(2) {
    background-color: transparent;
    display: block;
    margin-top: 2.6vw;
  }
  .kv-main .release01 > span:nth-child(2) > span {
    background-color: #fff;
  }
  .kv-main .release02 {
    margin-top: 2.6vw;
  }
  .kv .slogan01 {
    top: 35.413vw;
    right: 4.72vw;
  }
  .kv .slogan01 img {
    width: 5.7013vw;
  }
  .kv .slogan02 {
    top: 38.693vw;
    left: 4.4vw;
  }
  .kv .slogan02 img {
    width: 5.712vw;
  }
}

.site-title {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  flex-wrap: wrap;
  line-height: 1;
  margin: 2.5vw 0 0 0;
}

.site-title span {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  overflow: hidden;
  line-height: 1;
}

.site-title span img {
  width: auto;
  height: 7.10625vw;
  transform: translateY(110%);
  transition: transform .2s;
}

.site-title span:first-of-type {
  margin-right: 3.333vw;
}

.site-title span:first-of-type img:nth-child(2) {
  transition-delay: .1s;
}

.site-title span:first-of-type img:nth-child(3) {
  transition-delay: .15s;
}

.site-title span:first-of-type img:nth-child(4) {
  transition-delay: .2s;
}

.site-title span:first-of-type img:nth-child(5) {
  transition-delay: .25s;
}

.site-title span:last-of-type img:first-of-type {
  transition-delay: .3s;
}

.site-title span:last-of-type img:nth-child(2) {
  transition-delay: .35s;
}

.site-title span:last-of-type img:nth-child(3) {
  transition-delay: .4s;
}

.site-title span:last-of-type img:nth-child(4) {
  transition-delay: .45s;
}

.site-title span:last-of-type img:nth-child(5) {
  transition-delay: .5s;
}

.site-title span:last-of-type img:nth-child(6) {
  transition-delay: .55s;
}

.site-title span:last-of-type img:nth-child(7) {
  transition-delay: .6s;
}

.site-title span:last-of-type img:nth-child(8) {
  transition-delay: .65s;
}

.site-title span:last-of-type img:nth-child(9) {
  transition-delay: .7s;
}

.site-title [alt="T"] + [alt="O"] {
  margin-left: 0.868vw;
}

.site-title [alt="T"] + [alt="T"] {
  margin-left: 0.5694vw;
}

.site-title [alt="T"] + [alt="E"] {
  margin-left: 0.8888vw;
}

.site-title [alt="O"] {
  height: 7.4048vw;
}

.site-title [alt="O"] + [alt="K"] {
  margin-left: 1.10416vw;
}

.site-title [alt="K"] + [alt="Y"] {
  margin-left: 0.576388vw;
}

.site-title [alt="Y"] + [alt="O"] {
  margin-left: 0.71527vw;
}

.site-title [alt="B"] + [alt="U"] {
  margin-left: 1.10416vw;
}

.site-title [alt="U"] + [alt="T"] {
  margin-left: 0.86805vw;
}

.site-title [alt="E"] + [alt="R"] {
  margin-left: 1vw;
}

.site-title [alt="R"] + [alt="F"] {
  margin-left: 1.1805vw;
}

.site-title [alt="F"] + [alt="L"] {
  margin-left: 0.916vw;
}

.site-title [alt="L"] + [alt="Y"] {
  margin-left: -0.0694vw;
}

.site-title .jp-title {
  width: 100%;
  margin-top: 2.083vw;
  transform: translateY(30px);
  transition: 0.5s cubic-bezier(0.175, 0.39, 0.245, 1.01);
  transition-delay: .1s;
  opacity: 0;
}

.site-title .jp-title img {
  width: 24.55416vw;
}

@media (max-width: 768px) {
  .site-title {
    display: block;
    margin: 3.9vw 0 0 0;
  }
  .site-title span {
    -webkit-justify-content: center;
    justify-content: center;
  }
  .site-title span:first-of-type {
    margin: 0;
  }
  .site-title span + span {
    margin-top: 3.573vw;
  }
  .site-title span img {
    height: 11.8586vw;
  }
  .site-title [alt="T"] + [alt="O"] {
    margin-left: 1.44vw;
  }
  .site-title [alt="T"] + [alt="T"] {
    margin-left: 0.96vw;
  }
  .site-title [alt="T"] + [alt="E"] {
    margin-left: 1.493vw;
  }
  .site-title [alt="O"] {
    height: 12.3573vw;
  }
  .site-title [alt="O"] + [alt="K"] {
    margin-left: 1.84vw;
  }
  .site-title [alt="K"] + [alt="Y"] {
    margin-left: 0.96vw;
  }
  .site-title [alt="Y"] + [alt="O"] {
    margin-left: 1.253vw;
  }
  .site-title [alt="B"] + [alt="U"] {
    margin-left: 1.84vw;
  }
  .site-title [alt="U"] + [alt="T"] {
    margin-left: 1.44vw;
  }
  .site-title [alt="E"] + [alt="R"] {
    margin-left: 1.653vw;
  }
  .site-title [alt="R"] + [alt="F"] {
    margin-left: 1.973vw;
  }
  .site-title [alt="F"] + [alt="L"] {
    margin-left: 1.52vw;
  }
  .site-title [alt="L"] + [alt="Y"] {
    margin-left: -0.26vw;
  }
  .site-title .jp-title {
    height: 4.8vw;
    margin-top: 4.773vw;
  }
  .site-title .jp-title img {
    width: 40.9786vw;
    vertical-align: top;
  }
}

/* =============================================================================
   news
========================================================================== */
#news .container {
  position: relative;
  padding-top: 53px;
  padding-bottom: 55px;
}

#news .com-title {
  position: absolute;
  top: 54px;
  font-size: 24px;
  font-size: 1.5rem;
  writing-mode: inherit;
  -ms-writing-mode: lr-tb;
}

#news .mod-news {
  margin-left: 131px;
  margin-right: 100px;
}

@media (max-width: 768px) {
  #news .container {
    padding-top: 23px;
    padding-bottom: 30px;
  }
  #news .com-title {
    position: static;
    font-size: 20px;
    font-size: 1.25rem;
  }
  #news .mod-news {
    margin-left: 0;
    margin-right: 0;
  }
}

.hide-news_list {
  display: none;
  padding-top: 12px;
}

/* =============================================================================
   trailer
========================================================================== */
#trailer {
  position: relative;
  padding-top: 27.01388%;
  overflow: hidden;
}

#trailer:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../img/bg_trailer.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

#trailer .container {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 100%;
  max-width: inherit;
  height: 100%;
}

@media (max-width: 768px) {
  #trailer {
    padding-top: 53.3vw;
  }
  #trailer:before {
    background-image: url(../img/bg_trailer_sp.jpg);
  }
}

#play {
  position: relative;
  display: block;
  width: 10.41666vw;
  height: 10.41666vw;
}

#play .play-icon {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 7.63888vw;
  height: 7.63888vw;
}

#play .text {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  transition: .3s;
}

#play .text img {
  animation: roll 10s infinite 0s linear;
}

#play .circle {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 7.63888vw;
  height: 7.63888vw;
  margin: auto;
}

#play .circle circle {
  stroke: #fff;
  stroke-width: 2;
}

@media (max-width: 768px) {
  #play .circle {
    width: 18.933vw;
    height: 18.933vw;
  }
}

#play:hover .text {
  transform: scale(1.1);
  transition: .3s;
}

#play:hover .circle circle {
  animation: circle 1.5s infinite 0s linear;
}

@media (max-width: 768px) {
  #play {
    width: 25.8666vw;
    height: 25.8666vw;
  }
  #play .play-icon {
    width: 18.933vw;
    height: 18.933vw;
  }
}

@keyframes circle {
  0% {
    stroke-dasharray: 0 346;
  }
  99.9%, to {
    stroke-dasharray: 346 346;
  }
}

@keyframes roll {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* =============================================================================
   intro
========================================================================== */
#intro .mod-text p {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 2;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#intro .mod-text p + p {
  margin-top: 2em;
}

@media (max-width: 768px) {
  #intro .mod-text p {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

/* =============================================================================
   story
========================================================================== */
#story .mod-text p {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 2;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#story .mod-text p + p {
  margin-top: 2em;
}

@media (max-width: 768px) {
  #story .mod-text p {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

/* =============================================================================
   cast
========================================================================== */
#cast .container {
  padding-top: 150px;
  padding-bottom: 100px;
}

@media (max-width: 991px) {
  #cast .container {
    padding-top: 90px;
    padding-bottom: 80px;
  }
  #cast .mod-content_flex {
    display: block;
  }
  #cast .com-title {
    writing-mode: inherit;
    -ms-writing-mode: lr-tb;
  }
  #cast .com-title span {
    writing-mode: inherit;
    -ms-writing-mode: lr-tb;
  }
  #cast .mod-text {
    width: 100%;
    margin: 30px 0 0 0;
  }
}

@media (max-width: 768px) {
  #cast .container {
    padding-top: 45px;
    padding-bottom: 0;
  }
}

/* =============================================================================
   staff
========================================================================== */
#staff .container {
  padding-top: 22px;
  padding-bottom: 149px;
}

@media (max-width: 768px) {
  #staff .container {
    padding-top: 45px;
    padding-bottom: 46px;
  }
  #staff .mod-text {
    margin-top: 30px;
  }
}

/* =============================================================================
   video
========================================================================== */
#video {
  position: fixed;
  top: 0;
  bottom: 0;
  z-index: 100;
  width: 100%;
}

#video-container {
  position: relative;
  height: 100%;
  padding-top: 56.25%;
  overflow: hidden;
}

#player {
  position: fixed;
  height: 56.25vw;
  bottom: 0;
  margin: auto;
  top: 0;
  left: 0;
  width: 100%;
}

#overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  background-color: #000;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

#close {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 101;
  width: 75px;
  height: 75px;
  background-color: #fff;
  cursor: pointer;
}

#close .wrap {
  position: relative;
}

#close .wrap:before, #close .wrap:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: block;
  content: "";
  width: 30px;
  height: 5px;
  margin: auto;
  background-color: #000;
}

#close .wrap:before {
  transform: rotate(45deg);
}

#close .wrap:after {
  transform: rotate(-45deg);
}

@media (max-width: 768px) {
  #close {
    width: 40px;
    height: 40px;
  }
  #close .wrap:before, #close .wrap:after {
    content: "";
    width: 20px;
    height: 3px;
  }
}

body.Safari #video-container,
body.iphone #video-container {
  height: 0;
  overflow: inherit;
  -webkit-overflow-scrolling: touch;
}

/* =============================================================================
   comment
================================================================ */
.comment-before {
  width: 100%;
  padding-top: 13.472%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(../img/bg_comment_before.jpg);
}

@media (max-width: 768px) {
  .comment-before {
    padding-top: 26.667%;
    background-image: url(../img/bg_comment_before_sp.jpg);
  }
}

#comment .container {
  padding-top: 159px;
}

@media (max-width: 768px) {
  #comment .container {
    padding-top: 45px;
  }
}

/* =============================================================================
   Theater
========================================================================= */
#theater .contents {
  margin-top: 60px;
}

#theater p {
  margin-top: 5px;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 2;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#theater .theater-table {
  margin-top: 10px;
}

#theater .theater-table tbody td:first-of-type {
  text-align: center;
}

#theater .theater-table tbody td.tel {
  white-space: nowrap;
  word-break: keep-all;
}

@media (max-width: 768px) {
  #theater .container {
    padding-top: 45px;
  }
  #theater .contents {
    margin-top: 30px;
  }
  #theater p {
    font-size: 12px;
    font-size: 0.75rem;
    text-align: center;
  }
}

/* =============================================================================
   js
========================================================================== */
.js-fade {
  transform: translateY(30px);
  transition: 0.5s cubic-bezier(0.175, 0.39, 0.245, 1.01);
  transition-delay: .1s;
  opacity: 0;
}

.js-fade.in {
  transform: translateY(0) !important;
  opacity: 1 !important;
}

.js-list_fade li {
  transform: translateY(10px);
  transition: 0.5s cubic-bezier(0.59, 0.42, 0.62, 1.02);
  transition-delay: .1s;
  opacity: 0;
}

.js-list_fade li.in {
  transform: translateY(0);
  opacity: 1;
}

.js-kv.in .kv-img {
  background-size: 100% !important;
}

.js-kv.in .kv-img:before {
  transform: scaleX(0) !important;
}

.js-kv.in .site-title span img {
  transform: translateY(0) !important;
}

.js-bg:before {
  opacity: 0;
  transition: .8s .2s;
  transform: scale(1.2);
}

.js-bg.in:before {
  opacity: 1;
  transform: scale(1);
}

.js-zoom {
  overflow: hidden;
}

.js-zoom > * {
  opacity: 0;
  transform: scale(1.2);
  transition: .8s;
}

.js-zoom.in > * {
  opacity: 1 !important;
  transform: scale(1) !important;
}

/* utility
 -------------------------------------------------------------------------- */
.u-sp-visible-pc-hide {
  display: none !important;
}

@media (max-width: 767px) {
  .u-sp-visible-pc-hide {
    display: block !important;
  }
}

.u-pc-visible-sp-hide {
  display: block !important;
}

@media (max-width: 767px) {
  .u-pc-visible-sp-hide {
    display: none !important;
  }
}

.u-tab-visible-pc-hide {
  display: none !important;
}

@media (max-width: 991px) {
  .u-tab-visible-pc-hide {
    display: block !important;
  }
}

.u-pc-visible-tab-hide {
  display: block !important;
}

@media (max-width: 991px) {
  .u-pc-visible-tab-hide {
    display: none !important;
  }
}

/* -----------------------------------------------------------------------------
   #Text
   -------------------------------------------------------------------------- */
/*doc
---
title: text
name: text
categories: [utility]
---

テキストのスタイルを指定する汎用クラスです。

```block
<p class="u-text-light">font-weight 300</p>
<p class="u-text-normal">font-weight 400</p>
<p class="u-text-bold">font-weight 600</p>
<p class="u-text-indent">先頭の1文字目を1文字分字下げします。</p>
<p class="u-text-note">2行目以降の1文字目を1文字分字下げします。<br>2行目以降の1文字目を1文字分字下げします。</p>
<p class="u-text-nowrap">テキストを折り返させません。横幅を超えても、このテキストは折り返さずに表示されます。</p>
<p class="u-text-breakword">テキストを折り返させます。長文になっても、このテキストは必ず折り返して表示されます。</p>
<p class="u-text-justify">テキストを両端揃え（均等割り付け）させます。通常のテキストと文字間が違うのが分かると思います。</p>
<p class="u-text-none">記述した通りに表示します。</p>
<p class="u-text-lowercase">abcdEFGH すべての英単語を小文字で表示します。</p>
<p class="u-text-uppercase">abcdEFGH すべての英単語を大文字で表示します。</p>
<p class="u-text-capitalize">abcdEFGH 英単語の先頭を大文字で表示します。</p>
<p class="u-text-smallcaps">abcdEFGH スモールキャップ（小文字と同じ高さで作られた大文字）で表示します。</p>
<p class="u-text-vertical">abcdEFGH 縦書きで表示します。</p>
<p class="u-text-vertical u-text-vertical--upright">abcdEFGH 英文も縦書きにする場合はModifierを指定します。</p>
<p class="u-text-right">text-align right</p>
<p class="u-text-center">text-align center</p>
<p class="u-text-left">text-align left</p>
<p class="u-text-top">vertical-align top</p>
<p class="u-text-middle">vertical-align middle</p>
<p class="u-text-bottom">vertical-align bottom</p>
```
*/
/* font-colorを指定します。 */
.u-text-color--white {
  color: #fff !important;
}

.u-text-color--blk {
  color: #000 !important;
}

/* 文字に余白付きの下線を引きます */
.u-text-underline {
  padding-bottom: 3px;
  border-bottom: 1px solid #000;
}

/* font-weightを指定します。 */
.u-text-light {
  font-weight: 300 !important;
}

.u-text-normal {
  font-weight: 500 !important;
}

.u-text-bold {
  font-weight: 600 !important;
}

/* 先頭の1文字目を1文字分字下げします。 */
.u-text-indent {
  text-indent: 1em !important;
}

/* 2行目以降の1文字目を1文字分字下げします。 */
.u-text-note {
  margin-left: 1em !important;
  text-indent: -1em !important;
}

/* テキストを改行させません。 */
.u-text-nowrap {
  white-space: nowrap !important;
}

/* テキストを改行させます。 */
.u-text-breakword {
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

/* テキストを両端揃えさせます。 */
.u-text-justify {
  text-align: justify !important;
  text-justify: inter-ideograph !important;
}

/* 記述した通りに表示します。 */
.u-text-none {
  text-transform: none !important;
}

/* すべての英単語を小文字にします。 */
.u-text-lowercase {
  text-transform: lowercase !important;
}

/* すべての英単語を大文字にします。 */
.u-text-uppercase {
  text-transform: uppercase !important;
}

/* 英単語の先頭を大文字にします。 */
.u-text-capitalize {
  text-transform: capitalize !important;
}

/* スモールキャップ（小文字と同じ高さで作られた大文字）にします。 */
.u-text-smallcaps {
  font-variant: small-caps !important;
}

/* 縦書きにします。 */
.u-text-vertical {
  writing-mode: vertical-rl !important;
  text-orientation: mixed !important;
}

/* 英文も縦書きにする場合はModifierを指定します。 */
.u-text-vertical--upright {
  text-orientation: upright !important;
}

.u-text-right {
  text-align: right !important;
}

.u-text-center {
  text-align: center !important;
}

.u-text-left {
  text-align: left !important;
}

.u-text-top {
  vertical-align: top !important;
}

.u-text-middle {
  vertical-align: middle !important;
}

.u-text-bottom {
  vertical-align: bottom !important;
}
