/* =====================================================
   NEXURION — Editorial Rebrand v7
   Obsidian + Ivory + Electric Magenta (#BA55E3)
   "Very expensive firm" — private-bank / sovereign-research aesthetic
   ===================================================== */

:root{
  /* Brand — keyed off the real logo */
  /* On dark surfaces, ink reads as paper; the page-local styles use
     --ink for primary text on paper. We keep --ink dark and let dark
     sections override locally. */
  --ink:#1B1C1D;            /* logo dark — primary text */
  --ink-2:#0B0B0D;           /* truer black for chrome */
  --ink-mute:rgba(27,28,29,.74);
  --ink-soft:rgba(27,28,29,.55);
  --graphite:#2A2B2E;
  --slate:#5A5C63;
  --slate-2:#8B8E96;
  --gray:#5A5C63;
  --rule:rgba(27,28,29,.12);
  --rule-soft:rgba(27,28,29,.06);

  /* Paper — cooler, drier ivory */
  --bg:#F4F2EE;             /* primary page surface */
  --bg-warm:#FAF7F0;        /* lift / hover */
  --bg-cool:#ECE9E0;        /* deeper */
  --bg-raised:#FFFFFF;      /* card */
  --bg-deep:#0B0B0D;        /* inverted */
  --paper:#F4F2EE;          /* alias */
  --paper-warm:#FAF7F0;
  --paper-2:#ECE9E0;
  --white:#FFFFFF;

  /* Signal — the logo magenta is THE color */
  --magenta:#BA55E3;
  --magenta-bright:#D982FF;
  --magenta-deep:#8E2EBA;
  --magenta-soft:#F2D9FB;
  --magenta-mid:#E0A8F2;
  --med-purple:#E0A8F2;
  --violet-deep:#5A2D9C;

  /* Optional accents */
  --gold:#C9A35A;
  --coral:#D97757;

  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter Tight","Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink-2);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
img{display:block;max-width:100%}
h1,h2,h3,h4,h5,p{margin:0}
::selection{background:rgba(186,85,227,.28);color:var(--ink)}
html{scroll-behavior:smooth}

body::-webkit-scrollbar{width:10px}
body::-webkit-scrollbar-track{background:var(--paper)}
body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:0}
body::-webkit-scrollbar-thumb:hover{background:var(--magenta)}

/* ─────── Layout ─────── */
.container{max-width:1280px;margin:0 auto;padding:0 56px;position:relative}
.container-narrow{max-width:920px;margin:0 auto;padding:0 56px;position:relative}
.section{padding:128px 0;position:relative}

/* Mobile container padding: reclaim horizontal space on phones */
@media (max-width:780px){
  .container,.container-narrow{padding:0 24px}
}
@media (max-width:420px){
  .container,.container-narrow{padding:0 18px}
}
.section-tight{padding:88px 0}

/* ─────── Type ─────── */
.h1{font-family:var(--serif);font-size:clamp(52px,7vw,104px);font-weight:400;line-height:.94;letter-spacing:-.034em;color:var(--ink);text-wrap:balance}
.h2{font-family:var(--serif);font-size:clamp(40px,4.6vw,64px);font-weight:400;line-height:1.04;letter-spacing:-.024em;color:var(--ink);text-wrap:balance}
.h3{font-family:var(--serif);font-size:clamp(28px,2.8vw,38px);font-weight:400;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
.h4{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.25;letter-spacing:-.012em;color:var(--ink)}
em.t,.h1 em,.h2 em,.h3 em,.h4 em{font-style:italic;font-weight:400;color:var(--magenta-deep)}
em.accent{font-style:italic;font-weight:400;color:var(--coral)}
em.gold{font-style:italic;font-weight:400;color:var(--gold)}

.lede{font-family:var(--serif);font-size:clamp(18px,1.6vw,22px);line-height:1.5;color:rgba(11,11,13,.78);font-weight:400;letter-spacing:-.005em}
.body{font-family:var(--sans);font-size:16px;line-height:1.65;color:rgba(11,11,13,.78);font-weight:400}
.body-lg{font-family:var(--sans);font-size:17px;line-height:1.65;color:rgba(11,11,13,.78)}
.caption{font-family:var(--sans);font-size:13.5px;line-height:1.55;color:var(--slate)}

.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.26em;color:var(--magenta-deep);text-transform:uppercase;display:inline-flex;align-items:center;gap:12px}
.eyebrow .marker{width:9px;height:9px;background:var(--magenta);display:inline-block;animation:marker-pulse 2.4s ease-in-out infinite}
@keyframes marker-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}

