@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: #222;
  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;
}

a:hover {
  opacity: 0.8;
}

@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";
}

.is-menu-open .h-top {
  background-color: rgba(207, 207, 207, 0.7) !important;
}

/* 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(207, 207, 207, 0.7);
  transform: translateY(0);
  transition: transform 0.7s ease-in-out;
  z-index: 950;
}
@media screen and (max-width: 767px) {
  .header {
    background: rgba(207, 207, 207, 0.7);
    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: 2rem;
}
@media screen and (max-width: 767px) {
  .header.h-top {
    top: 0;
    padding: 1.2rem 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;
    width: 100%;
  }
}
.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: 11rem;
    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;
}
@media screen and (max-width: 767px) {
  .header__nav {
    align-items: start;
    width: 100%;
  }
}
.header__logo {
  width: 18rem;
  order: 1;
}
@media screen and (max-width: 1280px) {
  .header__logo {
    width: 8%;
  }
}
@media screen and (max-width: 767px) {
  .header__logo {
    width: 12rem;
    order: 2;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.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: 4.7rem;
  height: 6.2rem;
}

.menu {
  position: fixed;
  top: 0;
  right: 0;
  background-image: url("../images/about_sub_back_img_pc.png");
  background-size: 1920px auto;
  opacity: 0;
  z-index: 998 !important;
  width: 100%;
  height: 100%;
  transition: 0.5s;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .menu {
    background-image: url("../images/about_sub_back_img_sp.png");
    background-size: 750px auto;
  }
}
.menu__list {
  position: absolute;
  transform: translate(-50%, -50%);
  top: clamp(170px, 75vw, 485px);
  left: 50%;
  color: #fff;
}
.menu.open {
  opacity: 1;
  pointer-events: auto;
}

.header-nav {
  display: flex;
  align-items: center;
  justify-content: right;
  color: #000;
  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;
  font-weight: 500;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .header-nav__item a {
    padding: 1vw 1rem;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 700;
  }
}
.header-nav__item a:hover {
  opacity: 0.5;
}

.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;
}
.language-btn:hover {
  opacity: 0.5;
}
@media screen and (max-width: 1000) {
  .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__nami-bg {
  position: absolute;
  width: 100%;
  bottom: 6rem;
  transform: scale(1.05);
  transition: transform 2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .mv__nami-bg {
    width: clamp(75rem, 195.31vw, 150rem);
    height: auto;
    left: -50%;
  }
}
.mv__sumo {
  position: absolute;
  width: clamp(45rem, 46.88vw, 90rem);
  bottom: -5rem;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .mv__sumo {
    width: 100%;
  }
}
.mv__ring {
  position: absolute;
  bottom: -7rem;
  transform: scale(1.4);
}
@media screen and (max-width: 767px) {
  .mv__ring {
    bottom: 1rem;
    transform: scale(5);
  }
}
.mv__nami-left {
  position: absolute;
  width: clamp(66.7rem, 69.48vw, 133.4rem);
  bottom: -16%;
  left: -40%;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .mv__nami-left {
    width: 100%;
    bottom: -8%;
    left: -60%;
  }
}
.mv__nami-right {
  position: absolute;
  width: clamp(66.7rem, 69.48vw, 133.4rem);
  bottom: -14%;
  right: -37%;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .mv__nami-right {
    width: 100%;
    bottom: -8%;
    right: -60%;
  }
}
.mv-text {
  position: absolute;
  bottom: 13rem;
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}
@media screen and (max-width: 767px) {
  .mv-text {
    bottom: 3rem;
    gap: 0.4rem;
  }
}
.mv-text P {
  opacity: 0;
}
.mv-text--01 {
  color: #fff;
  text-shadow: 0 0 1rem #000, 0 0 1.5rem #000;
  font-size: clamp(22px, 2.5vw, 48px);
  font-style: italic;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.192rem;
  padding-left: 4rem;
}
@media screen and (max-width: 767px) {
  .mv-text--01 {
    text-shadow: 0px 0px 0.363rem #000, 0px 0px 0.55rem #000;
    font-size: 1.74rem;
    letter-spacing: 1.393px;
    padding-left: 1.4rem;
  }
}
.mv-text--02 {
  color: #fff;
  font-size: clamp(27px, 2.9166666667vw, 56px);
  font-style: italic;
  font-weight: 700;
  line-height: 110%;
  letter-spacing: 0.24rem;
  display: flex;
  padding: 1.3rem 3rem 3rem 4rem;
  justify-content: start;
  align-items: center;
  gap: 0.7292rem;
  align-self: stretch;
  background: #cb0c18;
  box-shadow: 0 1rem 2rem 0 rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 767px) {
  .mv-text--02 {
    font-size: 1.9rem;
    letter-spacing: 0.08rem;
    padding: 0.8rem 0.5rem 0.8rem 1.4rem;
  }
}
.mv-text--03 {
  display: flex;
  padding: 1rem 3rem 2rem 4rem;
  justify-content: start;
  align-items: center;
  gap: 0.7823rem;
  background: #222;
}
@media screen and (max-width: 767px) {
  .mv-text--03 {
    padding: 1rem 0.5rem 1rem 1.4rem;
  }
}
.mv-text--03 span {
  background: linear-gradient(180deg, #e2c59a 0%, #caa974 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: clamp(27px, 2.9166666667vw, 56px);
  font-style: italic;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.24rem;
  padding: 1rem 0.5rem 1rem 0;
  max-width: 60vw;
}
@media screen and (max-width: 999px) {
  .mv-text--03 span {
    font-size: 4.5rem;
    letter-spacing: 0.08rem;
  }
}
@media screen and (max-width: 767px) {
  .mv-text--03 span {
    font-size: 1.7rem;
    letter-spacing: 0.08rem;
    max-width: none;
  }
}

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

/* ABOUT */
.about {
  width: 100%;
  padding-bottom: 40rem;
  background-image: url(../images/about_middle_bottom_img_pc.png), url(../images/about_back_img.jpg);
  background-position: center calc(100% + 3px), center;
  background-repeat: no-repeat, no-repeat;
  background-size: 1920px auto, cover;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about {
    padding-bottom: 11.5rem;
    background-image: url(../images/about_middle_bottom_img_sp.png), url(../images/about_back_img_sp.jpg), url(../images/white_texture_sp.png);
    background-position: center calc(100% + 3px), center calc(100% - 25px), center top;
    background-repeat: no-repeat, no-repeat, repeat;
    background-size: 750px auto, contain, contain;
  }
}
@media screen and (min-width: 1921px) {
  .about {
    background-size: contain, cover;
  }
}
.about__open-text {
  font-size: 3rem;
  font-weight: 600;
  line-height: 180%;
  padding-top: 10.5rem;
}
@media screen and (max-width: 767px) {
  .about__open-text {
    font-size: 1.5rem;
    padding: 6rem 1rem 0 1rem;
  }
}
.about__open-text--red {
  color: #cb0c18;
}
.about__title {
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 100%; /* 216px */
  margin-top: 3rem;
  letter-spacing: 0.9rem;
  scroll-margin-top: 12rem;
}
@media screen and (max-width: 767px) {
  .about__title {
    font-size: 4.5rem;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
    padding: 0 1rem;
  }
}
.about__sub-title {
  font-family: "Playfair Display";
  font-size: 18rem;
  font-weight: 700;
  line-height: 100%; /* 180px */
  background: linear-gradient(180deg, #ceab77 34.13%, #c4a671 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .about__sub-title {
    font-size: 4.5rem;
    line-height: 100%; /* 90px */
    letter-spacing: 0;
    padding: 0 1rem;
  }
}
.about .l-inner {
  position: relative;
  z-index: 2;
}
.about__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 4.6vw;
  right: 10vw;
}
@media screen and (max-width: 767px) {
  .about__cloud {
    width: 23.65rem;
    height: 13.65rem;
    top: 4.6vw;
    right: -4vw;
  }
}
.about__gold-dust {
  width: 52.9rem;
  height: 72.1rem;
  position: absolute;
  top: 10vw;
  right: 4.8vw;
}
@media screen and (max-width: 767px) {
  .about__gold-dust {
    width: 18.7rem;
    height: 25.5rem;
    position: absolute;
    top: 18vw;
    right: -0.2vw;
  }
}

