/* ===========================================================
   ProductLab — legal pages (Privacy / Terms)
   =========================================================== */

.legal-nav { position: sticky; top: 0; z-index: 50; background: rgba(241,245,251,.85); backdrop-filter: blur(14px) saturate(1.3); border-bottom: 1px solid var(--line); }
.legal-nav-inner { display:flex; align-items:center; justify-content:space-between; height:70px; }
.legal-nav .nav-right { display:flex; align-items:center; gap:18px; }
.legal-nav .back-link { font-size:15px; font-weight:600; color:var(--ink-2); display:inline-flex; align-items:center; gap:7px; transition:color .15s; }
.legal-nav .back-link:hover { color: var(--brand-deep); }
@media (max-width: 620px){ .legal-nav .back-link span { display:none; } }

/* hero */
.legal-hero { padding: 56px 0 40px; border-bottom: 1px solid var(--line); }
.legal-hero h1 { font-size: clamp(38px, 5vw, 58px); line-height:1.02; margin-top: 12px; }
.legal-hero .legal-date { font-family: var(--font-mono); font-size: 13.5px; color: var(--ink-3); margin-top: 18px; display:inline-flex; align-items:center; gap:8px; }
.legal-hero .legal-date .dot { width:6px; height:6px; border-radius:50%; background: var(--brand); }
.legal-hero .legal-intro { font-size: 18px; color: var(--ink-2); line-height:1.55; max-width: 70ch; margin-top: 18px; }

/* layout: sticky TOC + content */
.legal-layout { display:grid; grid-template-columns: 248px 1fr; gap: 56px; padding: 48px 0 90px; align-items:start; }
.legal-toc { position: sticky; top: 92px; }
.legal-toc-label { font-family: var(--font-mono); font-size: 12px; letter-spacing:.12em; text-transform:uppercase; color: var(--ink-4); font-weight:700; margin-bottom: 14px; }
.legal-toc a { display:block; font-size: 14px; color: var(--ink-3); padding: 7px 0 7px 14px; border-left: 2px solid var(--line-2); transition: color .15s, border-color .15s; line-height:1.35; }
.legal-toc a:hover { color: var(--brand-deep); border-left-color: var(--brand); }
.legal-toc a.active { color: var(--brand-deep); border-left-color: var(--brand); font-weight:600; }
@media (max-width: 900px){ .legal-layout { grid-template-columns: 1fr; gap: 0; } .legal-toc { display:none; } }

/* prose */
.legal-body { max-width: 760px; }
.legal-body h2 { font-size: 26px; margin: 44px 0 0; scroll-margin-top: 92px; letter-spacing:-.01em; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 { font-family: var(--font-display); font-size: 18px; margin: 28px 0 0; color: var(--ink); }
.legal-body p { font-size: 16px; line-height: 1.7; color: var(--ink-2); margin-top: 14px; }
.legal-body ul { margin: 14px 0 0; padding-left: 0; list-style: none; display:flex; flex-direction:column; gap: 12px; }
.legal-body li { position: relative; padding-left: 26px; font-size: 16px; line-height: 1.65; color: var(--ink-2); }
.legal-body li::before { content:""; position:absolute; left: 6px; top: 11px; width: 7px; height: 7px; border-radius: 2px; background: var(--brand); transform: rotate(45deg); }
.legal-body li strong, .legal-body p strong { color: var(--ink); font-weight: 700; }
.legal-body a { color: var(--brand-deep); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; text-decoration-color: var(--green-300); }
.legal-body a:hover { text-decoration-color: var(--brand); }
.legal-body .lead { font-size: 17px; color: var(--ink-2); }

/* callout (for arbitration / all-caps legal emphasis) */
.legal-callout { margin-top: 20px; padding: 20px 22px; border: 1px solid var(--line-2); border-left: 4px solid var(--brand); border-radius: 12px; background: var(--paper); }
.legal-callout p { margin-top: 0; font-size: 14.5px; line-height: 1.6; color: var(--ink-2); }
.legal-callout p + p { margin-top: 12px; }

/* table */
.legal-table-wrap { margin-top: 18px; overflow-x: auto; border: 1px solid var(--line); border-radius: 14px; }
.legal-table { width: 100%; border-collapse: collapse; font-size: 14px; min-width: 620px; }
.legal-table th { text-align: left; background: var(--cream-2); padding: 14px 16px; font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--ink); border-bottom: 1px solid var(--line); }
.legal-table td { padding: 14px 16px; border-bottom: 1px solid var(--line); color: var(--ink-2); line-height:1.5; vertical-align: top; }
.legal-table tr:last-child td { border-bottom: none; }
.legal-table td:not(:last-child) { border-right: 1px solid var(--line); }

/* contact card at end */
.legal-contact { margin-top: 40px; padding: 28px 30px; border-radius: 18px; background: var(--cream-2); display:flex; align-items:center; gap: 18px; flex-wrap: wrap; }
.legal-contact .lc-ic { width: 48px; height: 48px; border-radius: 13px; background: var(--brand-soft); display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.legal-contact h4 { font-size: 18px; }
.legal-contact p { font-size: 14.5px; color: var(--ink-2); margin-top: 4px; }
.legal-contact a { color: var(--brand-deep); font-weight: 700; }
