/* ============================================================
   VISION GENESIS AI — "Superpowers" — design system
   Locked: navy #071426 / gold #ECB838 family + the VG monogram.
   Type: Fraunces (display, personality) · Inter (workhorse body)
         · JetBrains Mono (meta / eyebrows / statuses).
   Gold is a scalpel. Navy breathes in depths. Motion carries meaning.
   ============================================================ */
:root{
  --navy:        #071426;
  --navy-deep:   #030E1A;
  --navy-raise:  #0B1D36;
  --navy-card:   #0A1930;
  --navy-lift:   #0B1E36;
  --gold:        #ECB838;
  --gold-hi:     #FCD04A;
  --gold-deep:   #C88C1E;
  --gold-dim:    rgba(236,184,56,.55);
  --gold-glow:   rgba(252,208,74,.26);
  --ink:         #EAF1FB;
  --ink-soft:    #A8B8CF;
  --ink-faint:   #6E82A0;
  --line:        rgba(236,184,56,.14);
  --line-soft:   rgba(168,184,207,.10);
  --radius:      16px;
  --max:         1180px;
  --nav-h:       70px;
  --ease:        cubic-bezier(.22,1,.36,1);
  --disp:        'Fraunces', Georgia, 'Times New Roman', serif;
  --body:        'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --mono:        'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:calc(var(--nav-h) + 14px); -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--navy);
  color:var(--ink);
  line-height:1.65;
  font-size:1rem;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{ background:var(--gold); color:var(--navy-deep); }
img,svg,canvas{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }

/* ---- layout ---- */
.wrap{ width:100%; max-width:var(--max); margin-inline:auto; padding-inline:clamp(20px,5vw,52px); }
section{ position:relative; }
.section-pad{ padding-block:clamp(82px,12vw,150px); }
.center{ text-align:center; }

/* ---- type ---- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--mono);
  font-size:.7rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{ content:""; width:24px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.eyebrow.nodash::before{ display:none; }

h1,h2,h3{ font-family:var(--disp); line-height:1.04; letter-spacing:-.01em; font-weight:600; }
.h-display{ font-size:clamp(2.7rem,8vw,5.6rem); font-weight:600; letter-spacing:-.02em; }
.h-section{ font-size:clamp(2rem,5vw,3.4rem); margin-top:.4em; }
.h-sub{ font-family:var(--disp); font-size:clamp(1.4rem,3vw,2rem); font-weight:500; }
.lede{ font-family:var(--body); font-size:clamp(1.06rem,2.2vw,1.3rem); color:var(--ink-soft); max-width:40em; margin-top:1.1em; line-height:1.6; }
.gold{ color:var(--gold-hi); }
.glow-text{ color:var(--gold-hi); text-shadow:0 0 22px var(--gold-glow), 0 0 70px rgba(252,208,74,.16); }
.italic{ font-style:italic; }
em{ font-style:italic; color:var(--gold-hi); }

/* ============================================================ NAV */
.nav{
  position:fixed; inset:0 0 auto 0; height:var(--nav-h); z-index:100;
  display:flex; align-items:center;
  background:rgba(7,20,38,.66);
  -webkit-backdrop-filter:blur(15px); backdrop-filter:blur(15px);
  border-bottom:1px solid transparent; transition:border-color .4s, background .4s;
}
.nav.scrolled{ border-bottom-color:var(--line); background:rgba(5,13,27,.9); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; width:100%; }
.brand{ display:flex; align-items:center; gap:.62rem; font-weight:800; font-size:1.04rem; letter-spacing:-.01em; }
.brand .mono{ height:30px; width:auto; flex:none; filter:drop-shadow(0 0 10px var(--gold-glow)); }
.brand b{ font-weight:800; color:var(--ink); }
.brand b em{ font-style:normal; color:var(--gold-hi); }
.nav-links{ display:none; align-items:center; gap:2rem; list-style:none; }
.nav-links a{ font-size:.9rem; font-weight:600; color:var(--ink-soft); transition:color .25s; }
.nav-links a:hover{ color:var(--gold-hi); }
.nav-cta{
  display:none; font-size:.85rem; font-weight:700; color:var(--navy-deep);
  background:linear-gradient(135deg,var(--gold-hi),var(--gold));
  padding:.6em 1.25em; border-radius:999px; box-shadow:0 0 18px rgba(252,208,74,.22);
  transition:transform .25s var(--ease), box-shadow .25s;
}
.nav-cta:hover{ transform:translateY(-1px); box-shadow:0 0 28px rgba(252,208,74,.42); }
.burger{ display:flex; flex-direction:column; justify-content:center; gap:6px; width:44px; height:44px; padding:10px; }
.burger span{ display:block; height:2px; border-radius:2px; background:var(--gold-hi); transition:transform .35s var(--ease), opacity .25s; }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }
.mobile-menu{
  position:fixed; inset:0; z-index:99; display:flex; flex-direction:column; justify-content:center;
  padding:clamp(24px,8vw,56px); background:rgba(3,13,26,.97);
  -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s;
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu ul{ list-style:none; display:grid; gap:.3rem; }
.mobile-menu a{ font-family:var(--disp); font-size:clamp(1.7rem,7vw,2.3rem); font-weight:500; color:var(--ink); padding:.4em 0; border-bottom:1px solid var(--line-soft); }
.mobile-menu a:hover{ color:var(--gold-hi); }
.mobile-menu .menu-mail{ font-family:var(--mono); margin-top:1.6rem; font-size:.9rem; color:var(--gold); }
@media (min-width:880px){ .nav-links{ display:flex; } .nav-cta{ display:inline-block; } .burger,.mobile-menu{ display:none; } }

/* ============================================================ BUTTONS */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-weight:700; font-size:1rem; padding:.95em 1.85em; border-radius:999px;
  transition:transform .3s var(--ease), box-shadow .3s, background .3s, border-color .3s;
}
.btn-gold{ color:var(--navy-deep); background:linear-gradient(135deg,var(--gold-hi),var(--gold)); box-shadow:0 0 24px rgba(252,208,74,.3), 0 8px 28px rgba(0,0,0,.35); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 0 44px rgba(252,208,74,.5), 0 12px 32px rgba(0,0,0,.4); }
.btn-ghost{ color:var(--gold-hi); border:1px solid rgba(252,208,74,.38); background:rgba(252,208,74,.04); }
.btn-ghost:hover{ transform:translateY(-2px); border-color:var(--gold-hi); background:rgba(252,208,74,.1); box-shadow:0 0 24px rgba(252,208,74,.18); }
.btn-sm{ padding:.7em 1.3em; font-size:.9rem; }

/* ============================================================ REVEAL */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.1s; }
.reveal[data-delay="2"]{ transition-delay:.2s; }
.reveal[data-delay="3"]{ transition-delay:.3s; }

