/* ══════════════════════════════════════════════════════════════════════
   NAVIGIS COUNSEL — V2  ·  QOVES-styled interpretation
   Single source of truth for all 7 pages (v2/navigis-*.html).
   Reverse-engineered from qoves.com's real :root + element system:
     · deep green-slate ink #233137 · emerald #0c6826 · ice #d1ebf2
     · light editorial canvases, punctuated by slate / true-dark bands
     · type: Fraunces (→Denton, editorial serif display, two-tone)
             Switzer (→PP Neue Montreal, neo-grotesque workhorse)
             IBM Plex Mono (→F37 Zagma, uppercase micro-labels)
     · pill buttons + pill eyebrow badges · rounded hairline cards
     · ice-blue atmosphere · translateY+fade reveals · ease (.22,1,.36,1)
   Fonts are loaded per-page via <link> (Google Fonts + Fontshare).
   ══════════════════════════════════════════════════════════════════════ */

:root{
  /* ── Ink & text (Qoves exact) ── */
  --ink:#233137;          /* green-dark — headings / primary */
  --ink-soft:#33454d;     /* softened ink for large body leads */
  --body:#4c5559;         /* body copy */
  --muted:#758084;        /* labels / meta */
  --dim:#9aaeb5;          /* two-tone headline 2nd clause */

  /* ── Accents (used sparingly, exactly like Qoves) ── */
  --emerald:#0c6826;      /* links / ticks / active */
  --emerald-deep:#0a5620;
  --ice:#d1ebf2;          /* ice-blue atmosphere + accent on dark */
  --ice-soft:#eef7fa;

  /* ── Canvases ── */
  --bg:#ffffff;
  --bg-1:#f8fafa;
  --bg-2:#f2f5f5;
  --paper:#f7f6f3;        /* faint warm paper for statement moments */

  /* ── Lines ── */
  --hair:#e8e8e8;
  --hair-soft:#f2f2f2;
  --hair-ink:rgba(35,49,55,.10);

  /* ── Slate (hero / feature bands) ── */
  --slate-1:#34434a;
  --slate-2:#26333a;
  --slate-3:#1b272d;
  --near-black:#0f1618;   /* true-dark band (Qoves #0b1315) */

  /* ── Shadows (Qoves) ── */
  --sh-card:0 6px 14px rgba(35,49,55,.04);
  --sh-hover:0 30px 44px -26px rgba(35,49,55,.22), 0 44px 66px rgba(154,174,181,.14);
  --sh-pop:0 26px 60px -18px rgba(15,22,26,.30);
  --sh-btn:0 18px 30px -16px rgba(35,49,55,.5);

  /* ── System ── */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.33,.9,.28,1);
  --maxw:1200px;
  --gutter:clamp(1.4rem,4vw,2.75rem);
  --radius:14px;
  --radius-lg:20px;
  --pill:999px;

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Switzer","General Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,monospace;
}

/* ── Reset ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--body);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--ink);color:#fff}
:focus-visible{outline:2px solid var(--emerald);outline-offset:3px;border-radius:3px}

/* ── Atmosphere: faint ice halo behind whole doc ─────────────────────── */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 40% at 82% -8%, rgba(209,235,242,.35), transparent 60%),
    radial-gradient(46% 32% at 4% 6%, rgba(209,235,242,.20), transparent 60%);
}

/* ── Layout ────────────────────────────────────────────────────────── */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.container--wide{max-width:1320px}
.container--narrow{max-width:820px}
.section{position:relative;padding-block:clamp(4.5rem,8vw,8rem)}
.section--tight{padding-block:clamp(3rem,5vw,4.75rem)}
.section--flush-top{padding-top:clamp(2rem,4vw,3.25rem)}

/* Centered section header: badge → two-tone display → lead (Qoves .q-head) */
.head-block{max-width:760px}
.head-block--center{margin-inline:auto;text-align:center}
.head-block .display,.head-block .h2{margin-top:1.5rem}
.head-block .lead{margin-top:1.4rem}

