/* ============================================================
   Crumb VMS coming-soon site styles
   Tokens live in tokens.css. This file only composes them.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  background:var(--bg-app);
  color:var(--text-primary);
  font:var(--type-body);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--accent)}
strong{color:var(--text-strong);font-weight:600}
.mono{font-family:var(--font-mono)}
.amber{color:var(--accent)}

.container{max-width:var(--container-max);margin:0 auto;padding:0 32px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font:var(--type-eyebrow);
  letter-spacing:var(--tracking-caps);
  text-transform:uppercase;
  color:var(--text-faint);
  margin-bottom:18px;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--status-live);box-shadow:0 0 10px var(--status-live)}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-ui);font-weight:var(--weight-semibold);font-size:14px;
  border-radius:var(--radius-sm);padding:10px 18px;
  border:1px solid transparent;cursor:pointer;
  transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  text-decoration:none;
  line-height:1;
}
.btn-sm{padding:8px 14px;font-size:13px}
.btn-lg{padding:14px 22px;font-size:15px}
.btn-primary{background:var(--accent);color:var(--text-on-accent)}
.btn-primary:hover{background:var(--accent-hover)}
.btn-primary:active{background:var(--accent-press);transform:translateY(1px)}
.btn-ghost{background:transparent;color:var(--text-primary);border-color:var(--border-default)}
.btn-ghost:hover{border-color:var(--border-strong);background:var(--surface-panel)}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;
  background:linear-gradient(180deg, var(--bg-app) 60%, rgba(21,22,26,0.6) 100%);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border-soft);
}
.nav .brand{display:flex;align-items:center}
.nav-links{display:flex;align-items:center;gap:28px;font-size:14px;color:var(--text-muted)}
.nav-links a:hover{color:var(--text-primary)}
@media (max-width:900px){
  .nav{padding:14px 20px}
  .nav-links{display:none}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:64px 0 96px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 82% -8%, rgba(232,163,61,.12), transparent 50%),
    radial-gradient(80% 60% at 10% 90%, rgba(232,163,61,.05), transparent 50%);
  z-index:0;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-soft) 1px, transparent 1px);
  background-size:64px 64px;opacity:.25;
  mask-image:radial-gradient(80% 70% at 50% 30%, #000 30%, transparent 80%);
}
.hero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:minmax(380px, 0.92fr) 1.08fr;
  gap:56px;align-items:center;
}
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
}

.hero-copy h1{
  font-family:var(--font-display);
  font-weight:var(--weight-bold);
  font-size:clamp(48px, 6.4vw, 88px);
  line-height:.95;
  letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
}
.lede{
  font-size:18px;
  line-height:1.6;
  color:var(--text-muted);
  max-width:48ch;
  margin:22px 0 28px;
}

/* signup form */
.notify{
  display:flex;gap:10px;flex-wrap:wrap;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  padding:8px;
  border-radius:var(--radius-md);
  max-width:520px;
}
.notify input[type=email]{
  flex:1;min-width:200px;
  background:transparent;border:0;outline:0;
  color:var(--text-primary);
  font:var(--type-body);
  padding:10px 12px;
}
.notify input[type=email]::placeholder{color:var(--text-faint)}
.notify:focus-within{border-color:var(--accent);box-shadow:var(--glow-accent)}
.notify-foot{
  margin-top:10px;
  font-size:11px;
  letter-spacing:.06em;
  color:var(--text-faint);
}

.notify-large{max-width:560px;margin:8px auto 0}
.notify-confirm{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;
  color:var(--text-strong);
  font-family:var(--font-mono);font-size:13px;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  max-width:560px;
  margin:0 auto;
}
.notify-confirm{
  display:block;line-height:1.55;
}
.notify-confirm strong{color:var(--accent);font-weight:var(--weight-medium)}
.notify-confirm .confirm-dot{
  display:inline-block;
  width:8px;height:8px;border-radius:50%;
  background:var(--status-live);box-shadow:0 0 10px var(--status-live);
  margin-right:8px;vertical-align:middle;
}
.notify-confirm .confirm-fallback{
  color:var(--text-faint);font-size:12px;
}
.notify-confirm .confirm-fallback a{
  color:var(--accent);border-bottom:1px dotted var(--accent);
}
button[disabled]{opacity:.7;cursor:wait}

