@charset "utf-8";
@font-face {
  font-family: 'Material Symbols Rounded';
  font-style: normal;
  font-weight: 100 700;
  font-display: swap;
  src: url(/tyo/common/font/MaterialSymbolsRounded.woff2) format('woff2');
}
@font-face {
  font-family: 'Shippori Mincho';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/tyo/common/font/shippori-mincho-v17-japanese_latin-700.woff2) format('woff2');
}
/*------------------------------------------------*/
/*★ チャーターLP共通ベーススタイル設定 ★*/
/*★ リセット ★*/
html {
  scroll-behavior: auto; /* 最初は無効 */
  &.is-ready {
    scroll-behavior: smooth; /* JSでクラスが付いてから有効 */
  }
  --scroll-padding-top: 37px; /*固定ナビ分*/
  @media (width > 776px) {
    --scroll-padding-top: 55px;
  }
  scroll-padding-top: var(--scroll-padding-top);
}
:where(:root, body) {
  overflow-x: clip;
}
main {
  div:not([class])::after {
    content: none;
  }
  a {
    text-decoration: none;
    color: inherit;
    &[tabindex='-1'] {
      pointer-events: none;
      cursor: default;
    }
  }
  picture {
    display: block;
  }
  .is-em {
    font-weight: bold;
  }
  :where(p, ul, ol) {
    font-weight: inherit;
  }
  :where(h1, h2, h3, h4, h5, h6, p, ul, ol) {
    font-weight: inherit;
    font-size: inherit;
  }
  em {
    font-style: normal;
  }
  .ui-static-tab-button {
    border-radius: 0;
    padding: 0;
    &::before {
      content: none;
    }
  }
  .ui-static-tab-content {
    margin-top: 0;
  }
  button {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    color: inherit;
    cursor: pointer;
  }
}
/*------------------------------------------------*/
/*★ ページスタイル設定 ★*/
#hisApp {
  position: relative;
}
:root {
  /*color*/
  --default-color-white: #ffffff;
  --default-color-black: #000000;
  --default-color-blue1: #3e95aa;
  --default-color-blue2: #89c2cf;
  --default-color-btn-yoyaku: #ff7620;
  --default-color-btn-yoyaku-hover: #ff3c00;
  --default-color-dummy: #d9d9d9;
  --default-color-font-black: #2c2a29;
  --default-color-notice: #888888;
  --default-color-price: #d20546;
  --default-color-primary: #1b3c55;
  --default-color-table-color2: #dacdb8;
  --default-color-cruise-active: #fffad7;
  --default-color-cruise-bg-tel: #f6f3ec;
  --default-color-cruise-gray2: #b6b4af;
  --default-color-cruise-table-color: #bba27a;
  /*font-size*/
  --default-font-size-12: 12px;
  --default-font-size-14: 14px;
  --default-font-size-16: 16px;
  --default-font-size-14-12: clamp(12px, (12vw / 3.75), 14px);
  --default-font-size-16-14: clamp(14px, (14vw / 3.75), 16px);
  --default-font-size-18-16: clamp(16px, (16vw / 3.75), 18px);
  --default-font-size-20-16: clamp(16px, (16vw / 3.75), 20px);
  --default-font-size-22-17: clamp(17px, (17vw / 3.75), 22px);
  --default-font-size-26-18: clamp(18px, (18vw / 3.75), 26px);
  --default-font-size-40-32: clamp(32px, (32vw / 3.75), 40px);
  --default-font-size: var(--default-font-size-16-14);
  --default-font-size-notice: 12px;
  /*gap*/
  --default-gap-4-2: clamp(2px, (12vw / 3.75), 4px);
  --default-gap-8-4: clamp(4px, (4vw / 3.75), 8px);
  --default-gap-12-8: clamp(8px, (8vw / 3.75), 12px);
  --default-gap-16-12: clamp(12px, (12vw / 3.75), 16px);
  --default-gap-24-20: clamp(20px, (20vw / 3.75), 24px);
  --default-gap-32-24: clamp(24px, (24vw / 3.75), 32px);
  --default-gap-40-32: clamp(32px, (32vw / 3.75), 40px);
  --default-gap-64-48: clamp(48px, (48vw / 3.75), 64px);
  --default-gap-pc-only80: 0px;
  /*line-height*/
  --default-font-lh-150: 1.5;
  --default-font-lh-180: 1.8;
  --default-font-lh-130: 1.3;
  --default-font-lh: var(--default-font-lh-180);
  /*width*/
  --default-width-sp-val: 335;
  --default-width-pc-val: 1104;
  --default-width-sp: calc((335 / 375) * 100%);
  --default-width-pc: 1104px;
  --default-width: min(var(--default-width-sp), var(--default-width-pc));
  --default-width2: min(100%, var(--default-width-pc));
  --default-bg-width-pc: max(100%, 1920px);
  /*icon*/
  --default-icon-ff: 'Material Symbols Rounded';
  --default-icon-arrow-right: '\e5e1';
  --default-icon-blank: '\e89e';
  --default-icon-plus: '\e145';
  /*font-family*/
  --default-font-family: 'Noto Sans JP', sans-serif;
  --default-font-family-min: 'Shippori Mincho', serif;
  /*hover*/
  --default-hover-speed: 0.3s;
  --default-hover-opacity: 0.8;
  --default-hover-transition-opacity: opacity var(--default-hover-speed);
  --default-hover-transition-background: background var(--default-hover-speed);
  --default-hover-transition-color: color var(--default-hover-speed);
  /*border-radius*/
  --default-radius-button: 999px;
  --default-radius-4: 4px;
  --default-radius-8: 8px;
  --default-radius-16: 16px;
  --default-radius-24: 24px;
  /*border*/
  --default-border-black: 1px solid var(--default-color-black);
  /*box-shadow*/
  --default-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.25);
  /*transition*/
  --default-transition-speed: 0.3s;
  --default-transition-translate: translate var(--default-transition-speed) ease;
  --default-transition-color: color var(--default-transition-speed) ease;
}
.is-size-pc {
  --default-gap-pc-only80: 80px;
}
.material-symbols-rounded {
  font-family: var(--default-icon-ff);
  font-weight: var(--default-font-weight-normal);
  font-style: normal;
  font-size: 1em;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}
