/* ==========================================================================
   Glint — Light System · marketing site
   One stylesheet for the whole site. Ported from the Glint brand guidelines
   and the original "Instrument" homepage design. Zero-JS, static, fast.
   ========================================================================== */

/* ---- Design tokens (from the Glint Light System brand guidelines) -------- */
:root{
  /* Foundation */
  --paper:#F7F3EA;
  --paper-warm:#F1EADB;
  --paper-deep:#E9E0CD;
  --card:#FCFAF4;
  --hairline:#E0D6C2;
  --hairline-soft:#EBE3D3;

  /* Ink scale */
  --ink:#1A1814;
  --ink-soft:#43403A;
  --muted:#827C70;
  --whisper:#A8A192;

  /* The glint */
  --gold:#C8941E;
  --gold-bright:#E0A828;
  --gold-soft:#F0E2B8;
  --gold-wash:#F5EDD6;

  /* Semantic */
  --green:#2E8B6B;  --green-wash:#E3F0E9;
  --coral:#D2502E;  --coral-wash:#F7E5DE;
  --signal:#3A66C4; --signal-wash:#E4EAF7;

  --maxw:1240px;
  --pad:40px;

  --serif:'Instrument Serif',Georgia,'Times New Roman',serif;
  --sans:'Switzer',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}