.about-concept {
  margin: 5rem auto 0 auto;
}
@media screen and (max-width: 767px) {
  .about-concept {
    margin: 3rem auto 0 auto;
  }
}
.about-concept__inner {
  text-align: center;
}
.about-concept__text {
  font-size: 3rem;
  font-weight: 600;
  line-height: 180%; /* 54px */
  text-align: center;
}
@media screen and (max-width: 767px) {
  .about-concept__text {
    font-size: 1.5rem;
    line-height: 180%; /* 54px */
    padding: 0 1rem;
    text-align: left;
  }
}
.about-concept__img {
  width: 108rem;
  height: auto;
  margin: 6rem auto 0 auto;
}
@media screen and (max-width: 767px) {
  .about-concept__img {
    width: 34.5rem;
    margin: 3rem auto 0 auto;
  }
}

.about-sub {
  background-image: url(../images/about_sub_back_img_pc.png);
  background-repeat: repeat;
  background-size: 1920px auto;
  padding-bottom: 2rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-sub {
    background-image: url(../images/about_sub_back_img_sp.png);
    background-size: 750px auto;
    padding-top: 3rem;
    padding-bottom: 1rem;
  }
}
.about-sub-sumo-show, .about-sub-cuisine, .about-sub-sake-bar {
  margin-bottom: 8rem;
  position: relative;
  z-index: 2;
  scroll-margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .about-sub-sumo-show, .about-sub-cuisine, .about-sub-sake-bar {
    margin-bottom: 2rem;
    padding: 0 1rem;
  }
}
.about-sub-sumo-show__title, .about-sub-cuisine__title, .about-sub-sake-bar__title {
  font-family: "Playfair Display";
  font-size: 18rem;
  font-weight: 700;
  line-height: 100%; /* 180px */
  padding-top: 5rem;
  background: linear-gradient(180deg, #ceab77 34.13%, #c4a671 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .about-sub-sumo-show__title, .about-sub-cuisine__title, .about-sub-sake-bar__title {
    font-size: 4.5rem;
    line-height: 120%; /* 108px */
    padding-top: 2rem;
    letter-spacing: 0;
  }
}
.about-sub-sumo-show__detail, .about-sub-cuisine__detail, .about-sub-sake-bar__detail {
  width: 98rem;
  height: auto;
  margin: 7rem auto 0 auto;
}
@media screen and (max-width: 767px) {
  .about-sub-sumo-show__detail, .about-sub-cuisine__detail, .about-sub-sake-bar__detail {
    width: 100%;
    margin: 3rem auto 0 auto;
  }
}
.about-sub-sumo-show__detail .img, .about-sub-cuisine__detail .img, .about-sub-sake-bar__detail .img {
  width: 100%;
}
.about-sub-sumo-show__exp, .about-sub-cuisine__exp, .about-sub-sake-bar__exp {
  color: #fff;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 180%; /* 43.2px */
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .about-sub-sumo-show__exp, .about-sub-cuisine__exp, .about-sub-sake-bar__exp {
    font-size: 1.4rem;
  }
}
.about-sub .l-inner {
  position: relative;
  z-index: 2;
}
.about-sub__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 0.7vw;
  right: -11.6vw;
}
@media screen and (max-width: 767px) {
  .about-sub__cloud {
    width: 23.67rem;
    height: 13.65rem;
    position: absolute;
    top: 0vw;
    right: -8vw;
  }
}
.about-sub__gold-dust--left {
  position: absolute;
  top: -48rem;
  left: -10rem;
}
.about-sub__gold-dust--right {
  position: absolute;
  transform: scaleX(-1);
  top: -48rem;
  right: -14rem;
}

