/* ===== Price Page Styles ===== */

.page-price {
  padding: var(--space-2xl) 0;
}

.page-price__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.page-price__title {
  text-align: center;
  margin-bottom: var(--space-xl);
}

/* タブナビ */
.price-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  justify-content: center;
  margin-bottom: var(--space-xl);
}

.price-tabs__tab {
  display: inline-block;
  padding: var(--space-xs) var(--space-md);
  font-size: var(--font-body-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  background: none;
  border: 1px solid var(--color-secondary-100);
  border-radius: var(--radius-full);
  text-decoration: none;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.price-tabs__tab:hover,
.price-tabs__tab--active {
  background-color: var(--color-primary-500);
  color: var(--color-text-inverse);
  border-color: var(--color-primary-500);
}

/* 料金セクション */
.price-section {
  margin-bottom: var(--space-2xl);
  scroll-margin-top: 120px;
}

.price-section__title {
  font-size: var(--font-h2);
  border-bottom: 2px solid var(--color-primary-500);
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-lg);
}

/* 料金テーブル */
.price-table {
  margin-bottom: var(--space-lg);
}

.price-table__name {
  font-size: var(--font-h4);
  margin-bottom: var(--space-sm);
}

.price-table__name a {
  color: var(--color-text-primary);
  text-decoration: none;
}

.price-table__name a:hover {
  color: var(--color-primary-500);
}

.price-table__table {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
}

.price-table__table thead {
  background-color: var(--color-secondary-700);
}

.price-table__table thead th {
  padding: 14px 16px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-inverse);
  text-align: left;
}

.price-table__table tbody tr {
  border-bottom: 1px solid var(--color-border);
}

.price-table__table tbody tr:nth-child(even) {
  background-color: var(--color-bg-cream);
}

.price-table__table tbody td {
  padding: 14px 16px;
  font-size: 14px;
  color: var(--color-text-body);
}

.price-table__table tbody tr:hover {
  background-color: var(--color-primary-100);
}

/* お支払い方法 */
.price-payment {
  margin-bottom: var(--space-xl);
  background-color: var(--color-bg-light);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}

.price-payment__title {
  font-size: var(--font-h3);
  margin-bottom: var(--space-md);
}

.price-payment__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.price-payment__list li {
  padding-left: var(--space-md);
  position: relative;
  font-size: var(--font-body-sm);
  color: var(--color-text-body);
}

.price-payment__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary-500);
}

/* 注意事項 */
.price-notice {
  margin-bottom: var(--space-xl);
}

.price-notice__title {
  font-size: var(--font-h3);
  margin-bottom: var(--space-md);
}

.price-notice__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.price-notice__list li {
  padding-left: var(--space-md);
  position: relative;
  font-size: var(--font-body-sm);
  color: var(--color-text-secondary);
}

.price-notice__list li::before {
  content: "※";
  position: absolute;
  left: 0;
  color: var(--color-text-secondary);
}

/* JS無効環境用フォールバック: noscriptでは全セクション表示 */
noscript ~ .page-price__inner .price-section[hidden] {
  display: block !important;
}

/* ===== SP: タブバーの sticky 化 + タップ領域の最適化 ===== */
@media (max-width: 767px) {
  .price-tabs {
    position: sticky;
    top: 60px; /* SPヘッダーの高さ（実装時に実測で調整） */
    z-index: 50;
    background-color: var(--color-bg-white);
    padding: var(--space-sm) var(--container-padding); /* 12px 16px */
    margin-left: calc(-1 * var(--container-padding));
    margin-right: calc(-1 * var(--container-padding));
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
    /* 既存の margin-bottom をリセットし再定義 */
    margin-bottom: var(--space-lg); /* 24px */
  }

  /* タップ領域 44px 以上を確保: 12 + 14*1.7 + 12 = 47.8px */
  .price-tabs__tab {
    padding: var(--space-sm) var(--space-md); /* 12px 16px */
  }

  /* タブがsticky状態時の視覚的フィードバック */
  .price-tabs.is-stuck {
    box-shadow: var(--shadow-md);
  }
}

/* ===== SP: カード型レイアウト変換 ===== */
/* テーブルのHTML構造はそのまま維持。CSSのみでカード表示に変換する */
/* 根拠: 美容クリニックSPの主流パターン。初回価格の訴求力を最大化 */

