/* ==========================================================================
   components.css — 再利用可能な UI コンポーネント
   ----------------------------------------------------------------------------
   KV / セクション / カード / ボタン / フォーム要素 などを命名規則 BEM 風で定義。
   このファイルは肥大化しやすいため、3-2-3 以降フェーズごとに追記する。
   ========================================================================== */


/* ==========================================================================
   Header / Drawer — 3-2-4
   ========================================================================== */

.header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: var(--z-header);
  background-color: rgba(244, 246, 245, 0);
  transition: background-color var(--duration-base) var(--ease-base),
              backdrop-filter var(--duration-base) var(--ease-base),
              box-shadow var(--duration-base) var(--ease-base);
}

/* スクロール後 / 下層ページではこのクラスが付与される */
.header.is-scrolled,
.header.is-solid {
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-sm);
}

/* ドロワー展開時はヘッダー(=ハンバーガー/×)をドロワーより前面に */
body.is-drawer-open .header {
  z-index: calc(var(--z-overlay) + 1);
  background-color: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  block-size: 60px;
  gap: var(--sp-4);
}

@media (min-width: 1024px) {
  .header__inner {
    block-size: 80px;
  }
}

/* ロゴ */
.header__logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: inherit;
}

.header__logo img {
  block-size: 32px;
  inline-size: auto;
}

@media (min-width: 1024px) {
  .header__logo img {
    block-size: 40px;
  }
}

/* ナビ(PC) */
.header__nav {
  display: none;
  align-items: center;
  gap: var(--sp-8);
}

@media (min-width: 1024px) {
  .header__nav {
    display: flex;
  }
}

.header__menu {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
  margin: 0;
  padding: 0;
  list-style: none;
  line-height: 1;
}

.header__menu li {
  display: flex;
  align-items: center;
  line-height: 1;
  height: 100%;
  margin: 0;
  padding: 0;
}

/* base.css の `li + li { margin-block-start }` を打ち消す */
.header__menu li + li {
  margin-block-start: 0;
}

.header__menu a {
  font-family: var(--font-serif-en);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  font-style: normal;
  letter-spacing: var(--ls-wider);
  color: var(--color-text-invert);
  text-decoration: none;
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding-block: var(--sp-1);
  line-height: 1;
  white-space: nowrap;
  /* body 側の日本語向け設定をリセット(英字表示を安定させる) */
  font-feature-settings: normal;
  font-variant-numeric: normal;
  word-break: normal;
  overflow-wrap: normal;
  line-break: auto;
  text-rendering: geometricPrecision;
  transition: color var(--duration-base) var(--ease-base);
}

/* スクロール後 / 下層では文字色を反転 */
.header.is-scrolled .header__menu a,
.header.is-solid .header__menu a,
.header.is-scrolled .header__logo,
.header.is-solid .header__logo {
  color: var(--color-text);
}

.header__menu a::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  block-size: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--duration-base) var(--ease-base);
}

.header__menu a:hover::after,
.header__menu a:focus-visible::after {
  transform: scaleX(1);
}

/* CTA ボタン */
.header__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2) var(--sp-5);
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
  font-family: var(--font-sans-jp);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background-color var(--duration-base) var(--ease-base),
              transform var(--duration-base) var(--ease-base);
}

.header__cta:hover,
.header__cta:focus-visible {
  background-color: var(--color-text);
  color: var(--color-text-invert);
  transform: translateY(-1px);
}

/* ハンバーガー */
.header__burger {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  inline-size: 44px;
  block-size: 44px;
  background: transparent;
  border: 0;
  cursor: pointer;
  /* ドロワー展開時もボタンが押せるようドロワーより上に */
  position: relative;
  z-index: calc(var(--z-overlay) + 1);
}

@media (min-width: 1024px) {
  .header__burger {
    display: none;
  }
}

.header__burger span {
  display: block;
  inline-size: 22px;
  block-size: 1.5px;
  background-color: var(--color-text-invert);
  transition: transform var(--duration-base) var(--ease-base),
              opacity var(--duration-base) var(--ease-base),
              background-color var(--duration-base) var(--ease-base);
}

.header.is-scrolled .header__burger span,
.header.is-solid .header__burger span {
  background-color: var(--color-text);
}

/* ドロワー展開時 → ✕ */
.header__burger[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
.header__burger[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}
.header__burger[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-7.5px) rotate(-45deg);
}

.header__burger[aria-expanded="true"] span {
  background-color: var(--color-text);
}

/* --------------------------------------------------------------------------
   Drawer(モバイル用ドロワー)
   -------------------------------------------------------------------------- */
.drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background-color: var(--color-bg);
  background-image:
    radial-gradient(circle at 100% 0%, rgba(122, 154, 151, 0.10) 0%, transparent 45%),
    radial-gradient(circle at 0% 100%, rgba(200, 212, 210, 0.18) 0%, transparent 50%);
  display: flex;
  flex-direction: column;
  padding-block-start: 60px;
  transform: translateX(100%);
  transition: transform var(--duration-base) var(--ease-base);
  visibility: hidden;
  overflow: hidden;
}

.drawer.is-open {
  transform: translateX(0);
  visibility: visible;
}

/* 装飾 — 右上の連続線デイジー(ウォーターマーク) */
.drawer__deco {
  position: absolute;
  pointer-events: none;
  color: var(--color-primary);
}

.drawer__deco--top {
  inline-size: clamp(160px, 42vw, 220px);
  block-size: auto;
  inset-block-start: -40px;
  inset-inline-end: -40px;
  opacity: 0.18;
  transform: rotate(12deg);
}

.drawer__deco--bottom {
  position: static;
  inline-size: clamp(90px, 22vw, 120px);
  block-size: auto;
  margin-inline: auto;
  margin-block-start: var(--sp-4);
  opacity: 0.45;
  color: var(--color-primary-deep);
}

.drawer__inner {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: var(--sp-6) var(--section-pad-x) var(--sp-8);
  overflow-y: auto;
}

/* ブランドヘッダー */
.drawer__brand {
  text-align: center;
  margin-block-end: var(--sp-8);
  color: var(--color-primary-deep);
}

.drawer__brand-en {
  margin: 0;
  font-family: var(--font-serif-en);
  font-size: clamp(2rem, 7vw, 2.6rem);
  font-weight: var(--fw-light);
  letter-spacing: var(--ls-wider);
  font-style: italic;
  line-height: 1;
}

.drawer__brand-jp {
  margin: var(--sp-2) 0 0;
  font-family: var(--font-serif-jp);
  font-size: var(--fs-sm);
  letter-spacing: var(--ls-wider);
  color: var(--color-text-sub);
}

.drawer__sprig {
  display: block;
  inline-size: clamp(120px, 36vw, 160px);
  block-size: auto;
  margin: var(--sp-4) auto 0;
  color: var(--color-primary);
  opacity: 0.7;
}

/* メニュー */
.drawer__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.drawer__menu li {
  position: relative;
}

.drawer__menu li + li {
  border-block-start: 1px solid var(--color-line);
}

.drawer__menu a {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  padding-block: var(--sp-4);
  padding-inline: var(--sp-2);
  color: var(--color-text);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-base),
              padding-inline-start var(--duration-base) var(--ease-base);
}

.drawer__menu a::before {
  content: "";
  inline-size: 6px;
  block-size: 6px;
  border: 1px solid var(--color-primary);
  border-radius: 50%;
  background-color: transparent;
  transition: background-color var(--duration-fast) var(--ease-base),
              transform var(--duration-fast) var(--ease-base);
  flex-shrink: 0;
  align-self: center;
}

.drawer__menu-en {
  font-family: var(--font-serif-en);
  font-size: var(--fs-lg);
  font-style: italic;
  font-weight: var(--fw-light);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary-deep);
  min-inline-size: 5em;
}

.drawer__menu-jp {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-sm);
  letter-spacing: var(--ls-wide);
  color: var(--color-text-sub);
}

.drawer__menu a[aria-current="page"] .drawer__menu-en,
.drawer__menu a[aria-current="page"] .drawer__menu-jp {
  color: var(--color-primary-deep);
}

.drawer__menu a[aria-current="page"]::before {
  background-color: var(--color-primary);
}

.drawer__menu a:hover,
.drawer__menu a:focus-visible {
  color: var(--color-primary-deep);
  padding-inline-start: var(--sp-3);
}

.drawer__menu a:hover::before,
.drawer__menu a:focus-visible::before {
  background-color: var(--color-primary);
  transform: scale(1.1);
}

.drawer__menu a:hover .drawer__menu-en,
.drawer__menu a:focus-visible .drawer__menu-en,
.drawer__menu a:hover .drawer__menu-jp,
.drawer__menu a:focus-visible .drawer__menu-jp {
  color: var(--color-primary-deep);
}

/* CTA */
.drawer__cta {
  margin-block-start: var(--sp-8);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4) var(--sp-6);
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
  font-family: var(--font-sans-jp);
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  border-radius: var(--radius-full);
  text-decoration: none;
  letter-spacing: var(--ls-wide);
  box-shadow: var(--shadow-md);
}

/* フッター部 */
.drawer__foot {
  margin-block-start: auto;
  padding-block-start: var(--sp-8);
  text-align: center;
}

.drawer__ig {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--color-text-sub);
  font-family: var(--font-sans-en);
  font-size: var(--fs-sm);
  letter-spacing: var(--ls-wide);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-base);
}

.drawer__ig svg {
  inline-size: 18px;
  block-size: 18px;
}

.drawer__ig:hover,
.drawer__ig:focus-visible {
  color: var(--color-primary-deep);
}

.drawer__addr {
  margin: var(--sp-2) 0 0;
  font-family: var(--font-serif-jp);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  color: var(--color-text-mute);
}

/* ドロワー展開時、背後のスクロールを止める */
body.is-drawer-open {
  overflow: hidden;
}

/* ==========================================================================
   Form(フォーム)— 3-2-8
   ========================================================================== */

.form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  max-inline-size: var(--container-narrow);
  margin-inline: auto;
}

.form__field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.form__label {
  font-family: var(--font-sans-jp);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--color-text);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}

.form__required {
  display: inline-block;
  padding: 2px var(--sp-2);
  background-color: var(--color-error);
  color: #FFFFFF;
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  line-height: 1;
}

.form__optional {
  display: inline-block;
  padding: 2px var(--sp-2);
  background-color: var(--color-line);
  color: var(--color-text-sub);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  line-height: 1;
}

.form__input,
.form__textarea,
.form__select {
  inline-size: 100%;
  font-family: var(--font-sans-jp);
  font-size: var(--fs-base);
  line-height: var(--lh-snug);
  color: var(--color-text);
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: var(--sp-3) var(--sp-4);
  transition: border-color var(--duration-base) var(--ease-base),
              box-shadow var(--duration-base) var(--ease-base);
}

.form__textarea {
  min-block-size: 10em;
  resize: vertical;
}

.form__select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235C6F6C' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-4) center;
  background-size: 10px 7px;
  padding-inline-end: var(--sp-10);
}

.form__input:focus,
.form__textarea:focus,
.form__select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(122, 154, 151, 0.2);
}

.form__input[aria-invalid="true"],
.form__textarea[aria-invalid="true"],
.form__select[aria-invalid="true"] {
  border-color: var(--color-error);
}

.form__input[aria-invalid="true"]:focus,
.form__textarea[aria-invalid="true"]:focus,
.form__select[aria-invalid="true"]:focus {
  box-shadow: 0 0 0 3px rgba(178, 59, 59, 0.18);
}

.form__help {
  font-size: var(--fs-xs);
  color: var(--color-text-sub);
}

.form__error {
  font-size: var(--fs-xs);
  color: var(--color-error);
  display: none;
}

.form__field.is-error .form__error {
  display: block;
}

/* --- Radio / Checkbox --- */
.form__radio-group,
.form__checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

@media (min-width: 480px) {
  .form__radio-group--inline,
  .form__checkbox-group--inline {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--sp-4);
  }
}

.form__radio,
.form__checkbox {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  padding: var(--sp-2) 0;
  font-size: var(--fs-base);
  user-select: none;
}

.form__radio input,
.form__checkbox input {
  inline-size: 18px;
  block-size: 18px;
  accent-color: var(--color-primary-deep);
  cursor: pointer;
}

/* --- Consent --- */
.form__consent {
  padding: var(--sp-4);
  background-color: var(--color-bg-sub);
  border-radius: var(--radius-md);
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
}

.form__consent input {
  margin-block-start: 4px;
  flex-shrink: 0;
}

.form__consent label {
  font-size: var(--fs-sm);
  line-height: var(--lh-snug);
}

/* --- Actions --- */
.form__actions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  align-items: center;
  margin-block-start: var(--sp-4);
}

@media (min-width: 480px) {
  .form__actions {
    flex-direction: row;
    justify-content: center;
  }
}


/* --- Confirm 確認画面用の dl 表示 --- */
.confirm-list {
  max-inline-size: var(--container-narrow);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-block-start: 1px solid var(--color-line);
}

.confirm-list > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-1);
  padding: var(--sp-4) 0;
  border-block-end: 1px solid var(--color-line);
}

@media (min-width: 600px) {
  .confirm-list > div {
    grid-template-columns: 12em 1fr;
    gap: var(--sp-4);
    padding: var(--sp-5) 0;
  }
}

.confirm-list dt {
  font-family: var(--font-serif-en);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary-deep);
}

.confirm-list dd {
  margin: 0;
  color: var(--color-text);
  line-height: var(--lh-snug);
  word-break: break-word;
}


/* ==========================================================================
   Page header(下層ページ共通ヘッダー)— 3-2-7
   ========================================================================== */

.page-header {
  background-color: var(--color-bg-sub);
  padding-block-start: clamp(7rem, 14vw, 10rem);
  padding-block-end: clamp(3rem, 6vw, 5rem);
  border-block-end: 1px solid var(--color-line);
  position: relative;
  overflow: hidden;
}

.page-header::after {
  content: "";
  position: absolute;
  inset-inline-end: 5%;
  inset-block-end: -20%;
  inline-size: 280px;
  block-size: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(122, 154, 151, 0.12) 0%, transparent 70%);
  pointer-events: none;
}

.page-header__inner {
  position: relative;
  z-index: var(--z-base);
}

.page-header__en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-md);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary);
  margin: 0 0 var(--sp-2);
}

@media (min-width: 768px) {
  .page-header__en {
    font-size: var(--fs-lg);
  }
}

.page-header__title {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  line-height: var(--lh-tight);
  color: var(--color-text);
  margin: 0;
  text-wrap: balance;
}

@media (min-width: 768px) {
  .page-header__title {
    font-size: var(--fs-3xl);
  }
}

.page-header__lead {
  margin-block-start: var(--sp-4);
  max-inline-size: 36em;
  color: var(--color-text-sub);
  text-wrap: pretty;
}


/* ==========================================================================
   Breadcrumb — 3-2-7
   ========================================================================== */

.breadcrumb {
  margin-block-start: var(--sp-6);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
}

.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}

.breadcrumb li {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}

.breadcrumb li + li::before {
  content: "›";
  color: var(--color-text-mute);
  font-size: var(--fs-base);
}

.breadcrumb a {
  color: var(--color-text-sub);
  text-decoration: none;
  letter-spacing: var(--ls-wide);
}