/* spec row under hero CTA */
.specs{display:flex;gap:36px;margin-top:38px;flex-wrap:wrap}
.spec{display:flex;flex-direction:column;gap:4px}
.spec .n{font-family:var(--font-mono);font-size:24px;color:var(--text-strong);font-weight:var(--weight-medium)}
.spec .l{font-size:12px;color:var(--text-faint);letter-spacing:.04em}

/* ---------- Hero art: framed real screenshot ---------- */
.hero-art{position:relative}
.hero-shot{
  margin:0;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg), 0 0 0 1px rgba(232,163,61,.08), 0 0 60px rgba(232,163,61,.06);
  position:relative;
}
.hero-shot-chrome{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--bg-sunken);
  border-bottom:1px solid var(--border-soft);
}
.hero-shot-chrome .dot-r,
.hero-shot-chrome .dot-y,
.hero-shot-chrome .dot-g{
  width:10px;height:10px;border-radius:50%;
}
.hero-shot-chrome .dot-r{background:#e5484d}
.hero-shot-chrome .dot-y{background:#e8a33d}
.hero-shot-chrome .dot-g{background:#4fb477}
.hero-shot-title{
  margin-left:14px;font-size:11px;
  color:var(--text-faint);letter-spacing:.08em;
}
.hero-shot img{
  display:block;width:100%;height:auto;
}

/* ---------- Timeline band (full-width real screenshot) ---------- */
.timeline-band{
  padding:64px 0 32px;
  border-top:1px solid var(--border-soft);
  background:var(--bg-sunken);
}
.timeline-band-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
}
@media (max-width:1000px){
  .timeline-band-inner{grid-template-columns:1fr;gap:28px}
}
.timeline-band-h{
  font-family:var(--font-display);
  font-size:clamp(26px,2.8vw,38px);
  font-weight:var(--weight-bold);
  line-height:1.05;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  max-width:18ch;
}
.timeline-band-p{
  margin-top:14px;color:var(--text-muted);
  font-size:16px;line-height:1.65;max-width:54ch;
}
.timeline-band-shot{
  margin:0;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.timeline-band-shot img{display:block;width:100%;height:auto}

/* ---------- Read-more disclosure (Why + Full Transparency) ---------- */
.readmore{
  margin-top:14px;
}
.readmore > summary{
  cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;
  border:1px solid var(--border-default);
  border-radius:var(--radius-sm);
  color:var(--text-primary);
  font-family:var(--font-ui);font-weight:var(--weight-semibold);font-size:13px;
  background:var(--surface-panel);
  list-style:none;
  transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out);
  user-select:none;
}
.readmore > summary::-webkit-details-marker{display:none}
.readmore > summary::marker{content:""}
.readmore > summary::after{content:"↓";opacity:.7;font-family:var(--font-mono);font-size:12px}
.readmore[open] > summary::after{content:"↑"}
.readmore > summary:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:rgba(232,163,61,.06);
}
.readmore[open] > summary{margin-bottom:18px}
/* Section-tinted variants so each location feels at home */
.why-prose .readmore > summary{margin-left:0}
.status-prose .readmore > summary{margin-top:4px}

/* ---------- Why band (origin story, centered narrative) ---------- */
.why-band{padding:88px 0}
.why-inner{
  max-width:760px;margin:0 auto;text-align:left;
}
.why-h{
  max-width:24ch;
  font-size:clamp(30px, 3.6vw, 48px);
  line-height:1.05;
  margin-bottom:28px;
}
.why-prose p{
  font-size:17px;line-height:1.75;
  color:var(--text-primary);
  max-width:62ch;
  margin-bottom:20px;
}
.why-prose p.why-emph{
  position:relative;
  padding:18px 22px 18px 26px;
  background:linear-gradient(90deg, rgba(232,163,61,.07), rgba(232,163,61,0) 80%);
  border-left:3px solid var(--accent);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
  color:var(--text-strong);
  margin:8px 0 24px;
}
.why-prose p.why-emph strong{color:var(--accent);font-weight:var(--weight-semibold)}
.why-prose p.why-close{
  font-family:var(--font-display);
  font-size:18px;
  color:var(--text-strong);
  font-style:italic;
  margin-top:8px;
}

/* ---------- Status band (honest "where we are") ---------- */
.status-band .section-h{max-width:24ch}
.eyebrow .dot-amber{background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}
.status-grid{
  display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:start;
  margin-top:32px;
}
@media (max-width:900px){.status-grid{grid-template-columns:1fr;gap:28px}}
.status-prose p{
  font-size:17px;line-height:1.7;color:var(--text-primary);
  max-width:62ch;margin-bottom:18px;
}
.status-prose .status-h3{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:16px;color:var(--text-strong);
  letter-spacing:.02em;
  margin:32px 0 10px;
  padding-bottom:6px;
  border-bottom:1px solid var(--border-soft);
  max-width:62ch;
}
.status-prose .status-h3:first-child{margin-top:0}
.status-prose p.status-emph{
  border-left:3px solid var(--accent);
  padding:8px 0 8px 18px;
  background:linear-gradient(90deg, rgba(232,163,61,.05), transparent 80%);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  color:var(--text-primary);
}
.status-prose p.status-foot{
  margin-top:24px;
  padding-top:18px;
  border-top:1px dashed var(--border-soft);
  color:var(--text-muted);
  font-size:15px;
  line-height:1.65;
}
.status-prose strong{color:var(--text-strong)}
.status-meta{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:24px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-md);
}
.status-row{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:16px;border-bottom:1px dashed var(--border-soft);padding-bottom:12px;
}
.status-row:last-child{border-bottom:0;padding-bottom:0}
.status-key{
  font-size:10px;color:var(--text-faint);
  letter-spacing:.14em;text-transform:uppercase;
  flex-shrink:0;
}
.status-val{
  font-size:13px;color:var(--text-primary);
  text-align:right;line-height:1.5;
}