/* ── Typography ────────────────────────────────────────────────────── */
.display{
  font-family:var(--serif);
  font-weight:400;
  font-optical-sizing:auto;
  font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0;
  font-size:clamp(2.55rem,5.1vw,4.55rem);
  line-height:1.03;
  letter-spacing:-.022em;
  color:var(--ink);
  text-wrap:balance;
}
.h2{
  font-family:var(--serif);
  font-weight:400;
  font-optical-sizing:auto;
  font-variation-settings:"opsz" 90;
  font-size:clamp(2rem,3.7vw,3.15rem);
  line-height:1.08;
  letter-spacing:-.018em;
  color:var(--ink);
  text-wrap:balance;
}
.h3{
  font-family:var(--sans);
  font-weight:500;
  font-size:clamp(1.15rem,1.6vw,1.42rem);
  line-height:1.24;
  letter-spacing:-.012em;
  color:var(--ink);
}
.dim{color:var(--dim)}                 /* two-tone 2nd clause */
.serif-em{font-family:var(--serif);font-style:italic;font-weight:400}

.lead{
  font-size:clamp(1.06rem,1.15vw,1.28rem);
  line-height:1.62;
  color:var(--ink-soft);
  font-weight:400;
}
.lead b,.body b{font-weight:600;color:var(--ink)}
.body{font-size:1rem;line-height:1.68;color:var(--body)}
.micro{font-size:.82rem;line-height:1.55;color:var(--muted)}
.measure{max-width:40rem}
.measure-sm{max-width:34rem}

/* Eyebrow — mono pill badge (Qoves signature; Zagma → IBM Plex Mono) */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem .95rem;
  border:1px solid var(--hair-ink);
  border-radius:var(--pill);
  font-family:var(--mono);font-weight:500;
  font-size:.68rem;line-height:1;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
  background:rgba(255,255,255,.4);
  backdrop-filter:blur(4px);
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--emerald)}
.eyebrow--plain{border:0;padding:0;background:none;backdrop-filter:none}

/* Kicker — mono tick label (no pill), for card categories / section labels */
.kicker{
  display:inline-flex;align-items:center;gap:.65rem;
  font-family:var(--mono);font-weight:500;
  font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--emerald);
}
.kicker::before{content:"";width:1.6rem;height:1px;background:currentColor;opacity:.7}
.kicker--plain::before{display:none}

.tick{display:inline-block;width:1.6rem;height:1px;background:var(--emerald);vertical-align:middle;margin-right:.6rem}

/* Stat numerals */
.stat{
  font-family:var(--serif);font-weight:400;
  font-variation-settings:"opsz" 144;
  font-size:clamp(2.9rem,5vw,4.1rem);
  line-height:.95;letter-spacing:-.02em;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.stat-l{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.11em;
  text-transform:uppercase;color:var(--muted);margin-top:1.1rem;line-height:1.5;
}

/* ── Dividers ──────────────────────────────────────────────────────── */
.hairline{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--hair),transparent)}
.rule-top{border-top:1px solid var(--hair)}

/* ── Buttons (Qoves pills) ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  height:3.3rem;padding-inline:1.9rem;border-radius:var(--pill);
  font-family:var(--sans);font-weight:500;font-size:.94rem;letter-spacing:.005em;
  white-space:nowrap;
  transition:background-color .3s var(--ease),color .3s var(--ease),
             border-color .3s var(--ease),box-shadow .4s var(--ease),transform .4s var(--ease);
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--ink);color:#fff;border:1px solid var(--ink)}
.btn--primary:hover{background:#2d3b41;border-color:#2d3b41;transform:translateY(-2px);box-shadow:var(--sh-btn)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--hair-ink)}
.btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}
.btn--light{background:#fff;color:#233137;border:1px solid #fff}
.btn--light:hover{background:var(--ice);color:#233137;border-color:var(--ice);transform:translateY(-2px)}
.btn--sm{height:2.7rem;padding-inline:1.35rem;font-size:.86rem}

/* Text link with animated underline (Qoves) */
.tlink{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);font-weight:500;font-size:.92rem;color:var(--ink);
  background-image:linear-gradient(var(--emerald),var(--emerald));
  background-position:0 100%;background-repeat:no-repeat;background-size:0% 1.5px;
  padding-bottom:3px;transition:background-size .35s var(--ease),color .25s ease;
}
.tlink:hover{background-size:100% 1.5px;color:var(--emerald)}
.tlink .arw{transition:transform .35s var(--ease)}
.tlink:hover .arw{transform:translateX(4px)}
.tlink--muted{color:var(--muted)}

