/* ============================================================
   EMINENCE VSP — MASTER DESIGN SYSTEM STYLESHEET
   Single source of truth. EVERY page imports this file.
   No page-level style overrides permitted — change it here or not at all.
   ------------------------------------------------------------
   TOKENS
   Colours: paper #FFFFFF (canvas) · navy #05043A (ink/logo/CTA)
            ultramarine #2538B8 (accent) · coral #FF724F (small CTAs + Solutions/charts)
            sky #67B1FF / lemon #F1F57F (Solutions page accents + charts only)
   Type:    Financier Display 600 (H1/H2/quotes/stats, >=28px; italic = accent phrase)
            Founders Grotesk 400/500/600 (everything else; body 15-17px +0.5% tracking)
   Scale:   H1 clamp(50px,6.8vw,100px) · H2 clamp(38px,5vw,64px) · row-title clamp(26px,3.4vw,44px)
   Radius:  ledger corner — 0 R R R on all blocks (36 surface · 24 block · 16 card) · 100px pill
   Shape:   blocks are LANDSCAPE — feature ~2.5:1, grid card ~1.5:1, never square/portrait
   Content-block sets (locked 2026-06-12): FEATURE ROWS, GSAP scale — full-width hairline rows, /NN-or-KICKER column + serif title (24-33px) + body right, padding 30-46px. Index rows (svc/orow) for compact lists; grey surface blocks for links/features.
   Motion:  cubic-bezier(.16,1,.3,1) · scroll reveals via .rv/.in · reduced-motion respected
   Layout:  .wrap 1180px + 28px gutters · SECTIONS ARE BANDS (full-bleed white/grey/navy, one padding rhythm) — ledger-corner cards live INSIDE sections only
   ============================================================ */