.sec-count{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--slate);text-transform:uppercase;margin-bottom:20px;font-weight:500}

/* ─────── Buttons ─────── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 24px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.02em;border-radius:0;border:1px solid transparent;transition:background .25s ease,color .25s ease,border-color .25s ease,transform .25s ease;white-space:nowrap;cursor:pointer;position:relative;overflow:hidden;text-transform:uppercase}
.btn-lg{padding:18px 30px;font-size:13.5px}
.btn-xl{padding:22px 38px;font-size:14px;letter-spacing:.04em}
.btn-sm{padding:10px 16px;font-size:11.5px}

.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--magenta-deep)}
.btn-magenta{background:var(--magenta);color:var(--white)}
.btn-magenta:hover{background:var(--magenta-deep)}
.btn-coral{background:var(--coral);color:var(--white)}
.btn-coral:hover{background:#c4624a}

.btn-ghost{color:var(--ink);border-color:var(--rule)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.btn-dark-ghost{color:var(--paper);border-color:rgba(255,255,255,.3)}
.btn-dark-ghost:hover{border-color:var(--paper);background:rgba(255,255,255,.08)}

.btn .arrow{transition:transform .25s ease;display:inline-block}
.btn:hover .arrow{transform:translate(3px,-1px)}

/* ─────── God-mode CTA — sitewide hero pill with AI lighting ─────── */
/* Apply via class .btn-ai (combine with btn-sm/lg/xl for sizing).      */
.btn-ai{
  position:relative;isolation:isolate;overflow:hidden;
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  color:#fff;border:0;border-radius:999px;cursor:pointer;white-space:nowrap;
  background:#0B0B0D;
  box-shadow:
    0 0 0 1px rgba(186,85,227,.55),
    0 0 14px rgba(186,85,227,.45),
    0 8px 24px -8px rgba(186,85,227,.55),
    0 18px 48px -16px rgba(186,85,227,.4),
    inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease;
}
.btn-ai.btn-sm{padding:11px 18px;font-size:11.5px;gap:9px}
.btn-ai.btn-lg{padding:18px 30px;font-size:14px;gap:14px}
.btn-ai.btn-xl{padding:22px 38px;font-size:15px;gap:16px}

/* Animated conic gradient halo (the "AI light") — painted INSIDE the pill
   so overflow:hidden can clip the slide-fill. The outer glow comes from
   box-shadow on .btn-ai itself. */
