@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: 45px; /* #navAreaの高さ分 */
  }
  scroll-padding-top: var(--scroll-padding-top, 0);
  &:has(.is-size-sp .navi-contents.is-open) {
    overflow: hidden;
    .page-top {
      z-index: 0;
    }
  }
}
: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;
}
/*buttonのhover時ふわっと変更させるために@property利用*/
@property --default-color-grade0 {
  syntax: '<color>';
  inherits: false;
  initial-value: #b564d9;
}

@property --default-color-grade100 {
  syntax: '<color>';
  inherits: false;
  initial-value: #ee609c;
}
:root {
  /*color*/
  --default-color-black: #000000;
  --default-color-white: #ffffff;
  --default-color-pa: #4e0655;
  --default-color-pa-05: color-mix(in srgb, var(--default-color-pa) 50%, transparent); /*別フォルダ定義*/
  --default-color-pa2: #93199f;
  --default-color-pa3: #7e0989; /*別フォルダ定義*/
  --default-color-pa5: #9653b3; /*別フォルダ定義*/
  /* --default-color-grade0: #b564d9; 別フォルダ定義・変数名変更したい */
  /* --default-color-grade100: #ee609c; 別フォルダ定義・変数名変更したい */
  --default-color-grade: linear-gradient(180deg, var(--default-color-grade0) 0%, var(--default-color-grade100) 100%); /*バリアブル未定義*/
  --default-color-grade2: linear-gradient(180deg, var(--default-color-grade100) 0%, var(--default-color-grade0) 100%); /*バリアブル未定義*/
  --default-color-yellow3: #ceaa18; /*別フォルダ定義・最後変数名変更するかも？*/
  --default-color-yellow4: #e6cf71; /*別フォルダ定義・最後変数名変更するかも？*/
  --default-color-yellow6: #f9f1d3; /*別フォルダ定義・最後変数名変更するかも？*/
  --default-color-yellow7: #8a7523; /*別フォルダ定義・最後変数名変更するかも？*/
  --default-color-black-03: color-mix(in srgb, var(--default-color-black) 30%, transparent); /*別フォルダ定義*/
  --default-color-black-05: color-mix(in srgb, var(--default-color-black) 50%, transparent); /*別フォルダ定義*/
  --default-color-dummy: #d9d9d9;
  --default-color-notice: #403e3d;
  --default-color-font-color: var(--default-color-black);
  /*font-size*/
  --default-font-size-12: min((12vw / 3.75), 12px);
  --default-font-size-13: min((13vw / 3.75), 13px);
  --default-font-size-14: min((14vw / 3.75), 14px);
  --default-font-size-16: min((16vw / 3.75), 16px);
  --default-font-size-16-14: min((14vw / 3.75), 16px); /*バリアブル未定義*/
  --default-font-size-20-16: min((16vw / 3.75), 20px);
  --default-font-size-32-24: min((24vw / 3.75), 32px);
  --default-font-size-36-26: min((26vw / 3.75), 36px);
  --default-font-size-40-32: min((32vw / 3.75), 40px);
  --default-font-size-44-26: min((26vw / 3.75), 44px);
  --default-font-size: var(--default-font-size-16-14);
  --default-font-size-spot-lm-ttl: min((20vw / 3.75), 26px);
  --default-font-size-spot-lm-ttl-small: min((14vw / 3.75), 20px);
  --default-font-size-spot-lm-min: var(--default-font-size-20-16);
  --default-font-size-spot-s-ttl: min((16vw / 3.75), 22px);
  --default-font-size-spot-s-ttl-small: min((12vw / 3.75), 16px);
  --default-font-size-spot-s-min: min((12vw / 3.75), 18px);
  /*gap*/
  --default-gap-4: 4px; /*バリアブル未定義*/
  --default-gap-8: 8px; /*バリアブル未定義*/
  --default-gap-12: 12px; /*バリアブル未定義*/
  --default-gap-16: 16px; /*バリアブル未定義*/
  --default-gap-8-4: min((4vw / 3.75), 8px);
  --default-gap-16-12: min((12vw / 3.75), 16px);
  --default-gap-24-20: min((20vw / 3.75), 24px);
  --default-gap-32-24: min((24vw / 3.75), 32px);
  --default-gap-40-32: min((32vw / 3.75), 40px);
  --default-gap-64-48: min((48vw / 3.75), 64px);
  --default-gap-section-top-bottom: min((80vw / 3.75), 120px);
  --default-gap-bg-section-top-bottom: min((88vw / 3.75), 150px);
  --default-gap-product-margin: min((80vw / 3.75), 80px);
  --default-gap-spot-margin: min((72vw / 3.75), 104px);
  --default-gap-spot-main-ttl-bottom: min((32vw / 3.75), 64px);
  /* --以下デザイン確認して利用箇所次第では変数名変更*/
  --default-gap-bottom-bnr: min((72vw / 3.75), 96px);
  /*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: (335vw / 3.75);
  --default-width-pc: 1104px;
  --default-width: min(var(--default-width-sp), var(--default-width-pc));
  --default-width-max-pc: min(100%, var(--default-width-pc));
  --default-width-max-1920: max(100%, 1920px);
  --default-width-max-1280: min(100%, 1280px);
  /*icon*/
  --default-icon-ff: 'Material Symbols Rounded';
  --default-icon-arrow-right: '\e5e1';
  --default-icon-arrow-down: '\e69b';
  --default-icon-blank: '\e89e';
  --default-icon-plus: '\e145';
  --default-icon-variation-settings-fill-0: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  --default-icon-variation-settings-fill-1: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  /*font-family*/
  --default-font-family-min: 'Zen Old Mincho', serif;
  --default-font-family-noto: 'Noto Sans JP', sans-serif;
  --default-font-family: var(--default-font-family-noto);
  /*font-weight*/
  --default-font-weight-700: 700;
  --default-font-weight-900: 900; /*明朝体時に利用有*/
  --default-font-weight-normal: 400;
  /*border-radius*/
  --default-radius-circle: 100%;
  --default-radius-button: 100vmax;
  --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);
  /*hover*/
  --default-hover-opacity: 0.8;
  --default-hover-underline-offset: 0.2em;
  /*transition*/
  --default-transition-speed: 0.3s;
  --default-transition-setting: var(--default-transition-speed) ease;
  --default-transition-opacity: opacity var(--default-transition-setting);
  --default-transition-translate: translate var(--default-transition-setting);
  --default-transition-transform: transform var(--default-transition-setting);
  --default-transition-color: color var(--default-transition-setting);
  --default-transition-background: background var(--default-transition-setting);
  /*other*/
  --default-bg-size: min((50vw / 3.75), 100px);
}
.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-color);
  line-height: var(--default-font-lh);
  word-break: break-all;
  padding-bottom: 0 !important;
}
.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, var(--default-gap-40-32));
}
.base-button {
  min-width: var(--base-button-min-width, fit-content);
  min-height: var(--base-button-min-height, auto);
  --base-button-min-height: 30px;
  --base-button-padding-inline: 16px;
  --base-button-padding-block: 8px;
  --base-button-gap: 4px;
  --base-button-bg: var(--default-color-grade);
  &.is-size-large {
    --base-button-min-width: 256px;
    --base-button-min-height: 44px;
    --base-button-font-size: var(--default-font-size-16);
    --base-button-padding-block: 12px;
    &:has(.ui-static-icon) {
      --base-button-padding-inline: 24px 16px;
    }
    &.is-icon-before {
      --base-button-padding-inline: 16px 24px;
      --base-button-grid-template-columns: auto 1fr;
      &.is-icon-spot {
        --base-button-before-icon: '\e0c8'; /*アイコン名：location on*/
      }
      .base-button__link {
        &::before {
          content: var(--base-button-before-icon);
          font-family: var(--default-icon-ff);
          font-size: var(--default-icon-ff-size, 1em);
          line-height: 0.5;
          color: var(--base-button-before-icon-color, inherit);
          font-variation-settings: var(--base-button-before-icon-variation-settings, var(--default-icon-variation-settings-fill-1));
        }
      }
    }
  }
  &.is-size-medium {
    --base-button-gap: 8px;
    --base-button-font-size: var(--default-font-size-14);
    &:has(.ui-static-icon) {
      --base-button-padding-inline: 24px 20px;
    }
  }
  &.is-size-small {
    --base-button-font-size: var(--default-font-size-12);
    &:has(.ui-static-icon) {
      --base-button-padding-inline: 16px 12px;
    }
  }
  .ui-static-button {
    :is(&, &:not(.active):not(:disabled):active, &:focus, &.active, &.focused) {
      width: 100%;
      height: 100%;
      color: var(--base-button-font-color, #fff);
      font-size: var(--base-button-font-size);
      line-height: var(--base-button-font-lh, var(--default-font-lh-130));
      text-align: center;
      display: grid;
      grid-template-columns: var(--base-button-grid-template-columns, 1fr auto);
      gap: var(--base-button-gap);
      padding-inline: var(--base-button-padding-inline);
      padding-block: var(--base-button-padding-block);
      background: var(--base-button-bg);
      border: none;
      margin: auto;
      min-width: auto;
      .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;
        }
      }
    }
  }
}
/*base-textlink*/
.base-textlink {
  .base-textlink__link {
    font-size: var(--base-textlink-font-size, var(--default-font-size-14));
    --base-textlink-color: var(--default-color-pa2);
    color: var(--base-textlink-color);
    font-weight: var(--base-textlink-font-weight, var(--default-font-weight-700));
    display: inline-block;
    padding-bottom: 1px; /*hoverのborder考慮用*/
    &:focus {
      color: var(--base-textlink-color);
    }
    .base-textlink__texts {
      line-height: 1.2;
      color: inherit;
      display: grid;
      grid-auto-flow: column;
      align-items: center;
      gap: var(--base-textlink-gap, var(--default-gap-4));
      .ui-static-icon {
        --base-textlink-icon-size: var(--default-font-size-16);
        width: var(--base-textlink-icon-size);
        aspect-ratio: 1;
        border-radius: var(--default-radius-circle);
        background: var(--base-textlink-icon-bg, var(--default-color-grade2));
        font-size: var(--base-textlink-icon-size);
        line-height: 1;
        color: var(--base-textlink-icon-color, var(--default-color-white));
        display: grid;
        place-items: center;
      }
    }
  }
}