/* ============================================================ HERO */
.hero{
  min-height:100svh; display:flex; align-items:center; overflow:hidden;
  background:
    radial-gradient(1200px 720px at 76% -8%, rgba(252,208,74,.08), transparent 60%),
    radial-gradient(900px 600px at 8% 112%, rgba(236,184,56,.05), transparent 60%),
    var(--navy-deep);
}
#particles{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
#flux{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:1; opacity:0; }
.hero-core{
  position:absolute; top:50%; left:50%; width:min(120vw,920px); aspect-ratio:1;
  transform:translate(-50%,-50%); border-radius:50%;
  background:radial-gradient(circle, rgba(252,208,74,.10) 0%, rgba(252,208,74,.04) 32%, transparent 62%);
  animation:corePulse 5.5s ease-in-out infinite; pointer-events:none;
}
@keyframes corePulse{ 0%,100%{ opacity:.7; transform:translate(-50%,-50%) scale(1); } 50%{ opacity:1; transform:translate(-50%,-50%) scale(1.06); } }
.hero-grid{
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(168,184,207,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(168,184,207,.045) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 45%, black 18%, transparent 74%);
  mask-image:radial-gradient(ellipse 80% 70% at 50% 45%, black 18%, transparent 74%);
  pointer-events:none;
}
.hero-inner{ position:relative; z-index:2; padding-block:calc(var(--nav-h) + 44px) 92px; text-align:left; }
.hero .eyebrow{ animation:riseIn .9s var(--ease) both; }
.hero h1{ margin-top:.42em; max-width:13ch; animation:riseIn .9s var(--ease) .12s both; }
.hero .lede{ animation:riseIn .9s var(--ease) .26s both; }
.hero-body{ margin-top:1.5em; max-width:36em; color:var(--ink-soft); font-size:1.06rem; animation:riseIn .9s var(--ease) .34s both; }
.hero-body b{ color:var(--ink); font-weight:600; }
.hero-body .nots{ color:var(--ink); font-weight:600; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.3rem; animation:riseIn .9s var(--ease) .42s both; }
@keyframes riseIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:translateY(0); } }
.scroll-cue{ position:absolute; left:50%; bottom:24px; transform:translateX(-50%); z-index:2; width:25px; height:40px; border:2px solid rgba(236,184,56,.42); border-radius:13px; }
.scroll-cue::after{ content:""; position:absolute; top:7px; left:50%; width:4px; height:8px; margin-left:-2px; border-radius:3px; background:var(--gold-hi); animation:cueDrop 1.8s ease-in-out infinite; }
@keyframes cueDrop{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(13px); opacity:0; } 100%{ transform:translateY(0); opacity:0; } }

/* ============================================================ SECTION HEADERS / SHARED */
.sec-head{ max-width:46rem; }
.band-top{ border-top:1px solid var(--line-soft); }
.tint-deep{ background:radial-gradient(900px 600px at 0% 16%, rgba(252,208,74,.04), transparent 60%), var(--navy-deep); }
.tint-raise{ background:radial-gradient(800px 520px at 92% 0%, rgba(252,208,74,.05), transparent 60%), var(--navy); }
.tint-lift{ background:var(--navy-lift); }

/* ============================================================ NORRIS */
.norris-grid{ display:grid; gap:clamp(40px,6vw,72px); margin-top:clamp(40px,6vw,60px); align-items:center; }
@media (min-width:960px){ .norris-grid{ grid-template-columns:1.05fr .95fr; } }
.norris-copy p{ color:var(--ink-soft); margin-top:1.15em; max-width:36em; font-size:1.04rem; }
.norris-copy p strong{ color:var(--ink); font-weight:600; }
.norris-copy p .gold{ font-weight:600; }
/* the architecture stack */
.stack{ margin-top:1.7em; display:grid; gap:10px; max-width:34em; }
.stack-row{ display:flex; gap:.8em; align-items:flex-start; padding:.85em 1em; border:1px solid var(--line-soft); border-radius:12px; background:linear-gradient(170deg, rgba(12,30,55,.5), rgba(8,20,38,.5)); }
.stack-row .k{ font-family:var(--mono); font-size:.66rem; font-weight:700; letter-spacing:.1em; color:var(--gold); padding-top:.25em; min-width:74px; }
.stack-row .v{ font-size:.92rem; color:var(--ink-soft); }
.stack-row .v b{ color:var(--ink); font-weight:600; }

