/**
 * ValixData — Core Design System
 * The single source of truth for all design tokens, typography,
 * layout utilities, components, and animations.
 *
 * Every page links to this file. Changes here propagate everywhere.
 * DO NOT duplicate these rules in page-level <style> blocks.
 */


*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#060D1A;--s1:#0A1525;--s2:#0F1D30;--s3:#142038;--sur:#0D1B2E;--sur2:#122033;
  --tx:#EDE8DC;--tx2:#BDB8AE;--tx3:#8A96A6;--dim:#647080;
  --bd:rgba(255,255,255,0.06);--bd2:rgba(255,255,255,0.09);
  --gold:#C4A23A;--gold2:#E8C96A;--gold-d:rgba(196,162,58,0.12);--gold-b:rgba(196,162,58,0.22);
  --gr:#15C98A;--rd:#E85252;--am:#E8943A;--bl:#4A9EE0;--pu:#9B7FE0;
  --r:10px;--r2:7px;--nav-h:58px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',monospace;
}
html{scroll-behavior:smooth}
body{background:var(--bg);font-family:var(--sans);color:var(--tx);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes fadeup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(21,201,138,0.4)}50%{box-shadow:0 0 0 8px rgba(21,201,138,0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes countup{from{opacity:0}to{opacity:1}}

/* ══ HERO SIGNAL STREAM ══════════════════════════════════════════════ */
#hero-signal-stream{font-family:var(--mono)}
#signal-log div:first-child{animation:fadeup .3s ease}
.dc-processing-spin{display:inline-block;animation:spin .8s linear infinite}

/* ══ TICKER ══════════════════════════════════════════════════════════ */
.tl{color:var(--tx3)}.tv{color:var(--tx);font-weight:500}.tu{color:var(--gr);font-size:9px}.td{color:var(--rd);font-size:9px}.tn{color:var(--tx3);font-size:9px}

/* ══ NAV ═════════════════════════════════════════════════════════════ */

/* Dropdown menus */

/* ══ HERO ════════════════════════════════════════════════════════════ */
.hero{padding:80px 28px 60px;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:center}
.hero-eyebrow{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.hero-eyebrow-badge{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;padding:4px 10px;border-radius:4px;background:rgba(21,201,138,0.1);color:var(--gr);border:1px solid rgba(21,201,138,0.2)}
.hero-eyebrow-time{font-size:10px;color:var(--tx3);font-family:var(--mono)}
.hero-h1{font-family:var(--serif);font-size:58px;font-weight:700;line-height:1.05;letter-spacing:-1px;color:var(--tx);margin-bottom:20px}
.hero-h1 em{color:var(--gold);font-style:normal}
.hero-h1 .h1-sub{display:block;font-size:42px;font-weight:400;color:var(--tx2);margin-top:4px}
.hero-sub{font-size:16px;color:var(--tx2);line-height:1.6;margin-bottom:32px;max-width:480px}
.hero-sub strong{color:var(--tx);font-weight:600}
.hero-ctas{display:flex;align-items:center;gap:12px;margin-bottom:40px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--gold);color:#060D1A;font-size:14px;font-weight:700;border-radius:var(--r2);cursor:pointer;border:none;font-family:var(--sans);transition:all .15s;letter-spacing:.2px}
.btn-primary:hover{background:var(--gold2);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;background:transparent;color:var(--tx2);font-size:13px;font-weight:600;border-radius:var(--r2);cursor:pointer;border:1px solid var(--bd2);font-family:var(--sans);transition:all .15s}
.btn-ghost:hover{background:rgba(255,255,255,0.04);color:var(--tx);border-color:rgba(255,255,255,0.14)}
.hero-proof{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hero-proof-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--tx3)}
.hero-proof-item strong{color:var(--tx2);font-weight:600}

/* Hero right — live terminal preview */
.hero-terminal-preview{background:var(--s1);border:1px solid var(--bd);border-radius:12px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.hdp-bar{background:var(--s2);border-bottom:1px solid var(--bd);padding:10px 14px;display:flex;align-items:center;gap:8px}
.hdp-dot{width:8px;height:8px;border-radius:50%}
.hdp-title{font-size:10px;font-weight:700;color:var(--tx2);margin-left:4px;flex:1}
.hdp-live{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--gr);background:rgba(21,201,138,0.1);border:1px solid rgba(21,201,138,0.2);padding:2px 7px;border-radius:4px}
.hdp-kpis{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bd);margin:0}
.hdp-kpi{background:var(--s1);padding:12px 14px}
.hdp-kpi-label{font-size:9px;color:var(--tx3);font-family:var(--mono);margin-bottom:4px}
.hdp-kpi-val{font-size:18px;font-weight:700;color:var(--tx);font-family:var(--mono);letter-spacing:-0.5px}
.hdp-kpi-chg{font-size:10px;font-family:var(--mono);margin-top:2px}
.chg-up{color:var(--gr)}.chg-dn{color:var(--rd)}.chg-fl{color:var(--tx3)}
.hdp-aria{padding:12px 14px;border-top:1px solid var(--bd);background:rgba(155,127,224,0.04)}
.hdp-aria-prompt{font-size:11px;color:var(--tx3);margin-bottom:8px;font-style:italic}
.hdp-aria-resp{font-size:12px;color:var(--tx2);line-height:1.5}
.hdp-aria-badge{display:inline-flex;align-items:center;gap:4px;font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--pu);background:rgba(155,127,224,0.1);border:1px solid rgba(155,127,224,0.2);padding:2px 7px;border-radius:4px;margin-bottom:6px}
.hdp-footer{padding:10px 14px;border-top:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.hdp-updated{font-size:9px;color:var(--tx3);font-family:var(--mono)}
.hdp-updated span{color:var(--gr)}
.hdp-action{font-size:10px;color:var(--gold);font-weight:600;cursor:pointer}

/* ══ TIME SAVINGS STRIP ══════════════════════════════════════════════ */
.time-strip{background:linear-gradient(135deg,var(--s1),rgba(196,162,58,0.04));border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);padding:40px 28px}
.time-strip-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--bd)}
.ts-cell{background:var(--bg);padding:28px 32px}
.ts-num{font-family:var(--serif);font-size:52px;font-weight:700;color:var(--gold);line-height:1;margin-bottom:8px}
.ts-num em{font-style:normal;font-size:24px;color:var(--tx3)}
.ts-label{font-size:14px;font-weight:700;color:var(--tx);margin-bottom:4px}
.ts-desc{font-size:12px;color:var(--tx3);line-height:1.5}

