/* ============================================================
   Mabel Inbox — legal pages (Privacy Policy, Terms of Service)
   Same token sheet + type as the landing page. Readable measure,
   calm and plain. Imports the landing stylesheet for tokens and
   the shared .btn/.topbar vocabulary, then adds prose styling.
   ============================================================ */
@import url('landing.css');

.legal { background: var(--color-bg); min-height: 100vh; container-type: inline-size; }

/* slim header */
.legal-top { position: sticky; top: 0; z-index: 30; background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(8px); border-bottom: 1px solid var(--color-border); }
.legal-top .wrap { display: flex; align-items: center; gap: 12px; padding: 14px 32px; max-width: 880px; margin: 0 auto; }
.legal-top .wm { height: 28px; display: block; }
.legal-top .spacer { flex: 1; }
.legal-back { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; font-size: var(--text-sm);
  font-weight: 500; color: var(--color-text-secondary); padding: 6px 10px; border-radius: var(--radius-sm); white-space: nowrap;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.legal-back:hover { color: var(--color-accent-strong); background: var(--color-surface-sunken); }

/* document column */
.legal-body { max-width: 1000px; margin: 0 auto; padding: clamp(40px, 7vh, 72px) 32px clamp(56px, 8vh, 88px);
  display: grid; grid-template-columns: 1fr; gap: 0; }
.legal-head { grid-column: 1 / -1; }

/* layout wrapper that splits TOC + article once the doc starts */
.legal-cols { grid-column: 1 / -1; display: grid; grid-template-columns: 232px minmax(0, 1fr); gap: 56px; align-items: start; }
.legal-article { min-width: 0; }

/* sticky table of contents */
.legal-toc { position: sticky; top: 84px; align-self: start; }
.legal-toc .toc-label { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-text-tertiary); margin: 0 0 12px; padding-left: 11px; }
.legal-toc ol { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1px;
  border-left: 1px solid var(--color-border); }
.legal-toc li { padding: 0; }
.legal-toc a { display: block; font-size: var(--text-xs); line-height: 16px; color: var(--color-text-tertiary);
  text-decoration: none; padding: 6px 12px; margin-left: -1px; border-left: 2px solid transparent;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.legal-toc a:hover { color: var(--color-text-secondary); }
.legal-toc a.active { color: var(--color-accent-strong); border-left-color: var(--color-accent-strong); font-weight: 500; }
.legal-eyebrow { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-accent-strong); margin-bottom: 16px; }
.legal-body h1 { font-weight: 700; letter-spacing: -0.025em; line-height: 1.08; color: var(--color-text-primary);
  font-size: clamp(30px, 4cqw, 42px); margin: 0; text-wrap: balance; }
.legal-meta { display: flex; flex-wrap: wrap; gap: 6px 18px; margin: 18px 0 0; padding-bottom: 28px;
  border-bottom: 1px solid var(--color-border); }
.legal-meta span { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-text-tertiary); white-space: nowrap; }
.legal-meta b { color: var(--color-text-secondary); font-weight: 500; }

.legal-body h2 { font-weight: 700; letter-spacing: -0.015em; line-height: 1.2; color: var(--color-text-primary);
  font-size: var(--text-xl); margin: 44px 0 14px; scroll-margin-top: 76px; }
.legal-article > h2:first-child { margin-top: 0; }
.legal-body p { font-size: 16px; line-height: 27px; color: var(--color-text-secondary); margin: 0 0 16px; }
.legal-body p strong, .legal-body li strong { color: var(--color-text-primary); font-weight: 600; }
.legal-body a { color: var(--color-accent-strong); text-decoration: underline; text-underline-offset: 2px;
  text-decoration-thickness: 1px; }
.legal-body a:hover { text-decoration-thickness: 2px; }
.legal-body ul, .legal-body ol { margin: 0 0 16px; padding-left: 22px; display: flex; flex-direction: column; gap: 9px; }
.legal-body li { font-size: 16px; line-height: 26px; color: var(--color-text-secondary); padding-left: 4px; }
.legal-body li::marker { color: var(--color-text-tertiary); }
.legal-body blockquote { margin: 0 0 18px; padding: 14px 18px; background: var(--color-accent-subtle);
  border-radius: var(--radius-md); }
.legal-body blockquote p { margin: 0; color: var(--color-accent-ink); font-size: var(--text-sm); line-height: 22px; }

/* inline code: literals (domain, OAuth scopes) get a neutral chip;
   author placeholders ([ … ]) get a warning tint so they're easy to find + fill */
.legal-body code { font-family: var(--font-mono); font-size: 0.86em; background: var(--color-surface-sunken);
  color: var(--color-text-secondary); padding: 1px 6px; border-radius: 4px; word-break: break-word; }
.legal-body code.ph { background: var(--color-warning-subtle); color: var(--color-warning); }

/* footer */
.legal-foot { border-top: 1px solid var(--color-border); }
.legal-foot .wrap { max-width: 880px; margin: 0 auto; padding: 26px 32px; display: flex; align-items: center;
  gap: 12px 18px; flex-wrap: wrap; }
.legal-foot .wm { height: 22px; display: block; opacity: 0.9; }
.legal-foot .tag { font-size: var(--text-sm); color: var(--color-text-secondary); }
.legal-foot nav { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.legal-foot nav a { font-size: var(--text-sm); font-weight: 500; color: var(--color-text-secondary);
  text-decoration: none; }
.legal-foot nav a:hover { color: var(--color-accent-strong); }
.legal-foot nav a[aria-current="page"] { color: var(--color-accent-strong); }

@container (max-width: 860px) {
  .legal-cols { grid-template-columns: 1fr; gap: 0; }
  .legal-toc { position: static; top: auto; margin-bottom: 36px; padding: 16px 16px 8px; background: var(--color-surface-sunken);
    border-radius: var(--radius-md); }
  .legal-toc ol { border-left: none; gap: 0; }
  .legal-toc a { border-left: none; padding: 7px 0; }
  .legal-toc a.active { border-left: none; }
}

@container (max-width: 760px) {
  .legal-top .wrap, .legal-foot .wrap { padding-left: 20px; padding-right: 20px; }
  .legal-body { padding-left: 20px; padding-right: 20px; }
}
