/* =====================================================================
   LAUREN KINGSLEY STRATEGY  ::  Design System
   Sovereign businesses. Sovereign systems. Sovereign strategy.
   Glass-morphic  ::  Electric Blue / Lime / Midnight / Ice White
   ===================================================================== */

/* ---------- TOKENS ---------- */
:root{
  /* Brand palette  ::  Outcore-deep blue scale + lime accent */
  --blue:            #0B5CF0;   /* primary electric blue */
  --blue-deep:       #092676;   /* royal deep */
  --blue-darkest:    #050A34;   /* near-black navy */
  --blue-bright:     #4D8BFF;   /* lighter highlight (text/links) */
  --blue-vivid:      #1E5BFF;
  --ice:             #AFE9FD;   /* ice blue */
  --lime:            #C2F750;   /* signature pop accent */
  --lime-bright:     #CEFF1C;
  --lime-deep:       #A9DE2E;
  --gold:            #C9A24B;   /* premium hairline accent */
  --ink:             #050A34;   /* near-black navy base */
  --ink-2:           #0A1440;   /* surface */
  --ink-3:           #081031;   /* deepest card */
  --white:           #F5F6FC;   /* ice white */
  --mist:            #E6ECF7;

  /* Legacy aliases (kept so markup keeps working) */
  --cerulean:        var(--blue);
  --cerulean-deep:   var(--blue-deep);
  --cerulean-bright: var(--blue-bright);
  --tropical:        var(--lime);
  --tropical-deep:   var(--lime-deep);
  --fuchsia:         var(--lime-deep);
  --fuchsia-soft:    var(--lime);

  /* Functional */
  --bg:              var(--ink);
  --text:            var(--white);
  --text-dim:        #A7B6CC;
  --text-faint:      #6F84A0;

  /* Glass */
  --glass-bg:        rgba(255,255,255,0.05);
  --glass-bg-2:      rgba(255,255,255,0.08);
  --glass-brd:       rgba(255,255,255,0.13);
  --glass-brd-hi:    rgba(255,255,255,0.27);
  --glass-blur:      22px;
  --glass-shadow:    0 18px 50px -12px rgba(0,0,0,0.6);

  /* Gradients */
  --grad-primary:    linear-gradient(125deg, var(--blue-deep) 0%, var(--blue) 55%, var(--blue-vivid) 100%);
  --grad-accent:     linear-gradient(120deg, var(--lime) 0%, var(--lime-bright) 100%);
  --grad-text:       linear-gradient(120deg, var(--white) 0%, var(--ice) 48%, var(--blue-bright) 100%);
  --grad-lime-text:  linear-gradient(120deg, var(--lime) 0%, var(--lime-bright) 100%);

  /* Type  ::  Sora (bold geometric display) + Manrope (clean body) */
  --font-display: "Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:    "Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;

  /* Layout */
  --maxw: 1180px;
  --radius: 26px;
  --radius-sm: 16px;
  --gap: clamp(1rem, 2.5vw, 2rem);

  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
:focus-visible{ outline:2px solid var(--blue-bright); outline-offset:3px; border-radius:6px; }

/* ---------- BACKGROUND FIELD ---------- */
.bg-field{ position:fixed; inset:0; z-index:-2; overflow:hidden; background:
   radial-gradient(1200px 700px at 12% -5%, rgba(53,69,214,.34), transparent 60%),
   radial-gradient(1000px 800px at 95% 8%, rgba(77,139,255,.12), transparent 55%),
   radial-gradient(900px 700px at 60% 110%, rgba(55,75,255,.20), transparent 60%),
   var(--ink);
}
.bg-orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; animation:drift 26s var(--ease) infinite; }
.bg-orb.a{ width:520px; height:520px; left:-120px; top:-80px; background:radial-gradient(circle,var(--blue),transparent 65%); }
.bg-orb.b{ width:460px; height:460px; right:-100px; top:18%; background:radial-gradient(circle,var(--blue-vivid),transparent 65%); opacity:.32; animation-delay:-8s; }
.bg-orb.c{ width:420px; height:420px; left:30%; bottom:-140px; background:radial-gradient(circle,var(--blue-vivid),transparent 70%); opacity:.4; animation-delay:-15s; }
.bg-grid{ position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:54px 54px; mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 80%); }
@keyframes drift{ 50%{ transform:translate(40px,30px) scale(1.08); } }
@media (prefers-reduced-motion:reduce){ .bg-orb{ animation:none; } html{ scroll-behavior:auto; } }

/* ---------- LAYOUT ---------- */
.wrap{ width:min(var(--maxw),92vw); margin-inline:auto; }
section{ position:relative; padding:clamp(4rem,9vw,8rem) 0; }
.eyebrow{ display:inline-flex; align-items:center; gap:.55rem; font-size:.74rem; letter-spacing:.22em;
  text-transform:uppercase; font-weight:700; color:var(--ice);
  padding:.4rem .85rem; border:1px solid var(--glass-brd); border-radius:100px;
  background:var(--glass-bg); backdrop-filter:blur(8px); }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--ice); box-shadow:0 0 12px var(--blue); }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:1.08; letter-spacing:-.025em; }