/* ---- Self-hosted fonts (subset, woff2, font-display:swap) ---------------- */
/* Instrument Serif — display */
@font-face{font-family:'Instrument Serif';font-style:italic;font-weight:400;font-display:swap;
  src:url("/fonts/instrument-italic-latin.woff2") format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Instrument Serif';font-style:italic;font-weight:400;font-display:swap;
  src:url("/fonts/instrument-italic-latinext.woff2") format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;
  src:url("/fonts/instrument-latin.woff2") format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;
  src:url("/fonts/instrument-latinext.woff2") format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* JetBrains Mono — data/labels (one file serves 400/500/600) */
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400 600;font-display:swap;
  src:url("/fonts/jbmono-latin.woff2") format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400 600;font-display:swap;
  src:url("/fonts/jbmono-latinext.woff2") format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* Switzer — body (self-hosted from Fontshare) */
@font-face{font-family:'Switzer';font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/switzer-400.woff2") format('woff2');}
@font-face{font-family:'Switzer';font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/switzer-500.woff2") format('woff2');}
@font-face{font-family:'Switzer';font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/switzer-600.woff2") format('woff2');}
@font-face{font-family:'Switzer';font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/switzer-700.woff2") format('woff2');}

/* ---- Reset / base -------------------------------------------------------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  background:var(--paper-warm);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;line-height:1.5;font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
img,svg{max-width:100%;display:block}
a{color:inherit}
em{font-style:italic}

/* type helpers */
.serif{font-family:var(--serif);font-weight:400}
.mono{font-family:var(--mono)}
.italic{font-style:italic}

/* `hidden` attribute must win over author display rules (e.g. .ea-form{display:flex}) */
[hidden]{display:none!important}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* the gold dot used after "glint" */
.dot{display:inline-block;width:5px;height:5px;background:var(--gold-bright);border-radius:50%;
  margin-left:-4px;margin-bottom:15px;vertical-align:middle;box-shadow:0 0 10px rgba(224,168,40,.5)}

/* shared eyebrow / mono label */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}

/* shared buttons */
.btn{display:inline-block;border-radius:8px;font-size:15px;text-decoration:none;padding:15px 26px;
  transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap}
.btn-primary{background:var(--gold-bright);color:var(--ink);font-weight:600}
.btn-primary:hover{background:var(--gold)}
.btn-secondary{background:var(--card);color:var(--ink);font-weight:500;border:1px solid var(--hairline)}
.btn-secondary:hover{border-color:var(--ink)}

/* ==========================================================================
   NAV  (sticky, glassy)
   ========================================================================== */
/* Note: the glass blur lives on ::before, NOT on .site-nav itself.
   backdrop-filter/transform/filter on .site-nav would make it the containing
   block for the position:fixed mobile menu, sizing it to the header instead of
   the viewport. Keeping the filter on the pseudo avoids that. */
.site-nav{position:sticky;top:0;z-index:50;border-bottom:1px solid var(--hairline)}
.site-nav::before{content:"";position:absolute;inset:0;z-index:-1;
  background:rgba(241,234,219,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:16px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand-group{display:flex;align-items:center;gap:14px}
.brand{font-family:var(--serif);font-style:italic;font-size:26px;letter-spacing:-.03em;color:var(--ink);text-decoration:none}
.badge{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  background:var(--gold-wash);border:1px solid var(--gold-soft);padding:4px 8px;border-radius:5px}
.nav-right{display:flex;align-items:center;gap:34px}
.nav-links{display:flex;gap:28px;font-size:14px;color:var(--muted)}
.nav-links a{color:var(--muted);text-decoration:none;transition:color .15s ease}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:7px;font-weight:600;
  font-size:13px;text-decoration:none;white-space:nowrap;transition:background .15s ease}
.nav-cta:hover{background:var(--ink-soft)}

/* CSS-only mobile menu (checkbox hack — no JS) */
.nav-toggle,.nav-toggle-label{display:none}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{max-width:var(--maxw);margin:0 auto;padding:84px var(--pad) 96px}
.hero-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:72px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:var(--card);
  border:1px solid var(--hairline);padding:7px 14px;border-radius:999px;margin-bottom:30px}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(48px,6.6vw,86px);
  line-height:.96;letter-spacing:-.03em;color:var(--ink)}
.hero-title em{color:var(--gold)}
.hero-sub{font-size:19px;line-height:1.55;color:var(--ink-soft);margin-top:26px;max-width:46ch;text-wrap:pretty}
.btn-row{display:flex;gap:13px;margin-top:34px;flex-wrap:wrap}
.hero-stats{display:flex;gap:28px;margin-top:40px;font-family:var(--mono);font-size:11px;color:var(--muted)}
.hero-stats .num{display:block;font-family:var(--serif);font-style:italic;font-size:30px;color:var(--ink);line-height:1}

/* Instrument panel (the live monitor mock) */
.panel{background:var(--card);border:1px solid var(--hairline);border-radius:16px;
  box-shadow:0 24px 60px -28px rgba(26,24,20,.22);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;
  border-bottom:1px solid var(--hairline-soft);background:var(--paper)}
.panel-head .label{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}
.panel-head .label .led{width:7px;height:7px;border-radius:50%;background:var(--gold-bright)}
.panel-head .ts{font-family:var(--mono);font-size:10px;color:var(--muted)}
.panel-body{padding:24px}
.metric-row{display:grid;grid-template-columns:1.2fr 1fr;gap:16px;margin-bottom:16px}
.metric{border-radius:11px;padding:18px;min-width:0}
.metric--gold{background:var(--gold-wash);border:1px solid var(--gold-soft)}
.metric--plain{background:var(--paper);border:1px solid var(--hairline-soft);
  display:flex;flex-direction:column;justify-content:space-between}
.metric .cap{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.metric .big{font-family:var(--serif);font-size:46px;line-height:.9;color:var(--ink)}
.metric .big sup{font-size:22px;color:var(--gold);vertical-align:baseline}
.metric .delta{font-family:var(--mono);font-size:10px;color:var(--green);margin-top:6px}
.spark{display:flex;gap:3px;align-items:flex-end;height:22px}
.spark i{flex:1;background:var(--hairline);border-radius:1px;display:block}
.spark i.hot{background:var(--gold-bright)}
.panel-cap{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:18px 0 10px}
.engines{display:flex;flex-direction:column;gap:11px}
.engine{display:flex;align-items:center;gap:12px}
.engine .name{width:64px;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}
.engine .track{flex:1;height:7px;background:var(--hairline-soft);border-radius:4px;overflow:hidden}
.engine .fill{height:100%;background:var(--gold-bright)}
.engine .fill.dim{background:var(--gold)}
.engine .pct{width:30px;text-align:right;font-family:var(--mono);font-size:11px;color:var(--ink);font-weight:600}

/* ==========================================================================
   TRUST BAR
   ========================================================================== */
.trust{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);background:var(--paper)}
.trust-inner{max-width:var(--maxw);margin:0 auto;padding:22px var(--pad);
  display:flex;align-items:center;gap:32px;flex-wrap:wrap;justify-content:center}
.trust-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--whisper)}
.trust-logos{display:flex;gap:40px;flex-wrap:wrap;align-items:center;font-family:var(--serif);font-size:22px;color:var(--muted)}

/* ==========================================================================
   SECTIONS / FEATURES
   ========================================================================== */
.section{padding:120px 0}
.section--alt{background:var(--paper);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.section-head{max-width:60ch;margin-bottom:56px}
.section-head.center{text-align:center;margin-left:auto;margin-right:auto}
.h2{font-family:var(--serif);font-size:clamp(34px,4.6vw,58px);line-height:1;letter-spacing:-.025em;color:var(--ink)}
.h2 em{color:var(--gold)}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature{background:var(--card);border:1px solid var(--hairline);border-radius:14px;padding:30px}
.feature .ico{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;font-size:20px;margin-bottom:22px}
.ico-gold{background:var(--gold-wash);border:1px solid var(--gold-soft);color:var(--gold)}
.ico-signal{background:var(--signal-wash);border:1px solid #cdd9f2;color:var(--signal)}
.ico-green{background:var(--green-wash);border:1px solid #c4e2d4;color:var(--green)}
.feature h3{font-family:var(--serif);font-size:25px;color:var(--ink);margin-bottom:10px;letter-spacing:-.02em}
.feature p{font-size:15px;line-height:1.55;color:var(--ink-soft)}
.feature--dark{background:var(--ink);border-color:var(--ink);position:relative;overflow:hidden}
.feature--dark::before{content:"";position:absolute;top:-50px;right:-40px;width:160px;height:160px;
  background:radial-gradient(circle,var(--gold-bright) 0%,transparent 62%);opacity:.18;border-radius:50%}
.feature--dark .ico{background:rgba(245,196,67,.14);border:1px solid rgba(245,196,67,.3);color:#F5C443;position:relative}
.feature--dark h3{color:var(--paper);position:relative}
.feature--dark p{color:#A29F96;position:relative}

/* ==========================================================================
   LIVE SCAN SHOWCASE
   ========================================================================== */
.scan-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.scan-copy .h2{margin-bottom:22px}
.scan-copy p{font-size:18px;line-height:1.55;color:var(--ink-soft);max-width:42ch;text-wrap:pretty}
.answer{background:var(--card);border:1px solid var(--hairline);border-radius:16px;
  box-shadow:0 24px 60px -30px rgba(26,24,20,.22);overflow:hidden}
.answer-head{padding:16px 20px;border-bottom:1px solid var(--hairline-soft);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.answer-head .k{font-family:var(--mono);font-size:10px;color:var(--muted)}
.answer-head .q{font-size:14px;color:var(--ink)}
.answer-head .engine-tag{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.12em;
  text-transform:uppercase;background:var(--signal-wash);color:var(--signal);padding:3px 8px;border-radius:4px}
.answer-body{padding:24px;font-size:15px;line-height:1.7;color:var(--ink-soft)}
.answer-body mark{background:var(--gold-soft);color:var(--ink);padding:1px 4px;border-radius:3px;font-weight:600}
.answer-body .comp{color:var(--muted)}
.answer-foot{padding:16px 24px;border-top:1px solid var(--hairline-soft);background:var(--paper);
  display:flex;gap:20px;font-family:var(--mono);font-size:11px;flex-wrap:wrap}
.answer-foot .ok{color:var(--green)}
.answer-foot .miss{color:var(--coral)}
.answer-foot .note{color:var(--muted);margin-left:auto}

/* ==========================================================================
   QUOTE + STATS
   ========================================================================== */
.quote-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:center}
.quote{font-family:var(--serif);font-size:clamp(28px,3.6vw,44px);line-height:1.16;letter-spacing:-.02em;color:var(--ink)}
.quote em{color:var(--gold)}
.quote-author{display:flex;align-items:center;gap:13px;margin-top:32px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--paper-deep);display:flex;align-items:center;
  justify-content:center;font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink-soft);flex-shrink:0}
.quote-author .who{font-size:14px;color:var(--ink);font-weight:600;line-height:1.4}
.quote-author .who span{display:block;font-family:var(--mono);font-size:11px;font-weight:400;color:var(--muted)}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stat-box{background:var(--card);border:1px solid var(--hairline);border-radius:12px;padding:24px}
.stat-box .v{font-family:var(--serif);font-size:44px;line-height:.9}
.stat-box .v.gold{color:var(--gold)}
.stat-box .v.green{color:var(--green)}
.stat-box .l{font-size:13px;color:var(--ink-soft);margin-top:8px}

/* ==========================================================================
   PRICING
   ========================================================================== */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.price-card{background:var(--card);border:1px solid var(--hairline);border-radius:16px;padding:34px;position:relative}
.price-card--featured{border:2px solid var(--gold-bright);box-shadow:0 24px 50px -30px rgba(200,148,30,.5)}
.plan{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.price-card--featured .plan{color:var(--gold)}
.price{font-family:var(--serif);font-size:52px;line-height:.9;color:var(--ink);letter-spacing:-.02em}
.price span{font-size:17px;color:var(--muted);font-family:var(--sans)}
.price-cta{display:block;text-align:center;margin:24px 0;padding:12px;border-radius:8px;font-weight:600;
  font-size:14px;text-decoration:none;transition:background .15s ease,border-color .15s ease}
.price-cta.soft{background:var(--paper-warm);color:var(--ink);border:1px solid var(--hairline)}
.price-cta.soft:hover{border-color:var(--ink)}
.price-cta.gold{background:var(--gold-bright);color:var(--ink)}
.price-cta.gold:hover{background:var(--gold)}
.plan-tag{position:absolute;top:-12px;left:34px;font-family:var(--mono);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;background:var(--gold-bright);color:var(--ink);padding:5px 12px;border-radius:5px}
.feature-list{list-style:none;display:flex;flex-direction:column;gap:13px;font-size:14px;color:var(--ink-soft)}
.feature-list li{display:flex;gap:10px}
.feature-list li::before{content:"✓";color:var(--green)}

/* ==========================================================================
   FINAL CTA
   ========================================================================== */
.cta{max-width:var(--maxw);margin:0 auto;padding:120px var(--pad);text-align:center}
.cta .h2{font-size:clamp(40px,5.6vw,80px);line-height:.98;letter-spacing:-.03em;max-width:18ch;margin:0 auto}
.cta p{font-size:19px;color:var(--ink-soft);margin-top:22px}
.cta .btn-row{justify-content:center}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{border-top:1px solid var(--hairline);background:var(--paper)}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:48px var(--pad)}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
.footer-brand .brand{font-size:24px;color:var(--muted)}
.footer-brand p{font-size:14px;color:var(--muted);margin-top:12px;max-width:30ch}
.footer-col h4{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--whisper);margin-bottom:14px}
.footer-col a{display:block;font-size:14px;color:var(--ink-soft);text-decoration:none;margin-bottom:10px;transition:color .15s ease}
.footer-col a:hover{color:var(--ink)}
.footer-meta{border-top:1px solid var(--hairline);padding-top:24px;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--whisper)}

/* ==========================================================================
   NEWS (listing + article)
   ========================================================================== */
.page-head{max-width:var(--maxw);margin:0 auto;padding:80px var(--pad) 40px}
.page-head .h2{font-size:clamp(40px,5vw,68px)}
.page-head p{font-size:19px;color:var(--ink-soft);margin-top:18px;max-width:52ch}

.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.news-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--hairline);
  border-radius:14px;padding:28px;text-decoration:none;color:inherit;transition:border-color .15s ease,transform .15s ease}