/* ---------- Reference setup band ---------- */
.setup-band .section-h{max-width:24ch}
.setup-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  margin-top:16px;margin-bottom:32px;
}
@media (max-width:900px){.setup-grid{grid-template-columns:1fr}}
.setup-card{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:24px 26px;
  margin:0;
}
.setup-card-head{margin-bottom:14px}
.setup-key{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);
  display:block;margin-bottom:6px;
}
.setup-card-h{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);margin:0;
}
.spec-list{margin:0;display:flex;flex-direction:column;gap:0}
.spec-row{
  display:grid;grid-template-columns:90px 1fr;gap:14px;
  padding:10px 0;
  border-top:1px dashed var(--border-soft);
}
.spec-row:first-child{border-top:0}
.spec-row dt{
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-faint);
  padding-top:2px;
}
.spec-row dd{
  margin:0;font-size:13.5px;line-height:1.55;
  color:var(--text-primary);
}
.spec-tbd{
  font-family:var(--font-mono);font-size:11px;
  color:var(--accent);opacity:.85;
  padding:1px 6px;border:1px dashed rgba(232,163,61,.4);border-radius:var(--radius-xs);
}
.setup-block{
  margin-top:32px;
  padding-top:32px;
  border-top:1px solid var(--border-soft);
}
.setup-block .eyebrow{margin-bottom:10px}
.setup-h3{
  font-family:var(--font-display);font-weight:var(--weight-bold);
  font-size:clamp(20px,2.2vw,28px);
  line-height:1.1;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  max-width:28ch;
  margin-bottom:16px;
}
.setup-block p{
  font-size:15px;line-height:1.65;color:var(--text-primary);
  max-width:72ch;margin-bottom:14px;
}
.setup-block p strong{color:var(--text-strong)}
.bench-table-wrap{
  overflow-x:auto;
  margin:18px 0 22px;
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  background:var(--surface-panel);
}
.bench-table{
  width:100%;border-collapse:collapse;
  font-size:13.5px;
}
.bench-table th,.bench-table td{
  padding:10px 14px;
  text-align:left;
  border-bottom:1px solid var(--border-soft);
  color:var(--text-primary);
}
.bench-table th{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-faint);
  background:var(--surface-well);
  font-weight:var(--weight-medium);
}
.bench-table tr:last-child td{border-bottom:0}
.bench-table .bench-delta{color:var(--accent)}
.bench-table td:nth-child(2),
.bench-table td:nth-child(3),
.bench-table td:nth-child(4),
.bench-table th:nth-child(2),
.bench-table th:nth-child(3),
.bench-table th:nth-child(4){
  font-family:var(--font-mono);
}