.breadcrumb a:hover,
.breadcrumb a:focus-visible {
  color: var(--color-primary-deep);
  text-decoration: underline;
}

.breadcrumb [aria-current="page"] {
  color: var(--color-text);
  font-weight: var(--fw-medium);
}


/* ==========================================================================
   Article(記事本文)— 3-2-7
   下層ページの本文を流し込むラッパー。.flow を拡張。
   ========================================================================== */

.article {
  max-inline-size: var(--container-narrow);
  margin-inline: auto;
}

.article > * + * {
  margin-block-start: 1em;
}

.article h2 {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
  margin-block-start: 2.4em;
  padding-block-end: var(--sp-3);
  border-block-end: 1px solid var(--color-line);
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .article h2 {
    font-size: var(--fs-2xl);
  }
}

.article h3 {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  margin-block-start: 2em;
  color: var(--color-primary-deep);
}

.article h4 {
  font-family: var(--font-sans-jp);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  margin-block-start: 1.6em;
}

.article p {
  line-height: var(--lh-base);
  text-wrap: pretty;
}

.article ul,
.article ol {
  padding-inline-start: 1.5em;
}

.article ul li,
.article ol li {
  margin-block-start: 0.5em;
  line-height: var(--lh-base);
}

.article ul li::marker {
  color: var(--color-primary);
}

.article blockquote {
  margin-block: 1.6em;
  padding: var(--sp-4) var(--sp-6);
  border-inline-start: 3px solid var(--color-primary);
  background-color: var(--color-bg-sub);
  color: var(--color-text);
  font-style: normal;
}

.article figure {
  margin-block: 1.6em;
}

.article figure img {
  inline-size: 100%;
  border-radius: var(--radius-md);
}

.article figcaption {
  margin-block-start: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  text-align: center;
}

.article table {
  inline-size: 100%;
  border-collapse: collapse;
  margin-block: 1.6em;
}

.article table th,
.article table td {
  padding: var(--sp-3) var(--sp-4);
  border-block-end: 1px solid var(--color-line);
  text-align: start;
  vertical-align: top;
}

.article table th {
  background-color: var(--color-bg-sub);
  font-weight: var(--fw-medium);
  white-space: nowrap;
}

.article hr {
  margin-block: 2.4em;
  background-color: var(--color-line);
}

.article a:not(.btn) {
  color: var(--color-link);
  text-decoration: underline;
  text-decoration-color: var(--color-line-strong);
  text-underline-offset: 0.2em;
  text-decoration-thickness: 1px;
}

.article a:not(.btn):hover {
  color: var(--color-link-hover);
  text-decoration-color: currentColor;
}


/* ==========================================================================
   Page CTA(下層ページ末尾の予約 CTA)— 3-2-7
   .cta の軽量版
   ========================================================================== */

.page-cta {
  background-color: var(--color-primary-soft);
  text-align: center;
}

.page-cta .section-heading__jp {
  color: var(--color-text);
}

.page-cta__lead {
  max-inline-size: 32em;
  margin-inline: auto;
  margin-block-end: var(--sp-6);
  color: var(--color-text-sub);
}


/* ==========================================================================
   Section heading — 3-2-6 共通
   英字小見出し + 日本語大見出しの組み合わせ
   ========================================================================== */

.section-heading {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-block-end: var(--sp-10);
}

.section-heading--center {
  align-items: center;
  text-align: center;
}

/* --------------------------------------------------------------------------
   英字見出し(Message / Concept / Voice 等)— 大きく洗練された編集デザイン
   ・Cormorant Garamond italic を主役級のサイズで配置
   ・テキスト脇に細い水平線アクセント(エディトリアル定番)を添えて格を上げる
   ・寄せ方向に合わせて線の位置を切替える
   -------------------------------------------------------------------------- */
.section-heading__en {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin: 0;
  font-family: var(--font-serif-en);
  font-style: italic;
  font-weight: var(--fw-regular);
  font-size: clamp(2.25rem, 3vw + 1rem, 3.75rem);
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--color-primary);
  text-transform: none;
}

.section-heading__en::before,
.section-heading__en::after {
  content: "";
  flex: 0 0 auto;
  inline-size: clamp(1.75rem, 3vw, 3rem);
  block-size: 1px;
  background-color: currentColor;
  opacity: 0.55;
}

/* デフォルト(左寄せ):左側のみに細線 */
.section-heading__en::after { display: none; }

/* 中央寄せ:両側に細線 */
.section-heading--center .section-heading__en {
  justify-content: center;
}
.section-heading--center .section-heading__en::after {
  display: inline-block;
}

.section-heading__jp {
  font-family: var(--font-serif-jp);
  font-size: clamp(1.6rem, 5.5vw, 2.1rem);
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  line-height: 1.35;
  color: var(--color-primary-deep);
  margin: 0;
  text-wrap: balance;
}

@media (min-width: 768px) {
  .section-heading__jp {
    font-size: clamp(2.1rem, 2.6vw + 0.6rem, 2.8rem);
    letter-spacing: 0.08em;
  }
}

.section-heading__lead {
  font-size: var(--fs-base);
  color: var(--color-text-sub);
  max-inline-size: 38em;
  margin-block-start: var(--sp-4);
  text-wrap: pretty;
}

/* --------------------------------------------------------------------------
   Script accent — 手書き風(Klee One)を限定利用するユーティリティ
   使用箇所はサイト内2箇所のみ(KVキャッチ + CONCEPTリード)。
   font-family のみ上書きし、サイズ・色・余白は元の規約を継承する。
   -------------------------------------------------------------------------- */
.is-script {
  font-family: var(--font-script-jp);
  letter-spacing: 0.02em;
}


/* ==========================================================================
   Button(共通)— 3-2-6
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-8);
  font-family: var(--font-sans-jp);
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  border-radius: var(--radius-full);
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--duration-base) var(--ease-base),
              color var(--duration-base) var(--ease-base),
              border-color var(--duration-base) var(--ease-base),
              transform var(--duration-base) var(--ease-base);
  border: 1px solid transparent;
}

.btn:hover,
.btn:focus-visible {
  transform: translateY(-1px);
}

.btn--primary {
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
}

.btn--primary:hover,
.btn--primary:focus-visible {
  background-color: var(--color-text);
  color: var(--color-text-invert);
}

.btn--ghost {
  background-color: transparent;
  color: var(--color-primary-deep);
  border-color: var(--color-primary-deep);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
}

.btn--line {
  background-color: #06C755;
  color: #FFFFFF;
}

.btn--line:hover,
.btn--line:focus-visible {
  background-color: #04A347;
  color: #FFFFFF;
}

.btn--invert {
  background-color: var(--color-text-invert);
  color: var(--color-primary-deep);
}

.btn--invert:hover,
.btn--invert:focus-visible {
  background-color: var(--color-primary-soft);
  color: var(--color-text);
}

.btn--lg {
  padding: var(--sp-4) var(--sp-10);
  font-size: var(--fs-md);
}

.btn--full {
  inline-size: 100%;
}


/* ==========================================================================
   Card(汎用カード)— 3-2-6
   ========================================================================== */

.card {
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-base) var(--ease-base),
              box-shadow var(--duration-base) var(--ease-base);
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.card__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  position: relative;
  /* aspect-ratio を確実に固定:子の自然寸法に左右されないよう block-size を解除 */
  block-size: auto;
}

/* picture はデフォルト inline → block にして容器全面を満たす(高さ揃えに必須) */
.card__media picture {
  display: block;
  inline-size: 100%;
  block-size: 100%;
}

.card__media img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  /* EXIF オリエンテーション差異を吸収して全画像で一貫表示 */
  image-orientation: from-image;
  transition: transform var(--duration-slow) var(--ease-base);
}

.card:hover .card__media img {
  transform: scale(1.05);
}

.card__body {
  padding: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  flex: 1;
}

.card__num {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-sm);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary);
}

.card__title {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  margin: 0;
  text-wrap: balance;
}

.card__text {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: var(--lh-base);
  margin: 0;
}


/* ==========================================================================
   Section: MESSAGE — 3-2-6
   ========================================================================== */

.message {
  background-color: var(--color-bg);
  padding-block-end: clamp(2rem, 4vw, 4rem);
}

.message__split {
  display: grid;
  gap: var(--sp-10);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 768px) {
  .message__split {
    /* 画像をテキストより大きく見せる(7:5) */
    grid-template-columns: 7fr 5fr;
    gap: var(--sp-12);
  }
}

.message__media {
  overflow: hidden;
  position: relative;
}

.message__media img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center center;
}

/* PC ホバー:写真が背面フレームへ「そっと収まる」微動(オフセット縮小) */
@media (hover: hover) and (min-width: 768px) {
  .message__media {
    transition: box-shadow 700ms cubic-bezier(0.4, 0.4, 0, 1);
  }
  .message__media:hover {
    box-shadow: 12px 12px 0 0 var(--color-primary-soft);
  }
}

.message__body p {
  line-height: var(--lh-base);
  color: var(--color-text);
}

/* --------------------------------------------------------------------------
   D'案:オーバーレイ・レイヤード(写真+カードが重なる編集デザイン)
   --------------------------------------------------------------------------
   ・写真を画面左端までブリードさせて主役に
   ・本文をひとつのクリーム色のカードにまとめ、写真の右側に重ねて配置
   ・カードの背面には B案のレイヤードフレーム(オフセット枠)が透ける
   ・ホテルブランド / 高級スパサイトに通じる「掲載誌のような」見え方
   -------------------------------------------------------------------------- */

.message {
  position: relative;
  overflow: hidden; /* ブリードの結果生まれる横スクロールを抑制 */
}

.message__layout {
  /* コンテナ役:中央寄せ + 幅制限 */
  position: relative;
  max-inline-size: var(--container-wide);
  margin-inline: auto;
  padding-inline: var(--section-pad-x);
  display: grid;
  grid-template-columns: 1fr;
}

/* モバイルでは写真下スペースが存在しないため非表示 */
.message__illust {
  display: none;
}

.message__media {
  /* 共通:写真の額装感 */
  position: relative;
  z-index: 1;
  margin: 0;
  /* 角丸:柔らかさを取り戻す。box-shadow も角丸に追従して整った額装に */
  border-radius: var(--radius-lg);
  box-shadow: 14px 14px 0 0 var(--color-primary-soft);
  aspect-ratio: 4 / 5;
}

.message__media--portrait {
  aspect-ratio: 4 / 5;
}

@media (max-width: 767px) {
  .message__media {
    /* モバイル:画面左右までブリードする際は端は直線で見せる */
    margin-inline: calc(-1 * var(--section-pad-x, 1rem));
    border-radius: 0;
    box-shadow: 10px 10px 0 0 var(--color-primary-soft);
  }
}

.message__card {
  background-color: transparent;
  position: relative;
  z-index: 2;
  padding: var(--sp-10) var(--sp-6);
}

@media (max-width: 767px) {
  /* === カード: 左右対称・写真とのオーバーラップは控えめに === */
  .message__card {
    /* 写真の下端へ少しだけ食い込む(編集デザインの跡を残しつつ可読性優先) */
    margin-block-start: calc(-1 * var(--sp-8));
    margin-inline: 0;
    padding: var(--sp-8) var(--sp-5);
    /* 透明 → 背景色のソフトカードへ:写真上テキストの可読性を担保 */
    background-color: var(--color-bg);
    border-radius: var(--radius-md);
    box-shadow: 0 -8px 24px rgba(45, 63, 61, 0.06);
  }

  /* === 見出し: "Message" を編集風に大きく、JP は読みやすく === */
  .message__heading {
    margin-block-end: var(--sp-6);
  }

  .message__heading .section-heading__en {
    margin-inline-start: 0;
    font-size: clamp(2.8rem, 12vw, 4.5rem);
    color: var(--color-primary-deep);
    line-height: 0.95;
    letter-spacing: 0.01em;
    gap: var(--sp-3);
  }

  .message__heading .section-heading__en::before {
    display: none;
  }

  .message__heading .section-heading__jp {
    font-size: clamp(1.45rem, 6vw, 1.95rem);
    font-weight: var(--fw-bold);
    color: var(--color-primary-deep);
    letter-spacing: 0.06em;
    line-height: 1.5;
    margin-block-start: var(--sp-3);
    text-wrap: balance;
  }

  /* === 引用ブロック: padding を本文と揃える、引用符は控えめに === */
  .message__quote {
    /* 上下の padding を圧縮(過剰な空白の主因) */
    padding: var(--sp-2) var(--sp-2) var(--sp-2) var(--sp-6);
    font-size: clamp(1rem, 3.6vw, 1.2rem);
    line-height: 1.7;
  }

  .message__quote::before {
    font-size: 3em;
    inset-block-start: -0.05em;
  }

  .message__quote--upper {
    margin-block-start: 0;
  }

  .message__quote--upper p {
    /* nowrap を解除して画面幅に応じて折り返せるように */
    white-space: normal;
    font-size: clamp(0.95rem, 3.5vw, 1.2rem);
  }

  /* === 章ブロック: ヒエラルキーを正す(本文より章タイトルを大きく) === */
  .message__chapter-num {
    font-size: clamp(1.4rem, 5.2vw, 1.85rem);
    margin-block-end: var(--sp-3);
    gap: var(--sp-3);
  }

  .message__chapter h3 {
    /* 本来 0.95rem だったため本文より小さく見えていた → 大きく */
    font-size: clamp(1.1rem, 4.2vw, 1.35rem);
    font-weight: var(--fw-semibold);
    line-height: 1.55;
    margin-block-end: var(--sp-3);
    color: var(--color-primary-deep);
  }

  .message__chapter p {
    font-size: clamp(0.95rem, 3.5vw, 1.02rem);
    line-height: 1.85;
    margin-block-end: var(--sp-3);
  }

  /* === 縦リズムを整理 === */
  .message__card > * + * {
    margin-block-start: var(--sp-5);
  }

  /* 引用 → 章 は引用の余韻も padding で吸収済みなので最小限に */
  .message__card > .message__quote + .message__chapter {
    margin-block-start: var(--sp-5);
  }

  .message__card > .message__chapter + .message__chapter {
    margin-block-start: var(--sp-8);
  }
}