/* chat mockup */
.chat-shell{ position:relative; border-radius:22px; border:1px solid var(--line); background:linear-gradient(165deg,var(--navy-raise),var(--navy-card) 70%); box-shadow:0 30px 80px rgba(0,0,0,.45), 0 0 60px rgba(252,208,74,.05); padding:22px; max-width:440px; margin-inline:auto; width:100%; }
.chat-shell::before{ content:""; position:absolute; inset:-1px; border-radius:23px; padding:1px; background:linear-gradient(140deg, rgba(252,208,74,.42), transparent 30%, transparent 70%, rgba(252,208,74,.18)); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.chat-head{ display:flex; align-items:center; gap:.7rem; padding-bottom:15px; border-bottom:1px solid var(--line-soft); }
.chat-dot{ width:9px; height:9px; border-radius:50%; background:var(--gold-hi); box-shadow:0 0 10px var(--gold-hi); animation:dotPulse 2.4s ease-in-out infinite; }
@keyframes dotPulse{ 0%,100%{ opacity:1; } 50%{ opacity:.35; } }
.chat-head strong{ font-size:.9rem; }
.chat-head small{ margin-left:auto; font-family:var(--mono); color:var(--ink-faint); font-size:.66rem; letter-spacing:.08em; }
.chat-body{ display:grid; gap:11px; padding-top:16px; }
.msg{ max-width:88%; padding:.72em .95em; border-radius:15px; font-size:.9rem; line-height:1.5; }
.msg.user{ justify-self:end; background:rgba(168,184,207,.12); border:1px solid var(--line-soft); border-bottom-right-radius:5px; }
.msg.ai{ justify-self:start; background:rgba(236,184,56,.1); border:1px solid rgba(236,184,56,.22); border-bottom-left-radius:5px; }
.msg.ai b{ color:var(--gold-hi); }
.msg-meta{ font-family:var(--mono); font-size:.62rem; color:var(--ink-faint); letter-spacing:.05em; }
.msg-meta.right{ justify-self:end; }

/* differentiators — editorial list, not icon-circle grid */
.diff-list{ margin-top:clamp(46px,7vw,76px); display:grid; gap:0; border-top:1px solid var(--line-soft); }
/* mobile-first: clean vertical stack — number marker, then a FULL-WIDTH heading, then body.
   (the old default `auto 1fr` grid auto-flowed num/h3/p into 2 columns and squeezed the
   heading into a sliver, wrapping it one word per line.) */
.diff{ display:grid; grid-template-columns:1fr; gap:.5em 0; padding:clamp(26px,6vw,34px) 0; border-bottom:1px solid var(--line-soft); transition:background .3s; }
.diff:hover{ background:linear-gradient(90deg, rgba(252,208,74,.04), transparent 70%); }
.diff .num{ font-family:var(--mono); font-size:.74rem; font-weight:700; color:var(--gold); letter-spacing:.16em; }
.diff h3{ font-family:var(--disp); font-size:clamp(1.3rem,2.4vw,1.6rem); font-weight:500; line-height:1.16; }
.diff p{ color:var(--ink-soft); font-size:.97rem; max-width:44em; }
/* desktop: editorial 3-column — number · heading · body, on one baseline-aligned row */
@media (min-width:760px){ .diff{ grid-template-columns:auto 16em 1fr; gap:1.2em 1.4em; align-items:baseline; } .diff h3{ line-height:1.1; } .diff p{ margin-top:0; } }

/* ============================================================ LIVE — Ask Norris widget */
.live-wrap{ display:grid; gap:clamp(36px,5vw,60px); margin-top:clamp(36px,5vw,56px); align-items:center; }
@media (min-width:920px){ .live-wrap{ grid-template-columns:.92fr 1.08fr; } }
.asknorris{ position:relative; border-radius:22px; border:1px solid var(--line); background:linear-gradient(170deg,var(--navy-raise),var(--navy-card)); box-shadow:0 26px 70px rgba(0,0,0,.45),0 0 50px rgba(252,208,74,.05); overflow:hidden; }
.an-head{ display:flex; align-items:center; gap:.7rem; padding:16px 20px; border-bottom:1px solid var(--line-soft); background:rgba(252,208,74,.03); }
.an-head .mono-mark{ height:24px; width:auto; }
.an-head strong{ font-size:.95rem; }
.an-head small{ margin-left:auto; font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; color:var(--gold); display:flex; align-items:center; gap:.4em; }
.an-head small::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--gold-hi); box-shadow:0 0 8px var(--gold-hi); animation:dotPulse 1.8s ease-in-out infinite; }
.an-body{ height:300px; overflow-y:auto; padding:18px 20px; display:flex; flex-direction:column; gap:11px; scroll-behavior:smooth; }
.an-msg{ max-width:84%; padding:.7em .95em; border-radius:14px; font-size:.92rem; line-height:1.5; animation:popIn .35s var(--ease) both; }
@keyframes popIn{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
.an-msg.bot{ align-self:flex-start; background:rgba(236,184,56,.1); border:1px solid rgba(236,184,56,.2); border-bottom-left-radius:4px; }
.an-msg.me{ align-self:flex-end; background:rgba(168,184,207,.13); border:1px solid var(--line-soft); border-bottom-right-radius:4px; }
.an-msg.typing{ color:var(--ink-faint); font-style:italic; }
.an-msg.typing::after{ content:"…"; display:inline-block; width:1.1em; text-align:left; animation:anEllipsis 1.4s steps(4,end) infinite; }
@keyframes anEllipsis{ 0%{content:""} 25%{content:"."} 50%{content:".."} 75%{content:"…"} 100%{content:""} }
.an-msg a{ color:var(--gold-hi); text-decoration:underline; text-underline-offset:2px; font-weight:600; }
.an-msg b{ font-weight:700; }
.an-chips{ display:flex; flex-wrap:wrap; gap:8px; padding:0 20px 14px; }
.an-chip{ font-size:.78rem; font-weight:600; color:var(--gold-hi); border:1px solid rgba(252,208,74,.28); background:rgba(252,208,74,.05); padding:.45em .9em; border-radius:999px; transition:background .2s, border-color .2s; }
.an-chip:hover{ background:rgba(252,208,74,.12); border-color:var(--gold-hi); }
.an-input{ display:flex; gap:8px; padding:14px 16px; border-top:1px solid var(--line-soft); background:rgba(3,13,26,.5); }
.an-input input{ flex:1; background:rgba(168,184,207,.07); border:1px solid var(--line-soft); border-radius:999px; padding:.7em 1.1em; color:var(--ink); font-size:.92rem; outline:none; transition:border-color .2s; }
.an-input input:focus{ border-color:var(--gold-dim); }
.an-send{ width:42px; height:42px; flex:none; border-radius:50%; display:grid; place-items:center; color:var(--navy-deep); background:linear-gradient(135deg,var(--gold-hi),var(--gold)); }
.an-send svg{ width:18px; height:18px; }
.an-foot{ font-family:var(--mono); font-size:.6rem; color:var(--ink-faint); text-align:center; padding:0 16px 12px; letter-spacing:.04em; }

/* ============================================================ PROOF */
.proof-cards{ display:grid; gap:20px; margin-top:clamp(42px,6vw,62px); }
@media (min-width:820px){ .proof-cards{ grid-template-columns:repeat(3,1fr); } }
.pcard{ position:relative; display:flex; flex-direction:column; border-radius:20px; border:1px solid var(--line-soft); background:linear-gradient(175deg,var(--navy-raise),var(--navy-card) 75%); padding:28px 26px; overflow:hidden; transition:transform .4s var(--ease), border-color .4s, box-shadow .4s; }
.pcard::after{ content:""; position:absolute; top:0; left:10%; right:10%; height:1px; background:linear-gradient(90deg,transparent,rgba(252,208,74,.5),transparent); opacity:0; transition:opacity .4s; }
.pcard:hover{ transform:translateY(-6px); border-color:rgba(252,208,74,.28); box-shadow:0 26px 60px rgba(0,0,0,.45),0 0 44px rgba(252,208,74,.07); }
.pcard:hover::after{ opacity:1; }
.badge{ display:inline-flex; align-items:center; gap:.45em; align-self:flex-start; font-family:var(--mono); font-size:.62rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:.42em .9em; border-radius:999px; margin-bottom:16px; }
.badge-live{ color:var(--navy-deep); background:linear-gradient(135deg,var(--gold-hi),var(--gold)); }
.badge-live::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--navy-deep); animation:dotPulse 1.6s ease-in-out infinite; }
.badge-soft{ color:var(--gold); border:1px solid rgba(236,184,56,.34); background:rgba(236,184,56,.06); }
.pcard .vertical{ font-family:var(--mono); font-size:.66rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); }
.pcard h3{ font-family:var(--disp); font-size:1.45rem; font-weight:500; margin-top:.3em; }
.pcard p{ color:var(--ink-soft); font-size:.94rem; margin-top:.7em; flex:1; }
.pcard .plink{ display:inline-flex; align-items:center; gap:.5em; margin-top:1.5em; font-weight:700; font-size:.9rem; color:var(--gold-hi); transition:gap .3s var(--ease); }
.pcard .plink:hover{ gap:.85em; }
.pcard .plink svg{ width:15px; height:15px; }