/* ---------- Testers band ---------- */
.testers-band .section-h{max-width:24ch}
.testers-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;
  margin-top:16px;
}
@media (max-width:900px){.testers-grid{grid-template-columns:1fr;gap:32px}}
.testers-h{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);
  margin-bottom:16px;
}
.req-list{
  list-style:none;display:flex;flex-direction:column;gap:12px;
}
.req-list li{
  position:relative;padding-left:22px;
  font-size:14.5px;line-height:1.6;color:var(--text-primary);
}
.req-list li::before{
  content:"";position:absolute;left:0;top:8px;
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 10px var(--accent-glow);
}
.req-list-soft li::before{
  background:transparent;border:1px solid var(--accent);
}
.testers-foot{
  margin-top:18px;color:var(--text-faint);font-size:12.5px;line-height:1.6;
  padding-top:14px;border-top:1px dashed var(--border-soft);
}
.testers-cta{
  margin-top:24px;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:24px;
}
.testers-cta-lede{
  color:var(--text-primary);font-size:14.5px;line-height:1.65;
  margin-bottom:14px;
}
.testers-cta .notify{max-width:none}
.testers-cta .notify-foot{margin-top:10px}

/* ---------- Features wanted band ---------- */
.wanted-band .section-h{max-width:22ch}
.wanted-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin-top:8px;
}
@media (max-width:980px){.wanted-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.wanted-grid{grid-template-columns:1fr}}
.wanted-card{
  margin:0;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  padding:22px 22px 20px;
  position:relative;
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);
}
.wanted-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}
.wanted-head{margin-bottom:8px}
.wanted-tag{
  display:inline-block;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);
  padding:2px 8px;border-radius:var(--radius-pill);
  border:1px dashed var(--border-strong);
  margin-bottom:10px;
}
.wanted-card h3{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:16px;color:var(--text-strong);line-height:1.3;margin:0;
}
.wanted-card p{color:var(--text-muted);font-size:13.5px;line-height:1.6;margin:0}
.wanted-foot{
  margin-top:28px;
  color:var(--text-faint);font-size:13px;
  text-align:center;
  padding-top:18px;
  border-top:1px dashed var(--border-soft);
  max-width:60ch;margin-left:auto;margin-right:auto;
}

/* ---------- Coffee link (subtle, single reference) ---------- */
.coffee-link{
  color:var(--text-faint);
  border-bottom:1px dotted var(--text-faint);
  padding-bottom:1px;
  transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out);
}
.coffee-link:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- Real screens gallery ---------- */
.screens-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
}
@media (max-width:840px){.screens-grid{grid-template-columns:1fr}}
.screen-card{
  margin:0;
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);
}
.screen-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}
.screen-card-wide{grid-column:1 / -1}
.screen-img-wrap{
  background:var(--bg-sunken);
  border-bottom:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.screen-img-wrap img{
  display:block;max-width:100%;height:auto;
}
.screen-card figcaption{
  padding:22px 24px 24px;
}
.screen-card figcaption h3{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);
  margin:0 0 8px;
}
.screen-card figcaption p{
  color:var(--text-muted);font-size:14px;line-height:1.6;margin:0;
}