/* ══ HOW IT WORKS / ONBOARDING ════════════════════════════════════════ */
.section{padding:72px 28px;max-width:1200px;margin:0 auto}
.section-eyebrow{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--gold);margin-bottom:12px}
.section-title{font-family:var(--serif);font-size:42px;font-weight:700;color:var(--tx);margin-bottom:16px;line-height:1.1}
.section-title em{color:var(--gold);font-style:normal}
.section-sub{font-size:15px;color:var(--tx2);line-height:1.6;max-width:560px;margin-bottom:48px}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:24px;position:relative;transition:border-color .2s}
.step:hover{border-color:rgba(196,162,58,0.2)}
.step-num{width:32px;height:32px;border-radius:50%;background:rgba(196,162,58,0.1);border:1px solid rgba(196,162,58,0.25);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--gold);margin-bottom:16px;font-family:var(--mono)}
.step-icon{font-size:20px;margin-bottom:12px}
.step-title{font-size:14px;font-weight:700;color:var(--tx);margin-bottom:8px}
.step-desc{font-size:12px;color:var(--tx3);line-height:1.6}
.step-time{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--gr);background:rgba(21,201,138,0.08);border:1px solid rgba(21,201,138,0.15);padding:3px 8px;border-radius:4px}

/* ══ ARIA ONBOARDING AI ═══════════════════════════════════════════════ */
.aria-onboard{background:var(--s1);border:1px solid var(--bd);border-radius:12px;overflow:hidden;max-width:700px;margin:0 auto}
.aob-header{background:var(--s2);border-bottom:1px solid var(--bd);padding:14px 20px;display:flex;align-items:center;gap:10px}
.aob-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,rgba(155,127,224,0.3),rgba(74,158,224,0.2));border:1px solid rgba(155,127,224,0.3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.aob-name{font-size:13px;font-weight:700;color:var(--tx)}
.aob-status{font-size:10px;color:var(--gr)}
.aob-messages{padding:20px;display:flex;flex-direction:column;gap:14px;min-height:220px;max-height:340px;overflow-y:auto}
.aob-msg{display:flex;gap:10px;animation:fadeup .3s ease}
.aob-msg.user{flex-direction:row-reverse}
.aob-msg-avatar{width:26px;height:26px;border-radius:50%;background:var(--s3);border:1px solid var(--bd2);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--tx3);flex-shrink:0}
.aob-msg.user .aob-msg-avatar{background:rgba(196,162,58,0.1);border-color:rgba(196,162,58,0.2);color:var(--gold)}
.aob-bubble{background:var(--s2);border:1px solid var(--bd);border-radius:10px;padding:10px 14px;font-size:13px;color:var(--tx2);line-height:1.5;max-width:440px}
.aob-msg.user .aob-bubble{background:rgba(196,162,58,0.07);border-color:rgba(196,162,58,0.15);color:var(--tx)}
.aob-typing{display:flex;gap:4px;align-items:center;padding:6px 0}
.aob-typing span{width:5px;height:5px;border-radius:50%;background:var(--tx3);animation:blink .8s infinite}
.aob-typing span:nth-child(2){animation-delay:.2s}
.aob-typing span:nth-child(3){animation-delay:.4s}
.aob-chips{display:flex;gap:8px;flex-wrap:wrap;padding:0 20px 14px}
.aob-chip{padding:7px 14px;background:var(--s2);border:1px solid var(--bd2);border-radius:100px;font-size:11px;color:var(--tx2);cursor:pointer;transition:all .15s;font-weight:500}
.aob-chip:hover{border-color:rgba(196,162,58,0.3);color:var(--gold);background:rgba(196,162,58,0.06)}
.aob-input-wrap{border-top:1px solid var(--bd);padding:12px 16px;display:flex;gap:10px;align-items:center}
.aob-input{flex:1;background:rgba(255,255,255,0.04);border:1px solid var(--bd2);border-radius:var(--r2);padding:9px 14px;font-size:13px;color:var(--tx);font-family:var(--sans);outline:none}
.aob-input:focus{border-color:rgba(155,127,224,0.4)}
.aob-input::placeholder{color:var(--tx3)}
.aob-send{width:34px;height:34px;border-radius:7px;background:var(--gold);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;transition:background .15s}
.aob-send:hover{background:var(--gold2)}

/* ══ TERMINALS SHOWCASE ════════════════════════════════════════════════════ */
.terminal-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:24px}
.terminal-card{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:12px 14px;cursor:pointer;transition:all .15s;position:relative}
.terminal-card:hover{border-color:rgba(196,162,58,0.25);background:var(--s2);transform:translateY(-1px)}
.terminal-card-name{font-size:11px;font-weight:700;color:var(--tx);margin-bottom:4px}
.terminal-card-tag{font-size:10px;color:var(--tx3)}
.terminal-card-live{position:absolute;top:10px;right:10px;width:5px;height:5px;border-radius:50%;background:var(--gr);animation:blink 2s infinite}
.terminal-more{text-align:center;padding:16px}
.terminal-more a{font-size:13px;color:var(--gold);font-weight:600}
.terminal-more a:hover{color:var(--gold2)}

