/* Deckyard website — Neon design system.
   Self-contained: tokens copied verbatim from the app's token contract.
   No raw hex outside this :root block. */

:root {
  --bg: #070711;
  --surface: #111126;
  --surface-warm: #1e1540;
  --fg: #f8f7ff;
  --fg-2: #d6ccff;
  --muted: #9d8ad4;
  --meta: #c084fc;
  --border: #34265e;
  --border-soft: #241c42;
  --accent: #c084fc;
  --accent-on: #13051f;
  --accent-hover: color-mix(in oklab, var(--accent), black 8%);
  --accent-active: color-mix(in oklab, var(--accent), black 14%);
  --success: #39ff88;
  --warn: #fff34d;
  --danger: #ff4d8d;

  --font-display: Inter, system-ui, sans-serif;
  --font-body: Inter, system-ui, sans-serif;
  --font-mono: "SF Mono", ui-monospace, Menlo, monospace;

  --text-xs: 12px;
  --text-sm: 14px;
  --text-base: 16px;
  --text-lg: 18px;
  --text-xl: 24px;
  --text-2xl: 36px;
  --text-3xl: 54px;
  --text-4xl: 76px;

  --leading-body: 1.52;
  --leading-tight: 1.06;
  --tracking-display: -0.025em;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-12: 48px;

  --section-y-desktop: 96px;
  --section-y-tablet: 68px;
  --section-y-phone: 48px;

  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-pill: 9999px;

  --elev-flat: none;
  --elev-ring: 0 0 0 1px var(--border);
  --elev-raised: 0 24px 80px rgba(192, 132, 252, 0.22);
  --focus-ring: 0 0 0 4px rgba(192, 132, 252, 0.32);

  --motion-fast: 150ms;
  --motion-base: 240ms;
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);

  --container-max: 1180px;
  --container-gutter-desktop: 36px;
  --container-gutter-tablet: 24px;
  --container-gutter-phone: 16px;

  --accent-soft: color-mix(in oklab, var(--accent) 14%, transparent);
  --accent-glow: color-mix(in oklab, var(--accent) 28%, transparent);
  --success-soft: color-mix(in oklab, var(--success) 16%, transparent);
  --warn-soft: color-mix(in oklab, var(--warn) 16%, transparent);
  --danger-soft: color-mix(in oklab, var(--danger) 16%, transparent);
  --fg-soft: color-mix(in oklab, var(--fg) 6%, transparent);
  --surface-2: color-mix(in oklab, var(--surface) 88%, white);
  --surface-3: color-mix(in oklab, var(--surface) 76%, white);
  --hairline: color-mix(in oklab, var(--border) 70%, transparent);
}

/* ---------- reset + base ---------- */

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);
  -webkit-font-smoothing: antialiased;
}

img, svg { display: block; }

a { color: inherit; }

:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: var(--radius-sm);
}

.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-gutter-desktop);
}

section { padding-block: var(--section-y-desktop); }

.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--meta);
  margin: 0 0 var(--space-4);
}

h1, h2, h3 {
  font-family: var(--font-display);
  letter-spacing: var(--tracking-display);
  line-height: var(--leading-tight);
  margin: 0;
  text-wrap: balance;
}

h1 { font-size: clamp(var(--text-2xl), 6vw, var(--text-4xl)); font-weight: 700; }
h2 { font-size: clamp(var(--text-xl), 4vw, var(--text-3xl)); font-weight: 650; }
h3 { font-size: var(--text-lg); font-weight: 600; }

.lead {
  font-size: var(--text-lg);
  color: var(--fg-2);
  max-width: 56ch;
  text-wrap: pretty;
}

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* ---------- buttons ---------- */

.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-pill);
  font: 600 var(--text-sm)/1.2 var(--font-body);
  text-decoration: none;
  border: 1px solid var(--border);
  color: var(--fg);
  background: var(--surface);
  transition: background var(--motion-fast) var(--ease-standard),
              border-color var(--motion-fast) var(--ease-standard),
              transform var(--motion-fast) var(--ease-standard);
}

.btn:hover { background: var(--surface-2); border-color: var(--muted); }
.btn:active { transform: translateY(1px); }

.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-on);
}

.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }

.btn-lg { padding: var(--space-4) var(--space-8); font-size: var(--text-base); }

/* ---------- nav ---------- */

.site-nav {
  position: sticky;
  top: 0;
  z-index: 10;
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border-soft);
}

.site-nav .container {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  height: 64px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-weight: 700;
  font-size: var(--text-lg);
  letter-spacing: var(--tracking-display);
  text-decoration: none;
}

.brand-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px; /* matches the icon tile's own corner curvature at this size */
}

.site-footer .brand-icon { width: 24px; height: 24px; border-radius: 6px; }