.btn-ai::before{
  content:"";position:absolute;inset:0;z-index:-2;border-radius:inherit;
  background:conic-gradient(from var(--ai-angle,0deg),
    #BA55E3 0deg,
    #FF6FB5 80deg,
    #4FB6FF 160deg,
    #BA55E3 240deg,
    #8E2EBA 320deg,
    #BA55E3 360deg);
  filter:blur(8px) saturate(140%);opacity:.6;
  animation:ai-spin 6s linear infinite;
}
.btn-ai::after{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;
  background:linear-gradient(180deg,#1B1C1D 0%,#0B0B0D 60%,#000 100%);
}

@property --ai-angle{syntax:"<angle>";inherits:false;initial-value:0deg}
@keyframes ai-spin{to{--ai-angle:360deg}}
@supports not (background:conic-gradient(from 0deg,red,red)){
  .btn-ai::before{background:linear-gradient(135deg,#BA55E3,#4FB6FF,#FF6FB5,#BA55E3);background-size:200% 200%;animation:ai-pan 6s ease-in-out infinite;filter:blur(8px) saturate(140%)}
  @keyframes ai-pan{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
}

/* Slide-fill on hover — purple gradient slides in left → right, covering the
   dark inner background. The button has overflow:hidden so the slide-in is
   clipped to the pill; the outer purple glow comes from box-shadow. */
.btn-ai .ai-shine{
  position:absolute;inset:0;z-index:-1;border-radius:inherit;
  background:linear-gradient(90deg,#7A1FA8 0%,#A53BD9 45%,#BA55E3 100%);
  transform:translateX(-101%);
  transition:transform .55s cubic-bezier(.2,.75,.2,1);
  pointer-events:none;
}
.btn-ai:hover .ai-shine{transform:translateX(0)}
@media (prefers-reduced-motion:reduce){
  .btn-ai .ai-shine{transition:opacity .25s ease;transform:none;opacity:0}
  .btn-ai:hover .ai-shine{opacity:1}
}

/* Inner glow dot */
.btn-ai .ai-dot{
  width:7px;height:7px;border-radius:50%;
  background:radial-gradient(circle,#fff 0%,#FF6FB5 60%,#BA55E3 100%);
  box-shadow:0 0 8px #FF6FB5,0 0 14px rgba(186,85,227,.6);
  animation:ai-pulse 1.6s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes ai-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.7)}}

.btn-ai:hover{transform:translateY(-2px) scale(1.015);box-shadow:
  0 0 0 1px rgba(186,85,227,.8),
  0 0 18px rgba(186,85,227,.6),
  0 14px 30px -8px rgba(186,85,227,.7),
  0 28px 60px -18px rgba(255,111,181,.55),
  inset 0 1px 0 rgba(255,255,255,.12)}
.btn-ai:hover::before{animation-duration:3s;opacity:.3}
.btn-ai:active{transform:translateY(0) scale(.99)}

/* Dark backgrounds (footer/final): brighten the dot, intensify the halo */
.final .btn-ai,.footer .btn-ai{box-shadow:
  0 0 0 1px rgba(186,85,227,.7),
  0 0 18px rgba(186,85,227,.55),
  0 10px 28px -6px rgba(186,85,227,.6),
  0 22px 60px -18px rgba(255,111,181,.5),
  inset 0 1px 0 rgba(255,255,255,.1)}

@media (prefers-reduced-motion:reduce){
  .btn-ai::before,.btn-ai .ai-shine::before,.btn-ai .ai-dot{animation:none}
  .btn-ai::before{filter:blur(8px) saturate(120%);opacity:.7}
}

/* ─────── Calmer hero variant — solid pill, purple slide-fill on hover ─────── */
/* For high-typography heroes where the AI halo competes with the headline. */
.btn-fill{
  position:relative;isolation:isolate;overflow:hidden;
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;border-radius:999px;
  background:#0E0E10;color:#fff;
  font:600 13px/1 var(--ui,'Inter',system-ui,sans-serif);
  letter-spacing:.02em;text-decoration:none;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 8px 24px -10px rgba(0,0,0,.6);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),
             border-color .35s ease,
             box-shadow .35s ease,
             color .35s ease;
}
.btn-fill.btn-sm{padding:11px 18px;font-size:11.5px;gap:9px}
.btn-fill.btn-lg{padding:18px 30px;font-size:14px;gap:14px}
.btn-fill.btn-xl{padding:22px 38px;font-size:15px;gap:16px}

/* Mobile: let long CTA buttons wrap & shrink cleanly */
@media (max-width:560px){
  .btn,.btn-fill,.btn-ai{white-space:normal;text-align:center;line-height:1.25}
  .btn-xl,.btn-fill.btn-xl,.btn-ai.btn-xl{padding:18px 22px;font-size:14px}
  .btn-lg,.btn-fill.btn-lg,.btn-ai.btn-lg{padding:15px 20px;font-size:13px}
  .hero-cta,.final-actions{flex-direction:column;align-items:stretch;gap:12px}
  .hero-cta a,.final-actions a{justify-content:center}
}
/* Slide-fill layer */
.btn-fill::before{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;
  background:linear-gradient(90deg,#7A1FA8 0%,#A53BD9 45%,#BA55E3 100%);
  transform:translateX(-101%);
  transition:transform .55s cubic-bezier(.2,.75,.2,1);
}
.btn-fill .arrow{
  display:inline-block;transition:transform .35s cubic-bezier(.2,.75,.2,1);
}
.btn-fill:hover{
  transform:translateY(-1px);
  border-color:rgba(186,85,227,.55);
  box-shadow:
    0 0 0 1px rgba(186,85,227,.35),
    0 12px 30px -10px rgba(186,85,227,.45);
}
.btn-fill:hover::before{transform:translateX(0)}
.btn-fill:hover .arrow{transform:translateX(4px)}
.btn-fill:active{transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  .btn-fill::before{transition:opacity .25s ease;transform:none;opacity:0}
  .btn-fill:hover::before{opacity:1}
}


/* ─────── Top strip ─────── */
.topstrip{background:var(--ink);color:rgba(242,238,227,.85);font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.005em;border-bottom:1px solid rgba(255,255,255,.06)}
.topstrip-inner{max-width:1360px;margin:0 auto;padding:11px 56px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.topstrip .pill{display:inline-flex;align-items:center;gap:8px;color:var(--paper);font-weight:600;text-transform:none;letter-spacing:.06em;font-size:11.5px}
.topstrip .pill::before{content:"";width:6px;height:6px;background:var(--magenta);box-shadow:0 0 0 2px rgba(186,85,227,.25)}
.topstrip .sep{color:rgba(242,238,227,.25)}
.topstrip .right{margin-left:auto;display:flex;gap:18px;color:rgba(242,238,227,.55);text-transform:uppercase;letter-spacing:.14em;font-size:10px}
@media (max-width:900px){.topstrip .right{display:none}}

/* ─────── Nav ─────── */
.nav{position:sticky;top:0;z-index:60;background:rgba(242,238,227,.88);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--rule)}
.nav-inner{display:grid;grid-template-columns:minmax(170px,auto) 1fr minmax(170px,auto);align-items:center;gap:24px;padding:18px 56px;max-width:1360px;margin:0 auto}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink);min-width:0}
.brand-mark{display:inline-flex;align-items:center;height:22px;flex:0 0 auto;overflow:visible}
.brand-mark svg{height:22px;width:158px;display:block;max-width:none;overflow:visible}
.nav-center{display:flex;gap:28px;justify-content:center;flex-wrap:nowrap}
.nav-center a{font-family:var(--sans);font-size:13px;color:rgba(11,11,13,.66);font-weight:500;transition:color .18s ease;position:relative;letter-spacing:.01em;white-space:nowrap}
.nav-center a:hover,.nav-center a.active{color:var(--ink)}
.nav-center a.active::after{content:"";position:absolute;left:0;right:0;bottom:-22px;height:1px;background:var(--magenta)}
.nav-right{display:flex;gap:12px;justify-content:flex-end;align-items:center}
/* Nav collapses to hamburger early enough that the full link bar (8 items) never
   crowds the Contact CTA in the ~900–1080px band. */
@media (max-width:1080px){.nav-center{display:none}.nav-inner{grid-template-columns:auto 1fr auto;padding-left:24px;padding-right:24px}}
@media (max-width:1080px){.nav-right{display:none}}
@media (max-width:420px){.nav-inner{padding-left:18px;padding-right:18px}}

/* ─────── Mobile nav: hamburger + drawer ─────── */
.nx-burger{display:none;background:transparent;border:0;cursor:pointer;padding:10px;margin:0;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:8px;transition:background .2s ease}
.nx-burger:hover{background:rgba(11,11,13,.06)}
.nx-burger span{display:block;width:22px;height:1.5px;background:var(--ink);border-radius:2px;transition:transform .25s cubic-bezier(.2,.7,.2,1),opacity .2s ease}
.nx-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nx-burger.open span:nth-child(2){opacity:0}
.nx-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

body.nav-on-dark .nx-burger:hover{background:rgba(244,242,238,.08)}
body.nav-on-dark .nx-burger span{background:#F4F2EE}

@media (max-width:1080px){
  .nx-burger{display:flex}
}

/* Drawer overlay */
.nx-drawer{position:fixed;inset:0;z-index:200;pointer-events:none;visibility:hidden}
.nx-drawer.open{pointer-events:auto;visibility:visible}
.nx-drawer-backdrop{position:absolute;inset:0;background:rgba(11,11,13,.55);opacity:0;transition:opacity .3s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.nx-drawer.open .nx-drawer-backdrop{opacity:1}

.nx-drawer-panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(360px,86vw);
  background:var(--paper);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
  box-shadow:-30px 0 80px rgba(11,11,13,.25);
  overflow-y:auto;
}
.nx-drawer.open .nx-drawer-panel{transform:translateX(0)}

.nx-drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;
  border-bottom:1px solid var(--rule);
}
.nx-drawer-brand{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.22em;color:var(--ink);text-transform:uppercase;
}
.nx-drawer-close{
  background:transparent;border:0;cursor:pointer;
  width:36px;height:36px;font-size:24px;line-height:1;
  color:var(--ink);border-radius:50%;
  transition:background .2s ease;
}
.nx-drawer-close:hover{background:rgba(11,11,13,.06)}

.nx-drawer-links{display:flex;flex-direction:column;padding:24px 0;flex:1}
.nx-drawer-links a{
  display:flex;align-items:center;
  padding:14px 24px;
  font-family:var(--sans);font-size:18px;font-weight:300;
  letter-spacing:-.01em;color:var(--ink);
  text-decoration:none;
  border-left:3px solid transparent;
  transition:border-color .2s ease,background .2s ease,padding-left .2s ease;
}
.nx-drawer-links a:hover{background:rgba(186,85,227,.06);border-left-color:var(--magenta);padding-left:28px}
.nx-drawer-links a.active{border-left-color:var(--magenta);color:var(--magenta-deep);font-weight:500}

.nx-drawer-foot{
  padding:24px;
  border-top:1px solid var(--rule);
  background:rgba(186,85,227,.04);
}
.nx-drawer-cta{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;
  background:var(--ink);color:var(--paper);
  text-decoration:none;border-radius:6px;
  font-family:var(--sans);font-size:14px;font-weight:500;
  letter-spacing:-.005em;
  transition:background .2s ease;
}
.nx-drawer-cta:hover{background:var(--magenta-deep)}
.nx-drawer-cta span{font-family:var(--serif);font-style:italic;font-size:16px}
.nx-drawer-meta{
  margin:14px 0 0;
  font-family:var(--sans);font-size:12px;
  color:var(--ink-mute);font-weight:300;line-height:1.4;
  text-align:center;
}

/* ─────── Scroll progress + rail ─────── */
.scroll-bar{position:fixed;top:0;left:0;height:2px;background:var(--magenta);z-index:100;width:0%;transition:width .1s linear}
.scroll-rail{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;gap:14px;padding:14px 10px;background:rgba(242,238,227,.7);backdrop-filter:blur(10px);border:1px solid var(--rule)}
.scroll-rail a{position:relative;width:8px;height:8px;background:var(--rule);transition:all .25s ease;display:block}
.scroll-rail a:hover{background:var(--magenta);transform:scale(1.4)}
.scroll-rail a.active{background:var(--magenta-deep);transform:scale(1.4)}
.scroll-rail a::after{content:attr(data-label);position:absolute;right:calc(100% + 14px);top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.18em;color:var(--ink);text-transform:uppercase;background:var(--paper);padding:6px 10px;border:1px solid var(--rule);opacity:0;pointer-events:none;transition:opacity .2s ease;white-space:nowrap}
.scroll-rail a:hover::after{opacity:1}
@media (max-width:1100px){.scroll-rail{display:none}}

/* ─────── Section head ─────── */
.sec-head{display:grid;grid-template-columns:1.3fr 1fr;gap:96px;align-items:end;margin-bottom:88px}
.sec-head .lh h2{margin-top:24px}
.sec-head .rh{padding-bottom:8px;color:rgba(11,11,13,.72);font-family:var(--sans);font-size:17px;line-height:1.6}
@media (max-width:900px){.sec-head{grid-template-columns:1fr;gap:32px}}

/* ─────── Reveal ─────── */
.reveal{opacity:1;transform:none;transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.js-reveal .reveal:not(.in){opacity:0;transform:translateY(16px)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ─────── Footer ─────── */
.footer{background:var(--ink);color:rgba(242,238,227,.7);padding:104px 0 32px;border-top:3px solid var(--magenta);position:relative;overflow:hidden}
.footer::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 90% 0%,rgba(186,85,227,.12),transparent 60%);pointer-events:none}
.footer canvas.lattice{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.45}
.footer .container{max-width:1360px;position:relative}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:64px;padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .tag{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.4;color:var(--paper);max-width:380px;font-weight:400;margin:24px 0;letter-spacing:-.012em}
.footer-brand .addr{font-family:var(--sans);font-size:14px;letter-spacing:0;color:rgba(242,238,227,.7);line-height:1.7;font-weight:400}
.footer-brand .addr a{color:var(--magenta-mid);font-weight:500}
.footer-brand .addr a:hover{color:var(--paper)}
.footer-col h5{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.24em;color:var(--magenta-mid);text-transform:uppercase;margin-bottom:24px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:13px}
.footer-col ul li a{font-family:var(--sans);font-size:14px;color:rgba(242,238,227,.7);transition:color .18s ease}
.footer-col ul li a:hover{color:var(--paper)}
.footer-bottom{margin-top:32px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:20px}
.footer-bottom .copy{font-family:var(--sans);font-size:13px;letter-spacing:0;color:rgba(242,238,227,.55);line-height:1.65;font-weight:400}
.footer-bottom .copy.gov-entity{margin-top:6px;color:rgba(242,238,227,.65);font-size:12.5px;letter-spacing:0}
.footer-bottom .copy.gov-entity em{font-style:normal;font-weight:500;color:rgba(242,238,227,.78)}
.footer-bottom .copy.gov-entity code{font-family:var(--mono);font-weight:600;letter-spacing:.06em;color:var(--magenta-mid);background:rgba(186,85,227,.08);padding:1px 6px;border:1px solid rgba(186,85,227,.18);border-radius:1px;margin:0 2px}
.footer-bottom .copy.gov-entity a{color:var(--magenta-mid);text-decoration:none;border-bottom:1px solid rgba(186,85,227,.4);padding-bottom:1px;transition:color .18s ease,border-color .18s ease}
.footer-bottom .copy.gov-entity a:hover{color:var(--paper);border-color:var(--paper)}
.footer-bottom .copy-block{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.footer-bottom .badges{display:flex;gap:6px;flex-wrap:wrap}
.footer-bottom .badge{font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.22em;color:var(--magenta-mid);text-transform:uppercase;padding:6px 10px;border:1px solid rgba(255,255,255,.12)}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}}

/* ─────── Cards ─────── */
.tier{background:var(--paper);border:1px solid var(--rule);padding:38px 32px;display:flex;flex-direction:column;gap:24px;position:relative;cursor:pointer;transition:background .3s ease,border-color .3s ease;overflow:hidden}
.tier::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(500px circle at var(--mx,50%) var(--my,50%),rgba(186,85,227,.10),transparent 40%);opacity:0;transition:opacity .3s ease}
.tier:hover{border-color:rgba(186,85,227,.4)}
.tier:hover::before{opacity:1}
.tier.featured{background:var(--paper-warm)}
.tier .tk{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.24em;color:var(--magenta-deep);text-transform:uppercase}
.tier h3{font-family:var(--serif);font-size:32px;line-height:1.06;letter-spacing:-.022em;color:var(--ink);font-weight:400}
.tier h3 em{color:var(--magenta-deep);font-style:italic}
.tier .tagline{font-family:var(--sans);font-size:13px;color:var(--slate);line-height:1.5}
.tier ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;font-family:var(--sans);font-size:14.5px;color:rgba(11,11,13,.78);line-height:1.5}
.tier ul li{display:flex;gap:12px;position:relative}
.tier ul li::before{content:"—";color:var(--magenta);font-weight:600;flex-shrink:0;font-family:var(--mono)}