/* ---------- Bands (sections) ---------- */
.band{
  position:relative;
  padding:96px 0;
  border-top:1px solid var(--border-soft);
}
.band-sunken{background:var(--bg-sunken)}
.section-h{
  font-family:var(--font-display);
  font-size:clamp(28px, 3.2vw, 44px);
  font-weight:var(--weight-bold);
  line-height:1.05;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  max-width:22ch;
}
.section-lede{
  font-size:17px;line-height:1.6;color:var(--text-muted);
  max-width:64ch;margin-top:18px;margin-bottom:48px;
}
.section-foot{margin-top:18px;color:var(--text-faint);font-size:13px}
.key{color:var(--accent)}

/* ---------- Three-column card grid (What it is) ---------- */
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:900px){.three-col{grid-template-columns:1fr}}
.pill-card{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:28px;
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);
}
.pill-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}
.pill-icon{
  width:36px;height:36px;border-radius:var(--radius-md);
  background:rgba(232,163,61,.10);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.pill-icon svg{width:20px;height:20px}
.pill-card h3{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);margin-bottom:10px;
}
.pill-card p{color:var(--text-muted);font-size:14px;line-height:1.6}

/* ---------- Platforms ---------- */
.platforms{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media (max-width:840px){.platforms{grid-template-columns:1fr}}
.plat-card{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:28px;
}
.plat-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.plat-icon{
  width:48px;height:48px;border-radius:var(--radius-md);
  background:var(--surface-well);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
  border:1px solid var(--border-default);
}
.plat-name{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);
}
.plat-meta{font-size:11px;color:var(--text-faint);letter-spacing:.06em;margin-top:2px}
.plat-card p{color:var(--text-muted);font-size:14px;line-height:1.6;margin-bottom:14px}
.plat-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.plat-list li{
  font-size:13px;color:var(--text-primary);padding-left:18px;position:relative;
}
.plat-list li::before{
  content:"";position:absolute;left:0;top:8px;
  width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.8;
}

/* ---------- Features grid ---------- */
.features-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
@media (max-width:980px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.features-grid{grid-template-columns:1fr}}
.feat{
  border:1px solid var(--border-default);
  background:var(--surface-panel);
  border-radius:var(--radius-md);
  padding:20px;
}
.feat h4{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:15px;color:var(--text-strong);margin-bottom:8px;
}
.feat p{color:var(--text-muted);font-size:13.5px;line-height:1.6}
.feat-spotlight{
  grid-column:1 / -1;
  border-color:rgba(232,163,61,.45);
  background:
    linear-gradient(180deg, rgba(232,163,61,.05), transparent 60%),
    var(--surface-panel);
  padding:26px 28px;
  box-shadow:0 0 0 1px rgba(232,163,61,.08), 0 0 32px rgba(232,163,61,.06);
}
.feat-spotlight h4{
  font-size:18px;color:var(--accent);margin-bottom:10px;
}
.feat-spotlight p{color:var(--text-primary);font-size:14.5px}

/* ---------- Frigate ---------- */
.frigate-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
}
@media (max-width:1000px){.frigate-grid{grid-template-columns:1fr}}
.frigate-list{
  list-style:none;display:flex;flex-direction:column;gap:10px;
  margin:18px 0 6px;
}
.frigate-list li{
  font-size:14.5px;line-height:1.6;color:var(--text-primary);
  padding-left:24px;position:relative;
}
.frigate-list li::before{
  content:"↳";position:absolute;left:0;top:0;color:var(--accent);
}