.h-section{ font-size:clamp(2rem,4.6vw,3.4rem); margin:1rem 0 1rem; }
.lead{ font-size:clamp(1.02rem,1.5vw,1.22rem); color:var(--text-dim); max-width:62ch; }
.gradient-text{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.accent-text{ background:var(--grad-accent); -webkit-background-clip:text; background-clip:text; color:transparent; }
.center{ text-align:center; } .center .lead{ margin-inline:auto; }

/* ---------- GLASS CARD ---------- */
.glass{
  background:var(--glass-bg); border:1px solid var(--glass-brd);
  backdrop-filter:blur(var(--glass-blur)) saturate(140%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(140%);
  border-radius:var(--radius); box-shadow:var(--glass-shadow);
  position:relative; overflow:hidden;
}
.glass::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg,rgba(255,255,255,.42),transparent 40%,transparent 70%,rgba(11,92,240,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.glass.lift{ transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease); }
.glass.lift:hover{ transform:translateY(-6px); border-color:var(--glass-brd-hi);
  box-shadow:0 28px 60px -18px var(--shadow-blue); }
.pad{ padding:clamp(1.4rem,2.6vw,2.2rem); }

/* ---------- BUTTONS ---------- */
.btn{ display:inline-flex; align-items:center; gap:.55rem; font-weight:700; font-size:.96rem;
  padding:.92rem 1.5rem; border-radius:100px; transition:all .35s var(--ease); position:relative; }
.btn-primary{ background:var(--grad-primary); color:#fff; font-weight:700;
  box-shadow:0 12px 30px -8px var(--shadow-blue); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 20px 44px -10px var(--glow-blue); }
.btn-accent{ background:var(--grad-accent); color:var(--ink-2); font-weight:800;
  box-shadow:0 12px 30px -8px rgba(194,247,80,.5); }
.btn-accent:hover{ transform:translateY(-3px); box-shadow:0 20px 44px -10px rgba(194,247,80,.7); }
.btn-ghost{ background:var(--glass-bg); border:1px solid var(--glass-brd); color:var(--text);
  backdrop-filter:blur(10px); }
.btn-ghost:hover{ border-color:var(--glass-brd-hi); background:var(--glass-bg-2); transform:translateY(-3px); }
.btn svg{ transition:transform .35s var(--ease); }
.btn:hover svg{ transform:translateX(4px); }

/* ---------- NAV ---------- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:100; transition:all .4s var(--ease); }
.nav-inner{ width:min(var(--maxw),94vw); margin:.85rem auto; display:flex; align-items:center;
  justify-content:space-between; padding:.7rem 1.1rem; border-radius:100px;
  background:rgba(10,19,32,.5); border:1px solid var(--glass-brd);
  backdrop-filter:blur(16px) saturate(150%); }
.nav.scrolled .nav-inner{ background:rgba(10,19,32,.85); box-shadow:0 10px 30px -12px rgba(0,0,0,.6); }
.brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:800; font-size:1.05rem; }
.brand .mark{ width:30px; height:30px; border-radius:9px; background:var(--grad-primary);
  display:grid; place-items:center; color:#fff; font-weight:800; box-shadow:0 0 18px var(--glow-blue); }
.nav-links{ display:flex; gap:.3rem; align-items:center; }
.nav-links a{ font-size:.9rem; color:var(--text-dim); padding:.5rem .8rem; border-radius:100px; transition:all .3s var(--ease); }
.nav-links a:hover{ color:var(--white); background:var(--glass-bg); }
.nav-cta{ display:flex; align-items:center; gap:.6rem; }
.nav-toggle{ display:none; width:42px; height:42px; border-radius:12px; background:var(--glass-bg);
  border:1px solid var(--glass-brd); color:var(--text); font-size:1.2rem; align-items:center; justify-content:center; }

/* ---------- HERO ---------- */
.hero{ min-height:100svh; display:grid; place-items:center; padding-top:8rem; text-align:center; }
.hero h1{ font-size:clamp(2.6rem,7vw,5.4rem); margin:1.4rem 0; }
.hero .lead{ font-size:clamp(1.05rem,1.8vw,1.4rem); margin-inline:auto; margin-bottom:2.2rem; }
.hero-ctas{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-proof{ margin-top:3.2rem; display:flex; gap:clamp(1rem,4vw,3rem); justify-content:center; flex-wrap:wrap; }
.hero-proof .stat{ text-align:center; }
.hero-proof .num{ font-family:var(--font-display); font-size:clamp(1.6rem,3vw,2.4rem); font-weight:800; }
.hero-proof .lbl{ font-size:.78rem; color:var(--text-faint); text-transform:uppercase; letter-spacing:.1em; }

/* ---------- HERO (sovereign / silhouette in giant letters) ---------- */
.hero-sov{ position:relative; min-height:100svh; display:grid; grid-template-columns:1.08fr .92fr;
  align-items:center; gap:1.5rem; overflow:hidden; padding:9rem 0 2rem; }
.hero-bgword{ position:absolute; inset:0; display:grid; place-items:center; z-index:0; pointer-events:none; overflow:hidden; }
.hero-bgword span{ font-family:var(--font-display); font-weight:800; font-size:min(27vw,25rem); line-height:.78;
  letter-spacing:-.045em; color:transparent; -webkit-text-stroke:1.5px rgba(173,233,253,.16); white-space:nowrap; opacity:.7; }
.hero-copy{ position:relative; z-index:2; }
.hero-copy h1{ font-size:clamp(2.5rem,6vw,4.8rem); margin:1.3rem 0; }
.hero-copy .lead{ margin-bottom:2rem; }
.hero-figwrap{ position:relative; z-index:1; align-self:end; display:grid; place-items:end center; min-height:60vh; }
.hero-fig{ position:relative; max-height:88vh; width:auto; max-width:100%;
  filter:drop-shadow(0 0 55px rgba(11,92,240,.55)) drop-shadow(0 28px 55px rgba(0,0,0,.55));
  -webkit-mask-image:linear-gradient(#000 88%,transparent 100%); mask-image:linear-gradient(#000 88%,transparent 100%); }
.hero-fig.is-photo{ border-radius:var(--radius); max-height:72vh; border:1px solid var(--glass-brd);
  -webkit-mask-image:none; mask-image:none; box-shadow:var(--glass-shadow); }
@media(max-width:900px){
  .hero-sov{ grid-template-columns:1fr; text-align:center; padding-top:7rem; min-height:auto; }
  .hero-sov .hero-proof{ justify-content:center; }
  .hero-figwrap{ position:absolute; inset:0; opacity:.16; z-index:0; min-height:0; align-self:center; }
  .hero-fig{ max-height:100vh; }
  .hero-bgword span{ font-size:46vw; }
}

/* ---------- SOVEREIGNTY PILLARS ---------- */
.pillar{ position:relative; }
.pillar .pno{ font-family:var(--font-display); font-weight:800; font-size:.9rem; color:var(--blue-bright); letter-spacing:.08em; }
.pillar h3{ font-size:1.18rem; margin:.7rem 0 .5rem; }
.pillar p{ color:var(--text-dim); font-size:.92rem; }
.goldrule{ height:1px; width:64px; background:linear-gradient(90deg,var(--gold),transparent); margin:.4rem auto 0; }

/* ---------- ABOUT ---------- */
.about-photo{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--glass-shadow);
  border:1px solid var(--glass-brd); }
.about-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.about-photo::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(5,10,52,.6)); }

/* ---------- MARQUEE ---------- */
.marquee{ overflow:hidden; padding:1.4rem 0; border-block:1px solid var(--glass-brd);
  background:rgba(255,255,255,.02); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:3rem; width:max-content; animation:scroll 38s linear infinite; }
.marquee-track span{ font-family:var(--font-display); font-weight:600; color:var(--text-faint);
  font-size:1.05rem; display:inline-flex; align-items:center; gap:3rem; white-space:nowrap; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---------- GRID HELPERS ---------- */
.grid{ display:grid; gap:var(--gap); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }

/* ---------- FUNNEL STAGE CARDS ---------- */
.stage{ position:relative; }
.stage .stage-no{ font-family:var(--font-display); font-size:3rem; font-weight:800;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; opacity:.9; line-height:1; }
.stage h3{ font-size:1.3rem; margin:.5rem 0 .8rem; }
.stage .tag{ font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--blue-bright); font-weight:700; }
.stage ul.breaks{ display:grid; gap:.5rem; margin-top:1rem; }
.stage ul.breaks li{ font-size:.9rem; color:var(--text-dim); padding-left:1.4rem; position:relative; }
.stage ul.breaks li::before{ content:""; position:absolute; left:0; top:.55em; width:8px; height:8px;
  border-radius:2px; background:var(--blue-bright); transform:rotate(45deg); }

/* ---------- LEAKAGE INDICATOR ---------- */
.calc{ display:grid; grid-template-columns:1.1fr .9fr; gap:2rem; }
.calc .field{ margin-bottom:1.2rem; }
.calc label{ display:flex; justify-content:space-between; font-size:.85rem; color:var(--text-dim); margin-bottom:.5rem; font-weight:600; }
.calc label b{ color:var(--blue-bright); font-family:var(--font-display); }
.calc input[type=range]{ width:100%; -webkit-appearance:none; height:6px; border-radius:100px;
  background:rgba(255,255,255,.12); outline:none; }
.calc input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:22px; height:22px; border-radius:50%;
  background:var(--grad-primary); cursor:pointer; box-shadow:0 0 0 4px rgba(11,92,240,.3); transition:transform .2s; }
.calc input[type=range]::-webkit-slider-thumb:hover{ transform:scale(1.15); }
.calc input[type=number]{ width:100%; padding:.7rem .9rem; border-radius:12px; background:rgba(255,255,255,.06);
  border:1px solid var(--glass-brd); color:var(--white); font-size:1rem; }
.calc-result{ display:grid; place-content:center; text-align:center; gap:.4rem; }
.calc-result .big{ font-family:var(--font-display); font-size:clamp(2.4rem,6vw,3.8rem); font-weight:800;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; position:relative; }
.calc-result .big::after{ content:""; display:block; width:64px; height:3px; margin:.5rem auto 0; border-radius:3px; background:var(--grad-accent); }
.calc-result .sub{ color:var(--text-dim); font-size:.95rem; }
.calc-result .recov{ margin-top:.8rem; font-size:.85rem; color:var(--text-dim); font-weight:700; }

/* ---------- TESTIMONIALS ---------- */
.quote{ font-size:1.05rem; line-height:1.7; }
.quote .by{ margin-top:1.2rem; display:flex; align-items:center; gap:.8rem; }
.quote .av{ width:44px; height:44px; border-radius:50%; background:var(--grad-primary); display:grid;
  place-items:center; font-weight:800; color:#fff; font-family:var(--font-display); }
.quote .by .who{ font-weight:700; font-size:.92rem; }
.quote .by .role{ font-size:.8rem; color:var(--text-faint); }
.stars{ color:var(--gold); letter-spacing:2px; font-size:.95rem; }

/* ---------- FORMS ---------- */
.form-field{ margin-bottom:1.1rem; }
.form-field label{ display:block; font-size:.85rem; color:var(--text-dim); margin-bottom:.45rem; font-weight:600; }
.form-field input,.form-field select,.form-field textarea{
  width:100%; padding:.85rem 1rem; border-radius:12px; background:rgba(255,255,255,.05);
  border:1px solid var(--glass-brd); color:var(--white); font-size:.96rem; font-family:inherit; transition:border-color .3s; }
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{ border-color:var(--blue-bright); outline:none; }
.form-field textarea{ min-height:120px; resize:vertical; }
.form-note{ font-size:.8rem; color:var(--text-faint); margin-top:.6rem; }

/* ---------- FAQ ---------- */
.faq-item{ border-bottom:1px solid var(--glass-brd); }
.faq-q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center;
  gap:1rem; padding:1.3rem 0; font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:var(--text); }
.faq-q .ic{ flex:none; width:28px; height:28px; border-radius:50%; border:1px solid var(--glass-brd);
  display:grid; place-items:center; transition:transform .35s var(--ease); color:var(--blue-bright); }
.faq-item.open .faq-q .ic{ transform:rotate(45deg); color:var(--blue-bright); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-a p{ padding-bottom:1.3rem; color:var(--text-dim); }

/* ---------- FOOTER ---------- */
.footer{ padding:4rem 0 2rem; border-top:1px solid var(--glass-brd); margin-top:2rem; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; margin-bottom:3rem; }
.footer h4{ font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--text-faint); margin-bottom:1rem; }
.footer a{ display:block; color:var(--text-dim); font-size:.92rem; padding:.32rem 0; transition:color .25s; }
.footer a:hover{ color:var(--blue-bright); }
.footer-bot{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
  padding-top:2rem; border-top:1px solid var(--glass-brd); color:var(--text-faint); font-size:.84rem; }

/* ---------- REVEAL ANIM ---------- */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* ---------- BADGES / PILLS ---------- */
.pill{ display:inline-flex; align-items:center; gap:.4rem; font-size:.78rem; font-weight:600;
  padding:.35rem .8rem; border-radius:100px; background:var(--glass-bg); border:1px solid var(--glass-brd); color:var(--text-dim); }
.pill.green{ color:var(--blue-bright); border-color:rgba(77,139,255,.32); }
.pill.blue{ color:var(--blue-bright); border-color:rgba(77,139,255,.32); }
.pill.pink{ color:var(--gold); border-color:rgba(201,162,75,.34); }

/* ---------- DIVIDER WORD ---------- */
.sovereign-band{ text-align:center; padding:clamp(3rem,7vw,6rem) 0; }
.sovereign-band .word{ font-family:var(--font-display); font-weight:800;
  font-size:clamp(2.2rem,7vw,5rem); letter-spacing:-.025em; line-height:1.1; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .g-4{ grid-template-columns:repeat(2,1fr); }
  .g-3{ grid-template-columns:repeat(2,1fr); }
  .split,.calc{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .nav.open .nav-links{ display:flex; flex-direction:column; position:absolute; top:72px; left:4vw; right:4vw;
    padding:1rem; border-radius:24px; background:rgba(10,19,32,.96); border:1px solid var(--glass-brd); }
  .nav.open .nav-links a{ width:100%; }
}
@media (max-width:620px){
  .g-2,.g-3,.g-4{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .hero-ctas{ flex-direction:column; } .hero-ctas .btn{ width:100%; justify-content:center; }
}


/* ========================= UPGRADE: hero-depth ========================= */

/* ============================================================
   HERO 2.0  ::  grounding, reflection, rim glow, letter depth
   CSS-only upgrade. Appendable as-is. Targets existing classes:
   .hero-sov .hero-bgword .hero-figwrap .hero-fig
   Later rules win on equal specificity, so this safely refines
   the original hero block above without editing it.
   ============================================================ */

/* New tokens (brand-derived, no off-palette hexes) ---------- */
:root{
  --shadow-blue: rgba(11,92,240,.5);            /* --blue at 50% */
  --glow-blue:   rgba(30,91,255,.55);           /* --blue-vivid */
  --hero-floor:  color-mix(in srgb, var(--blue) 38%, transparent);
  --hero-rim:    color-mix(in srgb, var(--blue-bright) 60%, transparent);
}

/* ---- Editorial spacing + scale -----------------------------
   Slightly more air up top, tighter bottom so the figure can
   meet a grounded floor. Keep min-height behavior intact. */
.hero-sov{
  padding: clamp(8rem, 12vw, 11rem) 0 0;   /* BIG-AIR top, floor handles bottom */
  gap: clamp(1.25rem, 3vw, 2.75rem);
  align-items: end;                         /* anchor copy + figure to a shared baseline */
}
.hero-copy{ align-self: center; }           /* copy stays optically centered */
.hero-copy h1{
  font-size: clamp(2.75rem, 6vw, 5.4rem);
  letter-spacing: -.02em;
  line-height: 1.05;
  margin: 1.15rem 0 1.35rem;
}

/* ---- Giant SOVEREIGN letters: depth + partial occlusion ----
   The word already paints at z-index 0 (behind figure + copy).
   We deepen it so it reads as architecture: a soft top-light,
   a touch more presence on the left (copy side), and a fade on
   the right where the figure stands so the letters appear to
   slip BEHIND the cutout rather than float flatly under it. */
.hero-bgword{ overflow: visible; }
.hero-bgword span{
  font-size: min(28vw, 26rem);
  letter-spacing: -.05em;
  opacity: 1;                               /* control falloff via gradient mask instead */
  -webkit-text-stroke: 1.6px color-mix(in srgb, var(--ice) 26%, transparent);
  /* faint inner fill so strokes catch light without becoming a surface */
  color: color-mix(in srgb, var(--blue-bright) 5%, transparent);
  /* depth shadow: letters sit on the back wall */
  text-shadow:
    0 1px 0   color-mix(in srgb, var(--white) 6%, transparent),
    0 24px 60px rgba(0,0,0,.45);
  /* occlusion: dense on the left, dissolving toward the figure
     (right) and the floor (bottom) so the cutout reads in front */
  -webkit-mask-image:
    linear-gradient(90deg,#000 0%, #000 40%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.18) 100%),
    linear-gradient(#000 0%, #000 70%, rgba(0,0,0,.25) 100%);
          mask-image:
    linear-gradient(90deg,#000 0%, #000 40%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.18) 100%),
    linear-gradient(#000 0%, #000 70%, rgba(0,0,0,.25) 100%);
  -webkit-mask-composite: source-in;
          mask-composite: intersect;
}

/* ---- Figure wrapper: floor + reflection + occlusion scrim --
   The wrapper carries the grounding furniture so the <img>
   itself is untouched (works with any transparent cutout).
   position:relative and the grid placement are re-asserted here
   so this block is self-contained: the absolutely positioned
   pseudo-elements always have a positioning context to anchor to. */
.hero-figwrap{
  position: relative;
  display: grid;
  place-items: end center;
  align-self: end;
  min-height: 64vh;
  padding-bottom: clamp(2.5rem, 5vw, 4.5rem);  /* room for the floor glow */
  isolation: isolate;                          /* keep blend/glow local */
}

/* (1) Soft gradient FLOOR: a luminous ellipse the figure stands on.
   Reads as a grounded shadow plus ambient blue bounce, not a hard edge. */
.hero-figwrap::before{
  content:"";
  position:absolute;
  left:50%; bottom: clamp(1.25rem, 3vw, 2.75rem);
  width: min(78%, 560px);
  height: clamp(60px, 10vw, 130px);
  transform: translateX(-50%);
  z-index: 0;                                  /* under the figure */
  pointer-events:none;
  background:
    radial-gradient(60% 100% at 50% 50%,
      rgba(0,0,0,.55) 0%, rgba(0,0,0,.30) 38%, transparent 72%),
    radial-gradient(72% 120% at 50% 40%,
      var(--hero-floor) 0%, transparent 70%);
  filter: blur(14px);
}

/* (2) REFLECTION footprint: a fainter, taller blue bloom rising from
   the contact point so the figure feels to sit on a glossy surface.
   Image-agnostic (no flipped copy needed), so the cutout can change. */
.hero-figwrap::after{
  content:"";
  position:absolute;
  left:50%; bottom: clamp(1.25rem, 3vw, 2.75rem);
  width: min(54%, 380px);
  height: clamp(90px, 16vw, 220px);
  transform: translateX(-50%);
  z-index: 0;
  pointer-events:none;
  background:
    linear-gradient(to top,
      var(--glow-blue) 0%,
      color-mix(in srgb, var(--blue) 30%, transparent) 28%,
      transparent 78%);
  opacity:.5;
  filter: blur(20px);
  -webkit-mask-image: linear-gradient(to top, #000 0%, transparent 90%);
          mask-image: linear-gradient(to top, #000 0%, transparent 90%);
}

/* ---- The figure itself: stronger blue rim glow plus soft base fade --
   Keep the upright stack, add layered blue rim plus grounded contact
   shadow. The bottom mask fades the cutout into its reflection. */
.hero-fig{
  position: relative;
  z-index: 1;                                  /* above floor + reflection */
  max-height: 86vh;
  filter:
    drop-shadow(0 0 28px var(--hero-rim))               /* tight blue rim */
    drop-shadow(0 0 70px var(--shadow-blue))            /* wide blue halo  */
    drop-shadow(0 34px 46px rgba(0,0,0,.6));            /* grounded contact */
  -webkit-mask-image: linear-gradient(#000 84%, rgba(0,0,0,.35) 95%, transparent 100%);
          mask-image: linear-gradient(#000 84%, rgba(0,0,0,.35) 95%, transparent 100%);
}

/* Photo fallback: do NOT inherit the cutout glow/mask, keep the framed card.
   (Re-asserted after our new .hero-fig rule so the fallback never fires wrong.) */
.hero-fig.is-photo{
  z-index: 1;
  filter: drop-shadow(0 24px 50px rgba(0,0,0,.5));
  -webkit-mask-image: none; mask-image: none;
}
/* When the figure is the framed photo fallback, soften the blue reflection
   so it does not bloom past a rectangular card edge. */
.hero-figwrap:has(.hero-fig.is-photo)::after{ opacity:.28; }

/* ---- Mobile: preserve the faint full-bleed background ghost ----
   When the figure becomes a 0.16-opacity backdrop, the floor and
   reflection furniture must vanish (no stray glows over text). */
@media (max-width:900px){
  .hero-sov{ padding-top: clamp(6.5rem, 16vw, 8rem); align-items:center; }
  .hero-figwrap{ padding-bottom:0; min-height:0; isolation:auto; }
  .hero-figwrap::before,
  .hero-figwrap::after{ display:none; }
  .hero-fig{
    filter: drop-shadow(0 0 60px var(--shadow-blue));
    -webkit-mask-image: none; mask-image: none;     /* keep the existing soft ghost */
  }
  /* let the giant word read as a clean background again on small screens */
  .hero-bgword span{
    font-size: 46vw;
    -webkit-mask-image: linear-gradient(#000 76%, transparent 100%);
            mask-image: linear-gradient(#000 76%, transparent 100%);
    -webkit-mask-composite: source-over; mask-composite: add;
  }
}

/* ---- Reduced motion: nothing animates here, but ensure the
   blur-heavy floor/reflection stay crisp and never flicker. */
@media (prefers-reduced-motion:reduce){
  .hero-figwrap::before,
  .hero-figwrap::after{ transition:none; }
}


/* ========================= UPGRADE: bento ========================= */

/* =====================================================================
   BENTO LAYOUT + SECTION RHYTHM  (append-only upgrade)
   Premium layout: 3-tier vertical rhythm, gold hairline delimiters,
   size-encoded bento grids, refined glass depth + hover.
   All values use existing tokens. No new hex unless tokenized below.
   Lime stays rare. Gold is hairlines only. Blue carries the brand.
   ===================================================================== */

/* ---- New tokens (only additions, no off-palette) ---- */
:root{
  --bento-gap:        16px;                       /* flat desktop bento gap (research pattern 5) */
  --shadow-blue:      rgba(11,92,240,.5);         /* lift shadow, exact --blue #0B5CF0 */
  --hairline-gold:    linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
  --hairline-gold-l:  linear-gradient(90deg,var(--gold),transparent);
}

/* ---------------------------------------------------------------------
   1. SECTION RHYTHM  ::  break the one-tempo scroll (research pattern 1)
   Apply ONE of these classes to a <section> to override the uniform pace.
   --------------------------------------------------------------------- */
.sec-tight   { padding-block: clamp(2rem, 4vw, 3rem); }
.sec-default { padding-block: clamp(4.5rem, 8vw, 7rem); }
.sec-big-air { padding-block: clamp(7rem, 12vw, 11rem); }

/* Trim the top when a section directly follows a full-bleed band so the
   air does not double up. */
.sec-air-top    { padding-top:    clamp(7rem, 12vw, 11rem); }
.sec-air-bottom { padding-bottom: clamp(7rem, 12vw, 11rem); }

/* ---- Spacing utilities  ::  purge inline margin-top:3rem + the stack scale ---- */
.mt-section { margin-top: clamp(2rem, 4vw, 3rem) !important; }
.stack-sm   { margin-top: .75rem  !important; }
.stack      { margin-top: 1.25rem !important; }
.stack-lg   { margin-top: 2rem    !important; }

/* Body measure cap as a utility (extend the .lead 62ch idea to any paragraph) */
.measure { max-width: 65ch; }
.measure-center { max-width: 65ch; margin-inline: auto; }

/* ---------------------------------------------------------------------
   2. GOLD HAIRLINE DELIMITERS  ::  the recurring premium device
   --------------------------------------------------------------------- */
/* 64px centered gold-to-transparent hairline that sits above an oversized
   headline in BIG-AIR moments. Drop <div class="air-divider"></div> in. */
.air-divider{
  height:1px; width:64px; margin:0 auto clamp(1rem,2vw,1.4rem);
  background:var(--hairline-gold-l);
}
.air-divider.center,
.center .air-divider{ background:var(--hairline-gold); }

/* Full-width gold hairline between two major sections. Place a single
   <div class="section-rule wrap"></div> between sections (or add
   .section-rule to a thin spacer). Stays inside --maxw with the figure. */
.section-rule{ height:1px; border:0; margin-block: clamp(1.5rem,4vw,3rem);
  background:var(--hairline-gold); opacity:.7; }
.section-rule.full{ width:100%; }

/* ---------------------------------------------------------------------
   3. BENTO GRID  ::  size encodes importance (research pattern 5 + 7)
   Replace a monotonous .grid.g-3 / .g-4 with .bento and let tiles span.
   Desktop: flat 16px gap, dense packing so spans fill cleanly.
   --------------------------------------------------------------------- */
.bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:minmax(min-content,1fr);   /* equal height but never clips taller tile copy */
  grid-auto-flow:dense;
  gap:var(--bento-gap);
  align-items:stretch;
}
.bento.cols-4{ grid-template-columns:repeat(4,1fr); }
.bento.cols-2{ grid-template-columns:repeat(2,1fr); }

/* Span utilities (apply to any direct child tile) */
.bento .span-2{ grid-column:span 2; }
.bento .span-3{ grid-column:span 3; }
.bento .row-2 { grid-row:span 2; }
.bento .tall  { grid-row:span 2; }

/* .feature = the 2x2 flagship (hero of its grid). Pairs span-2 + row-2. */
.bento .feature{
  grid-column:span 2;
  grid-row:span 2;
  display:flex; flex-direction:column; justify-content:center;
}

/* ---- Family tinting  ::  the grid teaches hierarchy without labels ----
   Flagship sits on the deepest surface, supporting on the mid surface;
   borders stay the --glass-brd hairline (no new border colors). */
.bento .feature,
.bento .tile--flagship{ background-color: var(--ink-3); }
.bento .tile--support { background-color: var(--ink-2); }

/* ---- Bento tile structure helpers (optional, for the outcomes bento) ---- */
.tile-metric{
  font-family:var(--font-display); font-weight:800; line-height:1;
  font-size:clamp(2.4rem,5vw,3.6rem);
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.tile--support .tile-metric{ font-size:clamp(1.8rem,3vw,2.4rem); font-weight:700; }
.tile-metric-label{ color:var(--text-dim); font-size:.92rem; margin-top:.45rem; }
.tile-line{ color:var(--text-dim); font-size:1rem; margin-top:.7rem; max-width:34ch; }
.tile--support .tile-line{ font-size:.88rem; }

/* At most ONE accent tile per bento may carry the rare lime endpoint.
   Add .tile--accent to that single tile (lime corner hairline only). */
.bento .tile--accent::after{
  content:""; position:absolute; top:0; right:0; width:38px; height:38px;
  border-top:1px solid var(--lime-bright); border-right:1px solid var(--lime-bright);
  border-top-right-radius:var(--radius); opacity:.55; pointer-events:none;
}

/* ---------------------------------------------------------------------
   4. GLASS 2.0 DEPTH + HOVER  ::  refined, matches global physics
   Opt-in via .glass-pro so it composes with the existing .glass rule.
   Lift -4px, hairline brightens to --blue-bright, no scale, no lime glow.
   --------------------------------------------------------------------- */
.glass-pro{
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
}
/* Directional alpha gradient for real thickness (lighter top-left to darker
   bottom-right) + faint brand-blue tint overlay, behind content. */
.glass-pro::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; z-index:0;
  background:
    linear-gradient(145deg, var(--glass-brd-hi) 0%, transparent 38%, transparent 70%, color-mix(in srgb, var(--blue-deep) 16%, transparent) 100%),
    color-mix(in srgb, var(--blue-deep) 10%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
}
.glass-pro > *{ position:relative; z-index:1; }

/* Refined lift: applies to bento tiles and any .glass.lift on this layer.
   Appended after the base rule, so this is the effective hover. */
.glass.lift{
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.glass.lift:hover{
  transform:translateY(-4px);
  border-color:var(--blue-bright);
  box-shadow:0 26px 56px -18px var(--shadow-blue);
}
.bento > .glass{ overflow:hidden; }
.bento > .glass.lift:hover{ transform:translateY(-4px); border-color:var(--blue-bright); }

/* ---------------------------------------------------------------------
   5. FULL-BLEED EDITORIAL MOMENT  ::  one figure/ground break
   Add .bleed to the Leak Map section's inner grid so it extends past
   --maxw for the single editorial moment. Body text stays capped.
   --------------------------------------------------------------------- */
.bleed{ width:min(1320px, 96vw); margin-inline:auto; }

/* ---------------------------------------------------------------------
   6. RESPONSIVE  ::  bento reflow (research pattern 5 + 7)
   2x2 flagship collapses to full-width first at <980px,
   1x1 reflow 2-up then 1-up.
   --------------------------------------------------------------------- */
@media (max-width:980px){
  .bento{ grid-template-columns:repeat(2,1fr); }
  .bento.cols-4{ grid-template-columns:repeat(2,1fr); }
  .bento .feature,
  .bento .span-2,
  .bento .span-3{ grid-column:1 / -1; }
  .bento .feature{ grid-row:auto; }
  .bento .tall,
  .bento .row-2{ grid-row:auto; }
}
@media (max-width:620px){
  .bento,
  .bento.cols-2,
  .bento.cols-4{ grid-template-columns:1fr; }
  .bento .feature,
  .bento .span-2,
  .bento .span-3,
  .bento .tile{ grid-column:1 / -1; }
}

/* ---------------------------------------------------------------------
   7. REDUCED MOTION  ::  designed parallel state, never broken layout
   --------------------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .glass.lift,
  .bento > .glass.lift{ transition:border-color .01ms; }
  .glass.lift:hover,
  .bento > .glass.lift:hover{ transform:none; }
}


/* ========================= UPGRADE: funnel-viz ========================= */
/* =====================================================================
   LEAK FUNNEL VISUAL  ::  signature interactive hero for #funnel
   Scoped under .leak-funnel. Blue carries the brand; lime is the leak
   signal only (the worst-stage marker, the escaping streams, and one
   counter underline). Gold is a thin hairline delimiter. No dashes.
   ===================================================================== */
.leak-funnel{
  position:relative;
  margin:0 0 clamp(2rem,4vw,3rem);
  /* full-bleed editorial moment beyond --maxw, re-centered inside .wrap */
  width:100vw;
  margin-left:calc(50% - 50vw);
  padding:clamp(1.6rem,4vw,3rem) 0 clamp(1rem,2.5vw,1.6rem);
}
.leak-funnel__inner{
  width:min(var(--maxw),92vw);
  margin-inline:auto;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(1.5rem,4vw,3rem);
  align-items:center;
}

/* scoped visually-hidden utility for the polite live announcement */
.lf-sr{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ---- top gold hairline delimiter (premium recurring device) ---- */
.leak-funnel__rule{
  height:1px; width:64px; margin:0 auto clamp(1rem,2vw,1.4rem);
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* ---- stage of the figure: the SVG funnel ---- */
.leak-funnel__fig{
  position:relative;
  aspect-ratio:1 / 1;
  width:100%;
  max-width:520px;
  margin-inline:auto;
}
.leak-funnel__svg{ width:100%; height:100%; display:block; overflow:visible; }

/* the descending money column inside the spine */
.lf-flow{
  fill:none;
  stroke:url(#lfMoneyGrad);
  stroke-width:3;
  stroke-linecap:round;
  stroke-dasharray:7 13;
  opacity:.9;
  animation:lf-flow-drift 1.4s linear infinite;
}
@keyframes lf-flow-drift{ to{ stroke-dashoffset:-40; } }

/* funnel body walls */
.lf-wall{ fill:url(#lfWallGrad); stroke:color-mix(in srgb, var(--blue) 50%, transparent); stroke-width:1.25; }
.lf-wall-edge{ fill:none; stroke:var(--ice); stroke-width:1.5; opacity:.55; }

/* stage divider hairlines across the funnel */
.lf-divider{ stroke:var(--glass-brd); stroke-width:1; }
.lf-divider.is-break{ stroke:var(--blue-bright); stroke-width:1.5; opacity:.8; }

/* numbered stage nodes on the spine */
.lf-node{ fill:var(--ink-3); stroke:var(--blue-bright); stroke-width:1.5; }
.lf-node.is-break{ stroke:var(--lime); fill:color-mix(in srgb, var(--ink-3) 80%, var(--blue)); }
.lf-node-no{ font-family:var(--font-display); font-weight:800; font-size:13px; fill:var(--white); text-anchor:middle; dominant-baseline:central; }

/* output spout glow at the bottom (recovered revenue) */
.lf-spout{ fill:url(#lfMoneyGrad); }
.lf-spout-ring{ fill:none; stroke:var(--blue-bright); stroke-width:1.5; opacity:.5; }

/* lime leak streams escaping at broken stages (the signal) */
.lf-leak{
  fill:none;
  stroke:var(--lime);
  stroke-width:2.25;
  stroke-linecap:round;
  filter:drop-shadow(0 0 5px rgba(194,247,80,.45));
  stroke-dasharray:5 10;
  animation:lf-leak-run 1s linear infinite;
}
.lf-leak.s2{ animation-duration:1.25s; }
.lf-leak.s3{ animation-duration:.85s; }
@keyframes lf-leak-run{ to{ stroke-dashoffset:-30; } }

/* drip droplets that JS animates along leak paths (transform set inline) */
.lf-drip{ fill:var(--lime-bright); filter:drop-shadow(0 0 4px rgba(206,255,28,.6)); }

/* money tokens raining in at the top (JS animates cy/opacity inline) */
.lf-token{ fill:var(--ice); opacity:0; }
.lf-token.is-bright{ fill:var(--blue-bright); }

/* ---- copy + counter column ---- */
.leak-funnel__copy .lf-eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-body); font-weight:600;
  font-size:.76rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ice);
}
.leak-funnel__copy .lf-eyebrow::before{
  content:""; width:7px; height:7px; border-radius:50%;
  background:var(--blue-bright); box-shadow:0 0 12px var(--glow-blue, rgba(30,91,255,.55));
}
.leak-funnel__title{
  font-family:var(--font-display); font-weight:800; letter-spacing:-.02em;
  line-height:1.08; font-size:clamp(1.5rem,2.6vw,2.1rem);
  margin:.9rem 0 .5rem;
}
.leak-funnel__title .lf-leakword{
  background:var(--grad-lime-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.leak-funnel__sub{
  color:var(--text-dim); font-size:clamp(.95rem,1.4vw,1.05rem);
  max-width:46ch; margin-bottom:clamp(1.2rem,2.5vw,1.6rem);
}

/* the live recoverable-revenue counter, in a Glass 2.0 readout */
.lf-readout{
  position:relative; overflow:hidden;
  background:linear-gradient(140deg, var(--glass-brd-hi), transparent 55%), var(--glass-bg);
  border:1px solid var(--glass-brd);
  border-radius:var(--radius-sm);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  padding:clamp(1.1rem,2.4vw,1.5rem);
  box-shadow:var(--glass-shadow);
}
.lf-readout::before{
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
  background:linear-gradient(140deg, rgba(9,38,118,.10), transparent 60%);
}
.lf-readout__label{
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--text-dim); font-weight:600;
}
.lf-readout__num{
  font-family:var(--font-display); font-weight:800; line-height:1;
  font-size:clamp(2.2rem,5vw,3.2rem);
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
  margin:.35rem 0 .15rem;
  position:relative; display:inline-block;
}
/* the single permitted lime accent: a thin underline beneath the blue number */
.lf-readout__num::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:var(--grad-accent); border-radius:2px;
  transform:scaleX(0); transform-origin:left; transition:transform .7s var(--ease);
}
.lf-readout.is-live .lf-readout__num::after{ transform:scaleX(1); }
.lf-readout__note{ font-size:.82rem; color:var(--text-dim); margin-top:.6rem; }
.lf-readout__cta{ margin-top:1rem; }

/* legend chips under the counter */
.lf-legend{ display:flex; gap:1.1rem; flex-wrap:wrap; margin-top:1rem; }
.lf-legend span{ display:inline-flex; align-items:center; gap:.45rem; font-size:.78rem; color:var(--text-dim); }
.lf-legend i{ width:10px; height:10px; border-radius:2px; flex:none; }
.lf-legend i.in{ background:var(--ice); }
.lf-legend i.leak{ background:var(--lime); }
.lf-legend i.out{ background:var(--blue-bright); }

/* ---- responsive: stack figure above copy ---- */
@media (max-width:980px){
  .leak-funnel__inner{ grid-template-columns:1fr; gap:clamp(1.4rem,4vw,2.2rem); }
  .leak-funnel__fig{ max-width:380px; order:-1; }
  .leak-funnel__copy{ text-align:center; }
  .leak-funnel__copy .lf-eyebrow{ justify-content:center; }
  .leak-funnel__sub{ margin-inline:auto; }
  .lf-legend{ justify-content:center; }
  .lf-readout{ text-align:center; }
  .lf-readout__num::after{ left:50%; right:auto; width:60%; transform:translateX(-50%) scaleX(0); transform-origin:center; }
  .lf-readout.is-live .lf-readout__num::after{ transform:translateX(-50%) scaleX(1); }
}
@media (max-width:520px){
  .leak-funnel__fig{ max-width:300px; }
}

/* ---- reduced motion: designed parallel state, snap to final, no rAF drip ---- */
@media (prefers-reduced-motion:reduce){
  .lf-flow,.lf-leak{ animation:none; }
  .lf-token{ opacity:.7; }
  .lf-drip{ opacity:.9; }
  .lf-readout__num::after{ transition:none; }
}


/* ========================= UPGRADE: proof ========================= */

/* =====================================================================
   PROOF + TRUST SECTION  (additive, inserted after .marquee)
   Operators-we-work-inside strip + metric highlights + Leak Map readout
   Blue carries the brand. Gold = hairlines only. Lime = one endpoint dot.
   ===================================================================== */
.proof-strip{ padding:clamp(4.5rem,8vw,7rem) 0; }
.proof-strip .ps-head{ text-align:center; max-width:60ch; margin-inline:auto; }
.proof-strip .ps-head .lead{ margin-inline:auto; margin-top:1rem; }

/* ---- honest operators logo / credibility row ---- */
.ps-honest{ display:block; text-align:center; font-family:var(--font-body); font-weight:600;
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim);
  margin-top:clamp(2rem,4vw,3rem); }
.logo-chips{ display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem;
  margin-top:clamp(1.25rem,2.5vw,1.75rem); }
.logo-chip{ display:inline-flex; align-items:center; gap:.55rem;
  padding:.7rem 1.15rem; border-radius:14px;
  background:var(--ink-2); border:1px solid var(--glass-brd);
  backdrop-filter:blur(14px) saturate(150%); -webkit-backdrop-filter:blur(14px) saturate(150%);
  font-family:var(--font-display); font-weight:600; font-size:.98rem; color:var(--white);
  transition:transform .4s var(--ease), border-color .4s var(--ease); }
.logo-chip:hover{ transform:translateY(-4px); border-color:var(--blue-bright); }
.logo-chip .lc-mark{ width:24px; height:24px; border-radius:7px; flex:none;
  display:grid; place-items:center; font-size:.7rem; font-weight:800; letter-spacing:.02em;
  color:var(--ice); background:rgba(11,92,240,.18);
  border:1px solid var(--glass-brd-hi); /* fallback for no color-mix support */
  border:1px solid color-mix(in srgb,var(--blue) 50%,transparent); }
.logo-chip.is-slot{ color:var(--text-dim); border-style:dashed; }
.logo-chip.is-slot .lc-mark{ color:var(--text-faint); background:transparent; }

/* ---- metric highlight row (bento, family-tinted) ---- */
.metric-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  margin-top:clamp(2.5rem,5vw,3.5rem); }
.metric-tile{ position:relative; padding:clamp(1.4rem,2.4vw,1.9rem);
  border-radius:var(--radius); border:1px solid var(--glass-brd);
  background:var(--ink-2); backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%); overflow:hidden;
  transition:transform .4s var(--ease), border-color .4s var(--ease); }
.metric-tile::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg,var(--glass-brd-hi),transparent 42%,transparent 70%,color-mix(in srgb,var(--blue) 50%,transparent));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.metric-tile::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,.05),transparent 60%); pointer-events:none; }
.metric-tile:hover{ transform:translateY(-4px); border-color:var(--blue-bright); }
.metric-tile .mt-num{ font-family:var(--font-display); font-weight:700; line-height:1;
  font-size:clamp(2rem,3.4vw,2.9rem);
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.metric-tile .mt-lbl{ margin-top:.55rem; font-size:.82rem; color:var(--text-dim); font-weight:500; line-height:1.45; }
.metric-tile .mt-foot{ margin-top:.9rem; font-size:.74rem; color:var(--text-dim);
  padding-top:.7rem; border-top:1px solid var(--glass-brd); }

/* ---- "what you receive" : Revenue Leak Map readout (pure CSS mock) ---- */
.receive-wrap{ margin-top:clamp(4.5rem,8vw,7rem); display:grid;
  grid-template-columns:.82fr 1.18fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.goldrule--left{ margin:.4rem 0 0; }
.receive-copy .goldrule{ margin-bottom:1.1rem; }
.receive-copy h3{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.6rem,3vw,2.2rem);
  letter-spacing:-.02em; line-height:1.1; }
.receive-copy p{ color:var(--text-dim); font-size:1rem; max-width:48ch; margin-top:1rem; }
.receive-list{ display:grid; gap:.65rem; margin-top:1.4rem; }
.receive-list li{ position:relative; padding-left:1.7rem; color:var(--text-dim); font-size:.95rem; }
.receive-list li::before{ content:""; position:absolute; left:0; top:.5em; width:9px; height:9px;
  border-radius:2px; background:var(--blue-bright); transform:rotate(45deg); }

/* the readout "document" itself, flagship surface */
.leakmap{ position:relative; border-radius:var(--radius); overflow:hidden;
  background:var(--ink-3); border:1px solid var(--glass-brd);
  box-shadow:var(--glass-shadow); backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%); }
.leakmap::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg,var(--glass-brd-hi),transparent 45%,transparent 70%,color-mix(in srgb,var(--blue) 50%,transparent));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; z-index:2; }
.leakmap-bar{ display:flex; align-items:center; justify-content:space-between;
  padding:.95rem 1.3rem; border-bottom:1px solid var(--glass-brd);
  background:linear-gradient(180deg,rgba(11,92,240,.10),transparent); }
.leakmap-bar .lm-title{ display:flex; align-items:center; gap:.6rem;
  font-family:var(--font-display); font-weight:700; font-size:.95rem; color:var(--white); }
.leakmap-bar .lm-dot{ width:9px; height:9px; border-radius:50%; background:var(--blue-bright);
  box-shadow:0 0 12px var(--glow-blue,rgba(30,91,255,.55)); }
.leakmap-bar .lm-meta{ font-size:.72rem; color:var(--text-dim); letter-spacing:.04em; }
.lm-goldline{ height:1px; width:100%; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:.6; }
.leakmap-body{ padding:clamp(1.2rem,2.4vw,1.7rem); }
.lm-summary{ display:flex; align-items:flex-end; justify-content:space-between; gap:1rem;
  padding-bottom:1.1rem; margin-bottom:1.2rem; border-bottom:1px solid var(--glass-brd); }
.lm-summary .lm-big{ font-family:var(--font-display); font-weight:700; line-height:1;
  font-size:clamp(1.9rem,4vw,2.7rem);
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.lm-summary .lm-cap{ font-size:.72rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.14em; margin-bottom:.35rem; }
.lm-summary .lm-side{ text-align:right; }
.lm-summary .lm-side .v{ font-family:var(--font-display); font-weight:700; font-size:1.15rem; color:var(--blue-bright); }
.lm-summary .lm-side .k{ font-size:.7rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.1em; }

/* the draining pipeline rows */
.lm-rows{ display:grid; gap:.7rem; }
.lm-row{ display:grid; grid-template-columns:1.5rem 7.2rem 1fr auto; align-items:center; gap:.7rem; }
.lm-row .lm-no{ font-family:var(--font-display); font-weight:700; font-size:.78rem; color:var(--text-faint); }
.lm-row .lm-name{ font-size:.82rem; color:var(--white); font-weight:500; }
.lm-track{ position:relative; height:9px; border-radius:100px; background:rgba(255,255,255,.06); overflow:hidden; }
.lm-fill{ position:absolute; inset:0; border-radius:100px; width:var(--w,100%);
  background:linear-gradient(90deg,var(--blue),var(--ice)); }
.lm-row .lm-pct{ font-family:var(--font-display); font-weight:600; font-size:.78rem; color:var(--text-dim); min-width:2.6rem; text-align:right; }
/* one designated leak point: gold flag, no fill, plus the single rare lime endpoint dot */
.lm-row.is-leak .lm-name{ color:var(--white); }
.lm-row.is-leak .lm-track{ box-shadow:inset 0 0 0 1px var(--gold); }
.lm-row.is-leak .lm-fill{ background:linear-gradient(90deg,var(--blue),var(--ice)); }
.lm-row.is-leak .lm-fill::after{ content:""; position:absolute; right:-3px; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:50%; background:var(--lime);
  box-shadow:0 0 10px rgba(194,247,80,.7); }
.lm-leakflag{ display:inline-flex; align-items:center; gap:.4rem; margin-top:1.1rem;
  font-size:.74rem; color:var(--text-dim); }
.lm-leakflag b{ color:var(--white); font-weight:700; }
.lm-leakflag .lf-tick{ width:8px; height:8px; border-radius:50%; background:var(--lime);
  box-shadow:0 0 8px rgba(194,247,80,.6); flex:none; }

/* sparkline footer inside the readout */
.lm-spark{ margin-top:1.3rem; padding-top:1.2rem; border-top:1px solid var(--glass-brd);
  display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.lm-spark .ls-label{ font-size:.74rem; color:var(--text-dim); }
.lm-spark svg{ width:128px; height:34px; flex:none; }
.lm-spark .ls-line{ fill:none; stroke:var(--ice); stroke-width:2; stroke-linecap:round;
  stroke-dasharray:240; stroke-dashoffset:240; }
.proof-strip .reveal.in .lm-spark .ls-line{ stroke-dashoffset:0; transition:stroke-dashoffset 1.1s var(--ease) .25s; }
.lm-spark .ls-dot{ fill:var(--blue-bright); }

@media (prefers-reduced-motion:reduce){
  .logo-chip,.metric-tile{ transition:none; }
  .proof-strip .lm-spark .ls-line{ stroke-dashoffset:0; transition:none; }
}

/* ---- responsive ---- */
@media (max-width:980px){
  .metric-row{ grid-template-columns:repeat(2,1fr); }
  .receive-wrap{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  .metric-row{ grid-template-columns:1fr; }
  .lm-row{ grid-template-columns:1.3rem 5.6rem 1fr auto; gap:.5rem; }
  .lm-row .lm-name{ font-size:.76rem; }
}


/* ========================= UPGRADE: motion ========================= */

/* =====================================================================
   MOTION + MICRO-INTERACTIONS  ::  append-only, brand-locked
   Count-up proof, staggered reveals, magnetic CTA, scroll cue,
   scroll progress bar. All obeys prefers-reduced-motion as a
   designed parallel state (snap to final, opacity-only, no drift).
   ===================================================================== */

/* ---------- SCROLL PROGRESS BAR (thin, blue, top of viewport) ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:2px; z-index:200;
  transform-origin:0 50%; transform:scaleX(0);
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-vivid) 55%, var(--ice) 100%);
  box-shadow:0 0 10px rgba(11,92,240,.55);
  will-change:transform; pointer-events:none;
}

/* ---------- COUNT-UP NUMBERS (tabular, no layout shift mid-count) ---------- */
.num, .hero-proof .num, #leakNum{
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1;
}
/* Faint pre-count state so the value does not pop before it animates in */
.counting{ opacity:.92; }

/* ---------- STAGGERED REVEALS (retimed: y 24px, 0.7s, var(--ease)) ---------- */
.reveal{ transition:opacity .7s var(--ease), transform .7s var(--ease); transform:translateY(24px); }
.reveal.in{ transform:none; }
/* Tighter, evenly spaced stagger step (0.08s) reaffirmed for new motion timing */
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
.reveal.d5{ transition-delay:.40s; } .reveal.d6{ transition-delay:.48s; }

/* ---------- HOVER PHYSICS (restrained lift -4px, hairline brightens) ---------- */
.glass.lift{ transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease); }
.glass.lift:hover{ transform:translateY(-4px); border-color:var(--blue-bright);
  box-shadow:0 24px 56px -18px rgba(11,92,240,.5); }

/* Button lift polish, retimed to the 0.4s hover grammar */
.btn{ transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease), background-color .4s var(--ease); }

/* ---------- THE ONE LOUD INTERACTION: magnetic Diagnostic CTA ---------- */
/* Apply class .btn-magnetic to the single primary CTA only (the hero       */
/* .btn-accent "Get Your Free Leakage Audit" button).                       */
/* JS writes --mx / --my (max 6px) toward the cursor; lime sheen wipes in.   */
/* Specificity note: the existing .btn-accent:hover / .btn-primary:hover     */
/* set transform:translateY(-3px) at (0,2,0). We must MATCH OR BEAT that,    */
/* so all magnetic transforms are scoped to .btn.btn-magnetic and the hover  */
/* offset is FOLDED TOGETHER WITH the lift so both survive the cascade.      */
.btn.btn-magnetic{
  --mx:0px; --my:0px;
  transform:translate(var(--mx), var(--my));
  transition:transform .25s var(--ease), box-shadow .4s var(--ease), background-color .4s var(--ease);
  overflow:hidden; z-index:0;
}
/* Magnetic offset PLUS the brand lift, combined so .btn-accent:hover cannot
   clobber the translate. When JS is off or --mx/--my are 0, this is just the
   normal -3px lift, identical to the rest of the buttons. */
.btn.btn-magnetic:hover,
.btn.btn-magnetic:focus-visible{
  transform:translate(var(--mx), calc(var(--my) - 3px));
}
.btn-magnetic::after{
  content:""; position:absolute; inset:0; z-index:-1; border-radius:inherit;
  background:var(--grad-accent); opacity:0;
  transform:translateX(-101%);
  transition:transform .45s var(--ease), opacity .45s var(--ease);
}
.btn-magnetic:hover::after,
.btn-magnetic:focus-visible::after{ transform:translateX(0); opacity:1; }
/* Keep readable dark text over the lime wipe regardless of which button
   variant carries .btn-magnetic (accent is already ink-2; primary needs it). */
.btn-magnetic.btn-primary:hover,
.btn-magnetic.btn-primary:focus-visible,
.btn-magnetic.btn-accent:hover,
.btn-magnetic.btn-accent:focus-visible{ color:var(--ink-2); }
.btn-magnetic:hover{ box-shadow:0 20px 48px -12px rgba(194,247,80,.45); }
/* Keep the label and arrow glyph above the lime wipe */
.btn-magnetic > *{ position:relative; z-index:1; }

/* ---------- ANIMATED SCROLL CUE (hero) ---------- */
/* Add <a class="scroll-cue" href="#audience" aria-label="Scroll to explore">  */
/*   <span class="scroll-cue-mouse"><span class="scroll-cue-wheel"></span></span>*/
/*   <span class="scroll-cue-label">Explore</span></a>  inside .hero-copy        */
.scroll-cue{
  position:absolute; left:50%; bottom:clamp(1.2rem,3vw,2.4rem); transform:translateX(-50%);
  display:inline-flex; flex-direction:column; align-items:center; gap:.55rem; z-index:3;
  color:var(--text-dim); transition:color .3s var(--ease), opacity .4s var(--ease);
}
.scroll-cue:hover{ color:var(--white); }
.scroll-cue-mouse{
  width:24px; height:38px; border-radius:14px; border:1.5px solid var(--glass-brd-hi);
  display:grid; justify-items:center; padding-top:7px; background:var(--glass-bg);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.scroll-cue-wheel{
  width:3px; height:7px; border-radius:3px; background:var(--ice);
  animation:scrollWheel 1.9s var(--ease) infinite;
}
.scroll-cue-label{
  font-family:var(--font-body); font-weight:600; font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--text-dim);
}
@keyframes scrollWheel{
  0%{ transform:translateY(0); opacity:0; }
  30%{ opacity:1; }
  60%{ transform:translateY(9px); opacity:0; }
  100%{ transform:translateY(9px); opacity:0; }
}
@media(max-width:900px){ .scroll-cue{ display:none; } }

/* ---------- HERO SIGNATURE HAIRLINE SWEEP (once, under h1) ---------- */
/* Optional: add <span class="hero-hairline" aria-hidden="true"></span> after hero h1 */
.hero-hairline{
  display:block; height:1px; width:min(420px,72%); margin:1.1rem 0 0;
  background:linear-gradient(90deg, var(--gold), transparent);
  clip-path:inset(0 100% 0 0);
  transition:clip-path .6s var(--ease);
}
.hero-hairline.in{ clip-path:inset(0 0 0 0); }
@media(max-width:900px){ .hero-hairline{ margin-inline:auto; } }

/* ---------- REDUCED MOTION: designed parallel state ---------- */
/* The base stylesheet only reduces .bg-orb and html scroll-behavior, so this
   block also supplies the missing reduced-motion fallback for .reveal. */
@media (prefers-reduced-motion:reduce){
  .scroll-progress{ display:none; }
  .reveal{ transition:opacity .4s ease; transform:none; }
  .reveal.in{ transform:none; }
  .glass.lift{ transition:border-color .3s ease; }
  .glass.lift:hover{ transform:none; box-shadow:var(--glass-shadow); }
  .btn.btn-magnetic{ transform:none; }
  .btn.btn-magnetic:hover,
  .btn.btn-magnetic:focus-visible{ transform:none; }
  .btn-magnetic::after{ transition:opacity .25s ease; transform:none; }
  .btn-magnetic:hover::after,
  .btn-magnetic:focus-visible::after{ transform:none; }
  .scroll-cue-wheel{ animation:none; }
  .hero-hairline{ transition:none; clip-path:inset(0 0 0 0); }
  .counting{ opacity:1; }
}


/* ========================= UPGRADE: polish ========================= */
/* =====================================================================
   GLOBAL POLISH APPEND  ::  tokens, rhythm, focus, 404, offer note
   Appendable to styles.css as-is. Additive only. Existing vars untouched.
   No em or en dashes anywhere. Lime stays rare. Gold is hairlines only.
   ===================================================================== */

:root{
  /* New brand-true blue tokens (replace the off-palette violet casts) */
  --shadow-blue: rgba(11,92,240,.5);
  --glow-blue:   rgba(30,91,255,.55);
  --glass-edge:  color-mix(in srgb, var(--blue) 50%, transparent);

  /* 3-tier vertical rhythm so the scroll stops reading one-tempo */
  --pad-tight:   clamp(2rem, 4vw, 3rem);
  --pad-section: clamp(4.5rem, 8vw, 7rem);
  --pad-air:     clamp(7rem, 12vw, 11rem);

  /* Stack scale (kills inline margin-top:3rem repeats) */
  --stack-sm: .75rem;
  --stack:    1.25rem;
  --stack-lg: 2rem;

  /* Bento + card-title ramp */
  --bento-gap: 16px;
  --card-title-lg: 1.35rem;
  --card-title:    1.15rem;
}

/* ---------- SPACING UTILITIES (replace inline margin-top:3rem etc) ---------- */
.mt-section{ margin-top: clamp(2rem, 4vw, 3rem); }
.stack-sm > * + *{ margin-top: var(--stack-sm); }
.stack    > * + *{ margin-top: var(--stack); }
.stack-lg > * + *{ margin-top: var(--stack-lg); }

/* Section rhythm overrides. Apply via class on <section>/<header>. */
.pad-tight{ padding-block: var(--pad-tight) !important; }
.pad-section{ padding-block: var(--pad-section) !important; }
.pad-air{ padding-block: var(--pad-air) !important; }

/* The recurring premium delimiter for BIG-AIR moments.
   64px centered gold-to-transparent hairline above an oversized headline. */
.air-rule{ height:1px; width:64px; margin:0 auto clamp(1.25rem,3vw,2rem);
  background:linear-gradient(90deg, transparent, var(--gold), transparent); }

/* Body copy never exceeds 65ch. Utility, not inline. */
.measure{ max-width:65ch; }
.center .measure{ margin-inline:auto; }

/* ---------- FOCUS STATES (a11y hardening, no layout shift) ---------- */
/* NOTE: the base :focus-visible rule already exists earlier in this file.
   We only add the element-specific enhancements here, no duplicate base rule. */
.btn:focus-visible{ outline:2px solid var(--blue-bright); outline-offset:4px; border-radius:100px; }
.nav-toggle:focus-visible,
input[type=range]:focus-visible{ outline:2px solid var(--blue-bright); outline-offset:3px; }
input[type=range]:focus-visible::-webkit-slider-thumb{ box-shadow:0 0 0 5px var(--glow-blue); }
a:focus-visible{ outline:2px solid var(--blue-bright); outline-offset:3px; border-radius:4px; }

/* ---------- OFFER NOTE (under the Book heading) ---------- */
.offer-note{ display:inline-flex; align-items:center; gap:.6rem; flex-wrap:wrap;
  justify-content:center; margin-top:.9rem; padding:.55rem 1.1rem; border-radius:100px;
  background:var(--glass-bg); border:1px solid var(--glass-brd);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  font-size:.9rem; color:var(--text-dim); font-weight:600; }
.offer-note .price{ font-family:var(--font-display); font-weight:700; color:var(--white); }
.offer-note .price b{ background:var(--grad-text); -webkit-background-clip:text;
  background-clip:text; color:transparent; }
.offer-note .rule{ width:1px; height:1.05em; background:var(--gold); opacity:.7; display:inline-block; }
.offer-note .muted{ color:var(--text-dim); font-weight:500; }

/* ---------- 404 PAGE (shares the design system; lives in 404.html) ---------- */
.err-wrap{ min-height:100svh; display:grid; place-items:center; text-align:center;
  padding:clamp(6rem,12vw,9rem) 6vw; position:relative; }
.err-code{ font-family:var(--font-display); font-weight:800; line-height:.9;
  font-size:clamp(5rem,22vw,13rem); letter-spacing:-.04em;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.err-card{ width:min(640px,100%); }
.err-card h1{ font-size:clamp(1.6rem,4vw,2.6rem); margin:.4rem 0 .9rem; }
.err-card .lead{ margin-inline:auto; }
.err-ctas{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; margin-top:1.8rem; }
.err-links{ margin-top:1.6rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap;
  font-size:.9rem; }
.err-links a{ color:var(--text-dim); border-bottom:1px solid transparent; transition:color .3s var(--ease), border-color .3s var(--ease); }
.err-links a:hover{ color:var(--blue-bright); border-color:var(--blue-bright); }
@media (max-width:620px){ .err-ctas .btn{ width:100%; justify-content:center; } }

/* ========================= UPGRADE: pricing tiles ========================= */
.tile-price{ font-family:var(--font-display); font-weight:800; font-size:2rem; margin:.5rem 0 .7rem;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.tile-price span{ font-size:1rem; font-weight:600; color:var(--text-faint); -webkit-text-fill-color:var(--text-faint); }
.addon-card{ display:flex; flex-direction:column; gap:.3rem; }
.addon-card .ac-price{ font-family:var(--font-display); font-weight:700; color:var(--blue-bright); font-size:1.05rem; }
.steps{ counter-reset:step; display:grid; gap:.7rem; margin-top:.4rem; }
.steps li{ list-style:none; position:relative; padding-left:2.2rem; color:var(--text-dim); font-size:.92rem; }
.steps li::before{ counter-increment:step; content:counter(step); position:absolute; left:0; top:-.1rem;
  width:1.5rem; height:1.5rem; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display);
  font-size:.78rem; font-weight:700; color:var(--blue-bright); border:1px solid var(--glass-brd); background:var(--glass-bg); }
