@charset "UTF-8";
/* Reset */
html, body, header, main, footer, div, article, nav, section, p, span, a, table, thead, tbody, tr, th, td, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, form, input, select, textarea, label, button {
  position: relative;
}

html, body, #container {
  width: 100%;
  height: 100svh;
}

body {
  font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif", sans-serif;
  font-size: 1em;
  line-height: 1.6;
  background-color: #333;
}

#container {
  margin: 0 auto;
  width: 100%;
  max-width: 1920px;
  min-width: 340px;
}
#container .spacer {
  margin-top: 2px;
}
@media (width <= 820px) {
  #container::after {
    content: "";
    display: block;
    margin-top: 2px;
    width: 100%;
    height: 60px;
  }
}

h2 {
  margin: 0 auto 40px;
  text-align: center;
  color: #0E50AE;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  line-height: 1;
}

h3 {
  color: #0E50AE;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

h4 {
  color: #0E50AE;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1;
}

.fontL {
  font-size: 1.125rem;
}

.fontS {
  font-size: 0.875rem;
}

span.nw {
  white-space: nowrap;
}

.col_red {
  color: #D03434;
}

img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (hover: hover) and (pointer: fine) {
  a,
  summary,
  button {
    opacity: 1;
    transition: opacity 0.25s;
  }
  a:hover,
  summary:hover,
  button:hover {
    opacity: 0.25;
    transition: all 0.5s;
  }
  a.disabled,
  summary.disabled,
  button.disabled {
    pointer-events: none;
  }
  a.tel, a.mail {
    flex-shrink: 0;
    display: inline-block;
    padding-bottom: 0.25em;
    white-space: nowrap;
    font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif", sans-serif;
    line-height: 1;
    -webkit-text-decoration: solid underline #c8c8c8 1px;
            text-decoration: solid underline #c8c8c8 1px;
    text-underline-offset: 5px;
  }
}
[data-scrl=disp] {
  transition: opacity 0.5s 0.25s ease-in-out;
  opacity: 0;
}
[data-scrl=disp].disp {
  opacity: 1;
}

.forSP {
  display: none;
}
@media (width <= 576px) {
  .forSP {
    display: block;
  }
}

#header {
  padding: 0 0 13%;
  aspect-ratio: 2868/1763;
  width: 100%;
  height: auto;
}
@media (width <= 576px) {
  #header {
    height: 667px;
  }
}
#header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  aspect-ratio: 2868/1763;
  width: 100%;
  min-width: 1440px;
  height: auto;
  background-image: url(../img/header/mv_img.jpg);
  background-repeat: no-repeat;
  background-position: top;
  background-size: cover;
  transform: translateX(-50%);
}
@media (width <= 1440px) {
  #header::before {
    min-width: auto;
  }
}
@media (width <= 1200px) {
  #header::before {
    height: auto;
  }
}
@media (width <= 576px) {
  #header::before {
    aspect-ratio: 1/1;
    height: 100%;
  }
}
#header .header__body {
  aspect-ratio: 1440/800;
  padding: 0;
  width: 100%;
  height: auto;
}
@media (width <= 820px) {
  #header .header__body {
    min-height: auto;
  }
}
@media (width <= 576px) {
  #header .header__body {
    height: 95%;
  }
}
#header .header__body .logo {
  position: absolute;
  top: 50%;
  left: 50%;
  margin: 0 auto 0;
  padding: 15px;
  aspect-ratio: 1/1;
  width: 100%;
  max-width: 520px;
  min-width: 280px;
  height: auto;
  transform: translate(-50%, -50%);
}
@media (width <= 1440px) {
  #header .header__body .logo {
    width: 36%;
  }
}
@media (width <= 820px) {
  #header .header__body .logo {
    max-width: 450px;
  }
}
#header .header__body .logo img {
  width: 100%;
  height: 100%;
}
#header .header__body .info {
  position: absolute;
  bottom: 0;
  left: 50%;
  display: flex;
  gap: 16px;
  margin: 0 auto;
  padding: 0 15px;
  width: 100%;
  max-width: calc(600px + (30px));
  transform: translateX(-50%);
}
@media (width <= 1200px) {
  #header .header__body .info {
    max-width: calc(460px + (30px));
  }
}
@media (width <= 820px) {
  #header .header__body .info {
    max-width: calc(330px + (30px));
  }
}
#header .header__body .info .info__date {
  flex-grow: 1;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 4px;
  padding: 3.25%;
  max-width: calc((100% - 16px) / 2);
  background-color: #D03434;
  border-radius: 8px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  word-break: keep-all;
}
#header .header__body .info .info__date span:nth-of-type(1) {
  grid-column: 1/2;
  grid-row: 1/2;
}
#header .header__body .info .info__date span:nth-of-type(2) {
  grid-column: 1/2;
  grid-row: 2/3;
}
#header .header__body .info .info__date span:nth-of-type(3) {
  justify-self: end;
  align-self: center;
  grid-column: 2/3;
  grid-row: 1/3;
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 1;
  word-break: keep-all;
}
#header .header__body .info .info__date span:nth-of-type(3) span {
  font-size: 4rem;
  line-height: 0.6;
}
@media (width <= 1200px) {
  #header .header__body .info .info__date {
    font-size: calc(1.5rem * 0.75);
  }
  #header .header__body .info .info__date span:nth-of-type(3) {
    font-size: calc(2.5rem * 0.75);
  }
  #header .header__body .info .info__date span:nth-of-type(3) span {
    font-size: calc(4rem * 0.75);
  }
}
@media (width <= 820px) {
  #header .header__body .info .info__date {
    font-size: calc(1.5rem * 0.55);
  }
  #header .header__body .info .info__date span:nth-of-type(3) {
    font-size: calc(2.5rem * 0.55);
  }
  #header .header__body .info .info__date span:nth-of-type(3) span {
    font-size: calc(4rem * 0.55);
  }
}
#header .header__body .info .info__venue {
  flex-grow: 1;
  max-width: calc((100% - 16px) / 2);
  background-color: #FF7A00;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125rem;
  line-height: 1;
}
#header .header__body .info .info__venue span {
  display: block;
  width: 100%;
  text-align: center;
}
#header .header__body .info .info__venue span:nth-of-type(1)::before {
  content: "\f3c5";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0.25em;
}
#header .header__body .info .info__venue span:nth-of-type(2) {
  font-size: 3rem;
  font-weight: 900;
}
@media (width <= 1200px) {
  #header .header__body .info .info__venue {
    font-size: calc(1.125rem * 0.75);
  }
  #header .header__body .info .info__venue span:nth-of-type(2) {
    font-size: calc(3rem * 0.75);
  }
}
@media (width <= 820px) {
  #header .header__body .info .info__venue {
    font-size: calc(1.125rem * 0.55);
  }
  #header .header__body .info .info__venue span:nth-of-type(2) {
    font-size: calc(3rem * 0.55);
  }
}
#header::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  aspect-ratio: 1440/223;
  width: 100%;
  height: auto;
  background-image: url(../img/header/header_line.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: calc(100% + 2px);
  transform: translateX(-50%);
}