#pageApp {
  font-family: var(--default-font-family);
  font-size: var(--default-font-size);
  font-weight: var(--default-font-weight-normal);
  color: var(--default-color-font-black);
  line-height: var(--default-font-lh);
  word-break: break-all;
  padding-bottom: 0 !important;
}
.main {
  img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
  table {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
  }
}
.is-inline-block {
  display: inline-block;
}
.is-indent-1,
.section [class*='notes--item'] {
  text-indent: -1em;
  padding-left: 1em;
}
:where(.is-size-sp .is-dsp-pc, .is-size-pc .is-dsp-sp) {
  display: none !important;
}
.js-accordion-button {
  cursor: pointer;
  + * {
    display: none;
  }
}
.js-toggleControl:not([class*='active']) {
  cursor: pointer;
}
:is(.js-accordion-content, .js-modal-content):not(.is-open) {
  display: none;
}
/*base-button*/
.base-button__wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--default-gap-16);
  justify-items: center;
}
.base-button {
  --base-button-bg: var(--default-color-blue1);
  .is-type-reservation & {
    --base-button-bg: var(--default-color-btn-yoyaku);
    --base-button-font-size: var(--default-font-size-18-16);
    --base-button-padding-y: var(--default-gap-12-8);
    --base-button-min-width: 320px;
  }
  width: fit-content;
  .ui-static-button {
    :is(&, &:not(.active):not(:disabled):active, &:focus, &.active, &.focused) {
      width: 100%;
      color: var(--base-button-font-color, #fff);
      font-size: var(--base-button-font-size, var(--default-font-size));
      line-height: var(--base-button-font-lh, var(--default-font-lh-150));
      text-align: center;
      display: grid;
      grid-template-columns: repeat(2, auto);
      justify-items: center;
      gap: var(--base-button-gap, var(--default-gap-16-12));
      padding: var(--base-button-padding-y, var(--default-gap-8-4)) var(--base-button-padding-x, var(--default-gap-32-24));
      background: var(--base-button-bg);
      margin: auto;
      height: max-content;
      min-width: var(--base-button-min-width, auto);
      .ui-static-button-text {
        padding-left: 8px;
      }
      .ui-static-icon {
        position: static;
        transform: translateY(0);
        --wght: 400;
        color: var(--base-button-icon-color, inherit);
        font-size: 1.5em;
        line-height: 0.5;
        .is-type-blank & {
          font-size: 1em;
        }
      }
    }
  }
}
/*base-textlink*/
.base-textlink__link {
  font-size: var(--base-textlink-font-size, var(--default-font-size-14));
  color: var(--base-textlink-color, inherit);
  padding-bottom: 1px; /*hoverのborder考慮用*/
  .base-textlink__texts {
    vertical-align: middle;
    line-height: 1.2;
    color: inherit;
    .ui-static-icon {
      color: inherit;
      translate: 0 2px;
      margin-left: var(--default-gap-4);
      scale: 1.5;
      .is-type-blank & {
        scale: 1;
        translate: 0 2px;
      }
    }
  }
}
/*notes*/
:where(.is-indent-1, .section :is([class*='notes--item'], [class*='notes__item'])) {
  text-indent: -1em;
  padding-left: 1em;
}
:is([class*='notes--item'], [class*='notes__item']) {
  font-size: var(--default-font-size-notice);
  line-height: var(--default-font-lh-150);
  color: var(--default-color-notice);
  --notes-item-indent: 1em;
  text-indent: calc(calc(var(--notes-item-indent) * -1));
  padding-left: var(--notes-item-indent);
  &:not(:first-child) {
    margin-top: var(--notes-item-gap, 8px);
  }
}
/*page-top*/
.page-top {
  .page-top-button {
    --page-top-button-size: clamp(59px, (59vw / 3.75), 90px);
    --page-top-button-bg: url(/cruise/kanto/assets/common/images/topBtn_sp.png);
    background: var(--page-top-button-bg) no-repeat center / contain;
    width: var(--page-top-button-size);
    height: var(--page-top-button-size);
    #hisApp:has(.is-size-pc) & {
      --page-top-button-bg: url(/cruise/kanto/assets/common/images/topBtn_pc.png);
    }
    .ui-static-icon {
      display: none;
    }
  }
}
/*his-top__link*/
.his-top__link {
  .his-top__button {
    display: block;
    color: #fff;
    font-size: var(--default-font-size-14);
    font-weight: bold;
    line-height: 1.4;
    text-decoration: none;
    padding: calc(24em / 26) calc(60em / 26) calc(25em / 26) calc(20em / 26);
    background: #0057b8 url(/cmn/icon/icon_arrow_right_white.svg) no-repeat right calc(10em / 26) center / calc(48em / 26);
  }
}
/*float-button*/
.float-button {
  position: fixed;
  bottom: var(--floatbtn-posi-y);
  right: 10px;
  translate: var(--floatbtn-posi-x, 200%) 0;
  transition: translate 0.7s;
  z-index: 10;
  &.is-fixed:not(.is-over) {
    --floatbtn-posi-x: 0;
  }
}
.float-button__link {
  display: block;
  width: var(--floatbtn-size-w);
  height: var(--floatbtn-size-h);
  background: var(--floatbtn-bg) no-repeat center / contain;
}
/*------------------------------------------------*/
/*★ ＝＝ hover ＝＝ ★*/
@media (hover: hover) and (pointer: fine) {
  .base-button {
    --base-button-btn-hover: var(--default-color-primary);
    .is-type-reservation & {
      --base-button-btn-hover: var(--default-color-btn-yoyaku-hover);
    }
    .ui-static-button {
      :is(&, &:not(.active):not(:disabled):active, &:focus, &.active, &.focused) {
        &:hover {
          background-color: var(--base-button-btn-hover);
        }
      }
    }
  }
  .base-textlink__link {
    &:hover {
      color: inherit;
      .base-textlink__text {
        text-decoration: underline;
        text-underline-offset: 0.2em;
      }
    }
  }
}