/* ══ FEATURES GRID ══════════════════════════════════════════════════== */
.features-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.feat{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:24px;transition:border-color .2s}
.feat:hover{border-color:rgba(196,162,58,0.18)}
.feat-icon{font-size:22px;margin-bottom:14px}
.feat-title{font-size:14px;font-weight:700;color:var(--tx);margin-bottom:6px}
.feat-desc{font-size:12px;color:var(--tx3);line-height:1.6}
.feat-badge{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:3px 8px;border-radius:4px}
.feat-badge.live{background:rgba(21,201,138,0.1);color:var(--gr);border:1px solid rgba(21,201,138,0.2)}
.feat-badge.ai{background:rgba(155,127,224,0.1);color:var(--pu);border:1px solid rgba(155,127,224,0.2)}
.feat-badge.data{background:rgba(74,158,224,0.1);color:var(--bl);border:1px solid rgba(74,158,224,0.2)}

/* ══ DATA SOURCES ════════════════════════════════════════════════════ */
.sources-strip{border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);padding:28px 28px;background:var(--s1)}
.sources-inner{max-width:1200px;margin:0 auto}
.sources-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--tx3);margin-bottom:16px;text-align:center}
.sources-list{display:flex;align-items:center;gap:0;flex-wrap:wrap;justify-content:center}
.source-tag{padding:6px 16px;font-size:11px;color:var(--tx3);font-family:var(--mono);border-right:1px solid var(--bd);font-weight:500}
.source-tag:last-child{border-right:none}
.source-tag strong{color:var(--tx2)}

/* ══ PRICING ════════════════════════════════════════════════════════= */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:40px}
.price-card{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:24px;position:relative;transition:all .2s}
.price-card:hover{border-color:rgba(196,162,58,0.2)}
.price-card.featured{border-color:var(--gold);background:rgba(196,162,58,0.04)}
.price-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--gold);color:#060D1A;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:3px 12px;border-radius:100px;white-space:nowrap}
.price-name{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);margin-bottom:8px}
.price-amount{font-family:var(--mono);font-size:32px;font-weight:700;color:var(--tx);line-height:1;margin-bottom:4px}
.price-amount em{font-style:normal;font-size:14px;color:var(--tx3);font-weight:400}
.price-per{font-size:11px;color:var(--tx3);margin-bottom:20px}
.price-features{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.price-features li{font-size:12px;color:var(--tx2);display:flex;align-items:flex-start;gap:7px}
.price-features li:before{content:'✓';color:var(--gr);font-weight:800;flex-shrink:0;margin-top:1px}
.price-cta{width:100%;padding:11px;background:var(--gold);color:#060D1A;border:none;border-radius:var(--r2);font-size:13px;font-weight:700;cursor:pointer;font-family:var(--sans);transition:background .15s}
.price-cta:hover{background:var(--gold2)}
.price-card:not(.featured) .price-cta{background:transparent;color:var(--tx2);border:1px solid var(--bd2)}
.price-card:not(.featured) .price-cta:hover{background:rgba(255,255,255,0.04);color:var(--tx)}

/* ══ NOVA MORNING BRIEF ══════════════════════════════════════════════ */
.nova-section{background:linear-gradient(135deg,rgba(196,162,58,0.06),rgba(155,127,224,0.04));border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);padding:72px 28px}
.nova-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:center}
.nova-sample{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.nova-sample-head{background:var(--s2);border-bottom:1px solid var(--bd);padding:12px 16px;display:flex;align-items:center;justify-content:space-between}
.nova-sample-title{font-size:11px;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:1px}
.nova-sample-time{font-size:9px;color:var(--tx3);font-family:var(--mono)}
.nova-brief-item{padding:12px 16px;border-bottom:1px solid var(--bd)}
.nova-brief-item:last-child{border-bottom:none}
.nbi-cat{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--am);margin-bottom:4px}
.nbi-title{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:3px}
.nbi-body{font-size:11px;color:var(--tx3);line-height:1.5}
.nbi-sig{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;color:var(--gr);margin-top:4px}

/* ══ TESTIMONIALS ════════════════════════════════════════════════════ */
.testimonials{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.testi{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:24px}
.testi-quote{font-size:13px;color:var(--tx2);line-height:1.6;margin-bottom:16px;font-style:italic}
.testi-quote strong{color:var(--gold);font-style:normal}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--s2),var(--s3));border:1px solid var(--bd2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--gold)}
.testi-name{font-size:12px;font-weight:700;color:var(--tx)}
.testi-role{font-size:10px;color:var(--tx3)}

/* ══ DATA FRESHNESS BAR ═══════════════════════════════════════════════ */
.freshness-bar{background:var(--s1);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);padding:20px 28px}
.freshness-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:32px;flex-wrap:wrap}
.fresh-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--tx3)}
.fresh-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.fresh-dot.green{background:var(--gr);box-shadow:0 0 6px rgba(21,201,138,0.5)}
.fresh-dot.gold{background:var(--gold)}
.fresh-dot.blue{background:var(--bl)}
.fresh-label{font-weight:600;color:var(--tx2)}
.fresh-divider{width:1px;height:20px;background:var(--bd);flex-shrink:0}

/* ══ FOOTER ══════════════════════════════════════════════════════════ */

.ntd-green{background:var(--gr)}.ntd-blue{background:var(--bl)}.ntd-gold{background:var(--gold)}.ntd-purple{background:var(--pu)}.ntd-red{background:var(--rd)}