ul.basic {
  list-style-type: disc;
  padding-left: 1.4em;
}
ul.basic li {
  padding: 0.25em 0 0.25em 0;
  line-height: 1.2;
}
ul.annot li {
  padding: 0.25em 0 0.25em 1.25em;
  line-height: 1.2;
}
ul.annot li::before {
  content: "※";
  display: inline-block;
  margin-right: 0.25em;
  margin-left: -1.25em;
}
ul.guide {
  padding-left: 1.5em;
}
ul.guide li {
  padding: 0.25em 0 0.25em 0;
  font-size: 0.875rem;
  line-height: 1.2;
}
ul.guide li a {
  -webkit-text-decoration: solid underline #c8c8c8 1px;
          text-decoration: solid underline #c8c8c8 1px;
  text-underline-offset: 5px;
}
ul.guide li::before {
  display: inline-block;
  width: 16px;
  height: 16px;
  color: #FFC107;
  font-size: 16px !important;
  text-align: center;
}
ul.guide li.address::before {
  content: "\f3c5";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: -1.3em;
  margin-right: 0.3em;
}
ul.guide li.tel::before {
  content: "\f3ce";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: -1.3em;
  margin-right: 0.3em;
}
ul.guide li.url::before {
  content: "\f0ac";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: -1.3em;
  margin-right: 0.3em;
}

