/* ============================================================
   CUPPER — Legal / document pages (Terms, Privacy).
   Builds on cupper-ds.css tokens + cupper-components.css.
   Calm, readable long-form prose in the brand voice.
   ============================================================ */

.legal { padding: 56px 0 96px; }
@media (max-width: 720px){ .legal { padding: 40px 0 72px; } }

.legal-wrap { max-width: 760px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 720px){ .legal-wrap { padding: 0 20px; } }

/* ---------------- Document head ---------------- */
.legal-head { margin-bottom: 32px; padding-bottom: 28px; border-bottom: 1px solid var(--line-200); }
.legal-head .eyebrow-lp { margin-bottom: 14px; }
.legal-head h1 {
  font-family: var(--font-display); font-weight: 700; color: var(--ink-900);
  letter-spacing: -.015em; line-height: 1.06; text-wrap: balance;
  font-size: clamp(32px, 4.5vw, 46px); margin: 0;
}
.legal-meta { margin: 18px 0 0; display: flex; flex-direction: column; gap: 4px; font-size: 14.5px; color: var(--ink-600); }
.legal-meta b { color: var(--ink-800); font-weight: 700; }

/* draft / disclaimer banner (warm "low" tone, never alarming) */
.legal-note {
  display: flex; gap: 12px; align-items: flex-start; margin: 24px 0 0;
  padding: 14px 16px; border-radius: var(--r-md);
  background: var(--low-bg); border: 1px solid var(--low-border); color: var(--low-text);
  font-size: 14px; line-height: 1.55; text-wrap: pretty;
}
.legal-note svg { width: 20px; height: 20px; flex: none; color: var(--low-icon); margin-top: 1px; }

/* ---------------- Document body ---------------- */
.legal-body { color: var(--ink-700); font-size: 16px; line-height: 1.7; }
.legal-body h2 {
  font-family: var(--font-display); font-weight: 700; color: var(--ink-900);
  font-size: 21px; letter-spacing: -.01em; line-height: 1.25;
  margin: 40px 0 12px; scroll-margin-top: 90px;
}
.legal-body h2:first-child { margin-top: 24px; }
.legal-body p { margin: 0 0 14px; text-wrap: pretty; }
.legal-body ul { margin: 0 0 16px; padding-left: 22px; }
.legal-body li { margin: 0 0 8px; padding-left: 4px; }
.legal-body li::marker { color: var(--blue-300); }
.legal-body strong, .legal-body b { color: var(--ink-900); font-weight: 700; }
.legal-body a { color: var(--blue-600); text-decoration: underline; text-underline-offset: 2px; }
.legal-body a:hover { color: var(--blue-700); }

/* bracketed placeholders awaiting legal/operational input */
.legal-body code, code.ph {
  font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 13px;
  background: var(--surface-50); border: 1px solid var(--line-200);
  padding: 1px 6px; border-radius: 5px; color: var(--ink-700); white-space: nowrap;
}

/* back-to-home link under the document */
.legal-foot { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line-200); }
.legal-back { display: inline-flex; align-items: center; gap: 8px; color: var(--blue-700); font-weight: 600; text-decoration: none; font-size: 15px; }
.legal-back svg { width: 17px; height: 17px; transform: rotate(180deg); }
.legal-back:hover { color: var(--blue-600); }