@media (min-width: 768px) {
  .message__layout {
    /* PC:黄金比 1.618 : 1(写真 61.8% / テキスト 38.2%)
       タイポグラフィの "Message" 巨大タイトルがカラム境界を越えて
       写真側へ食い込み、ビジュアルとテキストを橋渡しする編集デザイン */
    grid-template-columns: minmax(0, 1.618fr) minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: start;
    column-gap: 0;
  }

  .message__media {
    grid-column: 1;
    grid-row: 1;
    /* 画面左端まで写真をブリードさせる */
    margin-inline-start: calc(50% - 50vw);
    margin-inline-end: 0;
    aspect-ratio: 4 / 5;
    box-shadow: 22px 22px 0 0 var(--color-primary-soft);
    align-self: start;
    /* PC でも角丸を維持(右端も画面端ではないので全周ラウンド) */
    border-radius: var(--radius-lg);
  }

  .message__media--portrait {
    aspect-ratio: 5 / 6;
  }

  .message__card {
    grid-column: 2;
    grid-row: 1 / span 2;
    margin-inline-start: 0;
    margin-block-start: clamp(3.5rem, 7vw, 7rem);
    margin-block-end: clamp(2.5rem, 5vw, 5rem);
    padding-block: clamp(3rem, 4vw + 1rem, 5.5rem);
    padding-inline: clamp(2rem, 3vw + 0.5rem, 3.5rem) 0;
    background-color: transparent;
    box-shadow: none;
    position: relative;
    z-index: 2;
    /* 巨大タイトルが左へはみ出すので overflow visible(デフォルト)を保証 */
    overflow: visible;
  }

  /* 写真下のスペースに置く連続線デイジー --------------------------------- */
  .message__illust {
    grid-column: 1;
    grid-row: 2;
    display: block;
    inline-size: clamp(200px, 24vw, 320px);
    block-size: auto;
    margin-block: clamp(2.5rem, 5vw, 5.5rem) 0;
    margin-inline: auto;
    color: var(--color-primary);
    opacity: 0.7;
    pointer-events: none;
  }

  /* === タイポブリッジ:英字 "Message" が写真側へ大きく食い込む === */
  .message__heading {
    overflow: visible;
    margin-block-end: var(--sp-8);
  }

  .message__heading .section-heading__en {
    /* 章立て編集デザインの主役:80–112px の巨大 italic */
    font-size: clamp(3.5rem, 7vw + 1rem, 7rem);
    /* 写真側へ食い込ませる(タイポブリッジ)。viewport が広いほど大きく */
    margin-inline-start: clamp(-12rem, -8vw, -3rem);
    line-height: 0.95;
    letter-spacing: 0.01em;
    /* 写真上の可読性を高めるため濃いめのブランドカラーへ */
    color: var(--color-primary-deep);
    /* 細線アクセントはカラム境界を跨ぐと邪魔になるので非表示 */
  }

  .message__heading .section-heading__en::before,
  .message__heading .section-heading__en::after {
    display: none;
  }

  /* JP見出し:狭い右カラム内に収まるよう少し縮小 + wrap 許容
     ただし「タイトル」として認識される大きさ・濃さを確保 */
  .message__heading .section-heading__jp {
    font-size: clamp(1.85rem, 2.4vw + 0.6rem, 2.6rem);
    font-weight: var(--fw-bold);
    color: var(--color-primary-deep);
    white-space: normal;
    text-wrap: balance;
    letter-spacing: 0.06em;
    line-height: 1.4;
    margin-block-start: clamp(0.6rem, 1vw, 1.2rem);
  }
}

/* 大画面ではさらに洗練された余白に */
@media (min-width: 1280px) {
  .message__card {
    margin-block-start: clamp(5rem, 8vw, 9rem);
    padding-block: clamp(4rem, 5vw + 1rem, 6.5rem);
    padding-inline-end: 0;
    padding-inline-start: clamp(2.5rem, 3vw + 0.5rem, 4rem);
  }
}

/* --- カード内コンテンツ ----------------------------------------------------- */

.message__heading {
  margin-block-end: var(--sp-6);
}

.message__heading .section-heading__jp {
  font-size: clamp(1.5rem, 1.8vw + 0.5rem, 2.1rem);
  font-weight: var(--fw-bold);
  color: var(--color-primary-deep);
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-wrap: balance;
}

/* オーバーレイカード内では英字見出しを左寄せのまま使用(右寄せ調整は不要) */

/* プルクオート:エディトリアル風の引用ブロック */
.message__quote {
  position: relative;
  margin: 0;
  padding: var(--sp-3) var(--sp-2) var(--sp-3) var(--sp-8);
  font-family: var(--font-serif-jp);
  font-size: clamp(1.1rem, 1.2vw + 0.65rem, 1.65rem);
  line-height: 1.7;
  color: var(--color-primary-deep);
  letter-spacing: 0.04em;
  font-weight: var(--fw-regular);
}

.message__quote p {
  margin: 0;
}

.message__quote::before {
  content: "“";
  position: absolute;
  inset-inline-start: -0.05em;
  inset-block-start: -0.25em;
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 4.5em;
  line-height: 1;
  color: var(--color-primary-soft);
  pointer-events: none;
  user-select: none;
}

/* 上のクオートは少し内側に寄せて、見出しと写真の間で「呼吸」させる */
.message__quote--upper {
  margin-block-start: 0;
}

/* 上クオートは短文なので 1 行で見せる(画面が狭ければ自動縮小) */
.message__quote--upper p {
  white-space: nowrap;
  font-size: clamp(0.95rem, 1.1vw + 0.55rem, 1.5rem);
}

/* 下のクオートは右寄せ + 引用符を右上に配置(対称崩しでアクセント) */
.message__quote--lower {
  padding: var(--sp-3) var(--sp-8) var(--sp-3) var(--sp-2);
  text-align: end;
}
.message__quote--lower::before {
  content: "”";
  inset-inline-start: auto;
  inset-inline-end: -0.05em;
  inset-block-start: auto;
  inset-block-end: -0.6em;
}

@media (max-width: 767px) {
  /* モバイルでは装飾を控えめに、左寄せで統一 */
  .message__quote--lower {
    padding: var(--sp-2) var(--sp-2) var(--sp-2) var(--sp-6);
    text-align: start;
  }
  .message__quote--lower::before {
    content: "“";
    inset-inline-start: -0.05em;
    inset-inline-end: auto;
    inset-block-start: -0.25em;
    inset-block-end: auto;
  }
}

/* カード内の縦リズム:見出し → クオート → 章 → CTA を自然な余白で繋ぐ */
.message__card > * + * {
  margin-block-start: var(--sp-8);
}

.message__card > .message__quote + .message__chapter {
  margin-block-start: var(--sp-6);
}

.message__card > .message__chapter + .message__chapter {
  margin-block-start: var(--sp-10);
}

/* 章ブロック:序数 + 区切り線 + 見出し + 本文 */
.message__chapter {
  display: block;
}

.message__chapter-num {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin: 0 0 var(--sp-4);
  font-family: var(--font-serif-en);
  font-style: italic;
  font-weight: var(--fw-regular);
  font-size: clamp(1.5rem, 1.4vw + 0.8rem, 2.1rem);
  letter-spacing: 0.06em;
  color: var(--color-primary);
  line-height: 1;
}

.message__chapter-num span {
  flex: 0 0 auto;
}

.message__chapter-num::after {
  content: "";
  flex: 1 1 auto;
  block-size: 1px;
  background-color: var(--color-line);
}

.message__chapter h3 {
  position: relative;
  margin: 0 0 var(--sp-4);
  padding-block-end: var(--sp-3);
  font-family: var(--font-serif-jp);
  /* 章タイトルを 1 行に収めるため、サイズと文字間を抑える */
  font-size: clamp(0.95rem, 0.35vw + 0.8rem, 1.1rem);
  font-weight: var(--fw-medium);
  line-height: var(--lh-snug);
  letter-spacing: 0;
  color: var(--color-text);
}

/* 黄金比カラム(38.2%)に収まるよう wrap 許容。
   text-wrap: balance で 2 行になっても上下のバランスが揃う */
.message__chapter h3 {
  text-wrap: balance;
}

/* タイトル下のエディトリアル風ダブルライン
   ───── 細い罫線(全幅・ライト)+ 短い太線アクセント(左揃え・ディープ) */
.message__chapter h3::before,
.message__chapter h3::after {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-end: 0;
  display: block;
}
.message__chapter h3::before {
  inline-size: 100%;
  block-size: 1px;
  background-color: var(--color-line);
}
.message__chapter h3::after {
  inline-size: clamp(2.25rem, 4vw, 3rem);
  block-size: 2px;
  background-color: var(--color-primary-deep);
}

.message__chapter p {
  margin: 0 0 var(--sp-4);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--color-text);
}

.message__chapter p:last-child {
  margin-block-end: 0;
}

.message__chapter strong {
  font-weight: var(--fw-medium);
  color: var(--color-primary-deep);
}

/* CTA:PCでは右下に静かに配置 */
.message__cta {
  margin-block-start: var(--sp-8);
}

@media (min-width: 768px) {
  .message__cta {
    justify-self: end;
    /* 最後の段落とボタンの距離を十分に取る(編集デザインの "間") */
    margin-block-start: clamp(2.5rem, 4vw, 4rem);
  }
}


/* ==========================================================================
   Section: CONCEPT(SALON 3特徴)— 3-2-6
   ========================================================================== */

.concept {
  background-color: var(--color-bg-sub);
}


/* ==========================================================================
   Section: MENU & PRICE — 3-2-6
   ========================================================================== */

.menu {
  background-color: var(--color-bg);
}

.menu__category {
  margin-block: var(--sp-12);
}

.menu__category:first-of-type {
  margin-block-start: 0;
}

.menu__category-title {
  display: inline-block;
  font-family: var(--font-serif-jp);
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-deep);
  padding-block-end: var(--sp-2);
  border-block-end: 2px solid var(--color-primary);
  margin-block-end: var(--sp-6);
}

.price-table {
  inline-size: 100%;
  border-collapse: collapse;
}

.price-table tr {
  border-block-end: 1px solid var(--color-line);
}

.price-table tr:first-child {
  border-block-start: 1px solid var(--color-line);
}

.price-table th,
.price-table td {
  padding: var(--sp-4) var(--sp-2);
  vertical-align: middle;
  text-align: start;
}

.price-table th {
  font-family: var(--font-sans-jp);
  font-weight: var(--fw-regular);
  font-size: var(--fs-base);
  color: var(--color-text);
}

.price-table td {
  font-family: var(--font-serif-en);
  font-weight: var(--fw-medium);
  font-size: var(--fs-lg);
  color: var(--color-primary-deep);
  text-align: end;
  white-space: nowrap;
}

.menu__note {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  margin-block-start: var(--sp-8);
}

/* price-table の右セル(バッジ + 金額)
   - td 内を inline-flex で並べ、バッジと金額の左右位置を揃える
   - 金額は min-inline-size で固定幅 → どの行でも右端が揃う
*/
.price-table--first td,
.price-table--regular td {
  white-space: nowrap;
  text-align: end;
}
.price-table--first td .price-badge,
.price-table--regular td .price-badge {
  margin-inline-end: var(--sp-3);
  vertical-align: middle;
}
.price-table__amount {
  display: inline-block;
  vertical-align: middle;
  min-inline-size: 5em;
  text-align: end;
  font-family: var(--font-serif-en);
  font-weight: var(--fw-medium);
  font-size: var(--fs-lg);
}
.price-table--first td .price-table__amount {
  color: var(--color-primary-deep);
}
.price-table--regular td .price-table__amount {
  color: var(--color-text);
}
@media (max-width: 600px) {
  .price-table--first td,
  .price-table--regular td {
    white-space: normal;
  }
  .price-table--first td .price-badge,
  .price-table--regular td .price-badge {
    display: inline-flex;
    margin-inline-end: var(--sp-2);
  }
  .price-table__amount {
    min-inline-size: 4.4em;
  }
}

/* ==========================================================================
   .menu-tabs — トップページの 初回 / 正規 切替タブ(誰向け / 何のメニュー)
   ========================================================================== */
.menu-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  max-inline-size: 38rem;
  margin: 0 auto var(--sp-6);
  padding: 0;
  background-color: transparent;
  border: none;
  box-shadow: none;
}

.menu-tabs__btn {
  display: flex;
  align-items: stretch;
  justify-content: center;
  padding: 0;
  border: 1.5px solid var(--color-line-strong);
  background-color: var(--color-bg);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: background-color 200ms ease, color 200ms ease, border-color 200ms ease, box-shadow 200ms ease, transform 200ms ease;
  -webkit-tap-highlight-color: transparent;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.menu-tabs__btn:hover:not(.is-active) {
  border-color: var(--color-primary);
  background-color: color-mix(in srgb, var(--color-primary-soft) 20%, var(--color-bg));
  transform: translateY(-1px);
}
.menu-tabs__btn:focus-visible {
  outline: 2px solid var(--color-primary-deep);
  outline-offset: 3px;
}

.menu-tabs__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  inline-size: 100%;
  padding: var(--sp-5) var(--sp-4);
}
.menu-tabs__sub {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: 0.12em;
  color: var(--color-text-sub);
  line-height: 1;
}
.menu-tabs__main {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-serif-jp);
  font-size: clamp(var(--fs-base), 2.4vw, var(--fs-lg));
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  color: var(--color-text);
  line-height: 1.2;
}
.menu-tabs__label {
  white-space: nowrap;
}

/* --- 初回タブ : 非アクティブ時もソフトプライマリで識別 --- */
.menu-tabs__btn--first {
  background-color: color-mix(in srgb, var(--color-primary-soft) 25%, var(--color-bg));
  border-color: color-mix(in srgb, var(--color-primary-deep) 30%, transparent);
}
.menu-tabs__btn--first .menu-tabs__main {
  color: var(--color-primary-deep);
}

/* --- 正規タブ : 非アクティブ時はミュート --- */
.menu-tabs__btn--regular {
  background-color: var(--color-bg);
  border-color: var(--color-line-strong);
}
.menu-tabs__btn--regular .menu-tabs__main {
  color: var(--color-text);
}

/* --- アクティブ状態 : はっきり塗りつぶし --- */
.menu-tabs__btn.is-active {
  box-shadow: var(--shadow-md);
  transform: translateY(0);
}
.menu-tabs__btn--first.is-active {
  background-color: var(--color-primary-deep);
  border-color: var(--color-primary-deep);
}
.menu-tabs__btn--regular.is-active {
  background-color: var(--color-text);
  border-color: var(--color-text);
}
.menu-tabs__btn.is-active .menu-tabs__sub {
  color: rgba(255, 255, 255, 0.85);
}
.menu-tabs__btn.is-active .menu-tabs__main {
  color: var(--color-text-invert);
}
.menu-tabs__btn.is-active .price-badge {
  background-color: var(--color-bg);
  color: var(--color-primary-deep);
  border-color: var(--color-bg);
}
.menu-tabs__btn--regular.is-active .price-badge {
  color: var(--color-text);
}
/* アクティブタブの底辺に▼マーカー(パネル接続感)*/
.menu-tabs__btn.is-active::after {
  content: "";
  position: absolute;
  inset-block-end: -1px;
  inset-inline-start: 50%;
  inline-size: 14px;
  block-size: 14px;
  background-color: inherit;
  transform: translate(-50%, 50%) rotate(45deg);
  z-index: 0;
  pointer-events: none;
}

/* --- モバイル(〜480px)--- */
@media (max-width: 480px) {
  .menu-tabs {
    gap: var(--sp-2);
  }
  .menu-tabs__inner {
    padding: var(--sp-4) var(--sp-2);
    gap: var(--sp-1);
  }
  .menu-tabs__sub {
    font-size: 0.72rem;
    letter-spacing: 0.08em;
  }
  .menu-tabs__main {
    flex-direction: column;
    gap: var(--sp-1);
    font-size: var(--fs-sm);
  }
  .menu-tabs__main .price-badge {
    font-size: 0.7em;
  }
}

/* ==========================================================================
   .menu-panel — タブ切替で表示・非表示するパネル
   ========================================================================== */
