/* Wardriver Security — site styles. Dark, tactical, premium. Pure CSS, no dependencies. */
:root{
  --bg:#07090e; --bg2:#0b0f18; --panel:#0e1320; --panel2:#121829;
  --line:#1b2233; --fg:#e9edf5; --muted:#8b95a7;
  /* purple-team palette: red = offense/brand/CTA, blue = defense/trust/live */
  --accent:#c1121f; --accent2:#ff2d3f; --signal:#3b9dff; --signal-dim:#1e5fa8;
  --purple:#8b5cf6; --purple2:#a855f7;   /* the fusion: where red (offense) + blue (defense) meet */
  --radius:16px; --maxw:1140px;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
  --sans:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.12;margin:0 0 .4em}
.accent{color:var(--accent2)}
.t-red{color:var(--accent2)}.t-blue{color:var(--signal)}.t-purple{color:var(--purple2)}
img,canvas{max-width:100%;display:block}

/* scroll progress */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--accent),var(--purple),var(--signal));box-shadow:0 0 12px rgba(139,92,246,.6)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem clamp(1rem,4vw,2.4rem);background:rgba(7,9,14,.72);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(7,9,14,.9)}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:.3px}
.brand-mark{flex:none;filter:drop-shadow(0 0 7px rgba(139,92,246,.55))}
.brand-text{font-size:1.34rem}
.brand-sub{display:block;font:600 .6rem/1 var(--mono);letter-spacing:.34em;color:var(--accent2);margin-top:2px}
.site-nav{display:flex;align-items:center;gap:1.4rem;font-size:.92rem}
.site-nav a{color:var(--muted);transition:color .15s;position:relative}
.site-nav a:not(.nav-cta):hover{color:var(--fg)}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--accent2);transition:width .2s}
.site-nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{color:var(--fg)!important;border:1px solid var(--accent);padding:.45rem .95rem;border-radius:10px;font-weight:600;transition:background .15s,box-shadow .2s}
.nav-cta:hover{background:var(--accent);box-shadow:0 0 20px rgba(193,18,31,.5)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--fg);transition:.25s}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(3rem,8vw,6.5rem) clamp(1rem,4vw,2.4rem) clamp(2.5rem,5vw,4rem)}
.hero-grid{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.5}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(820px 420px at 80% 2%,rgba(193,18,31,.22),transparent 60%),radial-gradient(560px 340px at 50% -8%,rgba(139,92,246,.14),transparent 60%),radial-gradient(700px 520px at 4% 0%,rgba(59,157,255,.10),transparent 55%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:2.5rem;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font:600 .8rem/1.4 var(--mono);letter-spacing:.06em;color:var(--purple2);text-transform:uppercase;margin:0 0 1.1rem}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--purple2);box-shadow:0 0 0 0 rgba(168,85,247,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(168,85,247,.55)}70%{box-shadow:0 0 0 10px rgba(168,85,247,0)}100%{box-shadow:0 0 0 0 rgba(168,85,247,0)}}
.hero h1{font-size:clamp(2.4rem,6vw,4.3rem);font-weight:850;letter-spacing:-.025em}
.type-host{display:inline-flex;align-items:baseline;min-height:1.1em}
.caret{display:inline-block;width:3px;height:1em;background:var(--accent2);margin-left:4px;transform:translateY(3px);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.slogan{font:700 clamp(1.05rem,2vw,1.35rem)/1.3 var(--sans);color:var(--fg);margin:1rem 0 .4rem}
.lede{max-width:54ch;color:#b9c2d2;font-size:clamp(1rem,1.5vw,1.14rem);margin:.7rem 0 1.7rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem}
.btn{display:inline-block;padding:.82rem 1.5rem;border-radius:12px;font-weight:700;font-size:.98rem;cursor:pointer;border:1px solid transparent;transition:transform .12s,background .15s,border-color .15s,box-shadow .2s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 24px -8px rgba(193,18,31,.7)}
.btn-primary:hover{background:var(--accent2);box-shadow:0 8px 30px -6px rgba(255,45,63,.75)}
.btn-ghost{border-color:var(--line);color:var(--fg)}
.btn-ghost:hover{border-color:var(--signal);color:var(--signal)}
.btn-lg{padding:1rem 2rem;font-size:1.05rem}

/* hero radar */
.hero-visual{display:flex;flex-direction:column;align-items:center;gap:.7rem}
.radar-frame{position:relative;width:340px;max-width:80vw;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(59,157,255,.06),transparent 70%);box-shadow:0 0 60px -10px rgba(59,157,255,.25),inset 0 0 40px rgba(0,0,0,.6)}
.radar-frame canvas{position:absolute;inset:0;width:100%;height:100%}
.radar-readout{position:absolute;left:50%;bottom:14%;transform:translateX(-50%);font:600 .72rem/1 var(--mono);
  color:var(--signal);background:rgba(7,9,14,.7);border:1px solid var(--signal-dim);border-radius:20px;padding:.35rem .7rem;letter-spacing:.05em;white-space:nowrap}
.radar-cap{font:.78rem/1 var(--mono);color:var(--muted);letter-spacing:.05em;margin:.2rem 0 0}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line);background:var(--bg2);padding:.85rem 0}
.marquee-track{display:inline-flex;gap:0;white-space:nowrap;animation:scroll 32s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font:600 .82rem/1 var(--mono);color:var(--muted);letter-spacing:.04em;padding:0 2.2rem;border-right:1px solid var(--line)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5.5rem) clamp(1rem,4vw,2.4rem)}
.section-alt{max-width:none;background:var(--bg2);border-block:1px solid var(--line)}
.section-alt>*{max-width:var(--maxw);margin-inline:auto}
.section-head{margin-bottom:2.4rem}
.kicker{font:600 .78rem/1 var(--mono);letter-spacing:.1em;color:var(--purple2);margin:0 0 .7rem}
.section h2{font-size:clamp(1.7rem,3.6vw,2.5rem);font-weight:800;letter-spacing:-.015em}
.sub{color:var(--muted);max-width:62ch;font-size:1.05rem}