/*base-title*/
.base-title {
  line-height: var(--default-font-lh-130);
  &.is-title-common-design-A {
    color: var(--default-color-pa3);
    text-align: center;
    font-family: var(--default-font-family-min);
    font-weight: var(--default-font-weight-900);
    font-size: var(--default-font-size-36-26);
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: var(--default-gap-40-32);
    justify-content: center;
    align-items: center;
    &::before,
    &::after {
      content: '';
      width: min((56vw / 3.75), 130px);
      height: 6px;
      background: linear-gradient(
          to bottom,
          var(--default-color-grade0) 1px,
          transparent 1px,
          transparent 5px,
          var(--default-color-grade0) 5px,
          var(--default-color-grade0) 100%
        )
        repeat-x;
    }
  }
  &.is-title-common-design-B {
    color: var(--base-title-common-design-B-font-color, var(--default-color-pa3));
    font-size: min((26vw / 3.75), 38px);
    text-align: center;
    font-family: var(--default-font-family-min);
    font-weight: var(--default-font-weight-900);
    display: grid;
    align-items: center;
    justify-content: center;
    grid-template-columns: repeat(3, auto);
    gap: min((16vw / 3.75), 40px);
    &::before,
    &::after {
      content: '';
      width: min((38vw / 3.75), 54px);
      aspect-ratio: 19 / 17;
      background: var(--default-color-yellow4);
      mask: url('../images/icon_monkey.svg') no-repeat center / contain;
    }
    &::before {
      scale: -1 1;
    }
  }
}
/*base-banner*/
.base-banners {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--default-gap-40-32); /*仮*/
}
.base-banner {
  width: var(--base-banner-size-w, min((300vw / 3.75), 500px));
  .base-banner__link {
    display: block;
  }
}
/*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-130));
  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);
  }
}
/*.page-top*/
#topbuttonApp .page-top {
  transition: var(--default-transition-opacity);
  .page-top-button {
    --page-top-button-size: min((80vw / 3.75), 100px);
    width: var(--page-top-button-size);
    height: var(--page-top-button-size);
    background: url(../images/btn_return_top.webp) no-repeat center / contain;
    padding: 0;
    body:has(.is-size-pc) & {
      --page-top-button-size: 140px;
    }
    .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;
}
/*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-bg-active: var(--default-color-grade0);
  --slider-pagination-gap: var(--default-gap-16);
  --slider-pagination-size: 10px;
  --slider-item-w: 258px;
  --slider-gap: 24px;
  max-width: var(--slider-max-width, var(--default-width-pc));
  margin: auto;
  &:not(.is-overflow) {
    .splide__list {
      justify-content: center;
    }
    .splide__slide:last-child {
      margin: 0 !important;
    }
  }
  .splide__track {
    overflow: visible;
    margin: 0 min((20vw / 3.75), 20px);
    @media (width > 1120px) {
      margin: auto;
      overflow: hidden;
    }
  }
  .splide__slide {
    width: var(--slider-item-w);
    margin-right: var(--slider-gap);
  }
  &.is-overflow {
    .splide__pagination {
      position: static;
      gap: var(--slider-pagination-gap);
      margin-top: var(--slider-pagination-yohaku, 24px);
      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, #c9bfca);
      border-radius: 50%;
      &.is-active {
        --slider-pagination-bg: var(--slider-pagination-bg-active);
        transform: scale(1);
      }
    }
  }
}
/*------------------------------------------------*/
/*★ ＝＝ hover ＝＝ ★*/
@media (hover: hover) and (pointer: fine) {
  .base-button {
    .ui-static-button {
      :is(&, &:not(.active):not(:disabled):active, &:focus, &.active, &.focused) {
        background: linear-gradient(
          180deg,
          var(--default-color-grade0) 0%,
          var(--default-color-grade100) 100%
        ); /*@property を使ったアニメーションを利用するために変数利用なしでbackgroundを指定し直し*/
        transition:
          --default-color-grade0 var(--default-transition-speed) ease,
          --default-color-grade100 var(--default-transition-speed) ease;
        &:hover {
          --default-color-grade0: #ee609c;
          --default-color-grade100: #b564d9;
        }
      }
    }
  }
  .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);
        }
      }
    }
  }
  .base-banner__link {
    transition: var(--default-transition-opacity);
    &:hover {
      opacity: var(--default-hover-opacity);
    }
  }
}