.button_area {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.button_area .btn-basic {
  display: grid;
  grid-template-columns: 45px auto auto 45px;
  margin: 0 auto;
  padding: 0;
  width: auto;
  height: 60px;
  background-color: #FF7A00;
  border-radius: 30px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.button_area .btn-basic > * {
  color: #fff;
}
.button_area .btn-basic::before {
  grid-column: 2/3;
  grid-row: 1/2;
  align-self: center;
  content: "";
  display: block;
  aspect-ratio: 1/1;
  margin-right: 5px;
  width: 40px;
  height: auto;
  background-color: #fff;
  -webkit-mask-image: url("../img/charm_tour/icon_fish.svg");
          mask-image: url("../img/charm_tour/icon_fish.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
.button_area .btn-basic h3 {
  grid-column: 3/4;
  grid-row: 1/2;
  align-self: center;
  line-height: 1;
}
.button_area .btn-basic h3 span {
  word-break: keep-all;
}
.button_area .btn-basic h3 span::after {
  content: "エントリー受付中";
}
.button_area .btn-basic.advance h3 span::after {
  content: "事前エントリーをする";
}
.button_area .btn-basic.reserv h3 span {
  word-break: normal;
}
.button_area .btn-basic.reserv h3 span::after {
  display: none;
}
.button_area .btn-basic.reserv::before {
  content: "\f015";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  background-color: transparent;
  -webkit-mask: unset;
          mask: unset;
  font-size: 1.5rem;
  color: #fff;
  transform: translateY(0.05em);
}
.button_area .btn-basic.reserv.disabled h3 span {
  word-break: keep-all;
}
.button_area .btn-basic.reserv.disabled h3 span::after {
  content: "宿泊予約受付前";
}
.button_area .btn-basic.disabled {
  pointer-events: none;
  background-color: #9CA3AF;
  cursor: not-allowed;
}
.button_area .btn-basic.disabled h3 span::after {
  content: "エントリー受付前";
}
.button_area .btn-basic.close {
  pointer-events: none;
  background-color: #9CA3AF;
  cursor: not-allowed;
}
.button_area .btn-basic.close h3 span {
  word-break: normal;
}
.button_area .btn-basic.close h3 span::after {
  display: none;
}
.button_area .btn-basic.privacy {
  gap: 1em;
  min-width: 300px;
}
.button_area .btn-basic.privacy h3 {
  grid-column: 2/4;
  text-align: center;
}
.button_area .btn-basic.privacy h3 span {
  color: #fff;
}
.button_area .btn-basic.privacy h3 span::after {
  content: "閉じる";
}
.button_area .btn-basic.privacy::before {
  display: none;
}
.button_area .btn-basic:not(.disabled):hover {
  opacity: 0.5;
}
@media (width <= 576px) {
  .button_area .btn-basic {
    grid-template-columns: 1fr auto auto 1fr;
    width: 100%;
  }
}
@media (width <= 400px) {
  .button_area .btn-basic.reserv {
    letter-spacing: -0.05em;
  }
  .button_area .btn-basic.reserv::before {
    display: none;
  }
  .button_area .btn-basic.close {
    letter-spacing: -0.05em;
  }
  .button_area .btn-basic.close::before {
    display: none;
  }
}

#contents {
  margin-top: -2px;
  width: 100%;
  background-color: #fff;
}
#contents .sec {
  margin: 0 auto 80px;
  padding: 0 30px;
  width: 100%;
  max-width: 1160px;
}
@media (width <= 576px) {
  #contents .sec {
    padding: 0 15px;
  }
}
#contents .sec.sec-top h2 {
  margin: 0 auto calc(2rem * -1 + 24px);
  max-width: 700px;
  text-align: center;
  color: #333;
  font-family: "Reggae One", system-ui;
  font-size: clamp(0.8rem, -0.211rem + 5.05vw, 2rem);
  font-weight: 400;
  line-height: 1.3;
  transform: translateY(calc(2rem * -1));
}
#contents .sec.sec-top .top_lead {
  margin: 0 auto 30px;
  width: 100%;
  max-width: 565px;
}
#contents .sec.sec-top .movie iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
}
@media (width <= 820px) {
  #contents .sec.sec-top {
    padding: 0 10px;
  }
  #contents .sec.sec-top h2 {
    margin: 0 auto calc(1rem * -1 + 24px);
    transform: translateY(calc(1rem * -1));
  }
}
@media (width <= 576px) {
  #contents .sec.sec-top h2 {
    margin: 0 auto calc(1rem * -1 + 24px);
    font-size: 1.25rem;
    overflow-wrap: anywhere;
    word-break: normal;
    line-break: strict;
  }
}
#contents .sec.sec-charm_tour > * {
  margin-bottom: 60px;
}
#contents .sec.sec-charm_tour > *:last-child(1) {
  margin-bottom: 0;
}
#contents .sec.sec-charm_tour h2 {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 24px 16px;
  background-color: #0E50AE;
  border-radius: 8px;
  font-size: clamp(1.75rem, 0.861rem + 4.44vw, 2.25rem);
}
#contents .sec.sec-charm_tour h2 span {
  min-height: 72px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_tour h2 span {
    min-height: 50px;
  }
}
#contents .sec.sec-charm_tour h2 span.left {
  width: 100%;
  max-width: 78px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_tour h2 span.left {
    max-width: 50px;
  }
}
#contents .sec.sec-charm_tour h2 span.left::before {
  content: "";
  position: absolute;
  top: 0;
  right: -10px;
  display: block;
  aspect-ratio: 55/36;
  width: 100%;
  max-width: 55px;
  height: auto;
  background-image: url(../img/charm_tour/h2_charm_ship.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_tour h2 span.left::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  display: block;
  aspect-ratio: 78/67;
  width: 100%;
  max-width: 78px;
  height: auto;
  background-image: url(../img/charm_tour/h2_charm_bubble01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_tour h2 span.text {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  max-width: 210px;
  color: #fff;
}
#contents .sec.sec-charm_tour h2 span.text::after {
  content: "";
  display: block;
  margin: 10px 0 0;
  aspect-ratio: 210/14;
  width: 100%;
  max-width: 210px;
  height: auto;
  background-image: url(../img/charm_tour/h2_charm_wave.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_tour h2 span.right {
  width: 100%;
  max-width: 78px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_tour h2 span.right {
    max-width: 50px;
  }
}
#contents .sec.sec-charm_tour h2 span.right::after {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 0;
  display: block;
  aspect-ratio: 67/59;
  width: 100%;
  height: auto;
  background-image: url(../img/charm_tour/h2_charm_bubble02.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_tour .tour_charm {
  counter-reset: charm_cnt;
  display: flex;
  justify-content: space-between;
  gap: 30px;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item {
  counter-increment: charm_cnt;
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
  width: calc((100% - 30px) / 2);
  max-width: 324px;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item h3 {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  color: #333;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item h3::before {
  counter-increment: section;
  content: counter(charm_cnt);
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  width: 100%;
  max-width: 64px;
  height: auto;
  border-radius: 50%;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item .img {
  aspect-ratio: 324/144;
  width: 100%;
  height: auto;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item:nth-of-type(1) h3::before {
  background-color: #BAE6FD;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item:nth-of-type(2) h3::before {
  background-color: #FFDBB9;
}
#contents .sec.sec-charm_tour .tour_charm .tour_charm__item:nth-of-type(3) h3::before {
  background-color: #FFEAAC;
}
@media (width <= 820px) {
  #contents .sec.sec-charm_tour .tour_charm {
    flex-wrap: wrap;
  }
  #contents .sec.sec-charm_tour .tour_charm .tour_charm__item {
    max-width: none;
  }
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour .tour_charm .tour_charm__item {
    width: 100%;
  }
}
#contents .sec.sec-charm_tour .tour_status {
  display: grid;
  grid-template-columns: 1fr 420px;
  grid-template-rows: auto auto auto auto auto auto;
  gap: 0px 0px;
  margin: 0 auto 120px;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status > * {
  align-self: start;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
#contents .sec.sec-charm_tour .tour_status .list_table {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  border: solid 1px #0C79ED;
  border-radius: 12px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
#contents .sec.sec-charm_tour .tour_status .list_table dt {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  width: 155px;
  background-color: #F0F9FF;
  border-style: solid;
  border-width: 1px;
  border-color: #F0F9FF;
  border-top: none;
  border-left: none;
}
#contents .sec.sec-charm_tour .tour_status .list_table dt:nth-of-type(1) {
  border-radius: 12px 0 0 0;
}
#contents .sec.sec-charm_tour .tour_status .list_table dt:nth-last-of-type(1) {
  border-radius: 0 0 0 12px;
}
#contents .sec.sec-charm_tour .tour_status .list_table dd {
  padding: 12px 16px;
  width: calc(100% - 155px);
  background-color: #fff;
  border-style: solid;
  border-width: 1px;
  border-color: #F0F9FF;
  border-top: none;
  border-right: none;
  border-left: none;
}
#contents .sec.sec-charm_tour .tour_status .list_table dd:nth-of-type(1) {
  border-radius: 0 12px 0 0;
}
#contents .sec.sec-charm_tour .tour_status .list_table dd:nth-last-of-type(1) {
  border-radius: 0 0 12px 0;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest {
  grid-column: 2/3;
  grid-row: 3/4;
  padding-top: 100px;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest h3 {
  color: #D03434;
  text-shadow: 1px 0 2px white, 1px 0 2px white, 1px 0 2px white, 1px 0 2px white, 1px 0 2px white, 1px 0 2px white, 1px 0 2px white;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__text {
  padding: 20px;
  background-color: #0E50AE;
  border-radius: 20px;
  color: #fff;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__text h4 {
  margin-bottom: 10px;
  color: #fff;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__text h4::before {
  content: "▼";
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img {
  grid-column: 1/2;
  grid-row: 3/4;
  margin: 50px auto 0;
  aspect-ratio: 600/800;
  width: 100%;
  max-width: 290px;
  height: auto;
  transform: rotate(5deg);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img img {
  border-radius: 20px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img::before, #contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img::after {
  content: "";
  position: absolute;
  display: block;
  aspect-ratio: 74/30;
  width: 74px;
  height: auto;
  background-color: #FFC107;
  -webkit-mask-image: url("../img/charm_tour/guest_light.svg");
          mask-image: url("../img/charm_tour/guest_light.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img::before {
  top: 0;
  left: 0;
  transform: rotate(-35deg) translate(-25%, -150%);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img::after {
  right: 0;
  bottom: 0;
  transform: rotate(145deg) translate(-25%, -150%);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest::before {
  content: "";
  position: absolute;
  top: 70px;
  left: 0;
  display: block;
  width: calc(100% - 20px);
  height: 83px;
  background-image: url("../img/charm_tour/guest_ship.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: right center;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__guest::after {
  z-index: 10;
  grid-column: 1/2;
  grid-row: 3/4;
  align-self: center;
  content: "";
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 360px;
  height: 79px;
  background-image: url("../img/charm_tour/guest_fish.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center left;
  transform: translate(0, 50%);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__rule {
  grid-column: 1/2;
  grid-row: 1/2;
  padding-right: 20px;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__rule h3::before {
  content: "\f24e";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 10px;
  color: #0C79ED;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__rule .list_table {
  max-width: 630px;
}
#contents .sec.sec-charm_tour .tour_status .bobble01,
#contents .sec.sec-charm_tour .tour_status .bobble02 {
  display: flex;
  width: 100%;
  max-width: 630px;
  height: 100%;
  min-height: 133px;
}
#contents .sec.sec-charm_tour .tour_status .bobble01::before,
#contents .sec.sec-charm_tour .tour_status .bobble02::before {
  content: "";
  display: block;
  width: 100%;
  max-width: 260px;
  height: 133px;
  background-image: url(../img/charm_tour/status_bobble.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: right;
}
#contents .sec.sec-charm_tour .tour_status .bobble01 {
  grid-column: 1/2;
  grid-row: 2/3;
  justify-content: flex-end;
  align-items: flex-end;
  margin-top: 20px;
}
#contents .sec.sec-charm_tour .tour_status .bobble02 {
  grid-column: 1/3;
  grid-row: 4/5;
  justify-content: center;
  align-items: center;
  max-width: none;
  height: 200px;
}
#contents .sec.sec-charm_tour .tour_status .bobble02::before {
  transform: rotate(180deg);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule {
  grid-column: 1/2;
  grid-row: 3/4;
  justify-self: end;
  padding-right: 20px;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule h3::before {
  content: "\f017";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 10px;
  color: #0C79ED;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .info__date {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 4px;
  padding: 11px 22px;
  width: 100%;
  max-width: 210px;
  background-color: #D03434;
  border-radius: 8px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1rem;
  line-height: 1;
  word-break: keep-all;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .info__date span:nth-of-type(1) {
  grid-column: 1/2;
  grid-row: 1/2;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .info__date span:nth-of-type(2) {
  grid-column: 1/2;
  grid-row: 2/3;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .info__date span:nth-of-type(3) {
  justify-self: end;
  align-self: center;
  grid-column: 2/3;
  grid-row: 1/3;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  word-break: keep-all;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .info__date span:nth-of-type(3) span {
  font-size: 3rem;
  line-height: 0.6;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list {
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item {
  padding: 16px 0 16px 16px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 1px;
  height: 100%;
  background-color: #BADBFF;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item::after {
  content: "";
  position: absolute;
  top: calc(16px + 0.25em);
  left: 0;
  display: block;
  aspect-ratio: 1/1;
  width: 16px;
  height: auto;
  border-radius: 50%;
  transform: translateX(-50%);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item .time {
  color: #0E50AE;
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 1;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item h4 {
  margin-bottom: 0.5em;
  color: #333;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item h4 .fa-ship {
  margin-left: 0.25em;
  color: #0C79ED;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(1) {
  padding-top: 32px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(1)::after {
  top: calc(32px + 0.25em);
  background-color: #FFC107;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(2)::after {
  background-color: #00A3E0;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(3)::after {
  background-color: #FF7A00;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(4)::after {
  background-color: #FFC107;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(5)::after {
  background-color: #00A3E0;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(6)::after {
  background-color: #FF7A00;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(7)::after {
  background-color: #FFC107;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(8) {
  padding-bottom: 32px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list .list__item:nth-of-type(8)::after {
  background-color: #00A3E0;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat {
  grid-column: 2/3;
  grid-row: 1/3;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat h3::before {
  content: "\f559";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 10px;
  color: #0C79ED;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_qual .list_qual__item {
  padding: 0.5em 0;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_qual .list_qual__item .basic {
  margin-top: 0.75em;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_qual .list_qual__item .link_list {
  flex-shrink: 0;
  display: inline-block;
  padding-bottom: 0.25em;
  white-space: nowrap;
  font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif", sans-serif;
  line-height: 1;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_qual .list_qual__item .link_list::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  border-bottom: solid 1px rgba(255, 122, 0, 0.5);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_shop {
  width: 100%;
  max-width: 650px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat .list_shop .list_shop__item .wrapper h5 {
  flex-grow: 1;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__qualificat h4 {
  color: #333;
  font-size: 1rem;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry {
  grid-column: 1/3;
  grid-row: 5/6;
  width: 100%;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry h3::before {
  content: "\f044";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 10px;
  color: #0C79ED;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text {
  display: grid;
  grid-template-columns: 1fr 630px;
  grid-template-rows: auto 1fr;
  gap: 0 20px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(1) {
  grid-column: 1/2;
  grid-row: 1/2;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(2) {
  grid-column: 2/3;
  grid-row: 1/3;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(3) {
  grid-column: 1/2;
  grid-row: 2/3;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry {
  align-self: start;
  display: flex;
  gap: 20px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 26px 26px 1fr;
  gap: 5px;
  padding: 8px 0;
  aspect-ratio: 10/9;
  width: 100%;
  max-width: 144px;
  height: auto;
  background-color: #fff;
  border: solid 4px #D03434;
  border-radius: 20px;
  text-align: center;
  color: #333;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item h4 {
  line-height: 1.2;
  color: #333;
  font-size: 1.25rem;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item h4 span {
  white-space: nowrap;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item p {
  line-height: 1.2;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item::after {
  content: "\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  position: absolute;
  right: 0;
  top: 50%;
  line-height: 1;
  color: #D03434;
  font-size: 2.5rem;
  transform: translate(16px, -50%);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item:nth-of-type(even) {
  background-color: #D03434;
  color: #fff;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item:nth-of-type(even) h4 {
  color: #fff;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item:nth-last-of-type(1) h4 {
  grid-row: 1/4;
  align-self: center;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item:nth-last-of-type(1)::after {
  display: none;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .table_wrapper .list_table dt {
  width: 220px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .table_wrapper .list_table dd {
  width: calc(100% - 220px);
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .table_wrapper .fish {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  height: 1px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .table_wrapper .fish .wrapper {
  margin: 0 auto;
  width: 100%;
  max-width: 1300px;
}
#contents .sec.sec-charm_tour .tour_status .tour_status__entry .table_wrapper .fish .wrapper::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  aspect-ratio: 178/137;
  width: 100%;
  max-width: 178px;
  height: auto;
  background-image: url(../img/charm_tour/entry_fish.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  transform: translate(0, -50px);
}
#contents .sec.sec-charm_tour .tour_status .button_area {
  grid-column: 1/3;
  grid-row: 6/7;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 30px;
}
#contents .sec.sec-charm_tour .tour_status .button_area .opt__text {
  display: block;
  text-align: center;
}
@media (width <= 1015px) {
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(1) {
    grid-column: auto;
    grid-row: auto;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(2) {
    grid-column: auto;
    grid-row: auto;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text > *:nth-child(3) {
    grid-column: auto;
    grid-row: auto;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .fish {
    display: none;
  }
}
@media (width <= 820px) {
  #contents .sec.sec-charm_tour .tour_status {
    display: block;
  }
  #contents .sec.sec-charm_tour .tour_status > * {
    margin-bottom: 40px;
  }
  #contents .sec.sec-charm_tour .tour_status > *:nth-last-child(1) {
    margin-bottom: 0;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table {
    flex-direction: column;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table dt {
    width: 100% !important;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table dt:nth-of-type(1) {
    border-radius: 12px 12px 0 0;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table dd {
    width: 100% !important;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table dd:nth-of-type(1) {
    border-radius: 0;
  }
  #contents .sec.sec-charm_tour .tour_status .list_table dd:nth-last-of-type(1) {
    border-radius: 0 0 12px 12px;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__guest,
  #contents .sec.sec-charm_tour .tour_status .tour_status__rule,
  #contents .sec.sec-charm_tour .tour_status .tour_status__schedule,
  #contents .sec.sec-charm_tour .tour_status .tour_status__qualificat,
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry {
    grid-column: auto;
    grid-row: auto;
    justify-self: center;
    padding-right: 0;
    max-width: none;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__guest {
    padding-top: 0;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__guest .guest__img {
    max-width: 250px;
    transform: rotate(0);
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__guest::before {
    top: -40px;
    max-width: 340px;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__rule .list_table {
    max-width: none;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__schedule .schedule__list {
    margin: 0 auto;
  }
  #contents .sec.sec-charm_tour .tour_status .bobble01,
  #contents .sec.sec-charm_tour .tour_status .bobble02 {
    justify-content: center;
    align-items: center;
    max-width: none;
    height: 160px;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry {
    flex-direction: column;
    align-items: center;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item {
    aspect-ratio: 7/3;
    max-width: 300px;
  }
  #contents .sec.sec-charm_tour .tour_status .tour_status__entry .entry__text .list_entry .list_entry__item::after {
    content: "\f0dd";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin-left: 0;
    margin-right: 0;
    top: auto;
    bottom: 0;
    right: 50%;
    transform: translate(50%, 18px);
  }
}
#contents .sec.sec-charm_tour .tour_status__award {
  margin: 0 calc(50% - 50vw) 120px;
  width: 100vw;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap {
  z-index: 1;
  margin: 0 auto;
  padding-top: 16px;
  max-width: 1100px;
  background-color: #FFC107;
  border-radius: 48px 48px 0 0;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding: 48px 48px;
  background-color: #fff;
  border-radius: 32px 32px 0 0;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body h3 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body h3::before, #contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body h3::after {
  content: "\f06b";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  display: inline-block;
  color: #FFC107;
  font-size: 2rem;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__text {
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__text .strong {
  color: #FF7A00;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list {
  display: flex;
  gap: 16px;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item {
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 288/162;
  width: 100%;
  max-width: calc((100% - 32px) / 3);
  height: auto;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item img {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item h4 {
  z-index: 100;
  color: #fff;
}
#contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item::before {
  content: "";
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}
#contents .sec.sec-charm_tour .tour_status__award::before {
  z-index: 0;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 1300px;
  height: 130px;
  background-image: url(../img/charm_tour/award_fish01.svg);
  background-repeat: no-repeat;
  background-size: 100px;
  transform: translate(-50%, 0);
}
#contents .sec.sec-charm_tour .tour_status__award::after {
  z-index: 0;
  content: "";
  display: block;
  position: absolute;
  bottom: -60px;
  left: 50%;
  width: 100%;
  max-width: 1450px;
  height: 137px;
  background-image: url(../img/charm_tour/award_fish02.svg);
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: 178px;
  transform: translate(-50%, 0);
}
@media (width <= 820px) {
  #contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body {
    padding: 24px 24px;
  }
  #contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list {
    flex-wrap: wrap;
  }
  #contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item {
    max-width: calc((100% - 16px) / 2);
  }
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour .tour_status__award .award__wrap .award__body .award__list .list__item {
    max-width: none;
  }
}
#contents .sec.sec-charm_tour .tour_status__oav {
  margin-bottom: 120px;
}
#contents .sec.sec-charm_tour .tour_status__oav > h3 {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin: 0 auto 40px;
  text-align: center;
  font-size: 2.25rem;
}
#contents .sec.sec-charm_tour .tour_status__oav > h3 > span {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 0;
  width: 100%;
  max-width: 450px;
  min-height: 72px;
  color: #0E50AE;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_tour .tour_status__oav > h3 > span {
    min-height: 50px;
  }
}
#contents .sec.sec-charm_tour .tour_status__oav > h3 > span::after {
  content: "";
  display: block;
  margin: 10px 0 0;
  aspect-ratio: 430/22;
  width: 100%;
  max-width: 430px;
  height: auto;
  background-color: #0E50AE;
  -webkit-mask-image: url(../img/charm_reg/charm_reg_wave.svg);
          mask-image: url(../img/charm_reg/charm_reg_wave.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour .tour_status__oav > h3 span span {
    display: block;
    padding: 0 0.5em;
  }
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 24px;
  margin: 0 auto 60px;
  width: 100%;
  max-width: 1100px;
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__img {
  aspect-ratio: 512/288;
  width: 100%;
  height: auto;
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__img a {
  display: block;
  width: 100%;
  height: 100%;
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__img a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__img.status__img-main {
  grid-column-end: span 2;
}
#contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__text {
  grid-column-end: span 2;
  align-self: start;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 16px;
  height: 100%;
}
#contents .sec.sec-charm_tour .tour_status__oav .button_area {
  grid-column: 1/3;
  grid-row: 6/7;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 0 auto;
}
#contents .sec.sec-charm_tour .tour_status__oav .button_area .opt__text {
  display: block;
  text-align: center;
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour .tour_status__oav .oav__status {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  #contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__img-main {
    margin-bottom: 32px;
  }
  #contents .sec.sec-charm_tour .tour_status__oav .oav__status .status__text {
    justify-content: flex-start;
    margin-bottom: 32px;
    height: auto;
  }
}
#contents .sec.sec-charm_tour .tour_status__acc,
#contents .sec.sec-charm_tour .tour_status__onsen {
  margin-bottom: 120px;
}
#contents .sec.sec-charm_tour .tour_status__acc > h3,
#contents .sec.sec-charm_tour .tour_status__onsen > h3 {
  margin-bottom: 30px;
}
#contents .sec.sec-charm_tour .tour_status__acc > h3::before,
#contents .sec.sec-charm_tour .tour_status__onsen > h3::before {
  content: "\f015";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0.25em;
}
#contents .sec.sec-charm_tour .tour_status__acc .facility_list,
#contents .sec.sec-charm_tour .tour_status__onsen .facility_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
#contents .sec.sec-charm_tour .tour_status__acc .facility_list .list__item,
#contents .sec.sec-charm_tour .tour_status__onsen .facility_list .list__item {
  border: solid 1px #0C79ED;
  border-radius: 20px;
  overflow: hidden;
}
#contents .sec.sec-charm_tour .tour_status__acc .facility_list .list__item h4,
#contents .sec.sec-charm_tour .tour_status__onsen .facility_list .list__item h4 {
  padding: 16px 20px;
  background-color: #BADBFF;
}
#contents .sec.sec-charm_tour .tour_status__acc .facility_list .list__item h4 .area,
#contents .sec.sec-charm_tour .tour_status__onsen .facility_list .list__item h4 .area {
  font-size: 1rem;
}
#contents .sec.sec-charm_tour .tour_status__acc .facility_list .list__item .item__text,
#contents .sec.sec-charm_tour .tour_status__onsen .facility_list .list__item .item__text {
  display: grid;
  gap: 1em;
  padding: 10px 20px 16px;
}
#contents .sec.sec-charm_tour .tour_status__gallery {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
#contents .sec.sec-charm_tour .tour_status__gallery h3 {
  text-align: center;
}
#contents .sec.sec-charm_tour .tour_status__gallery .previous__images {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item {
  margin: 12px 8px;
  aspect-ratio: 512/288;
  width: 100%;
  max-width: calc((100% - 72px) / 3);
  height: auto;
}
#contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item a {
  display: block;
  width: 100%;
  height: 100%;
}
#contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item:nth-of-type(1), #contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item:nth-of-type(2) {
  margin: 12px 12px;
  max-width: 40%;
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour .tour_status__gallery .previous__images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  #contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item {
    margin: 0;
    max-width: none;
  }
  #contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item:nth-of-type(1), #contents .sec.sec-charm_tour .tour_status__gallery .previous__images .images_item:nth-of-type(2) {
    margin: 0;
    max-width: none;
  }
}
@media (width <= 820px) {
  #contents .sec.sec-charm_tour .tour_status__acc .facility_list,
  #contents .sec.sec-charm_tour .tour_status__onsen .facility_list {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
@media (width <= 576px) {
  #contents .sec.sec-charm_tour h2 {
    margin-bottom: 40px;
  }
  #contents .sec.sec-charm_tour .tour_status__acc .facility_list,
  #contents .sec.sec-charm_tour .tour_status__onsen .facility_list {
    grid-template-columns: 1fr;
  }
}
#contents .sec.sec-charm_reg {
  padding: 0;
  max-width: none;
  border-bottom: solid 5px #fff;
  overflow-x: hidden;
}
#contents .sec.sec-charm_reg::before {
  content: "";
  display: block;
  margin-left: -2px;
  aspect-ratio: 1440/135;
  width: calc(100% + 4px);
  height: auto;
  background-color: #0E50AE;
  -webkit-mask-image: url("../img/charm_reg/charm_reg_line-top.svg");
          mask-image: url("../img/charm_reg/charm_reg_line-top.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
#contents .sec.sec-charm_reg .charm_reg__body {
  margin-top: -2px;
  padding: 80px 30px;
  background-color: #0E50AE;
}
#contents .sec.sec-charm_reg .charm_reg__body h2 {
  z-index: 10;
  display: flex;
  justify-content: center;
  gap: 15px;
  border-radius: 8px;
  font-size: 2.25rem;
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span {
  min-height: 72px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_reg .charm_reg__body h2 > span {
    min-height: 50px;
  }
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.left {
  width: 100%;
  max-width: 40px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_reg .charm_reg__body h2 > span.left {
    max-width: 30px;
  }
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.left::after {
  content: "";
  position: absolute;
  bottom: 20px;
  left: 0;
  display: block;
  aspect-ratio: 40/56;
  width: 100%;
  max-width: 40px;
  height: auto;
  background-image: url(../img/charm_reg/h2_charm_reg_bubble01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.text {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 0;
  width: 100%;
  max-width: 430px;
  color: #fff;
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.text::after {
  content: "";
  display: block;
  margin: 10px 0 0;
  aspect-ratio: 430/22;
  width: 100%;
  max-width: 430px;
  height: auto;
  background-image: url(../img/charm_reg/charm_reg_wave.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.right {
  width: 100%;
  max-width: 40px;
}
@media (width <= 450px) {
  #contents .sec.sec-charm_reg .charm_reg__body h2 > span.right {
    max-width: 30px;
  }
}
#contents .sec.sec-charm_reg .charm_reg__body h2 > span.right::after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 0;
  display: block;
  aspect-ratio: 40/56;
  width: 100%;
  max-width: 40px;
  height: auto;
  background-image: url(../img/charm_reg/h2_charm_reg_bubble01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
@media (width <= 576px) {
  #contents .sec.sec-charm_reg .charm_reg__body h2 span.left, #contents .sec.sec-charm_reg .charm_reg__body h2 span.right {
    display: none;
  }
  #contents .sec.sec-charm_reg .charm_reg__body h2 span.text span {
    display: block;
    padding: 0 0.5em;
  }
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area {
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 24px;
  margin: 0 auto 120px;
  width: 100%;
  max-width: 1100px;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__img {
  aspect-ratio: 512/288;
  width: 100%;
  height: auto;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__img a {
  display: block;
  width: 100%;
  height: 100%;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__img a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__img.area__img-main {
  grid-column-end: span 2;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__text {
  grid-column-end: span 2;
  align-self: start;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  color: #fff;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__text h3 {
  color: #fff;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing {
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin: 0 auto;
  width: 100%;
  max-width: 1100px;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text {
  align-self: center;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  color: #fff;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text h3 {
  color: #fff;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text .text__point {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text .text__point .point__item {
  text-indent: hanging 1.5em;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text .text__point .point__item::before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0.5em;
  color: #FFC107;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing__text .cs {
  padding: 1em;
  font-size: 1.25rem;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  aspect-ratio: 540/384;
  width: 100%;
  height: auto;
  transition: transform 0.5s;
  transform: rotate(-5deg) translateX(4%);
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images .images__item {
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 540/384;
  width: 100%;
  height: auto;
  background-color: #FFC107;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 4px 4px 10px 0 rgba(255, 255, 255, 0.5);
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images .images__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images .images__item .text {
  color: #0066D3;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(1rem, 0.618rem + 1.57vw, 1.5rem);
  font-weight: 700;
}
#contents .sec.sec-charm_reg .charm_reg__body::before {
  content: "";
  z-index: 0;
  position: absolute;
  left: 50%;
  aspect-ratio: 1440/500;
  display: block;
  width: 100%;
  max-width: 1440px;
  height: auto;
  background-image: url(../img/charm_reg/charm_reg_seaweed01.svg);
  background-repeat: no-repeat;
  background-size: 53%;
  background-position: bottom -3% left 8%;
  transform: translate(-50%, 0);
}
#contents .sec.sec-charm_reg .charm_reg__body::after {
  content: "";
  z-index: 0;
  position: absolute;
  bottom: 0;
  left: 50%;
  aspect-ratio: 1440/600;
  display: block;
  width: 100%;
  max-width: 1440px;
  height: auto;
  background-image: url(../img/charm_reg/charm_reg_fishes01.svg);
  background-repeat: no-repeat;
  background-size: 98%;
  background-position: top left;
  transform: translate(-50%, 0);
}
#contents .sec.sec-charm_reg .charm_reg__wave_bottom {
  margin-top: -2px;
  aspect-ratio: 1440/150;
  width: 100%;
  height: auto;
  background: linear-gradient(to top, #fff, #0E50AE 5px, #0E50AE);
}
#contents .sec.sec-charm_reg .charm_reg__wave_bottom::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  aspect-ratio: 1440/150;
  width: 101%;
  height: auto;
  background-color: #fff;
  -webkit-mask-image: url("../img/charm_reg/charm_reg_line-bottom.svg");
          mask-image: url("../img/charm_reg/charm_reg_line-bottom.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  transform: translate(-50%, 0);
}
#contents .sec.sec-charm_reg .charm_reg__wave_bottom::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 11%;
  display: block;
  aspect-ratio: 114/75;
  width: 8%;
  max-width: 114px;
  min-width: 90px;
  height: auto;
  background-color: #F6F6F6;
  -webkit-mask-image: url("../img/charm_reg/charm_reg_ship.svg");
          mask-image: url("../img/charm_reg/charm_reg_ship.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  transform: translateY(-100%);
}
@media (width <= 1200px) {
  #contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images {
    transition: transform 0.5s;
    transform: rotate(-5deg) translateX(2%);
  }
}
@media (width <= 820px) {
  #contents .sec.sec-charm_reg .charm_reg__body::before {
    aspect-ratio: 720/500;
    background-size: contain;
  }
}
@media (width <= 576px) {
  #contents .sec.sec-charm_reg .charm_reg__body {
    padding: 80px 15px;
  }
  #contents .sec.sec-charm_reg .charm_reg__body .reg__area {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  #contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__img-main {
    margin-bottom: 32px;
  }
  #contents .sec.sec-charm_reg .charm_reg__body .reg__area .area__text {
    margin-bottom: 32px;
  }
  #contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  #contents .sec.sec-charm_reg .charm_reg__body .reg__sightseeing .sightseeing_images {
    transition: transform 0.5s;
    transform: rotate(0) translateX(0);
  }
}
#contents .sec.sec-op {
  max-width: 1084px;
}
#contents .sec.sec-op .op__body h2 {
  z-index: 10;
  display: flex;
  justify-content: center;
  gap: 15px;
  border-radius: 8px;
  color: #0E50AE;
  font-size: 2.25rem;
}
#contents .sec.sec-op .op__body h2 > span {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 0;
  width: 100%;
  max-width: 430px;
  min-height: 72px;
}
@media (width <= 450px) {
  #contents .sec.sec-op .op__body h2 > span {
    min-height: 50px;
  }
}
#contents .sec.sec-op .op__body h2 > span::after {
  content: "";
  display: block;
  margin: 10px 0 0;
  aspect-ratio: 322/16;
  width: 100%;
  max-width: 322px;
  height: auto;
  background-color: #0E50AE;
  -webkit-mask-image: url(../img/charm_reg/charm_reg_wave.svg);
          mask-image: url(../img/charm_reg/charm_reg_wave.svg);
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
@media (width <= 576px) {
  #contents .sec.sec-op .op__body h2 span.left, #contents .sec.sec-op .op__body h2 span.right {
    display: none;
  }
  #contents .sec.sec-op .op__body h2 span.text span {
    display: block;
    padding: 0 0.5em;
  }
}
#contents .sec.sec-op .op__body .op__text {
  display: grid;
  grid-template-columns: minmax(1.875rem, 1fr) auto minmax(1.875rem, 1fr);
  gap: 0.5em;
  margin-bottom: 40px;
}
#contents .sec.sec-op .op__body .op__text::before {
  justify-self: end;
  align-self: center;
  content: "\f13d";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  color: #BADBFF;
  font-size: 1.875rem;
}
#contents .sec.sec-op .op__body .op__text span {
  align-self: center;
}
#contents .sec.sec-op .op__body .op__text::after {
  justify-self: start;
  align-self: center;
  content: "\f13d";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  color: #BADBFF;
  font-size: 1.875rem;
}
#contents .sec.sec-op .op__body .op__boat {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 4px;
  margin: 0 auto 40px;
  width: 100%;
  max-width: 900px;
}
#contents .sec.sec-op .op__body .op__boat .boat__item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  padding: 6px 16px;
  height: 38px;
  background-color: #F0F9FF;
  border-radius: 19px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.1);
  color: #0E50AE;
  font-weight: 700;
  line-height: 1;
}
#contents .sec.sec-op .op__body .op__boat .boat__item span > span {
  font-size: 0.875rem;
}
#contents .sec.sec-op .op__body .op__boat .boat__item::before {
  content: "\f21a";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  color: #0C79ED;
}
#contents .sec.sec-op .op__body .op__boat .annot {
  width: 100%;
  text-align: center;
}
#contents .sec.sec-op .op__body .op__sponsor {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
#contents .sec.sec-op .op__body .op__sponsor h3 {
  padding-bottom: 8px;
  border-bottom: solid 2px #BADBFF;
}
#contents .sec.sec-op .op__body .op__sponsor h4 {
  text-align: center;
  margin-bottom: 16px;
}
#contents .sec.sec-op .op__body .op__sponsor h4#maker_list {
  margin-top: 44px;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin: 24px auto 44px;
  width: 100%;
  max-width: calc(250px * 3 + 32px * 2);
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  width: 100%;
  text-align: center;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item h5 {
  font-size: 1.125rem;
  font-weight: 700;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item .img {
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  width: 100%;
  height: auto;
  border-radius: 50%;
  border: solid 6px #0C79ED;
  overflow: hidden;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item.cs {
  pointer-events: none;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__vip .vip__item.cs .img::before {
  content: "";
  display: block;
  aspect-ratio: 45/50;
  width: 100%;
  max-width: 100px;
  height: auto;
  background-color: #BADBFF;
  -webkit-mask-image: url("../img/common/icon_anker.svg");
          mask-image: url("../img/common/icon_anker.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  margin: 0 auto 44px;
  width: 100%;
  max-width: calc(128px * 5 + 32px * 4);
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item {
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 128/72;
  width: 100%;
  height: auto;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.nolink {
  pointer-events: none;
  border: solid 1px #0C79ED;
  text-align: center;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.nolink h5 {
  font-size: 0.75rem;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.nobanner {
  border: solid 1px #0C79ED;
  text-align: center;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.nobanner h5 {
  font-size: 0.75rem;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.cs {
  pointer-events: none;
  border: solid 1px #0C79ED;
}
#contents .sec.sec-op .op__body .op__sponsor .sponsor__normal .normal__item.cs::before {
  content: "Comming Soon";
  font-size: 0.75rem;
}
#contents .sec.sec-op .op__body .op__sponsor .annot {
  margin: 0 auto;
  max-width: 900px;
}
@media (width <= 820px) {
  #contents .sec.sec-op .op__body .op__sponsor .sponsor__vip {
    grid-template-columns: repeat(2, 1fr);
    max-width: calc(250px * 2 + 32px * 1);
  }
  #contents .sec.sec-op .op__body .op__sponsor .sponsor__normal {
    grid-template-columns: repeat(3, 1fr);
    max-width: calc(128px * 3 + 32px * 2);
  }
}
@media (width <= 576px) {
  #contents .sec.sec-op .op__body {
    padding: 80px 15px;
    max-width: none;
  }
  #contents .sec.sec-op .op__body .op__sponsor .sponsor__vip {
    grid-template-columns: 1fr;
    max-width: 250px;
  }
  #contents .sec.sec-op .op__body .op__sponsor .sponsor__normal {
    grid-template-columns: repeat(2, 1fr);
    max-width: calc(128px * 2 + 32px * 1);
  }
}
#contents .sec.sec-faq {
  max-width: 828px;
}
#contents .sec.sec-faq .faq__body h2 {
  color: #0E50AE;
  font-size: 2.25rem;
}
#contents .sec.sec-faq .faq__body .faq__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item {
  border: solid 1px #F3F4F6;
  border-radius: 8px;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item .item__question {
  display: flex;
  align-items: center;
  padding: 16px;
  height: 60px;
  cursor: pointer;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item .item__question h4 {
  flex-grow: 1;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item .item__question::after {
  flex-shrink: 0;
  content: "\f078";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  color: #0C79ED;
  line-height: 0;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item .item__ask .ask__wrap {
  padding: 0 16px 16px;
}
#contents .sec.sec-faq .faq__body .faq__list .list__item .item__ask .ask__wrap::before {
  content: "";
  display: block;
  margin-bottom: 16px;
  width: 100%;
  height: 0;
  border-top: dashed 1px #0C79ED;
}
#contents .sec.sec-entry {
  margin-bottom: 0;
  padding: 96px 30px 50px;
  max-width: none;
  background-color: rgba(0, 163, 224, 0.5);
  background-image: url(../img/entry/entry_bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  color: #fff;
}
#contents .sec.sec-entry .entry__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 0 auto 24px;
  max-width: 770px;
  padding: 48px 32px 32px;
  background-color: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(12px);
  border: solid 1px rgba(255, 255, 255, 0.3);
  border-radius: 16px;
}
#contents .sec.sec-entry .entry__body h2 {
  margin: 0;
  color: #fff;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 3rem;
  font-weight: 900;
}
#contents .sec.sec-entry .entry__body .entry__text {
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
}
#contents .sec.sec-entry .entry__body .opt__text {
  text-align: center;
}
#contents .sec.sec-entry .entry__caution {
  text-align: center;
  font-size: 0.875rem;
}
@media (width <= 576px) {
  #contents .sec.sec-entry {
    padding: 96px 15px;
    background-image: url(../img/entry/entry_bg-sp.jpg);
  }
  #contents .sec.sec-entry .entry__body {
    padding: 48px 16px 32px;
  }
}

#menu_buttons {
  z-index: 1000;
  position: sticky;
  left: 100vw;
  top: 10px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  width: 0;
  height: 0;
  line-height: 0;
}
#menu_buttons .button {
  z-index: 500;
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  width: 100%;
  max-width: 100px;
  min-width: 100px;
  height: auto;
  background-color: #FF7A00;
  border-radius: 50%;
  text-align: center;
  color: #fff;
  font-weight: 700;
  line-height: 1.2;
  transform: translateX(calc(-100% - 10px));
}
#menu_buttons .button#button-menu {
  flex-direction: column;
  gap: 4px;
  background-color: #00A3E0;
}
#menu_buttons .button#button-menu .icon {
  display: block;
  width: 32px;
  height: 20px;
}
#menu_buttons .button#button-menu .icon span {
  opacity: 1;
  position: absolute;
  left: 50%;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transition: all 0.2s;
}
#menu_buttons .button#button-menu .icon span:nth-of-type(1) {
  top: 0;
  transform: translate(-50%, 0);
}
#menu_buttons .button#button-menu .icon span:nth-of-type(2) {
  top: 50%;
  transform: translate(-50%, -50%);
}
#menu_buttons .button#button-menu .icon span:nth-of-type(3) {
  bottom: 0;
  transform: translate(-50%, 0);
}
#menu_buttons .button#button-menu.close .icon span:nth-of-type(1) {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}
#menu_buttons .button#button-menu.close .icon span:nth-of-type(2) {
  opacity: 0;
  top: 50%;
  transform: translate(-50%, -50%);
}
#menu_buttons .button#button-menu.close .icon span:nth-of-type(3) {
  bottom: 50%;
  transform: translate(-50%, 50%) rotate(-45deg);
}
@media (width <= 820px) {
  #menu_buttons .button#button-entry, #menu_buttons .button#button-news {
    position: fixed;
    top: auto;
    bottom: 0;
    aspect-ratio: unset;
    max-width: calc((100% - 6px) / 2);
    border-radius: 8px 8px 0 0;
    height: 60px;
    transform: translateX(0);
  }
  #menu_buttons .button#button-entry br, #menu_buttons .button#button-news br {
    display: none;
  }
  #menu_buttons .button#button-entry {
    right: auto;
    left: 2px;
  }
  #menu_buttons .button#button-news {
    right: 2px;
  }
}
@media (width <= 576px) {
  #menu_buttons .button {
    max-width: 70px;
    min-width: 70px;
  }
  #menu_buttons .button#button-menu {
    font-size: 0.875rem;
  }
  #menu_buttons .button#button-menu .icon {
    width: 22.4px;
    height: 14px;
  }
  #menu_buttons .button#button-entry br, #menu_buttons .button#button-news br {
    display: inline;
  }
}
#menu_buttons:has(#button-menu.close) {
  transition: position 0.2s;
  position: fixed;
}
@media (width <= 820px) {
  #menu_buttons {
    position: fixed;
  }
}