/* ── Cards ─────────────────────────────────────────────────────────── */
.card{
  position:relative;background:#fff;border:1px solid var(--hair);
  border-radius:var(--radius);box-shadow:var(--sh-card);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .3s ease;
}
.card:hover{transform:translateY(-6px);border-color:#dfe4e5;box-shadow:var(--sh-hover)}

/* Duotone image treatment — editorial monochrome-luxe (re-grades ../assets) */
.duo{position:relative;overflow:hidden;background:var(--slate-3)}
.duo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.04) brightness(1.02);
  mix-blend-mode:luminosity;opacity:.9;
  transition:transform 1.1s var(--ease),opacity .5s ease;
}
.duo::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(178deg,rgba(15,22,26,.05) 0%,rgba(20,30,34,.42) 62%,rgba(12,18,21,.86) 100%)}
.duo::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%,rgba(209,235,242,.16),transparent 60%);mix-blend-mode:screen}

/* Image teaser card (Insights / Speaking) */
.pcard{
  position:relative;display:block;border-radius:var(--radius);overflow:hidden;
  min-height:340px;isolation:isolate;
  box-shadow:var(--sh-card);transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05) brightness(1);mix-blend-mode:luminosity;opacity:.9;
  transition:transform 1.2s var(--ease)}
.pcard::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(175deg,rgba(20,30,34,.12) 0%,rgba(18,27,31,.5) 55%,rgba(11,16,19,.9) 100%)}
.pcard::after{content:"";position:absolute;inset:0;z-index:1;background:var(--slate-3);opacity:.28;mix-blend-mode:multiply}
.pcard__in{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.9rem 1.75rem;gap:.7rem;color:#fff}
.pcard .cat{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ice)}
.pcard h3{font-family:var(--serif);font-weight:400;font-size:1.32rem;line-height:1.18;letter-spacing:-.01em;color:#fff;
  font-variation-settings:"opsz" 60}