.trust-card{background:var(--paper);border:1px solid var(--rule);padding:30px 26px;display:flex;flex-direction:column;gap:14px;transition:border-color .25s ease,background .25s ease;position:relative;overflow:hidden;cursor:default}
.trust-card::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),rgba(186,85,227,.10),transparent 50%);opacity:0;transition:opacity .3s ease}
.trust-card:hover{border-color:rgba(186,85,227,.4)}
.trust-card:hover::after{opacity:1}
.trust-card .tl{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.22em;color:var(--magenta-deep);text-transform:uppercase}
.trust-card h4{font-family:var(--serif);font-size:24px;letter-spacing:-.016em;color:var(--ink);line-height:1.15;font-weight:400}
.trust-card h4 em{color:var(--magenta-deep);font-style:italic}
.trust-card p{font-family:var(--sans);font-size:14px;line-height:1.55;color:rgba(11,11,13,.7)}
.trust-card .tm{margin-top:auto;padding-top:14px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.2em;color:var(--slate);text-transform:uppercase}

/* ─────── Mono grid ─────── */
.grid-bg{background-image:linear-gradient(rgba(11,11,13,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(11,11,13,.04) 1px,transparent 1px);background-size:48px 48px}

/* ─────── Final CTA ─────── */
.final-lattice{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;opacity:.92}
.final{background:var(--ink);color:var(--paper);padding:120px 0;position:relative;overflow:hidden}
.final .final-inner{position:relative;z-index:3}
.final::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(900px 580px at 80% 10%,rgba(186,85,227,.22),transparent 60%);pointer-events:none}
.final::after{content:"";position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:64px 64px;pointer-events:none;mask-image:radial-gradient(ellipse 70% 80% at 30% 60%,#000,transparent)}
.final-inner{max-width:1180px;margin:0 auto;padding:0 56px;position:relative;z-index:2}
.final .eyebrow{color:var(--magenta-mid)}
.final .eyebrow .marker{background:var(--magenta-mid)}
.final h2{color:var(--paper);margin:24px 0 32px}
.final h2 em{color:var(--magenta-mid);font-style:italic}
.final .lede{color:rgba(242,238,227,.78);max-width:760px;margin-bottom:52px}
.final-cols{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-bottom:60px}
.final-cols p{font-family:var(--sans);font-size:15px;line-height:1.65;color:rgba(242,238,227,.7);margin-bottom:14px}
.final-cols em{color:var(--magenta-mid);font-style:italic;font-family:var(--serif)}
.final-actions{display:flex;gap:14px;flex-wrap:wrap}
.final-footer{margin-top:52px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.22em;color:rgba(242,238,227,.45);text-transform:uppercase}
@media (max-width:720px){.final-cols{grid-template-columns:1fr;gap:24px}}

.tag-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border:1px solid var(--rule);font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);font-weight:500}
.tag-chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tag-chip.magenta{color:var(--magenta-deep);border-color:rgba(186,85,227,.3)}

