@charset "UTF-8";
/* --------------------------
	フォントの設定
-------------------------- */
/* --------------------------
	レスポンシブ関連
-------------------------- */
/* --------------------------
	レスポンシブ関係
-------------------------- */
@media screen and (max-width: 1024px) {
  .is-pc {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .is-tab {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .is-tab {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .is-sp {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .is-pc-tab {
    display: none;
  }
}

@media screen and (min-width: 1025px) {
  .is-tab-sp {
    display: none;
  }
}

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

.u-txt-xsmall {
  font-size: 1.2rem;
}
@media screen and (max-width: 767px) {
  .u-txt-xsmall {
    font-size: 1rem !important;
  }
}

.u-txt-small {
  font-size: 1.4rem !important;
}
@media screen and (max-width: 767px) {
  .u-txt-small {
    font-size: 1.2rem !important;
  }
}

.u-txt-medium {
  font-size: 1.8rem !important;
}
@media screen and (max-width: 767px) {
  .u-txt-medium {
    font-size: 1.4rem !important;
  }
}

.u-txt-large {
  font-size: 2rem !important;
}
@media screen and (max-width: 767px) {
  .u-txt-large {
    font-size: 1.6rem !important;
  }
}

.u-link {
  color: #333;
  text-decoration: underline;
}
.u-link:hover {
  text-decoration: none;
}

.u-ul-default {
  margin: 1em 0;
  padding-left: 40px;
  list-style-type: disc;
}
.u-ul-default li {
  list-style: inherit;
}

.u-ol-default {
  margin: 1em 0;
  padding-left: 40px;
  list-style-type: decimal;
}
.u-ol-default li {
  list-style: inherit;
}

.u-ul-style > li {
  position: relative;
  padding-left: 1.3em;
}
.u-ul-style > li::before {
  content: "・";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
}
.u-ul-style--asterisk > li::before {
  content: "※";
}
.u-ul-style--disc > li::before {
  content: "●";
  color: #ccc;
}
.u-ul-style--disc-red > li::before {
  content: "●";
  color: #333;
}
.u-ul-style--number > li {
  counter-increment: number;
}
.u-ul-style--number > li::before {
  content: counter(number) ".";
}
.u-ul-style--number-red > li {
  counter-increment: number;
}
.u-ul-style--number-red > li::before {
  content: counter(number) ".";
  color: #333;
}

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

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

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

@media screen and (max-width: 1024px) {
  .u-align-l-tab {
    text-align: left !important;
  }
  .u-align-c-tab {
    text-align: center !important;
  }
  .u-align-r-tab {
    text-align: right !important;
  }
}
@media screen and (max-width: 767px) {
  .u-align-l-sp {
    text-align: left !important;
  }
  .u-align-c-sp {
    text-align: center !important;
  }
  .u-align-r-sp {
    text-align: right !important;
  }
}
.u-iframe-responsive {
  position: relative;
  height: 0;
  width: 100%;
  padding-top: 56.25%;
}
.u-iframe-responsive iframe,
.u-iframe-responsive video {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

/* --------------------------
	padding margin 調整用
-------------------------- */
.u-mt-s {
  margin-top: 2rem !important;
}
@media screen and (max-width: 767px) {
  .u-mt-s {
    margin-top: 1rem !important;
  }
}

.u-mt-m {
  margin-top: 4rem !important;
}
@media screen and (max-width: 767px) {
  .u-mt-m {
    margin-top: 2rem !important;
  }
}

.u-mt-l {
  margin-top: 6rem !important;
}
@media screen and (max-width: 767px) {
  .u-mt-l {
    margin-top: 3rem !important;
  }
}

.u-mt-xl {
  margin-top: 8rem !important;
}
@media screen and (max-width: 767px) {
  .u-mt-xl {
    margin-top: 4rem !important;
  }
}

.u-mb-s {
  margin-bottom: 2rem !important;
}
@media screen and (max-width: 767px) {
  .u-mb-s {
    margin-bottom: 1rem !important;
  }
}

.u-mb-m {
  margin-bottom: 4rem !important;
}
@media screen and (max-width: 767px) {
  .u-mb-m {
    margin-bottom: 2rem !important;
  }
}

.u-mb-l {
  margin-bottom: 6rem !important;
}
@media screen and (max-width: 767px) {
  .u-mb-l {
    margin-bottom: 3rem !important;
  }
}

.u-mb-xl {
  margin-bottom: 8rem !important;
}
@media screen and (max-width: 767px) {
  .u-mb-xl {
    margin-bottom: 4rem !important;
  }
}

.u-mt120 {
  margin-top: 12rem !important;
}

.u-mb120 {
  margin-bottom: 12rem !important;
}

.u-ml120 {
  margin-left: 12rem !important;
}

.u-mr120 {
  margin-right: 12rem !important;
}

.u-pt120 {
  padding-top: 12rem !important;
}

.u-pb120 {
  padding-bottom: 12rem !important;
}

.u-pl120 {
  padding-left: 12rem !important;
}

.u-pr120 {
  padding-right: 12rem !important;
}

.u-mt110 {
  margin-top: 11rem !important;
}

.u-mb110 {
  margin-bottom: 11rem !important;
}

.u-ml110 {
  margin-left: 11rem !important;
}

.u-mr110 {
  margin-right: 11rem !important;
}

.u-pt110 {
  padding-top: 11rem !important;
}

.u-pb110 {
  padding-bottom: 11rem !important;
}

.u-pl110 {
  padding-left: 11rem !important;
}

.u-pr110 {
  padding-right: 11rem !important;
}

.u-mt100 {
  margin-top: 10rem !important;
}

.u-mb100 {
  margin-bottom: 10rem !important;
}

.u-ml100 {
  margin-left: 10rem !important;
}

.u-mr100 {
  margin-right: 10rem !important;
}

.u-pt100 {
  padding-top: 10rem !important;
}

.u-pb100 {
  padding-bottom: 10rem !important;
}

.u-pl100 {
  padding-left: 10rem !important;
}

.u-pr100 {
  padding-right: 10rem !important;
}

.u-mt90 {
  margin-top: 9rem !important;
}

.u-mb90 {
  margin-bottom: 9rem !important;
}

.u-ml90 {
  margin-left: 9rem !important;
}

.u-mr90 {
  margin-right: 9rem !important;
}

.u-pt90 {
  padding-top: 9rem !important;
}

.u-pb90 {
  padding-bottom: 9rem !important;
}

.u-pl90 {
  padding-left: 9rem !important;
}

.u-pr90 {
  padding-right: 9rem !important;
}

.u-mt80 {
  margin-top: 8rem !important;
}

.u-mb80 {
  margin-bottom: 8rem !important;
}

.u-ml80 {
  margin-left: 8rem !important;
}

.u-mr80 {
  margin-right: 8rem !important;
}

.u-pt80 {
  padding-top: 8rem !important;
}

.u-pb80 {
  padding-bottom: 8rem !important;
}

.u-pl80 {
  padding-left: 8rem !important;
}

.u-pr80 {
  padding-right: 8rem !important;
}

.u-mt75 {
  margin-top: 7.5rem !important;
}

.u-mb75 {
  margin-bottom: 7.5rem !important;
}

.u-ml75 {
  margin-left: 7.5rem !important;
}

.u-mr75 {
  margin-right: 7.5rem !important;
}

.u-pt75 {
  padding-top: 7.5rem !important;
}

.u-pb75 {
  padding-bottom: 7.5rem !important;
}

.u-pl75 {
  padding-left: 7.5rem !important;
}

.u-pr75 {
  padding-right: 7.5rem !important;
}

.u-mt70 {
  margin-top: 7rem !important;
}

.u-mb70 {
  margin-bottom: 7rem !important;
}

.u-ml70 {
  margin-left: 7rem !important;
}

.u-mr70 {
  margin-right: 7rem !important;
}

.u-pt70 {
  padding-top: 7rem !important;
}

.u-pb70 {
  padding-bottom: 7rem !important;
}

.u-pl70 {
  padding-left: 7rem !important;
}

.u-pr70 {
  padding-right: 7rem !important;
}

.u-mt65 {
  margin-top: 6.5rem !important;
}

.u-mb65 {
  margin-bottom: 6.5rem !important;
}

.u-ml65 {
  margin-left: 6.5rem !important;
}

.u-mr65 {
  margin-right: 6.5rem !important;
}

.u-pt65 {
  padding-top: 6.5rem !important;
}

.u-pb65 {
  padding-bottom: 6.5rem !important;
}

.u-pl65 {
  padding-left: 6.5rem !important;
}

.u-pr65 {
  padding-right: 6.5rem !important;
}

.u-mt60 {
  margin-top: 6rem !important;
}

.u-mb60 {
  margin-bottom: 6rem !important;
}

.u-ml60 {
  margin-left: 6rem !important;
}

.u-mr60 {
  margin-right: 6rem !important;
}

.u-pt60 {
  padding-top: 6rem !important;
}

.u-pb60 {
  padding-bottom: 6rem !important;
}

.u-pl60 {
  padding-left: 6rem !important;
}

.u-pr60 {
  padding-right: 6rem !important;
}

.u-mt55 {
  margin-top: 5.5rem !important;
}

.u-mb55 {
  margin-bottom: 5.5rem !important;
}

.u-ml55 {
  margin-left: 5.5rem !important;
}

.u-mr55 {
  margin-right: 5.5rem !important;
}

.u-pt55 {
  padding-top: 5.5rem !important;
}

.u-pb55 {
  padding-bottom: 5.5rem !important;
}

.u-pl55 {
  padding-left: 5.5rem !important;
}

.u-pr55 {
  padding-right: 5.5rem !important;
}

.u-mt50 {
  margin-top: 5rem !important;
}

.u-mb50 {
  margin-bottom: 5rem !important;
}

.u-ml50 {
  margin-left: 5rem !important;
}

.u-mr50 {
  margin-right: 5rem !important;
}

.u-pt50 {
  padding-top: 5rem !important;
}

.u-pb50 {
  padding-bottom: 5rem !important;
}

.u-pl50 {
  padding-left: 5rem !important;
}

.u-pr50 {
  padding-right: 5rem !important;
}

.u-mt45 {
  margin-top: 4.5rem !important;
}

.u-mb45 {
  margin-bottom: 4.5rem !important;
}

.u-ml45 {
  margin-left: 4.5rem !important;
}

.u-mr45 {
  margin-right: 4.5rem !important;
}

.u-pt45 {
  padding-top: 4.5rem !important;
}

.u-pb45 {
  padding-bottom: 4.5rem !important;
}

.u-pl45 {
  padding-left: 4.5rem !important;
}

.u-pr45 {
  padding-right: 4.5rem !important;
}

.u-mt40 {
  margin-top: 4rem !important;
}

.u-mb40 {
  margin-bottom: 4rem !important;
}

.u-ml40 {
  margin-left: 4rem !important;
}

.u-mr40 {
  margin-right: 4rem !important;
}

.u-pt40 {
  padding-top: 4rem !important;
}

.u-pb40 {
  padding-bottom: 4rem !important;
}

.u-pl40 {
  padding-left: 4rem !important;
}

.u-pr40 {
  padding-right: 4rem !important;
}

.u-mt35 {
  margin-top: 3.5rem !important;
}

.u-mb35 {
  margin-bottom: 3.5rem !important;
}

.u-ml35 {
  margin-left: 3.5rem !important;
}

.u-mr35 {
  margin-right: 3.5rem !important;
}

.u-pt35 {
  padding-top: 3.5rem !important;
}

.u-pb35 {
  padding-bottom: 3.5rem !important;
}

.u-pl35 {
  padding-left: 3.5rem !important;
}

.u-pr35 {
  padding-right: 3.5rem !important;
}

.u-mt30 {
  margin-top: 3rem !important;
}

.u-mb30 {
  margin-bottom: 3rem !important;
}

.u-ml30 {
  margin-left: 3rem !important;
}

.u-mr30 {
  margin-right: 3rem !important;
}

.u-pt30 {
  padding-top: 3rem !important;
}

.u-pb30 {
  padding-bottom: 3rem !important;
}

.u-pl30 {
  padding-left: 3rem !important;
}

.u-pr30 {
  padding-right: 3rem !important;
}

.u-mt25 {
  margin-top: 2.5rem !important;
}

.u-mb25 {
  margin-bottom: 2.5rem !important;
}

.u-ml25 {
  margin-left: 2.5rem !important;
}

.u-mr25 {
  margin-right: 2.5rem !important;
}

.u-pt25 {
  padding-top: 2.5rem !important;
}

.u-pb25 {
  padding-bottom: 2.5rem !important;
}

.u-pl25 {
  padding-left: 2.5rem !important;
}

.u-pr25 {
  padding-right: 2.5rem !important;
}

.u-mt20 {
  margin-top: 2rem !important;
}

.u-mb20 {
  margin-bottom: 2rem !important;
}

.u-ml20 {
  margin-left: 2rem !important;
}

.u-mr20 {
  margin-right: 2rem !important;
}

.u-pt20 {
  padding-top: 2rem !important;
}

.u-pb20 {
  padding-bottom: 2rem !important;
}

.u-pl20 {
  padding-left: 2rem !important;
}

.u-pr20 {
  padding-right: 2rem !important;
}

.u-mt15 {
  margin-top: 1.5rem !important;
}

.u-mb15 {
  margin-bottom: 1.5rem !important;
}

.u-ml15 {
  margin-left: 1.5rem !important;
}

.u-mr15 {
  margin-right: 1.5rem !important;
}

.u-pt15 {
  padding-top: 1.5rem !important;
}

.u-pb15 {
  padding-bottom: 1.5rem !important;
}

.u-pl15 {
  padding-left: 1.5rem !important;
}

.u-pr15 {
  padding-right: 1.5rem !important;
}

.u-mt10 {
  margin-top: 1rem !important;
}

.u-mb10 {
  margin-bottom: 1rem !important;
}

.u-ml10 {
  margin-left: 1rem !important;
}

.u-mr10 {
  margin-right: 1rem !important;
}

.u-pt10 {
  padding-top: 1rem !important;
}

.u-pb10 {
  padding-bottom: 1rem !important;
}

.u-pl10 {
  padding-left: 1rem !important;
}

.u-pr10 {
  padding-right: 1rem !important;
}

.u-mt5 {
  margin-top: 0.5rem !important;
}

.u-mb5 {
  margin-bottom: 0.5rem !important;
}

.u-ml5 {
  margin-left: 0.5rem !important;
}

.u-mr5 {
  margin-right: 0.5rem !important;
}

.u-pt5 {
  padding-top: 0.5rem !important;
}

.u-pb5 {
  padding-bottom: 0.5rem !important;
}

.u-pl5 {
  padding-left: 0.5rem !important;
}

.u-pr5 {
  padding-right: 0.5rem !important;
}

.u-mt0 {
  margin-top: 0rem !important;
}

.u-mb0 {
  margin-bottom: 0rem !important;
}

.u-ml0 {
  margin-left: 0rem !important;
}

.u-mr0 {
  margin-right: 0rem !important;
}

.u-pt0 {
  padding-top: 0rem !important;
}

.u-pb0 {
  padding-bottom: 0rem !important;
}

.u-pl0 {
  padding-left: 0rem !important;
}

.u-pr0 {
  padding-right: 0rem !important;
}

@media screen and (max-width: 1024px) {
  .u-mt120-tab {
    margin-top: 12rem !important;
  }
  .u-mb120-tab {
    margin-bottom: 12rem !important;
  }
  .u-ml120-tab {
    margin-left: 12rem !important;
  }
  .u-mr120-tab {
    margin-right: 12rem !important;
  }
  .u-pt120-tab {
    padding-top: 12rem !important;
  }
  .u-pb120-tab {
    padding-bottom: 12rem !important;
  }
  .u-pl120-tab {
    padding-left: 12rem !important;
  }
  .u-pr120-tab {
    padding-right: 12rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt110-tab {
    margin-top: 11rem !important;
  }
  .u-mb110-tab {
    margin-bottom: 11rem !important;
  }
  .u-ml110-tab {
    margin-left: 11rem !important;
  }
  .u-mr110-tab {
    margin-right: 11rem !important;
  }
  .u-pt110-tab {
    padding-top: 11rem !important;
  }
  .u-pb110-tab {
    padding-bottom: 11rem !important;
  }
  .u-pl110-tab {
    padding-left: 11rem !important;
  }
  .u-pr110-tab {
    padding-right: 11rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt100-tab {
    margin-top: 10rem !important;
  }
  .u-mb100-tab {
    margin-bottom: 10rem !important;
  }
  .u-ml100-tab {
    margin-left: 10rem !important;
  }
  .u-mr100-tab {
    margin-right: 10rem !important;
  }
  .u-pt100-tab {
    padding-top: 10rem !important;
  }
  .u-pb100-tab {
    padding-bottom: 10rem !important;
  }
  .u-pl100-tab {
    padding-left: 10rem !important;
  }
  .u-pr100-tab {
    padding-right: 10rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt90-tab {
    margin-top: 9rem !important;
  }
  .u-mb90-tab {
    margin-bottom: 9rem !important;
  }
  .u-ml90-tab {
    margin-left: 9rem !important;
  }
  .u-mr90-tab {
    margin-right: 9rem !important;
  }
  .u-pt90-tab {
    padding-top: 9rem !important;
  }
  .u-pb90-tab {
    padding-bottom: 9rem !important;
  }
  .u-pl90-tab {
    padding-left: 9rem !important;
  }
  .u-pr90-tab {
    padding-right: 9rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt80-tab {
    margin-top: 8rem !important;
  }
  .u-mb80-tab {
    margin-bottom: 8rem !important;
  }
  .u-ml80-tab {
    margin-left: 8rem !important;
  }
  .u-mr80-tab {
    margin-right: 8rem !important;
  }
  .u-pt80-tab {
    padding-top: 8rem !important;
  }
  .u-pb80-tab {
    padding-bottom: 8rem !important;
  }
  .u-pl80-tab {
    padding-left: 8rem !important;
  }
  .u-pr80-tab {
    padding-right: 8rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt75-tab {
    margin-top: 7.5rem !important;
  }
  .u-mb75-tab {
    margin-bottom: 7.5rem !important;
  }
  .u-ml75-tab {
    margin-left: 7.5rem !important;
  }
  .u-mr75-tab {
    margin-right: 7.5rem !important;
  }
  .u-pt75-tab {
    padding-top: 7.5rem !important;
  }
  .u-pb75-tab {
    padding-bottom: 7.5rem !important;
  }
  .u-pl75-tab {
    padding-left: 7.5rem !important;
  }
  .u-pr75-tab {
    padding-right: 7.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt70-tab {
    margin-top: 7rem !important;
  }
  .u-mb70-tab {
    margin-bottom: 7rem !important;
  }
  .u-ml70-tab {
    margin-left: 7rem !important;
  }
  .u-mr70-tab {
    margin-right: 7rem !important;
  }
  .u-pt70-tab {
    padding-top: 7rem !important;
  }
  .u-pb70-tab {
    padding-bottom: 7rem !important;
  }
  .u-pl70-tab {
    padding-left: 7rem !important;
  }
  .u-pr70-tab {
    padding-right: 7rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt65-tab {
    margin-top: 6.5rem !important;
  }
  .u-mb65-tab {
    margin-bottom: 6.5rem !important;
  }
  .u-ml65-tab {
    margin-left: 6.5rem !important;
  }
  .u-mr65-tab {
    margin-right: 6.5rem !important;
  }
  .u-pt65-tab {
    padding-top: 6.5rem !important;
  }
  .u-pb65-tab {
    padding-bottom: 6.5rem !important;
  }
  .u-pl65-tab {
    padding-left: 6.5rem !important;
  }
  .u-pr65-tab {
    padding-right: 6.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt60-tab {
    margin-top: 6rem !important;
  }
  .u-mb60-tab {
    margin-bottom: 6rem !important;
  }
  .u-ml60-tab {
    margin-left: 6rem !important;
  }
  .u-mr60-tab {
    margin-right: 6rem !important;
  }
  .u-pt60-tab {
    padding-top: 6rem !important;
  }
  .u-pb60-tab {
    padding-bottom: 6rem !important;
  }
  .u-pl60-tab {
    padding-left: 6rem !important;
  }
  .u-pr60-tab {
    padding-right: 6rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt55-tab {
    margin-top: 5.5rem !important;
  }
  .u-mb55-tab {
    margin-bottom: 5.5rem !important;
  }
  .u-ml55-tab {
    margin-left: 5.5rem !important;
  }
  .u-mr55-tab {
    margin-right: 5.5rem !important;
  }
  .u-pt55-tab {
    padding-top: 5.5rem !important;
  }
  .u-pb55-tab {
    padding-bottom: 5.5rem !important;
  }
  .u-pl55-tab {
    padding-left: 5.5rem !important;
  }
  .u-pr55-tab {
    padding-right: 5.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt50-tab {
    margin-top: 5rem !important;
  }
  .u-mb50-tab {
    margin-bottom: 5rem !important;
  }
  .u-ml50-tab {
    margin-left: 5rem !important;
  }
  .u-mr50-tab {
    margin-right: 5rem !important;
  }
  .u-pt50-tab {
    padding-top: 5rem !important;
  }
  .u-pb50-tab {
    padding-bottom: 5rem !important;
  }
  .u-pl50-tab {
    padding-left: 5rem !important;
  }
  .u-pr50-tab {
    padding-right: 5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt45-tab {
    margin-top: 4.5rem !important;
  }
  .u-mb45-tab {
    margin-bottom: 4.5rem !important;
  }
  .u-ml45-tab {
    margin-left: 4.5rem !important;
  }
  .u-mr45-tab {
    margin-right: 4.5rem !important;
  }
  .u-pt45-tab {
    padding-top: 4.5rem !important;
  }
  .u-pb45-tab {
    padding-bottom: 4.5rem !important;
  }
  .u-pl45-tab {
    padding-left: 4.5rem !important;
  }
  .u-pr45-tab {
    padding-right: 4.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt40-tab {
    margin-top: 4rem !important;
  }
  .u-mb40-tab {
    margin-bottom: 4rem !important;
  }
  .u-ml40-tab {
    margin-left: 4rem !important;
  }
  .u-mr40-tab {
    margin-right: 4rem !important;
  }
  .u-pt40-tab {
    padding-top: 4rem !important;
  }
  .u-pb40-tab {
    padding-bottom: 4rem !important;
  }
  .u-pl40-tab {
    padding-left: 4rem !important;
  }
  .u-pr40-tab {
    padding-right: 4rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt35-tab {
    margin-top: 3.5rem !important;
  }
  .u-mb35-tab {
    margin-bottom: 3.5rem !important;
  }
  .u-ml35-tab {
    margin-left: 3.5rem !important;
  }
  .u-mr35-tab {
    margin-right: 3.5rem !important;
  }
  .u-pt35-tab {
    padding-top: 3.5rem !important;
  }
  .u-pb35-tab {
    padding-bottom: 3.5rem !important;
  }
  .u-pl35-tab {
    padding-left: 3.5rem !important;
  }
  .u-pr35-tab {
    padding-right: 3.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt30-tab {
    margin-top: 3rem !important;
  }
  .u-mb30-tab {
    margin-bottom: 3rem !important;
  }
  .u-ml30-tab {
    margin-left: 3rem !important;
  }
  .u-mr30-tab {
    margin-right: 3rem !important;
  }
  .u-pt30-tab {
    padding-top: 3rem !important;
  }
  .u-pb30-tab {
    padding-bottom: 3rem !important;
  }
  .u-pl30-tab {
    padding-left: 3rem !important;
  }
  .u-pr30-tab {
    padding-right: 3rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt25-tab {
    margin-top: 2.5rem !important;
  }
  .u-mb25-tab {
    margin-bottom: 2.5rem !important;
  }
  .u-ml25-tab {
    margin-left: 2.5rem !important;
  }
  .u-mr25-tab {
    margin-right: 2.5rem !important;
  }
  .u-pt25-tab {
    padding-top: 2.5rem !important;
  }
  .u-pb25-tab {
    padding-bottom: 2.5rem !important;
  }
  .u-pl25-tab {
    padding-left: 2.5rem !important;
  }
  .u-pr25-tab {
    padding-right: 2.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt20-tab {
    margin-top: 2rem !important;
  }
  .u-mb20-tab {
    margin-bottom: 2rem !important;
  }
  .u-ml20-tab {
    margin-left: 2rem !important;
  }
  .u-mr20-tab {
    margin-right: 2rem !important;
  }
  .u-pt20-tab {
    padding-top: 2rem !important;
  }
  .u-pb20-tab {
    padding-bottom: 2rem !important;
  }
  .u-pl20-tab {
    padding-left: 2rem !important;
  }
  .u-pr20-tab {
    padding-right: 2rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt15-tab {
    margin-top: 1.5rem !important;
  }
  .u-mb15-tab {
    margin-bottom: 1.5rem !important;
  }
  .u-ml15-tab {
    margin-left: 1.5rem !important;
  }
  .u-mr15-tab {
    margin-right: 1.5rem !important;
  }
  .u-pt15-tab {
    padding-top: 1.5rem !important;
  }
  .u-pb15-tab {
    padding-bottom: 1.5rem !important;
  }
  .u-pl15-tab {
    padding-left: 1.5rem !important;
  }
  .u-pr15-tab {
    padding-right: 1.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt10-tab {
    margin-top: 1rem !important;
  }
  .u-mb10-tab {
    margin-bottom: 1rem !important;
  }
  .u-ml10-tab {
    margin-left: 1rem !important;
  }
  .u-mr10-tab {
    margin-right: 1rem !important;
  }
  .u-pt10-tab {
    padding-top: 1rem !important;
  }
  .u-pb10-tab {
    padding-bottom: 1rem !important;
  }
  .u-pl10-tab {
    padding-left: 1rem !important;
  }
  .u-pr10-tab {
    padding-right: 1rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt5-tab {
    margin-top: 0.5rem !important;
  }
  .u-mb5-tab {
    margin-bottom: 0.5rem !important;
  }
  .u-ml5-tab {
    margin-left: 0.5rem !important;
  }
  .u-mr5-tab {
    margin-right: 0.5rem !important;
  }
  .u-pt5-tab {
    padding-top: 0.5rem !important;
  }
  .u-pb5-tab {
    padding-bottom: 0.5rem !important;
  }
  .u-pl5-tab {
    padding-left: 0.5rem !important;
  }
  .u-pr5-tab {
    padding-right: 0.5rem !important;
  }
}
@media screen and (max-width: 1024px) {
  .u-mt0-tab {
    margin-top: 0rem !important;
  }
  .u-mb0-tab {
    margin-bottom: 0rem !important;
  }
  .u-ml0-tab {
    margin-left: 0rem !important;
  }
  .u-mr0-tab {
    margin-right: 0rem !important;
  }
  .u-pt0-tab {
    padding-top: 0rem !important;
  }
  .u-pb0-tab {
    padding-bottom: 0rem !important;
  }
  .u-pl0-tab {
    padding-left: 0rem !important;
  }
  .u-pr0-tab {
    padding-right: 0rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt120-sp {
    margin-top: 12rem !important;
  }
  .u-mb120-sp {
    margin-bottom: 12rem !important;
  }
  .u-ml120-sp {
    margin-left: 12rem !important;
  }
  .u-mr120-sp {
    margin-right: 12rem !important;
  }
  .u-pt120-sp {
    padding-top: 12rem !important;
  }
  .u-pb120-sp {
    padding-bottom: 12rem !important;
  }
  .u-pl120-sp {
    padding-left: 12rem !important;
  }
  .u-pr120-sp {
    padding-right: 12rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt110-sp {
    margin-top: 11rem !important;
  }
  .u-mb110-sp {
    margin-bottom: 11rem !important;
  }
  .u-ml110-sp {
    margin-left: 11rem !important;
  }
  .u-mr110-sp {
    margin-right: 11rem !important;
  }
  .u-pt110-sp {
    padding-top: 11rem !important;
  }
  .u-pb110-sp {
    padding-bottom: 11rem !important;
  }
  .u-pl110-sp {
    padding-left: 11rem !important;
  }
  .u-pr110-sp {
    padding-right: 11rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt100-sp {
    margin-top: 10rem !important;
  }
  .u-mb100-sp {
    margin-bottom: 10rem !important;
  }
  .u-ml100-sp {
    margin-left: 10rem !important;
  }
  .u-mr100-sp {
    margin-right: 10rem !important;
  }
  .u-pt100-sp {
    padding-top: 10rem !important;
  }
  .u-pb100-sp {
    padding-bottom: 10rem !important;
  }
  .u-pl100-sp {
    padding-left: 10rem !important;
  }
  .u-pr100-sp {
    padding-right: 10rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt90-sp {
    margin-top: 9rem !important;
  }
  .u-mb90-sp {
    margin-bottom: 9rem !important;
  }
  .u-ml90-sp {
    margin-left: 9rem !important;
  }
  .u-mr90-sp {
    margin-right: 9rem !important;
  }
  .u-pt90-sp {
    padding-top: 9rem !important;
  }
  .u-pb90-sp {
    padding-bottom: 9rem !important;
  }
  .u-pl90-sp {
    padding-left: 9rem !important;
  }
  .u-pr90-sp {
    padding-right: 9rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt80-sp {
    margin-top: 8rem !important;
  }
  .u-mb80-sp {
    margin-bottom: 8rem !important;
  }
  .u-ml80-sp {
    margin-left: 8rem !important;
  }
  .u-mr80-sp {
    margin-right: 8rem !important;
  }
  .u-pt80-sp {
    padding-top: 8rem !important;
  }
  .u-pb80-sp {
    padding-bottom: 8rem !important;
  }
  .u-pl80-sp {
    padding-left: 8rem !important;
  }
  .u-pr80-sp {
    padding-right: 8rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt75-sp {
    margin-top: 7.5rem !important;
  }
  .u-mb75-sp {
    margin-bottom: 7.5rem !important;
  }
  .u-ml75-sp {
    margin-left: 7.5rem !important;
  }
  .u-mr75-sp {
    margin-right: 7.5rem !important;
  }
  .u-pt75-sp {
    padding-top: 7.5rem !important;
  }
  .u-pb75-sp {
    padding-bottom: 7.5rem !important;
  }
  .u-pl75-sp {
    padding-left: 7.5rem !important;
  }
  .u-pr75-sp {
    padding-right: 7.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt70-sp {
    margin-top: 7rem !important;
  }
  .u-mb70-sp {
    margin-bottom: 7rem !important;
  }
  .u-ml70-sp {
    margin-left: 7rem !important;
  }
  .u-mr70-sp {
    margin-right: 7rem !important;
  }
  .u-pt70-sp {
    padding-top: 7rem !important;
  }
  .u-pb70-sp {
    padding-bottom: 7rem !important;
  }
  .u-pl70-sp {
    padding-left: 7rem !important;
  }
  .u-pr70-sp {
    padding-right: 7rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt65-sp {
    margin-top: 6.5rem !important;
  }
  .u-mb65-sp {
    margin-bottom: 6.5rem !important;
  }
  .u-ml65-sp {
    margin-left: 6.5rem !important;
  }
  .u-mr65-sp {
    margin-right: 6.5rem !important;
  }
  .u-pt65-sp {
    padding-top: 6.5rem !important;
  }
  .u-pb65-sp {
    padding-bottom: 6.5rem !important;
  }
  .u-pl65-sp {
    padding-left: 6.5rem !important;
  }
  .u-pr65-sp {
    padding-right: 6.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt60-sp {
    margin-top: 6rem !important;
  }
  .u-mb60-sp {
    margin-bottom: 6rem !important;
  }
  .u-ml60-sp {
    margin-left: 6rem !important;
  }
  .u-mr60-sp {
    margin-right: 6rem !important;
  }
  .u-pt60-sp {
    padding-top: 6rem !important;
  }
  .u-pb60-sp {
    padding-bottom: 6rem !important;
  }
  .u-pl60-sp {
    padding-left: 6rem !important;
  }
  .u-pr60-sp {
    padding-right: 6rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt55-sp {
    margin-top: 5.5rem !important;
  }
  .u-mb55-sp {
    margin-bottom: 5.5rem !important;
  }
  .u-ml55-sp {
    margin-left: 5.5rem !important;
  }
  .u-mr55-sp {
    margin-right: 5.5rem !important;
  }
  .u-pt55-sp {
    padding-top: 5.5rem !important;
  }
  .u-pb55-sp {
    padding-bottom: 5.5rem !important;
  }
  .u-pl55-sp {
    padding-left: 5.5rem !important;
  }
  .u-pr55-sp {
    padding-right: 5.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt50-sp {
    margin-top: 5rem !important;
  }
  .u-mb50-sp {
    margin-bottom: 5rem !important;
  }
  .u-ml50-sp {
    margin-left: 5rem !important;
  }
  .u-mr50-sp {
    margin-right: 5rem !important;
  }
  .u-pt50-sp {
    padding-top: 5rem !important;
  }
  .u-pb50-sp {
    padding-bottom: 5rem !important;
  }
  .u-pl50-sp {
    padding-left: 5rem !important;
  }
  .u-pr50-sp {
    padding-right: 5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt45-sp {
    margin-top: 4.5rem !important;
  }
  .u-mb45-sp {
    margin-bottom: 4.5rem !important;
  }
  .u-ml45-sp {
    margin-left: 4.5rem !important;
  }
  .u-mr45-sp {
    margin-right: 4.5rem !important;
  }
  .u-pt45-sp {
    padding-top: 4.5rem !important;
  }
  .u-pb45-sp {
    padding-bottom: 4.5rem !important;
  }
  .u-pl45-sp {
    padding-left: 4.5rem !important;
  }
  .u-pr45-sp {
    padding-right: 4.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt40-sp {
    margin-top: 4rem !important;
  }
  .u-mb40-sp {
    margin-bottom: 4rem !important;
  }
  .u-ml40-sp {
    margin-left: 4rem !important;
  }
  .u-mr40-sp {
    margin-right: 4rem !important;
  }
  .u-pt40-sp {
    padding-top: 4rem !important;
  }
  .u-pb40-sp {
    padding-bottom: 4rem !important;
  }
  .u-pl40-sp {
    padding-left: 4rem !important;
  }
  .u-pr40-sp {
    padding-right: 4rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt35-sp {
    margin-top: 3.5rem !important;
  }
  .u-mb35-sp {
    margin-bottom: 3.5rem !important;
  }
  .u-ml35-sp {
    margin-left: 3.5rem !important;
  }
  .u-mr35-sp {
    margin-right: 3.5rem !important;
  }
  .u-pt35-sp {
    padding-top: 3.5rem !important;
  }
  .u-pb35-sp {
    padding-bottom: 3.5rem !important;
  }
  .u-pl35-sp {
    padding-left: 3.5rem !important;
  }
  .u-pr35-sp {
    padding-right: 3.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt30-sp {
    margin-top: 3rem !important;
  }
  .u-mb30-sp {
    margin-bottom: 3rem !important;
  }
  .u-ml30-sp {
    margin-left: 3rem !important;
  }
  .u-mr30-sp {
    margin-right: 3rem !important;
  }
  .u-pt30-sp {
    padding-top: 3rem !important;
  }
  .u-pb30-sp {
    padding-bottom: 3rem !important;
  }
  .u-pl30-sp {
    padding-left: 3rem !important;
  }
  .u-pr30-sp {
    padding-right: 3rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt25-sp {
    margin-top: 2.5rem !important;
  }
  .u-mb25-sp {
    margin-bottom: 2.5rem !important;
  }
  .u-ml25-sp {
    margin-left: 2.5rem !important;
  }
  .u-mr25-sp {
    margin-right: 2.5rem !important;
  }
  .u-pt25-sp {
    padding-top: 2.5rem !important;
  }
  .u-pb25-sp {
    padding-bottom: 2.5rem !important;
  }
  .u-pl25-sp {
    padding-left: 2.5rem !important;
  }
  .u-pr25-sp {
    padding-right: 2.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt20-sp {
    margin-top: 2rem !important;
  }
  .u-mb20-sp {
    margin-bottom: 2rem !important;
  }
  .u-ml20-sp {
    margin-left: 2rem !important;
  }
  .u-mr20-sp {
    margin-right: 2rem !important;
  }
  .u-pt20-sp {
    padding-top: 2rem !important;
  }
  .u-pb20-sp {
    padding-bottom: 2rem !important;
  }
  .u-pl20-sp {
    padding-left: 2rem !important;
  }
  .u-pr20-sp {
    padding-right: 2rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt15-sp {
    margin-top: 1.5rem !important;
  }
  .u-mb15-sp {
    margin-bottom: 1.5rem !important;
  }
  .u-ml15-sp {
    margin-left: 1.5rem !important;
  }
  .u-mr15-sp {
    margin-right: 1.5rem !important;
  }
  .u-pt15-sp {
    padding-top: 1.5rem !important;
  }
  .u-pb15-sp {
    padding-bottom: 1.5rem !important;
  }
  .u-pl15-sp {
    padding-left: 1.5rem !important;
  }
  .u-pr15-sp {
    padding-right: 1.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt10-sp {
    margin-top: 1rem !important;
  }
  .u-mb10-sp {
    margin-bottom: 1rem !important;
  }
  .u-ml10-sp {
    margin-left: 1rem !important;
  }
  .u-mr10-sp {
    margin-right: 1rem !important;
  }
  .u-pt10-sp {
    padding-top: 1rem !important;
  }
  .u-pb10-sp {
    padding-bottom: 1rem !important;
  }
  .u-pl10-sp {
    padding-left: 1rem !important;
  }
  .u-pr10-sp {
    padding-right: 1rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt5-sp {
    margin-top: 0.5rem !important;
  }
  .u-mb5-sp {
    margin-bottom: 0.5rem !important;
  }
  .u-ml5-sp {
    margin-left: 0.5rem !important;
  }
  .u-mr5-sp {
    margin-right: 0.5rem !important;
  }
  .u-pt5-sp {
    padding-top: 0.5rem !important;
  }
  .u-pb5-sp {
    padding-bottom: 0.5rem !important;
  }
  .u-pl5-sp {
    padding-left: 0.5rem !important;
  }
  .u-pr5-sp {
    padding-right: 0.5rem !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt0-sp {
    margin-top: 0rem !important;
  }
  .u-mb0-sp {
    margin-bottom: 0rem !important;
  }
  .u-ml0-sp {
    margin-left: 0rem !important;
  }
  .u-mr0-sp {
    margin-right: 0rem !important;
  }
  .u-pt0-sp {
    padding-top: 0rem !important;
  }
  .u-pb0-sp {
    padding-bottom: 0rem !important;
  }
  .u-pl0-sp {
    padding-left: 0rem !important;
  }
  .u-pr0-sp {
    padding-right: 0rem !important;
  }
}
.scroll-guide {
  position: relative;
}

@media screen and (max-width: 767px) {
  .scroll-guide {
    overflow: scroll;
  }
  .scroll-guide table {
    min-width: 50rem;
  }
  .scroll-guide .wp-block-table {
    overflow-x: visible;
  }
}
.table-wrap-hint {
  background: rgba(190, 0, 8, 0.6);
  color: #fff;
  text-align: center;
  padding: 0.5rem 1rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  transition: 0.25s;
  display: none;
}

@media screen and (max-width: 767px) {
  .table-wrap-hint {
    display: block;
  }
}
.table-wrap-hint.disable {
  opacity: 0;
}

.table-wrap-hint__icon {
  position: relative;
  width: 100%;
}

.table-wrap-hint__hand {
  display: inline-block;
  font-size: 2.8rem;
  line-height: 1.4;
  animation: anime-scroll-hand 1.2s;
  animation-iteration-count: 4;
}

.table-wrap-hint__txt {
  font-size: 1rem;
  line-height: 1.5;
}

@keyframes anime-scroll-hand {
  0% {
    opacity: 0;
    transform: translateX(75%);
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateX(-75%);
  }
}
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

/* ----------------------------------------------------

	リセットCSS調整ファイルです。
	リセットCSSを調整、カスタマイズしたい場合に編集します。

---------------------------------------------------- */
/* ====================================================

	EXAMPLES FONT-SIZE
	------------------
	77% = 9px
	85% = 10px
	93% = 11px
	100% = 12px
	108% = 13px
	116% = 14px
	124% = 15px
	131% = 16px
	139% = 17px
	147% = 18px
	154% = 19px
	162% = 20px
	170% = 21px
	177% = 22px
	185% = 23px
	193% = 24px
	200% = 25px
	---------------

==================================================== */
html {
  font-size: 62.5%;
}
@media screen and (width <= 1024px) {
  html {
    font-size: 52.5%;
  }
}

body {
  *font: x-small;
  _font-size: 14px;
}

ul,
li {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
  word-break: break-all;
}

img {
  vertical-align: middle;
}

* {
  box-sizing: border-box;
}

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

/* Layout */
html {
  scroll-behavior: smooth;
  font-size: 10px;
  overflow-x: hidden;
}
@media screen and (width <= 1500px) {
  html {
    font-size: 0.666666666vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 2.6667vw;
    overflow-Y: scroll;
    overflow-X: hidden;
    width: 100%;
  }
}

body {
  color: #333;
  font-size: 16px;
  font-size: 1.6rem;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.8 !important;
  overflow-X: hidden;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 1.4rem;
    overflow-Y: scroll;
    overflow-X: hidden;
    width: 100%;
  }
}

img {
  height: auto;
  max-height: 100%;
  max-width: 100%;
  vertical-align: middle;
}

.l-inner {
  margin: 0 auto;
  width: 1440px;
}
@media screen and (max-width: 1600px) {
  .l-inner {
    width: 90%;
  }
}
@media screen and (max-width: 767px) {
  .l-inner {
    padding: 0 1.5rem;
    width: 100%;
  }
}

.m-inner {
  margin: 0 auto;
  width: 1100px;
}
@media screen and (max-width: 1200px) {
  .m-inner {
    width: 90%;
  }
}
@media screen and (max-width: 767px) {
  .m-inner {
    width: 100%;
  }
}

.fade-in {
  opacity: 0;
  transform: translateY(5rem);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

@media screen and (max-width: 767px) {
  .stt-lang-select.br {
    bottom: 7rem !important;
  }
}

@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon.eot?ea6ps6");
  src: url("../fonts/icomoon.eot?ea6ps6#iefix") format("embedded-opentype"), url("../fonts/icomoon.ttf?ea6ps6") format("truetype"), url("../fonts/icomoon.woff?ea6ps6") format("woff"), url("../fonts/icomoon.svg?ea6ps6#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-], [class*=" icon-"] {
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-prev:before {
  content: "\ea1c";
}

.icon-next:before {
  content: "\ea1d";
}

/* Header Menu */
.header {
  position: fixed;
  padding: 2rem 0;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  transition: 0.2s;
  transform: translateY(0);
  background: rgba(0, 0, 0, 0.4);
  transform: translateY(0);
  transition: transform 0.7s ease-in-out;
}
@media screen and (max-width: 767px) {
  .header {
    top: 0;
    padding: 1.5rem 0 1rem 0;
    z-index: 999;
  }
}
.header.active {
  height: 0rem;
  /*padding: 0;
  opacity: 0;*/
  transform: translateY(-37rem);
  transition: transform 0.7s ease-in-out, height 0.7s ease-in-out;
}
.header.h-top {
  background: transparent;
  padding: 0;
  top: 4rem;
}
@media screen and (max-width: 767px) {
  .header.h-top {
    top: 0;
    padding: 1.5rem 0;
  }
}
.header.h-hidden {
  transform: translateY(-160%);
}
.header__inner {
  width: 95%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
@media screen and (max-width: 767px) {
  .header__inner {
    align-items: start;
  }
}
.header__logo {
  width: 17.6rem;
  order: 1;
}
@media screen and (max-width: 1280px) {
  .header__logo {
    width: 8%;
  }
}
@media screen and (max-width: 767px) {
  .header__logo {
    width: 8.6rem;
    order: 2;
  }
}
.header__hmbbtn {
  padding: 0 1.5rem 0 1.5rem;
  top: 0.8rem;
  transform: translateY(0);
  transition: 0.2s;
  width: 100%;
}
.header__hmbbtn.m-hidden {
  transform: translateY(-160%);
}
@media screen and (max-width: 767px) {
  .header__hmbbtn {
    padding: 0 0 0 0;
  }
}
.header__nav-box {
  order: 2;
}
@media screen and (max-width: 767px) {
  .header__nav-box {
    order: 3;
  }
}
.header__nav {
  display: flex;
  justify-content: center;
  align-items: center;
}
.header__sp-nav {
  width: 4rem;
  height: 5.6rem;
}

.hmb-btn__inner {
  /*position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  */
}
.hmb-btn__hmb {
  position: relative;
  width: 4rem;
  height: 5.6rem;
}

.menu {
  position: fixed;
  top: 0;
  right: 0;
  background: rgba(203, 12, 24, 0.8);
  opacity: 0;
  z-index: 998 !important;
  width: 100%;
  height: 100%;
  transition: 0.5s;
  pointer-events: none;
}
.menu__list {
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  color: #fff;
}
.menu.open {
  opacity: 1;
  pointer-events: auto;
}

.header-nav {
  display: flex;
  align-items: center;
  justify-content: right;
  color: #fff;
  font-family: "Inika", serif;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .header-nav {
    flex-direction: column;
    color: #222;
    font-weight: bold;
    font-family: "Cairo", sans-serif;
    font-size: 1.5rem;
    width: 24rem;
  }
}
.header-nav__item a {
  display: block;
  padding: 0 1rem;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .header-nav__item a {
    padding: 0.5rem 1rem;
    color: #fff;
    font-size: 1.4rem;
  }
}
.header-nav__item a:hover {
  opacity: 0.7;
}

.language-selector {
  display: inline-block;
  order: 3;
}
@media screen and (max-width: 767px) {
  .language-selector {
    order: 1;
    width: 5.4rem;
    height: 4.6rem;
  }
}
.language-btn {
  padding: 1rem 0;
  cursor: pointer;
}
@media screen and (max-width: 1000px) {
  .language-btn {
    height: 100%;
  }
}
@media screen and (max-width: 767px) {
  .language-btn {
    padding: 0;
  }
}
.language-list {
  display: none;
  position: absolute;
  top: 10rem;
  right: 1rem;
  background-color: #fff;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  width: 20rem;
  z-index: 9999;
}
@media screen and (max-width: 767px) {
  .language-list {
    top: 7.5rem;
    left: 1rem;
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    opacity: 1;
    transform: translateY(0);
  }
}
@media screen and (max-width: 767px) {
  .language-list.hidden {
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
  }
}
.language-item {
  padding: 1rem;
  cursor: pointer;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .language-item {
    padding: 1rem 1rem;
    cursor: pointer;
    line-height: 1.7rem;
    font-size: 1.4rem;
  }
}
.language-item:hover {
  background-color: #f1f1f1;
}
.language-selector.active .language-list {
  display: block;
  position: fixed;
  border-bottom-left-radius: 0.8rem;
  border-bottom-right-radius: 0.8rem;
  padding: 0.5rem 0;
}

@media screen and (max-width: 767px) {
  .lang-select__button-icon img {
    width: 100%;
    height: 100%;
  }
}

@media screen and (max-width: 1000px) {
  /*.language-btn {
      height: 100%;
  }
      */
  /*.language-list {
      top: 7.5rem;
      left: 1rem;
  }*/
}
@media screen and (max-width: 767px) {
  /*.language-item {
  padding: 5px 10px;
  cursor: pointer;
  line-height: 1.7rem;
  }
  */
  .language-list {
    /*transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    opacity: 1;
    transform: translateY(0);
     */
  }
  .language-list.hidden {
    /*
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
    */
  }
}
main {
  overflow-x: hidden;
}

.content-bg {
  background: url(../images/common/content-bg.png);
  background-position: center center;
  background-size: contain;
  background-repeat: repeat;
  width: 100%;
  overflow: hidden;
}

/* MV */
.mv {
  /*padding-bottom: 45vw;*/
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .mv {
    padding: 0;
  }
}
.mv__player {
  transform: scale(1.1);
  aspect-ratio: 16/9;
  vertical-align: middle;
  width: 100%;
}
.mv__img {
  /*display: none;*/
}
@media screen and (max-width: 767px) {
  .mv__img {
    position: relative;
    display: block;
  }
}
.mv__txt {
  position: absolute;
  text-align: center;
  color: #fff;
  font-family: "Libre Franklin", sans-serif;
  font-size: 1.9rem;
  font-weight: 900;
  line-height: 1.1;
  transform: translate(-50%, -50%);
  top: 31%;
  left: 50%;
}
.mv__txt span {
  font-size: 3.5rem;
}

#player-container {
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
@media screen and (max-width: 767px) {
  #player-container {
    display: none;
  }
}
#player-container iframe {
  aspect-ratio: 16/9;
  vertical-align: middle;
  width: 100%;
}

.ticket-bnr {
  width: 50rem;
  position: absolute;
  right: 0;
  bottom: 5rem;
  z-index: 900;
  transition: 0.2s;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.08);
}
.ticket-bnr:hover {
  opacity: 0.7;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .ticket-bnr {
    position: fixed;
    width: 100%;
    bottom: 0;
    right: auto;
    left: 0;
    background: #cb0c18;
    padding: 1rem 0;
  }
  .ticket-bnr img {
    padding: 0 15%;
  }
}

.ticket-bnr-fixed {
  width: 35rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.08);
  position: fixed;
  right: 0;
  bottom: 22rem;
  z-index: 900;
  transition: 0.3s;
  opacity: 0;
  pointer-events: none;
}
.ticket-bnr-fixed.active {
  opacity: 1;
  pointer-events: all;
}
.ticket-bnr-fixed:hover {
  opacity: 0.7;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .ticket-bnr-fixed {
    width: 100%;
    bottom: 0;
    right: auto;
    left: 0;
  }
}

/* News List */
.news-ticker {
  background: #000;
  padding: 3rem 0;
  overflow: hidden;
  width: 100%;
}
@media screen and (max-width: 1600px) {
  .news-ticker {
    padding: 1.5625vw 0;
  }
}
@media screen and (max-width: 767px) {
  .news-ticker {
    padding: 1.5rem 0;
  }
}
.news-ticker__wrapper {
  display: flex;
  white-space: nowrap;
}

.news-item {
  display: inline-block;
  margin-right: 50px;
}
.news-item__link {
  display: flex;
  align-items: center;
  color: #fff;
  gap: 2rem;
  transition: 0.15s;
}
.news-item__link:hover {
  opacity: 0.8;
}
.news-item__cate {
  color: #cb0c18;
  display: block;
  font-size: 1.8rem;
  width: 5rem;
  white-space: nowrap;
}
@media screen and (max-width: 1600px) {
  .news-item__cate {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 767px) {
  .news-item__cate {
    font-size: 1.3rem;
  }
}
.news-item__date {
  white-space: nowrap;
  font-size: 1.8rem;
}
@media screen and (max-width: 1600px) {
  .news-item__date {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 767px) {
  .news-item__date {
    font-size: 1.3rem;
  }
}
.news-item__ttl {
  white-space: nowrap;
  font-size: 1.8rem;
}
@media screen and (max-width: 1600px) {
  .news-item__ttl {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 767px) {
  .news-item__ttl {
    font-size: 1.3rem;
  }
}

/* About */
.about {
  background: url(../images/about-bg.png) no-repeat center center;
  background-size: 100%;
  padding-top: 14rem;
  padding-bottom: 36rem;
}
@media screen and (max-width: 767px) {
  .about {
    padding-top: 9rem;
    padding-bottom: 20rem;
    background-size: auto;
  }
}
.about .l-inner {
  position: relative;
}
.about .m-inner {
  position: relative;
}
.about__ttl {
  margin-bottom: 5rem;
}
@media screen and (max-width: 1600px) {
  .about__ttl {
    margin-bottom: 2.6041666667vw;
  }
}
.about__ttl img {
  height: 11rem;
}
@media screen and (max-width: 1600px) {
  .about__ttl img {
    height: 5.7291666667vw;
  }
}
@media screen and (max-width: 767px) {
  .about__ttl {
    margin-bottom: 2rem;
  }
  .about__ttl img {
    height: 4.5rem;
  }
}
.about .hirakuza-text {
  margin-bottom: 6rem;
}
.about .hirakuza-text img {
  height: 11rem;
}
@media screen and (max-width: 1600px) {
  .about .hirakuza-text {
    margin-bottom: 3.125vw;
  }
  .about .hirakuza-text img {
    height: 5.7291666667vw;
  }
}
@media screen and (max-width: 767px) {
  .about .hirakuza-text {
    margin-bottom: 3rem;
  }
  .about .hirakuza-text img {
    height: 4.5rem;
  }
}
.about .red {
  color: #CB0C18;
}
.about__wrap {
  line-height: 2.1;
  font-size: 2.9rem;
  margin-bottom: 6rem;
}
@media screen and (max-width: 1600px) {
  .about__wrap {
    font-size: 1.5625vw;
    margin-bottom: 3.125vw;
  }
}
@media screen and (max-width: 767px) {
  .about__wrap {
    font-size: 1.6rem;
    margin-bottom: 4rem;
  }
}
.about__img {
  max-width: 70rem;
  width: 36.4583333333vw;
  position: absolute;
  top: -17rem;
  right: -25rem;
}
@media screen and (max-width: 1600px) {
  .about__img {
    right: auto;
    transform: translateX(120%);
  }
}

.about-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7rem;
}
@media screen and (max-width: 1600px) {
  .about-list {
    gap: 3.6458333333vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list {
    flex-direction: column;
  }
}
.about-list li {
  background: url(../images/about-list-bg.png) no-repeat center center;
  background-size: cover;
  width: 38rem;
  height: 38rem;
  border-radius: 50%;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 1600px) {
  .about-list li {
    width: 19.7916666667vw;
    height: 19.7916666667vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list li {
    width: 100%;
    height: auto;
    border-radius: 0;
    flex-direction: row;
    background-size: 105%;
    gap: 1rem;
    padding: 1.5rem 1rem;
  }
}
.about-list__num {
  font-family: "Bayon", sans-serif;
  font-size: 8.5rem;
  line-height: 1.5;
  margin-top: 1.8rem;
}
@media screen and (max-width: 1600px) {
  .about-list__num {
    font-size: 4.4270833333vw;
    margin-top: 0.9375vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list__num {
    width: 16%;
    display: block;
    text-align: center;
    font-size: 4.5rem;
    margin-top: 0;
  }
}
.about-list__text {
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 1600px) {
  .about-list__text {
    font-size: 1.4583333333vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list__text {
    font-size: 1.6rem;
    width: 85%;
    text-align: left;
  }
}
.about-list__text span {
  font-size: 2.8rem;
}
@media screen and (max-width: 1600px) {
  .about-list__text span {
    font-size: 1.4583333333vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list__text span {
    font-size: 1.6rem;
  }
}

/* Program */
.program {
  color: #fff;
  background: #171717;
  padding-top: 7.8125vw;
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .program {
    /*padding-top: 8rem;*/
    padding-bottom: 4.5rem;
  }
}
.program .gold-dust-02 {
  max-width: 29.2rem;
  width: 15.2083333333vw;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .program .gold-dust-02 {
    width: 14rem;
    top: 3rem;
  }
}
.program .gold-dust {
  max-width: 50.7rem;
  width: 26.40625vw;
  top: 40%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .program .gold-dust {
    width: 18rem;
    top: 30%;
  }
}
.program__top {
  position: absolute;
  top: -13.0208333333vw;
  left: 0;
  width: 100%;
}
.program__deco {
  position: absolute;
}
.program__deco--left {
  top: -15.625vw;
  left: 0;
  max-width: 72rem;
  width: 37.5vw;
}
@media screen and (max-width: 767px) {
  .program__deco--left {
    top: -16rem;
    left: 0rem;
    width: 20rem;
  }
}
.program__deco--right {
  top: -21.3541666667vw;
  right: 0;
  max-width: 78rem;
  width: 40.625vw;
}
@media screen and (max-width: 767px) {
  .program__deco--right {
    width: 22rem;
    right: 0rem;
    top: -13rem;
  }
}
.program__bg {
  background: url(../images/program-bg.png) no-repeat center;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .program__bg {
    background-position: 80% 10%;
    background-size: 160% auto;
  }
}
.program .l-inner {
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .program .l-inner {
    padding-top: 6rem;
  }
}
.program__wrap {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
}
.program__ttl {
  margin-bottom: 5rem;
  height: 16rem;
  position: relative;
}
@media screen and (max-width: 1600px) {
  .program__ttl {
    margin-bottom: 3.125vw;
    height: 8.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .program__ttl {
    height: 4rem;
    margin-bottom: 3rem;
  }
}
.program__note {
  font-size: 2rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .program__note {
    font-size: 1.3rem;
    margin-bottom: 2rem;
  }
}
.program__cmt a {
  text-decoration: underline;
}
.program dl {
  display: flex;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .program dl {
    margin-bottom: 1.5rem;
  }
}
.program dl:last-of-type {
  padding-bottom: 30rem;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .program dl:last-of-type {
    padding-bottom: 6rem;
  }
}
.program dt {
  font-weight: bold;
  width: 9%;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .program dt {
    font-size: 1.3rem;
    width: 25%;
  }
}
.program dd {
  font-size: 2rem;
  width: 91%;
}
@media screen and (max-width: 767px) {
  .program dd {
    font-size: 1.3rem;
    width: 70%;
  }
}
.program .smoke-01 {
  left: 0;
  top: 0;
  width: 28.3333333333vw;
}
.program .smoke-02 {
  left: 0;
  top: 0;
  width: 23.75vw;
}
.program .smoke-03 {
  right: 0;
  bottom: 0;
  width: 33.0208333333vw;
}
.program__event-title {
  font-weight: 700;
  font-size: 2.4rem;
}
@media screen and (max-width: 767px) {
  .program__event-title {
    font-size: 1.6rem;
  }
}
.program__cmt {
  font-size: 1.7rem;
}
@media screen and (max-width: 767px) {
  .program__cmt {
    font-size: 1.2rem;
  }
}
.program__link {
  border-bottom: 1px solid #FFF;
}
.program__link:hover {
  border-bottom: none;
}

.what-bnr {
  margin-top: 8rem;
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .what-bnr {
    margin-top: 3rem;
  }
}

.what-bnr:hover a {
  background: #0e204a;
  opacity: 1;
}

.what-bnr:hover .what-bnr-text {
  color: #fff;
}

.what-bnr a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2rem 5rem;
  border: 3px solid #fff;
  background: #000;
  color: #FF2600;
  font-weight: bold;
  text-decoration: none;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a {
    padding: 2rem 2.6041666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a {
    padding: 0;
    min-height: 7rem;
    padding-right: 3px;
    padding-left: 1rem;
    justify-content: space-between;
    align-items: stretch;
    gap: 0;
  }
}

.what-bnr a .what-bnr-text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 75%;
  font-size: 5.5rem;
  line-height: 1;
  margin-top: 0;
  font-weight: 800;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a .what-bnr-text {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-text {
    gap: 0;
    font-size: 2rem;
    line-height: 1.3;
    margin-top: 0;
    width: 60%;
    font-feature-settings: "palt";
    padding: 1rem 0;
  }
}

.what-bnr a .what-bnr-tickets {
  width: 25%;
  color: #fff;
  background: #CB0C18;
  font-style: italic;
  padding: 0 7rem 0.1rem;
  font-size: 4.5rem;
  line-height: 1.5;
  white-space: nowrap;
  font-family: "Barlow Condensed", sans-serif;
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-tickets {
    font-size: 2.5rem;
    line-height: 1.5;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.5rem;
    height: inherit;
    width: 37%;
    border: none;
    margin: 3px 0;
  }
}

.what-bnr--2 .what-bnr-text {
  background: rgb(255, 212, 102);
  background: radial-gradient(circle, rgb(255, 212, 102) 0%, rgb(255, 196, 43) 19%, rgb(255, 214, 107) 86%, rgb(255, 198, 51) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text {
    flex-direction: column;
    gap: 0;
  }
}

.what-bnr--2 .what-bnr-text span {
  font-size: 5rem;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text span {
    font-size: 1.75rem;
  }
}

.what-bnr--2:hover .what-bnr-text {
  background: rgb(255, 255, 255);
  background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 19%, rgb(255, 255, 255) 86%, rgb(255, 255, 255) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #fff;
}

.swiper-program {
  cursor: pointer; /* マウスオーバー時に手のひらアイコンに変更 */
}

.swiper-slide {
  cursor: pointer; /* 各スライド上でも手のひらアイコン */
}

.swiper-carousel-control {
  display: flex;
  justify-content: end;
  position: absolute;
  top: 15px;
  width: 95%;
  transform: translateY(-50%);
  z-index: 2;
}

.swiper-carousel-button-prev, .swiper-carousel-button-next {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 2rem;
  margin-left: 0.7rem;
}

/* Program Card */
.program-item {
  display: flex;
  justify-content: space-between;
  gap: 10rem;
  margin-bottom: 8rem;
}
@media screen and (max-width: 767px) {
  .program-item {
    display: block;
    margin-bottom: 5rem;
    width: 90%;
    margin: 0 auto 5rem;
  }
}
.program-item:nth-of-type(2n) {
  flex-direction: row-reverse;
}
.program-item:nth-of-type(2n) .program-icon {
  left: auto;
  right: -3rem;
}
@media screen and (max-width: 767px) {
  .program-item:nth-of-type(2n) .program-icon {
    left: -1rem;
    top: -3rem;
    right: auto;
  }
}
.program-item:nth-of-type(2n) .program-wrap {
  text-align: right;
}
@media screen and (max-width: 767px) {
  .program-item:nth-of-type(2n) .program-wrap {
    text-align: left;
  }
}
.program-item:last-of-type {
  margin-bottom: 0;
}

.program-img {
  width: calc(50% - 5rem);
  position: relative;
}
@media screen and (max-width: 767px) {
  .program-img {
    width: 100%;
    margin-bottom: 1.5rem;
  }
}

.program-icon {
  width: 15.9rem;
  height: 15.9rem;
  position: absolute;
  left: -3rem;
  top: -8rem;
}
@media screen and (max-width: 767px) {
  .program-icon {
    width: 8rem;
    height: 8rem;
    left: -1rem;
    top: -3rem;
  }
}

.program-wrap {
  width: calc(50% - 5rem);
}
@media screen and (max-width: 767px) {
  .program-wrap {
    width: 100%;
  }
}
.program-wrap .title {
  font-weight: 500;
  font-size: 3.1rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .program-wrap .title {
    font-size: 1.9rem;
    margin-bottom: 1rem;
  }
}
.program-wrap .text {
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .program-wrap .text {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .swiper-slide-program {
    padding-top: 6rem;
  }
}

/* Sumo Show */
.show {
  color: #fff;
  background: #171717;
  padding-top: 7.8125vw;
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .show {
    padding-top: 9rem;
    padding-bottom: 4.5rem;
  }
}
.show .gold-dust-02 {
  max-width: 29.2rem;
  width: 15.2083333333vw;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .show .gold-dust-02 {
    width: 14rem;
    top: 3rem;
  }
}
.show .gold-dust {
  max-width: 50.7rem;
  width: 26.40625vw;
  top: 40%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .show .gold-dust {
    width: 18rem;
    top: 30%;
  }
}
.show__top {
  position: absolute;
  top: -13.0208333333vw;
  left: 0;
  width: 100%;
}
.show__deco {
  position: absolute;
}
.show__deco--left {
  top: -15.625vw;
  left: 0;
  max-width: 72rem;
  width: 37.5vw;
}
@media screen and (max-width: 767px) {
  .show__deco--left {
    top: -11rem;
    left: 0rem;
    width: 20rem;
  }
}
.show__deco--right {
  top: -21.3541666667vw;
  right: 0;
  max-width: 78rem;
  width: 40.625vw;
}
@media screen and (max-width: 767px) {
  .show__deco--right {
    width: 22rem;
    right: 0rem;
    top: -8rem;
  }
}
.show__bg {
  background: url(../images/show-bg.png) no-repeat center -50%;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .show__bg {
    background-position: 80% 10%;
    background-size: 160% auto;
  }
}
.show__desc {
  font-size: 3.3rem;
  text-align: center;
  margin-bottom: 7rem;
}
@media screen and (max-width: 767px) {
  .show__desc {
    font-size: 1.4rem;
    margin-bottom: 4rem;
  }
}
.show .show-card {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem 3rem;
  margin: 0;
  padding: 0;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .show .show-card {
    display: flex;
    gap: 0;
  }
}
.show .show-card--ttl {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 900;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .show .show-card--ttl {
    margin-bottom: 3rem;
  }
}
.show .l-inner {
  position: relative;
  z-index: 2;
}
.show__wrap {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
}
.show__ttl {
  margin-bottom: 5rem;
  height: 16rem;
  position: relative;
}
@media screen and (max-width: 1600px) {
  .show__ttl {
    margin-bottom: 3.125vw;
    height: 8.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .show__ttl {
    height: 4rem;
    margin-bottom: 3rem;
  }
}
.show__note {
  font-size: 2rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .show__note {
    font-size: 1.3rem;
    margin-bottom: 2rem;
  }
}
.show dl {
  display: flex;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .show dl {
    margin-bottom: 1.5rem;
  }
}
.show dl:last-of-type {
  margin-bottom: 20rem;
}
@media screen and (max-width: 767px) {
  .show dl:last-of-type {
    margin-bottom: 6rem;
  }
}
.show dt {
  font-weight: bold;
  width: 15%;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .show dt {
    font-size: 1.3rem;
    width: 25%;
  }
}
.show dd {
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .show dd {
    font-size: 1.3rem;
    width: 70%;
  }
}
.show .smoke-01 {
  left: 0;
  bottom: -5.2083333333vw;
  width: 28.3333333333vw;
}
.show .smoke-02 {
  left: 0;
  bottom: -5.2083333333vw;
  width: 23.75vw;
}
.show__event-title {
  font-weight: 700;
  font-size: 2.4rem;
}
@media screen and (max-width: 767px) {
  .show__event-title {
    font-size: 1.6rem;
  }
}
.show__cmt {
  font-size: 1.7rem;
}
@media screen and (max-width: 767px) {
  .show__cmt {
    font-size: 1.2rem;
  }
}

.what-bnr {
  margin-top: 8rem;
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .what-bnr {
    margin-top: 3rem;
  }
}

.what-bnr:hover a {
  background: #0e204a;
  opacity: 1;
}

.what-bnr:hover .what-bnr-text {
  color: #fff;
}

.what-bnr a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2rem 5rem;
  border: 3px solid #fff;
  background: #000;
  color: #FF2600;
  font-weight: bold;
  text-decoration: none;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a {
    padding: 2rem 2.6041666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a {
    padding: 0;
    min-height: 7rem;
    padding-right: 3px;
    padding-left: 1rem;
    justify-content: space-between;
    align-items: stretch;
    gap: 0;
  }
}

.what-bnr a .what-bnr-text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 75%;
  font-size: 5.5rem;
  line-height: 1;
  margin-top: 0;
  font-weight: 800;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a .what-bnr-text {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-text {
    gap: 0;
    font-size: 2rem;
    line-height: 1.3;
    margin-top: 0;
    width: 60%;
    font-feature-settings: "palt";
    padding: 1rem 0;
  }
}

.what-bnr a .what-bnr-tickets {
  width: 25%;
  color: #fff;
  background: #CB0C18;
  font-style: italic;
  padding: 0 7rem 0.1rem;
  font-size: 4.5rem;
  line-height: 1.5;
  white-space: nowrap;
  font-family: "Barlow Condensed", sans-serif;
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-tickets {
    font-size: 2.5rem;
    line-height: 1.5;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.5rem;
    height: inherit;
    width: 37%;
    border: none;
    margin: 3px 0;
  }
}

.what-bnr--2 .what-bnr-text {
  background: rgb(255, 212, 102);
  background: radial-gradient(circle, rgb(255, 212, 102) 0%, rgb(255, 196, 43) 19%, rgb(255, 214, 107) 86%, rgb(255, 198, 51) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text {
    flex-direction: column;
    gap: 0;
  }
}

.what-bnr--2 .what-bnr-text span {
  font-size: 5rem;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text span {
    font-size: 1.75rem;
  }
}

.what-bnr--2:hover .what-bnr-text {
  background: rgb(255, 255, 255);
  background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 19%, rgb(255, 255, 255) 86%, rgb(255, 255, 255) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #fff;
}

.swiper-show {
  cursor: pointer; /* マウスオーバー時に手のひらアイコンに変更 */
}

.swiper-slide {
  cursor: pointer; /* 各スライド上でも手のひらアイコン */
}

.swiper-carousel-control {
  display: flex;
  justify-content: end;
  position: absolute;
  top: 11%;
  width: 95%;
  transform: translateY(-50%);
  z-index: 2;
}

.swiper-carousel-show-button-prev,
.swiper-carousel-show-button-next {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 2.5rem;
  margin-left: 0.7rem;
}

/* Sumo Show Card */
.show-card .show-item {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  border: solid 1px #fff;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .show-card .show-item {
    display: block;
    margin-bottom: 5rem;
    width: 90%;
    margin: 0 auto 5rem;
  }
}

.showticket-card__head {
  height: 100%;
}

.showticket-card__head img {
  border-radius: 8px 8px 0 0;
  width: 100%;
}

.showticket-card__body {
  background: #fff;
  color: #000;
  min-height: 19.2rem;
  height: 100%;
  padding: 1.6rem 6% 2rem 6%;
  border-radius: 0 0 6px 6px;
}
.showticket-card__body .text {
  margin-top: 1rem;
  line-height: 1.9rem;
}

.showticket-card__ttl {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: clamp(1.1rem, 2.2vw, 2.2rem);
}
@media screen and (max-width: 767px) {
  .showticket-card__ttl {
    font-size: 1.6rem;
  }
}
.showticket-card__ttl .num {
  line-height: 4.1rem;
  color: #cb0c18;
  font-family: "Barlow Condensed";
  font-size: 4.1rem;
  font-style: italic;
  font-weight: bold;
}
.showticket-card__ttl .ruby {
  line-height: 1;
  font-size: 1.4rem;
  font-weight: normal;
}
.showticket-card__ttl p {
  margin-top: 0;
  line-height: 1.3;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .showticket-card__ttl p {
    margin-top: 0.6rem;
  }
}

.show-img {
  width: calc(50% - 5rem);
  position: relative;
}
@media screen and (max-width: 767px) {
  .show-img {
    width: 100%;
    margin-bottom: 1.5rem;
  }
}

.show-icon {
  width: 15.9rem;
  height: 15.9rem;
  position: absolute;
  left: -3rem;
  top: -8rem;
}
@media screen and (max-width: 767px) {
  .show-icon {
    width: 8rem;
    height: 8rem;
    left: -1rem;
    top: -3rem;
  }
}

.show-wrap {
  width: calc(50% - 5rem);
}
@media screen and (max-width: 767px) {
  .show-wrap {
    width: 100%;
  }
}
.show-wrap .title {
  font-weight: 500;
  font-size: 3.1rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .show-wrap .title {
    font-size: 1.9rem;
    margin-bottom: 1rem;
  }
}
.show-wrap .text {
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .show-wrap .text {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .swiper-slide-show {
    /*padding-top:4rem;*/
  }
}

/* Experience */
.experience-card {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem 3rem;
  margin: 0;
  padding: 0;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .experience-card {
    display: flex;
    gap: 0;
  }
}

.experience-card--ttl {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 900;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .experience-card--ttl {
    margin-bottom: 3rem;
  }
}

.experience {
  color: #fff;
  background: #171717;
  padding-top: 7.8125vw;
  padding-bottom: 7.2916666667vw;
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .experience {
    padding-top: 8rem;
    padding-bottom: 4.5rem;
  }
}
.experience .gold-dust-02 {
  max-width: 29.2rem;
  width: 15.2083333333vw;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .experience .gold-dust-02 {
    width: 14rem;
    top: 3rem;
  }
}
.experience .gold-dust {
  max-width: 50.7rem;
  width: 26.40625vw;
  top: 40%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .experience .gold-dust {
    width: 18rem;
    top: 30%;
  }
}
.experience__top {
  position: absolute;
  top: -13.0208333333vw;
  left: 0;
  width: 100%;
}
.experience__deco {
  position: absolute;
}
.experience__deco--left {
  top: -15.625vw;
  left: 0;
  max-width: 72rem;
  width: 37.5vw;
}
@media screen and (max-width: 767px) {
  .experience__deco--left {
    top: -9rem;
    left: 0rem;
    width: 20rem;
  }
}
.experience__deco--right {
  top: -21.3541666667vw;
  right: 0;
  max-width: 78rem;
  width: 40.625vw;
}
@media screen and (max-width: 767px) {
  .experience__deco--right {
    width: 22rem;
    right: 0rem;
    top: -8rem;
  }
}
.experience__bg {
  background: url(../images/experience-bg.png) no-repeat center -10%;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .experience__bg {
    background-position: 80% 10%;
    background-size: 160% auto;
  }
}
.experience__desc {
  font-size: 3.3rem;
  text-align: center;
  margin-bottom: 7rem;
}
@media screen and (max-width: 767px) {
  .experience__desc {
    font-size: 1.4rem;
    margin-bottom: 4rem;
  }
}
.experience .l-inner {
  position: relative;
  z-index: 2;
}
.experience__wrap {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
}
.experience__ttl {
  margin-bottom: 5rem;
  height: 58rem;
  position: relative;
}
@media screen and (max-width: 1600px) {
  .experience__ttl {
    margin-bottom: 3.125vw;
    height: 33.8541666667vw;
  }
}
@media screen and (max-width: 767px) {
  .experience__ttl {
    height: 16rem;
    margin-bottom: 3rem;
  }
}
.experience__note {
  font-size: 2rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .experience__note {
    font-size: 1.3rem;
    margin-bottom: 2rem;
  }
}
.experience dl {
  display: flex;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .experience dl {
    margin-bottom: 1.5rem;
  }
}
.experience dl:last-of-type {
  margin-bottom: 20rem;
}
@media screen and (max-width: 767px) {
  .experience dl:last-of-type {
    margin-bottom: 6rem;
  }
}
.experience dt {
  font-weight: bold;
  width: 15%;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .experience dt {
    font-size: 1.3rem;
    width: 25%;
  }
}
.experience dd {
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .experience dd {
    font-size: 1.3rem;
    width: 70%;
  }
}
.experience .smoke-01 {
  left: 0;
  bottom: -5.2083333333vw;
  width: 28.3333333333vw;
}
.experience .smoke-02 {
  left: 0;
  bottom: -5.2083333333vw;
  width: 23.75vw;
}
.experience .smoke-03 {
  right: 0;
  bottom: 35rem;
  width: 33.0208333333vw;
}
.experience__event-title {
  font-weight: 700;
  font-size: 2.4rem;
}
@media screen and (max-width: 767px) {
  .experience__event-title {
    font-size: 1.6rem;
  }
}
.experience__cmt {
  font-size: 1.7rem;
}
@media screen and (max-width: 767px) {
  .experience__cmt {
    font-size: 1.2rem;
  }
}

.what-bnr {
  margin-top: 8rem;
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .what-bnr {
    margin-top: 3rem;
  }
}

.what-bnr:hover a {
  background: #0e204a;
  opacity: 1;
}

.what-bnr:hover .what-bnr-text {
  color: #fff;
}

.what-bnr a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2rem 5rem;
  border: 3px solid #fff;
  background: #000;
  color: #FF2600;
  font-weight: bold;
  text-decoration: none;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a {
    padding: 2rem 2.6041666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a {
    padding: 0;
    min-height: 7rem;
    padding-right: 3px;
    padding-left: 1rem;
    justify-content: space-between;
    align-items: stretch;
    gap: 0;
  }
}

.what-bnr a .what-bnr-text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 75%;
  font-size: 5.5rem;
  line-height: 1;
  margin-top: 0;
  font-weight: 800;
  transition: 0.3s;
}
@media screen and (max-width: 1600px) {
  .what-bnr a .what-bnr-text {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-text {
    gap: 0;
    font-size: 2rem;
    line-height: 1.3;
    margin-top: 0;
    width: 60%;
    font-feature-settings: "palt";
    padding: 1rem 0;
  }
}

.what-bnr a .what-bnr-tickets {
  width: 25%;
  color: #fff;
  background: #CB0C18;
  font-style: italic;
  padding: 0 7rem 0.1rem;
  font-size: 4.5rem;
  line-height: 1.5;
  white-space: nowrap;
  font-family: "Barlow Condensed", sans-serif;
}
@media screen and (max-width: 767px) {
  .what-bnr a .what-bnr-tickets {
    font-size: 2.5rem;
    line-height: 1.5;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.5rem;
    height: inherit;
    width: 37%;
    border: none;
    margin: 3px 0;
  }
}

.what-bnr--2 .what-bnr-text {
  background: rgb(255, 212, 102);
  background: radial-gradient(circle, rgb(255, 212, 102) 0%, rgb(255, 196, 43) 19%, rgb(255, 214, 107) 86%, rgb(255, 198, 51) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text {
    flex-direction: column;
    gap: 0;
  }
}

.what-bnr--2 .what-bnr-text span {
  font-size: 5rem;
}
@media screen and (max-width: 767px) {
  .what-bnr--2 .what-bnr-text span {
    font-size: 1.75rem;
  }
}

.what-bnr--2:hover .what-bnr-text {
  background: rgb(255, 255, 255);
  background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 19%, rgb(255, 255, 255) 86%, rgb(255, 255, 255) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #fff;
}

.swiper-experience {
  cursor: pointer; /* マウスオーバー時に手のひらアイコンに変更 */
}

.swiper-slide {
  cursor: pointer; /* 各スライド上でも手のひらアイコン */
}

.swiper-carousel-control {
  display: flex;
  justify-content: end;
  position: absolute;
  top: 11%;
  width: 95%;
  transform: translateY(-50%);
  z-index: 2;
}

.swiper-carousel-experience-button-prev,
.swiper-carousel-experience-button-next {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 2.5rem;
  margin-left: 0.7rem;
}

/* Experience Card */
.show-item {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  border: solid 1px #fff;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .show-item {
    display: block;
    margin-bottom: 5rem;
    width: 90%;
    margin: 0 auto 5rem;
  }
}

.showticket-card__head {
  height: 100%;
}

.showticket-card__head img {
  border-radius: 8px 8px 0 0;
  width: 100%;
}

.showticket-card__body {
  background: #fff;
  color: #000;
  min-height: 19.2rem;
  height: 100%;
  padding: 1.6rem 6% 2rem 6%;
  border-radius: 0 0 6px 6px;
}
.showticket-card__body .text {
  margin-top: 1rem;
  line-height: 1.9rem;
}

.showticket-card__ttl {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: clamp(1.1rem, 2.2vw, 2.2rem);
}
@media screen and (max-width: 767px) {
  .showticket-card__ttl {
    font-size: 1.6rem;
  }
}
.showticket-card__ttl .num {
  line-height: 4.1rem;
  color: #cb0c18;
  font-family: "Barlow Condensed";
  font-size: 4.1rem;
  font-style: italic;
  font-weight: bold;
}
.showticket-card__ttl .ruby {
  line-height: 1;
  font-size: 1.4rem;
  font-weight: normal;
}
.showticket-card__ttl p {
  margin-top: 0;
  line-height: 1.3;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .showticket-card__ttl p {
    margin-top: 0.6rem;
  }
}

.experience-img {
  width: calc(50% - 5rem);
  position: relative;
}
@media screen and (max-width: 767px) {
  .experience-img {
    width: 100%;
    margin-bottom: 1.5rem;
  }
}

.experience-icon {
  width: 15.9rem;
  height: 15.9rem;
  position: absolute;
  left: -3rem;
  top: -8rem;
}
@media screen and (max-width: 767px) {
  .experience-icon {
    width: 8rem;
    height: 8rem;
    left: -1rem;
    top: -3rem;
  }
}

.experience-wrap {
  width: calc(50% - 5rem);
}
@media screen and (max-width: 767px) {
  .experience-wrap {
    width: 100%;
  }
}
.experience-wrap .title {
  font-weight: 500;
  font-size: 3.1rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .experience-wrap .title {
    font-size: 1.9rem;
    margin-bottom: 1rem;
  }
}
.experience-wrap .text {
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .experience-wrap .text {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .swiper-slide-experience {
    /*padding-top:4rem;*/
  }
}

/* Cast */
.cast {
  background: #181818;
  position: relative;
  padding-top: 9rem;
  padding-bottom: 7.2916666667vw;
}
.cast__top {
  position: absolute;
  top: -13.0208333333vw;
  left: 0;
  width: 100%;
}
.cast__deco {
  position: absolute;
}
.cast__deco--left {
  top: -7.03125vw;
  left: 0;
  max-width: 72rem;
  width: 28.125vw;
}
@media screen and (max-width: 767px) {
  .cast__deco--left {
    top: -9rem;
    left: 0rem;
    width: 20rem;
  }
}
.cast__deco--right {
  top: -18.5416666667vw;
  right: 0;
  max-width: 78rem;
  width: 41.6666666667vw;
}
@media screen and (max-width: 767px) {
  .cast__deco--right {
    width: 22rem;
    right: 0rem;
    top: -8rem;
  }
}
.cast .l-inner {
  position: relative;
  z-index: 3;
  padding-top: 5rem;
}
@media screen and (max-width: 767px) {
  .cast .l-inner {
    padding-top: 0;
  }
}
.cast .deco {
  position: absolute;
}
.cast .deco--01 {
  top: 5rem;
  right: 10.4166666667vw;
  width: 34.8958333333vw;
}
@media screen and (max-width: 767px) {
  .cast .deco--01 {
    width: 25rem;
    top: -5rem;
    right: 0;
  }
}
.cast .deco--02 {
  left: -1rem;
  bottom: 0;
  width: 30.9895833333vw;
}
.cast .deco--03 {
  right: 0;
  top: 5.2083333333vw;
  width: 24.8958333333vw;
}
@media screen and (max-width: 767px) {
  .cast .deco--03 {
    right: auto;
    top: 17rem;
    left: -11rem;
    width: 20rem;
  }
}
.cast .cloud-bottom {
  width: 100%;
  bottom: -13.0208333333vw;
}
@media screen and (max-width: 767px) {
  .cast .cloud-bottom {
    bottom: -5rem;
  }
}
.cast__ttl {
  margin-bottom: 4.1666666667vw;
}
@media screen and (max-width: 767px) {
  .cast__ttl {
    width: 23rem;
    margin-bottom: 5rem;
  }
}
.cast__ttl img {
  height: 8.2291666667vw;
}
@media screen and (max-width: 767px) {
  .cast__ttl img {
    height: 4.5rem;
  }
}

.cast-cards {
  display: flex;
  gap: 3.2rem;
  flex-wrap: wrap;
  margin-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .cast-cards {
    gap: 1.5rem;
    margin-bottom: 2.5rem;
  }
}

.mc {
  width: 90%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .mc {
    width: 100%;
  }
}
.mc__ttl {
  font-size: 3.8rem;
  font-weight: 500;
  margin-bottom: 3rem;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .mc__ttl {
    font-size: 2rem;
    margin-bottom: 1.5rem;
  }
}
.mc__list {
  display: flex;
  justify-content: center;
  gap: 2rem;
}
@media screen and (max-width: 767px) {
  .mc__list {
    gap: 1rem;
  }
}

/* Cast Card */
.cast-card {
  width: calc((100% - 6.4rem) * 1 / 3);
  clip-path: polygon(100% 0, 100% 80%, 80% 100%, 0 100%, 0 0);
  background: url(../images/common/deco.png) no-repeat 160% 110%, #FFF7E5;
  background-size: 80%;
  padding: 3.7rem 0;
  position: relative;
  overflow: hidden;
  min-height: 26rem;
}
@media screen and (max-width: 767px) {
  .cast-card {
    width: calc((100% - 1.5rem) / 2);
    min-height: 15rem;
    padding: 1.4rem 0;
    clip-path: polygon(100% 0, 100% 85%, 85% 100%, 0 100%, 0 0);
    background-size: 110%;
    background-position: -130% 110%;
  }
}
.cast-card__wrap {
  max-width: 60%;
  margin-left: auto;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .cast-card__wrap {
    max-width: 65%;
  }
}
.cast-card__name {
  margin: 0 auto 3.7rem;
}
@media screen and (max-width: 767px) {
  .cast-card__name {
    margin-bottom: 1rem;
  }
}
.cast-card__name img {
  height: 5.3rem;
}
@media screen and (max-width: 767px) {
  .cast-card__name img {
    height: 2.5rem;
    margin: 0 auto;
  }
}
.cast-card__img {
  position: absolute;
  left: 0;
  bottom: 0;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .cast-card__img {
    left: -0.5rem;
  }
}
.cast-card dl {
  padding-left: 1rem;
  display: inline-flex;
  flex-direction: column;
  font-size: 1.5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .cast-card dl {
    font-size: 1rem;
    padding-left: 0.5rem;
    align-items: right;
    margin-left: 2.5rem;
  }
}
.cast-card dl::after {
  content: "";
  width: 2px;
  height: 80%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0rem;
  background: #000;
}
.cast-card--1 .cast-card__img {
  width: 19.2rem;
}
@media screen and (max-width: 767px) {
  .cast-card--1 .cast-card__img {
    width: 10.5rem;
  }
}
.cast-card--2 .cast-card__img {
  width: 21.8rem;
}
@media screen and (max-width: 767px) {
  .cast-card--2 .cast-card__img {
    width: 12rem;
  }
}
.cast-card--3 .cast-card__img {
  width: 21.8rem;
}
@media screen and (max-width: 767px) {
  .cast-card--3 .cast-card__img {
    width: 11.5rem;
  }
}
.cast-card--4 .cast-card__img {
  width: 23.5rem;
}
@media screen and (max-width: 767px) {
  .cast-card--4 .cast-card__img {
    width: 13rem;
  }
}
.cast-card--5 .cast-card__wrap {
  max-width: 50%;
}
@media screen and (max-width: 767px) {
  .cast-card--5 .cast-card__wrap {
    max-width: 65%;
  }
}
.cast-card--5 .cast-card__img {
  width: 23.5rem;
}
@media screen and (max-width: 767px) {
  .cast-card--5 .cast-card__img {
    width: 12.5rem;
  }
}
.cast-card--6 .cast-card__img {
  width: 23.5rem;
}
@media screen and (max-width: 767px) {
  .cast-card--6 .cast-card__img {
    width: 12.5rem;
  }
}

/* Cast MC */
.mc-card {
  width: calc((100% - 4rem) * 1 / 3);
}
.mc-card__img {
  width: 100%;
  min-height: 7rem;
}
.mc-card img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .mc-card img {
    height: 100%;
    object-fit: cover;
  }
}
.mc-card__name {
  background: #FFF7E5;
  text-align: center;
  font-size: 1.8rem;
  padding: 1.8rem 0;
}
@media screen and (max-width: 767px) {
  .mc-card__name {
    padding: 0.5rem 0;
    font-size: 1.3rem;
    line-height: 1.5;
  }
  .mc-card__name span {
    display: block;
    font-size: 1rem;
  }
}

/* Food & Drink */
.food {
  position: relative;
  padding-top: 14rem;
  margin-top: 16rem;
  width: 100%;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .food {
    padding-top: 9rem;
    padding-bottom: 8rem;
    margin-top: 2rem;
  }
}
.food .l-inner {
  position: relative;
  z-index: 2;
}
.food__ttl {
  margin-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .food__ttl {
    margin-bottom: 2rem;
  }
}
.food__ttl img {
  height: 16rem;
}
@media screen and (max-width: 1600px) {
  .food__ttl img {
    height: 8.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .food__ttl img {
    height: 4rem;
  }
}
.food__intro {
  font-size: 3rem;
  margin-bottom: 40rem;
}
@media screen and (max-width: 1600px) {
  .food__intro {
    font-size: 1.5625vw;
    margin-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  .food__intro {
    font-size: 1.4rem;
    margin-bottom: 18rem;
  }
}
.food__img {
  max-width: 96rem;
  width: 50vw;
  position: absolute;
  right: 0;
  top: 43rem;
  z-index: 3;
}
@media screen and (max-width: 1600px) {
  .food__img {
    top: 31.25vw;
  }
}
@media screen and (max-width: 767px) {
  .food__img {
    width: 27rem;
    top: 20rem;
  }
}
.food__cloud {
  max-width: 82.2rem;
  width: 42.8125vw;
  position: absolute;
  top: 40rem;
  left: 0;
  z-index: -1;
}
@media screen and (max-width: 1600px) {
  .food__cloud {
    top: 34.8958333333vw;
  }
}
@media screen and (max-width: 767px) {
  .food__cloud {
    width: 21rem;
    top: 22rem;
  }
}
.food .gold-dust {
  position: absolute;
  right: 5rem;
  top: -50rem;
}
@media screen and (max-width: 767px) {
  .food .gold-dust {
    width: 30rem;
    top: -20rem;
    right: 0;
  }
}

.swiper-food {
  position: relative;
  padding-top: 10rem;
}
@media screen and (max-width: 1600px) {
  .swiper-food {
    padding-top: 28rem !important;
  }
}
@media screen and (max-width: 767px) {
  .swiper-food {
    width: 90%;
    margin: 0 auto;
    overflow: visible;
    position: relative;
    padding-top: 2rem !important;
  }
}
.swiper-food .swiper-wrapper-food {
  transition-timing-function: linear;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .swiper-food .swiper-wrapper-food {
    pointer-events: visible;
  }
}
.swiper-food .swiper-slide-food {
  width: 100%;
}
.swiper-food .food-img__box {
  height: 14.5vw;
  min-height: 17.5rem;
}
.swiper-food .food-img__img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
}
.swiper-food .food-name__box {
  height: 5.7rem;
}
.swiper-food .food-name__name {
  color: #FFF;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}
.swiper-food .swiper-pagination {
  transform: translateY(150%);
}
@media screen and (max-width: 767px) {
  .swiper-food .swiper-pagination .swiper-pagination-bullet {
    background: #000;
    border-color: #000;
    background-color: #000;
    margin: 1rem;
    /*transform: scale(3);*/
  }
}

.seat {
  color: #222;
  padding-top: 14rem;
  /*padding-bottom: 10rem;*/
  position: relative;
}
@media screen and (max-width: 767px) {
  .seat {
    padding-bottom: 0;
    padding-top: 9rem;
  }
}
.seat .l-inner {
  position: relative;
  z-index: 2;
}
.seat .deco {
  position: absolute;
}
.seat .deco-01 {
  width: 34.8958333333vw;
  top: 7rem;
  right: 10rem;
}
@media screen and (max-width: 767px) {
  .seat .deco-01 {
    width: 24rem;
    top: -60rem;
    right: 12rem;
  }
}
.seat .deco-02 {
  width: 43.2291666667vw;
  top: -40rem;
  left: 0;
}
@media screen and (max-width: 767px) {
  .seat .deco-02 {
    top: -10rem;
  }
}
.seat__ttl {
  margin-bottom: 2.6041666667vw;
}
@media screen and (max-width: 767px) {
  .seat__ttl {
    margin-bottom: 2rem;
  }
}
.seat__ttl img {
  height: 16rem;
}
@media screen and (max-width: 1600px) {
  .seat__ttl img {
    height: 8.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .seat__ttl img {
    height: 4rem;
  }
}
.seat__heading {
  font-size: 4.5rem;
  margin-bottom: 6.7708333333vw;
}
@media screen and (max-width: 1600px) {
  .seat__heading {
    font-size: 1.3020833333vw;
  }
}
@media screen and (max-width: 767px) {
  .seat__heading {
    font-size: 1.7rem;
    margin-bottom: 2.5rem;
  }
}
.seat__content {
  width: 100rem;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 8.4rem;
  margin-bottom: 4.5rem;
}
@media screen and (max-width: 767px) {
  .seat__content {
    width: 100%;
    flex-direction: column;
    gap: 4rem;
    margin-bottom: 4rem;
  }
}

.seating-chart {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .seating-chart {
    width: 90%;
    margin: 0 auto;
  }
}
.seating-chart__img {
  margin-bottom: 3.5rem;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .seating-chart__img {
    margin-bottom: 2rem;
  }
  .seating-chart__img img {
    margin: 0 auto;
  }
}
.seating-chart .btn-wrap {
  text-align: left;
}
.seating-chart .open-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1.5rem;
  color: #fff;
  font-size: 1.8rem;
  background: #CB0C18;
  border-radius: 50px;
  gap: 1rem;
  margin-right: auto;
  cursor: pointer;
}
.seating-chart .open-btn .icon {
  width: 2.2rem;
  height: 2.2rem;
}

.seat-heading {
  color: #fff;
  background: #CB0C18;
  padding: 2px 1rem;
  font-size: 2.8rem;
  font-weight: 500;
  margin-bottom: 2.5rem;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .seat-heading {
    font-size: 1.6rem;
    margin-bottom: 1.5rem;
  }
}

.time {
  margin-bottom: 4.5rem;
  text-align: center;
  width: 54rem;
}
@media screen and (max-width: 767px) {
  .time {
    width: 100%;
    margin-bottom: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .time__table {
    overflow: scroll;
  }
}
.time table {
  border-collapse: collapse;
  width: 100%;
  margin: 0 auto;
}
.time th, .time td {
  border: 1px solid #ddd;
  padding: 1rem;
  text-align: center;
  font-size: 1.8rem;
  vertical-align: middle;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .time th, .time td {
    font-size: 1.4rem;
    padding: 1rem 0;
  }
}
.time th .count, .time td .count {
  display: block;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .time th .count, .time td .count {
    font-size: 1rem;
  }
}
.time th .yen, .time td .yen {
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  .time th .yen, .time td .yen {
    font-size: 1rem;
  }
}
.time th {
  background-color: #FFE9EA;
  font-size: 2rem;
  font-weight: 500;
  height: 4rem;
  width: 27rem;
}
@media screen and (max-width: 767px) {
  .time th {
    font-size: 1.5rem;
    height: auto;
  }
}
.time td {
  background: #fff;
  height: 6rem;
}
@media screen and (max-width: 767px) {
  .time td {
    height: 4.5rem;
  }
}
.time__table-overflow {
  /*min-width:45rem;*/
}

.price {
  text-align: center;
  width: 80%;
  margin: 0 auto 8rem auto;
}
@media screen and (max-width: 767px) {
  .price {
    width: 100%;
    margin: 0 auto 5rem auto;
  }
}
.price__table {
  padding-bottom: 15rem;
}
@media screen and (max-width: 767px) {
  .price__table {
    overflow: scroll;
    margin-top: 4rem;
    padding-bottom: 0;
  }
}
.price table {
  border-collapse: collapse;
  width: 100%;
  margin: 0 auto;
  height: 100%;
}
.price th, .price td {
  border: 1px solid #ddd;
  padding: 1rem;
  text-align: center;
  font-size: 1.8rem;
  vertical-align: middle;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .price th, .price td {
    font-size: 1.4rem;
    padding: 1rem 0;
  }
}
.price th .count, .price td .count {
  display: block;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .price th .count, .price td .count {
    font-size: 1rem;
  }
}
.price th .yen, .price td .yen {
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  .price th .yen, .price td .yen {
    font-size: 1rem;
  }
}
.price th {
  background-color: #FFE9EA;
  font-size: 1.4rem;
  font-weight: 500;
  height: 5rem;
  padding: clamp(1.2rem, 2.4vw, 1rem) clamp(0.5rem, 1vw, 1rem);
}
@media screen and (max-width: 767px) {
  .price th {
    height: auto;
    font-weight: 400;
  }
}
.price td {
  background: #fff;
  height: 6rem;
}
@media screen and (max-width: 767px) {
  .price td {
    height: 4.5rem;
  }
}
.price .rank {
  border-bottom: 2px solid #333;
}
.price .rank {
  border-bottom: 2px solid #333;
}
.price .s-seat .rank {
  border-color: #C8152D;
}
.price .a-seat .rank {
  border-color: #22AC38;
}
.price .b-seat .rank {
  border-color: #E7010D;
}
.price .bl-seat_old .rank {
  border-color: #FFFFFF;
}
.price .pre-seat .rank {
  border-color: #C8152D;
  white-space: nowrap;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .price .pre-seat .rank {
    font-size: 1rem;
  }
}
.price .stan-seat .rank {
  border-color: #00ABEB;
  white-space: nowrap;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .price .stan-seat .rank {
    font-size: 1rem;
  }
}
.price .bl-seat .rank {
  border-color: #5F5497;
  white-space: nowrap;
  font-size: 1.4rem;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .price .bl-seat .rank {
    font-size: 1rem;
  }
}
.price .category--workshop {
  width: 40rem;
}
@media screen and (max-width: 767px) {
  .price .category--workshop {
    width: 13rem;
  }
}
.price__table-overflow {
  /*min-width: 50rem;*/
}

.price-show__table {
  margin-top: 2.5rem;
  width: 100%;
  height: 100%;
  font-size: clamp(1rem, 1.4vw, 1.4rem);
}
.price-show__table--flex {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 5rem;
  text-align: center;
  align-items: stretch;
}
@media screen and (max-width: 767px) {
  .price-show__table--flex {
    display: block;
    margin-top: 2rem;
  }
}
.price-show__table--caption {
  margin-top: 1rem;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .price-show__table--caption {
    margin-top: 2rem;
  }
}
.price-show__table--subttl {
  display: inline-block;
  padding: 0 2.2rem 1rem;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 3.3rem;
}
.price-show__table--subttl span {
  font-size: 2rem;
  font-style: normal;
  font-weight: 400;
}
.price-show__table--box {
  min-height: 8rem;
}

.asterisk {
  font-size: 1.5rem;
  text-align: left;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .asterisk {
    font-size: 1.4rem;
    margin-top: 4rem;
  }
}

.modal {
  display: none;
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.8);
}

.modal-content {
  position: relative;
  margin: auto;
  padding: 20px;
  padding-top: 50px;
  width: 80%;
  max-width: 1000px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    overflow: scroll;
  }
}

.close, .close_old {
  color: #fff;
  position: absolute;
  top: 10px;
  right: 25px;
  font-size: 35px;
  font-weight: bold;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .close, .close_old {
    position: fixed;
  }
}

.modal-image {
  width: 95%;
  height: auto;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .modal-content {
    width: 100%;
    padding: 0;
  }
  .close, .close_old {
    font-size: 3rem;
    top: -1.7rem;
    right: 0.5rem;
  }
}
.tickets-range-title {
  text-align: center;
  font-weight: 500;
  font-size: 1.8rem;
  margin: 9rem auto 7rem auto;
  scroll-margin-top: 10rem;
  background-color: #000;
  padding: 1rem 0;
  width: 80%;
}
@media screen and (max-width: 767px) {
  .tickets-range-title {
    margin: 5rem 0 4rem 0;
    padding: 0;
    width: 100%;
  }
}

.tickets-range-title span {
  color: #FFF;
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 1.4px;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .tickets-range-title span {
    font-size: 1.4rem;
    padding: 0.5rem 1.9rem;
  }
}

.tickets-range-title span span {
  font-size: 3.3rem;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .tickets-range-title span span {
    font-size: 1.6rem;
  }
}

/* Access */
.access {
  background: #F3F3F3;
  padding-top: 7.8125vw;
  padding-bottom: 1.0416666667vw;
}
@media screen and (max-width: 767px) {
  .access {
    background: #fff;
    padding-top: 9rem;
    padding-bottom: 3rem;
  }
}
.access__inner {
  margin: 0 auto;
  width: 1440px;
}
@media screen and (max-width: 1500px) {
  .access__inner {
    width: 90%;
  }
}
@media screen and (max-width: 767px) {
  .access__inner {
    width: 100%;
  }
}
.access__ttl {
  margin-bottom: 4.1666666667vw;
}
@media screen and (max-width: 767px) {
  .access__ttl {
    width: 23rem;
    margin-bottom: 3rem;
  }
}
.access__ttl img {
  height: 8.3333333333vw;
}
@media screen and (max-width: 767px) {
  .access__ttl img {
    height: 4rem;
  }
}
.access__address {
  font-size: 1.71875vw;
  font-weight: 500;
  margin-bottom: 2.3958333333vw;
}
@media screen and (max-width: 767px) {
  .access__address {
    margin-bottom: 2.5rem;
    font-size: 1.4rem;
  }
}
.access__map {
  position: relative;
  width: 100%;
  padding-bottom: 38.19%; /* 550px / 1440px * 100 */
  overflow: hidden;
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .access__map {
    padding-bottom: 75%;
    margin-bottom: 3.5rem;
  }
}
.access__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.transit {
  background: #fff;
  margin-bottom: 4rem;
  padding: 8rem 10rem;
  display: flex;
  flex-direction: column;
  gap: 6rem;
}
@media screen and (max-width: 1500px) {
  .transit {
    padding: 4.1666666667vw 8.8541666667vw;
  }
}
@media screen and (max-width: 767px) {
  .transit {
    padding: 0 2.5rem;
    margin-bottom: 4rem;
    gap: 5rem;
  }
}
.transit__heading {
  font-size: 2.2rem;
  font-weight: 500;
  margin-bottom: 4.3rem;
}
@media screen and (max-width: 767px) {
  .transit__heading {
    font-size: 1.4rem;
    margin-bottom: 2.5rem;
    text-align: center;
  }
}

.transit-list {
  display: flex;
  flex-direction: column;
  gap: 4.3rem;
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  .transit-list {
    flex-direction: row;
    gap: 2rem;
    justify-content: center;
  }
}
.transit-list__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  width: 82%;
}
@media screen and (max-width: 767px) {
  .transit-list__item {
    flex-direction: column;
    min-height: 28rem;
    width: calc((100% - 4rem) * 1 / 3);
    margin-bottom: 5rem;
  }
}
.transit-list__item .minutes {
  font-size: 1.2rem;
  background: #fff;
  padding: 1rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -23%;
}
@media screen and (max-width: 1500px) {
  .transit-list__item .minutes {
    font-size: 0.625vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list__item .minutes {
    font-size: 1rem;
    top: auto;
    bottom: -6rem;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    padding: 0.5rem 0;
    right: auto;
    text-align: center;
  }
}
.transit-list__item::before {
  content: "";
  width: 7rem;
  height: 1px;
  background: #000;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -7rem;
}
@media screen and (max-width: 1500px) {
  .transit-list__item::before {
    width: 2.0833333333vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list__item::before {
    width: 1px;
    height: 100%;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
.transit-list .from {
  background: #F3F3F3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 19rem;
  height: 8.6rem;
  padding: 1rem;
  font-size: 2.2rem;
  font-weight: 500;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1500px) {
  .transit-list .from {
    width: 11.9791666667vw;
    height: 4.4791666667vw;
    font-size: 1.0416666667vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list .from {
    flex-direction: column;
    font-size: 1.3rem;
    width: 100%;
    height: 7rem;
    padding: 0.5rem;
  }
}
.transit-list .line {
  background: #fff;
  font-size: 1.2rem;
  padding: 1rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1500px) {
  .transit-list .line {
    font-size: 0.625vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list .line {
    padding: 0.5rem;
    font-size: 1.1rem;
    line-height: 1.3;
    text-align: center;
    white-space: nowrap;
  }
}
.transit-list .via {
  font-size: 1.7rem;
  background: #F3F3F3;
  padding: 2rem 1rem;
  font-weight: 500;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1500px) {
  .transit-list .via {
    font-size: 0.8854166667vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list .via {
    width: 100%;
    text-align: center;
    font-size: 1.3rem;
    padding: 0.5rem;
  }
}
.transit-list .icon {
  margin-right: 1rem;
  width: 1.9rem;
  height: 1.9rem;
}
@media screen and (max-width: 1500px) {
  .transit-list .icon {
    width: 1.0416666667vw;
    height: 1.0416666667vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list .icon {
    width: 1.5rem;
    height: 1.5rem;
    margin-right: 0;
    position: relative;
    top: -0.5rem;
  }
}
.transit-list .to {
  color: #CB0C18;
  font-size: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #F3F3F3;
  width: 16rem;
  height: 5rem;
  font-weight: bold;
  position: relative;
  z-index: 2;
  text-align: center;
}
@media screen and (max-width: 1500px) {
  .transit-list .to {
    font-size: 1.1458333333vw;
    width: 8.3333333333vw;
    height: 2.6041666667vw;
  }
}
@media screen and (max-width: 767px) {
  .transit-list .to {
    width: 100%;
    font-size: 1.3rem;
    height: auto;
    padding: 0.5rem 0;
  }
}
.transit-list .border {
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .transit-list .border {
    width: 1px;
    height: 3rem;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%) translateY(100%);
  }
}

.howto__wrap {
  display: flex;
  flex-direction: column;
  gap: 5rem;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .howto__wrap {
    gap: 2rem;
  }
}
.howto__heading {
  text-align: center;
}
.howto__heading span {
  font-size: 2.8rem;
  color: #fff;
  font-weight: 500;
  background: #CB0C18;
  padding: 0 1rem;
}
@media screen and (max-width: 767px) {
  .howto__heading span {
    font-size: 2rem;
    padding: 0.5rem 1rem;
  }
}
.howto__movie {
  display: flex;
  justify-content: center;
  gap: 0;
}
@media screen and (max-width: 767px) {
  .howto__movie {
    flex-direction: column;
    gap: 2rem;
  }
}
.howto__movie li {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  min-width: 37rem;
}
@media screen and (max-width: 767px) {
  .howto__movie li {
    gap: 1rem;
  }
}
.howto__ttl {
  font-size: 2.2rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .howto__ttl {
    font-size: 1.4rem;
  }
}
.howto__ttl span {
  font-weight: bold;
  color: #CB0C18;
}
@media screen and (max-width: 767px) {
  .howto__img {
    width: 20rem;
    margin: 0 auto;
  }
}
.howto__img img {
  margin: 0 auto;
  cursor: pointer;
}
.howto__text {
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 5rem;
}
.howto__btn {
  text-align: center;
}
.howto__btn a {
  background: #CB0C18;
  color: #fff;
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  position: relative;
  padding: 0.5rem 3rem 0.5rem 2rem;
  gap: 1rem;
}
.howto__btn a::after {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: 50%;
  right: 1.5rem;
  transform: translateY(-50%) rotate(45deg);
}
.howto__btn .icon {
  width: 2.8rem;
  height: 2.8rem;
}

/* Ticket */
.ticket {
  background: url(../images/ticket-bg.jpg) no-repeat center center;
  background-size: cover;
  color: #fff;
  padding-top: 13rem;
  padding-bottom: 8rem;
}
@media screen and (max-width: 767px) {
  .ticket {
    background: url(../images/ticket-bg-sp.jpg) no-repeat center center;
    background-size: cover;
    padding-top: 9rem;
  }
}
.ticket__ttl {
  margin-bottom: 6rem;
}
@media screen and (max-width: 767px) {
  .ticket__ttl {
    margin-bottom: 3rem;
  }
}
.ticket__ttl img {
  height: 8.3333333333vw;
}
@media screen and (max-width: 767px) {
  .ticket__ttl img {
    height: 4rem;
  }
}
.ticket__text {
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .ticket__text {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}
.ticket__text--contact {
  margin-top: 1.8rem;
  font-size: 2.2rem;
  font-weight: 900;
}
.ticket__text--mail {
  font-size: 2.2rem;
}
@media screen and (max-width: 767px) {
  .ticket__text--mail {
    font-size: 1.4rem;
  }
}
.ticket__heading {
  font-weight: bold;
  font-size: 5.5rem;
  text-align: center;
  margin-bottom: 4.5rem;
}
@media screen and (max-width: 767px) {
  .ticket__heading {
    font-size: 2.7rem;
    margin-bottom: 2rem;
  }
}
.ticket__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5.6rem;
  margin-bottom: 4.8rem;
}
@media screen and (max-width: 767px) {
  .ticket__wrap {
    gap: 2.6rem;
    margin-bottom: 4rem;
  }
}
.ticket__link {
  display: block;
  width: 24.5rem;
  height: 24.5rem;
  background: #CB0C18;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.3s;
}
.ticket__link:hover {
  opacity: 0.6;
}
@media screen and (max-width: 767px) {
  .ticket__link {
    width: 12rem;
    height: 12rem;
  }
}
.ticket__link span {
  display: inline-block;
  position: relative;
  font-size: 3.3rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .ticket__link span {
    font-size: 1.6rem;
  }
}
.ticket__link span::after {
  content: "";
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  width: 1.5rem;
  height: 1.5rem;
  display: inline-block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  right: -2rem;
}
@media screen and (max-width: 767px) {
  .ticket__link span::after {
    width: 1.2rem;
    height: 1.2rem;
    right: -1.5rem;
  }
}
.ticket__terms {
  text-align: center;
}
.ticket__terms a {
  padding: 2px 5rem;
  font-weight: 500;
  color: #222;
  font-size: 1.8rem;
  display: inline-block;
  background: #fff;
  border-radius: 50px;
  text-align: left;
  position: relative;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .ticket__terms a {
    padding: 2px 2.5rem;
    font-size: 1.1rem;
    text-align: center;
  }
}
.ticket__terms a::after {
  content: "";
  border-top: 2px solid #222;
  border-right: 2px solid #222;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  right: 2rem;
  width: 1rem;
  height: 1rem;
  transition: 0.5s;
}
@media screen and (max-width: 767px) {
  .ticket__terms a::after {
    width: 0.8rem;
    height: 0.8rem;
    border-top: 1px solid #222;
    border-right: 1px solid #222;
    right: 1.3rem;
  }
}
.ticket__terms a:hover {
  opacity: 0.6;
}
.ticket__terms a:hover:after {
  transform: translate(3px, -50%) rotate(45deg);
}

/* Footer */
.footer {
  background: url(../images/footer-bg.jpg) no-repeat center center;
  background-size: cover;
  margin-top: 17rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .footer {
    margin-top: 7rem;
    margin-bottom: 7rem;
    background: url(../images/footer-bg-sp.jpg) no-repeat center center;
    background-size: cover;
  }
}
.footer__wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  gap: 3rem;
  padding-top: 7rem;
  padding-bottom: 7rem;
}
@media screen and (max-width: 767px) {
  .footer__wrap {
    gap: 2.5rem;
    padding-top: 5rem;
    padding-bottom: 5rem;
    width: 85%;
  }
}
.footer__logo img {
  width: 26rem;
}
@media screen and (max-width: 767px) {
  .footer__logo img {
    width: 16rem;
  }
}

.footer-nav {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .footer-nav {
    flex-wrap: wrap;
  }
}
.footer-nav__item {
  color: #fff;
  font-size: 1.8rem;
  font-family: "Inika", serif;
}
@media screen and (max-width: 767px) {
  .footer-nav__item {
    font-size: 1.4rem;
  }
}
.footer-nav__item a {
  display: block;
  padding: 0 1rem;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .footer-nav__item a {
    padding: 1rem;
  }
}
.footer-nav__item a:hover {
  opacity: 0.6;
}

.footer-sns {
  display: flex;
  justify-content: center;
  align-items: center;
}
.footer-sns__item {
  width: 5.2rem;
  height: 5.2rem;
}
.footer-sns__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  transition: 0.2s;
}
.footer-sns__item a:hover {
  opacity: 0.6;
}

.pagetop {
  color: #000;
  font-size: 1.8rem;
  line-height: 1;
  text-align: center;
  position: fixed;
  bottom: 5rem;
  right: 2rem;
  z-index: 997;
  width: 14.2rem;
  height: 14.2rem;
  cursor: pointer;
  transition: 0.5s;
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .pagetop {
    width: 7rem;
    height: 7rem;
    bottom: 12rem;
  }
}
.pagetop.active {
  opacity: 1;
  pointer-events: all;
}
.pagetop img {
  transition: 0.2s;
}
.pagetop:hover img {
  opacity: 0.5;
}

/* カレンダー */
.calendar {
  margin-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .calendar {
    margin-bottom: 5rem;
    width: 100%;
  }
}
.calendar-inner {
  width: 100rem;
  margin: 0 auto !important;
  display: none;
}
@media screen and (max-width: 767px) {
  .calendar-inner {
    width: 90%;
    margin: 0 auto !important;
  }
}
.calendar-inner.active {
  display: block;
}

.weekly {
  display: flex;
  justify-content: center;
  align-items: stretch;
}
@media screen and (max-width: 767px) {
  .weekly {
    display: block;
  }
}

.day_header {
  width: 14%;
  height: 2.9rem;
  border: 1px solid #ccc !important;
  color: #fff;
  text-align: center;
  font-weight: 700;
}
.day_header.weekday {
  background-color: #000;
}
.day_header.saturday {
  background-color: #03f;
}
.day_header.holiday {
  background-color: #cb0c18;
}

.day {
  width: 14%;
  min-height: 13rem;
  border: 1px solid #ccc !important;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .day {
    width: 100%;
    display: flex;
    justify-content: stretch;
    align-items: center;
    height: auto;
    min-height: 4.3rem;
    border-top: 1px solid #ccc !important;
    border-right: 2px solid #ccc !important;
    border-bottom: 1px solid #ccc !important;
    border-left: 2px solid #ccc !important;
  }
}
.day-number {
  font-weight: 700;
  font-size: 1.6rem;
  margin-top: 0.3rem !important;
  margin-left: 1.35rem !important;
}
@media screen and (max-width: 767px) {
  .day-number {
    font-weight: 700;
    font-size: 1.3rem;
    margin-top: 0rem !important;
    margin-left: 0rem !important;
    width: 30%;
    min-width: 30%;
    text-align: center;
  }
}
.day.saturday {
  color: #03f;
}
.day.holiday {
  color: #cb0c18;
}
.day.unnec.is-pc-flex {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .day.unnec.is-pc-flex {
    display: none !important;
  }
}
.day.unnec .day-number {
  opacity: 0.4;
}
@media screen and (max-width: 767px) {
  .day.unnec .day-number {
    opacity: 1;
  }
}
.day.calendar-close {
  background-color: #ebebeb;
  position: relative;
}
.day.calendar-close .event {
  font-weight: 400;
  color: #7d7d7d;
  position: absolute;
  bottom: 0;
  right: 0;
  width: auto;
}
@media screen and (max-width: 767px) {
  .day.calendar-close .event {
    position: unset;
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  .day--extra {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .day--opacity {
    overflow: hidden; /* 内容がボックスからはみ出さないようにする */
    position: relative;
    /* ここでグラデーションでフェード効果 */
    mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 10%, rgba(0, 0, 0, 0) 60%);
    -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 10%, rgba(0, 0, 0, 0) 60%);
  }
}

@media screen and (max-width: 767px) {
  .events {
    min-height: 4.3rem;
    border-left: 2px solid #CCC;
  }
}

.event {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 0.5rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .event {
    width: 100%;
    min-height: 4.2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    padding: 0.5rem;
    gap: 0.3rem;
    position: relative;
    margin-top: 0;
    padding-left: 2rem;
  }
}

.event-title {
  border-radius: 2.6rem;
  display: flex;
  width: 85%;
  height: auto;
  justify-content: center;
  align-items: center;
  font-size: 1.3rem;
  padding: 0 1rem;
}
@media screen and (max-width: 767px) {
  .event-title {
    margin-right: 5px !important;
    width: 13rem;
  }
}
.event-title.sumoshow {
  border: 1px solid #000;
  background: #000;
  color: #fff;
}
.event-title.workshop {
  border: 1px solid #cb0c18;
  background: #cb0c18;
  color: #fff;
}
.event-title.other {
  border: 1px solid #cb0c18;
  background-color: #fff;
  color: #cb0c18;
}

.event-time {
  color: #000;
  margin-top: 0 !important;
}
@media screen and (max-width: 767px) {
  .event-time {
    font-size: 1.3rem;
    margin-left: 10px !important;
  }
}

.is-pc-flex {
  display: flex !important;
}
@media screen and (max-width: 767px) {
  .is-pc-flex {
    display: none !important;
  }
}

.calendar-comment {
  font-size: 1.4rem;
  width: 100rem;
  margin: 0 auto;
  padding: 1rem;
}
@media screen and (max-width: 767px) {
  .calendar-comment {
    font-size: 1.4rem;
    width: 90%;
    margin: 2.5rem auto 0 auto;
  }
}
.calendar-comment p + p {
  margin-top: 0 !important;
}
.calendar-comment span {
  color: red;
}

.move-month {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 2.5rem;
  width: 96%;
  margin: 0 auto 1rem auto !important;
  width: 100rem;
}
@media screen and (max-width: 767px) {
  .move-month {
    flex-direction: column;
    gap: 1.5rem;
    width: 100%;
    align-items: center;
  }
}
.move-month__links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
}
.move-month__link {
  padding: 1rem 7.5rem;
  border-radius: 4.2rem;
  border: 1px solid #cb0c18;
  color: #cb0c18 !important;
  background: #fff;
  text-decoration: none !important;
  position: relative;
}
@media screen and (max-width: 767px) {
  .move-month__link {
    padding: 0.6rem 3.1rem;
  }
}
.move-month__link:hover {
  border: 1px solid #cb0c18;
  color: #fff !important;
  background: #cb0c18;
}
.move-month__arrow {
  position: absolute;
  font-size: 1.4rem;
}
.move-month__arrow.next-month {
  right: 3rem;
}
@media screen and (max-width: 767px) {
  .move-month__arrow.next-month {
    right: 1rem;
  }
}
.move-month__arrow.prev-month {
  left: 3rem;
}
@media screen and (max-width: 767px) {
  .move-month__arrow.prev-month {
    left: 1rem;
  }
}
.move-month__display-month {
  font-size: 3.2rem;
}
.move-month__display-month span {
  font-size: 2rem;
}

.is-hidden {
  visibility: hidden;
  pointer-events: none;
}

.calendar-ttl {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .calendar-showmore__btn {
    display: flex;
    height: 4.1rem;
    padding: 0.5rem 2rem;
    justify-content: center;
    align-items: center;
    gap: 1.6rem;
    border-radius: 2.1rem;
    border: 1px solid #CB0C18;
    background: #FFF;
    color: #CB0C18;
    font-size: 1.3rem;
    margin: 0 auto;
  }
}

.day-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .day-visible {
    display: flex;
  }
}