#nav_main {
  z-index: 500;
  position: fixed;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100svh;
  min-height: 100svh;
  background-color: #0E50AE;
  text-align: center;
  color: #fff;
  line-height: 1;
  transition: transform 0.2s;
  transform: translateX(100%);
}
#nav_main .nav_main__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 60px;
  padding: 30px 15px;
  width: 100%;
  max-height: 80dvh;
  overflow-y: auto;
}
#nav_main .nav_main__list .nav_main__item > a {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
}
#nav_main .nav_main__list .nav_main__item:nth-last-of-type(1) {
  margin-bottom: 0;
}
#nav_main .nav_sub__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 16px;
}
#nav_main.open {
  transition: all 0.2s;
  transform: translateX(0);
}

#footer {
  padding: 24px 15px;
  background-color: #0E50AE;
  text-align: center;
  color: #fff;
  line-height: 1;
}
#footer .copyright {
  font-size: 0.875rem;
}
#footer .copyright::before {
  content: "\f1f9";
  font-family: "Font Awesome 5 Free";
  font-weight: 400;
  margin-left: 0;
  margin-right: 0.25em;
}
#footer #btn-privacy {
  display: block;
  margin: 5px auto 0;
  font-size: 0.875rem;
}

#privacy {
  z-index: -1;
  opacity: 0;
  position: fixed;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 15px;
  width: 100%;
  height: 100svh;
  min-height: 100svh;
  background-color: rgba(0, 0, 0, 0.75);
  color: #fff;
}
#privacy .privacy__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  padding: 30px;
  width: 100%;
  max-width: 800px;
  height: 100%;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 0 10px 10px rgba(0, 0, 0, 0.3);
}
#privacy .privacy__body .scroll_area {
  width: 100%;
  height: 100%;
  overflow-y: auto;
}
#privacy .privacy__body h2 {
  text-align: center;
  font-size: 2.25rem;
  line-height: 1;
}
#privacy .privacy__body h3 {
  color: #333;
}
#privacy .privacy__body .sec {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 60px;
  color: #333;
  line-height: 1.2;
}
#privacy .privacy__body .sec ul {
  list-style: none;
  margin-left: 1em;
}
#privacy .privacy__body .sec ul li {
  margin: 0.5em 0;
  text-indent: hanging 1em;
}
#privacy .privacy__body .sec ul li::before {
  content: "\f111";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0;
  margin-right: 0;
  display: inline-block;
  transform: scale(0.4);
}
#privacy .privacy__body .sec ul li ul {
  margin: 1em 0 1em 1em;
}
#privacy .privacy__body .sec ul li ul li::before {
  content: "\f111";
  font-family: "Font Awesome 5 Free";
  font-weight: 400;
  margin-left: 0;
  margin-right: 0;
  display: inline-block;
  transform: scale(0.4);
}
#privacy .privacy__body .sec ol {
  margin-left: 1em;
  counter-reset: ol_cnt;
}
#privacy .privacy__body .sec ol li {
  counter-increment: ol_cnt;
  margin: 0.5em 0;
  text-indent: hanging 1em;
}
#privacy .privacy__body .sec ol li::before {
  content: counter(ol_cnt) ".";
  display: inline-block;
  width: 1em;
}
@media (width <= 820px) {
  #privacy .privacy__body {
    padding: 30px;
  }
  #privacy .privacy__body h2 {
    font-size: 2rem;
  }
  #privacy .privacy__body h3 {
    font-size: 1.25rem;
  }
}
@media (width <= 576px) {
  #privacy .privacy__body {
    padding: 30px 15px 15px;
  }
}
#privacy {
  transition: all 0.25s;
}
#privacy.open {
  z-index: -1;
  transition: all 0.25s;
  opacity: 1;
}