@media (max-width:720px){
  .container,.container-narrow{padding:0 24px}
  .section{padding:80px 0}
}


/* ───────── Cross-page nav theme: dark glass over hero, light bone after ─────────
   Toggled by /assets/nav-theme.js based on whether the first hero element is in view. */
body.nav-on-dark .nav{background:rgba(18,7,38,.55)!important;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-bottom:1px solid rgba(244,242,238,.10)!important}
body.nav-on-dark .nav .brand{filter:invert(1) hue-rotate(180deg) brightness(1.05)}
body.nav-on-dark .nav .nav-center a:link,body.nav-on-dark .nav .nav-center a:visited{color:rgba(244,242,238,.65)!important}
body.nav-on-dark .nav .nav-center a:hover,body.nav-on-dark .nav .nav-center a.active{color:#F4F2EE!important}
body.nav-on-dark .nav .btn-ghost{color:#F4F2EE!important;border-color:rgba(244,242,238,.25)!important}
body.nav-on-dark .nav .btn-ghost:hover{background:rgba(244,242,238,.08)!important;border-color:rgba(244,242,238,.45)!important}

/* When the dark hero is in play, the body bg and any topstrip above the nav
   should match the hero so the nav reads as one continuous dark band, not a
   light cap with dark below. */
body.nav-on-dark{background:#120726!important}
body.nav-on-dark .topstrip{background:transparent!important;border-bottom-color:rgba(244,242,238,.06)!important}

/* ─────── Inline contextual link styling (cross-framework + Field Notes) ─────── */
.inline-link{
  color:var(--magenta-deep);
  text-decoration:none;
  border-bottom:1px solid rgba(142,46,186,.28);
  transition:border-color .2s ease,color .2s ease;
  white-space:nowrap;
}
.inline-link:hover{
  color:var(--magenta);
  border-bottom-color:var(--magenta);
}
/* On dark backgrounds (final, ai-gov, gov-hero, founder) — flip to ivory */
.final .inline-link,
.founder .inline-link,
.ai-gov .inline-link,
.shannon .inline-link,
.stance .inline-link{
  color:var(--magenta-mid,#E0A8F2);
  border-bottom-color:rgba(224,168,242,.4);
}
.final .inline-link:hover,
.founder .inline-link:hover,
.ai-gov .inline-link:hover,
.shannon .inline-link:hover,
.stance .inline-link:hover{
  color:var(--magenta-bright,#D982FF);
  border-bottom-color:var(--magenta-bright,#D982FF);
}

/* ───────────────────────────────────────────────────────────
   MOBILE — scroll-driven "experience" sections (≤768px)
   The cinematic pinned experiences (.tjx/.ismsx · .cej/.afx · .bp/.dc)
   scrub a single panel across 5 stages over 520–560vh. On phones that
   pinned scrub doesn't work — it strands on stage 1 and the full-bleed
   width scrolls sideways. Each engine instead renders its full story as
   a static stacked list (.xs-*) and tags the section .xs-mobile; here we
   unpin it, kill the full-bleed width, and hide the original pinned grid.
   Desktop (>768px) never sees any of this. */
@media (max-width:768px){
  .xs-mobile{height:auto!important;width:100%!important;margin-left:0!important;max-width:100vw}
  .xs-mobile > .tjx-sticky,
  .xs-mobile > .ismsx-sticky,
  .xs-mobile > .cej-sticky,
  .xs-mobile > .afx-sticky,
  .xs-mobile > .bp-sticky,
  .xs-mobile > .dc-sticky{display:none!important}
  .xs-wrap{position:relative;z-index:2;max-width:560px;margin:0 auto;padding:60px 24px}
  .xs-kick{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:#D982FF;margin-bottom:10px}
  .xs-list{list-style:none;margin:0;padding:0}
  .xs-step{padding:22px 0;border-top:1px solid rgba(244,242,238,.14)}
  .xs-step:first-child{border-top:0;padding-top:6px}
  .xs-s{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(217,130,255,.85)}
  .xs-h{font-family:"Inter Tight",sans-serif;font-weight:300;font-size:clamp(22px,6.4vw,30px);line-height:1.18;letter-spacing:-.012em;color:#F4F2EE;margin:9px 0 7px}
  .xs-h em{font-style:normal;color:#D982FF}
  .xs-c{font-size:15px;line-height:1.55;color:rgba(244,242,238,.74);margin:0}
}