.nav-links {
  display: flex;
  gap: var(--space-6);
  margin-left: auto;
}

.nav-links a {
  text-decoration: none;
  font-size: var(--text-sm);
  color: var(--fg-2);
  transition: color var(--motion-fast) var(--ease-standard);
}

.nav-links a:hover { color: var(--fg); }

/* ---------- hero ---------- */

.hero { padding-block: calc(var(--section-y-desktop) + 24px) var(--section-y-desktop); position: relative; overflow: clip; }

.hero::before {
  /* the page's one glow flourish */
  content: "";
  position: absolute;
  top: -240px;
  left: 50%;
  translate: -50% 0;
  width: 880px;
  height: 560px;
  background: radial-gradient(closest-side, var(--accent-glow), transparent 70%);
  pointer-events: none;
}

.hero .container {
  position: relative;
  text-align: center;
}

.hero-below { display: flex; flex-direction: column; align-items: center; }

.hero p.lead { margin: 0 auto var(--space-8); max-width: 64ch; }

.hero-ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; align-items: center; justify-content: center; }

.hero-note {
  margin-top: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.dot-ok {
  width: 7px; height: 7px;
  border-radius: var(--radius-pill);
  background: var(--success);
  box-shadow: 0 0 8px var(--success-soft);
}

/* ---------- hero app mockup ---------- */

.app-mock {
  margin: var(--space-12) auto;
  max-width: 960px;
  text-align: left;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--elev-raised);
  overflow: clip;
  font-size: var(--text-xs);
  color: var(--fg-2);
}

.am-titlebar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-soft);
  background: var(--surface-2);
}

.am-dot {
  width: 10px; height: 10px;
  border-radius: var(--radius-pill);
  background: var(--border);
}

.am-title { margin-left: var(--space-3); color: var(--muted); letter-spacing: 0.08em; }

.am-body {
  display: grid;
  grid-template-columns: 148px 1fr 224px;
}

/* sidebar */

.am-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-4) var(--space-3);
  border-right: 1px solid var(--border-soft);
}

.am-side-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--muted);
}

.am-side-item svg { width: 14px; height: 14px; flex: none; }

.am-side-active {
  background: var(--accent-soft);
  color: var(--accent);
}

.am-side-status {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3) var(--space-4);
  margin-bottom: var(--space-3);
  color: var(--muted);
  border-bottom: 1px solid var(--border-soft);
}

.am-side-status .dot-ok { width: 6px; height: 6px; }

/* main column */

.am-main {
  display: flex;
  flex-direction: column;
  background: var(--bg);
}

.am-topbar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--border-soft);
}

.am-profile { color: var(--fg-2); }
.am-profile strong { color: var(--fg); font-weight: 600; }

.am-chip {
  padding: 2px var(--space-2);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-pill);
  color: var(--muted);
}

.am-top-actions { margin-left: auto; display: flex; gap: var(--space-2); }

.am-ghost-btn {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  color: var(--fg-2);
  font-weight: 600;
}

.am-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-2);
  padding: var(--space-5);
  max-width: 480px;
  width: 100%;
  margin-inline: auto;
}

.am-grid .key { border-radius: var(--radius-sm); }

.am-foot {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-soft);
}

.am-slider-group { display: flex; align-items: center; gap: var(--space-3); flex: 1; min-width: 0; }
.am-slider-label { color: var(--muted); }

.am-slider {
  flex: 1;
  max-width: 160px;
  height: 4px;
  border-radius: var(--radius-pill);
  background: var(--border-soft);
  position: relative;
}

.am-slider-fill {
  position: absolute;
  inset: 0 20% 0 0;
  border-radius: inherit;
  background: var(--muted);
}

.am-slider-fill::after {
  content: "";
  position: absolute;
  right: -5px;
  top: 50%;
  translate: 0 -50%;
  width: 10px; height: 10px;
  border-radius: var(--radius-pill);
  background: var(--fg);
}

.am-slider-val { color: var(--muted); }

.am-pages { display: flex; gap: var(--space-2); }

.am-page {
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-soft);
  color: var(--muted);
}

.am-page-active {
  border-color: var(--border);
  background: var(--surface-2);
  color: var(--fg);
}

/* inspector */

.am-inspect {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  border-left: 1px solid var(--border-soft);
}

.am-inspect-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.am-inspect-head strong { color: var(--fg); font-weight: 600; }

.am-field {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.am-field-label { color: var(--muted); }

.am-field-value {
  flex: 1;
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--fg);
  max-width: 140px;
}

.am-inspect-sub {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 10px;
  margin-top: var(--space-2);
}

.am-action {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  background: var(--bg);
}

.am-action-idx { color: var(--muted); }