/* PROGRAM */
.program {
  background-image: url(../images/about_middle_top_img.png);
  background-color: #222;
  background-position: center -3px;
  background-repeat: no-repeat;
  background-size: 1920px auto;
  padding-top: 22rem;
  padding-bottom: 3rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .program {
    padding-top: 0;
    padding-bottom: 0;
    background-size: 750px auto;
  }
}
@media screen and (min-width: 1921px) {
  .program {
    background-size: contain;
  }
}
.program__title {
  color: #fff;
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 100%; /* 216px */
  padding-top: 13rem;
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .program__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0rem;
    padding-top: 11rem;
  }
}
.program .show-card--ttl {
  color: #fff;
  font-family: "Playfair Display SC";
  font-size: 8.4rem;
  font-style: normal;
  font-weight: 400;
  line-height: 7.7rem; /* 91.667% */
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .program .show-card--ttl {
    font-size: 3rem;
    font-style: normal;
    font-weight: 400;
    line-height: 3.8rem; /* 128.333% */
    margin: 3rem 0 0 1.3rem;
  }
}
.program .show-card--ttl span {
  font-size: 7rem;
}
@media screen and (max-width: 767px) {
  .program .show-card--ttl span {
    font-size: 2.7rem;
  }
}
.program .l-inner {
  position: relative;
  z-index: 2;
}
.program__cloud--right {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 19.4vw;
  right: 0.4vw;
}
@media screen and (max-width: 767px) {
  .program__cloud--right {
    width: 23.66rem;
    height: 13.67rem;
    position: absolute;
    top: 24vw;
    right: -24vw;
  }
}
.program__cloud--left {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 47vw;
  left: -1vw;
}
@media screen and (max-width: 767px) {
  .program__cloud--left {
    width: 23.66rem;
    height: 13.67rem;
    position: absolute;
    top: 24vw;
    right: -24vw;
  }
}
.program__gold-dust--left {
  position: absolute;
  top: 4rem;
  left: -17rem;
}
@media screen and (max-width: 767px) {
  .program__gold-dust--left {
    top: -6rem;
    left: -5rem;
    width: 16rem;
  }
}
.program__gold-dust--right {
  position: absolute;
  transform: scaleX(-1);
  top: 4rem;
  right: -16rem;
}
@media screen and (max-width: 767px) {
  .program__gold-dust--right {
    top: -6.8rem;
    right: -3.5rem;
    width: 16rem;
  }
}