/* ============================================================ CASE — VTQ */
.case{ overflow:hidden; }
.case-glow{ position:absolute; top:-200px; right:-200px; width:640px; height:640px; border-radius:50%; background:radial-gradient(circle, rgba(252,208,74,.08), transparent 65%); pointer-events:none; }
.case-story{ max-width:42em; margin-top:1.3em; }
.case-story p{ color:var(--ink-soft); font-size:clamp(1.02rem,2vw,1.14rem); margin-top:1.05em; }
.case-story p strong{ color:var(--ink); }
.stat-row{ display:grid; gap:16px; margin-top:clamp(38px,5vw,54px); }
@media (min-width:720px){ .stat-row{ grid-template-columns:1fr auto 1fr; align-items:stretch; } }
.stat{ border-radius:var(--radius); border:1px solid var(--line-soft); padding:28px 26px; text-align:center; }
.stat .label{ font-family:var(--mono); font-size:.66rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); }
.stat .num{ font-family:var(--disp); font-size:clamp(2rem,5vw,2.9rem); font-weight:600; letter-spacing:-.02em; margin-top:.25em; line-height:1.1; }
.stat .sub{ color:var(--ink-soft); font-size:.86rem; margin-top:.4em; }
.stat-before{ background:rgba(168,184,207,.04); }
.stat-before .num{ color:var(--ink-soft); }
.stat-after{ background:linear-gradient(165deg,rgba(252,208,74,.1),rgba(236,184,56,.04)); border-color:rgba(252,208,74,.34); box-shadow:0 0 40px rgba(252,208,74,.07) inset; }
.stat-after .num{ color:var(--gold-hi); text-shadow:0 0 24px var(--gold-glow); }
.stat-arrow{ display:grid; place-items:center; color:var(--gold); }
.stat-arrow svg{ width:36px; height:36px; transform:rotate(90deg); }
@media (min-width:720px){ .stat-arrow svg{ transform:none; } }
/* experience flow */
.flow{ display:flex; flex-wrap:wrap; align-items:stretch; gap:12px; margin-top:clamp(40px,5vw,56px); }
.flow-step{ flex:1 1 170px; min-width:150px; position:relative; border-radius:14px; border:1px solid var(--line-soft); background:linear-gradient(170deg,rgba(12,30,55,.55),rgba(8,20,38,.55)); padding:18px 18px; }
.flow-step .fs-n{ font-family:var(--mono); font-size:.64rem; font-weight:700; color:var(--gold); letter-spacing:.1em; }
.flow-step h4{ font-family:var(--body); font-size:.98rem; font-weight:700; margin-top:.5em; color:var(--ink); }
.flow-step p{ font-size:.84rem; color:var(--ink-soft); margin-top:.35em; }
.flow-note{ width:100%; margin-top:14px; font-size:.86rem; color:var(--ink-faint); text-align:center; }
.flow-note b{ color:var(--gold); font-weight:600; }

/* small case studies row */
.mini-cases{ display:grid; gap:16px; margin-top:clamp(36px,5vw,52px); }
@media (min-width:640px){ .mini-cases{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .mini-cases{ grid-template-columns:repeat(4,1fr); } }
.mini{ border-radius:14px; border:1px solid var(--line-soft); background:rgba(11,29,54,.4); padding:22px 20px; transition:border-color .3s, transform .3s; }
.mini:hover{ border-color:rgba(252,208,74,.25); transform:translateY(-3px); }
.mini .mv{ font-family:var(--mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); }
.mini h4{ font-family:var(--disp); font-size:1.12rem; font-weight:500; margin-top:.35em; }
.mini p{ font-size:.86rem; color:var(--ink-soft); margin-top:.5em; }
.mini .tag{ display:inline-block; margin-top:.9em; font-family:var(--mono); font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); border:1px solid rgba(236,184,56,.3); border-radius:999px; padding:.3em .7em; }

/* ============================================================ HOW IT WORKS — 1-2-3 */
.steps{ display:grid; gap:0; margin-top:clamp(46px,6vw,68px); max-width:780px; }
.step{ position:relative; display:grid; grid-template-columns:58px 1fr; gap:22px; padding-bottom:clamp(34px,5vw,46px); }
.step:last-child{ padding-bottom:0; }
.step::before{ content:""; position:absolute; left:28px; top:58px; bottom:6px; width:2px; background:linear-gradient(180deg,rgba(252,208,74,.4),rgba(252,208,74,.05)); }
.step:last-child::before{ display:none; }
.step-num{ width:58px; height:58px; flex:none; display:grid; place-items:center; border-radius:50%; font-family:var(--disp); font-weight:600; font-size:1.25rem; color:var(--gold-hi); border:1px solid rgba(252,208,74,.4); background:radial-gradient(circle at 35% 30%, rgba(252,208,74,.18), rgba(252,208,74,.04)); box-shadow:0 0 22px rgba(252,208,74,.13); }
.step h3{ font-family:var(--disp); font-size:1.35rem; font-weight:500; padding-top:.45em; }
.step p{ color:var(--ink-soft); font-size:.98rem; margin-top:.5em; max-width:34em; }

/* ============================================================ PRODUCTS & SERVICES */
.ps-grid{ display:grid; gap:clamp(28px,4vw,40px); margin-top:clamp(40px,6vw,60px); }
@media (min-width:960px){ .ps-grid{ grid-template-columns:1fr 1fr; align-items:start; } }
.ps-col{ border:1px solid var(--line-soft); border-radius:18px; padding:clamp(26px,3.5vw,38px); background:linear-gradient(170deg,rgba(11,30,55,.45),rgba(8,20,38,.45)); }
.ps-col > .eyebrow{ margin-bottom:.4em; }
.ps-col h3{ font-family:var(--disp); font-size:1.7rem; font-weight:500; }
.ps-col .ps-intro{ color:var(--ink-soft); font-size:.96rem; margin-top:.5em; }
.ps-item{ padding:16px 0; border-bottom:1px solid var(--line-soft); display:grid; grid-template-columns:1fr auto; gap:.5em 1em; align-items:baseline; }
.ps-item:last-child{ border-bottom:0; padding-bottom:0; }
.ps-item h4{ font-family:var(--body); font-weight:700; font-size:1rem; color:var(--ink); }
.ps-item p{ grid-column:1/-1; font-size:.88rem; color:var(--ink-soft); margin-top:.1em; }
.ps-item .meta{ font-family:var(--mono); font-size:.6rem; letter-spacing:.08em; text-transform:uppercase; color:var(--gold); white-space:nowrap; }
.retainer-flag{ margin-top:18px; padding:14px 16px; border:1px solid rgba(252,208,74,.28); border-radius:12px; background:rgba(252,208,74,.05); font-size:.9rem; color:var(--ink-soft); }
.retainer-flag b{ color:var(--gold-hi); }