#loading {
  z-index: 5000;
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px;
  width: 100%;
  height: 100%;
  background-color: #fff;
}
#loading .loading__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  aspect-ratio: 1/1;
  width: 100%;
  min-width: 300px;
  max-width: 400px;
  height: auto;
  background-color: #2691f6;
  border-radius: 50%;
  color: #fff;
  overflow: hidden;
}
#loading .loading__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 30%;
  background-color: #96c9f6;
}
#loading .loading__body::after {
  content: "";
  display: block;
  aspect-ratio: 512/227;
  width: 100%;
  max-width: 100px;
  height: auto;
  background-color: #fff;
  -webkit-mask-image: url("../img/coming_soon/fish.svg");
          mask-image: url("../img/coming_soon/fish.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  animation-name: fish-move;
  animation-duration: 3s;
  animation-timing-function: ease-in-out;
  animation-delay: 0;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-fill-mode: both;
  transform: translateY(50%);
}
@keyframes fish-move {
  0% {
    transform: translateY(50%);
  }
  100% {
    transform: translateY(100%);
  }
}
#loading .wave-svg {
  position: absolute;
  top: 60px;
  left: 0;
  width: 200%;
  height: auto;
  animation: waveMove 6s linear infinite;
}
@keyframes waveMove {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-34%);
  }
}
#loading #title {
  text-align: center;
}
#loading #title span {
  display: inline-block;
  animation-name: cmt-wave;
  animation-duration: 1s;
  animation-timing-function: ease-in-out;
  animation-delay: 0;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-fill-mode: both;
  transform: translateY(-50%);
  animation-delay: calc((sibling-index()) * 0.1s);
}
@keyframes cmt-wave {
  0% {
    transform: translateY(-50%);
  }
  100% {
    transform: translateY(50%);
  }
}
#loading #comment {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Cherry Bomb One", system-ui;
  font-size: clamp(2rem, 0.5rem + 8vw, 2.5rem);
}
#loading #comment span {
  display: inline-block;
  animation-name: cmt-wave;
  animation-duration: 1.5s;
  animation-timing-function: ease-in-out;
  animation-delay: 0;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-fill-mode: both;
  transform: translateY(-10%);
  animation-delay: calc((sibling-index()) * 0.1s);
}
#loading #comment span:nth-last-of-type(8) {
  margin-left: 0.5em;
}
@keyframes cmt-wave {
  0% {
    transform: translateY(-10%);
  }
  100% {
    transform: translateY(10%);
  }
}
#loading.close {
  animation: loadingClose 0.25s ease-in 1 forwards;
}
@keyframes loadingClose {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
#loading.none {
  z-index: -1;
  display: none;
}/*# sourceMappingURL=style.css.map */