.pcard .m{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-top:.25rem}
.pcard::after,.pcard::before{transition:opacity .5s ease}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--sh-hover)}
.pcard:hover img{transform:scale(1.05)}
.pcard .arw-c{position:absolute;top:1.4rem;right:1.4rem;z-index:2;width:2.4rem;height:2.4rem;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;color:#fff;
  opacity:0;transform:translateY(-6px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.pcard:hover .arw-c{opacity:1;transform:none}

/* ── Slate / dark contexts — remap vars so components flip ──────────── */
.slate,.dark{
  --ink:#ffffff;--ink-soft:rgba(255,255,255,.9);--body:rgba(255,255,255,.76);
  --muted:rgba(255,255,255,.58);--dim:var(--ice);--emerald:var(--ice);
  --hair:rgba(255,255,255,.16);--hair-ink:rgba(255,255,255,.22);--hair-soft:rgba(255,255,255,.1);
  color:var(--body);
}
.slate{position:relative;color:#fff;
  background:
    radial-gradient(120% 120% at 50% -18%, rgba(209,235,242,.14), transparent 52%),
    radial-gradient(90% 90% at 50% 12%, var(--slate-1) 0%, var(--slate-2) 52%, var(--slate-3) 100%);
}
.dark{position:relative;color:#fff;background:var(--near-black)}
.dark::before,.slate::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(70% 55% at 50% 0%,rgba(209,235,242,.10),transparent 60%)}
.slate>*,.dark>*{position:relative;z-index:1}
.slate .eyebrow,.dark .eyebrow{background:rgba(255,255,255,.06)}
.slate .btn--ghost:hover,.dark .btn--ghost:hover{background:#fff;color:var(--slate-2);border-color:#fff}

/* ── Navigation (fixed, blur) ──────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease}
.nav.is-scrolled{border-bottom-color:var(--hair);background:rgba(255,255,255,.85)}
.nav__in{max-width:1320px;margin-inline:auto;padding:1rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;flex-direction:column;line-height:1;gap:.3rem}
.brand b{font-family:var(--sans);font-weight:600;font-size:1.28rem;letter-spacing:.02em;color:var(--ink)}
.brand span{font-family:var(--mono);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.nav__mid{display:flex;align-items:center;gap:1.9rem}
.navlink{font-family:var(--sans);font-weight:500;font-size:.86rem;letter-spacing:.01em;color:#48555b;
  position:relative;padding:.3rem 0;transition:color .25s ease}
.navlink:hover{color:var(--ink)}
.navlink.on{color:var(--ink)}
.navlink.on::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--emerald)}
.nav__end{display:flex;align-items:center;gap:1.15rem}
.nav__util{font-family:var(--sans);font-weight:500;font-size:.78rem;color:var(--muted);transition:color .25s}
.nav__util:hover{color:var(--ink)}
.nav__util.on{color:var(--emerald)}
.nav__lang{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;color:var(--muted);
  border:1px solid var(--hair);border-radius:var(--pill);padding:.28rem .55rem}
.burger{display:none;flex-direction:column;gap:5px;padding:.5rem;margin:-.5rem}
.burger span{display:block;width:24px;height:1.5px;background:var(--ink);transition:transform .3s var(--ease),opacity .2s}

/* Mobile menu panel */
.mnav{display:none}
@media (max-width:940px){
  .nav__mid,.nav__end .nav__util,.nav__end .nav__lang,.nav__end .btn{display:none}
  .burger{display:flex}
  .mnav{position:fixed;inset:64px 0 auto 0;z-index:55;display:block;
    background:rgba(255,255,255,.96);backdrop-filter:blur(18px);
    border-bottom:1px solid var(--hair);padding:1.6rem var(--gutter) 2.2rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .4s var(--ease),opacity .3s ease}
  .mnav.open{transform:none;opacity:1;pointer-events:auto}
  .mnav a{display:block;font-family:var(--sans);font-weight:500;font-size:1.15rem;color:var(--ink);
    padding:.85rem 0;border-bottom:1px solid var(--hair-soft)}
  .mnav a.on{color:var(--emerald)}
  .mnav .btn{margin-top:1.4rem;width:100%}
  .mnav .mono-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
    color:var(--muted);margin-bottom:.9rem;display:block}
  body.menu-open .burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  body.menu-open .burger span:nth-child(2){opacity:0}
  body.menu-open .burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* ── Footer ────────────────────────────────────────────────────────── */
.footer{background:var(--ink);color:#fff;position:relative}
.footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;
  padding-block:clamp(3.5rem,6vw,5.5rem)}
.footer .brand b{color:#fff}
.footer .brand span{color:rgba(255,255,255,.5)}
.footer .fblurb{color:rgba(255,255,255,.62);font-size:.94rem;line-height:1.6;margin-top:1.25rem;max-width:30ch}
.footer .fmail{display:inline-flex;margin-top:1.5rem;color:#fff;font-family:var(--sans);font-weight:500;
  border-bottom:1px solid rgba(255,255,255,.35);padding-bottom:2px;transition:color .25s,border-color .25s}
.footer .fmail:hover{color:var(--ice);border-color:var(--ice)}
.footer .fcol h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:1.15rem;font-weight:500}
.footer .fcol a:not(.brand):not(.fmail){display:block;color:rgba(255,255,255,.82);font-size:.94rem;padding:.42rem 0;transition:color .22s}
.footer .fcol a:not(.brand):not(.fmail):hover{color:var(--ice)}
.footer .bar{border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-block:1.6rem;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.footer .bar a:hover{color:var(--ice)}

/* ── Reveal motion ─────────────────────────────────────────────────── */
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.reveal{animation:rise .85s var(--ease) both}
.d1{animation-delay:.08s}.d2{animation-delay:.16s}.d3{animation-delay:.24s}
.d4{animation-delay:.32s}.d5{animation-delay:.4s}.d6{animation-delay:.48s}
/* scroll-triggered */
.obs{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.obs.in{opacity:1;transform:none}
.obs.s1{transition-delay:.06s}.obs.s2{transition-delay:.14s}.obs.s3{transition-delay:.22s}
.obs.s4{transition-delay:.3s}.obs.s5{transition-delay:.38s}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.obs{animation:none!important;opacity:1!important;transform:none!important;transition:none!important}
  .btn:hover,.card:hover,.pcard:hover{transform:none}
}

/* ══ PAGE SECTIONS (reused across pages — kept here, not duplicated) ══ */

/* Hero (slate, centered editorial) */
.hero{position:relative;text-align:center;
  padding-top:clamp(8rem,15vh,11rem);padding-bottom:clamp(9rem,15vw,13.5rem);overflow:hidden}
.hero .eyebrow{margin-bottom:2rem}
.hero .display{margin-inline:auto;max-width:19ch}
.hero__lede{margin:2rem auto 0;max-width:58ch;color:rgba(255,255,255,.82);
  font-size:clamp(1.04rem,1.2vw,1.25rem);line-height:1.62}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.7rem}
.hero__sub{margin:2.4rem auto 0;max-width:52rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem 1.4rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.11em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.hero__sub span{display:inline-flex;align-items:center;gap:.55rem}
.hero__sub span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--ice);opacity:.8}

/* Hero figure — wide duotone image overlapping hero → body */
.hero-figure{position:relative;z-index:3;max-width:1130px;margin:-14vw auto 0;
  border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/6.1;box-shadow:var(--sh-pop);background:var(--slate-3)}
.hero-figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.06) brightness(1.04)}
.hero-figure::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(35,49,55,.14) 0%,rgba(30,42,48,.30) 100%);mix-blend-mode:multiply}
.hero-figure::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 95% at 50% -6%,rgba(209,235,242,.18),transparent 56%);mix-blend-mode:screen}
.hero-figure .cap{position:absolute;left:1.6rem;bottom:1.4rem;z-index:2;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72)}
@media (max-width:940px){.hero-figure{margin-top:-22vw;aspect-ratio:16/9}}