.program-enjoy__program {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .program-enjoy__program {
    margin: 3rem 1rem 0 1rem;
  }
}
.program-enjoy__wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  gap: 7rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .program-enjoy__wrap {
    gap: 1rem;
  }
}
.program-enjoy__wrap::before {
  content: "";
  position: absolute;
  top: 10%;
  bottom: 10%;
  left: 12rem;
  width: 1px;
  background: #cb0c18;
  transform: translateX(-50%);
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .program-enjoy__wrap::before {
    left: 3.7rem;
  }
}
.program-enjoy__list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3rem;
  position: sticky;
}
@media screen and (max-width: 767px) {
  .program-enjoy__list {
    gap: 1.8rem;
  }
}
.program-enjoy__no {
  color: #fff;
  font-size: 4.8rem;
  font-style: italic;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.192rem;
  display: flex;
  width: 24rem;
  height: 24rem;
  padding: 1rem;
  margin-top: 1rem;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  aspect-ratio: 1/1;
  border-radius: 100rem;
  background: #cb0c18;
}
@media screen and (max-width: 767px) {
  .program-enjoy__no {
    text-align: center;
    font-size: 2.4rem;
    width: 7.5rem;
    height: 7.5rem;
    padding: 0.5rem;
  }
}
.program-enjoy__right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
}
@media screen and (max-width: 767px) {
  .program-enjoy__right {
    gap: 1rem;
  }
}
.program-enjoy__ttl {
  color: #fff;
  font-size: 5.5rem;
  font-style: normal;
  font-weight: 600;
  line-height: 180%; /* 99px */
}
@media screen and (max-width: 767px) {
  .program-enjoy__ttl {
    font-size: 2.4rem;
  }
}
.program-enjoy__text {
  color: #fff;
  font-family: "Noto Sans JP";
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 600;
  line-height: 180%; /* 43.2px */
}
@media screen and (max-width: 767px) {
  .program-enjoy__text {
    font-size: 1.4rem;
  }
}

/* FOOD */
.food {
  position: relative;
  padding: 16rem 0 2rem 0;
  width: 100%;
  z-index: 3;
  background-color: #222;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .food {
    padding: 8rem 0 8rem 0;
    scroll-margin-top: 8rem;
  }
}
.food .l-inner {
  position: relative;
  z-index: 2;
}
.food__title {
  color: #fff;
  font-family: "Playfair Display SC";
  font-size: 180px;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .food__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
  }
}
.food__list {
  display: flex;
  justify-content: start;
  align-self: center;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .food__list {
    flex-direction: column;
    gap: 2rem;
  }
}
.food__list--wrap {
  margin-top: 8rem;
  display: flex;
  justify-content: start;
  align-self: center;
  flex-direction: column;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .food__list--wrap {
    gap: 2rem;
    width: 90%;
    margin: 4rem auto 0 auto;
  }
}
.food-name__box {
  display: flex;
  justify-content: center;
  align-self: center;
  padding: 1.6rem 0;
}
@media screen and (max-width: 767px) {
  .food-name__box {
    flex-direction: column;
    padding: 0.8rem 0;
    min-height: 5rem;
  }
}
.food-name__name {
  color: #FFF;
  font-size: 1.4rem;
  font-style: normal;
  font-weight: 700;
  line-height: 150%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .food-name__name {
    font-size: 1.1rem;
  }
}
.food-name__name span {
  color: #FFF;
  text-align: center;
  font-size: 2rem;
  font-style: normal;
  font-weight: 700;
  line-height: 150%; /* 30px */
}
@media screen and (max-width: 767px) {
  .food-name__name span {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .food-name {
    font-size: 1.2rem;
  }
}
.food__exp {
  color: #FFF;
}
@media screen and (max-width: 767px) {
  .food__exp {
    width: 100%;
  }
}
.food__exp li {
  display: flex;
  justify-content: start;
  align-items: start;
  gap: 0.5rem;
}
.food__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 31.2vw;
  right: 8.9vw;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .food__cloud {
    width: 23.66rem;
    height: 13.64rem;
    position: absolute;
    top: 7vw;
    right: -8vw;
  }
}

