@charset "UTF-8";
@layer reset {
  /* モダンリセット（必要最小限） */
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }
  :where(html, body) {
    margin: 0;
    padding: 0;
  }
  img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  :where(ul, ol) {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  a {
    color: inherit;
    text-decoration: none;
  }
}
@layer base {
  :root {
    /* デザイントークン（Figma準拠） */
    --color-bg: #fff;
    --color-fg: #131313;
    --color-muted: #666;
    --color-accent: #014326;
    --color-red: #b00101;
    /* アクセント/CTA */
    --color-notice-bg: #014326;
    /* 告知バー背景 */
    --color-notice-fg: #fff;
    /* 告知バー文字 */
    --color-border: #c7c7c7;
    /* Footer線 */
    --color-footer-bg: #ebe9e3;
    /* Footer背景 */
    --space-2: 8px;
    --space-4: 16px;
    --space-6: 24px;
    --radius-sm: 4px;
    --radius-md: 12px;
    --shadow-1: 0 2px 8px rgb(0 0 0 / 8%);
    --container-max: 1440px;
    --bp-mobile-start: 640px;
    /* ここからモバイルを抜ける(min-width) */
    --bp-footer-cap: 1100px;
    /* フッター余白の打ち止め幅 */
    /* ヒーロー配置補助 */
    --hero-top-offset-pc: 408px;
    /* フォントトークン */
    --font-ja:
      'Noto Sans JP', system-ui, -apple-system, 'Yu Gothic UI', 'Yu Gothic', 'Meiryo', sans-serif;
    --font-ja-serif: 'Noto Serif JP', 'Times New Roman', serif;
    --font-en: "Inter", system-ui, -apple-system, 'Segoe UI', roboto, helvetica, arial, sans-serif;
    --font-display: 'Libre Caslon Text', 'Times New Roman', serif;
    --font-price: 'Cormorant Infant', 'Libre Caslon Text', 'Times New Roman', serif;
    --transition-duration-base: 0.3s;
  }
  html {
    color-scheme: light;
    scroll-behavior: smooth;
  }
  body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: var(--color-bg);
    color: var(--color-fg);
    font-family: var(--font-ja);
  }
  #main {
    flex: 1 0 auto;
  }
  a {
    color: inherit;
    text-decoration: none;
  }
  a img {
    transition: opacity var(--transition-duration-base) ease;
  }
  a:hover {
    color: var(--color-accent);
    text-decoration: underline;
  }
  a:hover img, a:focus img {
    opacity: 0.7;
  }
  .display {
    font-family: var(--font-display);
  }
  .en {
    font-family: var(--font-en);
  }
  @media (prefers-reduced-motion: reduce) {
    html {
      scroll-behavior: auto;
    }
  }
}
@layer layout {
  .container {
    max-inline-size: var(--container-max);
    padding-inline: clamp(12px, 3vw, 48px);
    margin-inline: auto;
  }
  @media (width >= 1440px) {
    .container {
      padding-inline: 60px;
    }
  }
  .skip-link {
    position: absolute;
    top: auto;
    left: -9999px;
    overflow: hidden;
    width: 1px;
    height: 1px;
  }
  .skip-link:focus {
    position: static;
    width: auto;
    height: auto;
    padding: var(--space-2) var(--space-4);
    background: rgba(255, 255, 255, 0.6666666667);
  }
}
@layer layout {
  body.admin-bar {
    --awl-admin-bar-offset: 32px;
  }
  @media (width <= 782px) {
    body.admin-bar {
      --awl-admin-bar-offset: 46px;
    }
  }
  .site-header {
    position: relative;
    z-index: 10;
  }
  .site-header[data-awl-follow=false] .header-main {
    position: static;
    width: 100%;
    background: transparent;
    color: #fff;
  }
  .site-header[data-awl-follow=false][data-awl-scroll-appearance=toggle] .header-main {
    position: absolute;
    top: 40px;
    inset-inline: 0;
  }
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > a,
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    color: #fff;
  }
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > a::after,
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    background-image: url("../img/common/nav-caret_white.svg");
  }
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > a:hover,
  .site-header[data-awl-follow=false] .primary-nav__list > .primary-nav__item > .primary-nav__toggle:hover {
    color: #fff;
  }
  .site-header[data-awl-scroll-appearance=toggle] .header-main.is-follow-enabled.is-at-top {
    position: absolute;
    top: 40px;
    z-index: 20;
    background: transparent;
    color: #fff;
    inset-inline: 0;
    --mobile-nav-toggle-top: 155px;
  }
  .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] {
    block-size: 110px;
  }
  @media (max-width: 640px) {
    .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] {
      block-size: 77px;
    }
  }
  .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] .header-main {
    position: fixed;
    top: var(--awl-admin-bar-offset, 0);
    z-index: 20;
    background: var(--color-bg);
    border-bottom: 1px solid #ECECEC;
    color: var(--color-fg);
    inset-inline: 0;
  }
  @media (max-width: 640px) {
    .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] .header-main {
      border-bottom: 0;
    }
  }
  .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] .header-main .mobile-nav-toggle {
    color: var(--color-fg);
  }
  .site-header[data-awl-follow=true][data-awl-scroll-appearance=fixed] .header-main.is-follow-enabled.is-at-top {
    position: static;
    top: auto;
    inset-inline: auto;
  }
  .notice-bar {
    background: var(--color-notice-bg);
    color: var(--color-notice-fg);
  }
  .notice-bar__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-block: 12px;
  }
  @media (max-width: 640px) {
    .notice-bar__inner {
      padding-block: 9px 10px;
    }
  }
  .notice-bar__text {
    margin: 0;
    font-size: 14px;
    line-height: 21px;
    letter-spacing: 0.28px;
    white-space: nowrap;
  }
  @media (max-width: 640px) {
    .notice-bar__text {
      font-size: 13px;
    }
  }
  .notice-bar__text a {
    color: var(--color-notice-fg);
    text-decoration: underline;
    text-underline-position: from-font;
  }
  .header-main {
    background: var(--color-bg);
    transition: background-color var(--transition-duration-base) ease, color var(--transition-duration-base) ease, box-shadow var(--transition-duration-base) ease;
    --mobile-nav-offset-top: 155px;
    --mobile-nav-offset-scrolled: 110px;
    --mobile-nav-toggle-top: 155px;
  }
  .header-main.is-follow-enabled {
    inset-inline: 0;
    z-index: 20;
  }
  .header-main.is-follow-enabled.is-fixed {
    position: fixed;
    top: calc(var(--awl-admin-bar-offset, 0px) + var(--awl-notice-offset, 0px));
    inset-inline: 0;
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > a,
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    color: #fff;
    font-family: var(--font-en);
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > a::after,
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    background-image: url("../img/common/nav-caret_white.svg");
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > a:hover,
  .header-main.is-follow-enabled.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle:hover {
    color: #fff;
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__dropdown-link {
    color: var(--color-fg);
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__dropdown-link:hover, .header-main.is-follow-enabled.is-at-top .primary-nav__dropdown-link:focus {
    color: var(--color-bg);
    text-decoration: none;
  }
  .header-main.is-follow-enabled.is-scrolled {
    background: var(--color-bg);
    border-bottom: 1px solid #ECECEC;
    color: var(--color-fg);
  }
  @media (max-width: 640px) {
    .header-main.is-follow-enabled.is-scrolled {
      border: none;
    }
  }
  .header-main.is-follow-enabled.is-scrolled .primary-nav__list > .primary-nav__item > a,
  .header-main.is-follow-enabled.is-scrolled .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    color: var(--color-fg);
  }
  .header-main.is-follow-enabled.is-scrolled .primary-nav__list > .primary-nav__item > a::after,
  .header-main.is-follow-enabled.is-scrolled .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    background-image: url("../img/common/nav-caret_black.svg");
  }
  .header-main.is-follow-enabled.is-scrolled .mobile-nav-toggle {
    color: var(--color-fg);
  }
  .header-main__inner {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    block-size: 110px;
  }
  @media (max-width: 1250px) {
    .header-main__inner {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
      align-items: center;
      gap: 16px;
      block-size: 110px;
    }
  }
  @media (max-width: 640px) {
    .header-main__inner {
      block-size: 76px;
      padding: 0 12px;
    }
  }
  .header-main.is-mobile-nav-open .mobile-nav-toggle {
    color: var(--color-fg);
  }
  .header-main.is-mobile-nav-open .mobile-nav-toggle__icon {
    background-color: transparent;
  }
  .header-main.is-mobile-nav-open .mobile-nav-toggle__icon::before {
    transform: translateY(6px) rotate(45deg);
  }
  .header-main.is-mobile-nav-open .mobile-nav-toggle__icon::after {
    transform: translateY(-6px) rotate(-45deg);
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    border-bottom: 1px solid #ddd;
    color: var(--color-fg);
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a:hover,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a:focus,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a:focus-visible,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a:active,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle:hover,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle:focus,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle:focus-visible,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle:active {
    color: var(--color-fg);
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > a::after,
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    background-image: url("../img/common/arrow-down.svg") !important;
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    position: relative;
    padding-right: 44px;
    background-position: right 3px center;
    background-size: 16px 16px;
    background-repeat: no-repeat;
  }
  @media (max-width: 1250px) {
    .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
      padding: 14px 0;
    }
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    position: absolute;
    margin-left: 0;
    background-position: center;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    transition: transform var(--transition-duration-base) ease;
    content: "";
    inline-size: 16px;
    block-size: 16px;
    inset-block-start: 50%;
    inset-inline-end: 3px;
    transform: translateY(-50%);
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item:not(.primary-nav__item--has-submenu) > a {
    padding-right: 44px;
    background-image: url("../img/common/arrow-down.svg");
    background-position: right 3px center;
    background-size: 16px 16px;
    background-repeat: no-repeat;
  }
  @media (max-width: 1250px) {
    .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item:not(.primary-nav__item--has-submenu) > a {
      padding: 18px 0;
    }
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item:not(.primary-nav__item--has-submenu) > a::after {
    content: none;
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item.primary-nav__item--about > a {
    padding-right: 0;
    background: none;
  }
  .header-main.is-mobile-nav-open .primary-nav__list > .primary-nav__item.primary-nav__item--about > a::after {
    content: none;
  }
  .header-main.is-mobile-nav-open .primary-nav__list {
    flex-direction: column;
    align-items: center;
    gap: 24px;
  }
  @media (max-width: 1250px) {
    .header-main.is-mobile-nav-open .primary-nav__list {
      gap: 0;
    }
  }
  .header-main.is-mobile-nav-open .primary-nav__item {
    width: 100%;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand,
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand-inline {
    left: auto;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    padding: 18px 0 0;
    text-transform: lowercase;
    gap: 0;
    inline-size: 100%;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand .primary-nav__dropdown-item,
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item {
    display: flex;
    flex: 0 0 33.333%;
    align-items: center;
    justify-content: center;
    border-top: 1px solid #CACACA;
    border-left: 1px solid #CACACA;
    inline-size: 33.333%;
    block-size: 67px;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand .primary-nav__dropdown-item:nth-child(3n),
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item:nth-child(3n) {
    border-right: 1px solid #CACACA;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand .primary-nav__dropdown-item:nth-last-child(-n+3),
  .header-main.is-mobile-nav-open .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item:nth-last-child(-n+3) {
    border-bottom: 1px solid #CACACA;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown-brand-link {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 0;
    text-align: center;
    inline-size: 100%;
    block-size: 100%;
  }
  .header-main.is-mobile-nav-open .primary-nav__dropdown--stack {
    gap: 12px;
    left: auto;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__toggle::after {
    margin-left: 0;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown {
    position: static;
    display: none;
    visibility: hidden;
    flex-direction: column;
    padding: 6px 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    pointer-events: none;
    gap: 12px;
    transform: none;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown::before, .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown::after {
    content: none;
  }
  @media (max-width: 1250px) {
    .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown {
      gap: 16px;
    }
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown--stack .primary-nav__dropdown-panel,
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu .primary-nav__dropdown--brand {
    opacity: 0;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu.is-open > .primary-nav__toggle {
    border-bottom: 0;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu.is-open .primary-nav__toggle::after {
    transform: translateY(-50%) rotate(180deg);
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu.is-open .primary-nav__dropdown {
    display: flex;
    visibility: visible;
    width: 100%;
    border-bottom: 1px solid #ddd;
    pointer-events: auto;
  }
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu.is-open .primary-nav__dropdown--stack .primary-nav__dropdown-panel,
  .header-main.is-mobile-nav-open .primary-nav__item--has-submenu.is-open .primary-nav__dropdown--brand {
    opacity: 1;
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    border-bottom: 1px solid #ddd;
    color: var(--color-fg);
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a:hover,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a:focus,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a:focus-visible,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a:active,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle:hover,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle:focus,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle:focus-visible,
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle:active {
    color: var(--color-fg);
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > a::after {
    background-image: url("../img/common/nav-caret_black.svg");
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    background-image: url("../img/common/arrow-down.svg");
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item.primary-nav__item--has-submenu.is-open > .primary-nav__toggle {
    border-bottom: 0;
  }
  .header-main.is-mobile-nav-open.is-at-top .primary-nav__list > .primary-nav__item.primary-nav__item--has-submenu.is-open > .primary-nav__dropdown {
    border-bottom: 1px solid #ddd;
  }
  .header-main.is-mobile-nav-open.is-at-top .mobile-nav-toggle {
    color: #fff;
  }
  @media (max-width: 1250px) {
    .header-main.is-mobile-nav-open .primary-nav {
      position: fixed;
      inset: var(--mobile-nav-offset, 72px) 0 0 0;
      z-index: 10;
      display: flex;
      flex-direction: column;
      padding: 7px clamp(20px, 3vw, 48px) 51px;
      background-color: #fff;
      overflow-y: auto;
    }
    .header-main.is-mobile-nav-open .primary-nav__item--search {
      display: flex;
      width: 100%;
    }
    .header-main.is-mobile-nav-open .primary-nav__search-form {
      width: 100%;
      max-inline-size: none;
      gap: 12px;
    }
    .header-main.is-mobile-nav-open .primary-nav__search-input {
      flex: 1 1 auto;
      inline-size: auto;
    }
  }
  .site-logo {
    display: flex;
    flex: 0 0 auto;
    justify-content: center;
    margin: 0;
    padding-top: 4px;
  }
  @media (max-width: 1250px) {
    .site-logo {
      flex: unset;
      grid-column: 2;
      justify-self: center;
      padding-top: 0;
    }
  }
  .header-actions {
    display: flex;
    flex: 1 1 0;
    align-items: center;
    justify-content: flex-end;
    min-width: 0;
    gap: 23px;
  }
  @media (max-width: 1250px) {
    .header-actions {
      flex: unset;
      grid-column: 3;
      justify-self: end;
      gap: 16px;
      margin: -12px 0 0;
    }
  }
  @media (max-width: 640px) {
    .header-actions {
      gap: 11px;
    }
  }
  .header-actions__link {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 0;
    background: none;
    border: 0;
    color: inherit;
    font: inherit;
    text-decoration: none;
    cursor: pointer;
    appearance: none;
  }
  .header-actions__link:is(button) {
    transition: opacity var(--transition-duration-base) ease;
  }
  .header-actions__link:is(button):hover, .header-actions__link:is(button):focus {
    opacity: 0.7;
  }
  @media (max-width: 1250px) {
    .header-actions__link[data-awl-hide-mobile=true] {
      display: none;
    }
  }
  .header-actions .icon {
    display: block;
  }
  .header-actions__icon--favorite {
    width: 26px;
    height: 23px;
  }
  @media (max-width: 640px) {
    .header-actions__icon--favorite {
      width: 19px;
      height: 17px;
    }
  }
  .header-actions__icon--cart {
    width: 25px;
    height: 25px;
  }
  @media (max-width: 640px) {
    .header-actions__icon--cart {
      width: 19px;
      height: 19px;
    }
  }
  .header-search {
    position: fixed;
    top: 150px;
    z-index: 19;
    display: none;
    padding: 16px var(--space-6);
    inset-inline: 0;
    transform: translate3d(0, -16px, 0);
    opacity: 0;
    transition: opacity 1s ease, transform 1s ease;
  }
  .header-search.is-active {
    display: block;
    background-color: transparent;
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
  .header-search__inner {
    display: flex;
    justify-content: center;
  }
  .header-search__form {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    inline-size: 100%;
  }
  .header-search__box {
    display: flex;
    align-items: center;
    gap: 12px;
    inline-size: 800px;
    max-inline-size: 100%;
    padding: 10px 16px;
    background-color: #F0F0F0;
    border-radius: 5px;
  }
  .header-search__input {
    flex: 1 1 auto;
    background: transparent;
    border: 0;
    color: var(--color-fg);
    font-size: 16px;
    line-height: 1.5;
  }
  .header-search__input:focus {
    outline: none;
  }
  .header-search__submit {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    padding: 0;
    background: none;
    border: 0;
    transition: opacity var(--transition-duration-base) ease;
    cursor: pointer;
  }
  .header-search__submit:hover, .header-search__submit:focus {
    opacity: 0.85;
  }
  .header-search__submit-icon {
    display: block;
    width: 24px;
    height: 24px;
  }
  .header-search__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    background: none;
    border: 0;
    color: var(--color-fg);
    transition: opacity var(--transition-duration-base) ease;
    cursor: pointer;
    inline-size: 32px;
    block-size: 32px;
  }
  .header-search__close:hover, .header-search__close:focus {
    opacity: 0.85;
  }
  .header-search__close-icon {
    position: relative;
    display: block;
    background-color: transparent;
    border-radius: 1px;
    inline-size: 24px;
    block-size: 2px;
  }
  .header-search__close-icon::before, .header-search__close-icon::after {
    position: absolute;
    left: 0;
    background-color: currentcolor;
    border-radius: 1px;
    content: "";
    inline-size: 24px;
    block-size: 2px;
  }
  .header-search__close-icon::before {
    transform: rotate(45deg);
  }
  .header-search__close-icon::after {
    transform: rotate(-45deg);
  }
  @media (max-width: 640px) {
    .header-search {
      display: none !important;
      padding: 12px var(--space-4);
    }
    .header-search__box {
      gap: 8px;
      padding: 10px 12px;
    }
    .header-search__submit {
      padding: 0;
    }
    .header-search__close {
      inline-size: 28px;
      block-size: 28px;
    }
    .header-search__close-icon {
      inline-size: 20px;
    }
    .header-search__close-icon::before, .header-search__close-icon::after {
      inline-size: 20px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .header-search {
      transition: none;
      transform: none;
    }
  }
  .header-main.is-follow-enabled.is-at-top + .header-search {
    top: calc(var(--awl-admin-bar-offset, 0px) + 150px);
  }
  .header-main.is-follow-enabled.is-fixed + .header-search,
  .header-main.is-follow-enabled.is-scrolled + .header-search {
    top: calc(var(--awl-admin-bar-offset, 0px) + 110px);
  }
  .header-main.is-follow-enabled.is-scrolled + .header-search.is-active {
    background-color: #fff;
  }
  .site-header[data-awl-scroll-appearance=fixed] .header-search.is-active {
    background-color: #fff;
  }
  .mobile-nav-toggle {
    position: relative;
    display: none;
    justify-content: center;
    margin: 0;
    padding: 0;
    background: none;
    border: 0;
    color: #fff;
    transition: color var(--transition-duration-base) ease;
    cursor: pointer;
    inline-size: 44px;
    block-size: 44px;
  }
  @media (max-width: 1250px) {
    .mobile-nav-toggle {
      display: inline-flex;
      grid-column: 1;
      align-items: center;
      justify-self: start;
      margin: -7px 0 0;
    }
  }
  @media (max-width: 640px) {
    .mobile-nav-toggle {
      inline-size: 24px;
      block-size: 24px;
    }
  }
  .mobile-nav-toggle__icon {
    position: relative;
    display: block;
    background-color: currentcolor;
    border-radius: 1px;
    transition: background-color var(--transition-duration-base) ease;
    inline-size: 22px;
    block-size: 1px;
  }
  .mobile-nav-toggle__icon::before, .mobile-nav-toggle__icon::after {
    position: absolute;
    left: 0;
    background-color: currentcolor;
    border-radius: 1px;
    transition: transform var(--transition-duration-base) ease;
    content: "";
    inline-size: 22px;
    block-size: 1px;
  }
  .mobile-nav-toggle__icon::before {
    top: -6px;
  }
  .mobile-nav-toggle__icon::after {
    top: 6px;
  }
  .primary-nav {
    display: flex;
    flex: 1 1 0;
    align-items: center;
    min-width: 0;
  }
  @media (max-width: 1250px) {
    .primary-nav {
      display: none;
      flex-direction: column;
      grid-column: 1/-1;
      gap: 24px;
      align-items: initial;
    }
  }
  .primary-nav__list {
    display: flex;
    align-items: center;
    gap: 22px;
  }
  .primary-nav__list > .primary-nav__item > a,
  .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
    display: inline-flex;
    align-items: center;
    color: var(--color-fg);
    font-size: 14.5px;
    line-height: 16.94px;
    letter-spacing: 0.28px;
    transition: color var(--transition-duration-base) ease;
  }
  .primary-nav__list > .primary-nav__item > a::after,
  .primary-nav__list > .primary-nav__item > .primary-nav__toggle::after {
    margin-left: 5px;
    background: no-repeat center/100% 100% url("../img/common/nav-caret_black.svg");
    transition: background-image var(--transition-duration-base) ease;
    content: "";
    inline-size: 9px;
    block-size: 6px;
  }
  .primary-nav__list > .primary-nav__item > a:hover,
  .primary-nav__list > .primary-nav__item > .primary-nav__toggle:hover {
    color: var(--color-accent);
  }
  .primary-nav__list > .primary-nav__item.primary-nav__item--about > a::after {
    content: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__list > .primary-nav__item > a,
    .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
      font-size: 19px;
      line-height: 1.6;
      letter-spacing: 0.04em;
      inline-size: 100%;
    }
    .primary-nav__list > .primary-nav__item > .primary-nav__toggle {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .primary-nav__list > .primary-nav__item--guide {
      margin-bottom: 27px;
    }
  }
  .primary-nav__item {
    position: relative;
    z-index: 1;
  }
  .primary-nav__item--guide .primary-nav__dropdown {
    inline-size: 210px;
  }
  .primary-nav__item--brand-collection {
    z-index: 0;
    display: none;
  }
  .primary-nav__item--search {
    display: none;
  }
  .primary-nav__item--has-submenu {
    position: relative;
  }
  .primary-nav__item--has-submenu.is-open .primary-nav__dropdown {
    display: flex;
    visibility: visible;
    pointer-events: auto;
  }
  .primary-nav__item--has-submenu.is-open .primary-nav__dropdown--brand {
    display: flex;
    opacity: 1;
  }
  @media (min-width: 1251px) {
    .primary-nav__item--has-submenu:hover .primary-nav__dropdown, .primary-nav__item--has-submenu:focus-within .primary-nav__dropdown {
      display: flex;
      visibility: visible;
      pointer-events: auto;
    }
    .primary-nav__item--has-submenu:hover .primary-nav__dropdown--stack, .primary-nav__item--has-submenu:focus-within .primary-nav__dropdown--stack {
      display: flex;
    }
    .primary-nav__item--has-submenu:hover .primary-nav__dropdown--brand, .primary-nav__item--has-submenu:focus-within .primary-nav__dropdown--brand {
      display: flex;
      opacity: 1;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__item--has-submenu .primary-nav__dropdown::before {
      box-shadow: initial;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__item--brand {
      display: none;
    }
    .primary-nav__item--brand-collection {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }
  }
  .primary-nav__login-button {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__login-button {
      z-index: 100;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-top: 12px;
      padding: 14px 0 13px !important;
      background: none !important;
      border: 1px solid var(--color-accent) !important;
      color: var(--color-accent) !important;
      font-size: 14px !important;
      line-height: 1.6;
      letter-spacing: 0.04em;
      text-align: center;
      text-decoration: none;
      transition: background-color var(--transition-duration-base) ease, color var(--transition-duration-base) ease;
      cursor: pointer;
      gap: 6px;
      inline-size: 100%;
    }
    .primary-nav__login-button:hover, .primary-nav__login-button:focus-visible {
      background-color: #01351c;
      color: #fff;
    }
    .primary-nav__login-button:focus-visible {
      outline: 2px solid var(--color-fg);
      outline-offset: 2px;
    }
  }
  .primary-nav__login-icon {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__login-icon {
      display: block;
      inline-size: 14px;
      block-size: 15px;
      flex-shrink: 0;
    }
  }
  .primary-nav__login-label {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__login-label {
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
  }
  .primary-nav__social-list {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__social-list {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      margin: 30px 0 0;
      padding: 0;
      list-style: none;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__social-item {
      display: flex;
    }
  }
  .primary-nav__social-link {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__social-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      inline-size: 40px;
      block-size: 40px;
    }
  }
  .primary-nav__social-icon {
    display: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__social-icon {
      z-index: 100;
      display: block;
      inline-size: 24px;
      block-size: 24px;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__social-icon--x {
      inline-size: 19px;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__social-icon--instagram {
      inline-size: 22px;
      block-size: 22px;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__social-icon--facebook {
      inline-size: 22px;
    }
  }
  @media (max-width: 1250px) {
    .primary-nav__social-icon--mail {
      inline-size: 24px;
    }
  }
  .primary-nav__brand-heading {
    margin-bottom: -26px;
    color: var(--color-fg);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.04em;
  }
  .primary-nav__search-form {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 2px 6px 1px;
    background-color: #f8f8f8;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    inline-size: 100%;
    max-inline-size: 220px;
  }
  .primary-nav__search-input {
    flex: 1 1 auto;
    padding: 0;
    background: transparent;
    border: 0;
    color: inherit;
    font: inherit;
    min-inline-size: 0;
  }
  .primary-nav__search-input:focus {
    outline: none;
  }
  .primary-nav__search-submit {
    display: inline-flex;
    overflow: hidden;
    align-items: center;
    justify-content: center;
    padding: 0;
    background-color: transparent;
    background-image: url("../img/common/icon-search-green.svg");
    background-position: center;
    background-size: 18px 18px;
    background-repeat: no-repeat;
    border: none;
    color: transparent;
    font: inherit;
    transition: opacity var(--transition-duration-base) ease;
    cursor: pointer;
    inline-size: 32px;
    block-size: 32px;
    text-indent: -9999px;
  }
  .primary-nav__search-submit:hover, .primary-nav__search-submit:focus-visible {
    opacity: 0.8;
  }
  .primary-nav__search-submit:focus-visible {
    outline: 2px solid var(--color-fg);
    outline-offset: 2px;
  }
  .primary-nav__toggle {
    padding: 0;
    background: transparent;
    border: 0;
    font: inherit;
    text-decoration: none;
    cursor: pointer;
    appearance: none;
  }
  #primary-nav-search-field {
    padding: 0;
    background: transparent;
    border: 0;
    min-block-size: 24px;
  }
  @media (max-width: 640px) {
    #primary-nav-search-field {
      color: #5e5e5e;
    }
    .primary-nav__search-form {
      max-inline-size: none;
    }
    .primary-nav__search-form::after {
      position: absolute;
      top: 50%;
      left: 16px;
      opacity: 1;
      color: #5e5e5e;
      font-size: 14px;
      transition: opacity var(--transition-duration-base) ease;
      content: "検索する";
      pointer-events: none;
      transform: translateY(-50%);
    }
    .primary-nav__search-form:focus-within::after, .primary-nav__search-form:has(.primary-nav__search-input:valid)::after {
      opacity: 0;
    }
    .primary-nav__search-submit {
      inline-size: 36px;
      block-size: 36px;
      background-size: 20px 20px;
    }
  }
  .primary-nav__dropdown {
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    z-index: 30;
    display: flex;
    visibility: hidden;
    flex-direction: column;
    padding: 0;
    background: transparent;
    opacity: 1;
    isolation: isolate;
    pointer-events: none;
    gap: 12px;
    inline-size: 180px;
    transform: none;
  }
  .primary-nav__dropdown::before {
    position: absolute;
    inset: 45px 0 0 0;
    z-index: 0;
    background: #fff;
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.12);
    content: "";
  }
  .primary-nav__dropdown::after {
    position: absolute;
    inset: 0 0 auto;
    z-index: 0;
    block-size: 45px;
    content: "";
  }
  .primary-nav__dropdown--stack {
    left: -20px;
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-top: 45px;
  }
  .primary-nav__dropdown--stack::before {
    content: none;
  }
  .primary-nav__dropdown--stack .primary-nav__dropdown-panel {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 0;
    background: #fff;
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.12);
    list-style: none;
    opacity: 0;
    transition: opacity var(--transition-duration-base) ease;
  }
  @media (max-width: 1250px) {
    .primary-nav__dropdown--stack {
      left: auto;
    }
    .primary-nav__dropdown--stack .primary-nav__dropdown-panel {
      box-shadow: none;
    }
  }
  .primary-nav__dropdown--brand {
    left: -30px;
    display: flex;
    flex-flow: row wrap;
    width: 335px;
    padding: 45px 0 0;
    opacity: 0;
    text-transform: lowercase;
    transition: opacity var(--transition-duration-base) ease;
    gap: 0;
    inline-size: 335px;
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-item {
    display: flex;
    flex: 0 0 33.333%;
    align-items: center;
    justify-content: center;
    border-top: 1px solid var(--color-border);
    border-left: 1px solid var(--color-border);
    inline-size: 33.333%;
    block-size: 64.1px;
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-item:nth-child(3n) {
    border-right: 1px solid var(--color-border);
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-item:nth-last-child(-n+3) {
    border-bottom: 1px solid var(--color-border);
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    text-align: center;
    inline-size: 100%;
    block-size: 100%;
  }
  @media (max-width: 1250px) {
    .primary-nav__dropdown--brand {
      left: auto;
      width: 100%;
      padding: 16px 0 0;
      inline-size: 100%;
    }
    .primary-nav__dropdown--brand .primary-nav__dropdown-item {
      inline-size: 33.333%;
    }
  }
  .primary-nav__dropdown-item {
    position: relative;
    z-index: 1;
    list-style: none;
  }
  @media (min-width: 1251px) {
    .primary-nav__item--has-submenu.is-open .primary-nav__dropdown--stack .primary-nav__dropdown-panel {
      opacity: 1;
    }
    .primary-nav__item--has-submenu:focus-within .primary-nav__dropdown--stack .primary-nav__dropdown-panel {
      opacity: 1;
    }
    .primary-nav__item--has-submenu:hover .primary-nav__dropdown--stack .primary-nav__dropdown-panel {
      opacity: 1;
    }
  }
  .primary-nav__dropdown-link {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 8px 28px;
    color: var(--color-fg);
    font-size: 14px;
    line-height: 1.4;
    letter-spacing: 0.26px;
    white-space: nowrap;
    transition: none;
    inline-size: 100%;
  }
  @media (max-width: 1250px) {
    .primary-nav__dropdown-link {
      padding: 0 0 16px;
    }
  }
  .primary-nav__dropdown-brand-link {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    border: 0;
    color: var(--color-fg);
    text-align: center;
    transition: none;
    inline-size: 100%;
    block-size: 100%;
  }
  .primary-nav__dropdown--stack .primary-nav__dropdown-link {
    gap: 10px;
    transition: background-color var(--transition-duration-base) ease, color var(--transition-duration-base) ease;
  }
  .primary-nav__dropdown--stack .primary-nav__dropdown-link::before {
    flex: 0 0 5px;
    inline-size: 5px;
    block-size: 10px;
    background-color: currentcolor;
    content: "";
    mask: no-repeat center/contain url("../img/common/icon-arrow-right.svg");
  }
  .primary-nav__dropdown--stack .primary-nav__dropdown-link:hover,
  .primary-nav__dropdown--stack .primary-nav__dropdown-link:focus {
    background: var(--color-notice-bg);
    color: var(--color-bg);
    text-decoration: none;
  }
  .primary-nav__logo-mask {
    position: relative;
    display: inline-block;
    inline-size: var(--brand-logo-width, auto);
    block-size: var(--brand-logo-height, auto);
    overflow: hidden;
  }
  .primary-nav__logo-mask::before, .primary-nav__logo-mask::after {
    position: absolute;
    inset: 0;
    transition: opacity var(--transition-duration-base) ease;
    content: "";
  }
  .primary-nav__logo-mask::before {
    background-color: #131313;
    mask-image: var(--brand-logo-mask-image);
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
  }
  .primary-nav__logo-mask::after {
    background: var(--brand-logo-image) no-repeat center/contain;
    opacity: 0;
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:hover .primary-nav__logo-mask::before,
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:focus .primary-nav__logo-mask::before,
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:focus-visible .primary-nav__logo-mask::before,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:hover .primary-nav__logo-mask::before,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:focus .primary-nav__logo-mask::before,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:focus-visible .primary-nav__logo-mask::before {
    opacity: 0;
  }
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:hover .primary-nav__logo-mask::after,
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:focus .primary-nav__logo-mask::after,
  .primary-nav__dropdown--brand .primary-nav__dropdown-brand-link:focus-visible .primary-nav__logo-mask::after,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:hover .primary-nav__logo-mask::after,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:focus .primary-nav__logo-mask::after,
  .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link:focus-visible .primary-nav__logo-mask::after {
    opacity: 1;
  }
  .primary-nav__dropdown-link--static {
    transition: none;
  }
  .primary-nav__dropdown-link--static:hover, .primary-nav__dropdown-link--static:focus {
    color: var(--color-fg);
  }
  .header-main.is-follow-enabled.is-at-top .primary-nav__dropdown--stack .primary-nav__dropdown-link:hover,
  .header-main.is-follow-enabled.is-at-top .primary-nav__dropdown--stack .primary-nav__dropdown-link:focus {
    background-color: var(--color-notice-bg);
    color: var(--color-bg);
    text-decoration: none;
  }
  @media (prefers-reduced-motion: reduce) {
    .primary-nav__dropdown--stack .primary-nav__dropdown-panel,
    .primary-nav__dropdown--brand {
      transition: none;
    }
  }
  .cart-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-accent);
    border-radius: 999px;
    color: #fff;
    font-size: 10px;
    inline-size: 15px;
    block-size: 15px;
  }
  body.is-mobile-nav-open {
    overflow: hidden;
  }
  .primary-nav__dropdown--brand-inline {
    position: static;
    display: none;
    visibility: visible;
    padding: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    gap: 16px;
    transform: none;
  }
  @media (max-width: 1250px) {
    .primary-nav__dropdown--brand-inline {
      left: auto;
      display: flex;
      flex-wrap: wrap;
      width: 100%;
      padding: 18px 0 0;
      text-transform: lowercase;
      gap: 0;
      inline-size: 100%;
    }
    .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item {
      display: flex;
      flex: 0 0 33.333%;
      align-items: center;
      justify-content: center;
      border-top: 1px solid var(--color-border);
      border-left: 1px solid var(--color-border);
      inline-size: 33.333%;
      block-size: 64.1px;
    }
    .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item:nth-child(3n) {
      border-right: 1px solid var(--color-border);
    }
    .primary-nav__dropdown--brand-inline .primary-nav__dropdown-item:nth-last-child(-n+3) {
      border-bottom: 1px solid var(--color-border);
    }
    .primary-nav__dropdown--brand-inline .primary-nav__dropdown-brand-link {
      display: flex;
      align-items: center;
      justify-content: center;
      border: 0;
      text-align: center;
      inline-size: 100%;
      block-size: 100%;
    }
  }
  @media (max-width: 1250px) {
    #primary-nav-dropdown-brand-inline::before {
      box-shadow: initial;
    }
  }
  @media (max-width: 640px) {
    .brand__logo {
      width: 110px;
    }
  }
  @media (max-width: 640px) {
    body.home .site-logo {
      margin-block-start: 2px;
    }
  }
  body:not(.home) .header-main__inner {
    block-size: 110px;
  }
  @media (max-width: 1250px) {
    body:not(.home) .header-main__inner {
      block-size: 110px;
    }
  }
  @media (max-width: 640px) {
    body:not(.home) .header-main__inner {
      block-size: 77px;
    }
  }
  body:not(.home) .header-main.is-scrolled .header-main__inner {
    block-size: 110px;
  }
  @media (max-width: 1250px) {
    body:not(.home) .header-main.is-scrolled .header-main__inner {
      block-size: 110px;
    }
  }
  @media (max-width: 640px) {
    body:not(.home) .header-main.is-scrolled .header-main__inner {
      block-size: 77px;
    }
  }
}
@layer layout {
  .hero {
    position: relative;
    overflow: hidden;
    min-height: calc(100svh - 36px - 110px);
    background-color: var(--color-fg);
    color: #fff;
    touch-action: pan-y;
  }
  @media (max-width: 1250px) {
    .hero .hero {
      padding-top: var(--hero-top-offset-pc);
    }
  }
  @media (max-width: 640px) {
    .hero {
      min-height: 147.6923076923vw;
    }
  }
  .hero__slides {
    position: relative;
    inline-size: 100%;
    min-block-size: calc(100svh - 36px - 110px);
  }
  .hero__slide {
    position: absolute;
    display: flex;
    visibility: hidden;
    align-items: flex-end;
    background-color: var(--color-fg);
    background-image: var(--hero-slide-image-pc);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 1200ms ease, visibility 1200ms ease;
    pointer-events: none;
    inline-size: 100%;
    min-block-size: inherit;
    padding-block: 60px 58px;
    inset: 0;
  }
  @media (max-width: 640px) {
    .hero__slide {
      min-block-size: 147.6923076923vw;
      padding-block: 60px 35px;
      background-image: var(--hero-slide-image-sp, var(--hero-slide-image-pc));
    }
  }
  .hero__slide.is-active {
    position: relative;
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }
  .hero__slide.is-active .hero__inner {
    animation: hero-slide-fade-in 1200ms ease;
  }
  .hero__slide--panel-link {
    cursor: pointer;
  }
  .hero__slide--panel-link .hero__container {
    pointer-events: none;
  }
  .hero__panel-link {
    position: absolute;
    z-index: 1;
    display: block;
    inset: 0;
  }
  .hero__panel-link:focus-visible {
    outline: none;
  }
  .hero__panel-link:focus-visible + .hero__container {
    outline: 2px solid #fff;
    outline-offset: -2px;
  }
  .hero__container {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    inline-size: 100%;
    block-size: 100%;
  }
  .hero__inner {
    text-align: left;
    inline-size: min(100%, 520px);
  }
  .hero__inner:not(:has(.hero__cta)) .hero__lead {
    margin-bottom: 77px;
  }
  @media (max-width: 640px) {
    .hero__inner:not(:has(.hero__cta)) .hero__lead {
      margin-bottom: 77px;
    }
  }
  .hero__title {
    margin: 0;
    font-size: 44px;
    line-height: 52.734px;
    letter-spacing: 4.2px;
  }
  .hero__title--ja {
    font-family: var(--font-ja-serif);
    font-size: 33px;
    font-weight: 500;
  }
  @media (max-width: 640px) {
    .hero__title {
      font-size: 34px;
      letter-spacing: 0.09em;
    }
  }
  .hero__lead {
    margin: 8px 0 0;
    max-inline-size: 56ch;
    font-family: var(--font-ja-serif);
    font-size: 17px;
    line-height: 27px;
    letter-spacing: 1.65px;
  }
  @media (max-width: 1250px) {
    .hero__lead {
      max-inline-size: 465px;
    }
  }
  @media (max-width: 640px) {
    .hero__lead {
      margin: 4px 0 0;
      font-size: 12px;
      line-height: 25px;
    }
  }
  .hero__lead > :first-child {
    margin-top: 0;
  }
  .hero__lead > :last-child {
    margin-bottom: 0;
  }
  .hero__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 26px;
    background: #fff;
    border-radius: 0;
    color: var(--color-accent);
    font-family: var(--font-ja-serif);
    font-size: 14px;
    font-weight: 600;
    line-height: 15.34px;
    letter-spacing: 0.28px;
    inline-size: 184px;
    block-size: 51px;
    text-decoration: none;
  }
  @media (max-width: 640px) {
    .hero__cta {
      margin-top: 17px;
      font-size: 13px;
      inline-size: 138px;
      block-size: 42px;
    }
  }
  .hero__controls {
    position: absolute;
    z-index: 2;
    pointer-events: none;
    inset-inline: 0;
    inset-block: 0;
  }
  @media (max-width: 640px) {
    .hero__controls {
      inset-block: 0;
    }
  }
  .hero__arrows {
    position: absolute;
    inset-inline: 0;
    inset-block-start: 50%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transform: translateY(-50%);
    pointer-events: none;
  }
  @media (max-width: 640px) {
    .hero__arrows {
      inset-block-start: 50%;
    }
  }
  .hero__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    padding: 0;
    background: transparent;
    border: 0;
    color: #fff;
    transition: opacity 200ms ease;
    cursor: pointer;
    pointer-events: auto;
  }
  .hero__arrow:hover, .hero__arrow:focus-visible {
    opacity: 0.75;
  }
  @media (max-width: 640px) {
    .hero__arrow {
      width: 42px;
      height: 42px;
    }
  }
  .hero__arrow-icon {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: currentcolor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 3;
    filter: drop-shadow(0 0 8px rgba(0, 0, 0, 0.24));
  }
  @media (max-width: 640px) {
    .hero__arrow-icon {
      width: 10px;
      height: 20px;
      stroke-width: 3.2;
    }
  }
  .hero__dots {
    position: absolute;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: 0;
    pointer-events: auto;
    inset-inline: 50%;
    inset-block-end: 58px;
    gap: 10px;
    list-style: none;
    transform: translateX(-50%);
  }
  .hero__dots > li {
    flex: 0 0 auto;
    list-style: none;
  }
  @media (max-width: 640px) {
    .hero__dots {
      gap: 8px;
      inset-block-end: 35px;
    }
  }
  .hero__dot {
    display: block;
    flex: 0 0 10px;
    width: 10px;
    height: 10px;
    padding: 0;
    background: rgba(255, 255, 255, 0.35);
    border: 0;
    border-radius: 50%;
    transition: transform 200ms ease, background-color 200ms ease;
    cursor: pointer;
    appearance: none;
  }
  .hero__dot.is-active {
    background: #fff;
    transform: scale(1.2);
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero__slide,
  .hero__slide.is-active .hero__inner {
    transition: none;
    animation: none;
  }
}
@keyframes hero-slide-fade-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@layer components {
  .logo-marquee {
    --logo-marquee-duration: 60s;
    --logo-marquee-gap: clamp(24px, 6vw, 42px);
    --logo-marquee-shift: -50%;
    position: relative;
    overflow: hidden;
    padding-block: 36px;
  }
  @media (max-width: 640px) {
    .logo-marquee {
      padding-block: 37.5px 7px;
    }
  }
  .logo-marquee::before,
  .logo-marquee::after {
    position: absolute;
    z-index: 1;
    content: "";
    pointer-events: none;
    inset-block: 0;
    inline-size: clamp(24px, 8vw, 120px);
  }
  .logo-marquee::before {
    inset-inline-start: 0;
    background: linear-gradient(to right, var(--color-bg, #fff), transparent);
  }
  .logo-marquee::after {
    inset-inline-end: 0;
    background: linear-gradient(to left, var(--color-bg, #fff), transparent);
  }
  .logo-marquee__viewport {
    position: relative;
    overflow: hidden;
  }
  .logo-marquee__inner {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: max-content;
    animation: logo-marquee-scroll var(--logo-marquee-duration, 60s) linear infinite;
    will-change: transform;
    gap: var(--logo-marquee-gap);
  }
  .logo-marquee__list {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    margin: 0;
    padding: 0;
    gap: var(--logo-marquee-gap);
    list-style: none;
  }
  .logo-marquee__item {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    inline-size: var(--logo-width-pc, auto);
    block-size: var(--logo-height-pc, auto);
  }
  @media (max-width: 640px) {
    .logo-marquee__item {
      inline-size: calc(var(--logo-width-sp, var(--logo-width-pc)) / 1.64);
      block-size: calc(var(--logo-height-sp, var(--logo-height-pc)) / 1.64);
    }
  }
  .logo-marquee__link {
    display: inline-flex;
    align-items: center;
    inline-size: 100%;
    block-size: 100%;
  }
  .logo-marquee__mask {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    background-color: #131313;
    mask-image: var(--logo-mask-image-pc);
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
  }
  @media (max-width: 640px) {
    .logo-marquee__mask {
      mask-image: var(--logo-mask-image-sp, var(--logo-mask-image-pc));
    }
  }
  .logo-marquee:hover .logo-marquee__inner,
  .logo-marquee__viewport:focus-within .logo-marquee__inner {
    animation-play-state: paused;
  }
  @media (prefers-reduced-motion: reduce) {
    .logo-marquee__inner {
      animation: none;
      transform: none;
    }
    .logo-marquee--force-motion .logo-marquee__inner {
      animation: logo-marquee-scroll var(--logo-marquee-duration, 60s) linear infinite;
    }
  }
}
@keyframes logo-marquee-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(var(--logo-marquee-shift, -50%));
  }
}
@layer components {
  .back-to-top {
    position: fixed;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    transition: opacity var(--transition-duration-base) ease, transform var(--transition-duration-base) ease;
    pointer-events: auto;
    inset-block-end: clamp(48px, 10vh, 96px);
    inset-inline-end: clamp(16px, 5vw, 48px);
  }
  .back-to-top.is-hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px);
  }
  .back-to-top__button {
    display: grid;
    place-items: center;
    padding: 0;
    background: transparent;
    border: none;
    text-decoration: none;
    transition: transform var(--transition-duration-base) ease, opacity var(--transition-duration-base) ease;
    cursor: pointer;
    inline-size: auto;
    block-size: auto;
  }
  .back-to-top__button:hover {
    transform: translateY(-2px);
    opacity: 0.8;
  }
  .back-to-top__button:focus-visible {
    outline: none;
    transform: translateY(-2px);
    opacity: 0.8;
  }
  .back-to-top__icon {
    display: block;
    inline-size: clamp(42px, 10vw, 50px);
    block-size: auto;
  }
  @media (max-width: 640px) {
    .back-to-top {
      inset-inline-end: 16px;
      inset-block-end: 32px;
    }
    .back-to-top__button {
      inline-size: auto;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .back-to-top {
      transition: none;
    }
    .back-to-top__button {
      transition: none;
    }
  }
}
@layer layout {
  .site-footer {
    background: var(--color-footer-bg, #ebe9e3);
    color: var(--color-fg);
    font-family: var(--font-ja);
    padding-block: 59px 70px;
  }
  .site-footer__inner {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 36px);
  }
  @media (max-width: 640px) {
    .site-footer__inner {
      gap: clamp(19px, 3vw, 36px);
    }
  }
  .site-footer__top {
    display: flex;
    flex-direction: column;
    container-type: inline-size;
  }
  .site-footer .footer-sections {
    display: flex;
    justify-content: space-between;
    gap: clamp(16px, 2vw, 24px);
  }
  .site-footer .footer-links {
    display: flex;
    flex-direction: column;
    margin-top: 38px;
    gap: clamp(12px, 1.5vw, 16px);
  }
  .site-footer .footer-sns {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: clamp(12px, 2vw, 26px);
    margin-bottom: 24px;
  }
  .site-footer .footer-sns__link {
    display: inline-flex;
    align-items: center;
  }
  .site-footer .footer-sns__link img {
    display: block;
    height: auto;
  }
  .site-footer__rule {
    height: 1px;
    margin: 95px 0 0;
    background: #DBDBDB;
    border: none;
  }
  .site-footer__bottom {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: 17px;
    gap: clamp(28px, 2vw, 40px);
  }
  .site-footer__info {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .site-footer__corp {
    margin: 0;
    opacity: 0.85;
    font-size: 12px;
    line-height: 16.28px;
    letter-spacing: 0.03em;
  }
  .site-footer__copyright {
    margin: 0;
    color: var(--color-muted);
    font-family: var(--font-en);
    font-size: 12px;
    line-height: 14.523px;
    letter-spacing: 0.1em;
  }
  .site-footer__payment-icon {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 7px;
  }
  .footer-columns {
    display: flex;
    gap: clamp(16px, 2vw, 24px);
  }
  .footer-columns > .footer-col:nth-of-type(2) {
    margin-left: 133px;
  }
  .footer-columns > .footer-col:nth-of-type(3) {
    margin-left: 140px;
  }
  .footer-col__title {
    margin: 32px 0 13px;
    font-family: var(--font-en);
    font-size: 23px;
    font-weight: 400;
    line-height: 26.625px;
  }
  .footer-col__trigger {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    background: none;
    border: 0;
    color: inherit;
    font-family: var(--font-en);
    font-size: 22px;
    line-height: inherit;
    letter-spacing: 0.07em;
    text-align: inherit;
    appearance: none;
  }
  .footer-col__trigger:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }
  .footer-col__group + .footer-col__group {
    margin-top: 16px;
  }
  .footer-col__list {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  .footer-col__item a {
    color: inherit;
    font-size: 16px;
    line-height: 35px;
    text-decoration: none;
    transition: color var(--transition-duration-base) ease;
  }
  .footer-col__item a:hover {
    color: var(--color-accent);
    text-decoration: underline;
  }
  .footer-legal__list {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  .footer-legal__item {
    margin: 0;
    padding: 0;
    text-align: right;
  }
  .footer-legal__item a {
    display: block;
    color: inherit;
    font-size: 13px;
    line-height: 30px;
    text-decoration: none;
    transition: color var(--transition-duration-base) ease;
  }
  .footer-legal__item a:hover {
    color: var(--color-accent);
    text-decoration: underline;
  }
  #footer-col-guide {
    margin-top: 42px;
  }
  @media (max-width: 1100px) {
    #footer-col-guide {
      margin-top: 0;
    }
  }
  @media (max-width: 640px) {
    #footer-col-guide {
      margin: 0;
    }
  }
  @media (max-width: 1100px) {
    .site-footer {
      padding-block: 45px;
    }
    .site-footer .footer-sections {
      display: block;
    }
    .footer-columns {
      display: block;
    }
    .footer-col__title {
      margin: 0;
      padding: 20px 10px 20px 0;
      border-top: 1px solid #ddd;
      font-size: 20px;
    }
    .footer-columns > .footer-col:nth-of-type(2),
    .footer-columns > .footer-col:nth-of-type(3) {
      margin-left: 0;
    }
    .has-footer-accordion .footer-col__list {
      overflow: hidden;
      max-height: 0;
      transition: max-height var(--transition-duration-base) ease;
    }
    .has-footer-accordion .footer-col.is-open > .footer-col__list,
    .has-footer-accordion .footer-col__group.is-open > .footer-col__list {
      max-height: none;
      margin-top: -7px;
      padding: 0 0 20px;
    }
    .site-footer__bottom {
      display: flex;
      flex-direction: column;
      align-items: center;
      margin-top: 4px;
      gap: clamp(28px, 2vw, 40px);
    }
    .site-footer__info {
      order: 2;
      gap: 10px;
    }
    .site-footer__payment-icon {
      justify-content: center;
      order: 1;
      margin-left: 0;
      gap: 6px;
    }
    .site-footer__payment-icon img {
      width: 49px;
    }
    .footer-legal__list {
      flex-flow: row wrap;
      justify-content: center;
      padding-bottom: 1px;
    }
    .footer-legal__item a {
      display: inline;
      font-size: 12px;
    }
    .footer-legal__item {
      margin-right: 16px;
      text-align: left;
    }
    .site-footer .footer-sns {
      justify-content: center;
      margin: 19px 0;
      gap: 28px;
    }
    .footer-col__trigger {
      position: relative;
      padding-right: 30px;
      font-size: 19px;
    }
    .has-footer-accordion .footer-col__trigger::after {
      position: absolute;
      top: 50%;
      right: 5px;
      width: 15px;
      height: 20px;
      margin-top: -9px;
      background-image: url("../img/common/arrow-down.svg");
      background-position: center;
      background-size: 20px 20px;
      background-repeat: no-repeat;
      transition: transform var(--transition-duration-base) ease;
      content: "";
      transform: rotate(0deg);
      transform-origin: center;
    }
    .has-footer-accordion #footer-col-about .footer-col__trigger::after {
      width: 10px;
      height: 14px;
      margin-top: -7px;
      margin-right: 3px;
      background-image: url("../img/common/icon-arrow-right.svg");
      background-size: 10px 17px;
    }
    .has-footer-accordion .footer-col.is-open .footer-col__trigger::after,
    .has-footer-accordion .footer-col__group.is-open .footer-col__trigger::after {
      transform: rotate(180deg);
    }
    .footer-col__group + .footer-col__group {
      margin: 0;
    }
    .site-footer__corp {
      margin-bottom: 6px;
      font-size: 11px;
      line-height: 1.9;
      text-align: center;
    }
    .site-footer__copyright {
      font-size: 10px;
      letter-spacing: 0.04em;
      text-align: center;
    }
  }
  @media (max-width: 1100px) and (max-width: 640px) {
    .site-footer__copyright {
      font-size: 9.25px;
    }
  }
  @media (max-width: 1100px) {
    .site-footer__rule {
      display: none;
    }
    .site-footer .footer-links {
      margin-top: 40px;
    }
    .footer-col__item a {
      margin-left: 2px;
      font-size: 12px;
    }
  }
}
@layer components {
  .section {
    padding-block: clamp(48px, 7vw, 118px);
  }
  .section__header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: clamp(16px, 3vw, 32px);
    font-family: var(--font-ja-serif);
    gap: clamp(12px, 2vw, 20px);
  }
  @media (max-width: 640px) {
    .section__header {
      display: block;
    }
  }
  .section__title {
    margin: 0;
    font-size: clamp(24px, 2.4vw, 40px);
    letter-spacing: 0.05em;
  }
  .section__title.display {
    letter-spacing: 2px;
  }
  .section__more {
    margin: 10px 0 0;
  }
  @media (max-width: 640px) {
    .section__more {
      margin: 11px 0 21px;
      font-size: 12px;
    }
  }
  .section--sale {
    padding-block: clamp(64px, 7vw, 99px);
  }
  .section--newin {
    padding-block-end: clamp(46px, 7vw, 98px);
  }
  .section.related-products {
    padding-block: clamp(28px, 7vw, 45px) clamp(46px, 7vw, 98px);
  }
  @media (max-width: 640px) {
    .section.related-products {
      padding-block: clamp(25px, 3vw, 54px) clamp(46px, 7vw, 98px);
    }
  }
  .section.related-products .section__title {
    font-size: clamp(18px, 2.4vw, 26px);
    font-weight: 600;
    letter-spacing: 0.06em;
  }
  .section--about {
    padding-block-end: clamp(81px, 7vw, 97px);
  }
  .section--gender-tiles {
    padding-block-end: clamp(82px, 7vw, 113px);
  }
  .section--info-cards {
    padding-block-end: clamp(63px, 7vw, 97px);
  }
  .section--service {
    padding-block-end: clamp(18px, 3vw, 39px);
  }
  .section--service .section__header {
    margin-bottom: clamp(21px, 3vw, 28px);
  }
  .section--membership {
    padding-block-end: clamp(73px, 7vw, 128px);
  }
  .section--years {
    padding-bottom: 190px;
  }
  @media (max-width: 640px) {
    .section--years {
      padding-bottom: 112px;
    }
  }
  .section--mens-ranking {
    padding-block-end: clamp(54px, 7vw, 95px);
  }
  .section--mens-ranking .section__title {
    word-spacing: 0.3em;
  }
  .section--mens-ranking .section__header {
    margin-bottom: clamp(16px, 3vw, 25px);
  }
  .section--mens-ranking .cards {
    counter-reset: mens-ranking;
  }
  .section--mens-ranking .cards > .card {
    position: relative;
  }
  .section--mens-ranking .cards > .card.card--placeholder::before {
    content: none;
  }
  .section--mens-ranking .cards > .card::before {
    position: absolute;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: #155bb7;
    font-family: var(--font-en, Inter, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
    font-size: 24px;
    letter-spacing: 0.04em;
    content: counter(mens-ranking);
    counter-increment: mens-ranking;
    inset: 0 auto auto 0;
    inline-size: 55px;
    block-size: 55px;
  }
  @media (max-width: 640px) {
    .section--mens-ranking .cards > .card::before {
      inline-size: 40px;
      block-size: 40px;
      font-size: 18px;
    }
  }
  @media (max-width: 640px) {
    .section--mens-ranking {
      padding-block-end: clamp(42px, 7vw, 95px);
    }
  }
  .section--womens-ranking {
    padding-block-end: clamp(52px, 7vw, 99px);
  }
  .section--womens-ranking .section__title {
    word-spacing: 0.3em;
  }
  .section--womens-ranking .section__header {
    margin-bottom: clamp(16px, 3vw, 24px);
  }
  .section--womens-ranking .cards {
    counter-reset: womens-ranking;
  }
  .section--womens-ranking .cards > .card {
    position: relative;
  }
  .section--womens-ranking .cards > .card.card--placeholder::before {
    content: none;
  }
  .section--womens-ranking .cards > .card::before {
    position: absolute;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: #c00c60;
    font-family: var(--font-en, Inter, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
    font-size: 24px;
    letter-spacing: 0.04em;
    content: counter(womens-ranking);
    counter-increment: womens-ranking;
    inset: 0 auto auto 0;
    inline-size: 55px;
    block-size: 55px;
  }
  @media (max-width: 640px) {
    .section--womens-ranking .cards > .card::before {
      inline-size: 40px;
      block-size: 40px;
      font-size: 18px;
    }
  }
  .section + .section {
    padding-top: 0;
  }
  .link-more {
    display: inline-flex;
    align-items: center;
    color: var(--color-accent);
    font-family: var(--font-ja-serif);
    font-size: 17px;
    text-decoration: underline;
    gap: 7px;
  }
  @media (max-width: 640px) {
    .link-more {
      font-size: 13px;
    }
  }
  .link-more::after {
    display: inline-block;
    width: 12px;
    height: 17px;
    background: url("../img/top/link-more-arrow.svg") no-repeat center/contain;
    content: "";
  }
  @media (max-width: 640px) {
    .link-more::after {
      width: 6px;
      margin: 2px 0 0;
    }
  }
}
@layer components {
  .ph {
    background: #eee;
  }
  .ph--square {
    aspect-ratio: 1/1;
  }
  .ph--tall {
    aspect-ratio: 3/4;
  }
  @media (max-width: 640px) {
    .ph--tall {
      aspect-ratio: 350/145;
    }
  }
  /* .ph--banner {
    aspect-ratio: 26 / 9;
  } */
  .ph--about {
    aspect-ratio: 650/513;
  }
  @media (max-width: 640px) {
    .ph--about {
      aspect-ratio: 350/272;
    }
  }
}
@layer components {
  .breadcrumb {
    padding: 20px 0 0;
    background-color: #fff;
    border-block-start: 1px solid #ececec;
  }
  @media (max-width: 640px) {
    .breadcrumb {
      margin: 2px 0 0 -6px;
      padding: 7px 0 9px;
      border-block-end: 1px solid #ececec;
    }
  }
  .breadcrumb__list {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;
    color: #747474;
    font-family: var(--font-ja, "Noto Sans JP", sans-serif);
    font-size: 11px;
    letter-spacing: 0.22px;
    gap: 13px;
    list-style: none;
  }
  @media (max-width: 640px) {
    .breadcrumb__list {
      font-size: 10px;
      gap: 7px;
    }
  }
  .breadcrumb__item {
    display: flex;
    align-items: center;
    color: #747474;
    font-weight: 400;
    line-height: 1.5;
  }
  .breadcrumb__item:not(:last-child)::after {
    display: inline-block;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='5' height='10' viewBox='0 0 5 10' fill='none'%3E%3Cpath d='M0.311705 5.36347e-08C0.232631 5.45393e-08 0.15171 0.033567 0.0910258 0.0987265C-0.0303421 0.229045 -0.0303421 0.442294 0.0910258 0.572613L4.24513 5.03307L0.15171 9.42837C0.0303417 9.55869 0.0303417 9.77194 0.15171 9.90226C0.273078 10.0326 0.471681 10.0326 0.593049 9.90226L4.90897 5.27002C5.03034 5.1397 5.03034 4.92645 4.90897 4.79613L0.534204 0.0987265C0.471681 0.0315925 0.392617 5.27091e-08 0.311705 5.36347e-08Z' fill='%23747474'/%3E%3C/svg%3E") no-repeat center/100% 100%;
    content: "";
    margin-inline-start: 14px;
    inline-size: 5px;
    block-size: 10px;
  }
  @media (max-width: 640px) {
    .breadcrumb__item:not(:last-child)::after {
      margin-inline-start: 7px;
      block-size: 7px;
    }
  }
  .breadcrumb__item a {
    color: inherit;
    text-decoration: underline;
    text-decoration-skip-ink: none;
    text-underline-position: from-font;
    transition: opacity var(--transition-duration-base) ease;
  }
  .breadcrumb__item a:hover {
    opacity: 0.7;
  }
  .breadcrumb__item span {
    color: inherit;
  }
}
@layer components {
  .cards {
    display: grid;
    gap: clamp(14px, 2.2vw, 22px);
  }
  .cards--grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  @media (width >= 900px) {
    .cards--grid-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  @media (max-width: 640px) {
    .cards--overlay {
      gap: 20px;
    }
  }
  .cards--overlay .card {
    position: relative;
  }
  .cards--overlay .card__overlay {
    position: absolute;
    padding: 23px 22px 30px 18px;
    color: #fff;
    inset: auto 0 0;
  }
  @media (max-width: 640px) {
    .cards--overlay .card__overlay {
      inset: 24px 0 0;
      padding: 22px 22px 30px 24px;
    }
  }
  .card {
    display: flex;
    flex-direction: column;
    gap: 19px;
  }
  .card__link {
    display: inherit;
    flex: 1 1 auto;
    flex-direction: inherit;
    gap: inherit;
    inline-size: 100%;
    block-size: 100%;
    color: inherit;
    text-decoration: none;
  }
  @media (max-width: 640px) {
    .card__link {
      gap: 10px;
    }
  }
  .card__link > div:last-child {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-block-size: 0;
  }
  .card__link--overlay {
    display: block;
  }
  .card__link:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 4px;
  }
  .card__link:is(:hover, :focus-visible) .card__media {
    opacity: 0.7;
  }
  .card__link:is(:hover, :focus-visible) {
    text-decoration: none;
  }
  .card__media {
    position: relative;
    overflow: hidden;
    transition: opacity var(--transition-duration-base) ease;
  }
  .card__media img {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
  .card__title {
    margin: 0;
    font-family: var(--font-ja-serif);
    font-size: 20px;
    font-weight: 500;
    line-height: 1.5;
  }
  @media (max-width: 640px) {
    .card__title {
      font-size: 13px;
      font-weight: 600;
      letter-spacing: 0.05em;
    }
  }
  .card__price {
    margin: 0;
    margin-top: auto;
    padding-top: 1px;
  }
  @media (max-width: 640px) {
    .card__price .price-currency {
      font-size: 12px;
    }
  }
  .card__price--old, .card__price--new, .card__price--soldout {
    font-size: 22px;
    font-weight: 600;
  }
  @media (max-width: 640px) {
    .card__price--old, .card__price--new, .card__price--soldout {
      font-size: 16px;
      font-weight: 600;
      letter-spacing: 0.05em;
    }
  }
  @media (max-width: 640px) {
    .card__price {
      margin-bottom: 14px;
      padding-top: 0;
      line-height: 1;
    }
  }
  .card__price--old {
    margin-right: 20px;
    color: var(--color-accent);
    font-family: var(--font-price);
  }
  @media (max-width: 640px) {
    .card__price--old {
      margin-right: 6px;
    }
  }
  .card__price--old .price-value {
    text-decoration: line-through;
  }
  .card__price--new {
    color: var(--color-accent);
    font-family: var(--font-price);
  }
  .card__price--old + .card__price--new {
    color: #b00101;
  }
  .card__price--soldout {
    color: #b00101;
    font-family: var(--font-ja-serif);
  }
  .card__kicker {
    display: flex;
    align-items: center;
    margin: 0 0 4px;
    font-family: var(--font-display);
    font-size: 32px;
    letter-spacing: 0.05em;
    gap: 9px;
  }
  @media (max-width: 640px) {
    .card__kicker {
      margin: 0 0 6px;
      font-size: 24px;
      gap: 8px;
      letter-spacing: 0.04em;
    }
  }
  .card__kicker::after {
    flex: 0 0 auto;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='39' viewBox='0 0 24 39'%3E%3Cpath d='M1 0L20.5 19.5 1 39' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
    background-size: 100% 100%;
    content: "";
    inline-size: 13px;
    block-size: 22px;
  }
  @media (max-width: 640px) {
    .card__kicker::after {
      inline-size: 10px;
      block-size: 23px;
      margin: 5px 0 0 2.5px;
    }
  }
  .card__caption {
    margin: 0;
    font-family: var(--font-ja-serif);
    font-size: 14px;
    letter-spacing: 0.05em;
  }
  @media (max-width: 640px) {
    .card__caption {
      font-size: 10.5px;
      font-weight: 300;
    }
  }
  .card .card__link:is(:hover, :focus-visible) {
    text-decoration: none !important;
  }
  .card--soldout .card__media {
    background: var(--color-fg);
  }
  .card--soldout .card__media img {
    opacity: 0.7;
  }
  .badge {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-en);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.24px;
    text-transform: uppercase;
    pointer-events: none;
    inset: 12px auto auto 12px;
    inline-size: 80px;
    block-size: 30px;
  }
  @media (max-width: 640px) {
    .badge {
      inset: 6px auto auto 6px;
      font-size: 10px;
      inline-size: 64px;
      block-size: 21px;
    }
  }
  .badge--sale {
    background-color: #fff;
    color: #b00101;
    font-weight: 500;
  }
  .badge--newin {
    background-color: #014326;
    color: #fff;
  }
  .badge--soldout {
    background-color: #b00101;
    color: #fff;
  }
  .section--sale .card__price--new {
    color: #b00101;
  }
  .section--mens-ranking .badge--soldout, .section--womens-ranking .badge--soldout {
    right: 12px;
    left: auto;
  }
  @media (max-width: 640px) {
    .section--mens-ranking .badge--soldout, .section--womens-ranking .badge--soldout {
      right: 6px;
    }
  }
  .section--info-cards .cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  @media (width >= 900px) {
    .section--info-cards .cards {
      grid-template-columns: repeat(4, 1fr);
    }
  }
  @media (max-width: 640px) {
    .section--info-cards .cards {
      grid-template-columns: 1fr;
    }
  }
}
@layer components {
  .tiles {
    display: grid;
    gap: 20px;
  }
  @media (max-width: 640px) {
    .tiles {
      gap: 21px;
    }
  }
  .tiles--2 {
    grid-template-columns: 1fr;
  }
  @media (min-width: 641px) {
    .tiles--2 {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  .tile {
    position: relative;
    display: block;
    color: inherit;
  }
  .tile__overlay {
    position: absolute;
    inset: 0;
    display: flex;
  }
  .tile__caption {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: #fff;
    font-size: clamp(24px, 4vw, 40px);
    letter-spacing: 0.125rem;
    padding-inline-start: clamp(20px, 4vw, 32.5px);
    padding-block-end: 5px;
  }
  .tile .section__more {
    position: absolute;
    right: 25px;
    bottom: 23px;
    display: inline-flex;
    align-items: center;
    margin: 0;
    color: #fff;
    font-family: var(--font-ja-serif);
    font-size: 15.5px;
    letter-spacing: 0.05em;
    text-decoration: underline;
    gap: 0.2em;
  }
  .tile .section__more::after {
    display: block;
    margin: 3px 0 0;
    border-top: 1.5px solid #fff;
    border-right: 1.5px solid #fff;
    content: "";
    transform: rotate(45deg);
    inline-size: 12px;
    block-size: 12px;
  }
  @media (max-width: 640px) {
    .tile .section__more::after {
      margin: 0;
    }
  }
  @media (max-width: 640px) {
    .tile__overlay {
      flex-direction: column;
      align-items: flex-start;
      justify-content: center;
      text-align: center;
      padding-inline-start: 24px;
    }
    .tile__caption {
      justify-content: center;
      padding-inline-start: 0;
      text-align: center;
    }
    .tile .section__more {
      position: static;
      margin: 0;
      font-size: 11px;
      letter-spacing: 0.1em;
    }
    .tile .section__more::after {
      inline-size: 10px;
      block-size: 10px;
    }
  }
}
@layer components {
  .about__title {
    margin: 8px 0 9px;
    font-family: var(--font-ja-serif);
    font-size: clamp(19px, 2.2vw, 29px);
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.08em;
  }
  @media (max-width: 640px) {
    .about__title {
      margin: 0 0 7px;
    }
  }
  .about__eyebrow {
    margin: 32px 0 16px;
    font-size: 24px;
    letter-spacing: 2.4px;
  }
  @media (max-width: 640px) {
    .about__eyebrow {
      margin: 33.5px 0 12px;
      font-size: 12.5px;
      letter-spacing: 1.6px;
    }
  }
  .about__sub {
    margin: 0 0 30px;
    color: var(--color-accent);
    font-size: 17px;
    letter-spacing: 0.05em;
  }
  @media (max-width: 640px) {
    .about__sub {
      margin: 0 0 12px;
      font-size: 11px;
      letter-spacing: 0.09em;
    }
  }
  .about__actions {
    margin-top: 12px;
  }
  .btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 4px;
    background: #fff;
    border: 1px solid var(--color-accent);
    color: var(--color-accent);
    font-family: var(--font-ja-serif);
    font-size: 14px;
    font-weight: 700;
    inline-size: 184px;
    block-size: 51px;
    text-decoration: none;
  }
  @media (max-width: 640px) {
    .btn-outline {
      padding-bottom: 0;
      font-size: 13px;
      inline-size: 176px;
      font-weight: 600;
    }
  }
  .section--about .about__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: var(--color-footer-bg, #ebe9e3);
  }
  @media (width <= 1000px) {
    .section--about .about__body {
      padding-bottom: 20px;
    }
  }
  @media (width >= 1000px) {
    .section--about .about__body {
      flex-direction: row;
      align-items: stretch;
      align-self: start;
      min-block-size: 513px;
    }
    .section--about .about__body > * {
      flex: 1 1 0;
    }
  }
  .section--about .about__media {
    display: flex;
    overflow: hidden;
  }
  @media (width >= 1000px) {
    .section--about .about__media {
      aspect-ratio: auto;
    }
  }
  .section--about .about__media img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
  .about__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
  .section--about .about__actions .btn-outline {
    block-size: 60px;
  }
  @media (max-width: 640px) {
    .section--about .about__actions .btn-outline {
      block-size: 42px;
      padding: 0 0 3px;
      letter-spacing: 0.05em;
    }
  }
}
@layer components {
  .features {
    display: grid;
    gap: 6px 20px;
    grid-template-columns: 1fr 1fr;
    list-style: none;
    padding: 0;
    counter-reset: feature;
  }
  @media (width >= 900px) {
    .features {
      grid-template-columns: repeat(4, 1fr);
    }
  }
  @media (max-width: 640px) {
    .features {
      display: block;
    }
  }
  .feature {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin: 0 0 16px;
    padding: 25px 0 0;
    border-top: 1px solid #d9d9d9;
    letter-spacing: 0.06em;
    counter-increment: feature;
  }
  .feature::before {
    display: block;
    margin-bottom: 19px;
    color: var(--color-accent);
    font-family: var(--font-en);
    font-size: 13px;
    letter-spacing: 0.05em;
    content: counter(feature, decimal-leading-zero);
  }
  @media (max-width: 640px) {
    .feature {
      flex-direction: row;
      margin: 0 0 21px;
      padding: 29px 0 0 15.5px;
    }
    .feature::before {
      margin-top: 2px;
      font-size: 12px;
      letter-spacing: 0.01em;
    }
  }
  .feature__title {
    margin: 0 0 18px;
    font-family: var(--font-ja-serif);
    font-size: 23px;
  }
  @media (max-width: 640px) {
    .feature__title {
      margin: 0 0 16px;
      font-size: 21px;
      font-weight: 700;
      line-height: 1;
      letter-spacing: 0.1em;
    }
  }
  .feature__desc {
    margin: 0;
    color: var(--color-fg);
    font-family: var(--font-ja-serif);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.9;
  }
  .feature__desc > span {
    display: inline;
  }
  @media (width > 1250px) {
    .feature__desc > span {
      display: block;
    }
  }
  @media (max-width: 640px) {
    .feature__desc {
      font-size: 13px;
    }
  }
  @media (max-width: 640px) {
    .feature__content {
      flex-direction: column;
      padding: 0 0 0 20px;
    }
  }
}
@layer components {
  .section--membership {
    position: relative;
  }
  .membership {
    position: relative;
    display: block;
    overflow: hidden;
  }
  .membership img {
    display: block;
    inline-size: 100%;
    block-size: auto;
  }
  .membership__body {
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    inset-inline: 20px;
    padding: 94px 62px 64px;
    color: #fff;
    inset-block-start: 50%;
    gap: 10px;
    transform: translateY(-50%);
  }
  @media (max-width: 640px) {
    .membership__body {
      margin-top: 11px;
      padding: 0;
      inset-inline: 22px;
      inset-block-start: 50%;
      gap: 5px;
      transform: translateY(-50%);
    }
  }
  .membership__body > p.link-more--inverse {
    margin-top: 50px;
    color: #fff;
    font-family: var(--font-ja-serif);
    text-decoration: underline;
  }
  @media (min-width: 640px) and (max-width: 800px) {
    .membership__body > p.link-more--inverse {
      margin-top: 0;
    }
  }
  @media (max-width: 640px) {
    .membership__body > p.link-more--inverse {
      display: inline-flex;
      align-items: center;
      margin: 0;
      color: #fff;
      font-family: var(--font-ja-serif);
      font-size: 11px;
      letter-spacing: 0.05em;
      text-decoration: underline;
      gap: 0.2em;
    }
    .membership__body > p.link-more--inverse::after {
      display: block;
      border-top: 1.5px solid #fff;
      border-right: 1.5px solid #fff;
      content: "";
      transform: rotate(45deg);
      inline-size: 10px;
      block-size: 10px;
    }
  }
  .membership__eyebrow {
    margin: 0;
    font-size: 17px;
    letter-spacing: 1.36px;
  }
  @media (max-width: 640px) {
    .membership__eyebrow {
      font-size: 12px;
    }
  }
  .membership__title {
    margin: 0;
    font-family: var(--font-ja-serif);
    font-size: clamp(28px, 3vw, 36px);
    font-weight: 400;
    letter-spacing: 0.05em;
  }
  .membership__desc {
    margin: 0;
    font-family: var(--font-ja-serif);
    font-size: 15px;
    letter-spacing: 0.04em;
  }
  @media (max-width: 640px) {
    .membership__desc {
      margin: 5px 0 29px;
      font-size: 12px;
      line-height: 1.8;
    }
  }
}
@layer components {
  .section--years .section__title {
    font-size: clamp(18px, 2.4vw, 26px);
    font-weight: 600;
    letter-spacing: 0.06em;
  }
  @media (max-width: 640px) {
    .section--years .section__title {
      font-weight: 600;
    }
  }
  .section--years .section__header {
    margin-bottom: clamp(21px, 3vw, 24px);
  }
  @media (max-width: 640px) {
    .section--years .section__header {
      margin-bottom: clamp(23px, 3vw, 24px);
    }
  }
  .years {
    display: grid;
    overflow: hidden;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    background: #fff;
    gap: 0;
  }
  @media (width >= 560px) {
    .years {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  @media (width >= 1220px) {
    .years {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }
  .year {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-block-start: 0;
    border-inline-start: 0;
    border-block-end: 1px solid #c7c7c7;
    border-inline-end: 1px solid #c7c7c7;
  }
  .year::after {
    position: absolute;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='39' viewBox='0 0 24 39'%3E%3Cpath d='M1 0L20.5 19.5 1 39' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
    background-size: 100% 100%;
    content: "";
    pointer-events: none;
    inset-inline-end: clamp(16px, 2.5vw, 26px);
    inset-block-start: 50%;
    transform: translateY(-50%);
    inline-size: 15px;
    block-size: 24px;
  }
  @media (max-width: 640px) {
    .year::after {
      inline-size: 16px;
      block-size: 14px;
      inset-inline-end: clamp(12px, 2.5vw, 26px);
    }
  }
  .year:hover::after {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='39' viewBox='0 0 24 39'%3E%3Cpath d='M1 0L20.5 19.5 1 39' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
    background-size: 100% 100%;
  }
  .year:nth-child(-n+2) {
    border-block-start: 1px solid #c7c7c7;
  }
  .year:nth-child(2n+1) {
    border-inline-start: 1px solid #c7c7c7;
  }
  .year__title {
    margin: 0;
    font-size: clamp(26px, 3.2vw, 36px);
    font-style: normal;
    letter-spacing: 2.15px;
  }
  .year__desc {
    margin: 0;
    color: var(--color-fg);
    font-family: var(--font-ja-serif);
    font-size: 14px;
    font-weight: 600;
    transition: color var(--transition-duration-base) ease;
  }
  @media (max-width: 640px) {
    .year__desc {
      margin-top: 2px;
      font-size: 13px;
      font-weight: 500;
    }
  }
  .year__link {
    display: flex;
    flex-direction: column;
    justify-content: center;
    block-size: 100%;
    min-block-size: 108px;
    padding: 24px 36px 18px 14px;
    text-decoration: none;
    transition: background-color var(--transition-duration-base) ease, color var(--transition-duration-base) ease;
  }
  @media (max-width: 640px) {
    .year__link {
      min-block-size: 100px;
      padding: 5px 36px 0 18px;
    }
  }
  .year__link:hover {
    background: var(--color-notice-bg);
    color: #fff;
  }
  .year__link:hover .year__desc {
    color: #fff;
  }
  @media (width >= 560px) {
    .year:nth-child(n) {
      border-block-start: 0;
      border-inline-start: 0;
    }
    .year:nth-child(-n+3) {
      border-block-start: 1px solid #c7c7c7;
    }
    .year:nth-child(3n+1) {
      border-inline-start: 1px solid #c7c7c7;
    }
    .year__link {
      min-block-size: 116px;
      padding: 28px 40px 20px 16px;
    }
  }
  @media (width >= 1220px) {
    .year:nth-child(n) {
      border-block-start: 0;
      border-inline-start: 0;
    }
    .year:nth-child(-n+5) {
      border-block-start: 1px solid #c7c7c7;
    }
    .year:nth-child(5n+1) {
      border-inline-start: 1px solid #c7c7c7;
    }
    .year__link {
      min-block-size: 0;
      padding: 32px clamp(44px, 6vw, 64px) clamp(20px, 3vw, 32px) clamp(16px, 3vw, 32px);
    }
  }
}
@layer utilities {
  .sr-only,
  .visually-hidden {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    clip-path: inset(50%);
    overflow: hidden;
    white-space: nowrap;
  }
  /* フォーカス時に表示（キーボードナビゲーション対応） */
  .visually-hidden:focus,
  .sr-only:focus {
    position: static;
    inline-size: auto;
    block-size: auto;
    clip-path: none;
    overflow: visible;
    white-space: normal;
  }
}
@layer utilities {
  .heading-serif {
    font-family: var(--font-display);
    font-weight: 500;
  }
  .text-red {
    color: var(--color-red);
  }
  .phrase > span {
    display: inline;
  }
  @media (max-width: 1100px) {
    .phrase > span {
      display: block;
    }
  }
  .phrase__pc > span {
    display: block;
  }
  @media (max-width: 640px) {
    .phrase__sp > span {
      display: block;
    }
    .phrase__pc > span {
      display: inline;
    }
  }
}
@layer reset, base, layout, components, utilities;

/*# sourceMappingURL=index.css.map */