/* diagram */
.diagram{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);
  padding:36px 28px;
  box-shadow:var(--shadow-md);
}
.d-row{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.d-row-bottom{margin-top:28px;justify-content:center}
.d-node{
  flex:1;min-width:120px;
  background:var(--surface-well);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  padding:16px 14px;text-align:center;
  display:flex;flex-direction:column;gap:4px;
}
.d-node.d-crumb{border-color:rgba(232,163,61,.55);box-shadow:var(--glow-accent)}
.d-label{
  font-size:11px;letter-spacing:.18em;color:var(--text-strong);
  font-weight:var(--weight-medium);
}
.d-node.d-crumb .d-label{color:var(--accent)}
.d-sub{font-size:11px;color:var(--text-faint)}
.d-arrow{flex:0 0 60px;display:flex;justify-content:center;align-items:center}
.d-arrow svg{width:60px;height:18px}
.d-stream{
  display:inline-flex;align-items:center;gap:14px;
  border:1px dashed var(--border-strong);
  border-radius:var(--radius-pill);
  padding:8px 18px;
  color:var(--text-muted);font-size:12px;
}
.d-tag{
  font-size:11px;color:var(--accent);
  letter-spacing:.12em;text-transform:uppercase;
}
.d-arrow-thin{color:var(--text-faint)}
@media (max-width:560px){
  .d-row{flex-direction:column;align-items:stretch}
  .d-arrow{transform:rotate(90deg);flex-basis:auto}
}

/* ---------- Privacy ---------- */
.privacy-card{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-xl);
  padding:48px;
  display:grid;grid-template-columns:96px 1fr;gap:32px;align-items:start;
  box-shadow:var(--shadow-md);
}
.privacy-card .section-h{margin-bottom:14px}
.privacy-art svg{width:72px;height:72px}
.privacy-foot{color:var(--text-muted);font-size:15px;line-height:1.65;margin-top:14px}
@media (max-width:720px){
  .privacy-card{grid-template-columns:1fr;padding:32px}
}

/* ---------- Stack tiles ---------- */
.stack-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
@media (max-width:900px){.stack-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.stack-grid{grid-template-columns:1fr}}
.stack-tile{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  padding:18px;
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
}
.stack-label{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-faint);
}
.stack-name{font-family:var(--font-display);font-weight:var(--weight-semibold);font-size:15px;color:var(--text-strong)}

/* ---------- CTA band ---------- */
.cta-band{
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(232,163,61,.10), transparent 60%),
    var(--bg-app);
  text-align:center;
}
.cta-inner{display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-inner .section-h{max-width:none}
.cta-inner .section-lede{margin-bottom:8px}

/* ---------- Footer ---------- */
.footer{
  padding:32px 0 56px;
  border-top:1px solid var(--border-soft);
}
.footer-inner{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.footer-meta{
  font-size:11px;color:var(--text-faint);
  display:flex;gap:8px;flex-wrap:wrap;
  letter-spacing:.04em;
}
.footer-tag{font-family:var(--font-display);font-size:14px;color:var(--text-muted)}

/* ---------- Updates: home-page feed ---------- */
.updates-band .updates-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  margin-bottom:32px;flex-wrap:wrap;
}
.updates-band .section-h{margin-bottom:0}
.updates-band .section-lede{margin:14px 0 0;max-width:60ch}
.updates-band .updates-all{flex:0 0 auto}
.update-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
@media (max-width:780px){.update-grid{grid-template-columns:1fr}}

/* ---------- Update card ---------- */
.update-card{
  background:var(--surface-panel);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  padding:22px;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);
}
.update-card:hover{
  border-color:var(--border-strong);
  transform:translateY(-2px);
}
.update-head{
  display:flex;align-items:center;gap:12px;
}
.update-date{
  font-size:11px;color:var(--text-faint);letter-spacing:.06em;
  text-transform:uppercase;
}
.update-title{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;line-height:1.3;color:var(--text-strong);
  margin:0;
}
.update-title a{color:inherit}
.update-title a:hover{color:var(--accent)}
.update-summary{color:var(--text-muted);font-size:14px;line-height:1.6;margin:0}
.update-meta{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:4px;
}
.update-platforms,.update-tags{
  display:flex;gap:6px;flex-wrap:wrap;
}
.update-card-compact{padding:18px 18px 16px}
.update-card-compact .update-title{font-size:16px}

/* ---------- Status badges ---------- */
.status{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--radius-pill);
  border:1px solid var(--border-default);
  background:var(--surface-well);
  color:var(--text-muted);
  font-weight:var(--weight-medium);
}
.status::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:currentColor;flex-shrink:0;
}
.status-shipped{color:var(--accent);border-color:rgba(232,163,61,.4);background:rgba(232,163,61,.08)}
.status-built{color:var(--status-live);border-color:rgba(79,180,119,.4);background:rgba(79,180,119,.08)}
.status-testing{color:var(--crumb-amber-300);border-color:rgba(240,193,112,.35);background:rgba(240,193,112,.08)}
.status-fixed{color:var(--status-rec);border-color:rgba(229,72,77,.4);background:rgba(229,72,77,.08)}
.status-designed{color:var(--status-info);border-color:rgba(94,155,214,.4);background:rgba(94,155,214,.08)}
.status-planned{color:var(--text-faint)}