/* ══ MODALS ══════════════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(3,8,16,0.88);z-index:900;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.modal-overlay.open{display:flex}
.modal{background:var(--s1);border:1px solid var(--bd2);border-radius:14px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.7);animation:fadeup .2s ease}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:12px}
.modal-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--tx);flex:1}
.modal-close{background:transparent;border:none;font-size:18px;color:var(--tx3);cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .15s}
.modal-close:hover{color:var(--tx)}
.modal-body{padding:24px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--tx2);margin-bottom:6px}
.form-input{width:100%;background:rgba(255,255,255,0.04);border:1px solid var(--bd2);border-radius:var(--r2);padding:10px 14px;font-size:13px;color:var(--tx);font-family:var(--sans);outline:none;transition:border-color .15s}
.form-input:focus{border-color:rgba(196,162,58,0.35)}
.form-input::placeholder{color:var(--tx3)}
.form-submit{width:100%;padding:13px;background:var(--gold);color:#060D1A;border:none;border-radius:var(--r2);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--sans);margin-top:8px;transition:background .15s}
.form-submit:hover{background:var(--gold2)}
.form-alt{text-align:center;font-size:12px;color:var(--tx3);margin-top:14px}
.form-alt a{color:var(--gold);cursor:pointer}
.form-err{color:var(--rd);font-size:11px;margin-top:4px;display:none}
.form-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:11px;color:var(--tx3)}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--bd)}

/* ══ TERMINAL FINDER MODAL ═══════════════════════════════════════════════ */
.terminal-finder{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:400px;overflow-y:auto}
.df-card{background:var(--s2);border:1px solid var(--bd);border-radius:8px;padding:12px;cursor:pointer;transition:all .15s}
.df-card:hover{border-color:rgba(196,162,58,0.25);background:rgba(196,162,58,0.04)}
.df-name{font-size:12px;font-weight:700;color:var(--tx);margin-bottom:2px}
.df-tag{font-size:10px;color:var(--tx3)}

/* ══ MISC ════════════════════════════════════════════════════════════ */
.section-divider{height:1px;background:var(--bd);max-width:1200px;margin:0 auto}
.text-gold{color:var(--gold)}
.text-gr{color:var(--gr)}
.loading-spinner{width:16px;height:16px;border:2px solid rgba(196,162,58,0.2);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}
.toast{position:fixed;bottom:24px;right:24px;background:var(--s2);border:1px solid var(--bd2);border-radius:8px;padding:12px 18px;font-size:13px;color:var(--tx);z-index:999;box-shadow:0 8px 32px rgba(0,0,0,.4);display:none;animation:fadeup .2s ease}
.toast.show{display:block}
.toast.success{border-color:rgba(21,201,138,0.3);color:var(--gr)}
.toast.error{border-color:rgba(232,82,82,0.3);color:var(--rd)}
.section-full{padding:72px 28px;border-top:1px solid var(--bd)}
.section-full-inner{max-width:1200px;margin:0 auto}

@media(max-width:900px){
  .hero{grid-template-columns:1fr;gap:32px}
  .hero-terminal-preview{display:none}
  .hero-h1{font-size:40px}
  .steps{grid-template-columns:1fr 1fr}
  .features-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .terminal-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:1fr}
  .nova-inner{grid-template-columns:1fr}
  .time-strip-inner{grid-template-columns:1fr}
  nav .nav-links{display:none}
  #hamburger{display:flex!important}
  .nav-hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none}
  .nav-hamburger span{display:block;width:20px;height:1.5px;background:var(--tx2);transition:all .2s}
  .mobile-nav{display:none}
  .mobile-nav-drawer{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:rgba(6,13,26,.98);z-index:400;padding:20px 24px;overflow-y:auto;flex-direction:column;gap:0}
  .mobile-nav-drawer.open{display:flex}
  .mob-link{display:block;padding:13px 0;font-size:15px;font-weight:500;color:var(--tx2);border-bottom:1px solid var(--bd);text-decoration:none}
  .mob-link:hover{color:var(--gold)}
  .mob-section{font-size:9px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--tx3);padding:18px 0 8px}
  .mob-btns{display:flex;gap:10px;margin-top:24px}
  .mob-btn{flex:1;padding:12px;border-radius:var(--r2);font-size:14px;font-weight:700;text-align:center;cursor:pointer;font-family:var(--sans);text-decoration:none}
  .mob-btn.outline{border:1px solid var(--bd2);color:var(--tx2);background:transparent}
  .mob-btn.gold{background:var(--gold);color:#060D1A;border:none}
  
}

.hero-left{min-width:0}

/* ── SHARED COMPONENT EXTENSIONS ──────────────────────────────────── */

/* Page layout wrapper */
.pw{max-width:1200px;margin:0 auto;padding:0 28px}

/* Section spacing */
.section{padding:72px 28px;max-width:1200px;margin:0 auto}
.section-sm{padding:48px 28px;max-width:1200px;margin:0 auto}

/* Typography */
.eyebrow{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--gold);display:block;margin-bottom:12px}
.page-title{font-family:var(--serif);font-size:52px;font-weight:700;line-height:1.05;color:var(--tx);margin-bottom:16px}
.page-title em{color:var(--gold);font-style:normal}
.page-sub{font-size:16px;color:var(--tx2);line-height:1.6;max-width:560px;margin-bottom:32px}
.section-title{font-family:var(--serif);font-size:38px;font-weight:700;line-height:1.1;color:var(--tx);margin-bottom:12px}
.section-title em{color:var(--gold);font-style:normal}

/* Cards */
.card{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:24px;transition:border-color .2s}
.card:hover{border-color:rgba(196,162,58,0.2)}
.card-title{font-size:14px;font-weight:700;color:var(--tx);margin-bottom:6px}
.card-desc{font-size:12px;color:var(--tx3);line-height:1.6}

/* Buttons */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--gold);color:#060D1A;font-size:14px;font-weight:700;border-radius:var(--r2);border:none;cursor:pointer;font-family:var(--sans);transition:all .15s;letter-spacing:.2px;text-decoration:none}
.btn-primary:hover{background:var(--gold2);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;background:transparent;color:var(--tx2);font-size:13px;font-weight:600;border-radius:var(--r2);border:1px solid var(--bd2);cursor:pointer;font-family:var(--sans);transition:all .15s;text-decoration:none}
.btn-ghost:hover{background:rgba(255,255,255,0.04);color:var(--tx);border-color:rgba(255,255,255,0.14)}
.btn-gold{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--gold);color:#060D1A;font-size:13px;font-weight:700;border-radius:var(--r2);border:none;cursor:pointer;font-family:var(--sans);transition:all .15s;text-decoration:none}
.btn-gold:hover{background:var(--gold2)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;background:transparent;border:1px solid var(--bd2);color:var(--tx2);font-size:13px;font-weight:600;border-radius:var(--r2);cursor:pointer;font-family:var(--sans);transition:all .15s;text-decoration:none}
.btn-outline:hover{background:rgba(255,255,255,0.04);color:var(--tx)}