/* ============================================================ INTAKE / FUNNEL */
.intake{ text-align:center; }
.intake .eyebrow{ justify-content:center; }
.intake .lede{ margin-inline:auto; }
.intake-quote{ margin:clamp(40px,6vw,58px) auto 0; max-width:34em; font-family:var(--disp); font-size:clamp(1.3rem,3vw,1.7rem); font-weight:500; color:var(--ink); line-height:1.4; }
.intake-quote .gold{ font-weight:600; }
/* intake widget */
.intake-widget{ max-width:680px; margin:clamp(40px,5vw,56px) auto 0; text-align:left; border-radius:22px; border:1px solid var(--line); background:linear-gradient(170deg,var(--navy-raise),var(--navy-card)); box-shadow:0 30px 80px rgba(0,0,0,.45),0 0 60px rgba(252,208,74,.05); overflow:hidden; }
.iw-head{ display:flex; align-items:center; gap:.7rem; padding:16px 22px; border-bottom:1px solid var(--line-soft); background:rgba(252,208,74,.03); }
.iw-head strong{ font-size:.95rem; }
.iw-head .iw-mode{ margin-left:auto; display:flex; gap:6px; }
.iw-tab{ font-family:var(--mono); font-size:.62rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); padding:.45em .8em; border-radius:999px; border:1px solid transparent; transition:.2s; }
.iw-tab.on{ color:var(--gold-hi); border-color:rgba(252,208,74,.3); background:rgba(252,208,74,.06); }
.iw-body{ min-height:230px; padding:20px 22px; display:flex; flex-direction:column; gap:12px; }
.iw-q{ font-family:var(--disp); font-size:1.2rem; font-weight:500; color:var(--ink); }
.iw-progress{ font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; color:var(--gold); }
.iw-a{ width:100%; background:rgba(168,184,207,.07); border:1px solid var(--line-soft); border-radius:12px; padding:.9em 1.1em; color:var(--ink); font-size:.98rem; outline:none; resize:vertical; min-height:84px; font-family:var(--body); transition:border-color .2s; }
.iw-a:focus{ border-color:var(--gold-dim); }
.iw-row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.iw-mic{ display:inline-flex; align-items:center; gap:.5em; font-size:.84rem; color:var(--gold-hi); border:1px solid rgba(252,208,74,.3); border-radius:999px; padding:.55em 1em; }
.iw-mic svg{ width:15px; height:15px; }
.iw-foot{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:14px 22px; border-top:1px solid var(--line-soft); background:rgba(3,13,26,.5); flex-wrap:wrap; }
.iw-foot small{ font-family:var(--mono); font-size:.6rem; color:var(--ink-faint); letter-spacing:.04em; }
/* record mode */
.rec-stage{ text-align:center; padding:8px 0; }
.rec-orb{ width:78px; height:78px; margin:6px auto 14px; border-radius:50%; display:grid; place-items:center; color:var(--navy-deep); background:linear-gradient(135deg,var(--gold-hi),var(--gold)); box-shadow:0 0 0 0 rgba(252,208,74,.5); }
.rec-orb.live{ animation:recPulse 1.6s ease-in-out infinite; }
@keyframes recPulse{ 0%{ box-shadow:0 0 0 0 rgba(252,208,74,.45); } 70%{ box-shadow:0 0 0 22px rgba(252,208,74,0); } 100%{ box-shadow:0 0 0 0 rgba(252,208,74,0); } }
.rec-orb svg{ width:30px; height:30px; }
.rec-prompts{ text-align:left; margin-top:14px; display:grid; gap:8px; max-height:150px; overflow-y:auto; }
.rec-prompt{ font-size:.9rem; color:var(--ink-soft); padding:.5em .8em; border-left:2px solid var(--line-soft); }
.rec-prompt.on{ color:var(--ink); border-left-color:var(--gold-hi); }

/* ============================================================ WAITLIST */
.waitlist{ max-width:620px; margin:0 auto; text-align:center; border:1px solid var(--line); border-radius:20px; padding:clamp(30px,5vw,48px); background:linear-gradient(170deg,rgba(11,30,55,.55),rgba(8,20,38,.55)); }
.wl-form{ display:flex; gap:10px; margin-top:1.5em; flex-wrap:wrap; justify-content:center; }
.wl-form input{ flex:1; min-width:220px; background:rgba(168,184,207,.07); border:1px solid var(--line-soft); border-radius:999px; padding:.85em 1.2em; color:var(--ink); outline:none; transition:border-color .2s; }
.wl-form input:focus{ border-color:var(--gold-dim); }
.wl-note{ font-family:var(--mono); font-size:.6rem; color:var(--ink-faint); margin-top:1em; letter-spacing:.04em; }

/* ============================================================ CTA */
.cta{ text-align:center; overflow:hidden; }
.cta-ring{ position:absolute; top:50%; left:50%; width:min(140vw,1100px); aspect-ratio:1; transform:translate(-50%,-50%); border-radius:50%; background:radial-gradient(circle, rgba(252,208,74,.09) 0%, rgba(252,208,74,.03) 35%, transparent 60%); animation:corePulse 6s ease-in-out infinite; pointer-events:none; }
.cta-inner{ position:relative; z-index:2; }
.cta h2{ font-size:clamp(2.2rem,6vw,4rem); font-weight:600; }
.cta .lede{ margin-inline:auto; }
.cta-actions{ display:flex; flex-direction:column; align-items:center; gap:16px; margin-top:2.4rem; }
.cta-mail{ font-family:var(--mono); color:var(--ink-faint); font-size:.84rem; }
.cta-mail a{ color:var(--gold); border-bottom:1px solid rgba(236,184,56,.3); }
.cta-mail a:hover{ color:var(--gold-hi); }

/* ============================================================ FOOTER */
footer{ background:var(--navy-deep); border-top:1px solid var(--line-soft); padding-block:44px; }
.foot{ display:flex; flex-direction:column; align-items:center; gap:16px; text-align:center; }
.foot .brand{ font-size:.95rem; }
.foot-links{ display:flex; flex-wrap:wrap; justify-content:center; gap:1.5rem; list-style:none; }
.foot-links a{ font-size:.85rem; font-weight:600; color:var(--ink-faint); transition:color .25s; }
.foot-links a:hover{ color:var(--gold-hi); }
.foot small{ font-family:var(--mono); color:var(--ink-faint); font-size:.72rem; letter-spacing:.04em; }
@media (min-width:760px){ .foot{ flex-direction:row; justify-content:space-between; text-align:left; } }

/* ============================================================ MOTION SAFETY */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .reveal{ opacity:1; transform:none; }
  #particles,#flux,.scroll-cue{ display:none; }
}


/* ============================================================ STICKY MOBILE CTA (board rec: phone/LinkedIn conversion) */
.sticky-cta{ position:fixed; left:0; right:0; bottom:0; z-index:90; display:none; align-items:center; justify-content:space-between; gap:12px;
  padding:10px 16px calc(10px + env(safe-area-inset-bottom)); background:rgba(5,13,27,.93);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border-top:1px solid var(--line); }
.sticky-cta p{ min-width:0; flex:1; font-size:.82rem; color:var(--ink-soft); line-height:1.2; }
.sticky-cta p b{ color:var(--gold-hi); font-weight:700; }
.sticky-cta .btn{ white-space:nowrap; flex:none; }
@media (max-width:879px){ .sticky-cta{ display:flex; } body{ padding-bottom:66px; } }


