/* =========================================================
   Triple Nine : brand stylesheet (v2)
   Single soft warm-white base. Colour lives in the hero,
   the final CTA, and large soft swirl washes only.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --mango:#FA7B47;
  --mango-deep:#FB6A33;
  --azalea:#E63B82;
  --violet:#780CD6;
  --azure:#11028E;
  --aqua:#57EBDE;

  --base:#FBF8F9;        /* single soft warm-white base */
  --paper:#FFFFFF;
  --ink:#1A0B2E;
  --muted:#6E6677;
  --line:rgba(120,12,214,.12);
  --line-soft:rgba(26,11,46,.07);

  /* signature gradient: coral -> pink, gradual with soft mid-tone */
  --grad-signature:linear-gradient(118deg,#FA7B47 0%,#F4607C 48%,#E63B82 100%);
  --grad-deep:linear-gradient(125deg,#FA7B47 0%,#E63B82 44%,#9B2BC4 78%,#780CD6 100%);
  --grad-text:linear-gradient(100deg,#FA7B47 0%,#E63B82 100%);

  --radius:18px;
  --radius-lg:24px;
  --shadow-card:0 14px 40px -26px rgba(26,11,46,.28);
  --shadow-soft:0 18px 50px -28px rgba(120,12,214,.28);

  --container:1180px;
  --pad:clamp(20px,5vw,40px);
  --section-y:clamp(66px,9vw,120px);

  --font-head:"Poppins",system-ui,sans-serif;
  --font-body:"Mulish",system-ui,sans-serif;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--base);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.08;color:var(--ink);font-weight:800}
h1{font-size:clamp(2.2rem,4.8vw,3.5rem);font-weight:900;letter-spacing:-.015em}
h2{font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:800;letter-spacing:-.01em}
h3{font-size:clamp(1.18rem,1.9vw,1.45rem);font-weight:700}
p{max-width:62ch}
.lead{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--muted);line-height:1.6}
.eyebrow{font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--azalea)}
.hl{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.hl-violet{color:var(--violet)}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
section{position:relative;overflow:hidden}
.section{padding-block:var(--section-y)}
.center{text-align:center}
.section-head{max-width:44rem}
.section-head.center{margin-inline:auto}
.section-head p{max-width:none}
.section>.container{position:relative;z-index:2}

/* gentle separation: occasional pure-white section on the warm-white base */
.band-alt{background:var(--paper)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-head);font-weight:700;font-size:1rem;
  padding:.85em 1.6em;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;
  line-height:1;white-space:nowrap;
}
.btn:focus-visible{outline:3px solid var(--violet);outline-offset:3px}
.btn-primary{background:var(--grad-signature);color:#fff;box-shadow:0 14px 30px -14px rgba(230,59,130,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 38px -14px rgba(230,59,130,.8)}
.btn-on-grad{background:#fff;color:var(--azalea)}
.btn-on-grad:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(0,0,0,.35)}
.btn-outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-outline-light{background:transparent;border-color:rgba(255,255,255,.7);color:#fff}
.btn-outline-light:hover{background:#fff;color:var(--azalea)}
.btn-lg{font-size:1.06rem;padding:1em 1.9em}
.arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(3px)}

.tlink{font-family:var(--font-head);font-weight:700;color:var(--violet);
  display:inline-flex;align-items:center;gap:.4em}
.tlink .arrow{transition:transform .18s ease}
.tlink:hover{color:var(--azalea)}
.tlink:hover .arrow{transform:translateX(4px)}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,248,249,.85);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px}
.nav .logo img{height:30px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none}
.nav-links a{font-family:var(--font-head);font-weight:600;font-size:.96rem;color:var(--ink);
  position:relative;padding:.3em 0}
.nav-links a:hover{color:var(--azalea)}
.nav-links a[aria-current="page"]{color:var(--azalea)}
.nav-links a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;
  height:2px;background:var(--grad-text);border-radius:2px}
.has-sub{position:relative}
.submenu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(6px);
  background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-soft);
  padding:.5rem;min-width:250px;opacity:0;visibility:hidden;transition:.18s ease;list-style:none}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu a{display:block;padding:.6rem .8rem;border-radius:10px;font-weight:600;font-size:.92rem}
.submenu a small{display:block;font-family:var(--font-body);font-weight:400;color:var(--muted);font-size:.8rem;margin-top:.1rem}
.submenu a:hover{background:var(--base)}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.2s}

/* ---------- Soft swirl washes (the "colour coverage" blobs) ---------- */
.swirl{position:absolute;z-index:0;pointer-events:none;border-radius:50%;filter:blur(14px)}
.swirl-coral{background:radial-gradient(closest-side,
  rgba(250,123,71,.34),rgba(244,96,124,.22) 55%,rgba(230,59,130,.08) 74%,transparent 82%)}
.swirl-pink{background:radial-gradient(closest-side,
  rgba(230,59,130,.30),rgba(155,43,196,.16) 58%,transparent 80%)}
.swirl-violet{background:radial-gradient(closest-side,
  rgba(120,12,214,.20),rgba(230,59,130,.12) 60%,transparent 80%)}
.swirl-soft{opacity:.7}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;display:flex;align-items:center;
  min-height:600px;padding-block:clamp(86px,11vw,134px) clamp(118px,16vw,180px)}
.hero-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 26%}
.hero-overlay{position:absolute;inset:0;z-index:1}
/* directional overlay for photo heroes: heavy left for text, lighter right so subject shows */
/* complex organic overlay (Asana-brochure colours), left-heavy so text stays legible
   and the photo still reads through on the right */