/* PRICE */
.price {
  background-image: url(../images/price_middle_top_img.png), url(../images/white_texture_pc.png);
  background-repeat: no-repeat, repeat;
  background-size: contain, 1920px auto;
  background-position: center -3px;
  padding: 7rem 0 12rem 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .price {
    background-image: url(../images/price_middle_top_img.png), url(../images/white_texture_sp.png);
    background-size: contain, 750px auto;
    width: 100%;
    margin: 0 auto 0rem auto;
    padding: 5rem 0 1rem 0;
  }
}
.price .l-inner {
  position: relative;
  z-index: 2;
}
.price__title {
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
  padding-top: 12rem;
  margin-top: 12rem;
}
@media screen and (max-width: 767px) {
  .price__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
    padding-top: 2.5rem;
    margin-top: 2.5rem;
    scroll-margin-top: 8rem;
  }
}
.price .price-map {
  margin: 5rem auto 0 auto;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .price .price-map {
    margin: 3rem 1rem 0 1rem;
  }
}
.price .price-map__img {
  margin: 3rem auto 0 auto;
  width: 98rem;
}
@media screen and (max-width: 767px) {
  .price .price-map__img {
    margin: 1rem auto 0 auto;
  }
}
.price-seat__name {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 3.1rem; /* 165.338% */
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .price-seat__name {
    font-size: 1.1rem;
    gap: 1rem;
    margin-top: 0.5rem;
  }
}
.price .square-color--purple::before {
  content: "■";
  color: #5c1c86;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .price .square-color--purple::before {
    font-size: 1.3rem;
  }
}
.price .square-color--yellow::before {
  content: "■";
  color: #e4c34f;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .price .square-color--yellow::before {
    font-size: 1.3rem;
  }
}
.price .square-color--red::before {
  content: "■";
  color: #e40c14;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .price .square-color--red::before {
    font-size: 1.3rem;
  }
}
.price__table {
  padding-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .price__table {
    overflow: scroll;
    margin-top: 0;
    padding-bottom: 0;
  }
}
.price table {
  border-collapse: collapse;
  width: 106.3rem;
  margin: 2rem auto 0 auto;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .price table {
    width: 100%;
  }
}
.price th,
.price td {
  border: 1px solid #ddd;
  padding: 1rem;
  text-align: center;
  font-size: 1.8rem;
  vertical-align: middle;
  line-height: 1;
  width: 26.6rem;
}
@media screen and (max-width: 767px) {
  .price th,
  .price td {
    font-size: 1rem;
    padding: 0.3rem 0;
    width: 26.6rem;
  }
}
.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;
    width: 25%;
    line-height: 1.2rem;
  }
}
.price .rank {
  border-bottom: 2px solid #333;
  display: inline-block;
}
.price .stan-seat .rank {
  border-color: #5c1c86;
  white-space: nowrap;
  font-size: 2.1rem;
  display: inline-block;
  padding-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .price .stan-seat .rank {
    font-size: 1rem;
    padding-bottom: 0.3rem;
  }
}
.price .pre-seat .rank {
  border-color: #e4c34f;
  white-space: nowrap;
  font-size: 2.1rem;
  display: inline-block;
  padding-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .price .pre-seat .rank {
    font-size: 1rem;
    padding-bottom: 0.3rem;
  }
}
.price .s-pre-seat .rank {
  border-color: #e40c14;
  white-space: nowrap;
  font-size: 1.9rem;
  display: inline-block;
  line-height: 2.2rem;
  padding-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .price .s-pre-seat .rank {
    font-size: 1rem;
    line-height: 1.4rem;
    padding-bottom: 0.3rem;
  }
}
.price .food-options {
  list-style: none;
  padding: 0.5rem 0;
  margin: 0 auto;
  text-align: left;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .price .food-options {
    font-size: 0.9rem;
  }
}
.price .food-options li {
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .price .food-options li {
    margin-bottom: 0rem;
  }
}
.price__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 17.3vw;
  right: 0.8vw;
}
@media screen and (max-width: 767px) {
  .price__cloud {
    width: 23.66rem;
    height: 13.64rem;
    position: absolute;
    top: 12vw;
    right: -24vw;
  }
}

.price-show {
  text-align: center;
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .price-show {
    margin-top: 4rem;
  }
}
.price-show__table {
  width: 100%;
  height: 100%;
  font-size: clamp(1rem, 1.4vw, 1.4rem);
  margin-top: 3.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .price-show__table {
    margin-top: 0;
  }
}
.price-show__table--caption {
  margin-top: 1rem;
  text-align: left;
  width: 106.3rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .price-show__table--caption {
    margin-top: 2rem;
    width: 100%;
    font-size: 1.4rem;
  }
}
.price-show__table--caption li {
  display: flex;
  justify-content: start;
  align-items: start;
  gap: 0.5rem;
}
@media screen and (max-width: 767px) {
  .price-show__table--caption li {
    margin-bottom: 0.5rem;
  }
}
.price-show__table--caption.cancellation-policy {
  color: #cb0c18;
  margin-top: 1.5rem;
}
.price-show__table--caption.cancellation-policy .bold {
  font-weight: 700;
}
.price-show__table--subttl {
  display: inline-block;
  padding: 0 2.2rem 1rem;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 3.3rem;
}
@media screen and (max-width: 767px) {
  .price-show__table--subttl {
    font-size: 2.2rem;
    font-weight: 900;
    line-height: 77px; /* 175% */
  }
}
.price-show__table--subttl span {
  font-size: 2rem;
  font-style: normal;
  font-weight: 400;
}
.price-show__table--box {
  min-height: 4rem;
}