@font-face{font-family:'Financier Display';src:url('../fonts/financier-display-semibold.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Financier Display';src:url('../fonts/financier-display-semibold-italic.woff2') format('woff2');font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:'Founders Grotesk';src:url('../fonts/founders-grotesk-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Founders Grotesk';src:url('../fonts/founders-grotesk-medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Founders Grotesk';src:url('../fonts/founders-grotesk-semibold.woff2') format('woff2');font-weight:600;font-display:swap}
:root{
  --blue:#2538B8;--navy:#05043A;--coral:#FF724F;--sky:#67B1FF;--lemon:#F1F57F;--paper:#FFFFFF;--grey:#F3F4F6;
  --t-sky:#EDF4FE;--t-coral:#FCEFE8;--t-lemon:#FAFAE9;--muted:#4A4A68;--line:rgba(5,4,58,.12);--line-l:rgba(255,255,255,.16);
  --fh:'Financier Display',Georgia,serif;--fb:'Founders Grotesk',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background-color:var(--paper);color:var(--navy);font-size:19px;line-height:1.62;letter-spacing:.004em}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.gridbg{}
h1,h2,h3.serif{font-family:var(--fh);font-weight:600;line-height:1.08}
/* —— TYPE HIERARCHY (locked scale: each level visibly distinct) ——
   H1 hero 100  ·  H2 section 64  ·  H3 sub-section serif 34  ·  card title sans 21  ·  body 17  ·  small 15 */
h2{font-size:clamp(40px,4.8vw,66px);letter-spacing:-.02em;line-height:1.06}
section .wrap>h2,.challenges h2,.industries h2,.solutions h2{margin-top:18px}
.lede{font-size:clamp(20px,2vw,26px);color:var(--muted);max-width:720px;margin-top:24px;line-height:1.45}
/* giant typographic statement moment (one per page max) */
.statement{font-family:var(--fh);font-weight:600;font-size:clamp(62px,10vw,146px);letter-spacing:-.03em;line-height:1;margin-top:18px}
.statement em{font-style:italic;color:var(--blue)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}
.eyebrow::before{content:"";width:24px;height:2px;background:currentColor}
.eyebrow.rv::before{transform:scaleX(0);transform-origin:left;transition:transform .9s cubic-bezier(.16,1,.3,1) .15s}
.eyebrow.rv.in::before{transform:scaleX(1)}
.ch{display:inline-block}
.btn{display:inline-block;font-weight:600;font-size:16px;padding:16px 30px;border-radius:100px;text-decoration:none;transition:.2s}
.b-blue{background:var(--navy);color:#fff}.b-blue:hover{background:var(--blue)}
.b-coral{background:var(--coral);color:#fff}.b-coral:hover{background:var(--navy)}
.b-navy-line{border:1.5px solid var(--navy);color:var(--navy)}
.b-paper{background:var(--paper);color:var(--navy)}
.b-sky-line{border:1.5px solid rgba(103,177,255,.6);color:var(--sky)}
section{padding:clamp(96px,11vw,140px) 0}

/* NAV — slim, right-clustered, hides on scroll down */
nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:transform .4s cubic-bezier(.16,1,.3,1)}
nav.hide{transform:translateY(-100%)}
/* nav breathes wider than the page grid — logo far left, like a frame */
nav .wrap{max-width:1880px;padding:0 clamp(28px,3vw,56px)}
.nav-i{display:flex;justify-content:space-between;align-items:center;height:84px}
.nav-i img{height:19px}
.nav-links{display:flex;gap:clamp(30px,3vw,46px);font-size:18px;font-weight:500;color:var(--navy);align-items:center;margin-left:auto;margin-right:44px}
.nav-links>a span,.ddwrap>span{padding-bottom:7px;border-bottom:1.5px solid transparent;transition:border-color .25s;cursor:pointer}
.nav-links>a:hover span,.ddwrap:hover>span,.ddwrap:focus-within>span{border-color:rgba(5,4,58,.3)}
.nav-links>a.active span{border-color:rgba(5,4,58,.45)}
@media(max-width:920px){.nav-links{display:none}}
/* Industries dropdown */
.ddwrap{position:relative}
.ddwrap>span::after{content:"⌄";font-size:15px;color:rgba(5,4,58,.4);margin-left:8px;font-weight:400;display:inline-block;transform:translateY(-2px)}
.dd{position:absolute;top:calc(100% + 14px);left:-18px;background:#fff;border:1px solid var(--line);border-radius:0 16px 16px 16px;padding:10px;min-width:280px;box-shadow:0 24px 60px rgba(5,4,58,.14);opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s cubic-bezier(.16,1,.3,1)}
.ddwrap:hover .dd,.ddwrap:focus-within .dd{opacity:1;visibility:visible;transform:none}
.ddwrap::before{content:'';position:absolute;top:100%;left:0;right:0;height:16px}
.dd a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:var(--navy);text-decoration:none;font-size:15px;font-weight:500}
.dd a:hover{background:rgba(37,56,184,.06);color:var(--blue)}
.dd a .dn{font-size:12px;font-weight:600;color:var(--blue);letter-spacing:.06em;min-width:22px}

/* HERO — navy + flowing sky lines */
.hero{padding:0;background:var(--grey);position:sticky;top:0;z-index:0}
.hero-card{background:var(--grey);border-radius:0;padding:clamp(130px,15vh,170px) 0 110px;position:relative;overflow:hidden}

.hero svg.flow{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:clamp(52px,7vw,104px);max-width:1100px;letter-spacing:-.025em;line-height:1.04}
.hero h1 em{font-style:italic;color:var(--blue)}
.hero .sub{font-size:clamp(19px,1.7vw,22px);color:var(--muted);max-width:600px;margin-top:30px;line-height:1.55}
.hero .ctas{display:flex;gap:14px;margin-top:42px;flex-wrap:wrap}
.hero .proof{display:flex;gap:22px;align-items:center;margin-top:54px;font-size:14.5px;color:var(--muted);flex-wrap:wrap}
.hero .proof .stars{color:var(--blue);letter-spacing:2px}

/* CHALLENGES */
.challenges h2{font-size:clamp(38px,5vw,64px);margin-top:14px}
.cards4{display:grid;grid-template-columns:1fr;gap:0;margin-top:48px;border-top:1px solid var(--line)}
.cardx{background:transparent;border:none;border-bottom:1px solid var(--line);border-radius:0;padding:clamp(30px,3.6vw,46px) 4px;display:grid;grid-template-columns:64px minmax(230px,330px) 1fr;gap:14px 32px;align-items:start;transition:.25s}
@media(max-width:760px){.cardx{grid-template-columns:1fr;gap:8px}}
.cardx .ill{display:none}
.cardx .num{font-size:13px;font-weight:600;color:var(--blue);letter-spacing:.1em}
.cardx h3{font-family:var(--fh);font-weight:600;font-size:clamp(24px,2.5vw,33px);margin:0;letter-spacing:-.012em;line-height:1.15}
.cardx p{font-size:17.5px;color:var(--muted);margin:0}
@media(max-width:600px){.cards4{grid-template-columns:1fr}}

/* INDUSTRIES — navy */
.industries{color:var(--navy)}
.industries .eyebrow{color:var(--blue)}
.industries h2{font-size:clamp(38px,5vw,64px);margin-top:14px}
.industries .sub{color:var(--muted);max-width:600px;margin-top:14px}
.ind{display:flex;align-items:center;gap:24px;border-bottom:1px solid var(--line);padding:30px 4px;font-family:var(--fh);font-size:clamp(26px,3.4vw,44px);cursor:pointer}
.ind:first-of-type{border-top:1px solid var(--line);margin-top:44px}
.ind .n{font-family:var(--fb);font-size:13px;font-weight:600;color:var(--blue);min-width:30px}
.ind .arr{margin-left:auto;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--fb);font-size:15px;flex-shrink:0}
.ind.open .arr{background:var(--navy);border-color:var(--navy);color:#fff}
.ind-body{display:grid;grid-template-columns:1fr;gap:24px;padding:10px 4px 36px 56px;align-items:center;max-width:720px}
.ind-body p{color:var(--muted);font-size:18.5px;max-width:540px;font-family:var(--fb)}
.chip{display:inline-block;background:rgba(5,4,58,.05);border:none;border-radius:100px;padding:8px 18px;font-size:14.5px;font-weight:500}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.ind-visual{background:linear-gradient(135deg,rgba(37,56,184,.05),rgba(103,177,255,.09));border:none;border-radius:0 22px 22px 22px;padding:30px;display:flex;align-items:center;justify-content:center}
@media(max-width:860px){.ind-body{grid-template-columns:1fr;padding-left:4px}}

/* SOLUTIONS */
.solutions h2{font-size:clamp(38px,5vw,64px);margin-top:14px}
.cards3{display:grid;grid-template-columns:1fr;gap:0;margin-top:48px;border-top:1px solid var(--line)}
.cards3 .cardx .dot{width:auto;height:auto;border-radius:0;background:none;color:var(--blue);font-weight:600;font-size:13px;letter-spacing:.1em;display:block;margin-bottom:12px}
@media(max-width:920px){.cards3{grid-template-columns:1fr}}

/* RESULTS + stats */
.results{}
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:44px}
.stat .n{font-family:var(--fh);font-weight:600;font-size:clamp(64px,7vw,96px);color:var(--navy);line-height:1}
.stat .l{font-size:17px;color:var(--muted);margin-top:10px;max-width:280px}
@media(max-width:760px){.statrow{grid-template-columns:1fr}}

/* TESTIMONIALS */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:48px}
.tcard{background:transparent;border:none;border-top:2px solid var(--navy);border-radius:0;padding:26px 4px 0}
.tcard .q{font-family:var(--fh);font-weight:600;font-size:25px;line-height:1.4}
.tcard .q::before{content:"\201C";color:var(--blue)}
.tcard .who{margin-top:18px;font-size:16px;color:var(--muted)}
.tcard .who b{color:var(--navy);font-weight:600}
@media(max-width:820px){.tgrid{grid-template-columns:1fr}}

/* CTA */
.ctablock{background:var(--navy);border-radius:0 24px 24px 24px;padding:62px 56px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;color:#fff}
.ctablock h2{font-size:clamp(28px,3.6vw,44px);max-width:520px}
.ctablock p{color:rgba(255,255,255,.78);margin-top:10px;font-size:17px}
@media(max-width:800px){.ctablock{padding:44px 28px}}

/* TALK — the conversion section (navy card, sits above the footer) */
/* CTA band — content, not footer: light ground, giant serif, coral action; navy footer below provides the break */
.talk{background:#fff;border-top:1px solid var(--line);border-radius:0;margin:0;padding:clamp(80px,9vw,120px) 0;color:var(--muted)}
.talk .btn{background:var(--coral)!important;color:#fff!important;border-color:transparent!important}
.talk .f-mail{color:var(--blue)}
.talk .inner{display:flex;justify-content:space-between;align-items:flex-end;gap:44px;flex-wrap:wrap}
.talk h2{color:var(--navy);font-size:clamp(44px,6vw,84px);letter-spacing:-.022em;margin-top:16px}
.talk .lede{color:var(--muted);max-width:460px;margin-top:18px}
.talk .eyebrow{color:var(--blue)!important}
.f-actions{display:grid;gap:20px;justify-items:start}
.f-mail{color:var(--sky);font-size:clamp(18px,1.9vw,23px);font-weight:500;text-decoration:none;border-bottom:1.5px solid rgba(103,177,255,.35);padding-bottom:3px;transition:border-color .25s}
.f-mail:hover{border-color:var(--sky)}

/* FOOTER — slim: wordmark, columns, legal */
footer{background:var(--navy);color:rgba(255,255,255,.75);padding:78px 0 36px;overflow:hidden}
.f-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.f-top img{height:14px}

.f-cols{display:flex;gap:60px;flex-wrap:wrap;font-size:14px}
.f-cols h6{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px}
.f-cols ul{list-style:none;display:grid;gap:8px}
.f-cols a{color:rgba(255,255,255,.75);text-decoration:none}
.f-cols a:hover{color:var(--sky)}
.f-bot{margin-top:46px;padding-top:22px;border-top:1px solid var(--line-l);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.5)}


/* ===== SECTION SEPARATION — air first, surfaces second (calm rhythm) ===== */
section{padding:clamp(96px,11vw,140px) 0;position:relative;overflow:hidden;z-index:2;background-color:var(--paper)}
/* full-bleed navy band — the hard separation moment */
.navyband{background-color:var(--navy);color:rgba(255,255,255,.78)}
.navyband .think{background:transparent;border-radius:0;padding:0;margin:0}
.navyband h2{color:#fff}
.navyband .eyebrow{color:var(--sky)}
.navyband .lede{color:rgba(255,255,255,.6)}
.navyband .secnum{color:rgba(255,255,255,.05)}
.navyband .inline-cta{color:var(--sky)}

/* services catalogue (Clay grammar): category → conviction → discipline list + media */
.catgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;margin-top:56px;align-items:center}
.svc{list-style:none}
.svc li{display:flex;gap:22px;align-items:baseline;padding:21px 4px;border-bottom:1px solid var(--line);font-size:clamp(17px,1.5vw,20px);font-weight:500;transition:padding .3s cubic-bezier(.16,1,.3,1)}
.svc li:first-child{border-top:1px solid var(--line)}
.svc li:hover{padding-left:16px}
.svc li span{font-size:12.5px;font-weight:600;color:var(--blue);letter-spacing:.08em;min-width:26px;flex-shrink:0}
.catmedia img{width:100%;display:block}
.catgrid.flip{grid-template-columns:.95fr 1.05fr}
.catgrid.flip .catmedia{order:-1}
.navyband .svc li{border-color:var(--line-l);color:rgba(255,255,255,.92)}
.navyband .svc li span{color:var(--sky)}
@media(max-width:900px){.catgrid{grid-template-columns:1fr;gap:44px}.catgrid.flip{grid-template-columns:1fr}.catgrid.flip .catmedia{order:0}}
/* stacking panels — each block pins at the top, the next slides up over it; after the last, normal scroll resumes */
.stack{position:relative}
.stackpanel{position:sticky;top:0;min-height:100vh;display:flex;align-items:center;padding:90px 0;background:var(--paper)}
.stackpanel.navyband{background-color:var(--navy)}
.stackpanel:last-child{position:relative}
.spgrid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(44px,6vw,90px);align-items:center;width:100%}
.spgrid h2{margin-top:14px}
.spgrid .lede{margin-top:20px}
@media(max-width:900px){.spgrid{grid-template-columns:1fr;gap:34px}.stackpanel{position:relative;min-height:0;padding:64px 0}}
section.seccard{background:var(--paper);padding:clamp(96px,11vw,140px) 0}
section.sectint{background:var(--grey);padding:clamp(96px,11vw,140px) 0}
section.seccard+section.seccard, section.sectint+section.seccard{margin-top:14px}
/* ghost numeral — quiet structure instead of loud labels */
.secnum{position:absolute;top:44px;right:4vw;font-family:var(--fh);font-weight:600;font-size:clamp(120px,15vw,220px);line-height:1;color:rgba(5,4,58,.045);letter-spacing:-.02em;pointer-events:none;user-select:none}


/* ===== MOTION (KOTA adoption, restrained) ===== */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}
h2.rv{transition-duration:.9s}
.btn{position:relative}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(5,4,58,.16)}
.cardx{transition:.3s cubic-bezier(.16,1,.3,1)}
.cardx:hover{transform:translateY(-4px)}
.tcard:hover{transform:translateY(-4px)}
.ind:hover{padding-left:14px;transition:padding .3s cubic-bezier(.16,1,.3,1)}
.nav-links span{position:relative}
.nav-links span::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--blue);transition:width .25s}
.nav-links span:hover::after{width:100%}
@media (prefers-reduced-motion: reduce){.rv{opacity:1;transform:none;transition:none}}