.hero-overlay-photo{background:
  radial-gradient(58% 80% at 6% 26%, rgba(242,104,58,.95), rgba(242,104,58,0) 60%),
  radial-gradient(55% 80% at 26% 104%, rgba(192,48,126,.82), rgba(192,48,126,0) 60%),
  radial-gradient(48% 66% at 54% 6%, rgba(230,59,130,.55), rgba(230,59,130,0) 64%),
  radial-gradient(60% 95% at 104% 96%, rgba(120,12,214,.30), rgba(120,12,214,0) 60%),
  linear-gradient(102deg, rgba(242,104,58,.88) 0%, rgba(230,59,130,.74) 44%, rgba(230,59,130,.40) 100%)}
/* layered organic coral coverage (Asana-brochure style) for plain heroes + bands */
.hero-grad{position:absolute;inset:0;z-index:0;background:
  radial-gradient(46% 70% at 10% 20%, #FB8A4D, rgba(251,138,77,0) 56%),
  radial-gradient(48% 74% at 90% 4%, #E63B82, rgba(230,59,130,0) 58%),
  radial-gradient(40% 58% at 66% 56%, #F4607C, rgba(244,96,124,0) 60%),
  radial-gradient(55% 82% at 98% 112%, #9B2BC4, rgba(155,43,196,0) 60%),
  radial-gradient(46% 70% at 4% 108%, #C0307E, rgba(192,48,126,0) 58%),
  linear-gradient(120deg,#F2683A 0%,#E63B82 52%,#C0307E 100%)}
.hero h1{color:#fff;max-width:20ch;text-shadow:0 2px 24px rgba(120,12,60,.22)}
.hero-sub{font-family:var(--font-head);font-weight:600;line-height:1.18;
  font-size:clamp(1.25rem,2.6vw,1.95rem);color:rgba(255,255,255,.96);margin-top:.55rem;max-width:24ch}
.hero .lead{color:rgba(255,255,255,.94);margin-top:1.2rem;max-width:52ch}
.hero-inner{max-width:780px;position:relative;z-index:5}
.hero .btn-row{margin-top:2rem}
.hero--inner{min-height:auto;padding-block:clamp(80px,9vw,116px) clamp(104px,13vw,150px)}
.btn-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}

/* wave divider sitting at the bottom of the hero (fills with --base) */
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;z-index:3;line-height:0}

/* ---------- Cards ---------- */
.grid{display:grid;gap:1.4rem}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:1.7rem;box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(120,12,214,.34)}
.card h3{margin-bottom:.5rem}
.card p{color:var(--muted)}

.pillar{display:flex;flex-direction:column;height:100%}
.pillar>p{min-height:5em}  /* equal intro height (up to 3 lines) so bullets line up across cards */
.pillar .ico{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:1.1rem}
.pillar.work .ico{background:rgba(250,123,71,.14)}
.pillar.strategy .ico{background:rgba(230,59,130,.13)}
.pillar.people .ico{background:rgba(120,12,214,.12)}
.pillar .ico svg{width:30px;height:30px}
.pillar ul{list-style:none;margin:.9rem 0 1.2rem;display:grid;gap:.55rem}
.pillar ul li{position:relative;padding-left:1.5rem;color:var(--muted);font-size:.96rem;line-height:1.5}
.pillar ul li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;border-radius:3px}
.pillar.work ul li::before{background:var(--mango)}
.pillar.strategy ul li::before{background:var(--azalea)}
.pillar.people ul li::before{background:var(--violet)}
.pillar .tlink{margin-top:auto}

/* recognition list */
.reco-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.reco{background:var(--paper);border:1px solid var(--line-soft);border-radius:16px;padding:1.1rem 1.25rem;
  display:flex;gap:.85rem;align-items:flex-start;font-size:.98rem;box-shadow:var(--shadow-card)}
.reco .dot{flex:0 0 auto;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;
  background:rgba(250,123,71,.15);color:var(--mango-deep);font-weight:800;font-family:var(--font-head)}
.reco p{color:var(--ink);margin:0}
.reco-note{margin-top:1.8rem;font-size:1.14rem;font-weight:600;color:var(--violet);text-align:center}
/* full-width light callout for a recognition closing line */
.reco-callout{margin-top:1.6rem;background:#FCEEE8;border:1px solid rgba(250,123,71,.20);
  border-radius:16px;padding:1.05rem 1.6rem;text-align:center;
  font-family:var(--font-head);font-weight:600;font-size:clamp(1rem,1.6vw,1.14rem);color:var(--ink)}

/* ---------- Liminality (centered) ---------- */
.lim{text-align:center;max-width:760px;margin-inline:auto}
.dict{display:inline-block;text-align:left;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:1.6rem 1.9rem;box-shadow:var(--shadow-card);max-width:440px}
.dict .word{font-family:var(--font-head);font-weight:800;font-size:1.55rem}
.dict .phon{color:var(--muted);font-style:italic;margin-left:.4rem;font-size:.98rem}
.dict .pos{color:var(--azalea);font-weight:700;font-size:.82rem;letter-spacing:.04em;margin-top:.2rem}
.dict .def{margin-top:.5rem;color:var(--ink);font-size:.98rem}
.lim-explain{margin-top:1.8rem;color:var(--ink);font-size:clamp(1.02rem,1.5vw,1.18rem);line-height:1.6}
.lim-quote{margin:1.9rem auto 0;text-align:left;max-width:660px;
  border-left:4px solid var(--mango);padding-left:1.4rem;
  font-family:var(--font-head);font-weight:600;font-size:clamp(1.12rem,1.9vw,1.45rem);
  line-height:1.42;color:var(--ink)}
.lim-quote cite{display:block;margin-top:.7rem;font-family:var(--font-body);font-style:normal;
  font-weight:600;font-size:.92rem;color:var(--muted)}

/* generic block quote (smaller now) */
.quote{border-left:4px solid var(--mango);padding-left:1.3rem;font-family:var(--font-head);
  font-weight:600;font-size:clamp(1.1rem,1.8vw,1.4rem);line-height:1.4;color:var(--ink)}
.quote cite{display:block;margin-top:.7rem;font-family:var(--font-body);font-style:normal;
  font-weight:600;font-size:.92rem;color:var(--muted)}

/* steps audit/build/optimise */
.steps{display:grid;gap:1.4rem;grid-template-columns:repeat(3,1fr)}
.step{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:1.7rem;box-shadow:var(--shadow-card)}
.step .num{font-family:var(--font-head);font-weight:900;font-size:2.4rem;line-height:1;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.step h3{margin:.5rem 0 .4rem}
.step p{color:var(--muted);font-size:.98rem}

/* logo strip */
.logos-label{text-align:center;font-family:var(--font-head);font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;font-size:.78rem;color:var(--muted);margin-bottom:1.8rem}
.logo-strip{display:grid;grid-template-columns:repeat(6,1fr);align-items:center;
  gap:clamp(1rem,3vw,2.2rem)}
.logo-strip span{display:grid;place-items:center}
.logo-strip img{max-height:46px;max-width:130px;width:auto;height:auto;object-fit:contain;
  filter:grayscale(1);opacity:.66;transition:.25s ease}
.logo-strip span:hover img{filter:grayscale(0);opacity:1}

/* coloured logo band: white logos sliding marquee (matches tripleninecollective.com) */
.logo-band{position:relative;color:#fff;overflow:hidden;padding-block:clamp(34px,4.4vw,52px)}
/* keep heading + logos above the coral .hero-grad background */
.logo-band .container{position:relative;z-index:2}
.logo-band .logo-marquee{position:relative;z-index:2}
.logo-band .logos-heading{text-align:center;color:#fff;margin-bottom:1.5rem;
  font-family:var(--font-head);font-weight:800;font-size:clamp(1.5rem,2.8vw,2rem)}
.logo-marquee{position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logo-track{display:flex;align-items:center;width:max-content;
  animation:logoscroll 32s linear infinite}
.logo-band:hover .logo-track{animation-play-state:paused}
.logo-track img{filter:none;opacity:.97;width:auto;object-fit:contain;flex:0 0 auto;
  margin-right:clamp(2.8rem,5.5vw,5.2rem)}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* per-logo sizing: equalise wordmark lettering, balance the icon+text lockups */
.l-green{height:clamp(28px,3.4vw,40px)}
.l-bol{height:clamp(28px,3.4vw,40px)}
.l-viess{height:clamp(28px,3.4vw,40px)}
.l-just{height:clamp(38px,4.6vw,54px)}
.l-king{height:clamp(50px,6vw,72px)}
.l-mister{height:clamp(30px,3.6vw,42px)}
.l-block{height:clamp(52px,6.2vw,74px)}
@media(max-width:760px){ .logo-strip--white{grid-template-columns:repeat(2,1fr);gap:2rem 1.6rem} }

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:2.4rem}
.tcard{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:1.6rem 1.7rem;box-shadow:var(--shadow-card)}
.tcard p{font-size:1.02rem;color:var(--ink)}
.tcard .who{margin-top:.9rem;font-family:var(--font-head);font-weight:700;font-size:.9rem;color:var(--violet)}
.tcard .quotemark{font-family:var(--font-head);font-weight:900;font-size:2.4rem;line-height:.4;
  color:var(--mango);opacity:.5}

/* about teaser with B&W portrait + coral accent */
.teaser{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.4rem);align-items:center}
.cred-list{list-style:none;display:grid;gap:.6rem;margin-top:1.2rem}
.cred-list li{display:flex;gap:.6rem;align-items:flex-start;color:var(--ink);font-size:.98rem}
.cred-list svg{flex:0 0 auto;margin-top:.15rem}
.portrait-wrap{position:relative;justify-self:center;max-width:420px;width:100%}
.portrait-wrap::before{content:"";position:absolute;inset:auto -18px -18px auto;width:72%;height:78%;
  border-radius:var(--radius-lg);background:var(--grad-signature);z-index:0;opacity:.9}
.portrait-wrap .frame{position:relative;z-index:1;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-soft);aspect-ratio:4/5;background:var(--base)}
.portrait-wrap .frame img{width:100%;height:100%;object-fit:cover}

/* ---------- Final CTA ---------- */
.cta-band{position:relative;color:#fff;text-align:center;overflow:hidden;
  padding-block:clamp(74px,11vw,132px);
  background:
    radial-gradient(48% 80% at 10% 18%, #FA7B47, rgba(250,123,71,0) 56%),
    radial-gradient(54% 86% at 90% 14%, #E63B82, rgba(230,59,130,0) 58%),
    radial-gradient(60% 95% at 80% 104%, #780CD6, rgba(120,12,214,0) 60%),
    radial-gradient(54% 86% at 16% 102%, #C0307E, rgba(192,48,126,0) 58%),
    linear-gradient(125deg,#F2683A 0%,#E63B82 40%,#9B2BC4 72%,#5A1FA0 100%)}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.9);margin-inline:auto}
.cta-wave-top{position:absolute;top:-1px;left:0;right:0;line-height:0;z-index:2}
.cta-band .container{position:relative;z-index:3}

/* ---------- Footer ---------- */
.site-footer{color:rgba(255,255,255,.80);padding-block:clamp(48px,7vw,76px);
  background:
    radial-gradient(46% 90% at 10% 6%, rgba(120,12,214,.55), rgba(120,12,214,0) 60%),
    radial-gradient(50% 90% at 94% -8%, rgba(230,59,130,.34), rgba(230,59,130,0) 56%),
    radial-gradient(60% 100% at 88% 108%, rgba(17,2,142,.60), rgba(17,2,142,0) 60%),
    radial-gradient(46% 86% at 6% 104%, rgba(250,123,71,.20), rgba(250,123,71,0) 58%),
    #160A26}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem}
.site-footer .brandline{font-family:var(--font-head);font-weight:600;color:#fff;margin-top:1rem;max-width:30ch}
.site-footer img.flogo{height:30px;margin-bottom:.4rem}
.foot-col h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.9rem}
.foot-col ul{list-style:none;display:grid;gap:.55rem}
.foot-col a{color:rgba(255,255,255,.78);font-size:.95rem}
.foot-col a:hover{color:#fff}
.site-footer a.foot-join{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.15rem;
  padding:.5rem 1rem;border-radius:999px;background:var(--grad-signature);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:.88rem;
  box-shadow:0 12px 26px -14px rgba(230,59,130,.85);transition:transform .2s ease,box-shadow .2s ease}
.site-footer a.foot-join:hover{color:#fff;transform:translateY(-1px);box-shadow:0 16px 30px -14px rgba(230,59,130,.95)}
.site-footer a.foot-join .arrow{transition:transform .2s ease}
.site-footer a.foot-join:hover .arrow{transform:translateX(3px)}
.foot-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.14);
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-size:.85rem;color:rgba(255,255,255,.6)}

/* ---------- Scroll fade-ins ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ================= Sales page: The Mid-Year Reset ================= */
.microtrans{text-align:center;font-family:var(--font-head);font-weight:700;color:var(--violet);
  font-size:clamp(1.05rem,1.9vw,1.4rem);padding-block:clamp(30px,5vw,52px);margin:0}
.urgency-strip{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.6rem;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.34);color:#fff;
  font-family:var(--font-head);font-weight:600;font-size:.92rem;border-radius:999px;padding:.5rem 1.05rem}
.urgency-strip strong{font-weight:800}
.sales-link{font-family:var(--font-head);font-weight:700;color:#fff;opacity:.9}
.sales-link:hover{opacity:1}
/* inner-monologue thoughts */
.thoughts{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.9rem}
@media(max-width:760px){ .thoughts{grid-template-columns:1fr} }
.thought{background:var(--paper);border:1px solid var(--line-soft);border-radius:16px;
  padding:1.05rem 1.3rem 1.05rem 2.2rem;box-shadow:var(--shadow-card);position:relative}
.thought::before{content:"\201C";position:absolute;top:.35rem;left:.75rem;font-family:var(--font-head);
  font-weight:900;color:var(--mango);opacity:.45;font-size:1.7rem}
.thought p{margin:0;max-width:none;font-style:italic;color:var(--ink)}
/* for-you / not-for-you */
.foryou{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:1.9rem}
@media(max-width:760px){ .foryou{grid-template-columns:1fr} }
.foryou .col{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:1.8rem;box-shadow:var(--shadow-card)}
.foryou h3{margin-bottom:1rem;font-size:1.12rem}
.foryou ul{list-style:none;display:grid;gap:.65rem}
.foryou li{display:flex;gap:.6rem;align-items:flex-start;font-size:.98rem;line-height:1.5}
.foryou li svg{flex:0 0 auto;margin-top:.18rem}
.foryou .yes li{color:var(--ink)}
.foryou .no li{color:var(--muted)}
/* pricing */
.pricing{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:2rem;align-items:stretch}
@media(max-width:760px){ .pricing{grid-template-columns:1fr} }
.price-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:2.1rem 1.9rem;box-shadow:var(--shadow-card);position:relative;display:flex;flex-direction:column}
.price-card.featured{border:2px solid var(--azalea);box-shadow:0 24px 54px -26px rgba(230,59,130,.42)}
.price-card .pc-name{font-family:var(--font-head);font-weight:800;font-size:1.22rem}
.price-card .pc-sub{color:var(--muted);font-size:.9rem;margin-top:.15rem}
.price-card .pc-amount{font-family:var(--font-head);font-weight:900;font-size:clamp(2.2rem,4vw,2.9rem);line-height:1;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;margin:.9rem 0 .15rem}
.price-card .pc-ex{color:var(--muted);font-size:.85rem}
.price-card ul{list-style:none;display:grid;gap:.6rem;margin:1.3rem 0 1.7rem}
.price-card li{display:flex;gap:.55rem;align-items:flex-start;font-size:.96rem;color:var(--ink);line-height:1.45}
.price-card li svg{flex:0 0 auto;margin-top:.2rem}
.price-card .btn{margin-top:auto;width:100%;justify-content:center}
.pc-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--grad-signature);
  color:#fff;font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;padding:.36rem .95rem;border-radius:999px;white-space:nowrap;box-shadow:0 10px 22px -10px rgba(230,59,130,.6)}
.price-micro{text-align:center;color:var(--muted);font-size:.9rem;margin-top:1.5rem;max-width:60ch;margin-inline:auto}
/* guarantee box */
.guarantee{display:flex;gap:1rem;align-items:flex-start;background:#F4EFFB;border:1px solid rgba(120,12,214,.16);
  border-radius:var(--radius-lg);padding:1.4rem 1.7rem;margin:1.9rem auto 0;max-width:720px}
.guarantee .gico{flex:0 0 auto;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:rgba(120,12,214,.12);margin-top:.1rem}
.guarantee p{margin:0;color:var(--ink);max-width:none}
.guarantee strong{color:var(--violet)}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .cols-3,.steps{grid-template-columns:1fr}
  .pillar>p{min-height:0}
  .teaser{grid-template-columns:1fr}
  .portrait-wrap{order:-1;margin-bottom:1rem}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--base);flex-direction:column;
    align-items:flex-start;gap:.2rem;padding:1rem var(--pad) 1.6rem;border-bottom:1px solid var(--line-soft);
    box-shadow:var(--shadow-soft);transform:translateY(-130%);transition:.28s ease;height:auto}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%;padding:.7rem 0;font-size:1.05rem}
  .nav-links a[aria-current="page"]::after{bottom:.55rem}
  .hero-photo{background-position:78% 26%}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    padding:.2rem 0 .4rem 1rem;min-width:0;background:transparent}
  .submenu a{padding:.45rem 0}
  .menu-toggle{display:block}
  .nav-cta .btn:not(.menu-toggle){display:none}
  .reco-grid,.tgrid,.cols-2{grid-template-columns:1fr}
  .logo-strip{grid-template-columns:repeat(3,1fr);gap:1.6rem 1rem}
  .foot-grid{grid-template-columns:1fr}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .btn,.card,.logo-strip img{transition:none!important}
  .logo-track{animation:none!important;flex-wrap:wrap;justify-content:center;width:100%;gap:2rem 2.6rem}
}

/* ---------- Nav: dropdown caret + EN/NL switcher ---------- */
.nav-links .caret{font-size:.62em;margin-left:.35em;vertical-align:middle;opacity:.7}
.lang{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-head);font-weight:700;
  font-size:.8rem;border:1px solid var(--line);border-radius:999px;padding:.34rem .66rem}
.lang a{color:var(--muted);opacity:.72;transition:.15s ease}
.lang a.active{color:var(--azalea);opacity:1}
.lang a:hover{color:var(--azalea);opacity:1}
.lang span{opacity:.35}
@media(max-width:760px){ .lang{display:none} }

/* ---------- Liminal: big bold pink heading ---------- */
.lim-heading{font-family:var(--font-head);font-weight:800;line-height:1.12;
  font-size:clamp(1.6rem,3vw,2.35rem);max-width:24ch;margin:0 auto 1.7rem;letter-spacing:-.01em;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- About: badges, triptych, mini-quote, speaking ---------- */
.sec-title{font-family:var(--font-head);font-weight:800;letter-spacing:-.01em;
  font-size:clamp(1.5rem,2.6vw,2.05rem);color:var(--azalea);margin:0}
.about-copy p{font-size:1.05rem;line-height:1.65;color:var(--muted);margin-top:1rem;max-width:60ch}
.about-copy p:first-child{margin-top:1.1rem}
/* official partner badges (never recoloured); sized for balanced visual weight */
.badge-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:clamp(2.4rem,6vw,5rem);margin-top:2.4rem}
.badge-strip img{width:auto;object-fit:contain}
.b-asana{height:clamp(56px,6.4vw,80px)}
.b-gtd{height:clamp(84px,9.4vw,116px)}
.b-holacracy{height:clamp(30px,3.6vw,44px)}
.mini-quote{font-family:var(--font-head);font-weight:600;font-size:1.02rem;line-height:1.4;
  color:var(--violet);border-left:3px solid var(--mango);padding-left:1rem;margin-top:1.5rem;max-width:34ch}
.speak-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3rem);align-items:stretch}
@media(max-width:880px){ .speak-grid{grid-template-columns:1fr} }
.triptych{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.6rem;height:100%;min-height:300px}
.triptych img{width:100%;height:100%;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-card)}
.topic-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.1rem 0}
.topic-tags span{font-family:var(--font-head);font-weight:600;font-size:.82rem;
  background:rgba(120,12,214,.08);color:var(--violet);border-radius:999px;padding:.36rem .82rem}