.menu-panel {
  display: none;
  animation: menu-panel-fade 220ms ease;
}
.menu-panel.is-active {
  display: block;
}
@keyframes menu-panel-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.menu-panel__lead {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.8;
}
.menu-panel__lead small {
  display: inline-block;
  margin-block-start: 0.4em;
  font-size: 0.85em;
}


/* ==========================================================================
   Section: VOICE preview — 3-2-6
   ========================================================================== */

.voice {
  background-color: var(--color-bg-sub);
  position: relative;
}

/* ==========================================================================
   VOICE JOURNAL — 案C「手紙(便箋)風」レイアウト 強化版
   - 罫線入り便箋(横ライン)
   - 上端の封筒フラップ風影 + 角の蝋封シール
   - 軽い傾き(scattered letters)
   - 行頭インデント、署名風の締め
   ========================================================================== */
.voice-journal {
  background-color: var(--color-bg-sub);
  /* セクション全体に紙テクスチャっぽい微細ノイズ感 */
  background-image:
    radial-gradient(rgba(120, 100, 80, 0.04) 1px, transparent 1px);
  background-size: 22px 22px;
}

.voice-letters {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10, 2.5rem);
  align-items: stretch;
}
@media (min-width: 720px) {
  .voice-letters {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1080px) {
  .voice-letters {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* 便箋本体 ---------------------------------------------------------------- */
.voice-letter {
  position: relative;
  display: flex;
  flex-direction: column;
  min-block-size: 22rem;
  padding: 4.25rem var(--sp-8, 2rem) 2.25rem;
  /* クリーム便箋色 + 罫線(横ライン)を背景に重ねる */
  background-color: #FBF6EC;
  background-image:
    /* 本文エリアの横罫線(等間隔) */
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 2.05rem,
      rgba(120, 100, 80, 0.10) 2.05rem,
      rgba(120, 100, 80, 0.10) 2.1rem
    );
  background-position: 0 4.25rem; /* 上の余白からラインを開始 */
  background-repeat: repeat;

  /* 紙の縁・影 */
  border: 1px solid rgba(120, 100, 80, 0.16);
  box-shadow:
    inset 0 0 0 6px #FBF6EC,
    inset 0 0 0 7px rgba(120, 100, 80, 0.10),
    0 1px 2px rgba(80, 60, 40, 0.06),
    0 12px 28px -18px rgba(80, 60, 40, 0.32);
}
.voice-letters .voice-letter + .voice-letter {
  margin-block-start: 0;
}

/* 全ての手紙を同じ大きさで揃える(統一感) */
/* 傾きは付けず、整列で美しく見せる */

/* 上端:封筒フラップ風 三角の影 + 中央に赤い蝋封 ----------------------- */
.voice-letter::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-inline: 0;
  block-size: 1.2rem;
  background:
    linear-gradient(180deg,
      rgba(120, 100, 80, 0.10) 0%,
      rgba(120, 100, 80, 0)    100%);
  pointer-events: none;
}

/* 蝋封シール:花モチーフを押した刻印風 ----------------------------------- */
.voice-letter::after {
  content: "❀";
  position: absolute;
  inset-block-start: 0.9rem;
  inset-inline-end: 1rem;
  inline-size: 2.6rem;
  block-size: 2.6rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  /* 蝋らしいムラのある赤茶 + ハイライト + 縁の暗み */
  background:
    radial-gradient(circle at 32% 28%, rgba(255, 220, 200, 0.55) 0%, rgba(255, 220, 200, 0) 28%),
    radial-gradient(circle at 70% 75%, rgba(60, 15, 8, 0.45) 0%, rgba(60, 15, 8, 0) 38%),
    radial-gradient(circle at 50% 50%, #B14A33 0%, #8B331E 55%, #5E1C0E 100%);
  /* 文字色は暗め=押し型で凹んだような色味に */
  color: rgba(60, 15, 8, 0.78);
  font-size: 1.55rem;
  line-height: 1;
  /* エンボス(凹)風の影 */
  text-shadow:
    0 1px 0 rgba(255, 200, 170, 0.35),
    0 -1px 0 rgba(40, 10, 5, 0.45);
  box-shadow:
    /* 内側の凹み・縁取り */
    inset 0 1px 0 rgba(255, 200, 170, 0.35),
    inset 0 -1px 0 rgba(0, 0, 0, 0.35),
    inset 0 0 0 1px rgba(60, 15, 8, 0.5),
    /* 外側に溶け広がった蝋の影 */
    0 1px 1px rgba(110, 37, 21, 0.35),
    0 4px 6px rgba(80, 20, 10, 0.35),
    0 0 0 0.5px rgba(0, 0, 0, 0.15);
  transform: rotate(-6deg);
}

/* 大きな飾りクォーテーション ------------------------------------------- */
.voice-letter__mark {
  position: absolute;
  inset-block-start: 0.4rem;
  inset-inline-start: 1rem;
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 500;
  font-size: 4.6rem;
  line-height: 1;
  color: rgba(180, 150, 110, 0.55);
  user-select: none;
  pointer-events: none;
}

/* 引用文(便箋の本文)----------------------------------------------------- */
.voice-letter__quote {
  margin: 0;
  flex: 1 1 auto; /* 伸ばして署名を下に固定 */
  font-family: var(--font-serif-jp, 'Shippori Mincho', serif);
  font-size: 0.98rem;
  line-height: 2.1rem; /* 罫線間隔と一致させる */
  letter-spacing: 0.04em;
  color: var(--color-text);
  text-indent: 1em;
}

/* 署名風メタ情報(必ず下端に固定) ---------------------------------------- */
.voice-letter__meta {
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: var(--sp-3, 0.75rem);
  margin: var(--sp-6, 1.5rem) 0 0;
  padding-block-start: var(--sp-4, 1rem);
  font-family: 'Klee One', var(--font-serif-jp, 'Shippori Mincho'), serif;
  font-size: var(--fs-sm, 0.875rem);
  color: var(--color-text-sub);
  letter-spacing: 0.06em;
}
.voice-letter__meta::before {
  content: "— from";
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-style: italic;
  color: var(--color-primary, #6B6650);
  margin-inline-end: var(--sp-2, 0.5rem);
}
.voice-letter__meta span {
  display: inline-flex;
  align-items: center;
  padding-inline: 0.6em;
  padding-block: 0.1em;
  border: 1px solid rgba(120, 100, 80, 0.35);
  border-radius: 999px;
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-style: italic;
  font-size: 0.85em;
  color: var(--color-primary, #6B6650);
  background-color: rgba(255, 253, 249, 0.7);
}

.voice-journal__note {
  text-align: center;
  margin-block-start: var(--sp-12, 3rem);
  font-size: var(--fs-sm, 0.875rem);
  color: var(--color-text-sub);
  line-height: 1.9;
}

.voice-card {
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  box-shadow: var(--shadow-sm);
}

.voice-card__quote {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  color: var(--color-text);
  position: relative;
  padding-inline-start: var(--sp-6);
}

.voice-card__quote::before {
  content: "“";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: -0.2em;
  font-family: var(--font-serif-en);
  font-size: 2.5em;
  line-height: 1;
  color: var(--color-primary);
}

.voice-card__meta {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  border-block-start: 1px solid var(--color-line);
  padding-block-start: var(--sp-3);
}


/* ==========================================================================
   Section: ACCESS preview — 3-2-6
   ========================================================================== */

.access {
  background-color: var(--color-bg);
}

/* ---- TOPページ ACCESS — 3チップカード ---- */
.access__chips {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-block-start: var(--sp-8);
  max-width: 960px;
  margin-inline: auto;
}

@media (min-width: 720px) {
  .access__chips {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-6);
  }
}

.access__chip {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-6) var(--sp-5);
  background-color: var(--color-bg-sub, #efeae2);
  border-radius: var(--radius-lg);
  text-align: center;
  position: relative;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.access__chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
}

.access__chip-en {
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-size: var(--fs-sm);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary);
  margin: 0;
  text-transform: uppercase;
}

.access__chip-title {
  font-family: var(--font-serif-jp, 'Shippori Mincho', serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-medium);
  margin: 0 0 var(--sp-2);
  color: var(--color-text);
}

.access__chip-body {
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed, 1.7);
  color: var(--color-text);
  margin: 0;
}

.access__chip-sub {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: var(--lh-base);
  margin: var(--sp-2) 0 0;
  padding-block-start: var(--sp-3);
  border-block-start: 1px solid rgba(0, 0, 0, 0.08);
}

.access__info dl {
  display: grid;
  grid-template-columns: 8em 1fr;
  gap: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  margin: 0;
}

.access__notes {
  margin-block-start: var(--sp-8);
}

.access__info dl > div {
  display: contents;
}

.access__info dt {
  font-family: var(--font-sans-en);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary);
  padding-block-start: 0.2em;
}

.access__info dd {
  margin: 0;
  color: var(--color-text);
  line-height: var(--lh-base);
}

/* ---- TOPページ ACCESS — 地図イラスト + 情報リスト(2カラム) ---- */
.access__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
  margin-block-start: var(--sp-8);
  max-width: 1080px;
  margin-inline: auto;
  align-items: start;
}

@media (min-width: 900px) {
  .access__layout {
    grid-template-columns: 1.05fr 1fr;
    gap: var(--sp-10);
    align-items: center;
  }
}

/* 地図カード */
.access__map {
  margin: 0;
  padding: var(--sp-6) var(--sp-5);
  background-color: var(--color-bg-sub, #efeae2);
  border-radius: var(--radius-lg);
  color: var(--color-primary);
  position: relative;
  overflow: hidden;
}

/* 角の控えめなコーナーマーク(額装感) */
.access__map::before,
.access__map::after {
  content: "";
  position: absolute;
  inline-size: 18px;
  block-size: 18px;
  border: 1px solid currentColor;
  opacity: 0.25;
}
.access__map::before {
  inset-block-start: 10px;
  inset-inline-start: 10px;
  border-inline-end: none;
  border-block-end: none;
}
.access__map::after {
  inset-block-end: 10px;
  inset-inline-end: 10px;
  border-inline-start: none;
  border-block-start: none;
}

.access__map-svg {
  display: block;
  inline-size: 100%;
  block-size: auto;
  max-block-size: 460px;
  margin-inline: auto;
}

.access__map-caption {
  text-align: center;
  font-size: var(--fs-xs, 0.75rem);
  color: var(--color-text-sub);
  margin-block-start: var(--sp-3);
  letter-spacing: var(--ls-wide);
  line-height: var(--lh-base);
}

/* 情報リスト */
.access__info-block {
  display: flex;
  flex-direction: column;
}

.access__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}

.access__list .access__row + .access__row {
  /* base.css の li+li マージンを上書き */
  margin-block-start: 0;
}

.access__row {
  padding-block: var(--sp-5);
  border-block-end: 1px solid rgba(0, 0, 0, 0.08);
}

.access__row:first-child {
  padding-block-start: 0;
}

.access__row:last-child {
  padding-block-end: 0;
  border-block-end: none;
}

.access__row-en {
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-size: var(--fs-sm);
  font-style: italic;
  letter-spacing: var(--ls-wider);
  color: var(--color-primary);
  margin: 0 0 var(--sp-1);
}

.access__row-title {
  font-family: var(--font-serif-jp, 'Shippori Mincho', serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-medium);
  margin: 0 0 var(--sp-2);
  color: var(--color-text);
  line-height: var(--lh-tight);
}

.access__row-body {
  margin: 0;
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed, 1.7);
  color: var(--color-text);
}

.access__row-sub {
  margin: var(--sp-2) 0 0;
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
  color: var(--color-text-sub);
}

.access__cta {
  margin-block-start: var(--sp-3);
  justify-content: flex-start;
}

@media (max-width: 899px) {
  .access__cta {
    justify-content: center;
  }
}


/* ==========================================================================
   Section: INSTAGRAM — 3-2-6
   ========================================================================== */

.instagram {
  background-color: var(--color-bg);
  padding-block-start: clamp(1.5rem, 3vw, 3rem);
}

/* バッジ風リンクカード(ブランドパレット統一) */
.instagram__card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-5);
  max-width: 560px;
  margin-inline: auto;
  margin-block-start: var(--sp-8);
  padding: var(--sp-5) var(--sp-6);
  border-radius: var(--radius-lg);
  background-color: var(--color-bg-alt);
  color: var(--color-text);
  text-decoration: none;
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-base) var(--ease-base),
              box-shadow var(--duration-base) var(--ease-base),
              border-color var(--duration-base) var(--ease-base);
}

.instagram__card:hover,
.instagram__card:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-soft);
  outline: none;
}

.instagram__card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
  flex-shrink: 0;
}

.instagram__card-body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}

.instagram__card-handle {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  line-height: 1.4;
  color: var(--color-primary-deep);
}

.instagram__card-text {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.5;
}

.instagram__card-arrow {
  font-size: var(--fs-lg);
  color: var(--color-text-sub);
  transition: transform 0.25s ease, color 0.25s ease;
  flex-shrink: 0;
}

.instagram__card:hover .instagram__card-arrow,
.instagram__card:focus-visible .instagram__card-arrow {
  transform: translateX(4px);
  color: var(--color-text);
}

@media (max-width: 480px) {
  .instagram__card {
    grid-template-columns: auto 1fr;
    gap: var(--sp-4);
    padding: var(--sp-4) var(--sp-5);
  }
  .instagram__card-arrow {
    display: none;
  }
}


/* ==========================================================================
   Section: CTA(予約)— 3-2-6
   ========================================================================== */

.cta {
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
  text-align: center;
}

.cta .section-heading__en,
.cta .section-heading__jp {
  color: var(--color-text-invert);
}

.cta__lead {
  max-inline-size: 36em;
  margin-inline: auto;
  margin-block-end: var(--sp-8);
  color: rgba(255, 255, 255, 0.85);
  text-wrap: pretty;
}

.cta__buttons {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  align-items: center;
}

@media (min-width: 768px) {
  .cta__buttons {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
}


/* ==========================================================================
   Fixed CTA(モバイル下部固定バー)— 3-2-6
   ========================================================================== */

.fixed-cta {
  position: fixed;
  inset-inline: 0;
  inset-block-end: 0;
  z-index: var(--z-fixed-cta);
  display: flex;
  background-color: var(--color-bg-alt);
  box-shadow: 0 -2px 12px rgba(45, 63, 61, 0.12);
  padding-block: env(safe-area-inset-bottom, 0);
}

@media (min-width: 1024px) {
  .fixed-cta {
    display: none;
  }
}

.fixed-cta a {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding-block: var(--sp-3);
  font-family: var(--font-sans-jp);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-decoration: none;
  transition: opacity var(--duration-base) var(--ease-base);
}

.fixed-cta a:hover,
.fixed-cta a:focus-visible {
  opacity: 0.8;
}

.fixed-cta__line {
  background-color: #06C755;
  color: #FFFFFF;
}

.fixed-cta__ig {
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
}

.fixed-cta svg {
  inline-size: 18px;
  block-size: 18px;
  fill: currentColor;
}

/* 固定 CTA 表示時、フッターの最下行が隠れないよう余白を確保 */
@media (max-width: 1023px) {
  body {
    padding-block-end: 56px;
  }
}


/* ==========================================================================
   Footer — 3-2-5
   ========================================================================== */

.footer {
  background-color: var(--color-text);          /* #2D3F3D 深いティールグレー */
  color: var(--color-text-invert);
  padding-block: var(--sp-16) var(--sp-8);
}

.footer__inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-12);
}

