@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@500;600;700;800&family=Geist:wght@400;500;600;700&display=swap');
/* ============================================================
   BriteBase, britebase.ca
   Premium enterprise stylesheet · static · no build step
   Type: Hanken Grotesk (headings) + Geist (body)
   Geist replaces Inter to step off the SaaS training-data default.
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --navy:#0B1733;
  --navy-2:#14213F;
  --deep:#06070F;
  /* Tasteful navy blue family. Replaced the previous purple set so the
     palette stays within the navy family — primary --navy stays dark, the
     accent family below sits in deep saturated blue territory. All pairings
     verified ≥4.5:1 contrast against white. */
  --purple:#1E40AF;
  --purple-2:#2563EB;
  --purple-dk:#1E3A8A;
  --soft:#93C5FD;
  --ink:#0B1733;
  --slate:#4F576E;
  --slate-2:#858CA3;
  --light:#EEF0F8;
  --tint:#F6F6FB;
  --line:#E6E7F1;
  --line-2:#EFEFF6;
  --ondark:#AAB1C9;
  --ondark-2:#7E86A2;
  --green:#1F9D6B;
  --red:#D1493E;
  --amber:#B5841A;
  --fh:'Hanken Grotesk','Liberation Sans',system-ui,sans-serif;
  --fb:'Geist','Inter','Liberation Sans',-apple-system,system-ui,sans-serif;
  --sh-sm:0 2px 10px -4px rgba(11,23,51,.14);
  --sh:0 22px 50px -30px rgba(11,23,51,.42);
  --sh-lg:0 40px 90px -38px rgba(11,23,51,.55);
  --grad:linear-gradient(120deg,var(--purple),var(--purple-2) 55%,var(--soft));
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);color:var(--slate);background:#fff;line-height:1.62;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:16px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
strong{color:var(--ink);font-weight:600}
::selection{background:rgba(30,64,175,.18)}

h1,h2,h3,h4{font-family:var(--fh);color:var(--ink);line-height:1.13;font-weight:700;
  letter-spacing:-.022em}

.wrap{max-width:1280px;margin:0 auto;padding:0 26px}
.narrow{max-width:820px;margin:0 auto}
/* Purple-accent emphasis on short phrases inside larger headings. Renamed
   from .grad-txt (which implied gradient text, banned by the design laws). */
.accent,.grad-txt{color:var(--purple)}

.eyebrow{font-family:var(--fh);font-weight:600;font-size:12.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--purple);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--purple);display:inline-block}
.eyebrow.on-dark{color:var(--soft)}
.eyebrow.on-dark::before{background:var(--soft)}
.eyebrow.center{justify-content:center}

/* ---------- Grid texture (carried from britebase.ca) ---------- */
.gridtex{position:relative}
.gridtex>*{position:relative;z-index:1}
.gridtex::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(to right,rgba(255,255,255,.055) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(ellipse 78% 74% at 50% 4%,#000 32%,transparent 78%);
  mask-image:radial-gradient(ellipse 78% 74% at 50% 4%,#000 32%,transparent 78%)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--fh);font-weight:600;font-size:15px;padding:15px 28px;border-radius:11px;
  border:0;cursor:pointer;text-decoration:none;white-space:nowrap;letter-spacing:-.005em;
  min-height:44px;
  transition:transform .15s ease,background .15s ease,box-shadow .15s ease,color .15s,border-color .15s}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--purple);color:#fff;
  box-shadow:0 14px 30px -12px rgba(30,64,175,.65)}
.btn-primary:hover{background:var(--purple-dk);transform:translateY(-2px);
  box-shadow:0 18px 38px -12px rgba(30,64,175,.75)}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(0,0,0,.55)}
/* Outline button reads as button: 2px navy border + navy text by default,
   tinted background on hover. Pale gray border (var(--line)) was getting
   eaten by light hero backgrounds. */
.btn-outline{background:transparent;color:var(--purple);border:2px solid var(--purple)}
.btn-outline:hover{background:rgba(30,64,175,.08);border-color:var(--purple-dk);
  color:var(--purple-dk);transform:translateY(-2px)}
.btn-outline.on-dark{color:#fff;border-color:rgba(255,255,255,.28)}
.btn-outline.on-dark:hover{border-color:rgba(147,197,253,.9);background:rgba(255,255,255,.06);color:#fff}
.btn-block{display:flex;width:100%}
.btn-sm{padding:11px 18px;font-size:13.5px;min-height:44px}
.btn-lg{padding:17px 34px;font-size:16px}
.btn:focus-visible{outline:3px solid rgba(30,64,175,.5);outline-offset:3px}

/* ---------- Free-training top banner ---------- */
.tbanner{background:var(--deep);color:#fff;font-family:var(--fb);
  position:relative;z-index:60;border-bottom:1px solid rgba(255,255,255,.08)}
.tbanner .wrap{display:flex;align-items:center;gap:16px;
  min-height:44px;padding-top:7px;padding-bottom:7px}
.tbanner .tb-tag{font-family:var(--fh);font-weight:700;font-size:9.5px;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;background:var(--grad);
  border-radius:6px;padding:4px 9px;white-space:nowrap;flex:none}
/* Marquee: text scrolls right→left in one slow loop. Two duplicate spans
   inside (.tb-marquee-item × 2) and a -50% translate produces a seamless
   loop. Edges fade via mask-image so text doesn't pop in/out at the box
   boundaries. Pauses on hover, disabled by prefers-reduced-motion. */
.tbanner .tb-txt{font-size:12.5px;line-height:1.45;flex:1;color:#D6D9E7;
  overflow:hidden;min-width:0;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%)}
.tbanner .tb-txt b{font-weight:600;color:#fff}
.tb-marquee{display:inline-flex;align-items:center;gap:4rem;white-space:nowrap;
  animation:tb-marquee 28s linear infinite;will-change:transform}
.tb-marquee-item{flex:none}
.tbanner:hover .tb-marquee,.tbanner:focus-within .tb-marquee{animation-play-state:paused}
@keyframes tb-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .tb-marquee{animation:none;display:inline}
  .tbanner .tb-txt{mask-image:none;-webkit-mask-image:none}
}
.tbanner .tb-cta{display:inline-flex;align-items:center;gap:5px;font-family:var(--fh);
  font-weight:600;font-size:11px;color:#fff;background:var(--purple);
  border:0;border-radius:6px;padding:6px 12px;cursor:pointer;white-space:nowrap;flex:none;
  box-shadow:0 6px 14px -6px rgba(30,64,175,.8);transition:transform .14s,background .14s}
.tbanner .tb-cta:hover{transform:translateY(-1px);background:var(--purple-dk)}
.tbanner .tb-cta svg{width:11px;height:11px}
.tbanner .tb-close{background:transparent;border:0;color:#8b92ab;cursor:pointer;
  font-size:19px;line-height:1;padding:3px;flex:none;transition:color .14s}
.tbanner .tb-close:hover{color:#fff}
.tbanner.hidden{display:none}

/* ---------- Header / nav ---------- */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);transition:box-shadow .2s,background .2s}
.hdr.scrolled{box-shadow:0 12px 34px -24px rgba(11,23,51,.55);background:rgba(255,255,255,.96)}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center}
.brand img{height:40px;width:auto}
.nav{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-link{font-family:var(--fh);font-weight:600;font-size:15.5px;color:var(--ink);
  padding:11px 16px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:0;letter-spacing:-.005em;transition:color .14s,background .14s}
.nav-link:hover{color:var(--purple);background:var(--tint)}
.nav-link .caret{width:12px;height:12px;transition:transform .2s}
.nav-item:hover .nav-link .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:248px;
  background:#fff;border:1px solid var(--line);border-radius:15px;
  box-shadow:var(--sh-lg);padding:8px;opacity:0;visibility:hidden;
  transform:translateY(-8px);transition:opacity .17s,transform .17s,visibility .17s}