.appearances{list-style:none;display:grid;gap:1rem;margin:1.2rem 0 .4rem}
.appearances li{font-size:.96rem;color:var(--ink);line-height:1.45;border-left:3px solid var(--mango);padding-left:.85rem}
.appearances .ap-line{display:block}
.appearances .ap-topic{display:block;color:var(--muted);font-size:.88rem;margin-top:.18rem}
.appearances .role{color:var(--muted);font-weight:600}
.appearances a{color:var(--violet);font-weight:600}

/* ---------- Library: books + article cards ---------- */
.book-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,3vw,1.8rem);margin-top:2rem}
@media(max-width:900px){ .book-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:600px){ .book-grid{grid-template-columns:repeat(2,1fr)} }
/* Flip cards: cover on the front, title/author/blurb on the back (text stays in the DOM) */
.book{perspective:1100px;transition:transform .25s ease}
.book:hover{transform:translateY(-4px)}
.book .flip{position:relative;width:100%;aspect-ratio:2/3;transform-style:preserve-3d;
  transition:transform .6s cubic-bezier(.2,.7,.2,1)}
@media(hover:hover){ .book:hover .flip{transform:rotateY(180deg)} }
.book:focus-visible{outline:none}
.book:focus-visible .flip,.book.is-flipped .flip{transform:rotateY(180deg)}
.book .face{position:absolute;inset:0;border-radius:10px;overflow:hidden;box-shadow:var(--shadow-card);
  backface-visibility:hidden;-webkit-backface-visibility:hidden}