/* Divider */
.divider{height:1px;background:var(--bd);margin:0}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:3px 8px;border-radius:4px}
.badge-live{background:rgba(21,201,138,0.1);color:var(--gr);border:1px solid rgba(21,201,138,0.2)}
.badge-ai{background:rgba(155,127,224,0.1);color:var(--pu);border:1px solid rgba(155,127,224,0.2)}
.badge-data{background:rgba(74,158,224,0.1);color:var(--bl);border:1px solid rgba(74,158,224,0.2)}
.badge-new{background:rgba(21,201,138,0.12);color:var(--gr)}

/* Cookie consent (present on all pages via nd-footer) */
#nd-ck{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#0A1525;border-top:1px solid rgba(196,162,58,0.18);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--sans);box-shadow:0 -4px 32px rgba(0,0,0,.5);animation:fadeup .3s ease}
#nd-ck p{font-size:12px;color:var(--tx2);line-height:1.5;margin:0;max-width:660px}
#nd-ck a{color:var(--gold);text-decoration:none}
.nd-ck-w{display:flex;gap:8px;flex-shrink:0}
.nd-cb{border:none;border-radius:7px;padding:8px 18px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}
.nd-ca{background:var(--gold);color:#060D1A}
.nd-cd{background:transparent;color:var(--tx3);border:1px solid rgba(255,255,255,0.1)}

/* Accessibility */
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* Scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.15)}

/* Selection */
::selection{background:rgba(196,162,58,0.25);color:var(--tx)}

/* Responsive utilities */
@media(max-width:768px){
  .pw{padding:0 20px}
  .section{padding:48px 20px}
  .section-sm{padding:32px 20px}
  .page-title{font-size:38px}
  .section-title{font-size:28px}
  .btn-primary{padding:12px 22px;font-size:13px}
}
@media(max-width:480px){
  .page-title{font-size:30px}
  .section-title{font-size:24px}
}

/* ── Nav dropdown + live badge + icon classes ── */
.has-drop{cursor:pointer}
.has-drop .nav-drop{display:none;position:absolute;top:100%;left:0}
.has-drop:hover .nav-drop,.has-drop.open .nav-drop{display:block}
.live-badge{display:inline-flex;align-items:center;gap:5px;font-size:9px;
  font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--gr);
  background:rgba(21,201,138,0.08);border:1px solid rgba(21,201,138,0.2);
  border-radius:100px;padding:3px 9px}
.live-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--gr);
  animation:blink 1.5s infinite;flex-shrink:0}
.ndi-icon{font-size:20px;width:36px;text-align:center;flex-shrink:0}
.ndi-desc{font-size:11px;color:var(--tx3);line-height:1.5;margin-top:2px}
.red{color:var(--rd)}

/* ══════════════════════════════════════════════════════════════════════
   DESIGN SYSTEM v2 — DEPTH, ATMOSPHERE, ELEVATION
   All rules below are purely additive. Zero breaking changes.
   ══════════════════════════════════════════════════════════════════════ */

/* ── Extended tokens ──────────────────────────────────────────────── */
:root {
  /* Shadow tokens */
  --sh-sm:  0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
  --sh-md:  0 4px 16px rgba(0,0,0,.5), 0 2px 6px rgba(0,0,0,.3);
  --sh-lg:  0 16px 48px rgba(0,0,0,.6), 0 4px 16px rgba(0,0,0,.4);
  --sh-xl:  0 32px 80px rgba(0,0,0,.7), 0 8px 24px rgba(0,0,0,.4);
  --sh-gold: 0 0 24px rgba(196,162,58,.18), 0 4px 12px rgba(0,0,0,.4);
  --sh-glow: 0 0 40px rgba(196,162,58,.12);

  /* Gradient tokens */
  --grad-gold: linear-gradient(135deg, #C4A23A 0%, #E8C96A 50%, #C4A23A 100%);
  --grad-surface: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%);
  --grad-hero: radial-gradient(ellipse 80% 50% at 50% -10%, rgba(196,162,58,.12) 0%, transparent 70%);
  --grad-card: linear-gradient(145deg, rgba(255,255,255,.035) 0%, rgba(255,255,255,.008) 100%);

  /* Spacing scale */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;

  /* Easing */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Atmosphere: page-level ambient light ─────────────────────────── */
body::before {
  content: '';
  position: fixed;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 120vw;
  height: 60vh;
  background: radial-gradient(ellipse at center,
    rgba(196,162,58,.055) 0%,
    rgba(21,201,138,.02) 40%,
    transparent 70%);
  pointer-events: none;
  z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* ── Grain overlay (subtle film texture) ─────────────────────────── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9998;
  opacity: .5;
}

/* ── Elevated card system ─────────────────────────────────────────── */
/* Replaces the flat s1+bd card look with proper elevation */
.card,
.feat,
.step,
.price-card,
.testi,
.nova-sample,
.aria-onboard {
  background: linear-gradient(145deg,
    rgba(255,255,255,.035) 0%,
    rgba(255,255,255,.008) 100%),
    var(--s1);
  box-shadow: var(--sh-sm), inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .2s var(--ease-out),
              border-color .2s,
              box-shadow .2s var(--ease-out);
}
.card:hover,
.feat:hover,
.step:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md), inset 0 1px 0 rgba(255,255,255,.08);
  border-color: rgba(196,162,58,.22);
}
.price-card.featured {
  box-shadow: var(--sh-gold);
  border-color: rgba(196,162,58,.6);
}
.price-card.featured::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: calc(var(--r) + 1px);
  background: linear-gradient(135deg,
    rgba(196,162,58,.4) 0%,
    rgba(232,201,106,.15) 50%,
    rgba(196,162,58,.4) 100%);
  z-index: -1;
}