/* Statement — large editorial pull statement on warm paper */
.statement{background:var(--paper);text-align:center}
.statement .q{font-family:var(--serif);font-weight:400;font-variation-settings:"opsz" 110;
  font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.18;letter-spacing:-.014em;color:var(--ink);
  max-width:24ch;margin:1.6rem auto 0;text-wrap:balance}
.statement .q .dim{color:var(--dim)}
.statement .kicker{justify-content:center}

/* Section header w/ trailing link (teasers) */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.7rem}
.sec-head__t .h2,.sec-head__t .display{margin-top:1rem}
.sec-head .tlink{flex:0 0 auto;padding-bottom:.4rem}

/* What We Do — practice cards (image + index + label) */
.pa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.9rem}
.pa-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;
  min-height:262px;padding:1.55rem 1.5rem;border-radius:var(--radius);overflow:hidden;isolation:isolate;
  color:#fff;box-shadow:var(--sh-card);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.pa-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05) brightness(1);mix-blend-mode:luminosity;opacity:.88;transition:transform 1.2s var(--ease)}
.pa-card::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(168deg,rgba(20,30,34,.28) 0%,rgba(16,24,28,.62) 60%,rgba(11,16,19,.9) 100%)}
.pa-card::after{content:"";position:absolute;inset:0;z-index:1;background:var(--slate-3);opacity:.24;mix-blend-mode:multiply}
.pa-card>*{position:relative;z-index:2}
.pa-card .idx{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;color:var(--ice)}
.pa-card b{font-family:var(--serif);font-weight:400;font-size:1.4rem;line-height:1.12;letter-spacing:-.01em;
  font-variation-settings:"opsz" 60;text-wrap:balance}
.pa-card:hover{transform:translateY(-6px);box-shadow:var(--sh-hover)}
.pa-card:hover img{transform:scale(1.06)}

/* Stat row (light ice band) */
.stat-band{background:linear-gradient(180deg,var(--ice-soft),#fff)}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;align-items:start}
.stat-row .cell{position:relative;padding-left:1.5rem}
.stat-row .cell::before{content:"";position:absolute;left:0;top:.35rem;bottom:.35rem;width:1px;background:var(--hair)}
.stat-row .cell:first-child::before{background:var(--emerald);width:2px}

/* Closing CTA band */
.cta-band{text-align:center}
.cta-band .display,.cta-band .h2{margin-inline:auto;max-width:20ch}
.cta-band p{margin:1.5rem auto 0;max-width:56ch;color:rgba(255,255,255,.8)}
.cta-band .hero-actions{margin-top:2.4rem}

@media (max-width:940px){
  .pa-grid{grid-template-columns:repeat(2,1fr)}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:2.2rem 1.5rem}
  .sec-head{flex-direction:column;align-items:flex-start;gap:1rem}
}
@media (max-width:560px){
  .pa-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr;gap:1.8rem}
  .stat-row .cell{padding-left:1.2rem}
}