.book .cover{background:var(--base)}
.book .cover img{width:100%;height:100%;object-fit:cover}
.book .back{transform:rotateY(180deg);background:linear-gradient(160deg,#ffffff,#f3ecfb);
  border:1px solid var(--line-soft);display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  padding:clamp(.9rem,1.6vw,1.15rem);text-align:left}
.book .bt{font-family:var(--font-head);font-weight:800;font-size:.96rem;line-height:1.2}
.book .ba{font-size:.82rem;color:var(--muted);margin-top:-.2rem}
.book .bw{font-size:.86rem;color:var(--muted);line-height:1.45}
.post-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:clamp(1.4rem,2.6vw,1.8rem);display:flex;flex-direction:column;gap:.5rem;
  transition:transform .2s ease,box-shadow .2s ease}
.post-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(120,12,214,.30)}
.post-card .cat{font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.07em;
  text-transform:uppercase;color:var(--violet)}
.post-card h3{font-size:1.18rem;line-height:1.2}
.post-card p{color:var(--muted);font-size:.96rem;margin:0;max-width:none}
.post-card.soon{opacity:.72}
.post-card .tlink{margin-top:auto}

/* ---------- Article (republished posts) ---------- */
.article{max-width:760px;margin-inline:auto}
.article h1{font-size:clamp(2rem,4vw,2.9rem)}
.article-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;align-items:center;color:var(--muted);
  font-size:.9rem;margin-top:1rem;font-family:var(--font-head);font-weight:600}