/* --- 上段:ブランド --- */
.footer__brand {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
}

.footer__brand img {
  block-size: clamp(80px, 10vw, 120px);   /* モバイル80px → デスクトップ最大120px */
  inline-size: auto;
  filter: brightness(0) invert(1);   /* ロゴを白で表示する想定。色付きロゴならこの行を削除 */
  opacity: 0.95;
}

.footer__tagline {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-md);
  letter-spacing: var(--ls-wide);
  line-height: var(--lh-snug);
  color: var(--color-primary-soft);
  margin: 0;
}

/* --- 中段:カラム --- */
.footer__columns {
  display: grid;
  gap: var(--sp-10);
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .footer__columns {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-16);
    padding-block: var(--sp-8);
    border-block: 1px solid rgba(255, 255, 255, 0.12);
  }
}

.footer__columns h2 {
  font-family: var(--font-serif-en);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary-soft);
  margin-block-end: var(--sp-4);
  text-transform: uppercase;
}

/* サイトマップ */
.footer__nav {
  display: flex;
  flex-direction: column;
  block-size: 100%;
}

.footer__nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);                 /* 12px → 16px に広げ、右コラムの行間と合わせる */
}

.footer__nav li + li {
  margin-block-start: 0;            /* base.css の li+li 余白を打ち消す */
}

.footer__nav a {
  display: inline-block;
  font-family: var(--font-sans-jp);
  font-size: var(--fs-sm);
  color: var(--color-text-invert);
  text-decoration: none;
  letter-spacing: var(--ls-wide);
  line-height: 1.4;
  transition: color var(--duration-base) var(--ease-base);
}

.footer__nav a:hover,
.footer__nav a:focus-visible {
  color: var(--color-primary);
}

/* 連絡先 */
.footer__contact {
  display: flex;
  flex-direction: column;
  block-size: 100%;                 /* グリッドセルいっぱいに伸ばす */
}

.footer__contact address {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);                 /* 8px → 12px、各行に呼吸を */
  font-style: normal;
  font-size: var(--fs-sm);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.6;                 /* snug(1.5) → 1.6 で左コラムの密度に近づける */
}

.footer__contact address p {
  margin: 0;
}

/* フッターの店舗情報:ラベル(小)+ 値(大)をグループごとに区切り線で整理 */
.footer__contact-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
  padding: 0;
}

.footer__contact-list > div {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1, 0.25rem);
  padding-block: var(--sp-3);
  border-block-start: 1px solid rgba(255, 255, 255, 0.12);
}

.footer__contact-list > div:first-child {
  padding-block-start: 0;
  border-block-start: 0;
}

.footer__contact-list > div:last-child {
  padding-block-end: 0;
}

.footer__contact-list dt {
  font-family: var(--font-sans-en);
  font-size: 0.72rem;
  font-weight: var(--fw-medium);
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.55);
  margin: 0;
}

.footer__contact-list dd {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: var(--fs-sm);
  line-height: 1.75;
  font-feature-settings: "tnum" 1;
}

.footer__note {
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.75);
  margin-block-start: var(--sp-3);
  line-height: 1.6;
}

.footer__note a {
  color: var(--color-primary-soft);
  text-decoration: underline;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 1px;
  transition: color var(--duration-fast) var(--ease-base);
}

.footer__note a:hover,
.footer__note a:focus-visible {
  color: var(--color-text-invert);
}

/* SNS — 連絡先カラムの最下部に押し下げ、両コラムの視覚高さを揃える */
.footer__sns {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-block-start: auto;         /* flex で残り空間を吸収 → 最下部に固定 */
  padding-block-start: var(--sp-6); /* 上のテキストとの最小間隔を確保 */
}

.footer__sns li + li {
  margin-block-start: 0;            /* base.css の li+li 余白を打ち消す */
}

.footer__sns a {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-full);
  font-family: var(--font-serif-en);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  color: var(--color-text-invert);
  text-decoration: none;
  transition: background-color var(--duration-base) var(--ease-base),
              border-color var(--duration-base) var(--ease-base);
}

.footer__sns a:hover,
.footer__sns a:focus-visible {
  background-color: var(--color-primary-deep);
  border-color: var(--color-primary-deep);
}

.footer__sns svg {
  inline-size: 16px;
  block-size: 16px;
  fill: currentColor;
}

/* --- 下段:法務 + コピーライト --- */
.footer__bottom {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  align-items: center;
  text-align: center;
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: var(--ls-wide);
}

@media (min-width: 768px) {
  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;          /* 横並び時の縦中央揃えを明示 */
  }
}

.footer__legal {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  line-height: 1;                  /* フォントメトリクス差を吸収 */
}

.footer__legal li {
  display: flex;
  align-items: center;
  line-height: 1;
}

.footer__legal li + li {
  margin-block-start: 0;           /* base.css の li+li 余白を打ち消す */
}

.footer__legal a {
  color: inherit;
  text-decoration: none;
  transition: color var(--duration-base) var(--ease-base);
}

.footer__legal a:hover,
.footer__legal a:focus-visible {
  color: var(--color-primary);
}

.footer__copyright {
  margin: 0;
  font-family: var(--font-serif-en);
  line-height: 1;                  /* 左側(.footer__legal)と縦位置を揃える */
  display: flex;
  align-items: center;
}


/* ==========================================================================
   KV(ファーストビュー)— 3-2-3
   ========================================================================== */

.kv {
  position: relative;
  display: grid;
  place-items: center;
  inline-size: 100%;
  min-block-size: 100svh;
  overflow: hidden;
  isolation: isolate;
  color: var(--color-text-invert);
}

@media (min-width: 768px) {
  .kv {
    min-block-size: 90vh;
  }
}

/* 背景メディア */
.kv__media {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.kv__media img,
.kv__media picture {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  /* ブラウザ拡大時の補間品質を最優先 */
  image-rendering: auto;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: high-quality;
}

/* KV Ken Burns:初回読込時のみゆっくりズームアウト(14秒で完結) */
.kv__media img {
  animation: kv-ken-burns 14s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  transform-origin: center 60%;
}

@keyframes kv-ken-burns {
  0%   { transform: scale(1.06); }
  100% { transform: scale(1.0); }
}

@media (prefers-reduced-motion: reduce) {
  .kv__media img {
    animation: none;
    transform: none;
  }
}

/* 視認性確保のオーバーレイ */
.kv::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    180deg,
    rgba(45, 63, 61, 0.30) 0%,
    rgba(45, 63, 61, 0.45) 60%,
    rgba(45, 63, 61, 0.55) 100%
  );
}

/* コンテンツ */
.kv__content {
  text-align: center;
  padding-block: var(--sp-12);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-6);
}

.kv__brand-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-weight: var(--fw-regular);
  font-size: var(--fs-xl);
  letter-spacing: var(--ls-wider);
  color: var(--color-primary-soft);
  margin: 0;
  opacity: 0;
  transform: translateY(8px);
  animation: kv-fade-in var(--duration-slow) var(--ease-out) 200ms forwards;
}

@media (min-width: 768px) {
  .kv__brand-en {
    font-size: var(--fs-2xl);
  }
}

.kv__catch {
  font-family: var(--font-serif-en, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: var(--fw-medium, 500);
  font-size: clamp(1.75rem, 4.5vw + 0.5rem, 4rem);
  line-height: 1.25;
  letter-spacing: 0.01em;
  color: var(--color-text-invert);
  margin: 0;
  text-wrap: balance;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateY(12px);
  animation: kv-fade-in var(--duration-slow) var(--ease-out) 400ms forwards;
}

/* 英語キャッチ直下の日本語訳(小さめ・控えめ) */
.kv__catch-jp {
  font-family: var(--font-serif-jp);
  font-size: clamp(0.85rem, 1vw + 0.55rem, 1.05rem);
  font-weight: var(--fw-regular);
  letter-spacing: 0.18em;
  color: var(--color-text-invert);
  margin: var(--sp-3) 0 0;
  opacity: 0;
  transform: translateY(10px);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.25);
  animation: kv-fade-in var(--duration-slow) var(--ease-out) 550ms forwards;
}

.kv__sub {
  font-family: var(--font-sans-jp);
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-wide);
  color: var(--color-text-invert);
  margin: var(--sp-4) 0 0;
  opacity: 0;
  transform: translateY(12px);
  animation: kv-fade-in var(--duration-slow) var(--ease-out) 750ms forwards;
}

/* スクロール誘導 */
.kv__scroll {
  position: absolute;
  inset-block-end: var(--sp-6);
  inset-inline: 0;
  margin-inline: auto;
  inline-size: max-content;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-serif-en);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  color: var(--color-text-invert);
  text-decoration: none;
  opacity: 0;
  animation: kv-fade-in var(--duration-slow) var(--ease-out) 900ms forwards;
}

.kv__scroll::after {
  content: "";
  inline-size: 1px;
  block-size: 60px;
  background: linear-gradient(
    to bottom,
    var(--color-text-invert) 0%,
    var(--color-text-invert) 50%,
    transparent 50%,
    transparent 100%
  );
  background-size: 100% 200%;
  background-position: 0 0;
  animation: kv-scroll-line 2.4s var(--ease-in-out) infinite;
}

.kv__scroll:hover,
.kv__scroll:focus-visible {
  color: var(--color-primary-soft);
}

@keyframes kv-fade-in {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes kv-scroll-line {
  0%   { background-position: 0 -100%; }
  100% { background-position: 0 100%; }
}

/* モーション低減 */
@media (prefers-reduced-motion: reduce) {
  .kv__brand-en,
  .kv__catch,
  .kv__catch-jp,
  .kv__sub,
  .kv__scroll {
    opacity: 1;
    transform: none;
    animation: none;
  }
  .kv__scroll::after {
    animation: none;
  }
}

/* --------------------------------------------------------------------------
   .kv__curve — KV 底面の曲線デコレーション
   背景色(--color-bg)で抜くことで「下端が緩やかに波打つ」表現を作る。
   -------------------------------------------------------------------------- */
.kv__curve {
  position: absolute;
  inset-inline: 0;
  inset-block-end: -1px;          /* サブピクセル隙間対策 */
  inline-size: 100%;
  block-size: clamp(48px, 6vw, 96px);
  display: block;
  z-index: 1;                      /* 画像オーバーレイより前面に */
  pointer-events: none;
}

.kv__curve path {
  fill: var(--color-bg);
}

/* --------------------------------------------------------------------------
   .brand-marquee — éclat Jua 右→左 流れるブランドマーキー
   ヒーロー直下の装飾帯。装飾用途のため aria-hidden。
   -------------------------------------------------------------------------- */
.brand-marquee {
  position: relative;
  overflow: hidden;
  background-color: var(--color-bg);
  padding-block: clamp(1.25rem, 4vw, 3.25rem);
  isolation: isolate;
  user-select: none;
}

.brand-marquee__track {
  display: flex;
  flex-wrap: nowrap;
  inline-size: max-content;
  animation: brand-marquee-scroll 38s linear infinite;
  will-change: transform;
}

.brand-marquee__text {
  flex-shrink: 0;
  font-family: var(--font-serif-en);
  font-style: italic;
  font-weight: var(--fw-regular);
  font-size: clamp(3.5rem, 13vw, 11rem);
  line-height: 1;
  letter-spacing: -0.005em;
  white-space: nowrap;
  /* オフホワイト系背景に対し、同系色の最も明るい白でわずかに浮かせる */
  color: var(--color-bg-alt);
  /* 端のフェード・トーンの統一感のため、わずかに不透明度を下げる */
  opacity: 0.9;
  padding-inline-end: 0.25em;
}

/* マーキー両端のソフトフェード(切れ目を曖昧に) */
.brand-marquee::before,
.brand-marquee::after {
  content: "";
  position: absolute;
  inset-block: 0;
  inline-size: clamp(40px, 8vw, 120px);
  z-index: 2;
  pointer-events: none;
}
.brand-marquee::before {
  inset-inline-start: 0;
  background: linear-gradient(to right, var(--color-bg), transparent);
}
.brand-marquee::after {
  inset-inline-end: 0;
  background: linear-gradient(to left, var(--color-bg), transparent);
}

@keyframes brand-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }   /* 同一テキストを2連結→ちょうど1つ分流れてループ */
}

@media (prefers-reduced-motion: reduce) {
  .brand-marquee__track {
    animation: none;
  }
}

/* マーキー直下の Message セクションは、写真までの間延びを抑えるため
   下padding と上padding を共に圧縮(PC・SP 共通の指針) */
.brand-marquee {
  padding-block-end: clamp(0.75rem, 1.5vw, 1.25rem);
}
.brand-marquee + .message.section {
  padding-block-start: clamp(1.25rem, 2.5vw, 2rem);
}

@media (max-width: 767px) {
  .brand-marquee {
    padding-block-end: clamp(0.5rem, 1.5vw, 1rem);
  }
  .brand-marquee + .message.section {
    padding-block-start: clamp(1rem, 3vw, 1.5rem);
  }
}

/* --------------------------------------------------------------------------
   .kv--split — PC(>=1024px)時のみスプリット型KVに切り替える修飾
   モバイル/タブレットでは既存のフルブリードレイアウトを維持(モバイル安全)。
   左35%:文字パネル(暖色背景・濃色文字)
   右65%:既存のメイン写真
   既存の .kv ルールには手を入れず、修飾子で上書きのみ。
   -------------------------------------------------------------------------- */
@media (min-width: 1024px) {
  .kv--split {
    display: grid;
    grid-template-columns: 35fr 65fr;
    place-items: stretch;
    min-block-size: 88vh;
  }

  /* オーバーレイ(KV全面の暗色グラデ)はスプリット時は不要 */
  .kv--split::before {
    display: none;
  }

  /* 写真は右カラムに配置(absolute → grid 配置に切り替え)。
     画像未配置時のフォールバックとしてブランド低彩度色をベタ敷き。 */
  .kv--split .kv__media {
    position: relative;
    inset: auto;
    z-index: 0;
    grid-column: 2;
    grid-row: 1;
    background-color: var(--color-primary-soft);
    overflow: hidden;
  }

  .kv--split .kv__media picture,
  .kv--split .kv__media img {
    display: block;
  }

  /* 文字パネルは左カラム・暖色背景・濃色テキスト */
  .kv--split .kv__content {
    grid-column: 1;
    grid-row: 1;
    background-color: var(--color-bg);
    color: var(--color-text);
    text-align: start;
    align-items: flex-start;
    justify-content: center;
    padding-inline: clamp(2rem, 4vw, 4rem);
    padding-block: var(--sp-16);
  }

  /* 文字色をスプリット用に上書き(白抜き → 濃色) */
  .kv--split .kv__brand-en {
    color: var(--color-primary-deep);
  }

  /* スプリットの 35% カラムに合わせて、ヒーローサイズを控えめに再定義。
     fs-hero(最大 4.5rem)はフルブリード時の値。スプリットでは 35% カラム
     幅に対して大きすぎるので、専用のクランプで縮小する。 */
  .kv--split .kv__catch {
    color: var(--color-text);
    text-shadow: none;
    font-size: clamp(1.625rem, 2.4vw + 0.5rem, 2.75rem);
    line-height: 1.4;
  }

  .kv--split .kv__sub {
    color: var(--color-text-sub);
  }

  /* SCROLL ガイドは画面下中央のままだが、写真側(右)に乗ると視認性が落ちるので右下隅へ */
  .kv--split .kv__scroll {
    inset-block-end: var(--sp-6);
    inset-inline-start: auto;
    inset-inline-end: var(--sp-8);
    transform: none;
    color: var(--color-text-invert);
  }
}