/* ── Grids used across pages ───────────────────────────────────────── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.ind-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}
.ind-grid .icard{flex:0 1 calc((100% - 3rem)/3);min-width:282px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.flow>*+*{margin-top:1.15rem}

@media (max-width:940px){
  .footer .top{grid-template-columns:1fr 1fr;gap:2rem 1.5rem}
  .footer .fbrandcol{grid-column:1 / -1}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .grid-3,.grid-2,.grid-4{grid-template-columns:1fr}
  .footer .top{grid-template-columns:1fr}
  .btn{width:100%}
  .hero-actions .btn{width:auto}
}

/* ══════════════════════════════════════════════════════════════════════
   INNER-PAGE COMPONENTS (shared across about / practice / industries /
   insights / speaking-media / contact — kept here, never duplicated)
   ══════════════════════════════════════════════════════════════════════ */

/* Light page hero (inner pages) */
.phero{position:relative;padding-top:clamp(9rem,16vh,12.5rem);padding-bottom:clamp(2rem,4vw,3.25rem);overflow:hidden}
.phero .eyebrow{margin-bottom:1.6rem}
.phero .display{max-width:17ch}
.phero__lede{margin-top:1.9rem;max-width:62ch}
.phero__meta{margin-top:1.5rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);line-height:1.6}
.phero__meta b{color:var(--ink);font-weight:500}

/* Group heading */
.ghead{display:flex;align-items:baseline;justify-content:space-between;gap:1.5rem;
  padding-bottom:1rem;border-bottom:1px solid var(--hair)}
.ghead h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.5rem,2.4vw,2.15rem);letter-spacing:-.014em;color:var(--ink);font-variation-settings:"opsz" 72}
.ghead .count{font-family:var(--mono);font-size:.68rem;letter-spacing:.11em;text-transform:uppercase;color:var(--muted);white-space:nowrap}

/* Post rows (insights / speaking lists) */
.prow{display:grid;grid-template-columns:210px 1fr;gap:clamp(1.5rem,3vw,2.4rem);
  padding:1.9rem 0;border-top:1px solid var(--hair);position:relative;transition:padding .3s var(--ease)}
.prow:first-child{border-top:none}
.prow::before{content:"";position:absolute;left:0;top:1.9rem;bottom:1.9rem;width:2px;background:var(--emerald);
  transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.prow:hover{padding-left:1.1rem}
.prow:hover::before{transform:scaleY(1)}
.prow__side{font-family:var(--mono);font-size:.66rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);line-height:1.6;padding-top:.3rem}
.prow__side b{display:block;color:var(--ink);font-weight:500;font-size:.7rem;margin-bottom:.3rem}
.prow h3{font-family:var(--serif);font-weight:400;font-size:1.32rem;line-height:1.22;letter-spacing:-.01em;color:var(--ink);font-variation-settings:"opsz" 50}
.prow h3 a{transition:color .25s}.prow:hover h3 a{color:var(--emerald)}
.prow__dek{margin-top:.6rem;font-size:.95rem;line-height:1.6;color:var(--body);max-width:66ch}
.prow .kicker{margin-bottom:.7rem}
.prow .also{margin-top:.9rem}

/* Tags */
.tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}
.tags span{font-family:var(--mono);font-size:.6rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--hair);border-radius:var(--pill);padding:.35rem .7rem;background:var(--bg-1)}

/* Featured article (insights) */
.feature{display:grid;grid-template-columns:1.5fr 1fr;border:1px solid var(--hair);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--sh-card);margin-top:1.6rem}
.feature__body{padding:clamp(1.8rem,3vw,2.7rem)}
.feature h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.55rem,2.4vw,2.15rem);line-height:1.12;
  letter-spacing:-.016em;color:var(--ink);margin-top:1rem;font-variation-settings:"opsz" 90}