/* ── Hero terminal preview — glass treatment ─────────────────────────── */
.hero-terminal-preview {
  box-shadow: var(--sh-xl);
  border-color: rgba(255,255,255,.1);
  background: linear-gradient(145deg,
    rgba(15,29,48,.98) 0%,
    rgba(10,21,37,.98) 100%);
}

/* ── Gold button — shimmer animation ─────────────────────────────── */
@keyframes gold-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
.btn-primary,
.btn-gold,
.price-cta,
.form-submit {
  background-size: 200% auto;
  background-image: linear-gradient(90deg,
    #C4A23A 0%, #E8C96A 30%, #D4B24A 50%, #C4A23A 100%);
  transition: background-position .4s var(--ease-in-out),
              transform .15s var(--ease-out),
              box-shadow .15s;
}
.btn-primary:hover,
.btn-gold:hover,
.price-cta:hover,
.form-submit:hover {
  background-position: right center;
  box-shadow: 0 4px 20px rgba(196,162,58,.35);
  transform: translateY(-1px);
}
.btn-primary:active,
.btn-gold:active {
  transform: translateY(0);
  box-shadow: none;
}

/* ── Gradient border utility ──────────────────────────────────────── */
.grad-border {
  position: relative;
  border: 1px solid transparent !important;
  background-clip: padding-box;
}
.grad-border::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg,
    rgba(196,162,58,.5) 0%,
    rgba(255,255,255,.06) 50%,
    rgba(196,162,58,.5) 100%);
  z-index: -1;
}

/* ── Section backgrounds — ambient light per section ─────────────── */
.nova-section {
  background:
    radial-gradient(ellipse 60% 50% at 20% 50%, rgba(196,162,58,.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 80% 50%, rgba(155,127,224,.04) 0%, transparent 60%),
    var(--bg);
}
.time-strip {
  background:
    radial-gradient(ellipse 70% 100% at 50% 50%, rgba(196,162,58,.04) 0%, transparent 70%),
    linear-gradient(135deg, var(--s1), rgba(196,162,58,.02));
}
.sources-strip {
  background:
    radial-gradient(ellipse 80% 100% at 50% 100%, rgba(21,201,138,.03) 0%, transparent 70%),
    var(--s1);
}

/* ── Typography: optical refinements ─────────────────────────────── */
.hero-h1 {
  text-shadow: 0 2px 40px rgba(196,162,58,.08);
  letter-spacing: -1.5px;
}
.section-title,
.page-title {
  text-shadow: 0 1px 20px rgba(0,0,0,.3);
}
/* Refined em/accent color with subtle glow */
.hero-h1 em,
.section-title em,
.page-title em {
  text-shadow: 0 0 30px rgba(196,162,58,.3);
}

/* ── Eyebrow: add accent line ─────────────────────────────────────── */
.eyebrow,
.section-eyebrow {
  position: relative;
  padding-left: 14px;
}
.eyebrow::before,
.section-eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 8px rgba(196,162,58,.6);
}

/* ── Number/stat display — monospace glow ─────────────────────────── */
.ts-num {
  text-shadow: 0 0 30px rgba(196,162,58,.2);
}
.hdp-kpi-val {
  text-shadow: 0 0 16px rgba(196,162,58,.15);
}

/* ── Live dot — breathing glow ────────────────────────────────────── */
@keyframes live-breathe {
  0%, 100% { box-shadow: 0 0 0 0 rgba(21,201,138,.5); opacity: 1; }
  50%       { box-shadow: 0 0 0 5px rgba(21,201,138,.0); opacity: .8; }
}
.hdp-live::before,
.terminal-card-live,
.live-dot,
.lb-dot,
.fresh-dot.green {
  animation: live-breathe 2s ease-in-out infinite !important;
}

/* ── Badge refinements ────────────────────────────────────────────── */
.badge-live,
.badge-ai,
.badge-data,
.step-time,
.feat-badge,
.hdp-live,
.hero-eyebrow-badge {
  backdrop-filter: blur(4px);
}

/* ── Form inputs — focus ring ─────────────────────────────────────── */
.form-input:focus,
.aob-input:focus,
.field input:focus,
.field textarea:focus,
.field select:focus {
  box-shadow: 0 0 0 3px rgba(196,162,58,.12);
}

/* ── Modal — glass effect ─────────────────────────────────────────── */
.modal-overlay {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: rgba(3,8,16,.82);
}
.modal {
  background: linear-gradient(145deg,
    rgba(15,29,48,.98) 0%,
    rgba(10,21,37,.98) 100%);
  box-shadow: var(--sh-xl), inset 0 1px 0 rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
}

/* ── Scroll-reveal utility ────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s var(--ease-out),
              transform .6s var(--ease-out);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* ── Subtle hover shimmer on table rows / list items ─────────────── */
tr:hover,
.nova-brief-item:hover {
  background: rgba(255,255,255,.025);
  transition: background .15s;
}

/* ── KPI cells — hover micro lift ────────────────────────────────── */
.hdp-kpi {
  transition: background .15s;
  cursor: default;
}
.hdp-kpi:hover {
  background: rgba(196,162,58,.04);
}

/* ── Pricing card: featured glow pulse ────────────────────────────── */
@keyframes featured-pulse {
  0%, 100% { box-shadow: var(--sh-gold); }
  50%       { box-shadow: 0 0 40px rgba(196,162,58,.25), 0 4px 16px rgba(0,0,0,.5); }
}
.price-card.featured {
  animation: featured-pulse 3s ease-in-out infinite;
}