/* ---------- live terminal ---------- */
.demo .terminal{max-width:820px;margin:0 auto;background:#05070b;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 30px 80px -30px rgba(0,0,0,.9),0 0 0 1px rgba(59,157,255,.04)}
.term-bar{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;background:#0b0f18;border-bottom:1px solid var(--line)}
.term-bar .dot{width:11px;height:11px;border-radius:50%}
.term-bar .dot.r{background:#ff5f56}.term-bar .dot.y{background:#ffbd2e}.term-bar .dot.g{background:#27c93f}
.term-title{margin-left:.6rem;font:.78rem/1 var(--mono);color:var(--muted)}
.term-body{margin:0;padding:1.2rem 1.3rem;min-height:280px;font:.86rem/1.7 var(--mono);color:#cdd9e9;white-space:pre-wrap;word-break:break-word}
.term-body .c{color:var(--signal)}.term-body .r{color:var(--accent2)}.term-body .y{color:#ffd166}.term-body .m{color:var(--muted)}.term-body .ok{color:var(--signal);font-weight:700}

/* ---------- service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.1rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;transition:border-color .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(300px 120px at var(--mx,50%) -10%,rgba(193,18,31,.16),transparent 60%);opacity:0;transition:opacity .25s}
.card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(193,18,31,.5)}
.card:hover::before{opacity:1}
.card-ico{width:44px;height:44px;display:grid;place-items:center;font-size:1.4rem;color:var(--accent2);background:rgba(193,18,31,.1);border:1px solid rgba(193,18,31,.3);border-radius:11px;margin-bottom:1rem}
.card h3{font-size:1.16rem}
.card p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- method ---------- */
.method{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.1rem}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;position:relative;overflow:hidden}
.step::after{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--purple2),transparent)}
.step .num{font:850 .9rem/1 var(--mono);color:var(--purple2);letter-spacing:.1em}
.step h3{margin:.5rem 0 .35rem;font-size:1.22rem}
.step p{color:var(--muted);margin:0;font-size:.94rem}
.approach-note{max-width:72ch;margin:2.2rem auto 0;color:#b9c2d2;font-size:1.06rem;border-left:3px solid var(--accent);padding-left:1.15rem}

/* ---------- story ---------- */
.story-narrative{max-width:70ch;margin:0 auto;font-size:1.12rem;color:#cdd5e2}
.story-narrative p{margin:0 0 1.15rem}
.story-narrative .lead-line{font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:750;color:var(--fg);line-height:1.3;margin-bottom:1.4rem}
.story-narrative .pull{border-left:3px solid var(--accent);padding-left:1.15rem;color:#fff;font-weight:600;font-size:1.18rem}
.story-cta{text-align:center;margin-top:2.2rem}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1.1rem}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.4rem;text-align:center}
.stat strong{display:block;font-size:clamp(2.2rem,5vw,3rem);font-weight:850;color:var(--accent2);line-height:1;font-variant-numeric:tabular-nums}
.stat span{display:block;margin-top:.6rem;color:var(--muted);font-size:.92rem}
.edge-cards{margin-top:1.1rem}
/* defensive pillar: blue-coded cards */
.protect-cards .card-ico{color:var(--signal);background:rgba(59,157,255,.1);border-color:rgba(59,157,255,.32)}
.protect-cards .card::before{background:radial-gradient(300px 120px at var(--mx,50%) -10%,rgba(59,157,255,.16),transparent 60%)}
.protect-cards .card:hover{border-color:var(--signal);box-shadow:0 18px 40px -22px rgba(59,157,255,.5)}
.protect-note{border-left-color:var(--signal)}
/* services pillar: purple-coded (we do it all = the fusion) */
.services-cards .card-ico{color:var(--purple2);background:rgba(168,85,247,.1);border-color:rgba(168,85,247,.32)}
.services-cards .card::before{background:radial-gradient(300px 120px at var(--mx,50%) -10%,rgba(168,85,247,.16),transparent 60%)}
.services-cards .card:hover{border-color:var(--purple2);box-shadow:0 18px 40px -22px rgba(168,85,247,.5)}
.about-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.6rem}
.about-tags span{font:.78rem/1 var(--mono);color:var(--muted);border:1px solid var(--line);border-radius:20px;padding:.5rem .85rem}

/* ---------- cta banner ---------- */
.cta-banner{max-width:var(--maxw);margin:0 auto;text-align:center;padding:clamp(3rem,7vw,5rem) clamp(1rem,4vw,2.4rem)}
.cta-banner h2{font-size:clamp(1.7rem,4vw,2.7rem);font-weight:850;letter-spacing:-.02em;max-width:18ch;margin-inline:auto}
.cta-banner p{color:var(--muted);font-size:1.1rem;margin:.6rem auto 1.6rem;max-width:50ch}

/* ---------- contact ---------- */
.contact-form{max-width:640px;margin:0 auto;display:grid;gap:1rem}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-form label{display:grid;gap:.4rem;font-size:.9rem;color:var(--muted)}
.contact-form input,.contact-form textarea{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:.75rem .85rem;color:var(--fg);font:inherit;font-size:.98rem;transition:border-color .15s,box-shadow .15s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px rgba(59,157,255,.12)}
.form-alt{text-align:center;color:var(--muted);font-size:.92rem;margin:.3rem 0 0}
.form-alt a{color:var(--signal)}
.form-sent{text-align:center;color:var(--purple2);font-size:.92rem;margin:.6rem 0 0}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:2.4rem clamp(1rem,4vw,2.4rem);max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:1rem 2rem;align-items:center;justify-content:space-between}
.foot-brand{display:flex;align-items:center;gap:.55rem;font-weight:700}
.foot-nav{display:flex;flex-wrap:wrap;gap:1.2rem;color:var(--muted);font-size:.92rem}
.foot-nav a:hover{color:var(--fg)}
.foot-fine{width:100%;color:var(--muted);font-size:.82rem;font-family:var(--mono);margin:.4rem 0 0;border-top:1px solid var(--line);padding-top:1rem}

/* ---------- how it works ---------- */
.steps3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.1rem}
.s3{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.s3n{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(193,18,31,.12);border:1px solid var(--accent);color:var(--accent2);font:800 1.05rem/1 var(--mono);margin-bottom:.9rem}
.s3 h3{font-size:1.15rem;margin-bottom:.3rem}.s3 p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- why us / vs ---------- */
.vs{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.vs-col{border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem}
.vs-them{background:var(--panel);opacity:.9}
.vs-us{background:linear-gradient(180deg,rgba(193,18,31,.09),var(--panel));border-color:var(--accent)}
.vs-col h3{font-size:1.1rem;margin-bottom:1rem;color:var(--muted)}
.vs-badge{background:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:8px;font-size:.98rem;font-weight:800}
.vs-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}
.vs-col li{position:relative;padding-left:1.7rem;color:#c7cedb;font-size:.97rem}
.vs-them li::before{content:"✕";position:absolute;left:0;color:#717a8a;font-weight:700}
.vs-us li::before{content:"✓";position:absolute;left:0;color:var(--signal);font-weight:800}

/* ---------- trust ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}
.trust-item{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.3rem;text-align:center}
.trust-item strong{display:block;color:var(--fg);font-size:1.05rem}
.trust-item span{display:block;color:var(--muted);font:.78rem/1.3 var(--mono);margin-top:.35rem}
.frameworks-label{text-align:center;color:var(--muted);margin:2.2rem 0 1rem;font-size:.95rem}
.frameworks{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}
.frameworks span{font:600 .82rem/1 var(--mono);color:#c7cedb;border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:.6rem .9rem}

/* ---------- testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.1rem}
.quote{margin:0;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;padding:1.6rem}
.quote p{margin:0 0 .8rem;font-size:1.06rem;color:var(--fg)}
.quote cite{color:var(--muted);font-style:normal;font:.85rem/1 var(--mono)}
.quote.ph p{color:var(--muted)}
.proof-note{text-align:center;color:var(--muted);margin-top:1.6rem}.proof-note a{color:var(--signal)}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:0 auto;display:grid;gap:.7rem}
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:0 1.2rem;transition:border-color .2s}
.faq details[open]{border-color:var(--accent)}
.faq summary{cursor:pointer;padding:1.1rem 0;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent2);font-size:1.4rem;font-weight:400;line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:0 0 1.1rem;color:var(--muted)}

/* ---------- self-check (lead magnet) ---------- */
.sc{display:grid;grid-template-columns:1.2fr .8fr;gap:1.4rem;align-items:start}
.sc-quiz{display:grid;gap:.7rem}
.sc-q{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.sc-q>span{font-size:.97rem;color:#dfe4ee}
.sc-toggle{display:flex;gap:.4rem;flex:none}
.sc-toggle button{background:var(--bg);border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:.45rem .9rem;font:inherit;font-weight:700;font-size:.86rem;cursor:pointer;transition:.15s}
.sc-toggle button:hover{border-color:var(--muted);color:var(--fg)}
.sc-toggle button[data-v="1"].on{background:var(--signal-dim);border-color:var(--signal);color:#04110c}
.sc-toggle button[data-v="0"].on{background:var(--accent);border-color:var(--accent);color:#fff}
.sc-result{background:var(--panel2);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;position:sticky;top:84px}
.sc-meter{height:10px;border-radius:6px;background:var(--bg);overflow:hidden;border:1px solid var(--line)}
.sc-meter-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),#ffd166,var(--signal));transition:width .45s cubic-bezier(.2,.7,.2,1)}
.sc-score{display:flex;align-items:baseline;gap:.4rem;margin:.9rem 0 .3rem}
.sc-score strong{font-size:2.2rem;font-weight:850;color:var(--fg);line-height:1;font-variant-numeric:tabular-nums}
.sc-score span{color:var(--muted);font-size:.9rem}
.sc-verdict{color:var(--muted);font-size:.97rem;margin:.3rem 0 1rem;min-height:2.6em}
.sc-verdict.good b{color:var(--signal)}.sc-verdict.mid b{color:#ffd166}.sc-verdict.bad b{color:var(--accent2)}
.sc-gaps:empty{display:none}
.sc-gaps{margin-bottom:1rem}
.sc-gaps-h{font:700 .76rem/1 var(--mono);color:var(--accent2);letter-spacing:.06em;text-transform:uppercase;margin:0 0 .5rem}
.sc-gaps ul{margin:0;padding-left:1.1rem;color:#cdd5e2;font-size:.92rem;display:grid;gap:.35rem}
.sc-form{display:grid;gap:.6rem}
.sc-form input{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:.7rem .85rem;color:var(--fg);font:inherit}
.sc-form input:focus{outline:none;border-color:var(--signal)}
.sc-fine{color:var(--muted);font-size:.82rem;margin:.7rem 0 0}.sc-fine a{color:var(--signal)}
@media(max-width:820px){.sc{grid-template-columns:1fr}.sc-result{position:static}}

/* ---------- myths ---------- */
.myths-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.1rem}
.myth{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;position:relative;overflow:hidden;transition:transform .15s,border-color .2s}
.myth::before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(var(--accent),var(--purple),var(--signal))}
.myth:hover{transform:translateY(-3px);border-color:var(--signal-dim)}
.myth-stat{font:850 2.3rem/1 var(--sans);color:var(--signal);margin-bottom:.65rem;letter-spacing:-.02em}
.myth-stat.sym{font-size:2.7rem}
.myth-myth{font-weight:700;color:#cdd5e2;margin:0 0 .6rem}
.myth-myth span{display:inline-block;font:700 .66rem/1 var(--mono);letter-spacing:.1em;color:var(--accent2);border:1px solid var(--accent);border-radius:6px;padding:.22rem .42rem;margin-right:.55rem;vertical-align:middle;text-transform:uppercase}
.myth-fact{color:var(--muted);margin:0;font-size:.95rem}
.myth-fact b{color:var(--fg);font-weight:600}
.myths-foot{text-align:center;color:var(--muted);font:.8rem/1.5 var(--mono);margin-top:1.7rem;opacity:.8}

img.brand-mark{width:48px;height:48px;object-fit:contain}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee-track,.pulse,.caret{animation:none}}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-copy{order:2}.hero-visual{order:1}
  .eyebrow,.hero-cta{justify-content:center}
  .lede{margin-inline:auto}
  .nav-toggle{display:flex}
  .site-nav{position:fixed;inset:0 0 auto auto;top:0;height:100vh;width:min(78vw,320px);flex-direction:column;align-items:flex-start;justify-content:center;gap:1.4rem;padding:2rem;background:var(--panel);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .3s;font-size:1.1rem}
  .site-nav.open{transform:none}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:640px){.vs{grid-template-columns:1fr}}
@media(max-width:560px){.contact-form .row{grid-template-columns:1fr}}

/* ---------- pricing page ---------- */
.pricing-hero{position:relative;padding:clamp(3rem,7vw,5.5rem) clamp(1rem,4vw,2.4rem) clamp(2rem,4vw,3rem);background:radial-gradient(800px 380px at 75% -10%,rgba(193,18,31,.2),transparent 60%),var(--bg)}
.ph-inner{max-width:var(--maxw);margin:0 auto}
.pricing-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:850;letter-spacing:-.02em}
.pricing-hero .lede{max-width:60ch;color:#b9c2d2;font-size:clamp(1rem,1.5vw,1.15rem);margin:1rem 0 1.6rem}
.seg{display:inline-flex;gap:.4rem;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.35rem}
.seg a{padding:.55rem 1.1rem;border-radius:9px;font-weight:700;font-size:.92rem;color:var(--muted)}
.seg a:hover{background:var(--bg);color:var(--fg)}
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(238px,1fr));gap:1.1rem}
.price-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.5rem;display:flex;flex-direction:column;position:relative}
.price-card.featured{border-color:var(--accent);box-shadow:0 18px 50px -28px rgba(193,18,31,.7)}
.tag-pop{position:absolute;top:-11px;left:1.5rem;background:var(--accent);color:#fff;font:700 .68rem/1 var(--mono);letter-spacing:.06em;text-transform:uppercase;padding:.35rem .6rem;border-radius:6px}
.price-card h3{font-size:1.2rem;margin-bottom:.5rem}
.price{display:flex;align-items:baseline;gap:.4rem;margin:0 0 .7rem}
.price .amt{font-size:1.7rem;font-weight:850;color:var(--fg)}
.price .per{color:var(--muted);font-size:.85rem;font-family:var(--mono)}
.price-desc{color:#c7cedb;font-size:.94rem;margin:0 0 1rem}
.price-feat{list-style:none;margin:0 0 1.3rem;padding:0;display:grid;gap:.5rem;flex:1}
.price-feat li{position:relative;padding-left:1.5rem;color:var(--muted);font-size:.92rem}
.price-feat li::before{content:"✓";position:absolute;left:0;color:var(--signal);font-weight:800}
.price-card .btn{text-align:center}
.addons{color:var(--muted);font-size:.92rem;margin-top:1.4rem;text-align:center}.addons strong{color:#c7cedb}
.proj-head{font-size:1.25rem;margin:2.6rem 0 1.1rem;text-align:center}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem}
.proj{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:1rem 1.2rem}
.proj strong{font-weight:600;font-size:.95rem}
.proj span{color:var(--signal);font:700 .9rem/1 var(--mono);white-space:nowrap}
.section-cta{text-align:center;margin-top:2rem}
.section-cta a{color:var(--signal);font-weight:700}

/* ---------- sub-page (Labs / Blog) ---------- */
.page{max-width:760px;margin:0 auto;padding:clamp(3rem,7vw,5rem) clamp(1rem,4vw,2.2rem)}
.page h1{font-size:clamp(2rem,4vw,2.8rem)}
.page p{color:#cdd5e2}
.page .back{font:.85rem/1 var(--mono);color:var(--signal)}
.post{border-top:1px solid var(--line);padding:1.4rem 0}
.post h3{margin:0 0 .3rem}
.post time{font:.78rem/1 var(--mono);color:var(--muted)}
.post-link{display:block;text-decoration:none;transition:border-color .2s,transform .12s}
.post-link:hover{border-top-color:var(--accent);transform:translateX(3px)}
.post-link .read-more{display:inline-block;margin-top:.5rem;color:var(--signal);font:700 .85rem/1 var(--mono)}
/* blog article */
.article{max-width:720px}
.article-meta{font:.78rem/1 var(--mono);color:var(--signal);letter-spacing:.05em;margin:.5rem 0 .6rem}
.article-lead{font-size:1.2rem;color:var(--fg);font-weight:500;line-height:1.5;margin:0 0 1.6rem}
.article h2{font-size:1.4rem;margin:2.1rem 0 .6rem}
.article p,.article li{color:#cdd5e2;font-size:1.04rem;line-height:1.7}
.article ul{padding-left:1.2rem;display:grid;gap:.5rem}
.article hr{border:0;border-top:1px solid var(--line);margin:2rem 0}
.article-source{color:var(--muted);font:.85rem/1.5 var(--mono)}
.article-quote{border-left:3px solid var(--accent);margin:1.7rem 0;padding:.5rem 0 .5rem 1.2rem;font-size:1.2rem;font-weight:600;color:#fff}
.article-cta{margin-top:2.4rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;text-align:center}
.article-cta h3{font-size:1.3rem;margin-bottom:.4rem}
.article-cta p{color:var(--muted);margin:0 0 1.2rem;max-width:48ch;margin-inline:auto}