.dropdown::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:flex;align-items:center;gap:11px;padding:12px 13px;border-radius:10px;
  font-family:var(--fh);font-weight:600;font-size:14.5px;color:var(--ink);
  transition:background .13s,color .13s}
.dropdown a:hover{background:var(--tint);color:var(--purple)}
/* Color set on .dd-ic so inline-SVG stroke="currentColor" inherits the accent
   automatically. Any future palette change in --purple propagates here. */
.dropdown a .dd-ic{width:34px;height:34px;border-radius:9px;background:var(--light);
  color:var(--purple);
  display:flex;align-items:center;justify-content:center;flex:none;transition:background .13s}
.dropdown a:hover .dd-ic{background:#fff}
.dropdown a .dd-ic svg{width:17px;height:17px}
.nav-actions{display:flex;align-items:center;gap:12px}
.burger{display:none;background:transparent;border:0;cursor:pointer;padding:8px;
  flex-direction:column;gap:5px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s}
.burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mnav{display:none;position:fixed;top:0;right:0;bottom:0;width:min(380px,88vw);
  background:#fff;z-index:70;padding:24px 24px 40px;overflow-y:auto;
  box-shadow:-30px 0 70px -34px rgba(11,23,51,.6);transform:translateX(103%);
  transition:transform .28s cubic-bezier(.32,.72,0,1)}
.mnav.open{transform:translateX(0)}
.mnav-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.mnav-head img{height:34px}
.mnav-close{background:var(--tint);border:0;font-size:24px;cursor:pointer;color:var(--ink);
  line-height:1;width:40px;height:40px;border-radius:10px}
.mnav-group{border-top:1px solid var(--line);padding:5px 0}
.mnav-group>a,.mnav-grouptop{font-family:var(--fh);font-weight:700;font-size:16.5px;color:var(--ink);
  display:block;padding:14px 4px}
.mnav-sub a{display:block;font-size:14.5px;color:var(--slate);padding:9px 4px 9px 18px;
  font-family:var(--fb);font-weight:500}
.mnav-sub a:hover,.mnav-group>a:hover{color:var(--purple)}
.mnav .btn{margin-top:20px}
.scrim{display:none;position:fixed;inset:0;background:rgba(6,7,15,.55);z-index:65;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.scrim.open{display:block}

/* ---------- Sections ---------- */
.sec{padding:104px 0}
.sec.light{background:var(--light)}
.sec.tint{background:var(--tint)}
.sec.navy{background:var(--navy);color:var(--ondark)}
.sec.deep{background:var(--deep);color:var(--ondark)}
.sec.navy h1,.sec.navy h2,.sec.navy h3,.sec.navy h4,
.sec.deep h1,.sec.deep h2,.sec.deep h3,.sec.deep h4{color:#fff}
.sec.tight{padding:78px 0}
.sec-head{max-width:720px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:39px;margin-top:18px}
.sec-head .lead{font-size:18px;margin-top:18px;line-height:1.62}
.sec.navy .sec-head .lead,.sec.deep .sec-head .lead{color:var(--ondark)}
.snum{font-family:var(--fh);font-weight:600;font-size:12.5px;letter-spacing:.16em;
  color:var(--purple);text-transform:uppercase;display:inline-flex;align-items:center;gap:9px}
.snum::before{content:"";width:22px;height:1.5px;background:var(--purple);display:inline-block}
.sec.navy .snum,.sec.deep .snum{color:var(--soft)}
.sec.navy .snum::before,.sec.deep .snum::before{background:var(--soft)}

/* "at a glance" strip */
.glance{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:38px}
.glance .g{background:#fff;padding:20px 22px}
.sec.navy .glance,.sec.deep .glance{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.12)}
.sec.navy .glance .g,.sec.deep .glance .g{background:rgba(255,255,255,.025)}
.glance .g .gl{font-family:var(--fh);font-weight:700;font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--purple)}
.sec.navy .glance .g .gl,.sec.deep .glance .g .gl{color:var(--soft)}
.glance .g .gv{font-size:14px;color:var(--ink);margin-top:8px;line-height:1.5}
.sec.navy .glance .g .gv,.sec.deep .glance .g .gv{color:#EAECF4}

/* ---------- Hero (homepage, light) ----------
   Committed: hero leaves pure white behind, sits on a tinted lavender
   field with stronger purple orbs. Color carries voice, not just decoration. */
.hero{background:linear-gradient(180deg,#F2F6FE 0%,#D5E3F8 100%);color:var(--ink);
  position:relative;overflow:hidden;padding:90px 0 104px;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;top:-200px;right:-150px;width:680px;height:680px;
  border-radius:42% 58% 63% 37%/47% 42% 58% 53%;
  background:radial-gradient(circle at 42% 42%,rgba(37,99,235,.28),rgba(37,99,235,0) 68%);
  z-index:0;pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-320px;left:-220px;width:600px;height:600px;
  border-radius:58% 42% 45% 55%/52% 56% 44% 48%;
  background:radial-gradient(circle,rgba(30,64,175,.18),rgba(30,64,175,0) 70%);
  z-index:0;pointer-events:none}
.hero .wrap{position:relative;z-index:2}

/* Centered type-led hero. Block layout, content stacks vertically and
   centers within a generous max-width on the inner copy block. */
.hero-grid{display:block;max-width:none}
/* Type-led hero, centered. Image removed earlier; the headline plus lede
   plus CTAs now compose as a centered stack so the empty right column is
   filled instead of left as negative space. Max-width on the block governs
   line length; max-width on h1 keeps the headline tight. */
.hero .hero-copy{text-align:center;margin:0 auto}
.hero h1{color:var(--ink);font-size:clamp(38px,6vw,76px);line-height:1.03;
  letter-spacing:-.034em;margin:24px auto 26px;max-width:18ch}
.hero h1 em{font-style:normal;color:var(--purple)}
.hero .lede{font-size:clamp(17px,1.4vw,21px);color:var(--ink);max-width:38em;line-height:1.55;
  font-weight:400;margin-left:auto;margin-right:auto}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;justify-content:center}
.trust{display:flex;flex-wrap:wrap;align-items:center;gap:9px;margin-top:38px;justify-content:center}
.trust .tl{font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--slate);margin-right:4px}
.chip{font-family:var(--fh);font-weight:500;font-size:12.5px;letter-spacing:.01em;
  color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:7px 14px;
  background:#fff}

/* ---------- Hero visual: glassmorphic frame around product image ----------
   Frosted glass card lets the hero gradient show through the frame edges.
   The image sits inside with its own rounded corners + soft drop shadow,
   so the visual hierarchy reads as "image inside a glass frame", not
   "blurry image". One purposeful use of glass against a colored hero. */
.hviz{position:relative;border-radius:22px;
  background:linear-gradient(155deg,rgba(255,255,255,0.55) 0%,rgba(255,255,255,0.38) 100%);
  -webkit-backdrop-filter:blur(16px) saturate(135%);
  backdrop-filter:blur(16px) saturate(135%);
  border:1px solid rgba(255,255,255,0.65);
  box-shadow:
    0 32px 80px -32px rgba(30,64,175,.28),
    0 8px 28px -12px rgba(11,23,51,.16),
    inset 0 1px 0 rgba(255,255,255,0.7),
    inset 0 -1px 0 rgba(11,23,51,0.05);
  padding:14px;overflow:hidden}
.hviz img{border-radius:14px;
  box-shadow:0 14px 36px -18px rgba(11,23,51,.32)}
.hv-bar{display:flex;align-items:center;gap:11px;padding:12px 15px;
  background:#0c1731;border-bottom:1px solid rgba(255,255,255,.08)}
.hv-dots{display:flex;gap:5px}
.hv-dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.16)}
.hv-dots i:first-child{background:var(--soft)}
.hv-title{font-family:var(--fh);font-weight:600;font-size:11.5px;color:#cfd3e4;flex:1;
  letter-spacing:-.005em}
.hv-live{display:inline-flex;align-items:center;gap:6px;font-family:var(--fh);font-weight:700;
  font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:#7FE3B6;
  background:rgba(31,157,107,.16);border:1px solid rgba(31,157,107,.32);
  border-radius:999px;padding:4px 9px}
.hv-live i{width:6px;height:6px;border-radius:50%;background:#2BD48A}
.hv-app{display:grid;grid-template-columns:46px 1fr}
.hv-side{display:flex;flex-direction:column;gap:8px;padding:15px 0;align-items:center;
  border-right:1px solid rgba(255,255,255,.07);background:#0a1326}
.hv-ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;
  justify-content:center;background:rgba(255,255,255,.05)}
.hv-ic svg{width:15px;height:15px}
.hv-ic.on{background:linear-gradient(135deg,var(--purple),var(--purple-2))}
.hv-main{padding:17px 18px;display:grid;gap:15px}
.hv-ring{display:flex;align-items:center;gap:15px}
.hv-ring svg{flex:none}
.hv-rt{font-family:var(--fh);font-weight:700;font-size:14px;color:#fff}
.hv-rd{font-size:11.3px;color:#9aa2bd;margin-top:3px;line-height:1.45}
.hv-metrics{display:grid;gap:9px}
.hv-m{display:flex;align-items:center;gap:11px}
.hv-ml{font-family:var(--fb);font-size:11px;color:#c2c7da;width:120px;flex:none}
.hv-bar2{flex:1;height:6px;border-radius:3px;background:rgba(255,255,255,.07);overflow:hidden}
.hv-bar2 span{display:block;height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--purple),var(--soft))}
.hv-list{display:grid;gap:8px;border-top:1px solid rgba(255,255,255,.07);padding-top:14px}
.hv-lh{font-family:var(--fh);font-weight:700;font-size:9.5px;letter-spacing:.1em;
  text-transform:uppercase;color:#7E86A2}
.hv-li{display:flex;align-items:center;gap:10px}
.hv-av{width:26px;height:26px;border-radius:7px;flex:none;display:flex;align-items:center;
  justify-content:center;font-family:var(--fh);font-weight:700;font-size:9px;color:#fff;
  background:rgba(255,255,255,.08)}
.hv-ld{flex:1;font-family:var(--fb);font-size:11px;color:#cfd3e4}
.hv-pill{font-family:var(--fh);font-weight:700;font-size:8.5px;letter-spacing:.04em;
  text-transform:uppercase;border-radius:999px;padding:3px 9px;flex:none}
.hv-pill.rev{color:#EBBE6A;background:rgba(181,132,26,.22)}
.hv-pill.ok{color:#7FE3B6;background:rgba(31,157,107,.18)}
.hv-pill.done{color:var(--soft);background:rgba(30,64,175,.26)}
.hv-foot{display:flex;align-items:center;gap:9px;padding:12px 16px;
  border-top:1px solid rgba(255,255,255,.08);background:#0c1731;
  font-family:var(--fh);font-weight:600;font-size:10.8px;color:#fff}
.hf-dot{width:8px;height:8px;border-radius:50%;background:#2BD48A;
  box-shadow:0 0 0 4px rgba(43,212,138,.18)}

/* Hero stat band: three equal navy cards, balanced size-to-text ratio.
   Navy background gives strong contrast against the light blue hero
   gradient above and the white sections below. White headings, near-white
   body text for AAA contrast on the navy fill. */
.hstats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:54px}
.hstat{background:var(--navy);border:1px solid var(--navy-2);border-radius:18px;
  padding:32px 28px;box-shadow:0 22px 56px -32px rgba(11,23,51,.40);
  display:flex;flex-direction:column}
.hstat h3{color:#fff;font-size:18px;letter-spacing:-.012em;line-height:1.18;margin:0}
.hstat p{color:#E6E9F4;font-size:14.5px;margin-top:12px;line-height:1.62}

/* ---------- Cards ---------- */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 28px;
  box-shadow:var(--sh-sm);transition:transform .16s,box-shadow .16s,border-color .16s}
.card.hover:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:#d9d8ee}
.sec.navy .card,.sec.deep .card{background:linear-gradient(165deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border-color:rgba(255,255,255,.12);box-shadow:none}
.card .ic{width:50px;height:50px;border-radius:13px;background:var(--navy);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:23px;height:23px}
.card.accent .ic{background:var(--grad)}
.sec.navy .card .ic{background:var(--grad)}
.card h3{font-size:19.5px}
.card p{font-size:14.5px;margin-top:10px;line-height:1.62}
.card .tag{display:inline-flex;align-items:center;gap:6px;margin-top:16px;
  font-family:var(--fh);font-weight:600;font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--purple)}
.card .tag svg{width:13px;height:13px}

/* numbered points */
.points{display:grid;gap:14px;margin-top:36px}
.point{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:15px;padding:22px 24px;box-shadow:var(--sh-sm)}
.point .pn{flex:none;width:38px;height:38px;border-radius:10px;background:var(--navy);color:#fff;
  font-family:var(--fh);font-weight:700;font-size:15px;display:flex;align-items:center;
  justify-content:center}
.point .pt{font-family:var(--fh);font-weight:600;font-size:16px;color:var(--ink)}
.point .pd{font-size:14px;color:var(--slate);margin-top:5px;line-height:1.58}

/* ---------- Compare blocks ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:40px}
.compare .col{border-radius:18px;padding:30px 28px;background:#fff;box-shadow:var(--sh-sm)}
.compare .bad{border:1px solid #EFD9D6}
.compare .good{border:1px solid #CFE8DD;background:linear-gradient(180deg,#fff,#FAFDFB)}
.compare .ch{font-family:var(--fh);font-weight:700;font-size:17px;display:flex;
  align-items:center;gap:11px}
.compare .ch svg{width:22px;height:22px;flex:none}
.compare .bad .ch{color:var(--red)}
.compare .good .ch{color:var(--green)}
.compare .csub{font-family:var(--fh);font-weight:600;font-size:10.5px;letter-spacing:.11em;
  text-transform:uppercase;margin-top:5px;color:var(--slate-2)}
.compare ul{list-style:none;margin-top:20px;display:grid;gap:13px}
.compare li{display:flex;gap:12px;font-size:14.5px;line-height:1.55}
.compare li .dot{flex:none;width:20px;height:20px;border-radius:50%;display:flex;
  align-items:center;justify-content:center;margin-top:1px}
.compare .bad li .dot{background:#FBE7E5}
.compare .good li .dot{background:#DFF1E9}
.compare li .dot svg{width:12px;height:12px}

/* ---------- Data-viz (regulatory stats) ---------- */
.vizgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:14px}
.vizcard{position:relative;border-radius:20px;padding:34px 32px;overflow:hidden;
  background:linear-gradient(165deg,rgba(255,255,255,.07),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.12)}
.vizcard .vk{font-family:var(--fh);font-weight:600;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--soft)}
.vizcard h3{color:#fff;font-size:18.5px;margin-top:20px}
.vizcard p{color:var(--ondark);font-size:13.7px;margin-top:8px;line-height:1.6}
.vizcard .vmeta{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.vizcard .vmeta span{font-family:var(--fh);font-weight:600;font-size:10.5px;letter-spacing:.04em;
  color:#D9DCEA;border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:5px 9px}

/* ---------- Prongs (homepage) ---------- */
.prongs{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:42px}
.prong{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:34px 32px;box-shadow:var(--sh-sm);overflow:hidden}
.prong::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}
.prong .pk{font-family:var(--fh);font-weight:700;font-size:10.5px;letter-spacing:.11em;
  text-transform:uppercase;color:var(--purple)}
.prong .pic{width:52px;height:52px;border-radius:14px;background:var(--navy);
  display:flex;align-items:center;justify-content:center;margin:14px 0 4px}
.prong .pic svg{width:25px;height:25px}
.prong h3{font-size:23px;margin:10px 0 10px}
.prong p{font-size:14.6px;line-height:1.62}
.prong ul{list-style:none;margin-top:18px;display:grid;gap:11px}
.prong li{display:flex;gap:11px;font-size:14px;color:var(--ink);line-height:1.5;
  font-weight:500;font-family:var(--fh)}
.prong li svg{flex:none;width:18px;height:18px;margin-top:1px}
.joinline{text-align:center;margin-top:34px;font-family:var(--fh);font-weight:600;
  font-size:18px;color:var(--ink);letter-spacing:-.01em}
.joinline em{font-style:normal;color:var(--purple)}

/* ---------- CTA band ---------- */
.ctaband{position:relative;overflow:hidden;text-align:center;
  background:var(--navy);color:#fff}
.ctaband::before{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);
  width:760px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(30,64,175,.46),transparent 66%)}
.ctaband .wrap{position:relative;z-index:1}
.ctaband h2{color:#fff;font-size:38px;max-width:17em;margin:0 auto;letter-spacing:-.025em}
.ctaband p{color:var(--ondark);font-size:17px;margin:16px auto 30px;max-width:36em}
/* Inline contact methods (phone + email) replace the modal-as-first-thought
   pattern: visitors at the CTA band are already convinced, give them the
   direct action without an extra tap. */
.cta-direct{display:inline-flex;flex-wrap:wrap;gap:12px;justify-content:center}
.cta-direct .btn{font-variant-numeric:tabular-nums}
.ctaband .alt{margin-top:24px;font-size:13.5px;color:var(--ondark-2)}
.ctaband .alt a{font-weight:600;color:#fff;text-decoration:underline;text-underline-offset:3px}
.ctaband .alt button.linklike{background:transparent;border:0;color:#fff;cursor:pointer;
  font:inherit;font-weight:600;text-decoration:underline;text-underline-offset:3px;padding:0}
.ctaband .alt button.linklike:hover{color:var(--soft)}

/* ---------- Page hero (interior) ---------- */
.phero{background:var(--navy);color:#fff;padding:78px 0 84px;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;top:-240px;right:-150px;width:560px;height:560px;
  border-radius:50%;background:radial-gradient(circle,rgba(30,64,175,.44),transparent 66%)}
.phero .wrap{position:relative;z-index:2}
.phero h1{color:#fff;font-size:50px;max-width:17em;margin:18px 0 20px;letter-spacing:-.03em;
  line-height:1.07}
.phero h1 em{font-style:normal;color:var(--soft)}
.phero .lede{font-size:18.5px;color:var(--ondark);max-width:42em;line-height:1.6}
.phero .hero-cta{margin-top:32px}

/* ---------- Flow / pillars / modules ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:32px}
.flow .fstage{border-radius:15px;padding:20px 20px;color:#fff;position:relative;overflow:hidden}
.flow .s1{background:linear-gradient(160deg,#1a2950,#101d3d)}
.flow .s2{background:linear-gradient(160deg,var(--purple-dk),var(--purple))}
.flow .s3{background:linear-gradient(160deg,#2a1d6b,#1a2950)}
.flow .s4{background:linear-gradient(160deg,#0f1a36,#0b1428);border:1px solid #243150}
.flow .fstage .fk{font-family:var(--fh);font-weight:700;font-size:11.5px;letter-spacing:.09em;
  text-transform:uppercase}
.flow .fstage .fd{font-size:12.5px;color:#cdd2e3;margin-top:6px;line-height:1.5}

.pillar{display:grid;grid-template-columns:264px 1fr;border:1px solid var(--line);
  border-radius:16px;overflow:hidden;margin-top:16px;background:#fff;box-shadow:var(--sh-sm)}
.pillar .pl{background:var(--navy);color:#fff;padding:26px 24px;position:relative;overflow:hidden}
.pillar .pl::before{content:"";position:absolute;bottom:-40px;right:-40px;width:120px;height:120px;
  border-radius:50%;background:radial-gradient(circle,rgba(30,64,175,.5),transparent 70%)}
.pillar .pl .pk{font-family:var(--fh);font-weight:700;font-size:10px;letter-spacing:.09em;
  text-transform:uppercase;color:var(--soft);position:relative}
.pillar .pl h3{color:#fff;font-size:18px;margin-top:9px;position:relative}
.pillar .pr{padding:26px 28px}
.pillar .pr .pname{font-family:var(--fh);font-weight:600;font-size:14.5px;color:var(--purple)}
.pillar .pr p{font-size:14.3px;margin-top:8px;line-height:1.6}

.modgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.module{background:#fff;border:1px solid var(--line);border-radius:17px;padding:26px 24px;
  box-shadow:var(--sh-sm);transition:transform .16s,box-shadow .16s}
.module:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.module .mtop{display:flex;align-items:center;justify-content:space-between}
.module .mn{width:42px;height:42px;border-radius:11px;background:var(--navy);color:#fff;
  font-family:var(--fh);font-weight:700;font-size:16px;display:flex;align-items:center;
  justify-content:center}
.module .mcluster{font-family:var(--fh);font-weight:700;font-size:9.5px;letter-spacing:.09em;
  text-transform:uppercase;color:var(--purple);background:var(--light);border-radius:7px;
  padding:6px 10px}
.module h3{font-size:17.5px;margin-top:16px}
.module p{font-size:13.8px;margin-top:9px;line-height:1.6}

/* ---------- Tier cards ---------- */
.draftnote{display:flex;gap:14px;align-items:flex-start;background:#FFF8E8;
  border:1px solid #EFDDB0;border-radius:14px;padding:18px 20px;margin-top:28px}
.draftnote svg{flex:none;width:22px;height:22px;margin-top:1px}
.draftnote .dt{font-family:var(--fh);font-weight:700;font-size:13.5px;color:#7a5a10}
.draftnote p{font-size:13.3px;color:#866526;margin-top:4px;line-height:1.55}

.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:28px}
.tier{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 24px;
  display:flex;flex-direction:column;position:relative;box-shadow:var(--sh-sm)}
.tier.feature{border:1.5px solid var(--purple);box-shadow:0 34px 70px -34px rgba(30,64,175,.6)}
.tier .tribbon{position:absolute;top:-12px;left:24px;background:var(--grad);color:#fff;
  font-family:var(--fh);font-weight:700;font-size:9.5px;letter-spacing:.08em;
  text-transform:uppercase;padding:6px 12px;border-radius:7px}
.tier .tstep{font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--purple)}
.tier h3{font-size:22px;margin-top:7px}
.tier .tfor{font-size:13px;color:var(--slate);margin-top:11px;line-height:1.55;min-height:4.3em}
.tier .tdraft{display:inline-block;margin-top:15px;font-family:var(--fh);font-weight:700;
  font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:#8a6912;
  background:#FFF8E8;border:1px solid #EFDDB0;border-radius:6px;padding:5px 9px}
.tier .tincl{font-family:var(--fh);font-weight:700;font-size:10px;letter-spacing:.09em;
  text-transform:uppercase;color:var(--slate-2);margin-top:18px}
.tier ul{list-style:none;margin:14px 0 24px;display:grid;gap:11px}
.tier li{display:flex;gap:10px;font-size:13.3px;line-height:1.5;color:var(--ink)}
.tier li svg{flex:none;width:16px;height:16px;margin-top:2px}
.tier li.muted{color:#9aa0b2}
.tier .btn{margin-top:auto}

/* ---------- Case studies ---------- */
.illus{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);font-weight:700;
  font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:#8a6912;
  background:#FFF8E8;border:1px solid #EFDDB0;border-radius:7px;padding:6px 12px}
.illus svg{width:14px;height:14px;flex:none}
.case{border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-top:24px;
  background:#fff;box-shadow:var(--sh)}
.case .chead{background:var(--navy);color:#fff;padding:28px 32px;position:relative;overflow:hidden}
.case .chead::before{content:"";position:absolute;top:-60px;right:-30px;width:200px;height:200px;
  border-radius:50%;background:radial-gradient(circle,rgba(30,64,175,.5),transparent 70%)}
.case .chead .ck{font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);position:relative}
.case .chead h3{color:#fff;font-size:23px;margin-top:9px;position:relative;letter-spacing:-.02em}
.case .cbody{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.case .cstep{background:#fff;padding:26px 30px}
.case .cstep .csl{font-family:var(--fh);font-weight:700;font-size:10.5px;letter-spacing:.09em;
  text-transform:uppercase;color:var(--purple);display:flex;align-items:center;gap:9px}
.case .cstep .csl .csn{width:22px;height:22px;border-radius:7px;background:var(--light);
  display:flex;align-items:center;justify-content:center;font-size:11px}
.case .cstep p{font-size:14px;margin-top:11px;line-height:1.62}
.case .coutcome{background:linear-gradient(170deg,#F3F1FD,#EEF0F8);padding:26px 30px}
.case .coutcome .csl{color:var(--green)}
.case .coutcome .csl .csn{background:#DFF1E9}

/* ---------- Articles ---------- */
.artgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.art{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:17px;padding:27px 25px;box-shadow:var(--sh-sm);
  transition:transform .16s,box-shadow .16s,border-color .16s}
.art:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:#d9d8ee}
.art .ameta{display:flex;align-items:center;gap:10px;font-family:var(--fh);font-weight:600;
  font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--purple)}
.art .ameta .adot{color:var(--line)}
.art .ameta .art-rt{color:var(--slate-2)}
.art h3{font-size:18px;margin-top:14px;line-height:1.3}
.art p{font-size:14px;margin:11px 0 18px;line-height:1.6}
.art .alink{margin-top:auto;font-family:var(--fh);font-weight:600;font-size:13.5px;
  color:var(--purple);display:inline-flex;align-items:center;gap:7px}
.art:hover .alink svg{transform:translateX(4px)}
.art .alink svg{width:15px;height:15px;transition:transform .16s}

.feature-row{display:grid;grid-template-columns:1.12fr .88fr;border:1px solid var(--line);
  border-radius:22px;overflow:hidden;margin-top:10px;background:#fff;box-shadow:var(--sh)}
.feature-row .fr-l{padding:42px 42px;display:flex;flex-direction:column;justify-content:center}
.feature-row .fr-r{background:var(--navy);color:#fff;padding:42px;display:flex;
  flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.feature-row .fr-r::before{content:"";position:absolute;top:-70px;right:-50px;width:240px;
  height:240px;border-radius:50%;background:radial-gradient(circle,rgba(30,64,175,.46),transparent 70%)}
.feature-row .fr-r>*{position:relative}
.feature-row .fr-r h3{color:#fff;font-size:21px}
.feature-row .fr-r p{color:var(--ondark);font-size:14px;margin-top:11px;line-height:1.6}
.feature-row .fr-r ul{list-style:none;margin:16px 0 0;display:grid;gap:10px}
.feature-row .fr-r li{display:flex;gap:10px;font-size:13.5px;color:#EAECF4}
.feature-row .fr-r li svg{flex:none;width:16px;height:16px;margin-top:2px}

/* ---------- Pricing page ---------- */
.pphilo{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:17px;padding:28px 26px;
  box-shadow:var(--sh-sm)}
.pcard .ic{width:48px;height:48px;border-radius:12px;background:var(--grad);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.pcard .ic svg{width:22px;height:22px}
.pcard h3{font-size:18px}
.pcard p{font-size:14px;margin-top:9px;line-height:1.6}

/* ---------- Company / founder ---------- */
.mv{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:38px}
.mv .mvcard{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:36px 32px;box-shadow:var(--sh-sm);overflow:hidden}
.mv .mvcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad)}
.mv .mvcard .ic{width:52px;height:52px;border-radius:14px;background:var(--grad);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.mv .mvcard .ic svg{width:25px;height:25px}
.mv .mvcard h3{font-size:22px}
.mv .mvcard p{font-size:15.5px;margin-top:12px;line-height:1.66}

.founder{display:grid;grid-template-columns:320px 1fr;gap:44px;align-items:start;margin-top:40px}
.founder .fphoto-wrap{position:relative}
.founder .fphoto{border-radius:20px;width:100%;border:1px solid rgba(255,255,255,.14)}
.founder .frole{font-family:var(--fh);font-weight:600;font-size:14px;color:var(--soft);
  margin:9px 0 16px}
.founder p{color:var(--ondark);font-size:15.5px;line-height:1.68;margin-bottom:14px}
.founder .creds{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}
.founder .creds span{font-family:var(--fh);font-weight:600;font-size:11px;letter-spacing:.04em;
  border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:8px 13px;color:#E2E4EF;
  background:rgba(255,255,255,.03)}
.exp{display:grid;gap:0;margin-top:20px}
.exp .erow{display:flex;gap:16px;align-items:baseline;padding:15px 0;
  border-top:1px solid rgba(255,255,255,.1)}
.exp .erole{font-family:var(--fh);font-weight:600;font-size:14.5px;color:#fff;flex:1}
.exp .eorg{font-size:13px;color:var(--ondark);text-align:right}

/* ---------- FAQ ---------- */
.faq{margin-top:30px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{font-family:var(--fh);font-weight:600;font-size:16.5px;color:var(--ink);
  padding:22px 40px 22px 0;cursor:pointer;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:5px;top:18px;font-size:24px;
  color:var(--purple);font-weight:300}
.faq details[open] summary::after{content:"\2013"}
.faq p{font-size:14.6px;padding:0 0 24px;max-width:52em;line-height:1.66}

/* ---------- Footer ---------- */
.ft{background:var(--deep);color:#8B92AB;padding:70px 0 34px;font-size:13.7px}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.ft-brand .ft-top{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.ft-brand .ft-top img{width:42px;height:42px;border-radius:10px}
.ft-brand .nm{font-family:var(--fh);font-weight:700;font-size:21px}
.ft-brand .nm b{color:#fff}.ft-brand .nm i{color:var(--soft);font-style:normal}
.ft-brand p{line-height:1.62;max-width:31em;margin-bottom:11px}
.ft-brand a{color:#C3C7D9}
.ft-brand a:hover{color:#fff}
.ft-col h4{font-family:var(--fh);font-weight:600;font-size:12px;letter-spacing:.11em;
  text-transform:uppercase;color:#fff;margin-bottom:16px}
.ft-col a{display:block;color:#8B92AB;padding:6px 0}
.ft-col a:hover{color:#fff}
.ft-col button.linklike{display:block;background:transparent;border:0;color:#8B92AB;
  padding:6px 0;cursor:pointer;font-family:var(--fb);font-size:13.7px;text-align:left}
.ft-col button.linklike:hover{color:#fff}
.ft-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;
  align-items:center;margin-top:48px;padding-top:26px;border-top:1px solid rgba(255,255,255,.09)}
.ft-bottom .small{font-size:11.7px;color:#5A6079}
.social{display:flex;gap:10px}
.social a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;
  transition:background .15s,border-color .15s,transform .15s}
.social a:hover{background:var(--purple);border-color:var(--purple);transform:translateY(-2px)}
.social svg{width:16px;height:16px;fill:#C3C7D9}
.social a:hover svg{fill:#fff}

/* ---------- Cookie banner ---------- */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;z-index:80;
  background:#fff;border:1px solid var(--line);border-radius:17px;
  box-shadow:var(--sh-lg);padding:22px 24px;display:none;max-width:580px}
.cookie.show{display:block}
.cookie h4{font-family:var(--fh);font-weight:700;font-size:15.5px;color:var(--ink)}
.cookie p{font-size:13px;margin-top:7px;line-height:1.6}
.cookie .ck-actions{display:flex;gap:11px;margin-top:16px}

/* ---------- Contact modal ---------- */
.modal-scrim{position:fixed;inset:0;background:rgba(6,7,15,.7);z-index:90;
  display:none;align-items:center;justify-content:center;padding:24px;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.modal-scrim.open{display:flex}
.modal{background:#fff;border-radius:24px;max-width:468px;width:100%;padding:38px 36px;
  position:relative;box-shadow:var(--sh-lg)}
.modal .mclose{position:absolute;top:18px;right:18px;background:var(--tint);border:0;
  width:38px;height:38px;border-radius:11px;cursor:pointer;font-size:20px;color:var(--slate);
  line-height:1}
.modal .mclose:hover{background:var(--light);color:var(--ink)}
.modal h3{font-size:26px;margin-top:12px;letter-spacing:-.02em}
.modal .msub{font-size:14.3px;margin-top:11px;line-height:1.6}
.modal .mways{display:grid;gap:13px;margin-top:24px}
.modal .mway{display:flex;align-items:center;gap:16px;border:1px solid var(--line);
  border-radius:14px;padding:17px 18px;transition:border-color .14s,background .14s,transform .14s}
.modal .mway:hover{border-color:var(--purple);background:var(--tint);transform:translateY(-1px)}
.modal .mway .mwi{flex:none;width:48px;height:48px;border-radius:12px;background:var(--navy);
  display:flex;align-items:center;justify-content:center}
.modal .mway .mwi svg{width:22px;height:22px}
.modal .mway .mwl{font-family:var(--fh);font-weight:600;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--slate-2)}
.modal .mway .mwv{font-family:var(--fh);font-weight:700;font-size:18px;color:var(--ink);
  margin-top:3px}
.modal .mnote{font-size:12.3px;margin-top:20px;text-align:center;color:var(--slate-2)}

/* ---------- Utilities ---------- */
.center{text-align:center}
.mt-s{margin-top:16px}.mt-m{margin-top:30px}.mt-l{margin-top:46px}
/* Tabular figures for prices, stats, phone numbers — prevents glyph-width
   jitter when numbers update or sit in columns. Apply selectively. */
.tnum{font-variant-numeric:tabular-nums}

/* ---------- Accessibility: skip-to-content link ----------
   Hidden until keyboard focus, then pops into the top-left so keyboard users
   can bypass the training banner + header nav on every page. */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;
  background:var(--navy);color:#fff;padding:12px 18px;border-radius:10px;
  font-family:var(--fh);font-weight:600;font-size:14px;
  box-shadow:var(--sh);z-index:100;
  outline:3px solid var(--purple);outline-offset:3px;text-decoration:none}

/* ---------- Accessibility: focus-visible on non-button interactive elements
   .btn already has focus-visible; this brings parity to nav, dropdown,
   mobile menu, footer links, FAQ disclosure, and the social row. */
.nav-link:focus-visible,
.dropdown a:focus-visible,
.mnav-group>a:focus-visible,
.mnav-sub a:focus-visible,
.mnav-close:focus-visible,
.burger:focus-visible,
.ft-col a:focus-visible,
.ft-col button.linklike:focus-visible,
.ft-brand a:focus-visible,
.faq summary:focus-visible,
.social a:focus-visible,
.tbanner .tb-close:focus-visible,
.modal .mclose:focus-visible,
.modal .mway:focus-visible,
.skip-link:focus-visible{outline:3px solid rgba(30,64,175,.5);outline-offset:3px;border-radius:8px}

/* ---------- Motion (restrained, scroll-triggered) ---------- */
.reveal{opacity:0;transform:translateY(20px);
  transition:opacity .48s cubic-bezier(.23,1,.32,1),transform .48s cubic-bezier(.23,1,.32,1)}
.reveal.in{opacity:1;transform:none}
.vz-arc,.vz-curve{stroke-dashoffset:0}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1080px){
  .nav,.nav-actions .btn{display:none}
  .burger{display:flex}
  .mnav{display:block}
  /* hero-grid override removed: hero is now a single-column block, clamp()
     on .hero h1 handles size scaling smoothly across viewports. */
  .hstats{grid-template-columns:1fr;gap:14px}
  .g3,.g4,.modgrid,.artgrid,.flow,.pphilo{grid-template-columns:repeat(2,1fr)}
  .pphilo{grid-template-columns:repeat(3,1fr)}
  .tiers{grid-template-columns:repeat(2,1fr)}
  .sec-head h2{font-size:32px}
  .feature-row{grid-template-columns:1fr}
  .founder{grid-template-columns:1fr;gap:28px}
  .founder .fphoto-wrap{max-width:300px}
  .glance{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body{font-size:15.5px}
  .sec{padding:68px 0}
  .sec.tight{padding:54px 0}
  .hero{padding:56px 0 72px}
  /* .hero h1 + .hero .lede font sizes now driven by clamp() — no overrides. */
  .phero{padding:54px 0 58px}
  .phero h1{font-size:34px}
  .sec-head h2{font-size:28px}
  .sec-head .lead{font-size:16px}
  .g2,.g3,.g4,.prongs,.compare,.modgrid,.artgrid,.mv,.vizgrid,.case .cbody,
  .flow,.pphilo,.hstats{grid-template-columns:1fr}
  .pillar{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:30px}
  .ctaband h2{font-size:28px}
  .glance{grid-template-columns:1fr}
  .modal{padding:32px 24px}
  .wrap{padding:0 20px}
  .tbanner .wrap{flex-wrap:wrap;gap:9px;padding:9px 0}
  .tbanner .tb-txt{flex:1 1 100%;order:3}
  .exp .erow{flex-direction:column;gap:3px}
  .exp .eorg{text-align:left}
  .hv-ml{width:96px}
}
@media(max-width:480px){
  .g3,.g4,.tiers,.artgrid,.ft-grid,.pphilo{grid-template-columns:1fr}
  .phero h1{font-size:29px}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .sec-head h2{font-size:25px}
}

/* ---------- Article detail ---------- */
.artmeta{margin-top:22px;font-family:var(--fh);font-weight:600;font-size:13px;color:var(--ondark-2);letter-spacing:.01em}
.artbody h2{font-size:25px;color:var(--ink);margin-top:44px;letter-spacing:-.018em;line-height:1.2}
.artbody h3{font-size:19px;color:var(--ink);margin-top:36px}
.artbody p{font-size:16.5px;color:var(--slate);line-height:1.78;margin-top:18px}
.artbody>p:first-child{margin-top:0}
.artbody h2+p,.artbody h3+p{margin-top:14px}
.artbody ul{list-style:none;margin:20px 0 0;display:grid;gap:13px}
.artbody li{position:relative;padding-left:26px;font-size:16px;color:var(--slate);line-height:1.7}
.artbody li::before{content:"";position:absolute;left:1px;top:10px;width:9px;height:9px;border-radius:3px;background:var(--grad)}
.artbody blockquote{margin:32px 0 0;padding:28px 32px;background:var(--tint);border:1px solid var(--line);border-radius:14px;position:relative}
.artbody blockquote::before{content:"";position:absolute;left:32px;top:-1px;width:32px;height:3px;background:var(--purple);border-radius:0 0 3px 3px}
.artbody blockquote p{margin:0;font-family:var(--fh);font-weight:600;font-size:17px;color:var(--ink);line-height:1.64}
.artbody blockquote cite{display:block;margin-top:13px;font-style:normal;font-family:var(--fh);font-weight:700;font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--slate-2)}
.artsources{margin-top:48px;border:1px solid var(--line);border-radius:16px;padding:24px 26px;background:var(--tint)}
.artsources .ash{font-family:var(--fh);font-weight:700;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2)}
.artsources ul{list-style:none;margin:14px 0 0;display:grid;gap:10px}
.artsources li{font-size:14px;line-height:1.5}
.artsources a{color:var(--purple);font-weight:600;font-family:var(--fh)}
.artsources a:hover{text-decoration:underline}
.artback{display:inline-flex;align-items:center;gap:8px;margin-top:34px;font-family:var(--fh);font-weight:600;font-size:14.5px;color:var(--purple)}
.artback svg{width:17px;height:17px}
.artback:hover{text-decoration:underline;text-underline-offset:3px}

/* ---------- Impeccable polish pass ---------- */
.vfig{margin:46px 0 0;padding:0}
.vfig svg{display:block;width:100%;height:auto;max-width:1024px;margin:0 auto}
.vfig figcaption{margin:22px auto 0;max-width:62em;font-size:14.5px;line-height:1.72;
  color:var(--ondark);text-align:center}
.vfig figcaption b{color:#fff;font-weight:600}
.vfig figcaption .src{display:block;margin-top:9px;font-family:var(--fh);font-weight:600;
  font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ondark-2)}
@media(max-width:760px){.vfig figcaption{font-size:13.5px;padding:0 6px}}

/* ---------- Emil polish pass: press feedback, modal enter, touch hover ---------- */
.btn,
.tbanner .tb-cta,
.modal .mway,
.dropdown a,
.social a{transition-property:transform,background,box-shadow,color,border-color,opacity;
  transition-duration:.16s;transition-timing-function:cubic-bezier(.23,1,.32,1)}
.btn:active,
.tbanner .tb-cta:active,
.modal .mway:active,
.dropdown a:active,
.social a:active{transform:scale(.97)}

/* Modal enter: scrim fades, modal scales from .96 with transform-origin center */
.modal-scrim{display:flex;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s cubic-bezier(.23,1,.32,1),visibility 0s linear .18s}
.modal-scrim.open{opacity:1;visibility:visible;pointer-events:auto;
  transition:opacity .18s cubic-bezier(.23,1,.32,1),visibility 0s}
.modal{transform-origin:center;transform:scale(.96);opacity:0;
  transition:transform .2s cubic-bezier(.23,1,.32,1),opacity .2s cubic-bezier(.23,1,.32,1)}
.modal-scrim.open .modal{transform:scale(1);opacity:1}

/* Touch devices: disable hover lifts that get stuck on tap */
@media (hover:none){
  .btn-primary:hover,
  .btn-light:hover,
  .btn-outline:hover,
  .tbanner .tb-cta:hover,
  .modal .mway:hover,
  .social a:hover,
  .card.hover:hover,
  .module:hover,
  .art:hover{transform:none}
}

@media (prefers-reduced-motion:reduce){
  .modal,.modal-scrim{transition:none}
  .btn:active,.tbanner .tb-cta:active,.modal .mway:active,
  .dropdown a:active,.social a:active{transform:none}
}