.seating-chart {
  text-align: center;
  margin-top: 2rem;
}
.seating-chart .open-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 1rem;
  color: #fff;
  font-size: 1.8rem;
  background: #cb0c18;
  border-radius: 50px;
  gap: 0.5rem;
  margin-right: auto;
  cursor: pointer;
}
.seating-chart .open-btn .icon svg {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .seating-chart .open-btn span {
    color: #fff;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 400;
    line-height: 2.1589rem;
  }
}
@media screen and (max-width: 767px) {
  .seating-chart .open-btn svg {
    width: 1.6rem !important;
  }
}

.modal {
  display: none;
}
@media screen and (max-width: 767px) {
  .modal {
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.8);
  }
}
.modal-seat__name {
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 3.1rem; /* 165.338% */
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  .modal-seat__name {
    font-size: 1rem;
    gap: 1rem;
    margin-top: 0.5rem;
  }
}
.modal .square-color--purple::before {
  content: "■";
  color: #5c1c86;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .modal .square-color--purple::before {
    font-size: 1.3rem;
  }
}
.modal .square-color--yellow::before {
  content: "■";
  color: #e4c34f;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .modal .square-color--yellow::before {
    font-size: 1.3rem;
  }
}
.modal .square-color--red::before {
  content: "■";
  color: #e40c14;
  font-size: 2.6rem;
}
@media screen and (max-width: 767px) {
  .modal .square-color--red::before {
    font-size: 1.3rem;
  }
}

.modal-content {
  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;
    padding: 0;
    padding-top: 0;
  }
}

.close {
  color: #fff;
  position: relative;
  top: 0px;
  right: -34vw;
  font-size: 35px;
  font-weight: bold;
  cursor: pointer;
}
.seat-heading {
  color: #fff;
  text-align: center;
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: 3px;
  background: #cb0c18;
  padding: 0.3rem 1.2rem;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .seat-heading {
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 3px;
  }
}

/* Cast */
.cast {
  background-color: #222;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 16rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .cast {
    padding-top: 8rem;
    scroll-margin-top: 8rem;
  }
}
.cast__top {
  position: absolute;
  top: -13.0208333333vw;
  left: 0;
  width: 100%;
}
.cast__title {
  color: #fff;
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .cast__title {
    color: #fff;
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
  }
}
.cast .l-inner {
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .cast .l-inner {
    padding-top: 0;
  }
}
.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__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 6.4vw;
  right: 2.6vw;
}
@media screen and (max-width: 767px) {
  .cast__cloud {
    width: 23.65rem;
    height: 13.6rem;
    position: absolute;
    top: 6.4vw;
    right: 2.6vw;
  }
}

.cast-cards {
  display: flex;
  gap: 3.2rem;
  flex-wrap: wrap;
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .cast-cards {
    gap: 1.5rem;
    margin: 3.5rem 1rem 0 1rem;
    justify-content: center;
  }
}

.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: 13rem;
    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%;
  }
}
@media screen and (max-width: 767px) {
  .cast-card__wrap dd {
    font-size: 0.7rem;
  }
}
.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-card--coming-soon {
  padding: 0;
}
.cast-card--coming-soon .cast-card__img {
  height: 100%;
}
.cast-card__wrap--coming-soon {
  background-color: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
  padding: 0;
}
.cast-card__coming-soon-text {
  color: #FFF;
  text-align: center;
  font-family: "Playfair Display SC";
  font-size: 5rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 60px */
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .cast-card__coming-soon-text {
    font-size: 2.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;
  }
}