/* ==========================================================================
   Elegant motion enhancements
   --------------------------------------------------------------------------
   トップページ全体に一貫した「静かで上品な」動きを追加する。
   ・横方向の大きな動きは避け、opacity と微小な縦移動・スケールのみ
   ・1〜1.6秒の長めのイージング(expo-out)でぬるりと止まる
   ・continuous な動きは画面外で完結させる(マーキー等)
   ・prefers-reduced-motion で全停止
   ========================================================================== */

/* --- 写真リビール:カード/メッセージ画像が静かにスケールイン -------------- */
.card__media,
.message__media {
  overflow: hidden;
}

.card__media img,
.message__media img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  /* 1.6秒・expo-out で「写真がそっと近づく」リビール */
  transition: transform 1600ms cubic-bezier(0.4, 0.4, 0, 1);
}

/* fade-in 化された親(.card / .message)が is-visible になる前は拡大状態 */
.fade-in .card__media img,
.fade-in .message__media img {
  transform: scale(1.06);
}

.fade-in.is-visible .card__media img,
.fade-in.is-visible .message__media img {
  transform: scale(1.0);
}

/* --- 見出し下線ドロー:英字見出しの下に細い装飾線が左→右に描画 ----------- */
.section-heading__en {
  display: inline-block;
  position: relative;
  padding-block-end: var(--sp-3);
}

.section-heading--center .section-heading__en {
  align-self: center;
}

.section-heading__en::after {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-end: 0;
  inline-size: 32px;
  block-size: 1px;
  background-color: currentColor;
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 1400ms cubic-bezier(0.4, 0.4, 0, 1) 600ms;
}

.section-heading--center .section-heading__en::after {
  inset-inline-start: 50%;
  transform-origin: center;
  transform: translateX(-50%) scaleX(0);
}

.section-heading.is-visible .section-heading__en::after,
.fade-in.is-visible.section-heading .section-heading__en::after {
  transform: scaleX(1);
}

.section-heading--center.is-visible .section-heading__en::after,
.fade-in.is-visible.section-heading--center .section-heading__en::after {
  transform: translateX(-50%) scaleX(1);
}

/* --- カードのホバー:微かな浮き上がり ------------------------------------ */
.card {
  transition:
    transform 600ms cubic-bezier(0.4, 0.4, 0, 1),
    box-shadow 600ms cubic-bezier(0.4, 0.4, 0, 1);
}

@media (hover: hover) {
  .card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
  }

  .card:hover .card__media img {
    transform: scale(1.04);
  }
}

/* --- リダクション設定への配慮 ---------------------------------------------*/
@media (prefers-reduced-motion: reduce) {
  .card__media img,
  .message__media img,
  .fade-in .card__media img,
  .fade-in .message__media img,
  .fade-in.is-visible .card__media img,
  .fade-in.is-visible .message__media img,
  .card,
  .section-heading__en::after {
    transition: none !important;
    transform: none !important;
    animation: none !important;
  }

  .section-heading__en::after {
    /* 線は表示するが描画アニメーションは無効 */
    transform: scaleX(1) !important;
  }
  .section-heading--center .section-heading__en::after {
    transform: translateX(-50%) scaleX(1) !important;
  }
}


/* ==========================================================================
   DECORATIVE ACCENTS — エレガントな曲線装飾
   Message セクション以降のセクションに、ボタニカルな小枝・手描き曲線・
   背景のソフトな円弧などを配し、抑制された上品さを演出する。
   ========================================================================== */

/* --- 1. 中央寄せセクションタイトル上のボタニカル小枝 ---------------------- */
.section-heading--center::before {
  content: "";
  display: block;
  margin-inline: auto;
  inline-size: clamp(56px, 7vw, 84px);
  block-size: 26px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 26' fill='none'><path d='M6 17 Q 42 2 78 17' stroke='%237A9A97' stroke-width='0.9' stroke-linecap='round' opacity='0.85'/><path d='M22 13 Q 28 7 35 8' stroke='%237A9A97' stroke-width='0.7' stroke-linecap='round' opacity='0.7'/><path d='M42 5 Q 48 8 49 13' stroke='%237A9A97' stroke-width='0.7' stroke-linecap='round' opacity='0.7'/><path d='M62 13 Q 56 7 49 8' stroke='%237A9A97' stroke-width='0.7' stroke-linecap='round' opacity='0.7'/><ellipse cx='28' cy='9' rx='4.5' ry='1.6' fill='%237A9A97' opacity='0.45' transform='rotate(-22 28 9)'/><ellipse cx='42' cy='5' rx='5' ry='1.8' fill='%237A9A97' opacity='0.55'/><ellipse cx='56' cy='9' rx='4.5' ry='1.6' fill='%237A9A97' opacity='0.45' transform='rotate(22 56 9)'/><circle cx='42' cy='17' r='1.3' fill='%237A9A97' opacity='0.7'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* CTA 等の濃色背景セクション(白文字)では小枝を白系に置換 */
.cta .section-heading--center::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 26' fill='none'><path d='M6 17 Q 42 2 78 17' stroke='%23FFFFFF' stroke-width='0.9' stroke-linecap='round' opacity='0.7'/><path d='M22 13 Q 28 7 35 8' stroke='%23FFFFFF' stroke-width='0.7' stroke-linecap='round' opacity='0.55'/><path d='M42 5 Q 48 8 49 13' stroke='%23FFFFFF' stroke-width='0.7' stroke-linecap='round' opacity='0.55'/><path d='M62 13 Q 56 7 49 8' stroke='%23FFFFFF' stroke-width='0.7' stroke-linecap='round' opacity='0.55'/><ellipse cx='28' cy='9' rx='4.5' ry='1.6' fill='%23FFFFFF' opacity='0.35' transform='rotate(-22 28 9)'/><ellipse cx='42' cy='5' rx='5' ry='1.8' fill='%23FFFFFF' opacity='0.45'/><ellipse cx='56' cy='9' rx='4.5' ry='1.6' fill='%23FFFFFF' opacity='0.35' transform='rotate(22 56 9)'/><circle cx='42' cy='17' r='1.3' fill='%23FFFFFF' opacity='0.6'/></svg>");
}


/* --- 2. JP 見出し下の手描き曲線アンダーライン ---------------------------- */
.section-heading--center .section-heading__jp {
  position: relative;
  padding-block-end: var(--sp-3);
}
.section-heading--center .section-heading__jp::after {
  content: "";
  position: absolute;
  inset-inline-start: 50%;
  inset-block-end: 0;
  transform: translateX(-50%);
  inline-size: clamp(120px, 16vw, 196px);
  block-size: 8px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 196 8' preserveAspectRatio='none' fill='none'><path d='M3 5 Q 98 -3 193 5' stroke='%237A9A97' stroke-width='1.1' stroke-linecap='round' opacity='0.55'/></svg>");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  pointer-events: none;
}
.cta .section-heading--center .section-heading__jp::after {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 196 8' preserveAspectRatio='none' fill='none'><path d='M3 5 Q 98 -3 193 5' stroke='%23FFFFFF' stroke-width='1.1' stroke-linecap='round' opacity='0.55'/></svg>");
}


/* --- 3. セクション背景のアンビエント円弧(やわらかい遠景) ---------------- */
.concept,
.menu,
.voice,
.access,
.instagram {
  position: relative;
  overflow: hidden;
}

/* container を前面に */
.concept > .container,
.menu > .container,
.voice > .container,
.access > .container,
.instagram > .container {
  position: relative;
  z-index: 1;
}

/* 左下の実線円弧(Concept / Voice — 背景sub) */
.concept::before,
.voice::before {
  content: "";
  position: absolute;
  inset-inline-start: -18%;
  inset-block-end: -28%;
  inline-size: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid var(--color-primary);
  opacity: 0.13;
  pointer-events: none;
  z-index: 0;
}

/* 右上の点線円弧(全セクション共通) */
.concept::after,
.menu::after,
.voice::after,
.access::after,
.instagram::after {
  content: "";
  position: absolute;
  inset-inline-end: -22%;
  inset-block-start: -24%;
  inline-size: 54%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px dashed var(--color-primary);
  opacity: 0.16;
  pointer-events: none;
  z-index: 0;
}


/* --- 4. ウェーブ・ディバイダー(セクション間に挿入できるユーティリティ)-- */
.section-divider-wave {
  display: block;
  block-size: 56px;
  margin: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 56' preserveAspectRatio='none' fill='none'><path d='M0 32 Q 200 8 400 32 T 800 32 T 1200 32' stroke='%237A9A97' stroke-width='1' opacity='0.45'/><path d='M0 40 Q 200 18 400 40 T 800 40 T 1200 40' stroke='%237A9A97' stroke-width='0.6' opacity='0.25'/></svg>");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center;
  pointer-events: none;
}


/* --- 5. カード末尾のさり気ないボタニカルサイン --------------------------- */
.card__body,
.voice-card {
  position: relative;
}
/* voice-card の ::after / ::before はカード枠と被って埋もれた印象になるため非表示
   (.card__body::after は他用途のため残す) */
.voice-card::after,
.voice-card::before {
  display: none !important;
}
.card__body::after {
  content: "";
  position: absolute;
  inset-inline-end: var(--sp-5);
  inset-block-end: var(--sp-3);
  inline-size: 42px;
  block-size: 22px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 22' fill='none' stroke='%237A9A97' stroke-linecap='round' stroke-linejoin='round'><path d='M3 18 C 12 12 22 8 39 4' stroke-width='0.9' opacity='0.6'/><path d='M14 14 C 18 9 22 8 26 9 C 22 11 17 14 14 14 Z' stroke-width='0.8' opacity='0.55'/><path d='M22 10 C 26 6 30 5 34 6 C 30 8 25 10 22 10 Z' stroke-width='0.8' opacity='0.55'/><path d='M30 7 C 33 4 36 4 38 5 C 36 6 33 7 30 7 Z' stroke-width='0.8' opacity='0.5'/><circle cx='39' cy='4' r='1.2' fill='%237A9A97' opacity='0.55'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
}

/* card__num の前に小さなリーフアクセント ----------------------------------- */
.card__num {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
.card__num::before {
  content: "";
  display: inline-block;
  inline-size: 1.4em;
  block-size: 0.6em;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 28 12' fill='none' stroke='%237A9A97' stroke-linecap='round' stroke-linejoin='round'><path d='M2 6 C 8 4 14 3 26 2' stroke-width='0.9'/><path d='M8 8 C 11 5 14 5 17 6 C 14 7 10 8 8 8 Z' stroke-width='0.8'/><path d='M16 6 C 19 3 22 3 25 4 C 22 5 19 6 16 6 Z' stroke-width='0.8'/></svg>");
  background-repeat: no-repeat;
  background-position: center left;
  background-size: contain;
  opacity: 0.85;
}

/* voice-card 左上に小さなボタニカル・コーナー ----------------------------- */
.voice-card::before {
  content: "";
  position: absolute;
  inset-inline-start: var(--sp-4);
  inset-block-start: calc(-1 * var(--sp-3));
  inline-size: 38px;
  block-size: 26px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 38 26' fill='none' stroke='%237A9A97' stroke-linecap='round' stroke-linejoin='round'><path d='M19 24 C 19 16 19 8 19 2' stroke-width='0.9' opacity='0.7'/><path d='M19 14 C 24 10 30 10 34 14 C 28 14 23 14 19 14 Z' stroke-width='0.8' opacity='0.6'/><path d='M19 18 C 14 14 8 14 4 18 C 10 18 15 18 19 18 Z' stroke-width='0.8' opacity='0.6'/><path d='M19 8 C 23 5 28 5 31 8 C 26 8 22 8 19 8 Z' stroke-width='0.8' opacity='0.55'/><circle cx='19' cy='2' r='1.3' fill='%237A9A97' opacity='0.7'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
}


/* --- 6. メニューカテゴリタイトル前の小さなリーフマーカー ----------------- */
.menu__category-title {
  position: relative;
  padding-inline-start: 1.6em;
}
.menu__category-title::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 50%;
  transform: translateY(-58%);
  inline-size: 1.05em;
  block-size: 1.05em;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237A9A97' stroke-linecap='round' stroke-linejoin='round'><path d='M12 3 Q 4 12 12 21 Q 20 12 12 3 Z' stroke-width='1.1' opacity='0.75'/><path d='M12 3 L 12 21' stroke-width='0.8' opacity='0.4'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}


/* --- 7. CTA セクションの円弧装飾(白い細線) ----------------------------- */
.cta {
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: "";
  position: absolute;
  inset-block-start: -32%;
  inset-inline-end: -22%;
  inline-size: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.18);
  pointer-events: none;
  z-index: 0;
}
.cta::after {
  content: none;
}
.cta > .container {
  position: relative;
  z-index: 1;
}


/* --- 8. レスポンシブ調整 ------------------------------------------------- */
@media (max-width: 640px) {
  .section-heading--center::before {
    inline-size: 56px;
    block-size: 22px;
  }
  .card__body::after,
  .voice-card::after {
    inset-inline-end: var(--sp-4);
    inset-block-end: var(--sp-2);
    inline-size: 24px;
    block-size: 10px;
  }
  .concept::before,
  .voice::before,
  .concept::after,
  .menu::after,
  .voice::after,
  .access::after,
  .instagram::after,
  .cta::before,
  .cta::after {
    inline-size: 80%;
  }
}

@media (prefers-reduced-motion: reduce) {
  /* 装飾要素はそのまま静的表示(アニメーションは元から無し) */
}


/* ==========================================================================
   INK ILLUSTRATIONS — 万年筆風ペン画装飾
   各セクションに上品で抑制された線画モチーフ(植物・薔薇・ハーブ等)を配置。
   .ink-illust 基底 + .ink-illust--{type} 形状 + .ink-illust--{position} で配置。
   ========================================================================== */

.ink-illust {
  position: absolute;
  pointer-events: none;
  user-select: none;
  color: var(--color-primary);
  opacity: 0.42;
  z-index: 0;
  /* container の最大幅(--container-base: 1080px)外側のガター内に配置する基準 */
  --illust-content-max: 1080px;
  --illust-edge-pad: 1rem;
}

/* 配置 — container 外側ガターに置く -------------------------------------- */
/* gutter (両端の余白) = max(0, (100vw - 1080) / 2)
   コーナー装飾は gutter 内に収め、文字本体には絶対重ねない。
   狭いビューポートではガターが消えるため非表示にする(下のメディアクエリで制御)*/
