/* Stage-0 design system. Tokens + component styles transcribed faithfully from
   docs/mockups/preview.html (the visual source of truth). Mockup-only chrome
   (.board/.screen/.frame) intentionally omitted — this is the live site, not
   the visual board. Token values mirror brand.config.json#tokens. */

:root{
  --primary:#1F3A5F;
  --primary-2:#163055;
  --accent:#B45F2E;
  --accent-2:#C97B40;
  --ink:#1A1A1A;
  --bg:#F7F5F0;
  --muted:#6B7280;
  --success:#3F7D5C;
  --error:#9C3B3B;
  --line:#E3DFD6;
  --card:#FFFFFF;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --heading:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --serif:'IBM Plex Serif',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}
body{background:var(--bg);font-family:var(--sans);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:2px}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
.wrap{max-width:1100px;margin:0 auto}
.skip{position:absolute;left:-999px}
.skip:focus{position:static;display:inline-block;padding:8px 14px;background:var(--primary);color:#fff}

/* nav */
.nav{display:flex;align-items:center;justify-content:space-between;
  padding:18px 30px;border-bottom:1px solid var(--line);background:#fff;flex-wrap:wrap;gap:12px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;
  color:var(--primary);letter-spacing:-.02em;text-decoration:none}
.logo-text{font-family:var(--heading);font-weight:700;font-size:17px;letter-spacing:-.01em}
.nav-text{justify-content:flex-start}
.rivet{width:22px;height:22px;border-radius:5px;background:var(--primary);
  position:relative;flex:none}
.rivet::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--accent)}
.logo-mark{height:36px;width:auto;flex:none;display:block}
.nav nav{display:flex;gap:24px;align-items:center;font-size:14px;font-weight:500;flex-wrap:wrap}
.nav nav a:not(.btn){color:#384150;text-decoration:none}
.nav nav a:not(.btn):hover{color:var(--primary)}

/* hero split — logo as right-column seal */
.hero-split{display:flex;align-items:center;gap:64px}
.hero-text{flex:1;min-width:0}
.hero-seal{flex:none;width:220px;display:flex;align-items:center;justify-content:center;
  border-left:2px solid var(--line);padding-left:48px;opacity:.88}
.hero-logo-mark{width:180px;height:auto;display:block}

/* buttons */
.btn{background:var(--primary);color:#fff;border:none;border-radius:8px;
  padding:10px 18px;font:600 14px var(--sans);cursor:pointer;text-decoration:none;
  display:inline-block}
.btn:hover{background:var(--primary-2)}
.btn.alt{background:var(--accent)}
.btn.alt:hover{background:var(--accent-2)}
.btn.ghost{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn.ghost:hover{background:var(--primary);color:#fff}
.btn.sm{padding:8px 14px;font-size:13px}

/* hero + sections */
.hero{padding:64px 30px;background:linear-gradient(180deg,#fff 0%,var(--bg) 100%)}
.kicker{font:600 12px/1 var(--mono);color:var(--accent);letter-spacing:.12em;
  text-transform:uppercase}
h1.big{font-family:var(--heading);font-size:44px;line-height:1.08;font-weight:800;letter-spacing:-.03em;
  margin:16px 0;max-width:16ch;color:var(--primary)}
.lede{font-size:18px;line-height:1.6;color:#3a4150;max-width:54ch;margin-bottom:26px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.sec{padding:44px 30px}
.sec h2{font-family:var(--heading);font-size:28px;color:var(--primary);letter-spacing:-.02em;margin-bottom:8px}
.sec .sub{color:var(--muted);font-size:15px;margin-bottom:28px}

/* product cards */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:#fff;padding:32px 28px}
.pcard h3{font-family:var(--heading);font-size:20px;color:var(--primary);margin-bottom:6px;letter-spacing:-.01em}
.pcard .tag{font:600 11px/1 var(--mono);color:var(--accent);text-transform:uppercase;
  letter-spacing:.1em}
.pcard p{color:#4a5160;font-size:14px;line-height:1.6;margin:12px 0 16px}
.bordered{border:1px solid var(--line);border-radius:10px}

/* honesty admonition (copper) — the brand differentiator */
.admon{border:1px solid var(--accent);background:#FBF1E8;border-left:5px solid var(--accent);
  border-radius:6px;padding:16px 18px;margin:18px 0}
.admon .h{font:700 12px/1 var(--mono);color:var(--accent);text-transform:uppercase;
  letter-spacing:.1em;margin-bottom:8px}
.admon p{font-size:14px;color:#5a4634;line-height:1.6}

/* code */
pre{background:var(--primary);color:#dfe7f0;font:500 13px/1.7 var(--mono);
  padding:18px 20px;border-radius:8px;overflow:auto;margin:14px 0}
pre .c{color:#9bb4cf}
code{font-family:var(--mono);background:#eee;padding:2px 6px;border-radius:4px;font-size:.92em}

/* status pills */
.pill{display:inline-block;font:600 11px/1 var(--mono);padding:5px 10px;
  border-radius:999px;letter-spacing:.05em}
.pill.live{background:#E3F0E9;color:var(--success)}
.pill.soon{background:#F0EBE3;color:var(--muted)}

/* tables (pricing, trust) */
table{width:100%;border-collapse:collapse;font-size:14px;margin:14px 0}
th,td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line)}
th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}

/* blog index — transcribed from preview.html screens 10/11 */
.blog{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:40px 0}
.post{border:1px solid var(--line);border-radius:10px;overflow:hidden;
  background:#fff;display:flex;flex-direction:column}
.post .thumb{height:120px;background:linear-gradient(135deg,var(--primary),var(--accent))}
.post .body{padding:18px;flex:1;display:flex;flex-direction:column}
.post .meta{font:500 11px var(--mono);color:var(--muted);text-transform:uppercase;
  letter-spacing:.06em}
.post h3{font-size:16px;color:var(--primary);margin:8px 0;line-height:1.3}
.post p{font-size:13px;color:#4a5160;line-height:1.6;flex:1}
.post .more{margin-top:14px;font:600 13px var(--sans);color:var(--accent);
  text-decoration:none}
a.post{text-decoration:none;color:inherit;transition:border-color .15s}
a.post:hover{border-color:var(--primary)}
.post.soon{opacity:.78}
.post.soon .thumb{filter:grayscale(.5)}

/* long-form article (about, legal, blog post) — Plex Serif body */
.article{max-width:680px;margin:0 auto;padding:48px 30px}
.article h1{font-size:34px;color:var(--primary);letter-spacing:-.02em;line-height:1.15}
.article .by{font:500 13px var(--mono);color:var(--muted);margin:16px 0 28px}
.article h2{font-size:20px;color:var(--primary);margin:28px 0 8px}
.article p{font-family:var(--serif);font-size:17px;line-height:1.75;color:#2c3340;margin:16px 0}
.article ul{font-family:var(--serif);font-size:17px;line-height:1.75;color:#2c3340;
  margin:16px 0 16px 22px}

/* waitlist block */
.waitlist{background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:28px;margin:30px 0;max-width:560px}
.waitlist h3{color:var(--primary);font-size:20px;margin-bottom:6px}
.waitlist p{color:#4a5160;font-size:14px;margin-bottom:16px}
.waitlist form{display:flex;gap:10px;flex-wrap:wrap}
.inp{border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:14px;
  flex:1;min-width:200px;font-family:var(--sans)}
.todo{display:inline-block;font:600 11px/1 var(--mono);color:var(--accent);
  background:#FBF1E8;border:1px dashed var(--accent);padding:4px 8px;border-radius:6px}

/* footer */
.footer{background:var(--primary);color:#c4d0e0;padding:34px 30px;font-size:13px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px}
.footer b{color:#fff;display:block;margin-bottom:10px;font-size:12px;
  text-transform:uppercase;letter-spacing:.1em}
.footer a{color:#c4d0e0;text-decoration:none;display:block;padding:3px 0}
.footer a:hover{color:#fff}
.footer .colophon{flex-basis:100%;border-top:1px solid rgba(255,255,255,.15);
  padding-top:16px;color:#9fb0c6}

@media (max-width:760px){
  .grid2,.grid3,.blog{grid-template-columns:1fr}
  h1.big{font-size:34px}
  .hero,.sec{padding:40px 22px}
  .hero-split{flex-direction:column;gap:36px}
  .hero-seal{border-left:none;border-top:2px solid var(--line);padding-left:0;padding-top:28px;width:auto}
  .hero-logo-mark{width:120px}
}

/* ============================================================
   EDITORIAL HOMEPAGE v2 — dark/light contrast, not plain
   Navy frame + serif italic h1 + copper accents + CSS mark
   ============================================================ */

/* 4px copper stripe — brand signature at top of page */
.site-bar{height:4px;background:var(--accent)}

/* dark region wrapping nav + hero — bookended by footer */
.page-dark-top{background:var(--primary)}

/* ghost nav on dark background */
.nav-ghost{display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px;flex-wrap:wrap;gap:12px}
.ghost-brand{font-family:var(--heading);font-weight:700;font-size:16px;
  color:#fff;text-decoration:none;letter-spacing:-.01em}
.nav-ghost nav{display:flex;gap:28px;align-items:center;font-size:13px;
  font-weight:500;flex-wrap:wrap}
.nav-ghost nav a{color:rgba(255,255,255,.55);text-decoration:none}
.nav-ghost nav a:hover{color:#fff}

/* hero — white type on navy, copper accent rule */
.ed-hero{padding:40px 40px 76px;display:flex;align-items:flex-start;
  justify-content:space-between;gap:48px}
.ed-hero-text{flex:1;min-width:0}
.ed-kicker{font:600 11px/1 var(--mono);color:var(--accent-2);letter-spacing:.15em;
  text-transform:uppercase;margin-bottom:24px}
.ed-h1{font-family:var(--serif);font-size:74px;line-height:.95;font-weight:400;
  font-style:italic;color:#fff;letter-spacing:-.025em;margin-bottom:0}
.ed-rule{height:3px;width:56px;background:var(--accent);margin:28px 0}
.ed-lede{font-size:16px;line-height:1.72;color:rgba(255,255,255,.6);max-width:46ch}

/* logo badge in hero — screen blend knocks out dark bg on navy hero */
.ed-hero-mark{flex:none;align-self:center}
.ed-logo-badge{width:240px;height:240px;display:block;object-fit:contain;
  mix-blend-mode:screen}

/* light content sections */
.ed-sec{padding:36px 40px;border-bottom:1px solid var(--line);background:var(--bg)}
.ed-sec-alt{background:#fff}
.ed-label{display:flex;align-items:center;gap:14px;font:600 11px/1 var(--mono);
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:26px}
.ed-label::after{content:'';flex:1;height:1px;background:var(--line)}
.ed-label span{color:var(--accent)}

/* product rows — flex with body block, not a card grid */
.prod-index{list-style:none}
.prod-row{display:flex;align-items:center;gap:20px;padding:22px 0;
  border-bottom:1px solid var(--line)}
.prod-row:last-child{border-bottom:none}
.prod-num{font:500 11px/1 var(--mono);color:var(--muted);flex:none;
  width:28px;padding-top:3px}
.prod-body{flex:1;min-width:0}
.prod-name{font-family:var(--heading);font-weight:700;font-size:20px;
  color:var(--primary);margin-bottom:5px}
.prod-desc{font-size:14px;color:#4a5160;line-height:1.5}
.prod-link{font:600 13px/1 var(--sans);color:var(--accent);text-decoration:none;
  flex:none;white-space:nowrap}
.prod-link:hover{text-decoration:underline}

/* serif prose with copper left rule */
.ed-prose{font-family:var(--serif);font-size:18px;line-height:1.82;color:#2c3340;
  max-width:600px;border-left:3px solid var(--accent);padding-left:22px}

/* contact */
.ed-contact{font-family:var(--heading);font-size:22px;font-weight:700;
  color:var(--primary);text-decoration:none;display:inline-block}
.ed-contact:hover{color:var(--accent)}

/* footer — matches page-dark-top, bookends the design */
.ed-footer{background:var(--primary-2);padding:20px 40px;
  display:flex;justify-content:space-between;align-items:center;
  font:500 12px/1 var(--mono);color:rgba(255,255,255,.4);
  flex-wrap:wrap;gap:8px}

@media (max-width:760px){
  .nav-ghost{padding:18px 22px}
  .ed-hero{flex-direction:column;gap:32px;padding:28px 22px 52px}
  .ed-logo-badge{width:140px}
  .ed-h1{font-size:52px}
  .ed-sec{padding:28px 22px}
  .prod-row{flex-wrap:wrap}
  .prod-link{padding-left:48px;margin-top:6px}
  .ed-footer{padding:16px 22px;flex-direction:column;align-items:flex-start}
}