.news-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.news-card .meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.news-card h3{font-family:var(--serif);font-size:27px;line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin-bottom:10px}
.news-card p{font-size:15px;line-height:1.55;color:var(--ink-soft)}
.news-card .more{margin-top:auto;padding-top:18px;font-family:var(--mono);font-size:12px;color:var(--gold)}

/* Article body — readable long-form */
.article{max-width:720px;margin:0 auto;padding:64px var(--pad) 96px}
.article .meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.article h1{font-family:var(--serif);font-size:clamp(38px,5.5vw,60px);line-height:1.02;letter-spacing:-.03em;color:var(--ink);margin-bottom:16px}
.article .standfirst{font-size:21px;line-height:1.5;color:var(--ink-soft);margin-bottom:40px;text-wrap:pretty}
.article-body{font-size:18px;line-height:1.7;color:var(--ink-soft)}
.article-body h2{font-family:var(--serif);font-size:32px;letter-spacing:-.02em;color:var(--ink);margin:48px 0 16px}
.article-body h3{font-family:var(--serif);font-size:24px;color:var(--ink);margin:36px 0 12px}
.article-body p{margin-bottom:22px}
.article-body a{color:var(--gold);text-underline-offset:3px}
.article-body ul,.article-body ol{margin:0 0 22px 22px}
.article-body li{margin-bottom:10px}
.article-body blockquote{border-left:3px solid var(--gold-bright);padding-left:24px;margin:32px 0;
  font-family:var(--serif);font-size:26px;line-height:1.3;color:var(--ink);font-style:italic}