.canonical-note{font-size:.86rem;color:var(--muted);background:var(--base);border:1px solid var(--line-soft);
  border-radius:12px;padding:.85rem 1.1rem;margin:1.6rem 0}
.canonical-note a{color:var(--violet);font-weight:600}
.article-body{font-size:1.06rem;line-height:1.75;color:#2c2238}
.article-body h2{font-family:var(--font-head);font-size:clamp(1.35rem,2.4vw,1.75rem);margin:2.1rem 0 .7rem;color:var(--ink)}
.article-body h3{font-family:var(--font-head);font-size:1.18rem;margin:1.7rem 0 .5rem;color:var(--ink)}
.article-body h4{font-family:var(--font-head);font-size:1.02rem;margin:1.3rem 0 .35rem;color:var(--violet)}
.article-body p{max-width:none;margin:0 0 1rem}
.article-body ul,.article-body ol{margin:0 0 1.1rem 1.25rem;display:grid;gap:.4rem}
.article-body blockquote{border-left:4px solid var(--mango);padding:.2rem 0 .2rem 1.2rem;margin:1.3rem 0;
  font-family:var(--font-head);font-weight:600;font-size:1.1rem;line-height:1.4;color:var(--ink)}
.article-body strong{color:var(--ink)}
.article-cta{margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line-soft);display:flex;
  flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}