.ink-illust--top-left,
.ink-illust--bottom-left {
  inset-inline-start: max(0.5rem, calc((100vw - var(--illust-content-max)) / 2 - var(--illust-w, 100px) - var(--illust-edge-pad)));
}
.ink-illust--top-right,
.ink-illust--bottom-right {
  inset-inline-end: max(0.5rem, calc((100vw - var(--illust-content-max)) / 2 - var(--illust-w, 100px) - var(--illust-edge-pad)));
}
.ink-illust--top-left {
  inset-block-start: clamp(2rem, 5vw, 5rem);
}
.ink-illust--top-right {
  inset-block-start: clamp(2rem, 5vw, 5rem);
}
.ink-illust--bottom-left {
  inset-block-end: clamp(2rem, 5vw, 5rem);
}
.ink-illust--bottom-right {
  inset-block-end: clamp(2rem, 5vw, 5rem);
}
/* top-center は通常フロー(absolute から外す)— 文字との重なりを根絶 ------- */
.ink-illust--top-center {
  position: static;
  display: block;
  margin-inline: auto;
  margin-block-end: var(--sp-6);
  transform: none;
}

/* container 外ガターが装飾サイズに足りない狭幅では表示しない ---------------
   イラストごとに必要ガター幅(= illust_w + edge_pad ≒ illust_w + 16px)が異なるため、
   サイズグループ単位で閾値を設定する。
   閾値の目安: 1080(コンテナ) + 2 × (illust_w + 16) px。
   これより狭いとイラストがコンテナ本文と重なるため非表示。
------------------------------------------------------------------------ */
/* 全サイズ共通の最低ライン(90px 未満相当・約 1280px 以下) */
@media (max-width: 1280px) {
  .ink-illust--top-left,
  .ink-illust--top-right,
  .ink-illust--bottom-left,
  .ink-illust--bottom-right {
    display: none;
  }
}
/* Small系(〜110px): branch/herb/leaflet/fern/lavender/olive/eucalyptus → 1340px 未満で隠す */
@media (max-width: 1340px) {
  .ink-illust--branch,
  .ink-illust--herb,
  .ink-illust--leaflet,
  .ink-illust--fern,
  .ink-illust--lavender,
  .ink-illust--olive,
  .ink-illust--eucalyptus {
    display: none;
  }
}
/* Medium系(〜130px): rose/wildflower → 1380px 未満で隠す */
@media (max-width: 1380px) {
  .ink-illust--rose,
  .ink-illust--wildflower {
    display: none;
  }
}
/* Large系(〜150px): anemone → 1420px 未満で隠す */
@media (max-width: 1420px) {
  .ink-illust--anemone {
    display: none;
  }
}
/* X-Large系(〜180px): daisy → 1480px 未満で隠す */
@media (max-width: 1480px) {
  .ink-illust--daisy {
    display: none;
  }
}

/* MENU セクション内のイラストはボタン/価格表と被りやすいため恒常的に非表示 */
.menu .ink-illust {
  display: none !important;
}

/* VOICE セクションの左下デイジーはセクション左下隅に固定(狭幅でも表示) */
.voice .ink-illust--daisy.ink-illust--bottom-left {
  display: block !important;
  position: absolute !important;
  --illust-w: 90px !important;
  inline-size: var(--illust-w) !important;
  block-size: auto !important;
  inset-inline-start: -1.5rem !important;
  inset-inline-end: auto !important;
  inset-block-end: -2rem !important;
  inset-block-start: auto !important;
  opacity: 0.4;
  z-index: 0;
}

/* 1080px 未満(モバイル/タブレット)では非表示 */
@media (max-width: 1080px) {
  .voice .ink-illust--daisy.ink-illust--bottom-left {
    display: none !important;
  }
}

/* タイプ別サイズ(--illust-w で位置計算にも反映) ------------------------ */
.ink-illust--branch    { --illust-w: 110px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--rose      { --illust-w: 130px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--herb      { --illust-w: 100px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--leaflet   { --illust-w: 110px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--garland   { --illust-w: clamp(160px, 26vw, 280px); inline-size: var(--illust-w); block-size: auto; }
.ink-illust--fern      { --illust-w: 100px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--lavender  { --illust-w:  90px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--wildflower{ --illust-w: 120px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--eucalyptus{ --illust-w: 110px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--olive     { --illust-w:  90px; inline-size: var(--illust-w); block-size: auto; }
/* 参考画像ベースの大型フィーチャー(連続線・薄塗り) */
.ink-illust--daisy     { --illust-w: 180px; inline-size: var(--illust-w); block-size: auto; opacity: 0.75; }
.ink-illust--anemone   { --illust-w: 150px; inline-size: var(--illust-w); block-size: auto; opacity: 0.7;  }
.ink-illust--bouquet   { --illust-w: clamp(200px, 30vw, 320px); inline-size: var(--illust-w); block-size: auto; opacity: 0.78; }
/* spa item 系 */
.ink-illust--aroma     { --illust-w:  46px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--candle    { --illust-w:  44px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--stones    { --illust-w:  62px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--lotus     { --illust-w:  56px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--mirror    { --illust-w:  44px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--dropper   { --illust-w:  40px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--towel     { --illust-w:  56px; inline-size: var(--illust-w); block-size: auto; }
.ink-illust--shell     { --illust-w:  56px; inline-size: var(--illust-w); block-size: auto; }

/* CTA(濃色背景)では白系で表示 ------------------------------------------ */
.cta .ink-illust {
  color: #ffffff;
  opacity: 0.4;
}
/* CTA の主役ブーケはやや濃く(花心の黄色も読めるように) */
.cta .ink-illust--bouquet {
  opacity: 0.6;
}
/* CTA は文字幅が狭く、左右の olive は本文と被りやすいため恒常的に非表示 */
.cta .ink-illust--olive {
  display: none !important;
}

/* container 前面化(他のテキスト/画像が前にくるように) ------------------ */
.concept > .container,
.menu > .container,
.voice > .container,
.access > .container,
.instagram > .container,
.cta > .container {
  position: relative;
  z-index: 1;
}
/* …ただしイラスト自身は section 直下の絶対配置のため z-index 0 で OK ----- */

/* 小型表示(モバイル)— top-center 系のみ縮小 ------------------------------ */
@media (max-width: 640px) {
  .ink-illust {
    opacity: 0.32;
  }
  .ink-illust--garland {
    --illust-w: 180px;
  }
}


/* ==========================================================================
   Spa Lineart Row — section-heading の lead 直下に並べる小さなスパ線画
   <ul class="spa-icons" aria-hidden="true">…</ul>
   ========================================================================== */

.spa-icons {
  list-style: none;
  margin: var(--sp-6) auto 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  color: var(--color-primary);
  opacity: 0.6;
}
.spa-icons > li {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: clamp(36px, 4vw, 48px);
  block-size: clamp(36px, 4vw, 48px);
}
.spa-icons svg {
  inline-size: 100%;
  block-size: 100%;
  display: block;
}
.cta .spa-icons {
  color: #fff;
  opacity: 0.55;
}


/* ==========================================================================
   Menu category icon — 種別ごとのペン画アイコン
   ========================================================================== */

/* 既存の旧 marker(::before)は無効化、SVG span に置換 ---------------------- */
.menu__category-title::before {
  content: none;
}

.menu__category-title {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding-inline-start: 0;
}

.menu__category-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 1.6em;
  block-size: 1.6em;
  flex: 0 0 auto;
  color: var(--color-primary);
  opacity: 0.85;
}

.menu__category-icon svg {
  inline-size: 100%;
  block-size: 100%;
  display: block;
}

/* category-title の下線が文字部分のみ強調されるように調整 ------------------ */
.menu__category--slim .menu__category-icon,
.menu__category--facial .menu__category-icon,
.menu__category--depilation .menu__category-icon {
  color: var(--color-primary);
}

/* ==========================================================================
   .price-menu — 初回お試し / 都度払い(正規) を 2 セクションで分離表示
   --------------------------------------------------------------------------
   設計方針:
   ・初回・正規を「同じ行に並べる」のではなく、別セクションに分けて
     ページ全体の文脈で混同を防止する。
   ・初回セクション = プライマリディープ基調の目立つトーン(販促)
   ・正規セクション = ミュート基調の落ち着いたトーン(レファレンス)
   ・各メニュー行には常にバッジを表示し、スクロール途中でも一目で識別可能。
   ========================================================================== */

.price-menu {
  background-color: var(--color-bg-alt);
}

/* --- 入会金バナー(基本) --- */
.price-menu__entry {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  inline-size: 100%;
  max-inline-size: 38rem;
  margin: 0 auto var(--sp-8);
  padding: var(--sp-4) var(--sp-6);
  background-color: var(--color-bg);
  border: 1.5px solid var(--color-line-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  position: relative;
  font-family: var(--font-serif-jp);
  color: var(--color-primary-deep);
}
.price-menu__entry-label {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
}
.price-menu__entry-dot {
  inline-size: 4px;
  block-size: 4px;
  border-radius: var(--radius-full);
  background-color: var(--color-primary-soft);
}
.price-menu__entry-amount {
  font-family: var(--font-serif-en);
  font-size: var(--fs-xl);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
}

/* ==========================================================================
   入会金キャンペーン版(¥5,000 → ¥0)
   ========================================================================== */
.price-menu__entry--campaign {
  /* リボンは枠線に被せず、上にしっかり離して配置 */
  margin-block-start: var(--sp-10);
  padding-block-start: var(--sp-6);
  padding-block-end: var(--sp-6);
  min-block-size: 6.5rem;
  border-color: color-mix(in srgb, var(--color-warning) 50%, var(--color-line-strong));
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--color-warning) 6%, var(--color-bg)) 0%,
      var(--color-bg) 100%);
  box-shadow:
    var(--shadow-md),
    inset 0 0 0 1px color-mix(in srgb, var(--color-warning) 18%, transparent);
}

/* 枠の上にきれいに浮かぶリボン --- */
.price-menu__entry-ribbon {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 50%;
  /* リボンの中央が枠線の上ライン上にぴったり重なる */
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  background-color: var(--color-warning);
  color: var(--color-text-invert);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
}
.price-menu__entry-ribbon-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 0.78rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.22em;
  line-height: 1;
  padding-inline-end: var(--sp-2);
  border-inline-end: 1px solid rgba(255, 255, 255, 0.45);
}
.price-menu__entry-ribbon-jp {
  font-family: var(--font-serif-jp);
  font-size: 0.82rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  line-height: 1;
}

/* 本体内部 --- */
.price-menu__entry--campaign .price-menu__entry-body {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-5);
  flex-wrap: wrap;
  inline-size: 100%;
  margin-inline: auto;
  text-align: center;
}
.price-menu__entry--campaign .price-menu__entry-label {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.16em;
  color: var(--color-primary-deep);
}

.price-menu__entry-prices {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
}
.price-menu__entry-original {
  position: relative;
  font-family: var(--font-serif-en);
  font-size: var(--fs-lg);
  font-weight: var(--fw-medium);
  color: var(--color-text-sub);
  letter-spacing: 0.04em;
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: color-mix(in srgb, var(--color-error) 75%, transparent);
}
.price-menu__entry-arrow {
  font-family: var(--font-serif-en);
  font-size: var(--fs-lg);
  color: var(--color-text-sub);
  line-height: 1;
}
.price-menu__entry-amount--zero {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-serif-en);
  letter-spacing: 0.02em;
}
.price-menu__entry-amount-num {
  font-size: clamp(2rem, 4.4vw + 0.5rem, 2.8rem);
  font-weight: var(--fw-bold);
  color: var(--color-primary-deep);
  line-height: 1;
}
.price-menu__entry-amount-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.4em 0.85em;
  font-family: var(--font-serif-jp);
  font-size: 0.78rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.18em;
  color: var(--color-text-invert);
  background-color: var(--color-primary-deep);
  border-radius: var(--radius-full);
  line-height: 1;
}

/* モバイル(〜480px) --- */
@media (max-width: 480px) {
  .price-menu__entry--campaign {
    margin-block-start: var(--sp-9);
    padding-block-start: var(--sp-5);
    padding-block-end: var(--sp-5);
    padding-inline: var(--sp-4);
    min-block-size: 0;
  }
  .price-menu__entry-ribbon {
    padding: var(--sp-1) var(--sp-3);
    transform: translate(-50%, -50%);
  }
  .price-menu__entry-ribbon-en {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
  }
  .price-menu__entry-ribbon-jp {
    font-size: 0.75rem;
  }
  .price-menu__entry--campaign .price-menu__entry-body {
    gap: var(--sp-3);
  }
  .price-menu__entry-amount-num {
    font-size: clamp(1.7rem, 7vw, 2.2rem);
  }
  .price-menu__entry-amount-tag {
    font-size: 0.7rem;
    padding: 0.32em 0.7em;
    letter-spacing: 0.14em;
  }
}

/* --- 凡例(初回 / 正規 説明) --- */
.price-menu__legend {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-2);
  max-inline-size: 32rem;
  margin: 0 auto var(--sp-12);
  padding: var(--sp-4) var(--sp-5);
  background-color: var(--color-bg);
  border: 1px dashed var(--color-line-strong);
  border-radius: var(--radius-md);
}
@media (min-width: 640px) {
  .price-menu__legend {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4);
  }
}
.price-menu__legend-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.price-menu__legend-text {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.5;
}

/* --- バッジ(初回 / 正規) --- */
.price-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-inline-size: 3em;
  padding: 0.18em 0.7em;
  border-radius: var(--radius-full);
  font-family: var(--font-sans-jp);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.12em;
  line-height: 1;
}
.price-badge--first {
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
}
.price-badge--regular {
  background-color: transparent;
  color: var(--color-text-sub);
  border: 1px solid var(--color-line-strong);
}
.price-badge--lg {
  font-size: var(--fs-sm);
  padding: 0.32em 1em;
  letter-spacing: 0.18em;
}

/* ==========================================================================
   セクション(初回 / 正規)— メタヘッダ + カテゴリ群を内包
   ========================================================================== */

.price-menu__section {
  margin-block-end: var(--sp-12);
}
.price-menu__section:last-of-type {
  margin-block-end: 0;
}

.price-menu__section-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  margin-block-end: var(--sp-8);
  padding-block: var(--sp-6);
  border-block: 1px solid var(--color-line);
}
.price-menu__section-titles {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.price-menu__section-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-md);
  letter-spacing: 0.16em;
  color: var(--color-primary);
  margin: 0;
}
.price-menu__section-jp {
  font-family: var(--font-serif-jp);
  font-size: clamp(1.5rem, 3vw + 0.4rem, 2.2rem);
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  line-height: 1.3;
  color: var(--color-primary-deep);
  margin: 0;
}
.price-menu__section-lead {
  max-inline-size: 32em;
  margin-block-start: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.7;
}

/* 初回セクションのトーン:プライマリディープ強調 */
.price-menu__section--first .price-menu__section-header {
  border-block-color: var(--color-primary-deep);
  background-color: color-mix(in srgb, var(--color-primary-soft) 25%, var(--color-bg-alt));
  border-radius: var(--radius-md);
}
.price-menu__section--first .price-menu__section-jp {
  color: var(--color-primary-deep);
}

/* 正規セクションのトーン:ミュート */
.price-menu__section--regular .price-menu__section-header {
  border-block-color: var(--color-line-strong);
  border-block-style: dashed;
}
.price-menu__section--regular .price-menu__section-jp {
  color: var(--color-text);
  font-weight: var(--fw-semibold);
}
.price-menu__section--regular .price-menu__section-en {
  color: var(--color-text-sub);
}

/* --- セクション間の仕切り --- */
.price-menu__divider {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-block: var(--sp-12);
}
.price-menu__divider span {
  flex: 1;
  block-size: 1px;
  background-color: var(--color-line-strong);
}
.price-menu__divider .price-menu__divider-mark {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  padding: var(--sp-2) var(--sp-5);
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--color-primary);
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-line-strong);
  border-radius: var(--radius-full);
  letter-spacing: 0.08em;
  block-size: auto;
}