.feature h3 a{transition:color .25s}.feature h3 a:hover{color:var(--emerald)}
.feature__dek{margin-top:1rem;font-size:1rem;line-height:1.62;color:var(--body);max-width:58ch}
.feature__meta{margin-top:1.1rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.feature__acts{margin-top:1.7rem;display:flex;gap:1.3rem;align-items:center;flex-wrap:wrap}
.feature__aside{position:relative;background:var(--slate-2);color:#fff;padding:2rem;display:flex;flex-direction:column;justify-content:flex-end;min-height:240px;overflow:hidden}
.feature__aside::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 82% 8%,rgba(209,235,242,.18),transparent 60%)}
.feature__aside .no{position:absolute;top:1.3rem;left:1.6rem;font-family:var(--serif);font-size:3.6rem;color:rgba(255,255,255,.12);line-height:1}
.feature__aside .src{font-family:var(--serif);font-size:1.6rem;line-height:1.08;position:relative;z-index:1}
.feature__aside .sub{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ice);margin-top:.9rem;position:relative;z-index:1}

/* Testimony cards (speaking) */
.tcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--hair);border-radius:var(--radius);
  padding:1.7rem 1.7rem 1.5rem;box-shadow:var(--sh-card);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--sh-hover)}
.tcard .cmte{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--emerald);line-height:1.5}
.tcard h3{font-family:var(--serif);font-weight:400;font-size:1.24rem;line-height:1.18;letter-spacing:-.01em;color:var(--ink);margin-top:.9rem;font-variation-settings:"opsz" 48}
.tcard h3 a:hover{color:var(--emerald)}
.tcard .role{font-size:.9rem;line-height:1.5;color:var(--body);margin-top:.9rem}
.tcard .role b{color:var(--ink);font-weight:600}
.tcard .tt{font-family:var(--mono);font-size:.6rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-top:.9rem;line-height:1.5}
.tcard .tlink{margin-top:auto;padding-top:1.5rem;align-self:flex-start}

/* Practice rows */
.parow{display:grid;grid-template-columns:330px 1fr;gap:clamp(2rem,4vw,3.5rem);
  padding:clamp(2.5rem,4vw,3.75rem) 0;border-top:1px solid var(--hair);align-items:start}
.parow:first-child{border-top:none}
.parow__idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--emerald)}
.parow h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,2.5vw,2.15rem);line-height:1.06;
  letter-spacing:-.018em;color:var(--ink);margin-top:.7rem;font-variation-settings:"opsz" 90}
.parow__thumb{margin-top:1.5rem;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10}
.parow__grp+.parow__grp{margin-top:1.6rem}
.parow .lbl{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--emerald);margin-bottom:.55rem}
.parow__body p{font-size:1rem;line-height:1.68;color:var(--body);max-width:72ch}

/* Industry cards */
.icard{background:#fff;border:1px solid var(--hair);border-radius:var(--radius);padding:1.9rem 1.75rem;
  box-shadow:var(--sh-card);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.icard:hover{transform:translateY(-5px);box-shadow:var(--sh-hover);border-color:#dfe4e5}
.icard .k{font-family:var(--mono);font-size:.64rem;letter-spacing:.11em;text-transform:uppercase;color:var(--emerald)}
.icard h3{font-family:var(--serif);font-weight:400;font-size:1.32rem;line-height:1.12;letter-spacing:-.012em;color:var(--ink);margin-top:.8rem;font-variation-settings:"opsz" 48}
.icard p{margin-top:.9rem;font-size:.94rem;line-height:1.62;color:var(--body)}

/* Bio (about) */
.bio{display:grid;grid-template-columns:360px 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.bio__portrait{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--sh-card)}
.bio__portrait img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03)}
.bio__portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(35,49,55,.32));mix-blend-mode:multiply}
.bio__body p{font-size:1rem;line-height:1.72;color:var(--body)}
.bio__body p+p{margin-top:1rem}
.creds{margin-top:1.9rem;border-top:1px solid var(--hair);padding-top:1.7rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem 2rem}
.creds div{font-size:.92rem;line-height:1.5;color:var(--body);padding-left:1.15rem;position:relative}
.creds div::before{content:"";position:absolute;left:0;top:.5rem;width:6px;height:6px;border-radius:50%;background:var(--emerald)}
.creds b{color:var(--ink);font-weight:600}

/* Pull quote (about) */
.pullq q{quotes:none;font-family:var(--serif);font-weight:400;font-size:clamp(1.85rem,3.5vw,3rem);line-height:1.16;
  letter-spacing:-.016em;color:#fff;display:block;max-width:24ch}
.pullq .attr{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ice);margin-top:1.7rem}