/* CALENDAR */
.calendar {
  background-image: url(../images/white_texture_pc.png);
  background-repeat: repeat;
  background-size: 1920px auto;
  position: relative;
  padding: 2rem 0 12rem 0;
  margin-top: -3px;
  scroll-margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .calendar {
    background-image: url(../images/white_texture_sp.png);
    background-size: 750px auto;
    padding: 2rem 0 2.7rem 0;
    scroll-margin-top: 8rem;
  }
}
.calendar__title {
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .calendar__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
  }
}
.calendar__contents {
  /*margin: 4rem auto 0 auto;*/
  /*width: 108rem;*/
}
@media screen and (max-width: 767px) {
  .calendar__contents {
    padding: 0 1rem;
  }
}
.calendar__link {
  width: 55rem;
  height: 8.3rem;
  padding: 0 18.3rem 0 8.3rem;
  border-radius: 0.8rem;
  background: #cb0c18;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin: 5.5rem auto 0 auto;
}
@media screen and (max-width: 767px) {
  .calendar__link {
    font-size: 1.6rem;
    width: 32.5rem;
    height: 6.8rem;
    padding: 0 7.3rem 0 3.3rem;
    margin: 3.5rem auto 0 auto;
  }
}
.calendar__link::after {
  content: "";
  background-image: url(../images/pdf_icon.svg);
  position: absolute;
  top: 50%;
  right: 16rem;
  transform: translate(50%, -50%);
  width: 3.7rem;
  height: 3.7rem;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .calendar__link::after {
    right: 6.5rem;
  }
}
.calendar__exp {
  color: #0e0e0e;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 28px; /* 200% */
  margin-top: 3rem;
  padding-left: 15rem;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .calendar__exp {
    padding-left: 0rem;
    margin-top: 1rem;
    line-height: 2.2rem;
  }
}
.calendar .l-inner {
  position: relative;
  z-index: 2;
}
.calendar__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 2.1vw;
  right: 1.9vw;
}
@media screen and (max-width: 767px) {
  .calendar__cloud {
    width: 23.66rem;
    height: 13.64rem;
    position: absolute;
    top: 7.1vw;
    right: -4.5vw;
  }
}

/* ACCESS */
.access {
  background-image: url(../images/white_texture_pc.png);
  background-repeat: repeat;
  background-size: 1920px auto;
  position: relative;
  padding: 2rem 0 12rem 0;
  margin-top: -3px;
  scroll-margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .access {
    background-image: url(../images/white_texture_sp.png);
    background-size: 750px auto;
    padding: 2rem 0 6rem 0;
    scroll-margin-top: 8rem;
  }
}
.access__title {
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
}
@media screen and (max-width: 767px) {
  .access__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
  }
}
.access__contents {
  margin: 4rem auto 0 auto;
  width: 108rem;
  display: flex;
  justify-content: center;
  align-items: start;
  gap: 4rem;
}
@media screen and (max-width: 767px) {
  .access__contents {
    flex-direction: column;
    width: auto;
    gap: 3rem;
    padding: 0 1rem;
  }
}
.access__map {
  min-width: 50rem;
  height: 67rem;
}
@media screen and (max-width: 767px) {
  .access__map {
    min-width: 0;
    height: auto;
  }
}
.access__map iframe {
  width: 100%;
  height: 100%;
}
.access__about {
  border-bottom: 1px solid #222;
  padding-bottom: 3rem;
  padding-right: 7rem;
}
@media screen and (max-width: 767px) {
  .access__about {
    padding-right: 0;
    padding-bottom: 1.2rem;
  }
}
.access__name {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 160%; /* 51.2px */
}
@media screen and (max-width: 767px) {
  .access__name {
    font-size: 2rem;
    font-style: normal;
  }
}
.access__address {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 160%; /* 38.4px */
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .access__address {
    font-size: 1.6rem;
    font-style: normal;
    margin-top: 0.5rem;
  }
}
.access__access {
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .access__access {
    margin-top: 1rem;
  }
}
.access__access-ttl {
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 180%; /* 43.2px */
}
@media screen and (max-width: 767px) {
  .access__access-ttl {
    font-size: 2.2rem;
  }
}
.access__access-li {
  font-size: 2rem;
  font-weight: 400;
  line-height: 140%;
  margin-top: 2.5rem;
  margin-left: 2.5rem;
}
@media screen and (max-width: 767px) {
  .access__access-li {
    font-size: 1.4rem;
    margin-top: 0.5rem;
    margin-left: 1.7rem;
  }
}
.access__access-li li {
  list-style-type: disc;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  .access__access-li li {
    margin-bottom: 0;
  }
}
.access .l-inner {
  position: relative;
  z-index: 2;
}
.access__cloud {
  width: 67rem;
  height: 38.6rem;
  position: absolute;
  top: 2.1vw;
  right: 1.9vw;
}
@media screen and (max-width: 767px) {
  .access__cloud {
    width: 23.66rem;
    height: 13.64rem;
    position: absolute;
    top: 7.1vw;
    right: -4.5vw;
  }
}