.article-body code{font-family:var(--mono);font-size:.85em;background:var(--paper);border:1px solid var(--hairline);
  border-radius:4px;padding:.1em .4em}
.article-body img{border-radius:12px;border:1px solid var(--hairline);margin:32px 0}
.article-back{display:inline-block;margin-bottom:40px;font-family:var(--mono);font-size:12px;color:var(--muted);text-decoration:none}
.article-back:hover{color:var(--ink)}

/* ==========================================================================
   EARLY ACCESS  (waitlist page)
   ========================================================================== */
@keyframes eaPulse{0%,100%{opacity:1}50%{opacity:.45}}
.ea-wrap{max-width:1180px;margin:0 auto;padding:0 var(--pad)}
.ea-sec{padding:110px 0}
.ea-band{background:var(--paper);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}

/* hero */
.ea-hero{padding:72px 0 96px}
.ea-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:center}
.ea-h1{font-family:var(--serif);font-weight:400;font-size:clamp(46px,6.4vw,82px);line-height:.95;
  letter-spacing:-.03em;color:var(--ink);max-width:15ch}
.ea-h1 em{color:var(--gold)}
.ea-lead{font-size:19px;line-height:1.55;color:var(--ink-soft);margin-top:24px;max-width:48ch;text-wrap:pretty}
.pill .pulse{animation:eaPulse 2.4s ease-in-out infinite;background:var(--gold-bright);box-shadow:none}