/* ── Divider with gradient ────────────────────────────────────────── */
.divider,
.section-divider {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.1) 20%,
    rgba(196,162,58,.2) 50%,
    rgba(255,255,255,.1) 80%,
    transparent 100%);
}

/* ── Scrollbar — thinner, gold accent ───────────────────────────── */
::-webkit-scrollbar { width: 3px; height: 3px; }
::-webkit-scrollbar-thumb { background: rgba(196,162,58,.3); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: rgba(196,162,58,.5); }

/* ── Selection — gold ─────────────────────────────────────────────── */
::selection {
  background: rgba(196,162,58,.3);
  color: var(--tx);
  text-shadow: none;
}

/* ── Nav refinement: border-bottom gradient ──────────────────────── */
#nd-nav::after,
nav::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(196,162,58,.3) 30%,
    rgba(196,162,58,.5) 50%,
    rgba(196,162,58,.3) 70%,
    transparent 100%);
}
#nd-nav,
nav {
  position: relative;
}

/* ── Toast — refined ─────────────────────────────────────────────── */
.toast {
  backdrop-filter: blur(12px);
  background: linear-gradient(135deg,
    rgba(15,29,48,.97) 0%,
    rgba(10,21,37,.97) 100%);
  box-shadow: var(--sh-lg), inset 0 1px 0 rgba(255,255,255,.06);
}

/* ── Testi quote: decorative left accent ─────────────────────────── */
.testi {
  border-left: 2px solid rgba(196,162,58,.15);
}
.testi:hover {
  border-left-color: rgba(196,162,58,.4);
  box-shadow: var(--sh-md), -4px 0 12px rgba(196,162,58,.06);
}

/* ── Data source tags: subtle hover ─────────────────────────────── */
.source-tag {
  transition: color .15s;
}
.source-tag:hover {
  color: var(--tx2);
}

/* ── Reduced motion: respect OS preference ────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  body::before,
  body::after { display: none; }
}

/* ══ PERFORMANCE — Decorative animation overrides ══════════════════════
 * These animations run on every page load and have no functional value.
 * Disabling them frees the GPU and makes content appear instantly.
 * All functional animations (blink, spin, dots, ticker) are preserved.
 * ══════════════════════════════════════════════════════════════════════ */

/* Kill shimmer — gold shimmer on cards */
@keyframes shimmer { from { background-position: 0 0 } to { background-position: 0 0 } }
@keyframes gold-shimmer { from { background-position: 0 0 } to { background-position: 0 0 } }

/* Kill entrance animations — content should be visible immediately */
@keyframes fadeup  { from { opacity:1; transform:none } to { opacity:1; transform:none } }
@keyframes countup { from { opacity:1 } to { opacity:1 } }

/* Live-breathe: redundant with blink dot, costs GPU on every terminal page */
@keyframes live-breathe { 0%,100% { opacity:1 } }

/* Featured-pulse: decorative glow on pricing card */
@keyframes featured-pulse { 0%,100% { box-shadow: none } }

/* Honour OS reduce-motion preference — kill everything decorative */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  /* But keep functional spinners at readable speed */
  .spin, [class*="spin"] { animation-duration: 1s !important; }
}