/* ==========================================================================
   カテゴリ群(脱毛 / エステ / フェイシャル / ボディメイク 等)
   ========================================================================== */

.price-menu__group {
  margin-block-end: var(--sp-8);
  background-color: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.price-menu__group:last-of-type {
  margin-block-end: 0;
}

.price-menu__group-header {
  padding: var(--sp-5) var(--sp-6);
  background-color: var(--color-primary);
  color: var(--color-text-invert);
  text-align: center;
}
/* 初回グループのヘッダはディープティールでアクセント */
.price-menu__group--first .price-menu__group-header {
  background-color: var(--color-primary-deep);
}
/* 正規グループのヘッダは標準プライマリ */
.price-menu__group--regular .price-menu__group-header,
.price-menu__group--catalog .price-menu__group-header {
  background-color: var(--color-primary);
}

.price-menu__group-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-sm);
  font-weight: var(--fw-regular);
  letter-spacing: 0.16em;
  opacity: 0.8;
  margin: 0 0 var(--sp-1);
}
.price-menu__group-title {
  font-family: var(--font-serif-jp);
  font-size: clamp(1.2rem, 2vw + 0.4rem, 1.6rem);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.24em;
  line-height: 1.2;
  margin: 0;
}
.price-menu__group-title small {
  font-size: 0.7em;
  letter-spacing: 0.08em;
  margin-inline-start: 0.3em;
  opacity: 0.85;
}
.price-menu__group-lead {
  margin: var(--sp-5) var(--sp-6) 0;
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  text-align: center;
}

/* --- 料金リスト --- */
.price-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.price-menu__item {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-6);
  border-block-start: 1px dashed var(--color-line);
}
.price-menu__item:first-child {
  border-block-start: none;
}
.price-menu__name {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  letter-spacing: 0.04em;
}
.price-menu__name small {
  font-size: 0.78em;
  font-weight: var(--fw-regular);
  color: var(--color-text-sub);
  margin-inline-start: 0.25em;
  letter-spacing: 0.02em;
}

/* --- 料金セル(初回 / 正規) --- */
.price-cell {
  display: inline-flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-md);
  align-self: flex-start;
}
.price-cell--first {
  background-color: color-mix(in srgb, var(--color-primary-soft) 35%, var(--color-bg-alt));
}
.price-cell--regular {
  background-color: var(--color-bg-sub);
}
.price-cell__amount {
  font-family: var(--font-serif-en);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.price-cell--first .price-cell__amount {
  font-size: var(--fs-xl);
  color: var(--color-primary-deep);
  font-weight: var(--fw-semibold);
}
.price-cell--regular .price-cell__amount {
  font-size: var(--fs-lg);
  color: var(--color-text);
  font-weight: var(--fw-medium);
}

/* --- PC: 名前を左、料金セルを右に並べる --- */
@media (min-width: 640px) {
  .price-menu__item {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-6);
    padding: var(--sp-5) var(--sp-8);
  }
  .price-menu__name {
    flex: 1 1 auto;
    font-size: var(--fs-lg);
  }
  .price-cell {
    flex: 0 0 auto;
    min-inline-size: 11rem;
    padding: var(--sp-3) var(--sp-5);
  }
}

/* --- 注意書き --- */
.price-menu__note {
  margin: 0;
  padding: var(--sp-4) var(--sp-6) var(--sp-6);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  background-color: var(--color-bg);
}

/* --- フェイシャル / ボディメイク カタログ(価格なし) --- */
.price-menu__group--catalog .price-menu__chips {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
  margin: 0;
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
}
.price-menu__group--catalog .price-menu__chips li {
  padding: 0.4em 1em;
  background-color: var(--color-bg-sub);
  color: var(--color-primary-deep);
  font-family: var(--font-serif-jp);
  font-size: var(--fs-base);
  letter-spacing: 0.06em;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-line);
}

/* --- 全体注釈 --- */
.price-menu__footnote {
  margin-block-start: var(--sp-12);
  padding: var(--sp-6);
  background-color: var(--color-bg);
  border-inline-start: 3px solid var(--color-primary-soft);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.price-menu__footnote p {
  margin: 0;
  padding-block: var(--sp-1);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.7;
}
.price-menu__footnote p + p {
  border-block-start: 1px dashed var(--color-line);
  padding-block-start: var(--sp-2);
  margin-block-start: var(--sp-2);
}
.price-menu__footnote strong {
  color: var(--color-primary-deep);
  font-weight: var(--fw-semibold);
}

/* ==========================================================================
   .price-compare — 4列比較テーブル: カテゴリ / メニュー / 初回 / 正規
   --------------------------------------------------------------------------
   PC: 横スクロールなしの 4 列フルテーブル
   モバイル: ヨコ最小限。カテゴリ列はコンパクト、価格列は折返さない
   ========================================================================== */

.price-compare__wrap {
  margin-block-start: var(--sp-10);
  background-color: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.price-compare {
  inline-size: 100%;
  border-collapse: collapse;
  font-family: var(--font-sans-jp);
}

/* --- ヘッダ行 --- */
.price-compare thead th {
  padding: var(--sp-4) var(--sp-3);
  background-color: var(--color-primary-deep);
  color: var(--color-text-invert);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  letter-spacing: 0.08em;
  text-align: start;
  border-block-end: 1px solid var(--color-primary-deep);
  white-space: nowrap;
}
.price-compare thead .price-compare__th-first,
.price-compare thead .price-compare__th-regular {
  text-align: end;
  width: 1%;
}
.price-compare thead .price-badge {
  background-color: var(--color-bg);
  color: var(--color-primary-deep);
  border-color: var(--color-bg);
}
.price-compare thead .price-badge--regular {
  background-color: transparent;
  color: var(--color-text-invert);
  border: 1px solid var(--color-bg);
}

/* --- 共通セル --- */
.price-compare td,
.price-compare tbody th {
  padding: var(--sp-4) var(--sp-3);
  border-block-start: 1px solid var(--color-line);
  vertical-align: middle;
  font-size: var(--fs-base);
  line-height: 1.5;
}

/* --- カテゴリ列(rowspan セル)--- */
.price-compare__cat {
  background-color: color-mix(in srgb, var(--color-primary-soft) 25%, var(--color-bg));
  border-inline-end: 1px solid var(--color-line);
  text-align: start;
  vertical-align: middle;
  padding: var(--sp-4);
  inline-size: 9rem;
  min-inline-size: 7rem;
}
.price-compare__cat-en {
  display: block;
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  color: var(--color-primary);
  margin-block-end: 0.25em;
}
.price-compare__cat-jp {
  display: block;
  font-family: var(--font-serif-jp);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-deep);
  letter-spacing: 0.08em;
  line-height: 1.3;
}
.price-compare__cat-jp small {
  display: block;
  font-size: 0.7em;
  font-weight: var(--fw-regular);
  letter-spacing: 0.04em;
  color: var(--color-text-sub);
  margin-block-start: 0.2em;
}

/* --- メニュー列 --- */
.price-compare__menu {
  font-family: var(--font-serif-jp);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  letter-spacing: 0.04em;
}
.price-compare__menu small {
  display: inline-block;
  margin-inline-start: 0.4em;
  font-size: 0.78em;
  font-weight: var(--fw-regular);
  color: var(--color-text-sub);
  letter-spacing: 0.02em;
}

/* --- 初回 / 正規 列 --- */
.price-compare__first,
.price-compare__regular {
  font-family: var(--font-serif-en);
  font-weight: var(--fw-semibold);
  text-align: end;
  white-space: nowrap;
  letter-spacing: 0.04em;
  width: 1%;
  padding-inline: var(--sp-5);
}
.price-compare__first {
  font-size: var(--fs-lg);
  color: var(--color-primary-deep);
  background-color: color-mix(in srgb, var(--color-primary-soft) 15%, var(--color-bg));
}
.price-compare__regular {
  font-size: var(--fs-lg);
  color: var(--color-text);
  background-color: var(--color-bg);
}
.price-compare__dash {
  color: var(--color-text-sub) !important;
  font-weight: var(--fw-regular);
  background-color: var(--color-bg-alt) !important;
}

/* --- グループ区切り(カテゴリの先頭行に強調線)--- */
.price-compare__row--group-start td,
.price-compare__row--group-start th {
  border-block-start: 2px solid var(--color-primary-deep);
}
.price-compare tbody tr:first-child td,
.price-compare tbody tr:first-child th {
  border-block-start: none;
}

/* --- ホバー(PCのみ)--- */
@media (hover: hover) {
  .price-compare tbody tr:hover .price-compare__menu,
  .price-compare tbody tr:hover .price-compare__first,
  .price-compare tbody tr:hover .price-compare__regular {
    background-color: color-mix(in srgb, var(--color-primary-soft) 18%, var(--color-bg));
    transition: background-color 120ms ease;
  }
}

/* --- モバイル最適化 --- */
@media (max-width: 600px) {
  .price-compare thead th,
  .price-compare td,
  .price-compare tbody th {
    padding: var(--sp-3) var(--sp-2);
    font-size: var(--fs-sm);
  }
  .price-compare__cat {
    inline-size: 5.5rem;
    min-inline-size: 5rem;
    padding: var(--sp-3) var(--sp-2);
  }
  .price-compare__cat-en {
    display: none;
  }
  .price-compare__cat-jp {
    font-size: var(--fs-sm);
    letter-spacing: 0.04em;
  }
  .price-compare__menu {
    font-size: var(--fs-sm);
  }
  .price-compare__menu small {
    display: block;
    margin-inline-start: 0;
    margin-block-start: 0.15em;
  }
  .price-compare__first,
  .price-compare__regular {
    font-size: var(--fs-base);
    padding-inline: var(--sp-2);
  }
}

/* ==========================================================================
   .price-menu__catalog — オーダーエステ内技術カタログ(価格なし)
   ========================================================================== */
.price-menu__catalog {
  margin-block-start: var(--sp-12);
  padding: var(--sp-8) var(--sp-6);
  background-color: var(--color-bg);
  border: 1px dashed var(--color-line-strong);
  border-radius: var(--radius-lg);
}
.price-menu__catalog-header {
  text-align: center;
  margin-block-end: var(--sp-7);
}
.price-menu__catalog-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-sm);
  letter-spacing: 0.18em;
  color: var(--color-primary);
  margin: 0 0 var(--sp-1);
}
.price-menu__catalog-title {
  font-family: var(--font-serif-jp);
  font-size: clamp(1.2rem, 2vw + 0.4rem, 1.6rem);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  color: var(--color-primary-deep);
  margin: 0 0 var(--sp-2);
}
.price-menu__catalog-lead {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  margin: 0;
}
.price-menu__catalog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}
@media (min-width: 720px) {
  .price-menu__catalog-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.price-menu__catalog-block h4 {
  font-family: var(--font-serif-jp);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.16em;
  color: var(--color-primary-deep);
  text-align: center;
  margin: 0 0 var(--sp-4);
  padding-block-end: var(--sp-3);
  border-block-end: 1px solid var(--color-line);
}

/* ==========================================================================
   .price-menu__columns — 左:初回 / 右:正規 の 2 カラム並列レイアウト
   --------------------------------------------------------------------------
   PC(1024px+): 2 カラムグリッド + 中央に縦ディバイダー
   タブレット(640-1023px): 2 カラム継続(ギャップ縮小)
   モバイル(〜639px): 1 カラム縦積み(初回 → 正規)
   ========================================================================== */

.price-menu__columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  margin-block-start: var(--sp-10);
}

@media (min-width: 900px) {
  .price-menu__columns {
    grid-template-columns: 1fr 1px 1fr;
    column-gap: var(--sp-8);
    align-items: stretch;
  }
  .price-menu__columns::before {
    content: "";
    grid-column: 2;
    grid-row: 1;
    inline-size: 1px;
    background: linear-gradient(
      to bottom,
      transparent 0%,
      var(--color-line-strong) 12%,
      var(--color-line-strong) 88%,
      transparent 100%
    );
    align-self: stretch;
  }
  .price-menu__column--first  { grid-column: 1; grid-row: 1; }
  .price-menu__column--regular { grid-column: 3; grid-row: 1; }
}

.price-menu__column {
  display: flex;
  flex-direction: column;
  min-inline-size: 0;
}

/* --- カラムヘッダー(該当カラムのラベル) --- */
.price-menu__column-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-2);
  padding: var(--sp-6) var(--sp-4) var(--sp-7);
  margin-block-end: var(--sp-7);
  border-radius: var(--radius-lg);
  position: relative;
}
.price-menu__column-header .price-badge--lg {
  margin-block-end: var(--sp-2);
}
.price-menu__column-en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: var(--fs-md);
  letter-spacing: 0.18em;
  margin: 0;
}
.price-menu__column-jp {
  font-family: var(--font-serif-jp);
  font-size: clamp(1.5rem, 2.4vw + 0.4rem, 2.1rem);
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  line-height: 1.3;
  margin: 0;
}
.price-menu__column-lead {
  max-inline-size: 26em;
  margin-block-start: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  line-height: 1.7;
}

/* 初回カラム: ディープティールのアクセントトーン */
.price-menu__column--first .price-menu__column-header {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-primary-soft) 35%, var(--color-bg)) 0%,
    var(--color-bg) 100%
  );
  border: 1px solid var(--color-primary-soft);
}
.price-menu__column--first .price-menu__column-en {
  color: var(--color-primary-deep);
}
.price-menu__column--first .price-menu__column-jp {
  color: var(--color-primary-deep);
}

/* 正規カラム: ミュートトーン */
.price-menu__column--regular .price-menu__column-header {
  background-color: var(--color-bg);
  border: 1px dashed var(--color-line-strong);
}
.price-menu__column--regular .price-menu__column-en {
  color: var(--color-text-sub);
}
.price-menu__column--regular .price-menu__column-jp {
  color: var(--color-text);
  font-weight: var(--fw-semibold);
}

/* カラム内のグループ:見やすく統一(価格セルのバッジは外して大きさで識別) */
.price-menu__column .price-cell {
  justify-content: flex-end;
}
.price-menu__column .price-cell--first {
  border: 1px solid color-mix(in srgb, var(--color-primary-deep) 25%, transparent);
}
.price-menu__column .price-cell--regular {
  border: 1px solid var(--color-line);
}

/* PC で 2 カラムになると料金セルの最小幅を絞る(1 カラム時は 11rem) */
@media (min-width: 900px) {
  .price-menu__column .price-cell {
    min-inline-size: 7.5rem;
  }
  .price-menu__column .price-menu__item {
    padding-inline: var(--sp-5);
  }
  .price-menu__column .price-menu__group-header {
    padding: var(--sp-4) var(--sp-5);
  }
}