/* ============================================================ NORRIS COMMAND CENTER (cockpit mockup) */
.cockpit{ position:relative; border-radius:20px; border:1px solid var(--line); background:linear-gradient(168deg,var(--navy-raise),var(--navy-card) 78%); box-shadow:0 30px 80px rgba(0,0,0,.45), 0 0 60px rgba(252,208,74,.05); overflow:hidden; }
.cockpit::before{ content:""; position:absolute; inset:-1px; border-radius:21px; padding:1px; background:linear-gradient(140deg, rgba(252,208,74,.4), transparent 32%, transparent 68%, rgba(252,208,74,.18)); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.cp-head{ display:flex; align-items:center; gap:.7rem; padding:15px 22px; border-bottom:1px solid var(--line-soft); background:rgba(252,208,74,.03); }
.cp-head .chat-dot{ width:9px;height:9px;border-radius:50%;background:var(--gold-hi);box-shadow:0 0 10px var(--gold-hi);animation:dotPulse 2.4s ease-in-out infinite; }
.cp-head strong{ font-size:.92rem; }
.cp-head small{ margin-left:auto; font-family:var(--mono); color:var(--ink-faint); font-size:.62rem; letter-spacing:.08em; }
.cp-grid{ display:grid; gap:1px; background:var(--line-soft); }
@media (min-width:620px){ .cp-grid{ grid-template-columns:1fr 1fr; } }
.cp-cell{ background:var(--navy-card); padding:18px 20px; }
.cp-label{ font-family:var(--mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:.5em; }
.cp-label svg{ width:13px; height:13px; }
.cp-li{ display:flex; gap:.6em; align-items:baseline; margin-top:.7em; font-size:.86rem; color:var(--ink-soft); }
.cp-li b{ color:var(--ink); font-weight:600; }
.cp-li .dot{ width:6px; height:6px; border-radius:50%; flex:none; margin-top:.45em; background:var(--gold); }
.cp-li .dot.warn{ background:#E8893A; }
.cp-li .dot.ok{ background:#5BB98C; }
/* mini bar chart */
.cp-chart{ display:flex; align-items:flex-end; gap:6px; height:54px; margin-top:.8em; }
.cp-chart span{ flex:1; background:linear-gradient(180deg, var(--gold-hi), rgba(236,184,56,.25)); border-radius:3px 3px 0 0; opacity:.85; }
.cp-chart .peak{ background:linear-gradient(180deg,#FCD04A,rgba(252,208,74,.4)); box-shadow:0 0 12px var(--gold-glow); }
.cp-metric{ display:flex; align-items:baseline; gap:.5em; margin-top:.5em; }
.cp-metric .n{ font-family:var(--disp); font-size:1.5rem; font-weight:600; color:var(--gold-hi); }
.cp-metric .d{ font-size:.74rem; color:#5BB98C; font-weight:600; }
.cp-strat{ font-size:.86rem; color:var(--ink-soft); margin-top:.7em; line-height:1.5; }
.cp-strat b{ color:var(--ink); }
/* the voice bar */
.cp-voice{ display:flex; align-items:center; gap:.8em; padding:14px 22px; border-top:1px solid var(--line-soft); background:rgba(3,13,26,.4); }
.cp-voice .mic{ width:34px; height:34px; flex:none; border-radius:50%; display:grid; place-items:center; color:var(--navy-deep); background:linear-gradient(135deg,var(--gold-hi),var(--gold)); }
.cp-voice .mic svg{ width:16px; height:16px; }
.cp-voice .ask{ font-size:.86rem; color:var(--ink-faint); font-style:italic; }


/* ============================================================ PROOF CARD refinements (R round 2) */
a.pcard{ color:inherit; cursor:pointer; }
.pcard .vertical{ min-height:2.4em; }            /* align headers across cards even when one wraps */
.pcard .fact{ font-family:var(--mono); font-size:.66rem; letter-spacing:.04em; color:var(--gold); margin-top:.45em; }
.pcard .plink{ cursor:pointer; }


/* ============================================================ PRODUCTS & SERVICES round-2 (equal height + buttons) */
@media (min-width:960px){ .ps-grid{ align-items:stretch; } }
.ps-col{ display:flex; flex-direction:column; }
.ps-link{ color:var(--gold-hi); font-weight:600; white-space:nowrap; }
.ps-cta{ margin-top:auto; padding-top:22px; }
.ps-cta .btn{ width:100%; }


/* ============================================================ TESTIMONIALS (R round 2) */
.quotes{ display:grid; gap:18px; margin-top:clamp(40px,6vw,56px); }
@media (min-width:820px){ .quotes{ grid-template-columns:1fr 1fr; } }
.quote{ border:1px solid var(--line-soft); border-radius:18px; padding:28px 28px 24px; background:linear-gradient(170deg,rgba(12,30,55,.5),rgba(8,20,38,.5)); display:flex; flex-direction:column; transition:border-color .3s, transform .3s; }
.quote:hover{ border-color:rgba(252,208,74,.25); transform:translateY(-3px); }
.quote .mark{ font-family:var(--disp); font-size:2.6rem; line-height:.4; color:var(--gold-dim); height:.5em; }
.quote blockquote{ font-size:1.02rem; color:var(--ink); line-height:1.6; margin:.5em 0 0; flex:1; }
.quote blockquote b{ color:var(--gold-hi); font-weight:600; }
.quote .by{ display:flex; flex-direction:column; gap:.15em; margin-top:1.3em; padding-top:1.2em; border-top:1px solid var(--line-soft); }
.quote .by .who{ font-weight:700; color:var(--ink); font-size:.96rem; }
.quote .by .role{ font-family:var(--mono); font-size:.66rem; letter-spacing:.03em; color:var(--ink-faint); }
.quote .by a{ color:var(--gold); }


/* ============================================================ FOOTER rebuild (R round 2: not ugly + drop "AI") */
footer{ padding-block:clamp(44px,6vw,64px); position:relative; }
footer::before{ content:""; position:absolute; top:0; left:10%; right:10%; height:1px; background:linear-gradient(90deg, transparent, var(--gold-dim), transparent); }
.foot-top{ display:grid; gap:30px; }
@media (min-width:760px){ .foot-top{ grid-template-columns:1.3fr 1fr; align-items:start; } }
.foot-brand-block .brand{ font-size:1.05rem; }
.foot-tagline{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-top:1.1em; }
.foot-blurb{ color:var(--ink-faint); font-size:.9rem; margin-top:.7em; max-width:30em; line-height:1.6; }
.foot-links{ display:flex; flex-wrap:wrap; gap:.8rem 1.5rem; list-style:none; }
@media (min-width:760px){ .foot-links{ flex-direction:column; gap:.75rem; align-items:flex-end; } }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; margin-top:clamp(30px,4vw,44px); padding-top:20px; border-top:1px solid var(--line-soft); }
.foot-bottom small{ font-family:var(--mono); color:var(--ink-faint); font-size:.72rem; letter-spacing:.04em; }
.foot-bottom small:last-child{ color:var(--gold-dim); }


/* ============================================================ ROUND 3 */
/* mission: AI for the good guys bigger + italic on its own line */
.intake-quote .aigg{ font-style:italic; font-size:1.2em; display:inline-block; margin-top:.15em; }
/* testimonials: org names gold, roles gray */
.quote .by .org{ color:var(--gold-hi); font-weight:600; }
/* proof cards: bulletproof header alignment (clamp vertical to 2 lines, fixed reserve) */
.pcard .vertical{ min-height:2.7em; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
/* product CTAs as little embedded pills */
.ps-link{ display:inline-flex; align-items:center; gap:.3em; font-size:.72rem; font-weight:700; color:var(--gold-hi);
  border:1px solid rgba(252,208,74,.38); background:rgba(252,208,74,.07); padding:.32em .8em; border-radius:999px;
  white-space:nowrap; vertical-align:middle; transition:background .2s, border-color .2s; }
.ps-link:hover{ background:rgba(252,208,74,.16); border-color:var(--gold-hi); }
/* intake recorder: glow to signal tappable; red + stop-square while recording */
.rec-orb{ position:relative; transition:background .3s, box-shadow .3s; animation:orbIdle 2.4s ease-in-out infinite; }
@keyframes orbIdle{ 0%,100%{ box-shadow:0 0 18px rgba(252,208,74,.4); } 50%{ box-shadow:0 0 34px rgba(252,208,74,.75); } }
.rec-orb .ic-stop{ display:none; }
.rec-orb.rec{ background:linear-gradient(135deg,#FF6152,#D8392A); animation:recPulseRed 1.3s ease-in-out infinite; }
.rec-orb.rec .ic-mic{ display:none; }
.rec-orb.rec .ic-stop{ display:block; color:#fff; }
@keyframes recPulseRed{ 0%{ box-shadow:0 0 0 0 rgba(255,97,82,.55); } 70%{ box-shadow:0 0 0 20px rgba(255,97,82,0); } 100%{ box-shadow:0 0 0 0 rgba(255,97,82,0); } }
.rec-hint{ font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-top:-6px; }


/* ============================================================ VTQ flow de-densify + catalog visual (R3 D2-D4) */
.vtq-grid{ display:grid; gap:clamp(24px,4vw,40px); margin-top:clamp(40px,5vw,56px); }
@media (min-width:880px){ .vtq-grid{ grid-template-columns:1fr 1fr; align-items:start; } }
.flow2{ display:grid; gap:12px; }
.fstep{ border:1px solid var(--line-soft); border-radius:14px; padding:15px 18px; background:linear-gradient(170deg,rgba(12,30,55,.5),rgba(8,20,38,.5)); transition:border-color .25s; }
.fstep:hover,.fstep:focus-within{ border-color:rgba(252,208,74,.32); }
.fstep-h{ display:flex; align-items:center; gap:.75em; }
.fstep-h .ic{ width:36px; height:36px; flex:none; border-radius:10px; display:grid; place-items:center; color:var(--gold-hi); background:rgba(252,208,74,.1); border:1px solid rgba(252,208,74,.25); }
.fstep-h .ic svg{ width:18px; height:18px; }
.fstep-h h4{ font-family:var(--body); font-weight:700; font-size:1.02rem; color:var(--ink); }
.fstep-h .more{ margin-left:auto; color:var(--ink-faint); font-size:1.2rem; line-height:1; transition:transform .3s, color .2s; }
.fstep:hover .fstep-h .more,.fstep:focus-within .fstep-h .more{ transform:rotate(45deg); color:var(--gold); }
.fstep-d{ font-size:.88rem; color:var(--ink-soft); max-height:0; opacity:0; overflow:hidden; transition:max-height .35s ease, opacity .3s ease, margin .35s; }
.fstep:hover .fstep-d,.fstep:focus-within .fstep-d{ max-height:7em; opacity:1; margin-top:.6em; }
@media (max-width:759px){ .fstep-d{ max-height:none; opacity:1; margin-top:.55em; } .fstep-h .more{ display:none; } }
/* self-improving catalog mockup */
.catalog-viz{ border-radius:18px; border:1px solid var(--line); background:linear-gradient(168deg,var(--navy-raise),var(--navy-card)); box-shadow:0 26px 70px rgba(0,0,0,.4),0 0 50px rgba(252,208,74,.05); overflow:hidden; }
.cv-head{ display:flex; align-items:center; gap:.55em; padding:14px 18px; border-bottom:1px solid var(--line-soft); background:rgba(252,208,74,.03); font-weight:600; font-size:.9rem; }
.cv-head .chat-dot{ width:8px;height:8px;border-radius:50%;background:var(--gold-hi);box-shadow:0 0 8px var(--gold-hi);animation:dotPulse 2.4s ease-in-out infinite; }
.cv-head small{ margin-left:auto; font-family:var(--mono); font-size:.58rem; letter-spacing:.08em; color:var(--gold); }
.cv-row{ display:flex; align-items:center; gap:.7em; padding:11px 18px; border-bottom:1px solid var(--line-soft); font-size:.88rem; }
.cv-row .lbl{ color:var(--ink-soft); flex:1; }
.cv-row .price{ font-family:var(--mono); color:var(--ink); font-weight:600; }
.cv-row .tick{ font-family:var(--mono); font-size:.6rem; color:#5BB98C; white-space:nowrap; }
.cv-foot{ padding:14px 18px; font-size:.86rem; color:var(--ink-soft); line-height:1.5; }
.cv-foot b{ color:var(--gold-hi); }

/* ===== Norris command center — frosted glass (R 2026-06-21) ===== */
.cc{ position:relative; border-radius:24px; padding:clamp(18px,3vw,30px); overflow:hidden;
  background:linear-gradient(168deg, rgba(13,30,54,.34), rgba(7,18,34,.18));
  border:1px solid var(--line-soft);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.6); }
.cc-glow{ position:absolute; z-index:0; pointer-events:none; width:560px; height:440px;
  top:-180px; right:-80px; border-radius:50%;
  background:radial-gradient(circle, rgba(252,208,74,.22), transparent 66%); filter:blur(8px); }
.cc-ring{ position:absolute; z-index:0; pointer-events:none; width:460px; height:460px;
  left:34%; top:30%; border-radius:50%; border:1px solid rgba(236,184,56,.12); }
.cc-head,.cc-grid,.cc-voice{ position:relative; z-index:1; }
.cc-head{ display:flex; align-items:center; gap:.7rem; padding:2px 4px 20px; }
.cc-title{ font-family:var(--disp); font-weight:500; font-size:clamp(17px,2vw,21px);
  letter-spacing:-.006em; color:var(--ink); line-height:1.1; }
.cc-sep{ color:var(--gold); padding:0 .38em; }
.cc-ul{ position:relative; display:inline-block; font-style:italic; }
.cc-ul svg{ position:absolute; left:-3%; bottom:-7px; width:106%; height:9px; overflow:visible; }
.cc-time{ margin-left:auto; font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; padding:7px 13px; border-radius:999px;
  background:rgba(255,255,255,.04); border:1px solid var(--line-soft);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); }
.cc-grid{ display:grid; grid-template-columns:1fr; gap:16px; }
@media (min-width:620px){ .cc-grid{ grid-template-columns:1fr 1fr; } }
.cc-card{ position:relative; border-radius:18px; padding:22px 24px;
  background:linear-gradient(168deg, rgba(28,52,88,.55), rgba(13,30,56,.40));
  border:1px solid rgba(255,255,255,.10);
  -webkit-backdrop-filter:blur(22px) saturate(150%); backdrop-filter:blur(22px) saturate(150%);
  box-shadow:0 24px 60px -24px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.10), inset 0 -12px 26px -18px rgba(0,0,0,.30); }
.cc-card::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg, rgba(252,208,74,.45), transparent 30%, transparent 66%, rgba(252,208,74,.22));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite:exclude; pointer-events:none; }
.cc-label{ display:flex; align-items:center; gap:.55em; font-family:var(--body); font-size:.62rem;
  font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.cc-label svg{ width:14px; height:14px; flex:none; }
.cc-rows{ display:flex; flex-direction:column; gap:13px; }
.cc-row{ display:flex; gap:11px; align-items:flex-start; }
.cc-row p{ font-size:.9rem; line-height:1.5; color:var(--ink-soft); }
.cc-row b{ font-weight:600; color:var(--gold-hi); }
.cc-dot{ flex:none; width:8px; height:8px; border-radius:50%; margin-top:.5em;
  background:var(--gold); box-shadow:0 0 0 4px rgba(236,184,56,.10); }
.cc-dot.warn{ background:#E8893A; box-shadow:0 0 0 4px rgba(232,137,58,.12); }
.cc-dot.ok{ background:#5BB98C; box-shadow:0 0 0 4px rgba(91,185,140,.12); }
.cc-metric{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; }
.cc-mfig{ display:flex; flex-direction:column; gap:9px; }
.cc-n{ font-family:var(--disp); font-weight:600; font-size:clamp(34px,4.4vw,48px); line-height:.92;
  letter-spacing:-.01em; color:var(--gold-hi); }
.cc-delta{ display:inline-flex; align-items:center; gap:5px; align-self:flex-start; font-size:.72rem;
  font-weight:600; color:#7fd6a0; background:rgba(91,185,140,.14); padding:4px 11px; border-radius:999px; }
.cc-bars{ display:flex; align-items:flex-end; gap:7px; height:72px; padding-bottom:2px; }
.cc-bars span{ width:11px; border-radius:4px 4px 2px 2px; background:rgba(168,184,207,.18); }
.cc-bars .peak{ background:linear-gradient(180deg, var(--gold-hi), var(--gold-deep));
  box-shadow:0 4px 14px -4px rgba(252,208,74,.5); }
.cc-strat{ font-size:.9rem; line-height:1.55; color:var(--ink-soft); margin-bottom:14px; }
.cc-strat b{ font-weight:600; color:var(--ink); }
.cc-voice{ margin-top:16px; display:flex; align-items:center; gap:15px; padding:13px 20px; border-radius:999px;
  background:linear-gradient(168deg, rgba(28,52,88,.5), rgba(13,30,56,.36)); border:1px solid rgba(255,255,255,.09);
  -webkit-backdrop-filter:blur(22px) saturate(150%); backdrop-filter:blur(22px) saturate(150%);
  box-shadow:0 20px 50px -24px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.10); }
.cc-mic{ flex:none; width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--navy-deep); background:linear-gradient(150deg, var(--gold-hi), var(--gold-deep));
  box-shadow:0 8px 20px -7px rgba(200,145,42,.6), inset 0 1px 0 rgba(255,255,255,.5); }
.cc-mic svg{ width:20px; height:20px; }
.cc-ask{ font-family:var(--disp); font-style:italic; font-size:clamp(15px,1.7vw,18px); color:var(--ink-soft); }

/* ===== Site-wide frosted glass (R 2026-06-21) ===== */
.pcard, .chat-shell, .asknorris, .intake-widget, .catalog-viz, .stat,
.quote, .waitlist, .stack-row, .mini{
  background:linear-gradient(168deg, rgba(28,52,88,.50), rgba(13,30,56,.36));
  border-color:rgba(255,255,255,.10);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  backdrop-filter:blur(20px) saturate(150%);
  box-shadow:0 24px 60px -26px rgba(0,0,0,.55), 0 0 48px rgba(252,208,74,.04),
    inset 0 1px 0 rgba(255,255,255,.10), inset 0 -12px 26px -18px rgba(0,0,0,.26);
}
/* frosted sticky nav */
.nav.scrolled{
  background:rgba(7,18,34,.55);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  backdrop-filter:blur(18px) saturate(160%);
}
/* chat bubbles: faint frost so they sit in the glass system */
.msg.user, .msg.ai, .an-msg{
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  backdrop-filter:blur(8px) saturate(140%);
}

/* ===== Animated demo chat — plays once on scroll-into-view (R 2026-06-21) ===== */
.chat-anim .msg, .chat-anim .msg-meta{ opacity:0; transform:translateY(11px);
  transition:opacity .55s var(--ease,ease), transform .55s var(--ease,ease); }
.chat-anim .msg.in, .chat-anim .msg-meta.in{ opacity:1; transform:none; }
.msg.ai{ position:relative; }
.ai-dots{ display:none; }
.chat-anim .ai-text{ opacity:0; transition:opacity .5s ease; }
.chat-anim .msg.ai.typed .ai-text{ opacity:1; }
.chat-anim .ai-dots{ display:inline-flex; gap:5px; position:absolute; top:1.05em; left:.95em;
  opacity:0; transition:opacity .3s ease; }
.chat-anim .msg.ai.in .ai-dots{ opacity:1; }
.chat-anim .msg.ai.typed .ai-dots{ opacity:0; }
.ai-dots i{ width:6px; height:6px; border-radius:50%; background:var(--gold-hi); display:block;
  animation:aiDot 1.2s ease-in-out infinite; }
.ai-dots i:nth-child(2){ animation-delay:.16s; } .ai-dots i:nth-child(3){ animation-delay:.32s; }
@keyframes aiDot{ 0%,60%,100%{ transform:translateY(0); opacity:.4 } 30%{ transform:translateY(-4px); opacity:1 } }
@media (prefers-reduced-motion:reduce){
  .chat-anim .msg, .chat-anim .msg-meta, .chat-anim .ai-text{ opacity:1!important; transform:none!important; }
  .chat-anim .ai-dots{ display:none!important; }
}