/* ---------- Pillar detail blocks (service sub-pages) ---------- */
.detail{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:clamp(1.6rem,3vw,2.4rem);margin-bottom:1.5rem}
.detail-head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.detail-head .ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;flex:0 0 auto}
.detail-head .ico svg{width:28px;height:28px}
.detail-head h3{margin:0;line-height:1.1}
.tag{display:inline-block;margin-top:.35rem;font-family:var(--font-head);font-weight:700;font-size:.7rem;
  letter-spacing:.09em;text-transform:uppercase;padding:.22rem .62rem;border-radius:999px}
.detail>p{color:var(--muted);max-width:74ch}
.ticks{list-style:none;display:grid;gap:.62rem;margin:1.1rem 0 0}
.ticks li{display:flex;gap:.65rem;align-items:flex-start;color:var(--ink);font-size:.99rem;line-height:1.5}
.ticks li svg{flex:0 0 auto;margin-top:.22rem}
.addons{margin-top:1.1rem;font-size:.94rem;color:var(--muted);border-top:1px solid var(--line-soft);padding-top:1rem;max-width:74ch}
/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,2.6rem);align-items:start}
@media(max-width:880px){ .contact-grid{grid-template-columns:1fr} }
.panel{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:clamp(1.4rem,3vw,2rem)}
.panel h3{margin-bottom:.3rem}
.panel .sub{color:var(--muted);font-size:.96rem;margin-bottom:1.2rem}
/* ---- FAQ accordion (native details/summary, fully crawlable) ---- */
.faq{max-width:760px;margin-inline:auto;display:grid;gap:.7rem}
.faq details{background:var(--paper);border:1px solid var(--line-soft);border-radius:16px;
  box-shadow:var(--shadow-card);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:1.05rem 1.25rem;font-family:var(--font-head);font-weight:600;
  font-size:1.02rem;line-height:1.35;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::marker{content:""}
.faq .faq-ico{flex:0 0 auto;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;
  background:rgba(250,123,71,.15);color:var(--mango-deep);font-weight:800;font-family:var(--font-head);
  transition:transform .2s ease}
.faq details[open] summary .faq-ico{transform:rotate(45deg)}
.faq .faq-body{padding:0 1.25rem 1.15rem;color:var(--muted);line-height:1.6;font-size:.98rem;margin:0}
.calendly-inline-widget{border-radius:14px;overflow:hidden;background:var(--base)}
.field{display:block;margin-bottom:1rem}
.field label{display:block;font-family:var(--font-head);font-weight:600;font-size:.9rem;margin-bottom:.35rem;color:var(--ink)}
.field input,.field textarea,.field select{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--base);border:1px solid var(--line);border-radius:12px;padding:.72rem .85rem;
  transition:border .15s ease,box-shadow .15s ease}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 1.15rem,calc(100% - 12px) 1.15rem;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(120,12,214,.12)}
.field textarea{min-height:130px;resize:vertical}
/* ---- checkbox group (optional multi-select inside a form field) ---- */
.field .field-note{display:block;font-family:var(--font-body);font-weight:400;font-size:.86rem;color:var(--muted);margin:-.15rem 0 .55rem}
.checks{display:grid;gap:.5rem;grid-template-columns:1fr 1fr}
.checks label{display:flex;align-items:flex-start;gap:.55rem;font-family:var(--font-body);font-weight:500;
  font-size:.95rem;color:var(--ink);line-height:1.4;margin-bottom:0;cursor:pointer}
.checks input[type="checkbox"]{width:auto;flex:0 0 auto;margin-top:.18rem;padding:0;border-radius:5px;
  accent-color:var(--azalea);box-shadow:none}
.checks input[type="checkbox"]:focus{outline:none;box-shadow:none}
@media (max-width:560px){.checks{grid-template-columns:1fr}}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.7rem}
.contact-links{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.3rem}
.contact-links a{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:600;
  font-size:.95rem;border:1px solid var(--line);border-radius:999px;padding:.52rem .95rem;color:var(--ink)}
.contact-links a:hover{border-color:var(--violet);color:var(--violet)}

