@charset "utf-8";
/*★ リセット ★*/
html {
  scroll-behavior: auto; /* 最初は無効 */
  &.is-ready {
    scroll-behavior: smooth; /* JSでクラスが付いてから有効 */
  }
  --scroll-padding-top: max((116vw / 860), 84px); /*固定ナビ分・特集毎に要調整*/
  &:has(.is-size-pc) {
    --scroll-padding-top: 95px;
  }
  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;
    }
  }
  .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;
  }
  :where(li) {
    display: block;
  }
  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;
  }
  img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
  table {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
  }
}
/*------------------------------------------------*/
/*★ ページスタイル設定 ★*/
#hisApp {
  position: relative;
}
:root {
  /*color*/
  --default-color-black: #000000;
  --default-color-white: #ffffff;
  --default-color-blue: #007cdd;
  --default-color-green: #009944;
  --default-color-lightblue: #eaf3fb;
  --default-color-lightgreen: #f0ffd2;
  --default-color-orange: #ff9700;
  --default-color-pink: #f54263;
  --default-color-dummy: #d9d9d9;
  --default-color-notice: #737373;
  --default-color-background-color: #f6f2ef;
  --default-color-font-color: #2c2a29;
  /*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-20-16: clamp(16px, (16vw / 3.75), 20px);
  --default-font-size-26-18: clamp(18px, (18vw / 3.75), 26px);
  --default-font-size-32-24: clamp(24px, (24vw / 3.75), 32px);
  --default-font-size-36-28: clamp(28px, (28vw / 3.75), 36px);
  --default-font-size-40-32: clamp(32px, (32vw / 3.75), 40px);
  --default-font-size: var(--default-font-size-14);
  --default-font-size-notice: var(--default-font-size-12);
  /*gap*/
  --default-gap-4-2: clamp(2px, (2vw / 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-80-64: clamp(64px, (64vw / 3.75), 80px);
  --default-gap-96-72: clamp(72px, (72vw / 3.75), 96px);
  --default-gap-container: var(--default-gap-80-64);
  --default-gap-section: var(--default-gap-80-64);
  --default-gap-section-gap: var(--default-gap-40-32);
  /*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-150);
  /*width*/
  --default-width-sp-val: 335;
  --default-width-pc-val: 1104;
  --default-width-sp: (335vw / 3.75);
  --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-zen: 'Zen Maru Gothic', sans-serif;
  --default-font-family-noto: 'Noto Sans JP', sans-serif;
  --default-font-family: var(--default-font-family-zen);
  /*font-weight*/
  --default-font-weight-bold: 700;
  --default-font-weight-normal: 500;
  /*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);
  --default-hover-underline-offset: 0.2em;
  /*border-radius*/
  --default-radius-button: 999px;
  --default-radius-4: 4px;
  --default-radius-8: 8px;
  --default-radius-16: 16px;
  --default-radius-24: 24px;
  --default-radius-32: 32px;
  /*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-opacity: opacity var(--default-transition-speed) ease;
  --default-transition-translate: translate var(--default-transition-speed) ease;
  --default-transition-transform: transform var(--default-transition-speed) ease;
  --default-transition-color: color var(--default-transition-speed) ease;
}
.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-bold);
  color: var(--default-color-font-color);
  line-height: var(--default-font-lh);
  word-break: break-all;
  padding-bottom: 0 !important;
  &:has(.is-page-kaigai),
  #product-kaigai,
  .product-kaigai-tour,
  .is-type-kaigai,
  .is-kaigai {
    --default-color-world-primary: #00479d;
    --default-color-world-main: var(--default-color-blue);
    --default-color-world-sub: var(--default-color-lightblue);
  }
  &:has(.is-page-kokunai),
  #product-kokunai,
  .product-kokunai-tour,
  .is-type-kokunai,
  .is-kokunai {
    --default-color-world-primary: #2ea307;
    --default-color-world-main: var(--default-color-green);
    --default-color-world-sub: var(--default-color-lightgreen);
  }
}
.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;
}
:where(#pageApp) {
  :is(.js-accordion-content, .js-modal-content):not(.is-open) {
    display: none;
  }
  .js-modal-content {
    position: absolute;
    z-index: 310;
    /* box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.25); */
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.5));
  }
}
/*base-button*/
.base-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--base-buttons-gap, 24px);
}
.base-button {
  width: min(100%, var(--base-button-max-width, 256px));
  --base-button-padding: 12px 16px;
  --base-button-padding-left: 24px;
  &.is-size-small {
    --base-button-max-width: fit-content;
    min-width: 100px;
  }
  &.is-type-pink {
    --base-button-border-color: #ca2d4a;
    --base-button-bg: var(--default-color-pink);
  }
  &.is-type-orange {
    --base-button-border-color: #be7100;
    --base-button-bg: var(--default-color-orange);
  }
  &:is(.is-type-pink, .is-type-orange) {
    --base-button-hover-bg: var(--default-color-white);
    --base-button-hover-font-color: var(--base-button-bg);
  }
  &:is(.is-type-kaigai, .is-type-kokunai) {
    --base-button-border-color: var(--default-color-world-main);
    --base-button-font-color: var(--default-color-world-main);
    --base-button-bg: var(--default-color-world-sub);
    --base-button-hover-bg: var(--base-button-border-color);
    --base-button-hover-font-color: var(--default-color-white);
  }
  .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, 16px);
      line-height: var(--base-button-font-lh, var(--default-font-lh-130));
      text-align: center;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: var(--base-button-gap, 4px);
      padding: var(--base-button-padding);
      padding-left: var(--base-button-padding-left);
      background: var(--base-button-bg);
      border: var(--base-button-border-color, inherit) solid var(--base-button-border-width, 2px);
      margin: auto;
      height: 100%;
      min-width: auto;
      .is-size-small & {
        border: none;
      }
      .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-link-type-blank & {
          font-size: 1em;
          /* margin-right: var(--default-gap-8); */
        }
      }
    }
  }
}
/*base-textlink*/
.base-textlink {
  + .base-textlink {
    margin-top: 4px;
  }
  .base-textlink__link {
    font-size: var(--base-textlink-font-size, var(--default-font-size-14));
    --base-textlink-color: #007cdd;
    color: var(--base-textlink-color);
    display: inline-block;
    padding-bottom: 1px; /*hoverのborder考慮用*/
    &:focus {
      color: var(--base-textlink-color);
    }
    .base-textlink__texts {
      vertical-align: middle;
      line-height: 1.2;
      color: inherit;
      .ui-static-icon {
        color: inherit;
        translate: 0 0.2em;
        margin-left: 2px;
        scale: 1.25;
        .is-link-type-blank & {
          scale: 0.85;
          translate: 0 0.15em;
        }
      }
    }
  }
}

