/* =====================================================================
   トレマネ LP — 法務ページ共通スタイル（利用規約 / プライバシーポリシー /
   お問い合わせ / 特定商取引法に基づく表記）

   - lp/styles.css の design token / 共通クラス（.site-header, .site-footer,
     .btn, .container 等）を再利用し、ここでは法務本文のタイポグラフィのみ補う。
   - 配信は Firebase Hosting（toremane.com/terms/ 等、guide と同じ要領）。
   - アプリ内 WebView（端末幅 = 狭い）と LP からの閲覧の両方を想定し
     モバイルファーストで読みやすさを最優先。
   ===================================================================== */

/* ---- ヘッダー右の「ホーム」ボタンの間隔 ---- */
.site-header .header-home { margin-left: auto; }

/* ---- ヒーロー（ページ見出し帯）---------------------------------------- */
.legal-hero { background: var(--hero-grad); color: #fff; padding: 56px 0 46px; }
.legal-hero .container { max-width: 860px; }
.legal-hero .eyebrow { margin-bottom: 14px; }
.legal-hero h1 { font-size: clamp(26px, 5vw, 40px); line-height: 1.25; color: #fff; margin: 0 0 12px; }
.legal-hero__sub { color: var(--muted-on-dark); font-size: clamp(14.5px, 2.2vw, 16px); line-height: 1.85; margin: 0; max-width: 60ch; }
.legal-hero__date {
  display: inline-block; margin-top: 18px; font-size: 12.5px; font-weight: 700;
  letter-spacing: .03em; color: #fff; background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.26); padding: 6px 13px; border-radius: 999px;
}

/* ---- 本文ラッパ ------------------------------------------------------- */
.legal { background: var(--bg); padding: 44px 0 72px; }
.legal .container { max-width: 860px; }
.legal__lead { color: var(--muted); font-size: 15.5px; line-height: 1.9; margin: 0 0 8px; }

/* ---- 目次（任意。条数が多い規約/プライバシー用）---------------------- */
.legal-toc {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-card); box-shadow: var(--shadow-card);
  padding: 18px 20px; margin: 24px 0 8px;
}
.legal-toc__title { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--primary-dark); margin: 0 0 12px; }
.legal-toc ol { margin: 0; padding-left: 1.3em; display: grid; gap: 7px; }
.legal-toc a { color: var(--text); text-decoration: none; font-size: 14.5px; }
.legal-toc a:hover { color: var(--primary-dark); text-decoration: underline; }

/* ---- セクション ------------------------------------------------------- */
.legal-section { margin-top: 40px; }
.legal-section[id] { scroll-margin-top: 80px; }
.legal-section > h2 {
  font-size: clamp(18px, 3.2vw, 22px); color: var(--navy); line-height: 1.4;
  margin: 0 0 16px; padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.legal-section > h3 { font-size: 16px; color: var(--navy); margin: 24px 0 10px; }

/* 本文要素 */
.legal p { margin: 0 0 14px; font-size: 15px; line-height: 1.95; }
.legal ul, .legal ol { margin: 0 0 14px; padding-left: 1.4em; }
.legal li { margin: 0 0 9px; font-size: 15px; line-height: 1.9; }
.legal li > ul, .legal li > ol { margin-top: 9px; }
.legal a { color: var(--primary-dark); text-decoration: underline; text-underline-offset: 2px; overflow-wrap: anywhere; }
.legal strong { color: var(--navy); font-weight: 700; }
.legal small { color: var(--muted); font-size: 13px; }

/* ---- 表（第三者サービス一覧 / 特商法の項目表）------------------------ */
.legal-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 0 0 16px; }
.legal-table { width: 100%; border-collapse: collapse; font-size: 14px; min-width: 460px; }
.legal-table th, .legal-table td {
  border: 1px solid var(--border); padding: 11px 13px; text-align: left;
  vertical-align: top; line-height: 1.7;
}
.legal-table thead th { background: var(--surface-2); color: var(--navy); font-weight: 700; }
.legal-table th[scope="row"] { background: var(--surface-2); color: var(--navy); font-weight: 700; white-space: nowrap; width: 30%; }
.legal-table td { background: var(--surface); }

/* 特商法など「項目：内容」の縦長テーブルは狭幅で横スクロール不要にする */
.legal-table--rows { min-width: 0; }
@media (max-width: 560px) {
  .legal-table--rows, .legal-table--rows tbody, .legal-table--rows tr, .legal-table--rows th, .legal-table--rows td { display: block; width: 100%; }
  .legal-table--rows th[scope="row"] { border-bottom: 0; padding-bottom: 4px; }
  .legal-table--rows td { border-top: 0; padding-top: 4px; margin-bottom: 4px; }
}

/* ---- コールアウト（ベータ注記 / オプトアウト手順など）--------------- */
.legal-callout {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px 16px; margin: 0 0 16px;
}
.legal-callout p:last-child { margin-bottom: 0; }
.legal-callout__title { font-weight: 700; color: var(--navy); margin: 0 0 6px; font-size: 14.5px; }

/* ---- CTA（お問い合わせのフォームボタンなど）------------------------- */
.legal-cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin: 4px 0 22px; }

/* お問い合わせフォームの埋め込み */
.form-embed {
  border: 1px solid var(--border); border-radius: var(--radius-card);
  overflow: hidden; box-shadow: var(--shadow-card); background: var(--surface);
}
.form-embed iframe { display: block; width: 100%; min-height: 1100px; border: 0; }

/* ---- ドキュメント末尾の制定/改定メタ ------------------------------- */
.legal-meta { margin-top: 48px; padding-top: 22px; border-top: 1px solid var(--border); color: var(--muted); font-size: 13.5px; line-height: 1.9; }
.legal-meta p { margin: 0 0 4px; font-size: 13.5px; }

/* ---- レスポンシブ ---------------------------------------------------- */
@media (max-width: 640px) {
  .legal-hero { padding: 44px 0 36px; }
  .legal { padding: 32px 0 56px; }
}