/* ---------- Cases ---------- */
.pillar-band{display:flex;align-items:center;gap:.7rem;margin:0 0 .2rem}
.pillar-band .eyebrow{margin:0}
.case-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:1.4rem}
@media(max-width:880px){ .case-grid{grid-template-columns:1fr} }
.case-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:clamp(1.4rem,2.6vw,1.9rem);display:flex;flex-direction:column;gap:.5rem}
.case-card .case-top{display:flex;align-items:baseline;justify-content:space-between;gap:.7rem;flex-wrap:wrap}
.case-card .co{font-family:var(--font-head);font-weight:800;font-size:1.12rem}
.case-card .ind{font-size:.78rem;color:var(--muted);font-weight:600}
.case-card .cl{display:block;font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.07em;
  text-transform:uppercase;color:var(--violet);margin-top:.5rem}
.case-card p{margin:.05rem 0 0;color:var(--muted);font-size:.95rem;max-width:none;line-height:1.5}
.case-card blockquote{margin-top:.5rem;border-left:3px solid var(--mango);padding-left:.9rem;
  font-family:var(--font-head);font-weight:600;font-size:.96rem;color:var(--ink)}
.case-card blockquote cite{display:block;font-family:var(--font-body);font-weight:600;font-style:normal;
  font-size:.82rem;color:var(--muted);margin-top:.3rem}

/* tier label inside a detail block */
.tier-label{font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.03em;
  color:var(--violet);margin:1.3rem 0 .2rem}
.tier-label:first-of-type{margin-top:.4rem}
/* soft lavender callout box */
.soft-box{background:#F4EFFB;border:1px solid rgba(120,12,214,.14);border-radius:18px;
  padding:1.4rem 1.6rem;margin-top:1.5rem}
.soft-box h4{font-family:var(--font-head);font-weight:800;font-size:1.08rem;margin-bottom:.4rem}
.soft-box p{color:var(--muted);margin:0;max-width:none}
.soft-box .tlink{margin-top:.7rem;font-size:.92rem}
/* recognition sub-heading inside a stream */
.sub-h{font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--ink);margin-bottom:.9rem}
/* big centered feature quote */
.feature-quote{font-family:var(--font-head);font-weight:700;line-height:1.3;
  font-size:clamp(1.4rem,3vw,2.15rem);max-width:740px;margin:1rem auto 0;color:var(--ink)}
/* simple two-column prose row */
.prose-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);margin-top:1.4rem}
.prose-2 p{color:var(--muted);max-width:none}
@media(max-width:760px){ .prose-2{grid-template-columns:1fr} }
/* mini case cards */
.minicase{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:transform .2s ease,box-shadow .2s ease}
.minicase:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(120,12,214,.30)}
.minicase .co{font-family:var(--font-head);font-weight:800;font-size:1.05rem}
.minicase p{color:var(--muted);font-size:.95rem;margin:0}
.minicase .tlink{margin-top:.4rem;font-size:.9rem}
/* honest-note callout */
.note-band{text-align:center}
.note-band .quote-lead{font-family:var(--font-head);font-weight:700;
  font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.25;max-width:22ch;margin:.6rem auto 0;color:var(--ink)}
.note-band p{max-width:60ch;margin:1rem auto 0;color:var(--muted)}

/* ---------- Venn (services framework) ---------- */
.venn-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.4rem);align-items:center}
.venn{max-width:560px;width:100%;margin-inline:auto;height:auto}
.venn-legend{list-style:none;display:grid;gap:.8rem;margin-top:1.4rem}
.venn-legend li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.venn-legend .sw{flex:0 0 auto;width:16px;height:16px;border-radius:5px;margin-top:.2rem}
@media(max-width:900px){ .venn-wrap{grid-template-columns:1fr} }

/* ---------- Who we work best with: profile cards ---------- */
.fit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.4rem}
.fit-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:1.6rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.7rem;
  transition:transform .2s ease,box-shadow .2s ease}
.fit-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(120,12,214,.30)}
.fit-card .fico{width:52px;height:52px;border-radius:15px;display:grid;place-items:center}
.fit-card .fico svg{width:27px;height:27px}
.fit-card h3{font-size:1.1rem;margin:0}
.fit-card p{color:var(--muted);font-size:.95rem;margin:0;line-height:1.55}
.fit-callout{margin:2.4rem auto 0;max-width:900px;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:1.8rem 2.1rem;text-align:center}
.fit-callout p{color:var(--ink);font-size:1rem;line-height:1.6;max-width:none;margin:0}
.fit-callout p + p{margin-top:.9rem}
@media(max-width:900px){ .fit-grid{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .fit-grid{grid-template-columns:1fr} }

/* ========================================================
   Cases v2 : focus-area filter + clickable cards + modal
   ======================================================== */
.case-filter{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:0 0 2.2rem}
.case-filter button{font-family:var(--font-head);font-weight:700;font-size:.85rem;cursor:pointer;
  border:1px solid var(--line);background:var(--paper);color:var(--ink);border-radius:999px;
  padding:.5rem 1.1rem;transition:.18s ease}
.case-filter button:hover{border-color:var(--violet);color:var(--violet)}
.case-filter button[aria-pressed="true"]{background:var(--grad-signature);color:#fff;border-color:transparent;
  box-shadow:0 12px 26px -14px rgba(230,59,130,.6)}

.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
@media(max-width:900px){ .cases-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:600px){ .cases-grid{grid-template-columns:1fr} }

.ccard{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;
  cursor:pointer;text-align:left;transition:transform .2s ease,box-shadow .2s ease}
.ccard:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(120,12,214,.34)}
.ccard:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(120,12,214,.28),var(--shadow-card)}
.ccard__logo{height:48px;display:flex;align-items:center}
.ccard__logo img{max-height:48px;max-width:185px;width:auto;object-fit:contain}
.ccard__ind{font-family:var(--font-head);font-weight:600;font-size:.76rem;letter-spacing:.02em;color:var(--muted);margin:.5rem 0 0}
.ccard__title{font-family:var(--font-head);font-weight:800;font-size:1.1rem;line-height:1.15;margin:.1rem 0 0}
.ccard__line{color:var(--muted);font-size:.95rem;line-height:1.5;margin:.15rem 0 0}
.ccard__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem}
.mtag{font-family:var(--font-head);font-weight:600;font-size:.72rem;color:var(--muted);
  background:var(--base);border:1px solid var(--line-soft);border-radius:999px;padding:.22rem .62rem}