.am-action-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.am-action-body strong { color: var(--fg); font-weight: 600; }
.am-action-body > span { color: var(--muted); display: flex; gap: var(--space-1); flex-wrap: wrap; }

.am-kbd {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 1px var(--space-2);
  border: 1px solid var(--border);
  border-bottom-width: 2px;
  border-radius: 5px;
  background: var(--surface-2);
  color: var(--fg-2);
}

.am-inspect-foot {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-soft);
}

.am-apply-btn {
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-pill);
  background: var(--accent);
  color: var(--accent-on);
  font-weight: 600;
}

/* device rendering (Home Assistant band) */

.device {
  background: linear-gradient(160deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--elev-raised);
}

.device-keys {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-3);
}

.key {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  background: var(--bg);
  border: 1px solid var(--border-soft);
  display: grid;
  place-items: center;
  color: var(--muted);
}

.key svg { width: 38%; height: 38%; }

.key-active {
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 0 24px var(--accent-glow);
}

.key-success { color: var(--success); }

.device-foot {
  margin-top: var(--space-6);
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted);
}

/* ---------- feature grid ---------- */

.features-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-12);
}

.feature-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  transition: border-color var(--motion-base) var(--ease-standard),
              transform var(--motion-base) var(--ease-standard);
}

.feature-card:hover { border-color: var(--border); transform: translateY(-2px); }

.feature-icon {
  width: 40px; height: 40px;
  border-radius: var(--radius-sm);
  background: var(--fg-soft);
  display: grid;
  place-items: center;
  color: var(--fg-2);
  margin-bottom: var(--space-5);
}

.feature-icon svg { width: 20px; height: 20px; }

.feature-card h3 { margin-bottom: var(--space-2); }
.feature-card p { margin: 0; color: var(--muted); font-size: var(--text-sm); }

/* ---------- workflow showcase ---------- */

.showcase { background: var(--surface); border-block: 1px solid var(--border-soft); }

.showcase-head { max-width: 60ch; margin-bottom: var(--space-12); }
.showcase-head p { color: var(--muted); }

.canvas {
  position: relative;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle, var(--hairline) 1px, transparent 1px) 0 0 / 24px 24px,
    var(--bg);
  height: 420px;
  overflow-x: auto;
  overflow-y: hidden;
}

.canvas-inner {
  position: relative;
  width: 1060px;
  height: 100%;
  margin-inline: auto;
}

.canvas-edges { position: absolute; inset: 0; width: 100%; height: 100%; }

.edge {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
  opacity: 0.85;
  stroke-dasharray: 6 6;
  animation: edge-flow 1.4s linear infinite;
}

@keyframes edge-flow { to { stroke-dashoffset: -24; } }

@media (prefers-reduced-motion: reduce) {
  .edge { animation: none; }
  html { scroll-behavior: auto; }
}

.node {
  position: absolute;
  width: 196px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
}

.node-head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border-soft);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.node-body { padding: var(--space-3); color: var(--fg-2); }

.node-cat {
  width: 8px; height: 8px;
  border-radius: 2px;
  background: var(--muted);
}

.node-cat.is-trigger { background: var(--accent); }
.node-cat.is-wait { background: var(--warn); }
.node-cat.is-ok { background: var(--success); }

.node .port {
  position: absolute;
  top: 50%;
  width: 9px; height: 9px;
  border-radius: var(--radius-pill);
  background: var(--bg);
  border: 2px solid var(--accent);
  translate: 0 -50%;
}

.port-in { left: -5px; }
.port-out { right: -5px; }

.node-status {
  position: absolute;
  top: -10px;
  right: var(--space-3);
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 1px var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--success-soft);
  color: var(--success);
  border: 1px solid color-mix(in oklab, var(--success) 40%, transparent);
}

.node-status.is-running {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: color-mix(in oklab, var(--accent) 40%, transparent);
}

/* ---------- local-first split ---------- */

.split .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.split-points { list-style: none; margin: var(--space-8) 0 0; padding: 0; display: grid; gap: var(--space-5); }

.split-points li { display: flex; gap: var(--space-4); align-items: baseline; }

.split-points .tick {
  font-family: var(--font-mono);
  color: var(--success);
  font-size: var(--text-sm);
}

.split-points strong { display: block; }
.split-points span:last-child { color: var(--muted); font-size: var(--text-sm); }

/* three-across variant for the local-first points (no side visual) */
.split-points-row {
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  margin-top: var(--space-12);
}

/* sections that sit on a raised band, like the workflow showcase */
.band { background: var(--surface); border-block: 1px solid var(--border-soft); }

.band .device { background: linear-gradient(160deg, var(--surface-3), var(--surface-2)); }

.device-keys-3 { grid-template-columns: repeat(3, 1fr); }

/* ---------- device compatibility ---------- */