.ticket {
  background-color: rgba(34, 34, 34, 0.8);
  background-image: url(../images/footer_back_img.png);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: contain;
  position: relative;
  padding-bottom: 13rem;
}
@media screen and (max-width: 767px) {
  .ticket {
    background-image: url(../images/footer_back_img_sp.png);
    background-position: center calc(100% - 6rem);
  }
}
.ticket__title {
  color: #fff;
  font-family: "Playfair Display SC";
  font-size: 18rem;
  font-weight: 700;
  line-height: 120%; /* 216px */
  letter-spacing: 0.9rem;
  padding-top: 5rem;
  scroll-margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .ticket__title {
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 120%; /* 108px */
    letter-spacing: 0;
  }
}
.ticket-contact__wrap {
  color: #fff;
  width: 100%;
  text-align: center;
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  .ticket-contact__wrap {
    margin-top: 0rem;
  }
}
.ticket-contact__text {
  font-feature-settings: "palt" on;
  font-size: 2.2rem;
  line-height: 25px; /* 113.636% */
}
@media screen and (max-width: 767px) {
  .ticket-contact__text {
    color: #fff;
    font-size: 1.1rem;
    font-weight: 400;
    margin-top: 2rem;
  }
}
.ticket-contact__send {
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 53.2px; /* 190% */
  letter-spacing: 0.7px;
  margin-top: 1rem;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .ticket-contact__send {
    font-size: 1.4rem;
    line-height: 1.5rem;
  }
}
.ticket-contact__mailaddress {
  font-size: 2.2rem;
  line-height: 29.4px; /* 133.636% */
  letter-spacing: 0.7px;
}
@media screen and (max-width: 767px) {
  .ticket-contact__mailaddress {
    font-size: 1.1rem;
    font-weight: 400;
    line-height: 1.5rem;
  }
}
.ticket-buy__wrap {
  text-align: center;
}
.ticket-buy__title {
  color: #fff;
  font-size: 5.5rem;
  font-weight: 700;
  letter-spacing: 5.5px;
  margin-top: 0.7rem;
}
@media screen and (max-width: 767px) {
  .ticket-buy__title {
    font-size: 2.5rem;
    line-height: normal;
  }
}
.ticket-logo {
  max-width: 33rem;
  height: auto;
  margin: 12rem auto 0 auto;
}
@media screen and (max-width: 767px) {
  .ticket-logo {
    max-width: 16.5rem;
    margin: 6rem auto 0 auto;
  }
}
.ticket-sns__wrap {
  margin: 4rem auto 0 auto;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3rem;
}
@media screen and (max-width: 767px) {
  .ticket-sns__wrap {
    margin: 2rem auto 0 auto;
    gap: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  .ticket-sns__wrap img {
    width: 3rem;
    height: auto;
  }
}
.ticket__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5.6rem;
  margin: 4rem 0 4.8rem 0;
}
@media screen and (max-width: 767px) {
  .ticket__wrap {
    gap: 2.6rem;
    margin: 2.2rem 0 1.8rem 0;
  }
}
.ticket__wrap span {
  color: #fff;
  font-size: 3.3rem;
  font-weight: 700;
  letter-spacing: 3.3px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .ticket__wrap span {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.16rem;
  }
}
.ticket__wrap 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: -1.5rem;
}
@media screen and (max-width: 767px) {
  .ticket__wrap span::after {
    width: 1rem;
    height: 1rem;
    right: -1rem;
  }
}
.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;
}
@media screen and (max-width: 767px) {
  .ticket__link {
    width: 12.2rem;
    height: 12.2rem;
  }
}
.ticket .l-inner {
  position: relative;
  z-index: 2;
}
.ticket__gold-dust-02 {
  width: 71rem;
  height: 71.23rem;
  position: absolute;
  top: 13vw;
  left: -2.6vw;
}
.ticket__gold-dust-03 {
  width: 82.08rem;
  height: 85.8rem;
  position: absolute;
  top: 9.4vw;
  right: -4.7vw;
}

.terms_use_link {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 1.8px;
  padding: 0.2rem 4rem 0.3rem 2rem;
  border-radius: 5rem;
  background: #fff;
  position: relative;
}
@media screen and (max-width: 767px) {
  .terms_use_link {
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 0.09rem;
    padding: 0.1rem 2rem 0.1rem 1.5rem;
  }
}
.terms_use_link span::after {
  content: "";
  border-top: 2px solid #222;
  border-right: 2px solid #222;
  width: 1rem;
  height: 1rem;
  display: inline-block;
  position: absolute;
  top: 55%;
  right: 2.3rem;
  transform: translateY(-50%) rotate(45deg);
}
@media screen and (max-width: 767px) {
  .terms_use_link span::after {
    width: 0.5rem;
    height: 0.5rem;
    right: 1.4rem;
  }
}
.terms_use_link svg {
  position: absolute;
  top: 50%;
  right: 2.5rem;
  transform: translate(50%, -50%);
  stroke: #222;
}
@media screen and (max-width: 767px) {
  .terms_use_link svg {
    right: 1.2rem;
    width: 1rem;
    height: 1rem;
  }
}

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