﻿@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@100..900&family=Oxanium:wght@200..800&display=swap");
.fc-white {
  color: #fff !important;
}
.bg-white {
  background: #fff !important;
}
.bd-white {
  border-color: #fff !important;
}
.fc-black {
  color: #020202 !important;
}
.bg-black {
  background: #020202 !important;
}
.bd-black {
  border-color: #020202 !important;
}
.fc-yellow {
  color: #fbb03b !important;
}
.bg-yellow {
  background: #fbb03b !important;
}
.bd-yellow {
  border-color: #fbb03b !important;
}
.fc-yellow_light {
  color: #fded07 !important;
}
.bg-yellow_light {
  background: #fded07 !important;
}
.bd-yellow_light {
  border-color: #fded07 !important;
}
.fc-cream {
  color: #f6f4eb !important;
}
.bg-cream {
  background: #f6f4eb !important;
}
.bd-cream {
  border-color: #f6f4eb !important;
}
.fc-blue {
  color: #0a58ca !important;
}
.bg-blue {
  background: #0a58ca !important;
}
.bd-blue {
  border-color: #0a58ca !important;
}
.fc-grapefruit {
  color: #f4323f !important;
}
.bg-grapefruit {
  background: #f4323f !important;
}
.bd-grapefruit {
  border-color: #f4323f !important;
}
.fc-red_dark {
  color: #ac1f27 !important;
}
.bg-red_dark {
  background: #ac1f27 !important;
}
.bd-red_dark {
  border-color: #ac1f27 !important;
}
.fc-lightgray {
  color: #f5f7fa !important;
}
.bg-lightgray {
  background: #f5f7fa !important;
}
.bd-lightgray {
  border-color: #f5f7fa !important;
}
.fc-lightgray_dark {
  color: #e6e9ed !important;
}
.bg-lightgray_dark {
  background: #e6e9ed !important;
}
.bd-lightgray_dark {
  border-color: #e6e9ed !important;
}
.fc-mediumgray {
  color: #ccd1d9 !important;
}
.bg-mediumgray {
  background: #ccd1d9 !important;
}
.bd-mediumgray {
  border-color: #ccd1d9 !important;
}
.fc-mediumgray_dark {
  color: #aab2bd !important;
}
.bg-mediumgray_dark {
  background: #aab2bd !important;
}
.bd-mediumgray_dark {
  border-color: #aab2bd !important;
}
.fc-darkgray {
  color: #656d78 !important;
}
.bg-darkgray {
  background: #656d78 !important;
}
.bd-darkgray {
  border-color: #656d78 !important;
}
.fc-darkgray_dark {
  color: #434a54 !important;
}
.bg-darkgray_dark {
  background: #434a54 !important;
}
.bd-darkgray_dark {
  border-color: #434a54 !important;
}
.m0 {
  margin: 0 !important;
}
.mt0 {
  margin-top: 0 !important;
}
.mr0 {
  margin-right: 0 !important;
}
.mb0 {
  margin-bottom: 0 !important;
}
.ml0 {
  margin-left: 0 !important;
}
.m3 {
  margin: 3px !important;
}
.mt3 {
  margin-top: 3px !important;
}
.mr3 {
  margin-right: 3px !important;
}
.mb3 {
  margin-bottom: 3px !important;
}
.ml3 {
  margin-left: 3px !important;
}
.m5 {
  margin: 5px !important;
}
.mt5 {
  margin-top: 5px !important;
}
.mr5 {
  margin-right: 5px !important;
}
.mb5 {
  margin-bottom: 5px !important;
}
.ml5 {
  margin-left: 5px !important;
}
.m10 {
  margin: 10px !important;
}
.mt10 {
  margin-top: 10px !important;
}
.mr10 {
  margin-right: 10px !important;
}
.mb10 {
  margin-bottom: 10px !important;
}
.ml10 {
  margin-left: 10px !important;
}
.m15 {
  margin: 15px !important;
}
.mt15 {
  margin-top: 15px !important;
}
.mr15 {
  margin-right: 15px !important;
}
.mb15 {
  margin-bottom: 15px !important;
}
.ml15 {
  margin-left: 15px !important;
}
.m20 {
  margin: 20px !important;
}
.mt20 {
  margin-top: 20px !important;
}
.mr20 {
  margin-right: 20px !important;
}
.mb20 {
  margin-bottom: 20px !important;
}
.ml20 {
  margin-left: 20px !important;
}
.m25 {
  margin: 25px !important;
}
.mt25 {
  margin-top: 25px !important;
}
.mr25 {
  margin-right: 25px !important;
}
.mb25 {
  margin-bottom: 25px !important;
}
.ml25 {
  margin-left: 25px !important;
}
.m30 {
  margin: 30px !important;
}
.mt30 {
  margin-top: 30px !important;
}
.mr30 {
  margin-right: 30px !important;
}
.mb30 {
  margin-bottom: 30px !important;
}
.ml30 {
  margin-left: 30px !important;
}
.m35 {
  margin: 35px !important;
}
.mt35 {
  margin-top: 35px !important;
}
.mr35 {
  margin-right: 35px !important;
}
.mb35 {
  margin-bottom: 35px !important;
}
.ml35 {
  margin-left: 35px !important;
}
.m40 {
  margin: 40px !important;
}
.mt40 {
  margin-top: 40px !important;
}
.mr40 {
  margin-right: 40px !important;
}
.mb40 {
  margin-bottom: 40px !important;
}
.ml40 {
  margin-left: 40px !important;
}
.m45 {
  margin: 45px !important;
}
.mt45 {
  margin-top: 45px !important;
}
.mr45 {
  margin-right: 45px !important;
}
.mb45 {
  margin-bottom: 45px !important;
}
.ml45 {
  margin-left: 45px !important;
}
.m50 {
  margin: 50px !important;
}
.mt50 {
  margin-top: 50px !important;
}
.mr50 {
  margin-right: 50px !important;
}
.mb50 {
  margin-bottom: 50px !important;
}
.ml50 {
  margin-left: 50px !important;
}
.m55 {
  margin: 55px !important;
}
.mt55 {
  margin-top: 55px !important;
}
.mr55 {
  margin-right: 55px !important;
}
.mb55 {
  margin-bottom: 55px !important;
}
.ml55 {
  margin-left: 55px !important;
}
.m60 {
  margin: 60px !important;
}
.mt60 {
  margin-top: 60px !important;
}
.mr60 {
  margin-right: 60px !important;
}
.mb60 {
  margin-bottom: 60px !important;
}
.ml60 {
  margin-left: 60px !important;
}
.m65 {
  margin: 65px !important;
}
.mt65 {
  margin-top: 65px !important;
}
.mr65 {
  margin-right: 65px !important;
}
.mb65 {
  margin-bottom: 65px !important;
}
.ml65 {
  margin-left: 65px !important;
}
.m70 {
  margin: 70px !important;
}
.mt70 {
  margin-top: 70px !important;
}
.mr70 {
  margin-right: 70px !important;
}
.mb70 {
  margin-bottom: 70px !important;
}
.ml70 {
  margin-left: 70px !important;
}
.m80 {
  margin: 80px !important;
}
.mt80 {
  margin-top: 80px !important;
}
.mr80 {
  margin-right: 80px !important;
}
.mb80 {
  margin-bottom: 80px !important;
}
.ml80 {
  margin-left: 80px !important;
}
.m90 {
  margin: 90px !important;
}
.mt90 {
  margin-top: 90px !important;
}
.mr90 {
  margin-right: 90px !important;
}
.mb90 {
  margin-bottom: 90px !important;
}
.ml90 {
  margin-left: 90px !important;
}
.m100 {
  margin: 100px !important;
}
.mt100 {
  margin-top: 100px !important;
}
.mr100 {
  margin-right: 100px !important;
}
.mb100 {
  margin-bottom: 100px !important;
}
.ml100 {
  margin-left: 100px !important;
}
.ml-auto {
  margin-left: auto !important;
}
.mr-auto {
  margin-right: auto !important;
}
.p0 {
  padding: 0 !important;
}
.pt0 {
  padding-top: 0 !important;
}
.pr0 {
  padding-right: 0 !important;
}
.pb0 {
  padding-bottom: 0 !important;
}
.pl0 {
  padding-left: 0 !important;
}
.p5 {
  padding: 5px !important;
}
.pt5 {
  padding-top: 5px !important;
}
.pr5 {
  padding-right: 5px !important;
}
.pb5 {
  padding-bottom: 5px !important;
}
.pl5 {
  padding-left: 5px !important;
}
.p10 {
  padding: 10px !important;
}
.pt10 {
  padding-top: 10px !important;
}
.pr10 {
  padding-right: 10px !important;
}
.pb10 {
  padding-bottom: 10px !important;
}
.pl10 {
  padding-left: 10px !important;
}
.p15 {
  padding: 15px !important;
}
.pt15 {
  padding-top: 15px !important;
}
.pr15 {
  padding-right: 15px !important;
}
.pb15 {
  padding-bottom: 15px !important;
}
.pl15 {
  padding-left: 15px !important;
}
.p20 {
  padding: 20px !important;
}
.pt20 {
  padding-top: 20px !important;
}
.pr20 {
  padding-right: 20px !important;
}
.pb20 {
  padding-bottom: 20px !important;
}
.pl20 {
  padding-left: 20px !important;
}
.p25 {
  padding: 25px !important;
}
.pt25 {
  padding-top: 25px !important;
}
.pr25 {
  padding-right: 25px !important;
}
.pb25 {
  padding-bottom: 25px !important;
}
.pl25 {
  padding-left: 25px !important;
}
.p30 {
  padding: 30px !important;
}
.pt30 {
  padding-top: 30px !important;
}
.pr30 {
  padding-right: 30px !important;
}
.pb30 {
  padding-bottom: 30px !important;
}
.pl30 {
  padding-left: 30px !important;
}
.p35 {
  padding: 35px !important;
}
.pt35 {
  padding-top: 35px !important;
}
.pr35 {
  padding-right: 35px !important;
}
.pb35 {
  padding-bottom: 35px !important;
}
.pl35 {
  padding-left: 35px !important;
}
.p40 {
  padding: 40px !important;
}
.pt40 {
  padding-top: 40px !important;
}
.pr40 {
  padding-right: 40px !important;
}
.pb40 {
  padding-bottom: 40px !important;
}
.pl40 {
  padding-left: 40px !important;
}
.p45 {
  padding: 45px !important;
}
.pt45 {
  padding-top: 45px !important;
}
.pr45 {
  padding-right: 45px !important;
}
.pb45 {
  padding-bottom: 45px !important;
}
.pl45 {
  padding-left: 45px !important;
}
.p50 {
  padding: 50px !important;
}
.pt50 {
  padding-top: 50px !important;
}
.pr50 {
  padding-right: 50px !important;
}
.pb50 {
  padding-bottom: 50px !important;
}
.pl50 {
  padding-left: 50px !important;
}
.p60 {
  padding: 60px !important;
}
.pt60 {
  padding-top: 60px !important;
}
.pr60 {
  padding-right: 60px !important;
}
.pb60 {
  padding-bottom: 60px !important;
}
.pl60 {
  padding-left: 60px !important;
}
.p70 {
  padding: 70px !important;
}
.pt70 {
  padding-top: 70px !important;
}
.pr70 {
  padding-right: 70px !important;
}
.pb70 {
  padding-bottom: 70px !important;
}
.pl70 {
  padding-left: 70px !important;
}
.p80 {
  padding: 80px !important;
}
.pt80 {
  padding-top: 80px !important;
}
.pr80 {
  padding-right: 80px !important;
}
.pb80 {
  padding-bottom: 80px !important;
}
.pl80 {
  padding-left: 80px !important;
}
.p90 {
  padding: 90px !important;
}
.pt90 {
  padding-top: 90px !important;
}
.pr90 {
  padding-right: 90px !important;
}
.pb90 {
  padding-bottom: 90px !important;
}
.pl90 {
  padding-left: 90px !important;
}
.p100 {
  padding: 100px !important;
}
.pt100 {
  padding-top: 100px !important;
}
.pr100 {
  padding-right: 100px !important;
}
.pb100 {
  padding-bottom: 100px !important;
}
.pl100 {
  padding-left: 100px !important;
}
.w100 {
  width: 100% !important;
}
.w95 {
  width: 95% !important;
}
.w90 {
  width: 90% !important;
}
.w85 {
  width: 85% !important;
}
.w80 {
  width: 80% !important;
}
.w75 {
  width: 75% !important;
}
.w70 {
  width: 70% !important;
}
.w65 {
  width: 65% !important;
}
.w60 {
  width: 60% !important;
}
.w55 {
  width: 55% !important;
}
.w50 {
  width: 50% !important;
}
.w45 {
  width: 45% !important;
}
.w40 {
  width: 40% !important;
}
.w35 {
  width: 35% !important;
}
.w30 {
  width: 30% !important;
}
.w25 {
  width: 25% !important;
}
.w20 {
  width: 20% !important;
}
.w15 {
  width: 15% !important;
}
.w10 {
  width: 10% !important;
}
.block-block {
  display: block !important;
}
.block-inline {
  display: inline !important;
}
.block-inlineblock {
  display: inline-block !important;
}
.block-flex {
  display: flex !important;
}
.lh1 {
  line-height: 1 !important;
}
.lh12 {
  line-height: 1.2 !important;
}
.lh13 {
  line-height: 1.3 !important;
}
.lh15 {
  line-height: 1.5 !important;
}
.lh16 {
  line-height: 1.6 !important;
}
.lh18 {
  line-height: 1.8 !important;
}
.lh19 {
  line-height: 1.9 !important;
}
.lh20 {
  line-height: 2 !important;
}
.lh21 {
  line-height: 2.1 !important;
}
.lh2-15 {
  line-height: 2.15 !important;
}
.lh24 {
  line-height: 2.4 !important;
}
.lh26 {
  line-height: 2.6 !important;
}
.lh28 {
  line-height: 2.8 !important;
}
.lh30 {
  line-height: 3 !important;
}
.lh32 {
  line-height: 3.2 !important;
}
.lh34 {
  line-height: 3.4 !important;
}
.lh36 {
  line-height: 3.6 !important;
}
.lh38 {
  line-height: 3.8 !important;
}
.lh40 {
  line-height: 4 !important;
}
.lh42 {
  line-height: 4.2 !important;
}
.lh46 {
  line-height: 4.6 !important;
}
.lh48 {
  line-height: 4.8 !important;
}
.lh50 {
  line-height: 5 !important;
}
.lh60 {
  line-height: 6 !important;
}
.lh70 {
  line-height: 7 !important;
}
.lh80 {
  line-height: 8 !important;
}
.lh50 {
  line-height: 9 !important;
}
.lh100 {
  line-height: 100 !important;
}
.ls005 {
  letter-spacing: 0.05em !important;
}
.ls01 {
  letter-spacing: 0.1em !important;
}
.ls05 {
  letter-spacing: 0.5em !important;
}
.ls1 {
  letter-spacing: 1em !important;
}
.b0 {
  font-weight: normal !important;
}
.b {
  font-weight: bold !important;
}
.b300 {
  font-weight: 300 !important;
}
.b400 {
  font-weight: 400 !important;
}
.b500 {
  font-weight: 500 !important;
}
.b600 {
  font-weight: 600 !important;
}
.b700 {
  font-weight: 700 !important;
}
.fs12 {
  font-size: 1.2em !important;
}
.fs11 {
  font-size: 1.1em !important;
}
.fs1 {
  font-size: 1em !important;
}
.fs09 {
  font-size: 0.9em !important;
}
.fs08 {
  font-size: 0.8em !important;
}
.ov-hidden {
  overflow: hidden;
}
.ov-visible {
  overflow: visible;
}
.ov-scroll {
  overflow: scroll;
}
.dec_under {
  text-decoration: underline !important;
}
.dec_none {
  text-decoration: none !important;
}
.rd0 {
  -moz-border-radius: 0 !important;
  -webkit-border-radius: 0 !important;
  -ms-border-radius: 0 !important;
}
.rd0-tr {
  -moz-border-top-right-radius: 0 !important;
  -webkit-border-top-right-radius: 0 !important;
  -ms-border-top-right-radius: 0 !important;
}
.rd0-br {
  -moz-border-bottom-right-radius: 0 !important;
  -webkit-border-bottom-right-radius: 0 !important;
  -ms-border-bottom-right-radius: 0 !important;
}
.rd0-bl {
  -moz-border-bottom-left-radius: 0 !important;
  -webkit-border-bottom-left-radius: 0 !important;
  -ms-border-bottom-left-radius: 0 !important;
}
.rd0-tl {
  -moz-border-top-left-radius: 0 !important;
  -webkit-border-top-left-radius: 0 !important;
  -ms-border-top-left-radius: 0 !important;
}
.rd3 {
  -moz-border-radius: 3px !important;
  -webkit-border-radius: 3px !important;
  -ms-border-radius: 3px !important;
}
.rd3-tr {
  -moz-border-top-right-radius: 3px !important;
  -webkit-border-top-right-radius: 3px !important;
  -ms-border-top-right-radius: 3px !important;
}
.rd3-br {
  -moz-border-bottom-right-radius: 3px !important;
  -webkit-border-bottom-right-radius: 3px !important;
  -ms-border-bottom-right-radius: 3px !important;
}
.rd3-bl {
  -moz-border-bottom-left-radius: 3px !important;
  -webkit-border-bottom-left-radius: 3px !important;
  -ms-border-bottom-left-radius: 3px !important;
}
.rd3-tl {
  -moz-border-top-left-radius: 3px !important;
  -webkit-border-top-left-radius: 3px !important;
  -ms-border-top-left-radius: 3px !important;
}
.rd4 {
  -moz-border-radius: 4px !important;
  -webkit-border-radius: 4px !important;
  -ms-border-radius: 4px !important;
}
.rd4-tr {
  -moz-border-top-right-radius: 4px !important;
  -webkit-border-top-right-radius: 4px !important;
  -ms-border-top-right-radius: 4px !important;
}
.rd4-br {
  -moz-border-bottom-right-radius: 4px !important;
  -webkit-border-bottom-right-radius: 4px !important;
  -ms-border-bottom-right-radius: 4px !important;
}
.rd4-bl {
  -moz-border-bottom-left-radius: 4px !important;
  -webkit-border-bottom-left-radius: 4px !important;
  -ms-border-bottom-left-radius: 4px !important;
}
.rd4-tl {
  -moz-border-top-left-radius: 4px !important;
  -webkit-border-top-left-radius: 4px !important;
  -ms-border-top-left-radius: 4px !important;
}
.rd5 {
  -moz-border-radius: 5px !important;
  -webkit-border-radius: 5px !important;
  -ms-border-radius: 5px !important;
}
.rd5-tr {
  -moz-border-top-right-radius: 5px !important;
  -webkit-border-top-right-radius: 5px !important;
  -ms-border-top-right-radius: 5px !important;
}
.rd5-br {
  -moz-border-bottom-right-radius: 5px !important;
  -webkit-border-bottom-right-radius: 5px !important;
  -ms-border-bottom-right-radius: 5px !important;
}
.rd5-bl {
  -moz-border-bottom-left-radius: 5px !important;
  -webkit-border-bottom-left-radius: 5px !important;
  -ms-border-bottom-left-radius: 5px !important;
}
.rd5-tl {
  -moz-border-top-left-radius: 5px !important;
  -webkit-border-top-left-radius: 5px !important;
  -ms-border-top-left-radius: 5px !important;
}
.rd8 {
  -moz-border-radius: 8px !important;
  -webkit-border-radius: 8px !important;
  -ms-border-radius: 8px !important;
}
.rd8-tr {
  -moz-border-top-right-radius: 8px !important;
  -webkit-border-top-right-radius: 8px !important;
  -ms-border-top-right-radius: 8px !important;
}
.rd8-br {
  -moz-border-bottom-right-radius: 8px !important;
  -webkit-border-bottom-right-radius: 8px !important;
  -ms-border-bottom-right-radius: 8px !important;
}
.rd8-bl {
  -moz-border-bottom-left-radius: 8px !important;
  -webkit-border-bottom-left-radius: 8px !important;
  -ms-border-bottom-left-radius: 8px !important;
}
.rd8-tl {
  -moz-border-top-left-radius: 8px !important;
  -webkit-border-top-left-radius: 8px !important;
  -ms-border-top-left-radius: 8px !important;
}
.rd10 {
  -moz-border-radius: 10px !important;
  -webkit-border-radius: 10px !important;
  -ms-border-radius: 10px !important;
}
.rd10-tr {
  -moz-border-top-right-radius: 10px !important;
  -webkit-border-top-right-radius: 10px !important;
  -ms-border-top-right-radius: 10px !important;
}
.rd10-br {
  -moz-border-bottom-right-radius: 10px !important;
  -webkit-border-bottom-right-radius: 10px !important;
  -ms-border-bottom-right-radius: 10px !important;
}
.rd10-bl {
  -moz-border-bottom-left-radius: 10px !important;
  -webkit-border-bottom-left-radius: 10px !important;
  -ms-border-bottom-left-radius: 10px !important;
}
.rd10-tl {
  -moz-border-top-left-radius: 10px !important;
  -webkit-border-top-left-radius: 10px !important;
  -ms-border-top-left-radius: 10px !important;
}
.rd15 {
  -moz-border-radius: 15px !important;
  -webkit-border-radius: 15px !important;
  -ms-border-radius: 15px !important;
}
.rd15-tr {
  -moz-border-top-right-radius: 15px !important;
  -webkit-border-top-right-radius: 15px !important;
  -ms-border-top-right-radius: 15px !important;
}
.rd15-br {
  -moz-border-bottom-right-radius: 15px !important;
  -webkit-border-bottom-right-radius: 15px !important;
  -ms-border-bottom-right-radius: 15px !important;
}
.rd15-bl {
  -moz-border-bottom-left-radius: 15px !important;
  -webkit-border-bottom-left-radius: 15px !important;
  -ms-border-bottom-left-radius: 15px !important;
}
.rd15-tl {
  -moz-border-top-left-radius: 15px !important;
  -webkit-border-top-left-radius: 15px !important;
  -ms-border-top-left-radius: 15px !important;
}
.rd20 {
  -moz-border-radius: 20px !important;
  -webkit-border-radius: 20px !important;
  -ms-border-radius: 20px !important;
}
.rd20-tr {
  -moz-border-top-right-radius: 20px !important;
  -webkit-border-top-right-radius: 20px !important;
  -ms-border-top-right-radius: 20px !important;
}
.rd20-br {
  -moz-border-bottom-right-radius: 20px !important;
  -webkit-border-bottom-right-radius: 20px !important;
  -ms-border-bottom-right-radius: 20px !important;
}
.rd20-bl {
  -moz-border-bottom-left-radius: 20px !important;
  -webkit-border-bottom-left-radius: 20px !important;
  -ms-border-bottom-left-radius: 20px !important;
}
.rd20-tl {
  -moz-border-top-left-radius: 20px !important;
  -webkit-border-top-left-radius: 20px !important;
  -ms-border-top-left-radius: 20px !important;
}
.title,
h1,
h2,
h3,
h4,
h5 {
  position: relative;
  line-height: 1.3;
  letter-spacing: 0.1em;
  color: #020202;
}
.btn-yellow {
  background: #fbb03b;
  border-color: #fbb03b;
  color: #020202 !important;
}
.btn-yellow:hover,
.btn-yellow:focus {
  background: #fbb64a;
  border-color: #fbb64a;
}
.btn-yellow:active {
  background: #faa013 !important;
  border-color: #faa013 !important;
}
.btn-grapefruit {
  background: #f4323f;
  border-color: #f4323f;
  color: #fff !important;
}
.btn-grapefruit:hover,
.btn-grapefruit:focus {
  background: #f5414d;
  border-color: #f5414d;
}
.btn-grapefruit:active {
  background: #f00d1c !important;
  border-color: #f00d1c !important;
}
html,
body {
  height: 100%;
}
body {
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo, sans-serif;
  font-feature-settings: "palt";
  font-weight: 400;
  word-break: break-all;
  color: #020202;
}
a {
  letter-spacing: 0.1em;
  transition: all 0.4s;
  cursor: pointer;
  color: #020202;
}
a:hover,
a:focus,
a:active {
  text-decoration: none;
  color: #0a58ca;
}
p {
  margin: 0 0 20px;
  font-feature-settings: "palt";
  word-break: break-word;
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-size: 18px;
}
img {
  max-width: 100%;
}
.disc,
.disc > ul {
  list-style: disc;
  margin: 15px auto;
  padding-left: 30px;
}
ol.parent-type,
ul.parent-type {
  margin: 15px auto;
  list-style: none;
}
ol.parent-type > li,
ul.parent-type > li {
  position: relative;
  padding-left: 20px;
}
ol.parent-type > li:before,
ul.parent-type > li:before {
  position: absolute;
  left: -5px;
  counter-increment: number;
  content: "(" counter(number) ")";
}
.decimal,
.decimal > ul {
  list-style: decimal;
  margin: 15px auto;
  padding-left: 30px;
}
ol.notice-list,
ul.notice-list {
  list-style: none;
  padding-left: 0;
}
ol.notice-list > li,
ul.notice-list > li {
  position: relative;
  padding-left: 15px;
}
ol.notice-list > li::before,
ul.notice-list > li::before {
  position: absolute;
  left: -5px;
  content: "※";
}
.btn {
  padding: 10px;
  border-radius: 8px;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
.table th,
.table td {
  background: transparent;
}
body {
  background: #020202;
}
.global-navigation {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030;
  transition: background 0.4s;
  backdrop-filter: blur(10px);
}
@media screen and (max-width: 991px) {
  .global-navigation {
    backdrop-filter: unset;
  }
}
.global-navigation .navbar {
  padding: 0;
}
.global-navigation .navbar .container-fluid {
  padding: 0;
}
@media screen and (max-width: 991px) {
  .global-navigation .navbar .container-fluid {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
}
.global-navigation .navbar .container-fluid .navbar-brand {
  padding: 10px;
}
@media screen and (max-width: 991px) {
  .global-navigation .navbar .container-fluid .navbar-brand {
    padding: 5px;
  }
}
.global-navigation .navbar .container-fluid .navbar-brand img {
  max-width: 100px;
  transition: all 0.4s;
}
@media screen and (max-width: 991px) {
  .global-navigation .navbar .container-fluid .navbar-brand img {
    max-width: 60px;
  }
}
.global-navigation .navbar .container-fluid .navbar-nav .nav-item {
  letter-spacing: 0.1em;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
  font-weight: 700;
  font-size: large;
}
.global-navigation .navbar .container-fluid .navbar-nav .nav-item .nav-link {
  position: relative;
  padding: 5px 20px;
  color: #fff;
  font-size: 20px;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link::before {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background: #fbb03b;
  border-radius: 50px;
  transition: width 0.3s;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:hover,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:focus,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:active {
  color: #fbb03b;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:hover::before,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:focus::before,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link:active::before {
  width: 30px;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu {
  padding: 0px;
  overflow: hidden;
  z-index: 1100;
  position: absolute;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  li:last-of-type {
  border-bottom: 0;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  .dropdown-item {
  font-weight: 500;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  .dropdown-item:hover,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  .dropdown-item:focus,
.global-navigation
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  .dropdown-item:active {
  color: #fbb03b;
}
.global-navigation .navbar .container-fluid .nav-button {
  margin: 10px 15px 10px 10px;
}
.global-navigation .navbar .container-fluid .navbar-toggler {
  padding-top: 0;
  border: 0;
  border-radius: 0;
  transition: opacity 0.3s;
}
.global-navigation .navbar .container-fluid .navbar-toggler:focus {
  box-shadow: none;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-toggler
  .navbar-toggle-icon {
  font-size: 35px;
  color: #fff;
}
.global-navigation
  .navbar
  .container-fluid
  .navbar-toggler
  .navbar-toggle-text {
  display: block;
  margin-top: -3px;
  font-size: 10px;
  color: #fff;
}
.global-navigation .navbar .offcanvas.offcanvas-top {
  bottom: unset;
  height: auto;
  background: rgba(0, 0, 0, 0.8);
}
.global-navigation .navbar .offcanvas .offcanvas-header {
  padding: 0;
  background: #020202;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.global-navigation .navbar .offcanvas .offcanvas-header .offcanvas-title {
  padding: 5px;
}
.global-navigation .navbar .offcanvas .offcanvas-header .offcanvas-title img {
  max-width: 60px;
}
.global-navigation .navbar .offcanvas .offcanvas-header .offcanvas-close {
  padding: 10px;
  margin-right: 7px;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  border: 0;
  line-height: 1;
  font-size: 24px;
  transition: opacity 0.3s;
  color: #fff;
}
.global-navigation .navbar .offcanvas .offcanvas-header .offcanvas-close:focus,
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-header
  .offcanvas-close:active {
  opacity: 0.6;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-header
  .offcanvas-close
  .offcanvas-close-text {
  display: block;
  margin-top: 3px;
  font-size: 10px;
  color: #fff;
}
.global-navigation .navbar .offcanvas .offcanvas-body {
  padding: 0;
}
.global-navigation .navbar .offcanvas .offcanvas-body .navbar-nav .nav-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item:last-of-type {
  border-bottom: 0;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .nav-link {
  padding: 20px 15px;
  text-align: left;
  letter-spacing: 0.1em;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
  font-weight: 500;
  line-height: 1.3;
  color: #fff;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .nav-link:focus,
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .nav-link:active {
  color: #fbb03b;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.btn-item {
  padding: 10px;
  text-align: center;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.btn-item
  .reserve-btn {
  width: 90%;
  padding: 15px 20px;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu {
  border-radius: 0;
  border: 0;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  li:last-of-type {
  border-bottom: 0;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item.dropdown
  .dropdown-menu
  li
  .dropdown-item {
  color: #fff;
}
/* Mobile Navigation Collapse Styles */
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-collapse-toggle {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  position: relative;
  cursor: pointer;
  text-decoration: none;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-collapse-toggle
  .nav-text {
  flex: 1;
  text-align: left;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-collapse-toggle
  .collapse-icon {
  font-size: 12px;
  transition: transform 0.3s ease;
  opacity: 0.7;
  margin-left: 10px;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-collapse-toggle[aria-expanded="true"]
  .collapse-icon {
  transform: rotate(180deg);
  opacity: 1;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-collapse-toggle[aria-expanded="true"] {
  color: #fbb03b;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-collapse {
  background: rgba(0, 0, 0, 0.1);
  margin: 0 -15px;
  padding: 0 15px;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-list
  li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-list
  li:last-child {
  border-bottom: none;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-item {
  color: #ccc;
  padding: 12px 20px;
  font-size: 14px;
  transition: all 0.3s ease;
  display: block;
  text-decoration: none;
  margin-left: 20px;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-item:hover,
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-item:focus {
  background: rgba(251, 176, 59, 0.1);
  color: #fbb03b;
  transform: translateX(5px);
  text-decoration: none;
}
.global-navigation
  .navbar
  .offcanvas
  .offcanvas-body
  .navbar-nav
  .nav-item
  .mobile-submenu-item:active {
  background: rgba(251, 176, 59, 0.2);
  color: #fff;
}

/* Responsive Navigation Display Fixes */
.global-navigation .navbar-collapse.d-none.d-lg-flex {
  display: none !important;
}

@media (min-width: 992px) {
  .global-navigation .navbar-collapse.d-none.d-lg-flex {
    display: flex !important;
  }
  
  .global-navigation .navbar-toggler.d-lg-none {
    display: none !important;
  }
  
  .global-navigation .offcanvas.d-lg-none {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  .global-navigation .navbar-collapse.d-none.d-lg-flex {
    display: none !important;
  }
  
  .global-navigation .navbar-toggler.d-lg-none {
    display: block !important;
  }
  
  .global-navigation .offcanvas.d-lg-none {
    display: block !important;
  }
}

/* Active page highlighting styles */
.global-navigation .nav-link.active {
  color: #fbb03b !important;
  font-weight: 600;
}

.global-navigation .mobile-collapse-toggle.active {
  color: #fbb03b !important;
}

.global-navigation .mobile-collapse-toggle.active .collapse-icon {
  color: #fbb03b !important;
  opacity: 1;
}

.global-navigation .mobile-submenu-item.active {
  color: #fbb03b !important;
  background: rgba(251, 176, 59, 0.1);
  font-weight: 600;
}

.global-navigation .dropdown-toggle.active {
  color: #fbb03b !important;
}

.global-navigation .dropdown-item.active {
  color: #fbb03b !important;
  background: rgba(251, 176, 59, 0.1);
  font-weight: 600;
}
.global-navigation.scrolled {
  background: rgba(0, 0, 0, 0.8);
}
.global-navigation.scrolled .navbar .container-fluid {
  border-bottom: 0;
}
.global-navigation.scrolled
  .navbar
  .container-fluid
  .navbar-nav
  .nav-item
  .nav-link {
  text-shadow: none;
}
.global-navigation.scrolled .navbar .container-fluid .navbar-brand img {
  max-width: 80px;
}
/* Responsive breakpoints for mobile navigation */
@media screen and (max-width: 991px) {
  .global-navigation.scrolled .navbar .container-fluid .navbar-brand img {
    max-width: 50px;
  }
  
  /* Ensure mobile dropdowns work properly on small screens */
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item.dropdown
    .mobile-dropdown-menu {
    position: static !important;
    transform: none !important;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

@media screen and (max-width: 768px) {
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item.dropdown
    .mobile-dropdown-menu {
    min-width: 100%;
    margin-top: 4px;
  }
  
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item.dropdown
    .mobile-dropdown-menu
    .dropdown-item {
    padding: 14px 20px;
    font-size: 15px;
  }
}

@media screen and (max-width: 480px) {
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item.dropdown
    .mobile-dropdown-toggle {
    padding: 20px 15px;
  }
  
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item.dropdown
    .mobile-dropdown-menu
    .dropdown-item {
    padding: 16px 20px;
    font-size: 16px;
  }
}

/* Additional responsive styles for mobile collapse */
@media screen and (max-width: 768px) {
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item
    .mobile-submenu-collapse {
    margin: 0 -15px;
    padding: 0 15px;
  }
  
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item
    .mobile-submenu-item {
    padding: 14px 20px;
    font-size: 15px;
    margin-left: 15px;
  }
}

@media screen and (max-width: 480px) {
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item
    .mobile-collapse-toggle {
    padding: 20px 15px;
  }
  
  .global-navigation
    .navbar
    .offcanvas
    .offcanvas-body
    .navbar-nav
    .nav-item
    .mobile-submenu-item {
    padding: 16px 20px;
    font-size: 16px;
    margin-left: 10px;
  }
}

.reserve-btn {
  padding: 10px 20px;
  background: #fbb03b;
  border: 1px solid #fbb03b !important;
  font-weight: 600;
  color: #020202;
}
.reserve-btn:hover,
.reserve-btn:focus,
.reserve-btn:active {
  color: #fbb03b;
}
.hero {
  position: relative;
  background: #020202;
  max-height: 600px;
  overflow: hidden;
  aspect-ratio: 1.6 / 1;
  width: 100%;
}
.hero.overlay::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 70%;
  height: 100%;
  content: "";
  background: linear-gradient(90deg, #000 0%, transparent 100%);
  z-index: 2;
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .hero.overlay::before {
    width: 80%;
    opacity: 0.6;
  }
}
.hero.overlay::after {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 70%;
  height: 100%;
  content: "";
  background: linear-gradient(-90deg, #000 0%, transparent 100%);
  z-index: 1;
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .hero.overlay::after {
    width: 80%;
    opacity: 0.6;
  }
}
.hero .hero-swiper .swiper-slide {
  aspect-ratio: 1.6 / 1;
}
.hero .hero-swiper .swiper-slide .slide-item {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  height: 100%;
}
.hero .hero-swiper .swiper-slide .slide-item img,
.hero .hero-swiper .swiper-slide .slide-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero .hero-swiper .swiper-slide.swiper-slide-active .slide-item,
.hero .hero-swiper .swiper-slide.swiper-slide-duplicate-active .slide-item,
.hero .hero-swiper .swiper-slide.swiper-slide-prev .slide-item {
  animation: zoomUp 10s linear 0s 1 normal both;
}
@keyframes zoomUp {
  0% {
    transform: translate(-50%, -50%) scale(1);
  }
  100% {
    transform: translate(-50%, -50%) scale(1.15);
  }
}
.top-news_container {
  padding: 3em 15px;
}
.top-news_container .top_news-title {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: flex-start;
  margin-bottom: 20px;
  font-weight: 700;
  word-break: break-all;
  color: #fff;
}
.top-news_container .top_news-title img {
  max-width: 45px;
  margin-right: 5px;
}
.top-news_container .top_news-list {
  border-top: 1px dotted rgba(255, 255, 255, 0.2);
}
.top-news_container .top_news-list .top_news-item {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  border-bottom: 1px dotted rgba(255, 255, 255, 0.2);
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top-news_container .top_news-list .top_news-item {
    flex-wrap: wrap;
    padding: 10px 0;
  }
}
.top-news_container .top_news-list .top_news-item .news-date {
  padding: 10px;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .top-news_container .top_news-list .top_news-item .news-date {
    padding: 0 10px;
  }
}
.top-news_container .top_news-list .top_news-item .news-label {
  padding: 5px 15px;
  margin: 0 10px;
  border: 1px solid #fbb03b;
  white-space: nowrap;
  line-height: 1.2;
  font-size: 0.9em;
  color: #fbb03b;
}
.top-news_container .top_news-list .top_news-item .news-title {
  margin: 0;
  padding: 20px 10px;
  word-break: break-all;
  font-size: 1em;
}
@media screen and (max-width: 767px) {
  .top-news_container .top_news-list .top_news-item .news-title {
    padding: 10px;
    width: 100%;
  }
}
.top-news_container .top_news-list .top_news-item .news-title a {
  text-decoration: none;
  color: #fff;
}
.top-news_container .top_news-list .top_news-item .news-title a:hover,
.top-news_container .top_news-list .top_news-item .news-title a:focus,
.top-news_container .top_news-list .top_news-item .news-title a:active {
  text-decoration: underline;
  color: #fbb03b;
}
.top-news_container .news-more {
  margin-top: 1.5em;
  text-align: center;
}
.top_concept-container {
  position: relative;
  padding: 3em 15px;
  background: #020202;
}
.top_concept-container::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100%;
  transform: translate(-50%, -50%);
  background: url("../images/pubq-screen.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  opacity: 0.2;
}
.top_concept-container .top_concept-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.top_concept-container .top_concept-title img {
  max-width: 60px;
}
.top_concept-container .top_concept-figure {
  position: relative;
  margin: 2em auto;
  text-align: center;
}
.top_concept-container .top_concept-figure img {
  width: 100%;
  max-width: 900px;
  border-radius: 10px;
  box-shadow: 0 5px 30px rgba(0, 0, 0, 0.5);
}
.top_concept-container .concept-text {
  font-size: 1.3em;
}
@media screen and (max-width: 575px) {
  .top_concept-container .concept-text {
    font-size: 1em;
  }
}
.top_plan-container {
  padding: 3em 15px;
  max-width: 1350px;
  margin: 0 auto;
}
.top_plan-container .top_plan-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.top_plan-container .top_plan-title img {
  max-width: 60px;
}
.top_plan-container .plan-box {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: space-between;
  margin: 5em auto;
}
.top_plan-container .plan-box.reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box.reverse {
    flex-direction: column-reverse;
  }
}
.top_plan-container .plan-box.reverse .plan-info {
  padding-left: 3em;
  padding-right: 0;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box.reverse .plan-info {
    width: 100%;
    padding-left: 0;
  }
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box {
    flex-direction: column-reverse;
  }
}
.top_plan-container .plan-box .plan-info {
  width: 55%;
  padding-right: 3em;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box .plan-info {
    width: 100%;
    padding-right: 0;
  }
}
.top_plan-container .plan-box .plan-info dl {
  margin-bottom: 0;
}
.top_plan-container .plan-box .plan-info dl dt {
  padding: 15px 20px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
  color: #fff;
}
.top_plan-container .plan-box .plan-info dl dd {
  padding: 30px 20px;
  margin-bottom: 0;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box .plan-info dl dd {
    padding: 30px 0;
  }
}
.top_plan-container .plan-box .plan-info dl dd p {
  letter-spacing: 0.15em;
  line-height: 1.6;
}
.top_plan-container .plan-box .plan-image {
  position: relative;
  width: 45%;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box .plan-image {
    width: 100%;
    overflow: hidden;
    aspect-ratio: 2 / 1;
  }
}
.top_plan-container .plan-box .plan-image img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box .plan-image img {
    object-fit: cover;
    height: 100%;
  }
}
.top_plan-container .plan-box_price {
  position: relative;
  margin-top: 2em;
  padding: 15px 20px 10px;
  border: 1px solid #fff;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box_price {
    padding: 15px 10px;
  }
}
.top_plan-container .plan-box_price .plan-box_price_title {
  position: absolute;
  top: -12px;
  left: 1rem;
  display: inline-block;
  padding: 5px 10px;
  margin: 0;
  background: #020202;
  text-align: center;
  line-height: 1 !important;
  font-size: 0.9em;
  color: #fff;
}
.top_plan-container .plan-box_price .plan-box_price_table {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top_plan-container
    .plan-box_price
    .plan-box_price_table
    tr.price-row
    td:last-of-type {
    padding-top: 0;
  }
}
.top_plan-container
  .plan-box_price
  .plan-box_price_table
  tr.price-last-row
  td:first-of-type {
  padding: 0 10px;
}
.top_plan-container
  .plan-box_price
  .plan-box_price_table
  tr.price-last-row
  td:last-of-type {
  padding: 10px 10px 20px;
}
.top_plan-container .plan-box_price .plan-box_price_table td {
  padding: 10px 10px;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .top_plan-container .plan-box_price .plan-box_price_table td {
    display: block;
  }
}
.top_plan-container .plan-box_price .plan-box_price_table td .price-per {
  font-weight: 300;
  font-size: 14px;
}
.top_plan-container .plan-box_price .plan-box_price_table td.price-system {
  border-top: 1px dashed #fff;
}
.top-menu_container {
  padding: 3em 15px;
  max-width: 1350px;
  margin: 0 auto;
}
.top-menu_container .top_menu-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.top-menu_container .top_menu-title img {
  max-width: 60px;
}
.top-menu_container .menu-box {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: space-between;
  margin: 5em auto;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box {
    flex-direction: column;
  }
}
.top-menu_container .menu-box.reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box.reverse {
    flex-direction: column;
  }
}
.top-menu_container .menu-box.reverse .menu-content {
  padding-left: 0;
  padding-right: 3em;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box.reverse .menu-content {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    padding-top: 20px;
    padding-right: 0;
  }
}
.top-menu_container .menu-box .menu-image {
  width: 40%;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box .menu-image {
    width: 100%;
    aspect-ratio: 2 / 1;
    overflow: hidden;
  }
}
.top-menu_container .menu-box .menu-image img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box .menu-image img {
    height: 100%;
    object-fit: cover;
  }
}
.top-menu_container .menu-box .menu-content {
  width: 60%;
  padding-left: 3em;
}
@media screen and (max-width: 767px) {
  .top-menu_container .menu-box .menu-content {
    width: 100%;
    padding-left: 0;
  }
}
.top-menu_container .menu-box .menu-content .menu-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  margin: 0;
  color: #fbb03b;
}
.top-menu_container .menu-box .menu-content .menu-title img {
  max-width: 23px;
  margin-right: 20px;
}
.top-menu_container .menu-box .menu-content .menu-section {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  padding: 20px 0;
}
.top-menu_container .menu-box .menu-content .menu-section.drink-menu {
  padding: 0;
  margin-top: 20px;
  border-top: 0;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .accordion-header {
  padding: 20px 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  transition: background 0.3s;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .accordion-header:hover,
.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .accordion-header:focus,
.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .accordion-header:active {
  background: rgba(255, 255, 255, 0.05);
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .menu-title {
  color: #fff;
}

.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .submenu-title {
  color: #fff;
  padding:20px 10px;
}

.drink-menu-wrap .submenu-title{
    color:#fff;

}

.top-menu_container
  .menu-box
  .menu-content
  .menu-section.drink-menu
  .accordion-content
  .menu-list {
  padding: 0 20px 10px;
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section.drink-menu
    .accordion-content
    .menu-list {
    padding: 0 10px 10px;
  }
}
.top-menu_container .menu-box .menu-content .menu-section .accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-header::-webkit-details-marker {
  display: none;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-header
  .menu-title-icon {
  transition: opacity 0.3s;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 300;
  font-size: 0.85em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section
    .accordion-header
    .menu-title-icon {
    font-size: 0.8em;
  }
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section
    .accordion-header
    .menu-title-icon
    .hide-md {
    display: none;
  }
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-header:hover
  .menu-title-icon,
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-header:focus
  .menu-title-icon,
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-header:active
  .menu-title-icon {
  opacity: 0.7;
}
.top-menu_container .menu-box .menu-content .menu-section .accordion-content {
  display: none;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-content
  .menu-list {
  list-style: none;
  margin: 0;
  padding: 30px 20px 10px;
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section
    .accordion-content
    .menu-list {
    padding: 10px 10px;
  }
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-content
  .menu-list
  li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 0;
  letter-spacing: 0.15em;
  line-height: 1.3;
  font-weight: 300;
  color: #fff;
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-content
  .menu-list
  li
  .menu-name {
  display: flex;
  align-items: center;
  width: 70%;
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section
    .accordion-content
    .menu-list
    li
    .menu-name {
    padding-right: 10px;
    align-items: flex-start;
  }
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-content
  .menu-list
  li
  .menu-name
  .menu-star {
  display: block;
  width: 30px;
  margin-right: 5px;
}
@media screen and (max-width: 767px) {
  .top-menu_container
    .menu-box
    .menu-content
    .menu-section
    .accordion-content
    .menu-list
    li
    .menu-name
    .menu-star {
    width: 25px;
  }
}
.top-menu_container
  .menu-box
  .menu-content
  .menu-section
  .accordion-content
  .menu-list
  li
  .menu-price {
  min-width: 20%;
  text-align: right;
  white-space: nowrap;
}
.top-gallery_container {
  background: url("../images/main-picture.jpg");
  background-position: center;
  background-size: cover;
}
.top-gallery_container .top-gallery_content-inner {
  padding: 3em 15px;
  margin: 0 auto;
  max-width: 1350px;
}
.top-gallery_container .top_gallery-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.top-gallery_container .top_gallery-title img {
  max-width: 60px;
}
.top-gallery_container .gallery-box,
.gallery-container .gallery-box {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin: 3em auto 5em;
  max-width: 960px;
}
@media screen and (max-width: 767px) {
  .top-gallery_container .gallery-box,
  .gallery-container .gallery-box {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 575px) {
  .top-gallery_container .gallery-box,
  .gallery-container .gallery-box {
    gap: 10px;
  }
}
.top-gallery_container .gallery-box .gallery-item:nth-child(5n-4),
.gallery-container .gallery-box .gallery-item:nth-child(5n-4) {
  grid-row: auto / span 2;
  grid-column: auto / span 2;
}
@media screen and (max-width: 767px) {
  .top-gallery_container .gallery-box .gallery-item:nth-child(5n-4),
  .gallery-container .gallery-box .gallery-item:nth-child(5n-4) {
    grid-row: auto;
  }
}
.top-gallery_container .gallery-box .gallery-item:nth-child(5n-1),
.gallery-container .gallery-box .gallery-item:nth-child(5n-1) {
  grid-row: auto / span 2;
}
@media screen and (max-width: 767px) {
  .top-gallery_container .gallery-box .gallery-item:nth-child(5n-1),
  .gallery-container .gallery-box .gallery-item:nth-child(5n-1) {
    grid-row: auto;
  }
}
.top-gallery_container .gallery-box .gallery-item img,
.gallery-container .gallery-box .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 5px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
.top-gallery_container .modal-content,
.gallery-container .modal-content {
  background: rgba(0, 0, 0, 0.5);
}
.top-gallery_container .modal-content .modal-body,
.gallery-container .modal-content .modal-body {
  position: relative;
}
.top-gallery_container .modal-content .modal-body .image-modal-close,
.gallery-container .modal-content .modal-body .image-modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  appearance: none;
  border: 0;
  border-radius: 50%;
  transition: background 0.3s;
  cursor: pointer;
  color: #020202;
}
.top-gallery_container .modal-content .modal-body .image-modal-close:hover,
.top-gallery_container .modal-content .modal-body .image-modal-close:focus,
.top-gallery_container .modal-content .modal-body .image-modal-close:active,
.gallery-container .modal-content .modal-body .image-modal-close:hover,
.gallery-container .modal-content .modal-body .image-modal-close:focus,
.gallery-container .modal-content .modal-body .image-modal-close:active {
  background: #fbb03b;
}
.top-shop_container {
  padding: 3em 15px;
  margin: 0 auto;
  max-width: 1350px;
}
.top-shop_container .top_gallery-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 40px;
  font-weight: 700;
  color: #fff;
}
.top-shop_container .top_gallery-title img {
  max-width: 60px;
}
.top-shop_container .shop-access_wrap {
  position: relative;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  margin-bottom: 6em;
}
@media screen and (max-width: 991px) {
  .top-shop_container .shop-access_wrap {
    flex-direction: column;
  }
}
.top-shop_container .shop-access_wrap .access-map {
  position: relative;
  width: 80vw;
  padding-top: calc(1 / 2 * 100%);
  height: 0;
}
@media screen and (max-width: 991px) {
  .top-shop_container .shop-access_wrap .access-map {
    width: 100%;
  }
}
.top-shop_container .shop-access_wrap .access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}
.top-shop_container .shop-access_wrap .shop-info {
  position: absolute;
  right: 0;
  bottom: -40px;
  width: 40vw;
  padding: 20px;
  min-width: 600px;
  background: #020202;
}
@media screen and (max-width: 991px) {
  .top-shop_container .shop-access_wrap .shop-info {
    position: relative;
    right: auto;
    bottom: auto;
    min-width: unset;
    width: 100%;
  }
}
@media screen and (max-width: 575px) {
  .top-shop_container .shop-access_wrap .shop-info {
    padding: 20px 0;
  }
}
.top-shop_container .shop-access_wrap .shop-info .shop-name {
  margin-bottom: 10px;
  font-weight: 700;
  color: #fbb03b;
}
.top-shop_container .shop-access_wrap .shop-info .shop-address {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 575px) {
  .top-shop_container .shop-access_wrap .shop-info .shop-address {
    flex-direction: column;
    align-items: flex-start;
    margin: 15px auto;
  }
}
.top-shop_container .shop-access_wrap .shop-info .shop-address .address {
  margin-bottom: 0;
  color: #fff;
}
.top-shop_container .shop-access_wrap .shop-info .shop-address .address-pin {
  font-weight: 300;
  font-size: 0.9em;
  color: #fff;
}
@media screen and (max-width: 575px) {
  .top-shop_container .shop-access_wrap .shop-info .shop-address .address-pin {
    display: block;
    margin-top: 10px;
    width: 100%;
    border: 1px solid #fff;
    text-align: center;
    padding: 15px;
  }
}
.top-shop_container .shop-access_wrap .shop-info .shop-contact {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  margin-top: 10px;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.top-shop_container .shop-access_wrap .shop-info .shop-contact .shop-tel {
  margin-right: 10px;
  line-height: 1.3;
}
.top-shop_container .shop-access_wrap .shop-info .shop-contact .shop-tel-num {
  text-decoration: none;
  line-height: 1.3;
  font-size: 1.5em;
  color: #fff;
}
.top-shop_container .shop-access_wrap .shop-info .shop-open-time {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding-top: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
}
.top-shop_container
  .shop-access_wrap
  .shop-info
  .shop-open-time
  .open-time-name {
  margin-right: 20px;
  color: #fff;
}
.page-header {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 20px;
  height: 400px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .page-header {
    height: 250px;
  }
}
.page-header .page-title {
  position: relative;
  margin-bottom: 0;
  letter-spacing: 0.15em;
  line-height: 1.3;
  font-weight: 700;
  font-size: 3em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .page-header .page-title {
    font-size: 2em;
  }
}
@media screen and (max-width: 575px) {
  .page-header .page-title {
    font-size: 1.5em;
  }
}
.page-header::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.6);
  width: 100%;
  height: 100%;
}
.page-header.page-news {
  background: url("../images/gallery1.png");
  background-position: center;
  background-size: cover;
}
.page-header.page-menu {
  background: url("../images/food_fish_and_chips.jpg");
  background-position: center;
  background-size: cover;
}
.page-header.page-common {
  background: url("../images/guide01.jpg");
  background-position: center;
  background-size: cover;
}
.section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 700;
  color: #fff;
}
.section-title img {
  max-width: 60px;
}
.table-type1 {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
}
@media screen and (max-width: 767px) {
  .table-type1 {
    border-top: 0;
  }
}
.table-type1 th,
.table-type1 td {
  border-bottom-color: rgba(255, 255, 255, 0.3) !important;
  padding: 20px 10px;
  color: #fff;
}
.table-type1 th a,
.table-type1 td a {
  text-decoration: underline;
  font-weight: 300;
  color: #fff;
}
.table-type1 th a:hover,
.table-type1 th a:focus,
.table-type1 th a:active,
.table-type1 td a:hover,
.table-type1 td a:focus,
.table-type1 td a:active {
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .table-type1 th,
  .table-type1 td {
    border-bottom: 0;
    display: block;
    width: 100% !important;
  }
}
@media screen and (max-width: 767px) {
  .table-type1 th {
    padding: 10px 20px;
    border-left: 1px solid #fff;
  }
}
@media screen and (max-width: 767px) {
  .table-type1 td {
    padding: 15px 20px 30px;
  }
}
.fade-target {
  opacity: 0;
  transform: translate(0, -30px);
  transition: all 1.5s;
}
.fade-target.scrollin {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
}
.system-wrap {
  max-width: 960px;
  margin: 5em auto;
}
.system-wrap .system-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.system-wrap .system-table thead th {
  width: 33%;
  padding: 30px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  text-align: center;
  vertical-align: middle;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-size: 1.2em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .system-wrap .system-table thead th {
    width: 50%;
    padding: 30px 10px;
  }
}
.system-wrap .system-table thead th:first-of-type {
  border-left: 1px solid #fff;
}
.system-wrap .system-table thead th:last-of-type {
  border-right: 1px solid #fff;
}
@media screen and (max-width: 767px) {
  .system-wrap .system-table thead th.hide-md {
    display: none;
  }
}
.system-wrap .system-table td {
  padding: 20px;
  background: #f6f4eb;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  text-align: center;
  vertical-align: middle;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 700;
  font-size: 1.1em;
  color: #020202;
}
.system-wrap .system-table tbody tr:first-of-type td {
  border-top: 5px solid #020202;
}
.system-wrap .system-table tbody tr:last-of-type td {
  border-bottom: 0;
}
@media screen and (max-width: 767px) {
  .system-wrap .system-table tbody tr td.hide-md {
    display: none;
  }
}
.system-wrap .system-table tbody .system-time {
  display: none;
}
@media screen and (max-width: 767px) {
  .system-wrap .system-table tbody .system-time {
    display: block;
    padding: 0 0 10px;
    margin-bottom: 10px;
    border-bottom: 1px dashed rgba(0, 0, 0, 0.2);
  }
}
.plan-cards-wrap {
  max-width: 1000px;
  margin: 3em auto 5em;
  display: flex;
  align-items: stretch;
  justify-content: center;
}
@media screen and (max-width: 991px) {
  .plan-cards-wrap {
    flex-wrap: wrap;
  }
}
.plan-cards-wrap .plan-card {
  display: flex;
  flex-direction: column;
  width: calc(100% / 3 - 30px);
  border: 5px solid #f6f4eb;
  margin: 0 15px;
}
@media screen and (max-width: 991px) {
  .plan-cards-wrap .plan-card {
    width: calc(100% / 2 - 30px);
    margin: 0 15px 15px;
  }
}
@media screen and (max-width: 767px) {
  .plan-cards-wrap .plan-card {
    width: 100%;
    margin: 15px auto;
  }
}
.plan-cards-wrap .plan-card .plan-card_header {
  padding: 20px;
  background: #020202;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1.2;
  font-weight: 700;
  font-size: 1.3em;
  color: #fff;
}
.plan-cards-wrap .plan-card .plan-card_body {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 10px;
  background: #f6f4eb;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .plan-cards-wrap .plan-card .plan-card_body .plan-detail {
    justify-content: center;
  }
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-time {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 95px;
  height: 95px;
  border-radius: 50%;
  background: #ac1f27;
  margin-right: 10px;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: 800;
  color: #fff;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-time .plan-num {
  display: inline-block;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-time .fs-min {
  display: inline-block;
  font-size: 1.2em;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-price {
  text-align: center;
  line-height: 1;
  letter-spacing: 0.1em;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
  font-weight: 800;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-price .plan-num {
  display: inline-block;
  font-family: "Montserrat", "Noto Sans JP", "Hiragino Kaku Gothic ProN",
    "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "メイリオ", "Helvetica Neue",
    "Segoe UI", Meiryo;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-detail .plan-price .fs-yen {
  display: inline-block;
  font-size: 1.2em;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-card_divider {
  border-color: rgba(0, 0, 0, 0.4);
  width: 100%;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-card_footer {
  flex: 1;
  width: 100%;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-card_footer ul {
  margin-bottom: 0;
}
.plan-cards-wrap .plan-card .plan-card_body .plan-card_footer ul li {
  margin-bottom: 5px;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 500;
  font-size: 1.1em;
}
.plan-cards-wrap
  .plan-card
  .plan-card_body
  .plan-card_footer
  ul
  li:last-of-type {
  margin-bottom: 0;
}
.plan-wrap {
  max-width: 960px;
  margin: 3em auto 5em;
}
.plan-wrap .plan-table {
  border-collapse: separate;
  border-spacing: 0;
  background: #f6f4eb;
  width: 100%;
}
.plan-wrap .plan-table thead th {
  width: 33%;
  padding: 30px;
  text-align: center;
  vertical-align: middle;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-size: 1.2em;
  background: #020202;
  border-top: 5px solid #f6f4eb;
  border-left: 5px solid #f6f4eb;
  color: #fbb03b;
}
@media screen and (max-width: 767px) {
  .plan-wrap .plan-table thead th {
    width: 50%;
    padding: 30px 10px;
  }
}
.plan-wrap .plan-table thead th:last-of-type {
  border-right: 5px solid #f6f4eb;
}
@media screen and (max-width: 767px) {
  .plan-wrap .plan-table thead th.hide-md {
    display: none;
  }
}
.plan-wrap .plan-table td {
  padding: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  text-align: center;
  vertical-align: middle;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 700;
  font-size: 1.1em;
  color: #020202;
}
@media screen and (max-width: 767px) {
  .plan-wrap .plan-table td {
    padding: 20px 10px;
  }
}
.plan-wrap .plan-table tbody tr:last-of-type td {
  border-bottom: 0;
}
@media screen and (max-width: 767px) {
  .plan-wrap .plan-table tbody tr td.hide-md {
    display: none;
  }
}
.plan-wrap .plan-table tbody .plan-time {
  display: none;
}
@media screen and (max-width: 767px) {
  .plan-wrap .plan-table tbody .plan-time {
    display: block;
    padding: 0 0 10px;
    margin-bottom: 10px;
    border-bottom: 1px dashed rgba(0, 0, 0, 0.2);
    font-weight: 700;
  }
}
.menu-container {
  margin: 3em auto 5em;
  max-width: 1350px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .menu-container {
    padding: 0 20px;
  }
}
.food-menu-section {
  position: relative;
  margin: 5em auto;
}
@media screen and (max-width: 767px) {
  .food-menu-section {
    flex-direction: column-reverse;
  }
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu-title {
    text-align: center;
  }
}
.food-menu-section .food-menu-tabs {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 960px;
  margin: 2em auto;
  padding-left: 5px;
  padding-right: 5px;
}
@media screen and (max-width: 479px) {
  .food-menu-section .food-menu-tabs {
    padding-left: 0;
    padding-right: 0;
  }
}
.food-menu-section .food-menu-tabs .food-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(100% / 2 - 20px);
  padding: 20px 20px;
  margin: 10px;
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  line-height: 1.3;
  letter-spacing: 0.1em;
  word-break: break-word;
  text-decoration: none;
  font-weight: 400;
  font-size: 1.1em;
  cursor: pointer;
  color: #fff;
  transition: background 0.3s, border-color 0.3s, color 0.3s;
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu-tabs .food-tab {
    font-size: 1em;
  }
}
@media screen and (max-width: 479px) {
  .food-menu-section .food-menu-tabs .food-tab {
    width: 100%;
    margin: 10px auto;
  }
}
.food-menu-section .food-menu-tabs .food-tab:hover,
.food-menu-section .food-menu-tabs .food-tab:focus,
.food-menu-section .food-menu-tabs .food-tab:active {
  border-color: #fbb03b;
  font-weight: bold;
  color: #fbb03b;
}
.food-menu-section .food-menu-tabs .food-tab.is-active {
  border-color: #fbb03b;
  font-weight: bold;
  color: #fbb03b;
}
.food-menu-section .food-menu {
  margin: -70px auto;
  padding-top: 100px;
  padding-right: 20px;
  padding-left: 20px;
  max-width: 1000px;
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu {
    padding-left: 0;
    padding-right: 0;
  }
}
.food-menu-section .food-menu .food-menu-divider {
  border-color: rgba(255, 255, 255, 0.5);
}
.food-menu-section .food-menu .food-menu-cards {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: wrap;
  list-style-type: none;
  margin: 0;
  margin-left: -15px;
  margin-right: -15px;
  padding: 0;
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu .food-menu-cards {
    margin: 0 auto;
  }
}
.food-menu-section .food-menu .food-menu-cards .food-menu-card {
  width: calc(100% / 3 - 30px);
  margin: 15px;
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu .food-menu-cards .food-menu-card {
    width: calc(100% / 2 - 30px);
  }
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu .food-menu-cards .food-menu-card {
    width: auto;
    margin: 15px auto;
  }
}
.food-menu-section .food-menu .food-menu-cards .food-menu-card .food-menu-info {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin: 12px auto;
  color: #fff;
}
.food-menu-section
  .food-menu
  .food-menu-cards
  .food-menu-card
  .food-menu-info
  .food-name {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  line-height: 1.3;
  letter-spacing: 0.1em;
}
.food-menu-section
  .food-menu
  .food-menu-cards
  .food-menu-card
  .food-menu-info
  .food-price {
  margin-left: 10px;
  text-align: right;
  white-space: nowrap;
  line-height: 1.3;
}
.food-menu-section .food-menu .food-menu-list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style-type: none;
  padding: 0;
  margin: 0 auto;
}
.food-menu-section .food-menu .food-menu-list li {
  width: calc(100% / 2 - 40px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  padding: 12px 0;
  letter-spacing: 0.1em;
  line-height: 1.3;
  color: #fff;
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu .food-menu-list li {
    width: 100%;
  }
}
.food-menu-section .food-menu .food-menu-list li .menu-name {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu .food-menu-list li .menu-name {
    padding-right: 10px;
    align-items: flex-start;
  }
}
.food-menu-section .food-menu .food-menu-list li .menu-name .menu-point {
  display: block;
  width: 30px;
  margin-right: 5px;
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu .food-menu-list li .menu-name .menu-point {
    width: 25px;
  }
}
.food-menu-section .food-menu-panel {
  margin: 0 auto;
  max-width: 1000px;
}
.food-menu-section .food-menu-panel .food-menubox-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu-panel .food-menubox-wrap {
    flex-wrap: wrap;
  }
}
.food-menu-section .food-menu-panel .food-menubox-wrap .food-menubox {
  width: calc(100% / 3 - 30px);
  margin: 15px;
}
@media screen and (max-width: 767px) {
  .food-menu-section .food-menu-panel .food-menubox-wrap .food-menubox {
    width: calc(100% / 2 - 30px);
  }
}
@media screen and (max-width: 575px) {
  .food-menu-section .food-menu-panel .food-menubox-wrap .food-menubox {
    width: 100%;
    margin: 15px auto;
  }
}
.food-menu-section .food-menu-panel .food-menubox-wrap .food-info {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin: 20px auto;
  color: #fff;
}
.food-menu-section .food-menu-panel .food-menubox-wrap .food-info .food-name {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  line-height: 1.3;
  letter-spacing: 0.1em;
}
.food-menu-section .food-menu-panel .food-menubox-wrap .food-info .food-price {
  text-align: right;
  white-space: nowrap;
  margin-left: 10px;
  line-height: 1.3;
}
.drink-menu-section .drink-menu-title {
  text-align: center;
}
.drink-menu-section .menu-tabs {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 960px;
  margin: 2em auto;
  padding-left: 5px;
  padding-right: 5px;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 479px) {
  .drink-menu-section .menu-tabs {
    padding-left: 0;
    padding-right: 0;
  }
}
.drink-menu-section .menu-tabs .menu-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(100% / 3 - 10px);
  padding: 20px 20px;
  margin: 5px;
  text-align: center;
  border: 1px solid #fff;
  line-height: 1.3;
  letter-spacing: 0.1em;
  word-break: break-word;
  text-decoration: none;
  font-weight: 400;
  cursor: pointer;
  color: #fff;
  transition: background 0.3s, border-color 0.3s, color 0.3s;
}
@media screen and (max-width: 575px) {
  .drink-menu-section .menu-tabs .menu-tab {
    width: calc(100% / 2 - 10px);
  }
}
@media screen and (max-width: 479px) {
  .drink-menu-section .menu-tabs .menu-tab {
    width: 100%;
    margin: 5px auto;
  }
}
.drink-menu-section .menu-tabs .menu-tab:hover,
.drink-menu-section .menu-tabs .menu-tab:focus,
.drink-menu-section .menu-tabs .menu-tab:active {
  border-color: #fbb03b;
  background: #fbb03b;
  color: #020202;
}
.drink-menu-section .menu-tabs .menu-tab.is-active {
  border-color: #fbb03b;
  background: #fbb03b;
  color: #020202;
}
.drink-menu-section .menu-panels {
  margin-top: -70px;
}
.drink-menu-section .menu-panels .menu-panel {
  padding-top: 100px;
  display: none;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 1000px;
}

[id] {
  scroll-margin-top: 200px;
}
@media screen and (max-width: 991px) {
  .drink-menu-section .menu-panels .menu-panel {
    padding-top: 60px;
  }
}
@media screen and (max-width: 767px) {
  .drink-menu-section .menu-panels .menu-panel {
    flex-direction: column;
  }
}
.drink-menu-section .menu-panels .menu-panel .menu-image {
  width: 30%;
}
@media screen and (max-width: 767px) {
  .drink-menu-section .menu-panels .menu-panel .menu-image {
    width: 100%;
    aspect-ratio: 1.5 / 1;
    overflow: hidden;
    margin-bottom: 1.5em;
  }
}
.drink-menu-section .menu-panels .menu-panel .menu-image img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .drink-menu-section .menu-panels .menu-panel .menu-image img {
    height: 100%;
    object-fit: cover;
  }
}
.drink-menu-section .menu-panels .menu-panel.is-active {
  display: flex;
  animation: panel-show 0.9s ease-in-out forwards;
}
.drink-menu-section .menu-panels .menu-panel .drink-menu-wrap {
  width: 70%;
  padding-right: 3em;
  padding-left: 2em;
}
@media screen and (max-width: 767px) {
  .drink-menu-section .menu-panels .menu-panel .drink-menu-wrap {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
}
.drink-menu-section .menu-panels .menu-panel .drink-menu-wrap .drink-menu-list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style-type: none;
  padding: 0;
  margin-bottom: 2em;
}
.drink-menu-section
  .menu-panels
  .menu-panel
  .drink-menu-wrap
  .drink-menu-list
  li {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  padding: 15px 0;
  letter-spacing: 0.1em;
  line-height: 1.3;
  color: #fff;
}
.drink-menu-section
  .menu-panels
  .menu-panel
  .drink-menu-wrap
  .drink-menu-list
  li
  .menu-name {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .drink-menu-section
    .menu-panels
    .menu-panel
    .drink-menu-wrap
    .drink-menu-list
    li
    .menu-name {
    padding-right: 10px;
    align-items: flex-start;
  }
}
.drink-menu-section
  .menu-panels
  .menu-panel
  .drink-menu-wrap
  .drink-menu-list
  li
  .menu-name
  .menu-star {
  display: block;
  width: 30px;
  margin-right: 5px;
}
@media screen and (max-width: 767px) {
  .drink-menu-section
    .menu-panels
    .menu-panel
    .drink-menu-wrap
    .drink-menu-list
    li
    .menu-name
    .menu-star {
    width: 25px;
  }
}
@media screen and (max-width: 767px) {
  .drink-menu-section
    .menu-panels
    .menu-panel
    .drink-menu-wrap
    .drink-menu-list
    li
    .menu-price {
    white-space: nowrap;
  }
}
@media screen and (max-width: 991px) {
  .drink-menu-section
    .menu-panels
    .menu-panel
    .drink-menu-wrap
    .drink-menu-list
    li {
    width: 100%;
  }
}
@keyframes panel-show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.gallery-container {
  max-width: 1350px;
  padding: 0 20px;
  margin: 5em auto;
}
.contact-form input.form-control {
  padding: 14px 12px;
  background: transparent;
  border-radius: 4px 4px 0 0;
  border: 0;
  border-bottom: 1px solid #fff;
  letter-spacing: 0.1em;
  line-height: 1.3;
  color: #fff;
}
.contact-form input.form-control::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.contact-form input.form-control:focus {
  background: rgba(255, 255, 255, 0.05);
  box-shadow: none;
}
.contact-form input.form-control:-webkit-autofill {
  box-shadow: 0 0 0 1000px #000 inset !important;
  -webkit-text-fill-color: #fff !important;
}
.contact-form textarea.form-control {
  padding: 14px 12px;
  background: transparent;
  border-radius: 4px 4px 0 0;
  border: 0;
  border-bottom: 1px solid #fff;
  letter-spacing: 0.1em;
  line-height: 1.3;
  color: #fff;
}
.contact-form textarea.form-control::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.contact-form textarea.form-control:focus {
  background: rgba(255, 255, 255, 0.05);
  box-shadow: none;
}
.contact-form textarea.form-control:-webkit-autofill {
  box-shadow: 0 0 0 1000px #000 inset !important;
  -webkit-text-fill-color: #fff !important;
}
.news-container {
  max-width: 960px;
  margin: 5em auto;
}
.news-container .news-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  padding: 30px 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}
.news-container .news-item:first-of-type {
  padding-top: 10px;
}
.news-container .news-item:last-of-type {
  border-bottom: 0;
}
@media screen and (max-width: 575px) {
  .news-container .news-item {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 50px 20px;
    margin-bottom: 0;
  }
}
.news-container .news-item:hover,
.news-container .news-item:focus,
.news-container .news-item:active {
  background: rgba(255, 255, 255, 0.05);
}
.news-container .news-item:hover .news-item_link .link-btn_bd_white,
.news-container .news-item:focus .news-item_link .link-btn_bd_white,
.news-container .news-item:active .news-item_link .link-btn_bd_white {
  background: #fff;
  color: #020202;
}
.news-container .news-item .news-item_thumb {
  width: 200px;
  min-width: 200px;
  overflow: hidden;
  margin-right: 30px;
}
.news-container .news-item .news-item_thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media screen and (max-width: 575px) {
  .news-container .news-item .news-item_thumb img {
    object-fit: cover;
  }
}
@media screen and (max-width: 575px) {
  .news-container .news-item .news-item_thumb {
    width: 100%;
    min-width: unset;
    aspect-ratio: 2 / 1;
    margin-right: 0;
    margin-bottom: 20px;
  }
}
.news-container .news-item .news-item_content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: space-between;
}
.news-container .news-item .news-item_content .item_content-header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  margin-bottom: 10px;
}
.news-container .news-item .news-item_content .item_content-header .news-label {
  padding: 5px 15px;
  margin-right: 10px;
  border: 1px solid #fbb03b;
  white-space: nowrap;
  line-height: 1.2;
  font-size: 0.9em;
  color: #fbb03b;
}
.news-container .news-item .news-item_content .item_content-header .news-date {
  font-size: 0.9em;
  color: #fff;
}
.news-container .news-item .news-item_content .item_content-body {
  width: 100%;
  flex: 1;
  word-break: break-all;
}
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_title {
  color: #fff;
}
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text {
  color: #fff;
}
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  h1,
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  h2,
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  h3,
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  h4,
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  h5 {
  color: #fff;
}
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_text
  p {
  color: #fff;
}
.news-container
  .news-item
  .news-item_content
  .item_content-body
  .news-item_link {
  text-align: right;
}
.news-container .news-post-wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 20px;
}
.news-container .news-post-wrap .news-post-thumbnail img {
  width: 100%;
}
.news-container .news-post-wrap .post-info {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 10px auto;
}
.news-container .news-post-wrap .post-info .post-label {
  padding: 5px 15px;
  margin-right: 10px;
  border: 1px solid #fbb03b;
  white-space: nowrap;
  line-height: 1.2;
  font-size: 0.9em;
  color: #fbb03b;
}
.news-container .news-post-wrap .post-info .post-date {
  font-size: 0.9em;
  color: #fff;
}
.news-container .news-post-wrap .post-title {
  margin-bottom: 20px;
  font-weight: 700;
  word-break: break-all;
  color: #fff;
}
.news-container .news-post-wrap .post-body {
  padding: 20px 0;
  word-break: break-all;
  color: #fff;
}
.news-container .news-post-wrap .post-body h1,
.news-container .news-post-wrap .post-body h2,
.news-container .news-post-wrap .post-body h3,
.news-container .news-post-wrap .post-body h4,
.news-container .news-post-wrap .post-body h5 {
  color: #fff;
}
.news-container .news-post-wrap .post-body p {
  color: #fff;
}
.news-container .news-post-wrap .post-body a {
  text-decoration: underline;
  color: #fbb03b;
}
.news-container .news-post-wrap .post-body a:hover,
.news-container .news-post-wrap .post-body a:focus,
.news-container .news-post-wrap .post-body a:active {
  color: #fff;
}
.shop-map {
  position: relative;
  width: 100%;
  padding-top: calc(1 / 1.2 * 100%);
  height: 0;
}
.shop-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}
.shop-tel_wrap {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  margin-bottom: 30px;
  font-weight: 700;
  color: #fff;
}
.shop-tel_wrap .shop-tel {
  margin-right: 10px;
  line-height: 1.3;
}
.shop-tel_wrap .shop-tel-num {
  text-decoration: none;
  line-height: 1.3;
  font-size: 1.5em;
  color: #fff;
}
.link-btn_black {
  display: inline-block;
  border: 1px solid #020202;
  padding: 15px 20px;
  text-decoration: none;
  text-align: center;
  color: #020202;
}
@media screen and (max-width: 767px) {
  .link-btn_black {
    display: block;
  }
}
.link-btn_black:hover,
.link-btn_black:focus,
.link-btn_black:active {
  opacity: 1;
  background: #020202;
  color: #fff;
}
.link-btn_white {
  display: inline-block;
  border: 1px solid #fff;
  background: #fff;
  padding: 15px 20px;
  text-decoration: none;
  text-align: center;
  color: #020202;
}
@media screen and (max-width: 767px) {
  .link-btn_white {
    display: block;
  }
}
.link-btn_white:hover,
.link-btn_white:focus,
.link-btn_white:active {
  opacity: 1;
  background: transparent;
  color: #fff;
}
.link-btn_bd_white {
  display: inline-block;
  border: 1px solid #fff;
  padding: 15px 20px;
  text-decoration: none;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .link-btn_bd_white {
    display: block;
  }
}
.link-btn_bd_white:hover,
.link-btn_bd_white:focus,
.link-btn_bd_white:active {
  opacity: 1;
  background: #fff;
  color: #020202;
}
.link-btn_yellow {
  display: inline-block;
  border: 1px solid #fbb03b;
  background: #fbb03b;
  padding: 15px 20px;
  text-decoration: none;
  text-align: center;
  color: #020202;
}
@media screen and (max-width: 767px) {
  .link-btn_yellow {
    display: block;
  }
}
.link-btn_yellow:hover,
.link-btn_yellow:focus,
.link-btn_yellow:active {
  opacity: 1;
  background: transparent;
  color: #fbb03b;
}
.link-btn_bd_yellow {
  display: inline-block;
  border: 1px solid #fbb03b;
  padding: 15px 20px;
  text-decoration: none;
  text-align: center;
  color: #fbb03b;
}
@media screen and (max-width: 767px) {
  .link-btn_bd_yellow {
    display: block;
  }
}
.link-btn_bd_yellow:hover,
.link-btn_bd_yellow:focus,
.link-btn_bd_yellow:active {
  opacity: 1;
  background: #fbb03b;
  color: #020202;
}
.footer {
  background: url("../images/main-picture.jpg");
  background-position: center;
  background-size: cover;
}
.footer .footer-fade {
  opacity: 0;
  transform: translate(0, -30px);
  transition: all 1.5s;
}
.footer .footer-fade.scrollin {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
}
.footer .footer-wrapper {
  padding-top: 3em;
  text-align: center;
}
.footer .footer-wrapper .footer-restaurant-info {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
  padding-bottom: 30px;
  max-width: 960px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
@media screen and (max-width: 767px) {
  .footer .footer-wrapper .footer-restaurant-info {
    flex-direction: column;
  }
}
.footer .footer-wrapper .footer-restaurant-info .restaurant-details {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  flex: 1;
}
@media screen and (max-width: 767px) {
  .footer .footer-wrapper .footer-restaurant-info .restaurant-details {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 575px) {
  .footer .footer-wrapper .footer-restaurant-info .restaurant-details {
    flex-direction: column;
    justify-content: center;
  }
}
.footer .footer-wrapper .footer-restaurant-info .restaurant-details .site-logo {
  padding: 0px;
}
@media screen and (max-width: 575px) {
  .footer
    .footer-wrapper
    .footer-restaurant-info
    .restaurant-details
    .site-logo {
    margin-bottom: 30px;
  }
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .site-logo
  img {
  max-width: 100px;
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner {
  padding-left: 20px;
}
@media screen and (max-width: 575px) {
  .footer
    .footer-wrapper
    .footer-restaurant-info
    .restaurant-details
    .details-inner {
    padding-left: 0;
    text-align: center;
  }
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner
  .restaurant-name {
  display: block;
  margin-bottom: 5px;
  letter-spacing: 0.1em;
  text-decoration: none;
  font-weight: 600;
  color: #fbb03b;
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner
  .restaurant-location {
  margin-bottom: 0;
  font-weight: 300;
  font-size: 0.9em;
  color: #fff;
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner
  .restaurant-tel {
  display: flex;
  align-items: center;
  margin-top: 15px;
  text-decoration: none;
  color: #fff;
}
@media screen and (max-width: 575px) {
  .footer
    .footer-wrapper
    .footer-restaurant-info
    .restaurant-details
    .details-inner
    .restaurant-tel {
    justify-content: center;
  }
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner
  .restaurant-tel
  .tel-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  color: #020202;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  margin-right: 10px;
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-details
  .details-inner
  .restaurant-tel
  .tel {
  line-height: 1.2;
  font-weight: 700;
  font-size: 1.6em;
}
.footer .footer-wrapper .footer-restaurant-info .restaurant-reserve {
  width: 30%;
}
@media screen and (max-width: 575px) {
  .footer .footer-wrapper .footer-restaurant-info .restaurant-reserve {
    width: 100%;
  }
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-reserve
  .reserve-btn {
  width: 100%;
  padding: 15px;
}
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-reserve
  .reserve-btn:hover,
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-reserve
  .reserve-btn:focus,
.footer
  .footer-wrapper
  .footer-restaurant-info
  .restaurant-reserve
  .reserve-btn:active {
  border-color: #fbb03b !important;
  color: #fbb03b;
}
@media screen and (max-width: 575px) {
  .footer
    .footer-wrapper
    .footer-restaurant-info
    .restaurant-reserve
    .reserve-btn {
    max-width: 300px;
  }
}
.footer .footer-nav {
  margin-top: 20px;
  margin-bottom: 20px;
}
.footer .footer-nav .navbar {
  padding: 0;
}
.footer .footer-nav .navbar .navbar-nav .nav-item .nav-link {
  transition: color 0.3s;
  text-decoration: none;
  font-weight: 300;
  color: #fff;
  font-size: 20px;
}
.footer .footer-nav .navbar .navbar-nav .nav-item .nav-link:hover,
.footer .footer-nav .navbar .navbar-nav .nav-item .nav-link:focus,
.footer .footer-nav .navbar .navbar-nav .nav-item .nav-link:active {
  opacity: 1;
  color: #fbb03b;
}
.footer .footer-sns {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin: 30px auto;
}
.footer .footer-sns .sns-button {
  display: inline-block;
  padding: 12px 20px;
  margin: 5px;
  border: 1px solid #fff;
  border-radius: 6px;
  line-height: 1.2;
  text-decoration: none;
  color: #fff;
}
.footer .footer-sns .sns-button:hover,
.footer .footer-sns .sns-button:focus,
.footer .footer-sns .sns-button:active {
  border-color: #fbb03b;
  color: #fbb03b;
}
.footer .copyright {
  margin-bottom: 0;
  text-align: center;
  font-weight: 300;
  font-size: 0.9em;
  color: #fff;
}
.scroll-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 99;
  transform: scale(0);
  transition: transform 0.3s;
}
.scroll-top.show {
  transform: scale(1);
}
.scroll-top .scroll-top-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 60px;
  height: 60px;
  background: #fbb03b;
  border-radius: 50%;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  line-height: 1;
  font-size: 40px;
  font-weight: 700;
  cursor: pointer;
  color: #020202;
}
.scroll-top .scroll-top-icon:hover,
.scroll-top .scroll-top-icon:focus,
.scroll-top .scroll-top-icon:active {
  opacity: 0.8;
}
@media (min-width: 992px) {
  .global-navigation .navbar .navbar-collapse {
    display: flex !important;
    justify-content: space-between; /* nav on left-center, button on right */
    align-items: center;
  }
  .global-navigation .navbar .navbar-nav {
    margin: 0 auto; /* center the nav links */
    display: flex;
    gap: 60px; /* increased spacing between links */
  }
  .global-navigation .navbar .nav-button {
    margin: 0; /* keep button on the right */
  }

   .global-navigation .navbar .nav-item.dropdown {
    position: relative;
  }
  .global-navigation .navbar .nav-item.dropdown:hover > .dropdown-menu,
  .global-navigation .navbar .nav-item.dropdown:focus-within > .dropdown-menu {
    display: block;
    opacity: 1;
    visibility: visible;
  }
  .global-navigation .navbar .dropdown-menu {
    display: block; /* always block for positioning */
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 100%;
    left: 0;
    width: 200px; /* adjust as needed */
    background: rgba(255, 255, 255, 0.1);  /* dark semi-transparent background */
    border: none; /* remove border */
    border-radius: 0; /* square corners */
    padding: 20px;
    transition: opacity 0.3s ease, visibility 0.3s ease;
  }
  .global-navigation .navbar .dropdown-menu .dropdown-item {
    color: #fff;
    padding: 10px;
    font-weight: 500;
    letter-spacing: 0.05em;
    transition: background 0.3s, color 0.3s;
  }
  .global-navigation .navbar .dropdown-menu .dropdown-item:hover,
  .global-navigation .navbar .dropdown-menu .dropdown-item:focus {
    background: rgba(255, 255, 255, 0.1); /* subtle hover effect */
    color: #FBB03B; /* match main nav hover color */
  }
}


/* ---------------- Submenu Navbar ---------------- */
.submenu-navbar {
  background-color: #000;
  border-top: 1px solid #222;
  border-bottom: 1px solid #222;
  padding: 1rem 0;
  position: sticky;
  top: 80px;
}

/* Links flex layout with icon and text */
.submenu-navbar .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem; /* space between icon and text */
  color: #aaa;
  font-size: 1.25rem;
  font-weight: 500;
  position: relative;
  transition: color 0.2s ease;
}

/* Text only hover & underline */
.submenu-navbar .submenu-text {
  position: relative;
  transition: color 0.2s ease;
}

.submenu-navbar .submenu-text::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 50%;
  width: 100%;
  height: 2px;
  background-color: #f7f4eb;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform 0.3s ease;
}

.submenu-navbar .nav-link:hover .submenu-text {
  color: #f7f4eb;
}

.submenu-navbar .nav-link:hover .submenu-text::after {
  transform: translateX(-50%) scaleX(1);
}

/* Active text */
.submenu-navbar .nav-link.active .submenu-text {
  color: #f7f4eb;
}

.submenu-navbar .nav-link.active .submenu-text::after {
  transform: translateX(-50%) scaleX(1);
}

/* Icon size and hover effect */
.submenu-navbar .submenu-icon {
  width: 52px;       /* smaller icon */
  height: 42px;      /* maintain aspect ratio */
  flex-shrink: 0;    
  filter: grayscale(100%) brightness(50%);
  transition: filter 0.2s ease;
}
@media screen and (max-width: 767px) {
  .submenu-navbar .submenu-icon {
    display: none; /* hide icons */
  }

  .submenu-navbar .nav-link {
    display: flex !important;       /* ensure flex layout */
    flex-direction: row !important; /* force row layout */
    justify-content: center;        /* center text horizontally */
    align-items: center;            /* center vertically */
  }
}



.submenu-navbar .nav-link:hover .submenu-icon,
.submenu-navbar .nav-link.active .submenu-icon {
  filter: grayscale(0%) brightness(100%);
}

/* ---------------- Facility Section ---------------- */
.facility-section {
  background-color: #020202;
  padding: 3rem 0;
}

/* Boxes */
.facility-box {
  padding: 2rem 1rem;  
  width: 95%;             
  max-width: 970px;       
  margin: 0 auto; 
  text-align: center;
  font-weight: 600;
  font-size: 1.1rem;  
  margin-top: 3rem;    
  border: 1px solid #888; /* gray border for all boxes */
}

/* First box black with bottom margin */
.facility-box.first-box {
  background-color: #020202;
  color: #f7f4eb;
  margin-bottom: 1.5rem;
  border-radius: 0.25rem;
}

/* Other boxes attached */
.facility-box.no-gap {
  background-color: #f7f4eb;
  color: #000;
  border-radius: 0; /* attached appearance */
  margin: 0 auto;
  border-left: 1px solid #888;
  border-right: 1px solid #888;
}

/* Add top border to the first attached box for separation */
.facility-box.no-gap:first-of-type {
  border-top: 1px solid #888;
}

/* Heading below boxes */
.facility-title {
  font-size: 1rem !important;
  font-weight: 600;
  margin-top: 2rem !important;
  margin-left: 11rem;
}

/* Bracket text under price */
.bracket-text {
  font-weight: 400;   
  font-size: 1rem;    
  display: block;     
}

/* ---------------- Course Section ---------------- */
.course-section {
  background-color: #000;
  color: #f7f4eb;
  padding: 3rem 1rem; /* smaller horizontal padding for mobile */
}

.course-section .section-title {
  font-size: 2rem;
  color: #fff;
}

.course-section .section-title img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  margin-right: 0.5rem;
}

/* ---------------- Course Menu Box ---------------- */
.coursemenu-box {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  flex-wrap: wrap;
  justify-content: center;
}

/* Left Column: Image */
.coursemenu-image {
  flex: 1 1 400px;
  max-width: 400px;
}

.coursemenu-image img {
  width: 100%;
  border-radius: 10px;
  display: block;
}

/* Right Column: Description */
.coursemenu-content {
  flex: 1 1 400px;
  max-width: 600px;
}

/* Course title with icon */
.coursemenu-title {
  font-size: 1.5rem;
  color: #fbb03b;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.coursemenu-title img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

/* Course menu list */
.coursemenu-list {
  list-style: none;
  padding: 0;
  margin: 0;
  color: #f7f4eb;
}

.coursemenu-list li {
  margin-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: baseline;
}

.coursemenu-list .coursemenu-name,
.coursemenu-list .coursemenu-price {
  font-size: 1.2rem;
  font-weight: 500;
  color: #f7f4eb;
}

.coursemenu-list .coursemenu-price {
  font-weight: bold;
  color: #fff;
  margin-left: 1rem; /* push price to the right */
  white-space: nowrap;
}

/* Extra spacing for specific items */
.coursemenu-list li:nth-child(7) {
  margin-top: 3rem;
}

.coursemenu-list li:nth-child(8) {
  margin-top: 0;
}

.coursemenu-list li:last-child {
  margin-top: 3rem;
}

/* ---------------- Snack Menu (if used) ---------------- */
.snack-menu {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.snack-menu-list {
  list-style: disc;
  padding: 1.5rem;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

.snack-menu-list li::before {
  content: "•";
  color: #fff;
  display: inline-block;
  width: 1em;
}

.snack-menu-list li {
  display: flex;
  justify-content: space-between;
  font-size: 1rem;
  color: #fff;
}

.food-name {
  flex: 1;
  font-weight: 200;
}

.food-price {
  font-weight: 600;
}

/* ---------------- Responsive ---------------- */
@media (max-width: 992px) {
  .coursemenu-box {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }

  .coursemenu-image,
  .coursemenu-content {
    width: 100%;
    max-width: 100%;
    padding: 0 1rem; /* optional horizontal padding */
    margin: 0;
  }
}

@media (max-width: 768px) {
  .coursemenu-title {
    font-size: 1.3rem;
  }

  .coursemenu-list .coursemenu-name,
  .coursemenu-list .coursemenu-price {
    font-size: 1rem;
  }

  .snack-menu-list li {
    font-size: 0.95rem;
  }
}

#alacarteSection .section-title {
  margin-bottom: 0.5rem; /* small gap */
}

#alacarteSection .food-menu-tabs:first-of-type {
  margin-top: 0; /* remove gap above first tab */
}

.submenu-section {
  position: sticky;
  top: 90px;
  z-index: 999;
}
.food-menu-card img {
  width: 100%;
  height: 250px; /* you can adjust this to your preferred height */
  object-fit: cover; /* keeps proportions while cropping evenly */
}

/* ===== Party Content Sections ===== */
section.party-content {
  display: flex;
  flex-direction: column;
  align-items: center; /* center content horizontally */
  justify-content: center;
  width: 100%;
  margin: 3rem 0; /* vertical spacing between sections */
  color: white;
  font-size: 18px; /* font size */
  line-height: 1.6; /* spacing between lines */
  padding: 1rem 2rem; /* padding around content */
  background: rgba(0, 0, 0, 0.2); /* subtle background */
  border-radius: 10px; /* rounded corners */
}

/* ===== Row and Columns (Scoped to Party Section) ===== */
section.party-content .row {
  display: flex;
  flex-wrap: nowrap;
  gap: 2rem; /* gap between image and text */
  width: 100%;
  align-items: flex-start;
}

section.party-content .col-md-4 {
  flex: 0 0 38%;
  max-width: 38%;
}

section.party-content .col-md-8 {
  flex: 0 0 62%;
  max-width: 62%;
  display: flex;
  flex-direction: column;
  justify-content: center; /* vertically center content if desired */
}

/* Image column */
section.party-content .col-md-4 img.party-image {
  width: 100%;
  height: 250px;
  object-fit: cover;
  border-radius: 5px;
}

section.party-content ul {
  padding-left: 1.5rem; /* proper indentation for bullets */
  margin: 1rem 0; /* spacing above and below the list */
}

section.party-content ul li {
  margin-bottom: 0.8rem; /* space between each bullet */
}

/* Optional: increase bullet size */
section.party-content ul li::marker {
  font-size: 1.2em; /* slightly bigger bullets */
}

/*===== Responsive: stack on small screens =====*/
@media (max-width: 768px) {
  section.party-content .row {
    flex-wrap: wrap;
  }

  section.party-content .col-md-4,
  section.party-content .col-md-8 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  section.party-content .col-md-4 img.party-image {
    height: 200px; /* smaller image on mobile */
  }

  section.party-content {
    font-size: 1.1rem;
    padding: 1rem;
  }
}

/* Section titles */
section.party-content .section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 2rem;
}

/*# sourceMappingURL=main-style.css.map */