/* ============ PAGE COMPONENTS (verticals, form, stories, faq) ============ */
.page-hero{padding:14px 14px 0}
.page-hero .hero-card{padding:110px 0 90px}
.page-hero h1{font-size:clamp(42px,5.4vw,80px);max-width:980px}
.inline-cta{display:inline-flex;align-items:center;gap:10px;color:var(--blue);font-weight:600;font-size:16px;margin-top:26px;text-decoration:none;transition:gap .25s cubic-bezier(.16,1,.3,1)}
.inline-cta:hover{gap:16px}
/* nooks */
::selection{background:var(--navy);color:var(--paper)}
.ind .arr{transition:transform .35s cubic-bezier(.16,1,.3,1),background .25s,color .25s}
.ind.open .arr{transform:rotate(180deg)}
html{scrollbar-width:thin;scrollbar-color:rgba(5,4,58,.3) transparent}
.painblock{border-top:2px solid var(--navy);padding:50px 0 66px;display:grid;grid-template-columns:1fr 1fr;gap:54px}
.painblock h3{font-family:var(--fh);font-weight:600;font-size:clamp(30px,3.8vw,46px);max-width:460px;line-height:1.1}
.painblock .body p{color:var(--muted);font-size:18.5px;margin-bottom:18px}
/* buyer questions — bold open text with a ledger-bar marker (no box) */
.qa{background:none;border:none;border-radius:0;padding:22px 0 0;margin-top:30px;font-weight:600;font-size:clamp(18px,1.6vw,21px);line-height:1.45;color:var(--navy);position:relative;max-width:540px}
.qa::before{content:"How can I — ";color:var(--blue)}
.qa::after{content:'';position:absolute;top:0;left:0;width:36px;height:10px;border-radius:5px;background:var(--blue)}
@media(max-width:860px){.painblock{grid-template-columns:1fr}}
.think{background:var(--navy);border-radius:0 24px 24px 24px;padding:54px 48px;color:var(--paper);margin-top:30px}
.think h3{font-family:var(--fh);font-size:clamp(34px,4.6vw,62px);max-width:760px;line-height:1.08;color:#fff}
.think p{color:rgba(255,255,255,.72);margin-top:20px;max-width:680px;font-size:clamp(17px,1.5vw,19px)}
.think .pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.think .pill{border:1px solid rgba(255,255,255,.3);border-radius:100px;padding:7px 16px;font-size:13.5px}
.storycard{display:grid;grid-template-columns:1fr;gap:0;background:var(--grey);border:none;border-radius:0 24px 24px 24px;overflow:hidden;margin-top:30px;text-decoration:none;color:var(--navy);transition:.3s cubic-bezier(.16,1,.3,1)}
.storycard:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(5,4,58,.1)}
.storycard .media{background:var(--navy);min-height:240px;display:flex;align-items:center;justify-content:center;padding:30px}
.storycard .body{padding:44px}
.storycard .meta{display:flex;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.08em;color:var(--blue);text-transform:uppercase;margin-bottom:12px}
.storycard h3{font-family:var(--fh);font-weight:600;font-size:24px;line-height:1.25}
.storycard p{color:var(--muted);font-size:17px;margin-top:10px}
.storycard .go{margin-top:18px;font-weight:600;font-size:14.5px;color:var(--blue)}
@media(max-width:820px){.storycard{grid-template-columns:1fr}}
.faq{background:transparent;border:none;border-radius:0;border-bottom:1px solid var(--line);margin-top:0;overflow:hidden;box-shadow:none}
.faq summary{padding:28px 4px;font-weight:500;font-size:18.5px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::after{content:"↓";font-size:18px;color:var(--blue);font-weight:400;transition:transform .35s cubic-bezier(.16,1,.3,1);flex-shrink:0}
.faq[open] summary::after{transform:rotate(180deg)}
.faq .a{padding:0 4px 28px;color:var(--muted);font-size:18px;max-width:740px}
.navyband .faq{border-color:var(--line-l)}
.navyband .faq summary{color:#FFFFFF}
.navyband .faq summary::after{color:var(--sky)}
.navyband .faq .a{color:rgba(255,255,255,.75)}
.navyband .sub{color:rgba(255,255,255,.78)}
.formgrid{display:grid;gap:14px;max-width:560px;margin-top:36px}
.formgrid label{font-size:13.5px;font-weight:600;letter-spacing:.04em}
.formgrid input,.formgrid textarea{font-family:var(--fb);font-size:15.5px;padding:15px 18px;border:1px solid var(--line);border-radius:0 12px 12px 12px;background:#fff;color:var(--navy);outline:none;width:100%}
.formgrid input:focus,.formgrid textarea:focus{border-color:var(--blue)}
.formgrid .hp{position:absolute;left:-9999px;opacity:0}
.formnote{font-size:15.5px;color:var(--muted);margin-top:14px;max-width:500px}
.success{display:none;background:#fff;border:1px solid var(--line);border-radius:0 16px 16px 16px;padding:34px;max-width:560px;margin-top:36px}
.success h3{font-family:var(--fh);font-size:24px}
.values5{display:grid;grid-template-columns:1fr;margin-top:44px;border-top:1px solid var(--line)}
.values5 .v{border-bottom:1px solid var(--line);padding:clamp(28px,3.2vw,40px) 4px;display:grid;grid-template-columns:54px minmax(240px,340px) 1fr;gap:14px 32px;align-items:center}
.values5 .v h4{margin:0;font-family:var(--fh);font-weight:600;font-size:clamp(22px,2.3vw,30px);letter-spacing:-.01em;line-height:1.18}
.values5 .v p{margin:0;font-size:17px;color:var(--muted)}
.values5 h4{font-size:16px;font-weight:600}
.values5 p{font-size:13px;color:var(--muted)}
@media(max-width:700px){.values5 .v{grid-template-columns:42px 1fr}.values5 .v p{grid-column:2}}
.steps4{display:grid;gap:14px;margin-top:44px}
.step4{background:transparent;border:none;border-top:2px solid var(--navy);border-radius:0;padding:26px 4px 0;display:grid;grid-template-columns:90px 1fr 1.2fr;gap:24px;align-items:start;transition:border-color .25s}
.step4:hover{border-top-color:var(--blue)}
.step4 .sn{font-size:13px;font-weight:600;color:var(--blue);letter-spacing:.1em}
.step4 h3{font-family:var(--fh);font-size:22px}
.step4 ul{list-style:none;display:grid;gap:8px;font-size:16px;color:var(--muted)}
.step4 li{padding-left:20px;position:relative}
.step4 li::before{content:"";position:absolute;left:0;top:9px;width:11px;height:2px;background:var(--blue)}
@media(max-width:860px){.step4{grid-template-columns:1fr}}
.offer{background:var(--paper);border:none;border-radius:0;padding:30px 4px 26px;margin-top:24px;border-top:2px solid var(--accent,var(--navy));transition:border-color .25s}
.offer h3{font-family:var(--fh);font-size:26px}
.offer .inc{margin-top:18px;display:grid;gap:8px;list-style:none;font-size:16.5px;color:var(--muted)}
.offer .inc li{padding-left:22px;position:relative}
.offer .inc li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:2px;background:var(--accent,var(--blue))}

/* ============ INSIGHTS / ARTICLES ============ */
.artgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px 26px;margin-top:44px}
.artcard{background:transparent;border:none;border-radius:0;padding:0;text-decoration:none;color:var(--navy);display:block}
.artcover{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:0 24px 24px 24px;border:1px solid var(--line);margin:0 0 20px;transition:transform .45s cubic-bezier(.16,1,.3,1)}
.artcard:hover .artcover{transform:translateY(-6px)}
.catpill{display:inline-block;border:1.5px solid;padding:6px 16px;border-radius:100px;font-size:13px;font-weight:600;letter-spacing:.02em;background:#fff}
.cat-dl{color:var(--blue);border-color:rgba(37,56,184,.45)}
.cat-comp{color:#D6532E;border-color:rgba(255,114,79,.55)}
.cat-ai{color:#2E7CC9;border-color:rgba(103,177,255,.6)}
.cat-plat{color:var(--navy);border-color:rgba(5,4,58,.35)}
.artcard h3{font-family:var(--fh);font-weight:600;font-size:21px;line-height:1.3;margin-top:13px}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-top:36px}
.fpill{border:1.5px solid rgba(5,4,58,.25);background:#fff;color:var(--navy);border-radius:100px;padding:10px 22px;font-family:var(--fb);font-weight:500;font-size:15px;cursor:pointer;transition:.25s}
.fpill:hover{border-color:var(--navy)}
.fpill.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.artcard p{color:var(--muted);font-size:16px;margin-top:9px}
.artcard .go{margin-top:16px;font-weight:600;font-size:14px;color:var(--blue)}
@media(max-width:1020px){.artgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.artgrid{grid-template-columns:1fr}}
.article{max-width:760px;margin:0 auto;padding:0 28px}
.article .meta{font-size:13px;font-weight:600;letter-spacing:.08em;color:var(--blue);text-transform:uppercase}
.article h1{font-size:clamp(34px,4.6vw,56px);margin-top:14px;line-height:1.12}
.article .standfirst{font-size:19px;color:var(--muted);margin-top:18px;line-height:1.55}
.article h2{font-family:var(--fh);font-weight:600;font-size:28px;margin:44px 0 14px}
.article p{font-size:18.5px;color:#2A2A45;margin-top:16px;line-height:1.7}
.article .pull{font-family:var(--fh);font-weight:600;font-size:24px;line-height:1.45;border-left:3px solid var(--blue);padding-left:22px;margin:36px 0;color:var(--navy)}
.article ul{margin:16px 0 0 20px;color:#2A2A45;font-size:17.5px;display:grid;gap:8px}
.article .note{background:#fff;border:1px solid var(--line);border-radius:0 14px 14px 14px;padding:20px 24px;font-size:15px;color:var(--muted);margin-top:28px}
.article .svcline{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);font-size:14.5px;color:var(--muted)}
.article .svcline a{color:var(--blue);font-weight:600}
/* badge row */
.badgerow{display:flex;gap:26px;align-items:center;flex-wrap:wrap;margin-top:34px}
.badgerow img{height:52px;width:auto}
.badgerow .b-note{font-size:13px;color:var(--muted)}
/* AI page stack cards */
.stackgrid{display:grid;grid-template-columns:1fr;gap:0;margin-top:44px;border-top:1px solid var(--line)}
.stackcard{background:transparent;border:none;border-bottom:1px solid var(--line);border-radius:0;padding:clamp(28px,3.2vw,42px) 4px;display:grid;grid-template-columns:130px minmax(230px,330px) 1fr;gap:14px 32px;align-items:start}
.stackcard .k{font-size:12.5px;font-weight:600;letter-spacing:.12em;color:var(--blue);text-transform:uppercase;padding-top:8px}
.stackcard h4{font-family:var(--fh);font-weight:600;font-size:clamp(22px,2.3vw,30px);letter-spacing:-.01em;margin:0;line-height:1.18}
.stackcard p{font-size:16.5px;color:var(--muted);margin:0;line-height:1.55}
@media(max-width:760px){.stackcard{grid-template-columns:1fr;gap:8px}}
@media(max-width:920px){.stackgrid{display:grid;grid-template-columns:1fr;gap:0;margin-top:44px;border-top:1px solid var(--line)}}
.guard{display:grid;grid-template-columns:1fr;gap:0;margin-top:40px;border-top:1px solid var(--line)}
.guard .g{border-bottom:1px solid var(--line);padding:clamp(28px,3.2vw,42px) 4px;display:grid;grid-template-columns:minmax(260px,380px) 1fr;gap:14px 32px;align-items:start}
.guard .g h4{font-family:var(--fh);font-weight:600;font-size:clamp(22px,2.3vw,30px);margin:0;letter-spacing:-.01em;line-height:1.18}
.guard .g p{margin:0}
@media(max-width:760px){.guard .g{grid-template-columns:1fr}}
.guard h4{font-size:16.5px;font-weight:600}
.guard p{font-size:14px;color:var(--muted);margin-top:6px}


/* ============ ILLUSTRATION DRAW-IN (spec v2 — the line-draw moment) ============
   SVGs mark structure paths .d (draw), solid anchors .f (fill pop), chart bars .r (rise).
   Stagger waves: .s2 .s3 .s4. Container needs [data-anim]; JS adds .anim on scroll. */
[data-anim] svg .d{stroke-dasharray:720;stroke-dashoffset:720}
[data-anim] svg .f{opacity:0;transform:scale(.55);transform-origin:center}
[data-anim] svg .r{opacity:0;transform:translateY(26px);transform-origin:center}
[data-anim].anim svg .d{animation:evspDash 1.3s cubic-bezier(.45,0,.15,1) forwards}
[data-anim].anim svg .f{animation:evspPop .65s cubic-bezier(.16,1,.3,1) forwards}
[data-anim].anim svg .r{animation:evspRise .7s cubic-bezier(.16,1,.3,1) forwards}
[data-anim].anim svg .s2{animation-delay:.4s}
[data-anim].anim svg .s3{animation-delay:.85s}
[data-anim].anim svg .s4{animation-delay:1.15s}
@keyframes evspDash{to{stroke-dashoffset:0}}
@keyframes evspPop{to{opacity:1;transform:scale(1)}}
@keyframes evspRise{to{opacity:1;transform:translateY(0)}}
@keyframes evspNudge{0%,100%{transform:scale(1)}45%{transform:scale(1.07)}}
@media (prefers-reduced-motion: reduce){
  [data-anim] svg .d{stroke-dasharray:none;stroke-dashoffset:0}
  [data-anim] svg .f,[data-anim] svg .r{opacity:1;transform:none}
  [data-anim].anim svg .d,[data-anim].anim svg .f,[data-anim].anim svg .r{animation:none}
}

/* accordion body entrance */
.ind-body.pop{animation:evspBody .5s cubic-bezier(.16,1,.3,1)}
@keyframes evspBody{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ===== STYLE GUIDE PAGE (/brand) ===== */
.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-top:40px}
.sw{border-radius:0 18px 18px 18px;padding:18px;height:140px;display:flex;flex-direction:column;justify-content:flex-end;font-size:13.5px;font-weight:600;line-height:1.35}
.sw small{font-weight:400;opacity:.75}
.typerow{border-top:1px solid var(--line);padding:26px 0;display:grid;grid-template-columns:230px 1fr;gap:24px;align-items:baseline}
.typerow .tl{font-size:13px;color:var(--muted);font-weight:600;letter-spacing:.06em}
.glyphrow{display:flex;gap:34px;flex-wrap:wrap;margin-top:36px;align-items:flex-end}
.glyphrow figure{display:grid;gap:8px;justify-items:center}
.glyphrow img{width:56px;height:56px}
.glyphrow figcaption{font-size:12px;color:var(--muted);letter-spacing:.04em}
.logorow{display:flex;gap:18px;flex-wrap:wrap;margin-top:36px;align-items:stretch}
.logorow .cell{border-radius:0 18px 18px 18px;padding:40px 48px;display:flex;align-items:center;justify-content:center;min-height:120px}
.specimen{background:#fff;border-radius:0 22px 22px 22px;padding:48px;margin-top:36px;box-shadow:0 1px 2px rgba(5,4,58,.04)}
.rulelist{margin-top:30px;display:grid;gap:12px}
.rulelist .rule{display:flex;gap:14px;font-size:16px;align-items:baseline}
.rulelist .rule::before{content:"—";color:var(--blue);font-weight:600}

/* ===== ILLUSTRATION SYSTEM (monogram DNA: bar grid, rx ends, ledger-line accent) ===== */
.glyph{display:block;width:44px;height:44px;margin-bottom:18px}
.glyph.g-sm{width:36px;height:36px;margin-bottom:14px}
.ctablock,.think{position:relative;overflow:hidden}

/* ===== MOTION DESIGN (full choreography) ===== */
/* hero headline — word-by-word reveal (JS splits; CSS animates) */
.hero h1.split{opacity:1;transform:none;animation:none}
.hero h1 .w{display:inline-block;transform:translateY(110%);opacity:0;animation:evspWord .85s cubic-bezier(.16,1,.3,1) forwards}
@keyframes evspWord{to{transform:none;opacity:1}}
/* glyphs respond to their card */
.glyph{transition:transform .4s cubic-bezier(.16,1,.3,1)}
.offer:hover .glyph,.v:hover .glyph{transform:translateY(-5px) rotate(-5deg)}
/* Solutions — offers stack and pin as you scroll (one card over the last) */
.offerstack .offer{position:sticky;top:104px}
.offerstack .offer:nth-of-type(2){top:126px}
.offerstack .offer:nth-of-type(3){top:148px}
@media(max-width:860px){.offerstack .offer{position:static}}
@media (prefers-reduced-motion: reduce){.hero h1 .w{transform:none;opacity:1;animation:none}.offerstack .offer{position:static}}

/* hero load-in (no-scroll-needed first impression) */
.hero h1,.hero .sub,.hero .ctas,.hero .proof,.hero .badgerow{opacity:0;transform:translateY(28px);animation:evspHero .9s cubic-bezier(.16,1,.3,1) forwards}
.hero .sub{animation-delay:.15s}.hero .ctas{animation-delay:.28s}.hero .proof{animation-delay:.4s}.hero .badgerow{animation-delay:.5s}
@keyframes evspHero{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){.hero h1,.hero .sub,.hero .ctas,.hero .proof,.hero .badgerow{opacity:1;transform:none;animation:none}}

/* vertical slides — looped-wipe stack (GSAP demo grammar): each block wipes up over the last */
.vslides{position:relative;margin-top:56px}
.vslide{position:relative;overflow:hidden}
.vslide .vouter,.vslide .vinner{width:100%;height:100%}
.vslides.on{height:100vh;overflow:hidden}
.vslides.on .vslide{position:absolute;inset:0}
.vslides.on .vouter{height:100%;overflow:hidden}
.vslides.on .vinner{height:100%;display:flex;align-items:center}
.vslide{display:flex;align-items:center;padding:84px 0}
.vslides.on .vslide{padding:0}
.vs-navy{background:var(--navy);color:#fff}
.vs-navy .vline{color:rgba(255,255,255,.75)}
.vs-navy .chip{background:rgba(255,255,255,.08);color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.18)}
.vs-navy .inline-cta{color:var(--sky)}
.vs-light{background:var(--grey)}
.vcontent{position:relative;width:100%;padding-right:clamp(170px,24vw,360px)}
.vghost{position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:var(--fh);font-weight:600;font-size:clamp(140px,19vw,300px);line-height:1;opacity:.05;pointer-events:none;user-select:none}
.vtitle{font-family:var(--fh);font-weight:600;font-size:clamp(46px,7vw,104px);letter-spacing:-.025em;line-height:1.02;max-width:14ch}
.vline{font-size:clamp(18px,1.6vw,21px);color:var(--muted);max-width:520px;margin-top:22px}
.vslide .chips{margin-top:26px}
.vslide .inline-cta{margin-top:26px;display:inline-block}
.vcount{position:absolute;right:0;bottom:-44px;font-size:13px;font-weight:600;letter-spacing:.12em;opacity:.55}
.vslides.on .vcount{bottom:auto;top:0}
@media(max-width:900px){.vghost{display:none}.vcontent{padding-right:0}}

/* horizontal testimonial gallery — section pins, vertical scroll drives the strip sideways */
.hwrap{margin-top:48px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}
.hwrap::-webkit-scrollbar{display:none}
.hwrap.on{overflow:hidden}
.htrack{display:flex;gap:22px;width:max-content;padding:0 max(28px,calc((100vw - 1124px)/2))}
.htrack .tcard{width:min(520px,82vw);flex-shrink:0}

.hctrl{display:flex;gap:12px;justify-content:flex-end;margin-top:30px}
.harrow{width:54px;height:54px;border-radius:50%;border:1.5px solid var(--line);background:#fff;font-size:20px;color:var(--navy);cursor:pointer;transition:.25s cubic-bezier(.16,1,.3,1)}
.harrow:hover:not(:disabled){background:var(--navy);color:#fff;border-color:var(--navy)}
.harrow:disabled{opacity:.25;cursor:default}
.hctrl.center{justify-content:center}

/* single-testimonial block — one voice at a time, arrows to move */
.tsolo{background:var(--grey);border-radius:0 36px 36px 36px;margin-top:52px;padding:clamp(64px,8vw,110px) clamp(28px,7vw,100px);text-align:center}
.tview{display:none}
.tview.cur{display:block}
.tsolo .q{font-family:var(--fh);font-weight:600;font-size:clamp(23px,2.7vw,38px);line-height:1.32;letter-spacing:-.01em;color:var(--navy);max-width:900px;margin:0 auto}
.tsolo .q::before{content:"\201C";color:var(--blue);margin-right:2px}
.tsolo .who{margin-top:36px;font-size:16.5px;color:var(--muted)}
.tsolo .who b{color:var(--navy);display:block;font-size:17.5px;margin-bottom:4px}

/* footer newsletter (Futureform grammar, EVSP skin) */
.f-news{max-width:380px}
.f-blurb{font-size:15.5px;color:rgba(255,255,255,.6);margin-top:20px;line-height:1.55}
.newsform{margin-top:24px}
.newsform label{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:8px}
.newsform input{width:100%;max-width:330px;height:52px;border-radius:100px;border:none;padding:0 22px;font-family:var(--fb);font-size:16px;color:var(--navy);background:#fff;display:block}
.newsform input:focus{outline:2px solid var(--sky)}
.nbtn{margin-top:14px;background:transparent;border:1.5px solid rgba(255,255,255,.7);color:#fff;border-radius:100px;padding:12px 30px;font-family:var(--fb);font-weight:500;font-size:15.5px;cursor:pointer;transition:.25s}
.nbtn:hover{background:#fff;color:var(--navy)}
.f-note{font-size:13px;color:rgba(255,255,255,.45);margin-top:16px}
.f-note a{color:rgba(255,255,255,.6)}

/* offer index — number / serif title / one-liner / arrow; whole row is the link */
.oindex{margin-top:48px;border-top:1px solid var(--line)}
.orow{display:grid;grid-template-columns:56px 280px 1fr 40px;gap:28px;align-items:center;padding:32px 4px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--navy);transition:padding .3s cubic-bezier(.16,1,.3,1)}
.orow:hover{padding-left:18px}
.onum{font-size:13px;font-weight:600;color:var(--blue);letter-spacing:.08em}
.otitle{font-family:var(--fh);font-weight:600;font-size:clamp(22px,2.3vw,31px);letter-spacing:-.01em;line-height:1.15}
.odesc{font-size:16.5px;color:var(--muted);line-height:1.5;max-width:580px}
.oarr{font-size:21px;color:var(--blue);justify-self:end;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.orow:hover .oarr{transform:translateX(7px)}
@media(max-width:900px){.orow{grid-template-columns:40px 1fr;gap:10px 18px}.odesc{grid-column:2}.oarr{display:none}}

/* contact form card */
.formcard{background:var(--grey);border-radius:0 24px 24px 24px;padding:clamp(26px,3vw,40px)}
@media(max-width:900px){.formcard{margin-top:10px}}

/* brand colour rotation on row markers — blue, coral, sky, navy, repeat */
.oindex .orow:nth-child(4n+1) .onum,.oindex .orow:nth-child(4n+1) .oarr,
.cards4 .cardx:nth-child(4n+1) .num,.cards3 .cardx:nth-child(4n+1) .num,
.stackgrid .stackcard:nth-child(4n+1) .k,.svc li:nth-child(4n+1) span{color:var(--blue)}
.oindex .orow:nth-child(4n+2) .onum,.oindex .orow:nth-child(4n+2) .oarr,
.cards4 .cardx:nth-child(4n+2) .num,.cards3 .cardx:nth-child(4n+2) .num,
.stackgrid .stackcard:nth-child(4n+2) .k,.svc li:nth-child(4n+2) span{color:var(--coral)}
.oindex .orow:nth-child(4n+3) .onum,.oindex .orow:nth-child(4n+3) .oarr,
.cards4 .cardx:nth-child(4n+3) .num,.cards3 .cardx:nth-child(4n+3) .num,
.stackgrid .stackcard:nth-child(4n+3) .k,.svc li:nth-child(4n+3) span{color:var(--sky)}
.oindex .orow:nth-child(4n) .onum,.oindex .orow:nth-child(4n) .oarr,
.cards4 .cardx:nth-child(4n) .num,.cards3 .cardx:nth-child(4n) .num,
.stackgrid .stackcard:nth-child(4n) .k,.svc li:nth-child(4n) span{color:var(--navy)}
.navyband .svc li:nth-child(4n) span{color:#fff}

/* row interactions — one behaviour everywhere the pattern lives:
   nudge right, hairline sharpens, marker brightens; linking rows also slide their arrow */
.cardx,.stackcard,.guard .g,.values5 .v{transition:padding .35s cubic-bezier(.16,1,.3,1),border-color .35s}
.cardx:hover,.stackcard:hover,.guard .g:hover,.values5 .v:hover{padding-left:18px;border-bottom-color:rgba(5,4,58,.42)}
.orow:hover{border-bottom-color:rgba(5,4,58,.42)}
.svc li:hover{border-bottom-color:rgba(5,4,58,.42)}
.navyband .svc li:hover{border-bottom-color:rgba(255,255,255,.45)}
.cardx .num,.stackcard .k,.svc li span,.orow .onum{transition:transform .35s cubic-bezier(.16,1,.3,1)}
.cardx:hover .num,.stackcard:hover .k,.svc li:hover span,.orow:hover .onum{transform:translateX(4px) scale(1.08)}
@media (prefers-reduced-motion: reduce){
  .cardx:hover,.stackcard:hover,.guard .g:hover,.values5 .v:hover{padding-left:4px}
  .cardx:hover .num,.stackcard:hover .k,.svc li:hover span,.orow:hover .onum{transform:none}
}

/* THE ARCHITECT'S HAND — annotation layer: Financier italic + drawn coral strokes on the typeset page */
.anno{font-family:var(--fh);font-style:italic;font-size:19px;line-height:1.4;color:#D6532E;max-width:250px;transform:rotate(-1.6deg);margin-top:26px}
.anno svg{display:block;width:46px;height:auto;margin-bottom:6px}
.anno-up svg{transform:scaleY(-1)}
.anno-em{position:relative;white-space:nowrap}
.anno-em::after{content:'';position:absolute;left:0;right:0;bottom:-.08em;height:.14em;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 12' preserveAspectRatio='none'%3E%3Cpath d='M3 8c60-5 120-4 180-3 40 1 80 1 114-2' fill='none' stroke='%23FF724F' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E") center/100% 100% no-repeat;transform:scaleX(0);transform-origin:left;animation:evspInk .9s cubic-bezier(.45,0,.15,1) 1.15s forwards}
@keyframes evspInk{to{transform:scaleX(1)}}
.sig{margin-top:34px}
.sig-name{font-family:var(--fh);font-style:italic;font-weight:600;font-size:36px;color:var(--navy);letter-spacing:-.01em;display:block}
.sig svg{display:block;width:200px;height:14px;margin-top:2px}
.sig-role{display:block;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px;font-family:var(--fb);font-style:normal}
@media (prefers-reduced-motion: reduce){.anno-em::after{animation:none;transform:scaleX(1)}}

.cat-rb{color:#2E7CC9;border-color:rgba(103,177,255,.6)}
.cat-cb{color:var(--blue);border-color:rgba(37,56,184,.45)}
.cat-cib{color:var(--navy);border-color:rgba(5,4,58,.35)}


/* pen physics — strokes draw with hand speed, ink lands with a press-blob */
[data-anim] svg .ink{stroke-dasharray:1;stroke-dashoffset:1}
[data-anim].anim svg .ink{animation:evspPen .85s cubic-bezier(.55,.06,.28,.99) forwards}
[data-anim] svg .blob{opacity:0;transform:scale(.2);transform-origin:center}
[data-anim].anim svg .blob{animation:evspBlob .22s cubic-bezier(.16,1,.3,1) forwards}
@keyframes evspPen{to{stroke-dashoffset:0}}
@keyframes evspBlob{to{opacity:1;transform:scale(1)}}
.anno{cursor:default}
.sig-init{font-size:15px;opacity:.75;margin-left:6px}
@media (prefers-reduced-motion: reduce){[data-anim] svg .ink{stroke-dashoffset:0}[data-anim] svg .blob{opacity:1;transform:none}}

.think .sig-name{color:#fff}
.think .sig-role{color:rgba(255,255,255,.6)}

/* MOBILE NAV — hamburger + full-screen menu (<=920px) */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:6px;width:44px;height:44px;background:none;border:none;cursor:pointer;margin-left:12px;padding:10px}
.nav-burger span{display:block;height:2.5px;width:24px;background:var(--navy);border-radius:2px;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .2s}
.nav-burger.open span:first-child{transform:translateY(4.2px) rotate(45deg)}
.nav-burger.open span:last-child{transform:translateY(-4.2px) rotate(-45deg)}
@media(max-width:920px){.nav-burger{display:flex}.nav-i .btn{padding:9px 16px!important;font-size:13px!important;white-space:nowrap}}
@media(max-width:600px){.nav-i>.btn{display:none}.nav-i img{height:16px}.nav-i{height:68px}
  body>a[href="/contact"][style*="fixed"]{padding:11px 18px!important;font-size:13px!important;right:16px!important}}
.mnav{position:fixed;inset:0;background:var(--paper);z-index:49;padding:118px 28px 44px;overflow:auto;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .35s cubic-bezier(.16,1,.3,1),transform .35s cubic-bezier(.16,1,.3,1),visibility .35s}
.mnav.open{opacity:1;visibility:visible;transform:none}
.mnav-in{display:flex;flex-direction:column;max-width:520px;margin:0 auto}
.mnav-label{font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin:26px 0 6px}
.mnav-label:first-child{margin-top:0}
.mnav a:not(.btn){font-family:var(--fh);font-weight:600;font-size:clamp(27px,6.4vw,38px);letter-spacing:-.015em;color:var(--navy);text-decoration:none;padding:9px 0;border-bottom:1px solid var(--line);opacity:0;transform:translateY(14px);transition:opacity .45s cubic-bezier(.16,1,.3,1),transform .45s cubic-bezier(.16,1,.3,1)}
.mnav.open a:not(.btn){opacity:1;transform:none}
.mnav.open a:nth-of-type(1){transition-delay:.04s}.mnav.open a:nth-of-type(2){transition-delay:.08s}.mnav.open a:nth-of-type(3){transition-delay:.12s}.mnav.open a:nth-of-type(4){transition-delay:.16s}.mnav.open a:nth-of-type(5){transition-delay:.2s}.mnav.open a:nth-of-type(6){transition-delay:.24s}.mnav.open a:nth-of-type(7){transition-delay:.28s}.mnav.open a:nth-of-type(8){transition-delay:.32s}.mnav.open a:nth-of-type(9){transition-delay:.36s}.mnav.open a:nth-of-type(10){transition-delay:.4s}
body.mnav-lock{overflow:hidden}
body.mnav-lock>a[href="/contact"][style*="fixed"]{display:none}
@media (prefers-reduced-motion: reduce){.mnav,.mnav a:not(.btn){transition:none;transform:none}}

/* MOBILE PASS — stack inline grids, scale sections and heroes for phones */
@media(max-width:880px){
  .wrap[style*="grid-template-columns"]{display:block!important}
  .wrap[style*="grid-template-columns"]>*+*{margin-top:36px}
  .painblock{grid-template-columns:1fr;gap:18px;padding:40px 0 48px}
  .statrow{grid-template-columns:1fr!important;gap:36px!important}
}
@media(max-width:700px){
  section{padding:72px 0}
  .hero-card{padding:96px 0 72px}
  .hero h1{font-size:clamp(38px,10.5vw,52px)}
  h2{font-size:clamp(32px,8.4vw,40px)}
  .statement{font-size:clamp(44px,13vw,62px)}
  .lede{font-size:18.5px}
  .talk{padding:64px 0}
  .talk h2{font-size:clamp(40px,11vw,52px)}
  .anno-em{white-space:normal}
  .anno-em::after{display:none}
  .f-cols{gap:30px 38px}
  .svc li{font-size:16.5px;gap:14px}
  .oindex .otitle{font-size:22px}
  .stackpanel{padding:56px 0}
  .vtitle{font-size:clamp(34px,9.5vw,46px)}
  .tsolo .q{font-size:20px}
}

/* COLOUR FIELDS — sections as colour, navy ink on everything (Payz grammar, EVSP palette) */
.f-sky{background:var(--t-sky)}
.f-coral{background:var(--t-coral)}
.f-lemon{background:var(--t-lemon)}
.f-coral .eyebrow{color:#D6532E}
.f-coral .tsolo,.f-coral .storycard,.f-sky .formcard{background:#fff}
/* the coral full stop — every hero headline signed by the brand disc */
.hero h1::after{content:'';display:inline-block;width:.16em;height:.16em;border-radius:50%;background:var(--coral);margin-left:.1em;vertical-align:.02em}
/* scroll colour morph: when active, light sections go transparent and the body interpolates */
footer{position:relative;z-index:2}

/* persistent CTA — fixed at top right; takes over the moment the nav bar hides */
body>a[href="/contact"][style*="fixed"]{top:16px!important;bottom:auto!important;right:24px!important;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .35s cubic-bezier(.16,1,.3,1),transform .35s cubic-bezier(.16,1,.3,1)}
body.navhid>a[href="/contact"][style*="fixed"]{opacity:1;pointer-events:auto;transform:none}