/* ── Live data flash — fires when a value updates, not constantly ───── */
@keyframes nd-live-flash {
  0%   { color: var(--gold, #C4A23A); text-shadow: 0 0 8px rgba(196,162,58,.5); }
  60%  { color: var(--gold, #C4A23A); text-shadow: 0 0 4px rgba(196,162,58,.25); }
  100% { color: inherit; text-shadow: none; }
}
.nd-flashed {
  animation: nd-live-flash 0.5s ease-out forwards;
}

/* ══════════════════════════════════════════════════════════════════════
 * UNIVERSAL RESPONSIVE SYSTEM
 * Targets: 375px (iPhone SE) → 2560px (30" 1440p monitor)
 *
 * Breakpoints:
 *   375   — iPhone SE / small Android
 *   430   — iPhone 14/15 Pro Max
 *   768   — iPad portrait / large phone landscape
 *   1024  — iPad landscape / small laptop
 *   1280  — MacBook 13", 1366×768 laptop
 *   1440  — MacBook 16", standard desktop
 *   1920  — Full HD desktop
 *   2560  — 1440p / 4K / 30" monitors (cap content width)
 *
 * Philosophy: content should never be wider than it needs to be,
 * and never smaller than it's readable. clamp() handles the middle.
 * ══════════════════════════════════════════════════════════════════════ */

/* ── Universal container — use on every page wrapper ───────────────── */
.nd-container {
  width: 100%;
  max-width: 1260px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(16px, 4vw, 40px);
  padding-right: clamp(16px, 4vw, 40px);
}

/* Wide variant for full-bleed sections that still need a cap */
.nd-container-wide {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(16px, 4vw, 60px);
  padding-right: clamp(16px, 4vw, 60px);
}

/* ── Fluid typography scale ─────────────────────────────────────────── */
/* These replace hard-coded px sizes on headings.
   Usage: add class nd-h1, nd-h2, etc. to existing heading elements.
   Existing inline font-sizes take precedence — these are opt-in. */
.nd-h1 { font-size: clamp(28px, 5vw, 56px); line-height: 1.08; }
.nd-h2 { font-size: clamp(22px, 3.5vw, 44px); line-height: 1.12; }
.nd-h3 { font-size: clamp(18px, 2.5vw, 28px); line-height: 1.2; }
.nd-body { font-size: clamp(13px, 1.2vw, 15px); line-height: 1.7; }
.nd-small { font-size: clamp(11px, 0.9vw, 13px); }

/* ── 2560px cap — prevent content stretching on large monitors ──────── */
@media (min-width: 1920px) {
  .container,
  [class*="page-wrap"],
  [class*="wrap"] > .inner,
  .nd-container { max-width: 1260px; }
  .nd-container-wide { max-width: 1440px; }
  /* Nav and footer stay full-width but inner content caps */
  #nd-nav > *:not(#nd-burger):not(#nd-mob-overlay) { max-width: none; }
  .ndf-inner { max-width: 1260px !important; }
}

/* ── 1440px — MacBook 16" / 1440p monitors ─────────────────────────── */
@media (max-width: 1440px) {
  .nd-container { padding-left: clamp(16px, 3.5vw, 36px); padding-right: clamp(16px, 3.5vw, 36px); }
}

/* ── 1280px — MacBook 13" / 1366×768 laptops ───────────────────────── */
@media (max-width: 1280px) {
  .nd-container { padding-left: 28px; padding-right: 28px; }
  /* Pricing grid: 4 → 2 columns on smaller laptops */
  .pricing-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Hero: reduce top padding */
  #hero { padding-top: clamp(48px, 8vh, 80px); }
}

/* ── 1024px — iPad landscape / 11" laptop ──────────────────────────── */
@media (max-width: 1024px) {
  .nd-container { padding-left: 24px; padding-right: 24px; }
  /* Terminal grid: 4-col → 2-col */
  .terminals-grid, .for-grid { grid-template-columns: repeat(2, 1fr); }
  /* Stats: 4-col → 2-col */
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  /* Proof stat row: 3 → 1 column on tablet */
  .proof-stat-row { grid-template-columns: repeat(3, 1fr); }
}

/* ── 820px — iPad 10th gen portrait (820×1180) ──────────────────────── */
@media (max-width: 860px) {
  .nd-container { padding-left: 20px; padding-right: 20px; }
  .hero-grid { grid-template-columns: 1fr !important; }
  .hero-terminal { display: none; }
  .proof-section-grid { grid-template-columns: 1fr !important; }
  .proof-stat-row { grid-template-columns: 1fr !important; }
  .proof-stat-cell { border-right: none; border-bottom: 1px solid var(--bd); }
  .trust-grid { grid-template-columns: 1fr !important; }
  .diff-grid { grid-template-columns: 1fr !important; }
  .diff-divider { display: none; }
  .diff-col.bad { border-right: none; border-bottom: 1px solid var(--bd); }
  .pricing-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .for-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .cap-grid { grid-template-columns: 1fr !important; }
  .steps-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ndf-grid { grid-template-columns: 1fr 1fr !important; }
}

/* ── 768px — Standard tablet/phone boundary ─────────────────────────── */
@media (max-width: 768px) {
  .nd-container { padding-left: 18px; padding-right: 18px; }
  .container { padding: 0 18px !important; }
  /* Section spacing tighten */
  section, .section { padding-top: clamp(40px, 8vw, 72px); padding-bottom: clamp(40px, 8vw, 72px); }
}

/* ── 520px — Large phone / small phone landscape ────────────────────── */
@media (max-width: 520px) {
  .nd-container { padding-left: 16px; padding-right: 16px; }
  .pricing-grid { grid-template-columns: 1fr !important; }
  .for-grid { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: 1fr !important; }
  .steps-grid { grid-template-columns: 1fr !important; }
  .proof-section-grid { grid-template-columns: 1fr !important; }
  .ndf-grid { grid-template-columns: 1fr !important; }
  /* Reduce card padding on small screens */
  .price-card { padding: 20px 18px; }
  .proof-card { padding: 20px 16px; }
}

/* ── 430px — iPhone 14/15 Pro Max ───────────────────────────────────── */
@media (max-width: 430px) {
  .nd-container { padding-left: 14px; padding-right: 14px; }
  /* Hero copy */
  .hero-h1 { font-size: clamp(26px, 8vw, 36px) !important; }
  .hero-sub { font-size: 13px !important; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions a { text-align: center; }
  /* Nav CTA — hide ghost button */
  .nd-btn:not(.nd-gold) { display: none !important; }
  /* Section headings */
  .section-h2 { font-size: clamp(22px, 7vw, 32px) !important; }
  /* Reduce section padding */
  .preview-grid { grid-template-columns: 1fr !important; }
  /* Demo section full width */
  .demo-wrap { padding: 0 !important; }
  /* Hide feature discovery on smallest screens */
  #nd-fx { display: none !important; }
}

/* ── 375px — iPhone SE / minimum supported width ───────────────────── */
@media (max-width: 390px) {
  .nd-container { padding-left: 12px; padding-right: 12px; }
  .container { padding: 0 12px !important; }
  .hero-h1 { font-size: clamp(22px, 7.5vw, 28px) !important; }
  .section-h2 { font-size: clamp(20px, 7vw, 26px) !important; }
  .btn-primary, .btn-ghost { padding: 12px 18px !important; font-size: 13px !important; }
  .hero-social-proof { flex-direction: column; gap: 8px; }
  .proof-sep { display: none; }
  /* Nav tighten */
  .nd-logo { font-size: 20px !important; }
  .nd-logo-badge { display: none; }
  /* Pricing: ensure single col */
  .pricing-grid { grid-template-columns: 1fr !important; }
  /* Footer: single col */
  .ndf-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .ndf-bottom-inner { flex-direction: column; text-align: center; gap: 10px; }
  .ndf-bottom-links { justify-content: center; }
}

/* ── iOS Safari: prevent auto-zoom on input focus (requires font-size >= 16px) */
@media(max-width:430px){
  input[type="text"],input[type="email"],input[type="password"],
  input[type="search"],input[type="tel"],input[type="number"],
  textarea,select{font-size:16px!important}
}

/* ── Touch targets: minimum 44×44px tap area on mobile ─────────────── */
@media(max-width:768px){
  button,a.btn,a.btn-primary,a.btn-ghost,.nd-btn,
  .nd-link,.help-cat,.faq-cat{min-height:44px;min-width:44px}
  input,textarea,select{min-height:44px}
}

/* ── Prevent horizontal scroll on any page ─────────────────────────── */
html,body{overflow-x:hidden;max-width:100vw}