@media (max-width: 767px) {
  /* テーブル全体をブロック表示に */
  .price-table__table {
    display: block;
    border: none;
    border-radius: 0;
    overflow: visible;
  }

  /* thead: 視覚的に非表示、スクリーンリーダーには読ませる（sr-only パターン） */
  .price-table__table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  /* tbody: カードの縦並び */
  .price-table__table tbody {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm); /* 12px */
  }

  /* tr: 各行をグリッドカードに変換 */
  .price-table__table tbody tr {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto auto;
    gap: 0;
    background-color: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md); /* 8px */
    padding: 0;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
  }

  /* 偶数行のストライプ・ホバーをリセット（カード型では不要） */
  .price-table__table tbody tr:nth-child(even) {
    background-color: var(--color-bg-white);
  }

  .price-table__table tbody tr:hover {
    background-color: var(--color-bg-white);
  }

  /* td共通: ボーダーリセット */
  .price-table__table tbody td {
    padding: 0;
    font-size: inherit;
    border-bottom: none;
  }

  /* --- 1段目: 部位・内容（全幅） --- */
  .price-table__table tbody td:nth-child(1) {
    grid-column: 1 / -1;
    grid-row: 1;
    padding: var(--space-sm) var(--space-md); /* 12px 16px */
    background-color: var(--color-primary-50); /* #FAF6F1 */
    font-size: var(--font-body-sm); /* 14px */
    font-weight: 500;
    color: var(--color-text-primary); /* #2C3E50 */
    border-bottom: 1px solid var(--color-border);
    line-height: var(--lh-body-sm);
  }

  .price-table__table tbody td:nth-child(1)::before {
    content: "部位・内容";
    display: block;
    font-size: var(--font-caption); /* 12px */
    font-weight: 400;
    color: var(--color-text-secondary); /* #6C757D */
    margin-bottom: var(--space-3xs); /* 2px */
    letter-spacing: var(--ls-body);
  }

  /* --- 2段目左: 回数 --- */
  .price-table__table tbody td:nth-child(2) {
    grid-column: 1;
    grid-row: 2;
    padding: var(--space-sm) var(--space-md); /* 12px 16px */
    font-size: var(--font-body-sm); /* 14px */
    color: var(--color-text-body); /* #4A4A4A */
    border-right: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    line-height: var(--lh-body-sm);
  }

  .price-table__table tbody td:nth-child(2)::before {
    content: "回数";
    display: block;
    font-size: var(--font-caption); /* 12px */
    font-weight: 400;
    color: var(--color-text-secondary); /* #6C757D */
    margin-bottom: var(--space-3xs); /* 2px */
  }

  /* --- 2段目右: 通常価格 --- */
  .price-table__table tbody td:nth-child(3) {
    grid-column: 2;
    grid-row: 2;
    padding: var(--space-sm) var(--space-md); /* 12px 16px */
    font-size: var(--font-body-sm); /* 14px */
    font-weight: 500;
    color: var(--color-text-primary); /* #2C3E50 */
    border-bottom: 1px solid var(--color-border);
    line-height: var(--lh-body-sm);
  }

  .price-table__table tbody td:nth-child(3)::before {
    content: "通常価格（税込）";
    display: block;
    font-size: var(--font-caption); /* 12px */
    font-weight: 400;
    color: var(--color-text-secondary); /* #6C757D */
    margin-bottom: var(--space-3xs); /* 2px */
  }

  /* --- 3段目: 初回限定価格（全幅・強調） --- */
  .price-table__table tbody td:nth-child(4) {
    grid-column: 1 / -1;
    grid-row: 3;
    padding: var(--space-sm) var(--space-md); /* 12px 16px */
    background-color: var(--color-bg-cream); /* #FAF6F1 */
    text-align: center;
    font-size: var(--font-price); /* SP: 1.25rem = 20px */
    font-weight: 700;
    color: var(--color-accent-500); /* #C0392B */
  }

  .price-table__table tbody td:nth-child(4)::before {
    content: "初回限定価格（税込）";
    display: block;
    font-size: var(--font-caption); /* 12px */
    font-weight: 500;
    color: var(--color-accent-500); /* #C0392B */
    margin-bottom: var(--space-3xs); /* 2px */
    letter-spacing: var(--ls-body);
  }

  /* 初回価格が空の場合（ACFで未入力時） */
  .price-table__table tbody td:nth-child(4):empty {
    display: none;
  }
}