/*base-title*/

/*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']) {
  --notes-item-indent: 1em;
  font-size: var(--notes-item-font-size, var(--default-font-size-12));
  line-height: var(--notes-item-font-lh, var(--default-font-lh));
  font-weight: var(--notes-item-font-weight, var(--default-font-weight-normal));
  color: var(--notes-item-font-color, var(--default-color-notice));
  text-indent: calc(calc(var(--notes-item-indent) * -1));
  padding-left: var(--notes-item-indent);
  &:not(:first-child) {
    margin-top: var(--notes-item-gap, 0);
  }
}
/*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;
}
/*toggle-animation*/
.toggle-animation {
  .toggle-animation-trigger {
    cursor: pointer;
    display: block;
  }
  .toggle-animation-target-wrapper {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.3s ease; /* 時間はJSの待機時間と合わる */
    overflow: hidden;
  }
  .toggle-animation-target {
    min-height: 0;
    visibility: hidden; /*アニメーション安定用*/
    transition: visibility 0.3s;
  }
  &[open] {
    .toggle-animation-target-wrapper {
      grid-template-rows: 1fr; /* detailsが開いている間、かつJSで0frに上書きされていない場合に1frにする */
    }
    .toggle-animation-target {
      visibility: visible;
    }
  }
}
/*slider*/
#pageApp {
  .splide {
    --slider-pagination-size: 10px;
    --slider-yohaku-btm: 40px;
    --slider-item-w: 258px;
    --slider-gap: 24px;
    padding-bottom: var(--slider-yohaku-btm);
    max-width: var(--slider-max-width, var(--default-width-pc));
    margin: auto;
  }
  .splide:not(:has(.splide__pagination li:nth-child(2))) {
    --slider-yohaku-btm: 0;
    .splide__list {
      justify-content: center;
    }
    .splide__pagination {
      display: none;
    }
  }
  .is-size-sp & {
    .splide:not(:has(.splide__pagination li:nth-child(2))) {
      --slider-yohaku-btm: 0;
      .splide__list {
        justify-content: center;
      }
      .splide__pagination {
        display: none;
      }
    }
  }
  .splide__track {
    overflow: visible;
    margin: 0 min((20vw / 3.75), 20px);
    @media (width > 1185px) {
      margin: auto;
      overflow: hidden;
    }
  }
  .splide__slide {
    width: var(--slider-item-w);
    margin-right: var(--slider-gap);
  }
  .splide__arrow {
    --slider-arrow-size: 44px;
    --slider-arrow-icon-size: 32%;
    --slider-arrow-icon-bc: var(--default-color-white);
    --slider-arrow-icon-posi-y: 50%;
    --slider-arrow-icon-posi-ty: calc(-50% - (var(--slider-yohaku-btm) / 2));
    --slider-arrow-icon-posi-x: calc((var(--slider-arrow-size) / 2) * -1);
    background: var(--slider-arrow-bg, var(--default-color-orange));
    width: var(--slider-arrow-size);
    height: var(--slider-arrow-size);
    opacity: 1;
    transition:
      opacity 0.1s,
      var(--default-hover-transition-background);
    top: var(--slider-arrow-icon-posi-y,);
    transform: translateY(var(--slider-arrow-icon-posi-ty));
    &:disabled {
      opacity: 0;
      cursor: default;
    }
    svg {
      fill: var(--slider-arrow-icon-bc);
      width: var(--slider-arrow-icon-size);
      height: var(--slider-arrow-icon-size);
    }
  }
  .splide__arrow--prev {
    left: var(--slider-arrow-icon-posi-x);
  }
  .splide__arrow--next {
    right: var(--slider-arrow-icon-posi-x);
  }
  .splide__pagination {
    bottom: 0;
    gap: var(--slider-pagination-gap, 4px);
    display: flex;
    li {
      line-height: 0;
    }
  }
  .splide__pagination__page {
    opacity: 1;
    margin: 0;
    width: var(--slider-pagination-size);
    height: var(--slider-pagination-size);
    aspect-ratio: 1;
    background: var(--slider-pagination-bg, rgba(192, 197, 204, 0.7));
    border-radius: 50%;
    &.is-active {
      --slider-pagination-size: 12px;
      --slider-pagination-bg: var(--default-color-orange);
      transform: scale(1);
    }
  }
}
/*------------------------------------------------*/
/*★ ＝＝ hover ＝＝ ★*/
@media (hover: hover) and (pointer: fine) {
  .base-button {
    .ui-static-button {
      :is(&, &:not(.active):not(:disabled):active, &:focus, &.active, &.focused) {
        transition: var(--default-hover-transition-opacity), var(--default-hover-transition-background), var(--default-hover-transition-color);
        &:hover {
          background-color: var(--base-button-hover-bg);
          color: var(--base-button-hover-font-color);
          :is(.is-type-kaigai, .is-type-kokunai) & {
            opacity: var(--default-hover-opacity);
          }
        }
      }
    }
  }
  .base-textlink {
    .base-textlink__link {
      &:hover {
        color: var(--base-textlink-color);
        .base-textlink__text {
          text-decoration: underline;
          text-underline-offset: var(--default-hover-underline-offset);
        }
      }
    }
  }
}