/* CTA button + note (email capture handled by PostHog) */
.ea-formwrap{margin-top:36px}
.ea-cta-btn{border:0;cursor:pointer;padding:16px 30px;font-size:16px}
.ea-note{font-size:13px;color:var(--muted);margin-top:14px}
.ea-ack{font-size:14px;color:var(--green);font-weight:600;margin-top:14px}

/* social proof */
.ea-proof{display:flex;align-items:center;gap:14px;margin-top:36px}
.ea-avatars{display:flex}
.ea-avatars span{width:34px;height:34px;border-radius:50%;border:2px solid var(--paper-warm);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:15px}
.ea-avatars span+span{margin-left:-10px}
.ea-proof .label{font-size:14px;color:var(--ink-soft)}
.ea-proof strong{color:var(--ink);font-weight:600}

/* founding-member pass */
.ea-pass{background:var(--ink);border-radius:18px;padding:34px;position:relative;overflow:hidden;
  box-shadow:0 30px 70px -34px rgba(26,24,20,.5)}
.ea-pass::before{content:"";position:absolute;top:-90px;right:-70px;width:300px;height:300px;
  background:radial-gradient(circle,var(--gold-bright) 0%,transparent 62%);opacity:.16;border-radius:50%}
.ea-pass-top{display:flex;justify-content:space-between;align-items:center;position:relative}
.ea-pass-brand{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--paper);letter-spacing:-.03em}
.ea-pass-brand .dot{background:#F5C443;box-shadow:0 0 12px rgba(245,196,67,.6)}
.ea-pass-badge{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#F5C443;
  border:1px solid rgba(245,196,67,.35);padding:5px 10px;border-radius:5px}
.ea-pass-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#7c776e;margin-top:40px;position:relative}
.ea-pass-cohort{font-family:var(--serif);font-size:clamp(40px,5vw,58px);line-height:.9;color:var(--paper);letter-spacing:-.02em;margin-top:8px;position:relative}
.ea-pass-rule{height:1px;background:rgba(247,243,234,.12);margin:28px 0;position:relative}
.ea-pass-perks{display:flex;flex-direction:column;gap:14px;position:relative}
.ea-pass-perks div{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--paper)}
.ea-pass-perks .s{color:#F5C443}
.ea-pass-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:34px;position:relative}
.ea-pass-foot .cap{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#7c776e}
.ea-pass-spots{font-family:var(--serif);font-size:34px;color:#F5C443;line-height:1}
.ea-pass-spots span{font-size:16px;color:#7c776e}
.ea-pass-foot .est{font-family:var(--mono);font-size:10px;color:#7c776e;text-align:right}
.ea-pass-foot .est span{color:#A29F96}

/* perks (big numbered cards) + section heading */
.ea-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.ea-h2{font-family:var(--serif);font-size:clamp(32px,4.4vw,56px);line-height:1;letter-spacing:-.025em;color:var(--ink)}
.ea-h2 em{color:var(--gold)}
.ea-perks{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ea-perk{background:var(--card);border:1px solid var(--hairline);border-radius:16px;padding:34px}
.ea-perk .n{font-family:var(--serif);font-style:italic;font-size:44px;color:var(--gold);line-height:.8;margin-bottom:24px}
.ea-perk h3{font-family:var(--serif);font-size:27px;color:var(--ink);margin-bottom:12px;letter-spacing:-.02em}
.ea-perk p{font-size:15px;line-height:1.6;color:var(--ink-soft)}

/* timeline steps */
.ea-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ea-step{background:var(--card);border:1px solid var(--hairline);border-radius:14px;padding:30px}
.ea-step-head{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.ea-step-num{width:28px;height:28px;border-radius:50%;background:var(--gold-wash);border:1px solid var(--gold-soft);
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;color:var(--gold);font-weight:600;flex-shrink:0}
.ea-step-num.done{background:var(--green-wash);border-color:#c4e2d4;color:var(--green)}
.ea-step-when{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.ea-step h4{font-family:var(--serif);font-size:22px;color:var(--ink);margin-bottom:8px;letter-spacing:-.01em}
.ea-step p{font-size:14px;line-height:1.55;color:var(--ink-soft)}

/* dark CTA box */
.ea-cta{max-width:1180px;margin:0 auto;padding:40px var(--pad) 120px}
.ea-cta-box{background:var(--ink);border-radius:18px;padding:80px 56px;text-align:center;position:relative;overflow:hidden}
.ea-cta-box::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:520px;height:340px;
  background:radial-gradient(circle,var(--gold-bright) 0%,transparent 60%);opacity:.14;border-radius:50%}
.ea-cta-box h2{font-family:var(--serif);font-size:clamp(34px,5vw,68px);line-height:.98;letter-spacing:-.03em;
  color:var(--paper);max-width:18ch;margin:0 auto;position:relative}
.ea-cta-box .btn{margin-top:36px;position:relative}
.ea-cta-note{font-family:var(--mono);font-size:11px;color:#7c776e;margin-top:20px;letter-spacing:.1em;position:relative}

/* ==========================================================================
   RESPONSIVE  (mobile-friendly)
   ========================================================================== */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .scan-grid,.quote-grid{grid-template-columns:1fr;gap:40px}
  .features-grid,.pricing-grid,.news-grid,.ea-perks{grid-template-columns:repeat(2,1fr)}
  .ea-hero-grid{grid-template-columns:1fr;gap:48px}
  .ea-steps{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  :root{--pad:22px}
  .section{padding:72px 0}
  .hero{padding:56px var(--pad) 64px}
  /* keep big display type from overflowing narrow screens */
  .hero-title{font-size:clamp(34px,8.8vw,52px)}
  .h2{font-size:clamp(30px,7.4vw,44px)}
  .article h1{font-size:clamp(32px,8vw,46px)}
  .metric .big{font-size:38px}
  .features-grid,.pricing-grid,.news-grid,.ea-perks{grid-template-columns:1fr}
  .price-card--featured{order:-1}
  .stat-grid{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr 1fr;gap:24px}
  .hero-stats{gap:20px}
  /* early-access page */
  .ea-hero{padding:48px 0 64px}
  .ea-h1{font-size:clamp(36px,9vw,56px)}
  .ea-h2{font-size:clamp(28px,7.4vw,44px)}
  .ea-sec{padding:72px 0}
  .ea-cta{padding:24px var(--pad) 80px}
  .ea-cta-box{padding:56px 28px}

  /* --- CSS-only hamburger nav ---
     The closed panel stays anchored at right:0 INSIDE the viewport (never
     translated off to the right — that would expand horizontal scroll because
     position:fixed ignores ancestor overflow). It's hidden with opacity +
     visibility and only animates vertically, so it can't cause overflow. */
  .nav-right{position:fixed;top:0;right:0;bottom:0;width:min(82vw,320px);background:var(--paper);
    border-left:1px solid var(--hairline);flex-direction:column;align-items:stretch;gap:0;
    padding:84px 28px 28px;
    opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-6px);
    transition:opacity .22s ease,transform .22s ease,visibility .22s;
    box-shadow:-20px 0 60px -30px rgba(26,24,20,.4);z-index:60}
  .nav-links{flex-direction:column;gap:0;font-size:17px}
  .nav-links a{padding:16px 0;border-bottom:1px solid var(--hairline-soft);color:var(--ink)}
  .nav-cta{text-align:center;margin-top:20px;padding:14px 18px;font-size:15px}
  .nav-toggle-label{display:flex;flex-direction:column;justify-content:center;gap:5px;
    width:42px;height:42px;cursor:pointer;z-index:70;position:relative}
  .nav-toggle-label span{display:block;height:2px;width:24px;background:var(--ink);border-radius:2px;
    transition:transform .25s ease,opacity .25s ease}
  .nav-toggle:checked ~ .nav-right{opacity:1;visibility:visible;pointer-events:auto;transform:none}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* dim backdrop when open */
  .nav-toggle:checked ~ .nav-scrim{position:fixed;inset:0;background:rgba(26,24,20,.35);z-index:55}
}
@media(min-width:721px){.nav-scrim{display:none}}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important}
}