/* Narrative block (about firm) */
.narr{display:grid;grid-template-columns:230px 1fr;gap:clamp(1.5rem,4vw,3rem)}
.narr .lab{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-top:.4rem}
.narr__body p{font-size:1.08rem;line-height:1.7;color:var(--ink-soft)}
.narr__body p+p{margin-top:1.1rem}

/* Outlets strip */
.outlets{text-align:center}
.outlets .lab{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1.9rem}
.outlets .row{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.2rem;max-width:920px;margin-inline:auto}
.outlets .row span{font-family:var(--serif);font-size:1.2rem;letter-spacing:.005em;color:var(--dim);transition:color .25s;font-variation-settings:"opsz" 40}
.outlets .row span:hover{color:var(--ink)}

/* Book credit band (insights) */
.creditband{background:var(--slate-2);color:#fff}
.creditband .in{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
.creditband h2{color:#fff}
.creditbox{border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);padding:1.9rem}
.creditbox .t{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.creditbox .v{font-size:.98rem;margin-top:.4rem;line-height:1.4}
.creditbox .v.accent{color:var(--ice)}
.creditbox .divide{height:1px;background:rgba(255,255,255,.14);margin:1.3rem 0}

/* Honors band (speaking) */
.honors{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem}
.honor{display:block;border-top:2px solid rgba(255,255,255,.4);padding-top:1.05rem;color:#fff}
.honor .h{font-family:var(--serif);font-size:1.22rem;line-height:1.08}
.honor .d{font-family:var(--mono);font-size:.6rem;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-top:.7rem;line-height:1.5}
a.honor:hover .h{color:var(--ice)}

/* Contact form */
.cform-grid{display:grid;grid-template-columns:1.3fr .82fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.cform label{display:block;font-family:var(--mono);font-size:.63rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.55rem}
.cform .field{margin-bottom:1.3rem}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.cform input,.cform textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;
  border:1px solid var(--hair);border-radius:10px;padding:.9rem 1rem;transition:border-color .25s,box-shadow .25s}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(12,104,38,.1)}
.cform textarea{min-height:155px;resize:vertical}
.cform .confid{font-size:.85rem;color:var(--muted);margin:.2rem 0 1.5rem;line-height:1.55}
.cinfo{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:clamp(1.8rem,3vw,2.4rem);align-self:start}
.cinfo .blk{padding:1.4rem 0;border-top:1px solid rgba(255,255,255,.14)}
.cinfo .blk:first-child{padding-top:0;border-top:none}
.cinfo .k{font-family:var(--mono);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ice);margin-bottom:.55rem}
.cinfo .big{font-size:1.12rem;font-weight:500;line-height:1.3}
.cinfo .big a{border-bottom:1px solid rgba(255,255,255,.3);transition:color .25s,border-color .25s}
.cinfo .big a:hover{color:var(--ice);border-color:var(--ice)}
.cinfo p{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.75);margin-top:.5rem}

/* CTA band shared bottom (inner pages) */
.cta-inner{text-align:left}
.cta-inner .display,.cta-inner .h2{max-width:20ch}
.cta-inner p{margin-top:1.4rem;max-width:60ch;color:rgba(255,255,255,.8)}
.cta-inner .hero-actions{justify-content:flex-start;margin-top:2.2rem}

/* ── Inner-page responsive ── */
@media (max-width:940px){
  .feature{grid-template-columns:1fr}
  .feature__aside{min-height:180px}
  .prow{grid-template-columns:1fr;gap:.5rem}
  .prow:hover{padding-left:0}
  .prow::before{display:none}
  .grid-3.tgrid{grid-template-columns:1fr 1fr}
  .parow{grid-template-columns:1fr;gap:1.5rem}
  .bio{grid-template-columns:1fr;gap:2rem}
  .bio__portrait{max-width:320px}
  .creds{grid-template-columns:1fr}
  .narr{grid-template-columns:1fr;gap:.8rem}
  .creditband .in{grid-template-columns:1fr}
  .honors{grid-template-columns:repeat(2,1fr);gap:1.8rem 1.5rem}
  .cform-grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  .tgrid{grid-template-columns:1fr!important}
  .honors{grid-template-columns:1fr}
  .cform .frow{grid-template-columns:1fr;gap:0}
  .outlets .row{gap:.7rem 1.3rem}
}