.compat .lead { margin-bottom: var(--space-12); }

.compat-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  overflow-x: auto;
}

.compat-table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.compat-table th {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border);
}

.th-sub { text-transform: none; letter-spacing: 0; opacity: 0.7; }

.compat-table td {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border-soft);
  color: var(--fg-2);
}

.compat-table tbody tr:last-child td { border-bottom: none; }

.compat-table tbody tr:hover td { background: var(--fg-soft); }

.compat-table td:first-child { font-weight: 500; color: var(--fg); }

.td-sub {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--muted);
  margin-left: var(--space-2);
}

.pill {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px var(--space-3);
  border-radius: var(--radius-pill);
}

.pill-tested {
  color: var(--success);
  background: var(--success-soft);
  border: 1px solid color-mix(in oklab, var(--success) 40%, transparent);
}

.pill-untested {
  color: var(--muted);
  background: var(--fg-soft);
  border: 1px solid var(--border-soft);
}

.compat-note {
  margin-top: var(--space-6);
  font-size: var(--text-sm);
  color: var(--muted);
  max-width: 72ch;
  text-wrap: pretty;
}

/* ---------- download ---------- */

.download { text-align: center; }

.download .lead { margin: var(--space-6) auto var(--space-12); }

.dl-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  max-width: 640px;
  margin-inline: auto;
  text-align: left;
}

.dl-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.dl-card .feature-icon { margin-bottom: var(--space-4); }

.dl-card h3 { font-size: var(--text-base); }

.dl-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted);
  margin: 0 0 var(--space-5);
}

.dl-card .btn { margin-top: auto; justify-content: center; }

/* coming-soon placeholder shown while the download grid above is commented out */

.dl-soon {
  max-width: 520px;
  margin-inline: auto;
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.dl-soon-pill {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-pill);
  padding: var(--space-1) var(--space-3);
}

.dl-soon p {
  margin: 0;
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: var(--leading-body);
}

/* ---------- footer ---------- */

.site-footer {
  border-top: 1px solid var(--border-soft);
  padding-block: var(--space-12);
}

.site-footer .container {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.site-footer .brand { font-size: var(--text-base); }

.footer-links { display: flex; gap: var(--space-6); margin-left: auto; }

.footer-links a {
  font-size: var(--text-sm);
  color: var(--muted);
  text-decoration: none;
}

.footer-links a:hover { color: var(--fg); }

.footer-fine {
  width: 100%;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted);
  margin-top: var(--space-4);
}

/* ---------- legal pages (privacy, terms) ----------
   Drop raw paragraphs/headings/lists into .legal-body and they
   pick up this styling automatically — no classes required. */

.legal { padding-block: var(--section-y-desktop); }

.legal .container { max-width: 760px; }

.legal-updated {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted);
  margin: var(--space-4) 0 0;
}

.legal-body { margin-top: var(--space-12); }

.legal-body h2 {
  font-size: var(--text-xl);
  margin: var(--space-12) 0 var(--space-4);
}

.legal-body h3 {
  margin: var(--space-8) 0 var(--space-3);
}

.legal-body p {
  color: var(--fg-2);
  margin: 0 0 var(--space-5);
  max-width: 70ch;
  text-wrap: pretty;
}

.legal-body ul, .legal-body ol {
  color: var(--fg-2);
  margin: 0 0 var(--space-5);
  padding-left: var(--space-6);
  display: grid;
  gap: var(--space-2);
}

.legal-body a { color: var(--accent); }

.legal-body strong { color: var(--fg); }

.legal-body blockquote {
  margin: 0 0 var(--space-5);
  padding: var(--space-4) var(--space-6);
  border-left: 2px solid var(--border);
  color: var(--muted);
}

.legal-placeholder {
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  color: var(--muted);
  font-size: var(--text-sm);
}

/* ---------- responsive ---------- */

@media (max-width: 980px) {
  .container { padding-inline: var(--container-gutter-tablet); }
  section { padding-block: var(--section-y-tablet); }
  .split .container { grid-template-columns: 1fr; }
  .split-points-row { grid-template-columns: 1fr; gap: var(--space-5); }
  .split .device { max-width: 420px; }
  .features-grid { grid-template-columns: 1fr 1fr; }
  .dl-grid { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .am-body { grid-template-columns: 148px 1fr; }
  .am-inspect { display: none; }
}

@media (max-width: 620px) {
  .container { padding-inline: var(--container-gutter-phone); }
  section { padding-block: var(--section-y-phone); }
  .features-grid { grid-template-columns: 1fr; }
  .device { padding: var(--space-5); }
  .am-body { grid-template-columns: 1fr; }
  .am-side { display: none; }
  .am-chip, .am-top-actions { display: none; }
  .am-grid { padding: var(--space-4); }
}