/* ---------- Tag + platform pills ---------- */
.tag-pill,.plat-pill{
  display:inline-block;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.06em;
  padding:3px 8px;border-radius:var(--radius-pill);
  border:1px solid var(--border-soft);
  color:var(--text-muted);
  background:transparent;
}
.plat-pill{color:var(--text-primary);border-color:var(--border-default)}

/* ---------- Compact hero (used on /updates and /updates/<slug>) ---------- */
.hero-compact{padding:56px 0 36px}
.hero-compact-inner{position:relative;z-index:1}
.updates-h1{
  font-family:var(--font-display);
  font-weight:var(--weight-bold);
  font-size:clamp(36px, 4.6vw, 56px);
  line-height:1.02;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  max-width:24ch;
  margin-bottom:18px;
}

/* ---------- /updates archive ---------- */
.update-month{margin-bottom:48px}
.update-month-h{
  font-family:var(--font-display);
  font-weight:var(--weight-semibold);
  font-size:22px;color:var(--text-strong);
  margin-bottom:18px;
  display:flex;align-items:baseline;gap:14px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border-soft);
}
.month-tag{font-size:12px;color:var(--text-faint);letter-spacing:.14em}
.update-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
@media (max-width:780px){.update-list{grid-template-columns:1fr}}

/* ---------- /updates/<slug> post page ---------- */
.back-link{
  display:inline-block;font-size:12px;color:var(--text-faint);
  margin-bottom:24px;letter-spacing:.06em;
}
.back-link:hover{color:var(--accent)}
.post-head{display:flex;flex-direction:column;gap:14px}
.post-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.post-title{
  font-family:var(--font-display);
  font-weight:var(--weight-bold);
  font-size:clamp(32px, 4.2vw, 52px);
  line-height:1.02;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  max-width:24ch;
}
.post-pills{display:flex;gap:6px;flex-wrap:wrap}
.post-prose{
  max-width:68ch;margin:0 auto;
  font-size:16.5px;line-height:1.7;color:var(--text-primary);
}
.post-prose h2{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:24px;letter-spacing:var(--tracking-tight);
  color:var(--text-strong);
  margin:36px 0 12px;
}
.post-prose h3{
  font-family:var(--font-display);font-weight:var(--weight-semibold);
  font-size:18px;color:var(--text-strong);
  margin:28px 0 8px;
}
.post-prose p{margin:0 0 18px;color:var(--text-primary)}
.post-prose a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(232,163,61,.4)}
.post-prose a:hover{border-bottom-color:var(--accent)}
.post-prose ul,.post-prose ol{margin:0 0 18px 22px}
.post-prose li{margin-bottom:6px}
.post-prose code{
  font-family:var(--font-mono);font-size:13.5px;
  background:var(--surface-well);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xs);
  padding:1px 6px;color:var(--text-strong);
}
.post-prose pre{
  background:var(--bg-sunken);
  border:1px solid var(--border-default);
  border-radius:var(--radius-md);
  padding:16px 18px;
  overflow-x:auto;
  margin:0 0 22px;
}
.post-prose pre code{
  background:transparent;border:0;padding:0;
  font-size:13px;color:var(--text-primary);
}
.post-prose blockquote{
  margin:0 0 22px;padding:14px 18px;
  background:var(--surface-panel);
  border-left:3px solid var(--accent);
  border-radius:var(--radius-sm);
  color:var(--text-muted);
}
.post-prose blockquote p{margin:0;font-style:italic}
.post-prose hr{
  border:0;height:1px;background:var(--border-soft);margin:32px 0;
}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(12px);transition:opacity 600ms var(--ease-out), transform 600ms var(--ease-out)}
.reveal.in{opacity:1;transform:none}