.ccard__more{margin-top:auto;padding-top:.7rem;font-family:var(--font-head);font-weight:700;font-size:.85rem;
  color:var(--violet);display:inline-flex;align-items:center;gap:.35rem}
.ccard:hover .ccard__more .arrow{transform:translateX(3px)}
.ccard__full{display:none}

/* focus-area tag colours (reuse .tag) */
.tag--work{background:rgba(250,123,71,.14);color:var(--mango-deep)}
.tag--strategy{background:rgba(230,59,130,.13);color:var(--azalea)}
.tag--people{background:rgba(120,12,214,.12);color:var(--violet)}

/* modal */
.case-modal[hidden]{display:none}
.case-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-start;justify-content:center;
  padding:clamp(1rem,4vw,3rem)}
.case-modal__overlay{position:absolute;inset:0;background:rgba(26,11,46,.55);backdrop-filter:blur(3px)}
.case-modal__panel{position:relative;z-index:2;background:var(--paper);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);max-width:760px;width:100%;max-height:90vh;overflow:auto;
  padding:clamp(1.6rem,3.4vw,2.8rem)}
.case-modal__close{position:absolute;top:14px;right:14px;background:var(--base);
  border:1px solid var(--line);border-radius:999px;width:38px;height:38px;cursor:pointer;
  font-size:1.4rem;line-height:1;color:var(--ink);display:grid;place-items:center;z-index:4}
.case-modal__close:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
body.modal-open{overflow:hidden}

/* case content (rendered inside modal) */
.case-detail{overflow:hidden}
.case-detail__head{float:right;margin:.1rem 0 .9rem 1.4rem;max-width:48%}
.case-detail__head img{max-height:54px;max-width:170px;width:auto;object-fit:contain}
.case-detail .role{font-family:var(--font-head);font-weight:800;font-size:1.5rem;letter-spacing:0;
  color:var(--violet);line-height:1.18;margin:.1rem 0 .55rem}
.case-detail__ind{display:inline-block;font-family:var(--font-head);font-weight:700;font-size:.74rem;
  letter-spacing:.02em;color:var(--muted);background:var(--base);border:1px solid var(--line-soft);
  border-radius:999px;padding:.28rem .72rem;margin:0 0 1.3rem}
.case-detail h3{font-family:var(--font-head);font-size:1.06rem;margin:1.4rem 0 .4rem;color:var(--ink);clear:both}
.case-detail .wd-sub{font-family:var(--font-head);font-weight:800;color:var(--mango-deep);font-size:.9rem;
  letter-spacing:.04em;text-transform:uppercase;margin:1rem 0 .3rem}
.rev figure{margin:0}
.rev__shot{display:block;max-width:260px;width:100%;height:auto;border:1px solid var(--line-soft);
  border-radius:12px;margin:.8rem 0 .4rem;box-shadow:var(--shadow-card);cursor:zoom-in}
.rev__cap{font-size:.78rem;color:var(--muted)}
.case-detail__country{display:block;font-family:var(--font-head);font-weight:600;font-size:.84rem;
  color:var(--muted);margin:-1rem 0 1.3rem}
.img-zoom{position:fixed;inset:0;z-index:200;background:rgba(26,11,46,.82);display:flex;align-items:center;
  justify-content:center;padding:4vw;cursor:zoom-out}
.img-zoom[hidden]{display:none}
.img-zoom img{max-width:min(760px,92vw);max-height:92vh;width:auto;height:auto;border-radius:12px;
  box-shadow:var(--shadow-soft)}
@media(max-width:560px){
  .case-detail__head{float:none;max-width:none;margin:.1rem 0 .9rem}
  .case-detail__head img{max-height:46px}
}
.case-detail p{color:#352a44;margin:0 0 .85rem;max-width:none;line-height:1.65}
.case-detail ul{list-style:none;display:grid;gap:.5rem;margin:0 0 1rem}
.case-detail ul li{position:relative;padding-left:1.3rem;color:#352a44;line-height:1.55}
.case-detail ul li::before{content:"";position:absolute;left:0;top:.58em;width:8px;height:8px;border-radius:3px;background:var(--mango)}
.case-detail .lead-in{font-weight:800;color:var(--ink)}
.case-detail blockquote{border-left:4px solid var(--mango);padding-left:1.1rem;margin:1rem 0;
  font-family:var(--font-head);font-weight:600;color:var(--ink)}
.case-detail blockquote cite{display:block;font-family:var(--font-body);font-style:normal;font-weight:600;
  font-size:.85rem;color:var(--muted);margin-top:.4rem}

/* alternating review boxes (left / right zigzag) */
.case-reviews{margin-top:1.9rem;border-top:1px solid var(--line-soft);padding-top:1.5rem;display:grid;gap:1rem}
.case-reviews .rev-h{font-family:var(--font-head);font-weight:700;font-size:.96rem;color:var(--ink);text-align:center;margin-bottom:.3rem}
.rev{background:var(--base);border:1px solid var(--line-soft);border-radius:16px;padding:1rem 1.2rem;
  font-size:.95rem;color:var(--ink);line-height:1.55;max-width:84%}
.rev--l{justify-self:start;border-left:3px solid var(--mango)}
.rev--r{justify-self:end;border-right:3px solid var(--azalea);text-align:right}
@media(max-width:600px){ .rev{max-width:100%;text-align:left} .rev--r{border-right:0;border-left:3px solid var(--azalea)} }
