/*
 * Consilium Group Advisors — theme stylesheet
 * Ported from the Claude Design system (Design System.dc.html + Consilium Home.dc.html).
 * Tokens live in :root; components are semantic classes so templates stay clean.
 */

/* ============================ RESET / BASE ============================ */
*, *::before, *::after { box-sizing: border-box; }
body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, ul, ol { margin: 0; }
ul[class], ol[class] { list-style: none; padding: 0; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

:root {
  --navy: #154A96;
  --navy-deep: #0E3470;
  --navy-11: #11315E;
  --teal: #1C7C93;
  --sky: #5CC8DE;
  --accent: #FF6B35;
  --accent-ink: #C2511E;
  --paper: #F4F1EB;
  --paper-2: #ECE6DA;
  --header-bg: #FBFAF7;
  --cream: #FAF7F1;
  --ink: #14233A;
  --ink-2: #41505F;
  --ink-3: #56646F;
  --ink-4: #5E6B7A;
  --muted: #7A8794;
  --pad: 116px;
  --maxw: 1300px;
  --gutter: 48px;
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
  --font-display: 'Archivo', system-ui, sans-serif;
  --font-body: 'Public Sans', system-ui, sans-serif;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  overflow-x: hidden;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
::selection { background: var(--accent); color: var(--navy); }

/* ============================ LAYOUT ============================ */
.container { max-width: var(--maxw); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }
.section { padding-top: var(--pad); padding-bottom: var(--pad); }
.section--sm { padding-top: 96px; padding-bottom: 96px; }
.bg-paper { background: var(--paper); }
.bg-paper-2 { background: var(--paper-2); }
.bg-navy { background: var(--navy); color: var(--cream); }
.bg-navy-deep { background: var(--navy-deep); color: var(--cream); }

.grid { display: grid; }
.flex { display: flex; }
.wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.items-start { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.gap-40 { gap: 40px; }

/* ============================ TYPE HELPERS ============================ */
.display { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; }
.h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(46px, 7.2vw, 104px); line-height: 1.0; letter-spacing: -0.03em; }
.h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.4vw, 44px); line-height: 1.12; letter-spacing: -0.018em; }
.h2--tight { line-height: 1.1; }
.lead { font-size: 18px; line-height: 1.62; }
.body { font-size: 17px; line-height: 1.68; color: var(--ink-2); }
.italic-accent { font-style: italic; color: var(--accent); }
.italic-accent-ink { font-style: italic; color: var(--accent-ink); }
.measure { max-width: 62ch; }

/* Eyebrow (rule + tracked label) */
.eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.eyebrow__rule { width: 24px; height: 1px; background: var(--accent-ink); flex-shrink: 0; }
.eyebrow__label { font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 0.24em; color: var(--accent-ink); text-transform: uppercase; }
.eyebrow--center { justify-content: center; }
.on-navy .eyebrow__rule, .eyebrow--navy .eyebrow__rule { background: var(--accent); }
.on-navy .eyebrow__label, .eyebrow--navy .eyebrow__label { color: rgba(244,241,235,0.72); }

/* section intro divider label */
.divider-label { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.divider-label span:first-child { font-family: var(--font-body); font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--sky); }
.divider-label .line { flex: 1; height: 1px; background: rgba(244,241,235,0.16); }
.divider-label--ink span:first-child { color: var(--navy); }
.divider-label--ink .line { background: rgba(20,35,58,0.14); }

/* ============================ BUTTONS ============================ */
.btn { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; padding: 14px 24px; border-radius: 2px; border: 1px solid transparent; transition: filter 0.25s ease, background 0.25s ease, border-color 0.25s ease, color 0.25s ease; }
.btn--primary { background: var(--accent); color: #1A0E06; }
.btn--primary:hover { filter: brightness(1.07); }
.btn--navy { background: var(--navy); color: #fff; font-weight: 700; }
.btn--navy:hover { background: var(--accent); color: #1A0E06; }
.btn--outline { border-color: rgba(20,35,58,0.3); color: var(--ink); }
.btn--outline:hover { border-color: rgba(20,35,58,0.65); }
.btn--ghost { border-color: rgba(244,241,235,0.3); color: var(--cream); }
.btn--ghost:hover { border-color: rgba(244,241,235,0.65); }
.btn--lg { font-size: 15px; padding: 16px 28px; }

/* Pills / tags */
.pills { display: flex; flex-wrap: wrap; gap: 10px; }
.pill { font-size: 12.5px; font-weight: 500; color: var(--ink); border: 1px solid rgba(20,35,58,0.18); border-radius: 100px; padding: 8px 16px; }
.pill--serif { font-family: var(--font-display); font-size: 15px; color: #2B3A4F; padding: 7px 15px; }

/* ============================ HEADER ============================ */
.site-header { position: sticky; top: 0; z-index: 50; background: var(--header-bg); border-bottom: 1px solid rgba(20,35,58,0.10); box-shadow: 0 1px 0 rgba(20,35,58,0.02), 0 6px 22px rgba(20,35,58,0.05); }
.site-header__inner { max-width: var(--maxw); margin: 0 auto; padding: 14px 48px; display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.brand { display: flex; align-items: center; gap: 16px; color: #142B45; }
.brand__pin { height: 46px; width: auto; flex-shrink: 0; }
.brand__mark { height: 28px; width: auto; }
.brand__rule { width: 1px; height: 36px; background: rgba(20,35,58,0.18); }
.brand__name { display: flex; flex-direction: column; line-height: 1.34; }
.brand__name b { font-weight: 800; font-size: 13px; letter-spacing: 0.17em; color: #142B45; }
.brand__name i { font-style: normal; font-weight: 700; font-size: 9.5px; letter-spacing: 0.2em; color: var(--teal); }

.main-nav { display: flex; align-items: center; gap: 28px; font-size: 13px; font-weight: 600; color: #46546A; }
.main-nav a { padding: 4px 0; transition: color 0.2s ease; }
.main-nav a:hover, .main-nav .current-menu-item > a, .main-nav .current_page_item > a { color: var(--navy); }
.main-nav a.btn--navy, .main-nav .menu-item-cta > a { padding: 10px 20px; background: var(--navy); border-radius: 2px; color: #fff; font-weight: 700; }
.main-nav a.btn--navy:hover, .main-nav .menu-item-cta > a:hover { background: var(--accent); color: #1A0E06; }

.nav-toggle { display: none; background: none; border: 0; padding: 8px; color: var(--navy); }
.nav-toggle svg { width: 26px; height: 26px; }

/* ============================ HERO (home) ============================ */
.hero { background: var(--navy); color: var(--paper); position: relative; }
.hero__inner { max-width: var(--maxw); margin: 0 auto; padding: 92px 48px 0; animation: cgaUp 0.8s var(--ease) both; }
.hero__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(46px, 7.2vw, 104px); line-height: 1.0; letter-spacing: -0.03em; max-width: 18ch; color: var(--cream); }
.hero__row { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 40px; margin-top: 42px; }
.hero__lead { font-size: 18px; line-height: 1.62; max-width: 50ch; color: rgba(244,241,235,0.8); }
.hero__lead strong { color: var(--cream); font-weight: 400; }
.hero__media { max-width: var(--maxw); margin: 50px auto 0; padding: 0 48px; }
.hero__frame { height: clamp(300px, 42vw, 540px); border-radius: 3px 3px 0 0; position: relative; overflow: hidden; background: var(--navy-deep); }
.hero__frame img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 60% 44%; animation: cgaFloat 15s ease-in-out infinite; will-change: transform; }
.hero__scrim-1 { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(14,52,112,0.78) 0%, rgba(14,52,112,0.28) 34%, rgba(14,52,112,0) 56%); }
.hero__scrim-2 { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(14,52,112,0.5) 0%, rgba(14,52,112,0) 30%); }
.hero__tag { position: absolute; left: 26px; bottom: 22px; display: flex; align-items: center; gap: 11px; }
.hero__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent); }
.hero__tag span:last-child { font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: #fff; }
.hero-eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 32px; }
.hero-eyebrow span:first-child { width: 32px; height: 1px; background: var(--accent); }
.hero-eyebrow span:last-child { font-family: var(--font-body); font-size: 11.5px; font-weight: 500; letter-spacing: 0.24em; color: rgba(244,241,235,0.7); text-transform: uppercase; }

/* ============================ STAT ROW ============================ */
.stat-row { max-width: var(--maxw); margin: 0 auto; padding: 0 48px; }
.stat-row__grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(244,241,235,0.16); }
.stat { padding: 34px 24px; border-right: 1px solid rgba(244,241,235,0.14); }
.stat:first-child { padding-left: 0; }
.stat:last-child { padding-right: 0; border-right: 0; }
.stat__num { font-family: var(--font-display); font-size: 44px; font-weight: 600; letter-spacing: -0.02em; color: var(--cream); }
.stat__num span { color: var(--accent); }
.stat__label { font-size: 12.5px; color: rgba(244,241,235,0.66); margin-top: 6px; }
.stat-panel { background: var(--navy); border-radius: 8px; padding: 8px 40px; }
.stat-panel .stat-row__grid { border-top: 0; }

/* ============================ SECTION HEADER (two-column) ============================ */
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 48px; flex-wrap: wrap; margin-bottom: 56px; }
.sec-head__aside { font-size: 14.5px; line-height: 1.6; color: var(--ink-4); max-width: 34ch; }
.on-navy .sec-head__aside { color: rgba(244,241,235,0.7); }

/* WHO WE ARE (sticky two-col) */
.whoweare { display: grid; grid-template-columns: 0.85fr 1.45fr; gap: 80px; align-items: start; }
.whoweare__aside { position: sticky; top: 110px; }
.whoweare__quote { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.4; color: #2B3A4F; max-width: 22ch; }

/* Core promise */
.promise { text-align: center; }
.promise__text { font-family: var(--font-display); font-weight: 600; font-size: clamp(26px, 3.6vw, 46px); line-height: 1.22; letter-spacing: -0.015em; color: var(--ink); max-width: 26ch; margin: 26px auto 0; }

/* ============================ CARDS ============================ */
.card-grid { display: grid; gap: 18px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
.cols-5 { grid-template-columns: repeat(5, 1fr); }

/* Value card (numbered, icon, centered) */
.value-card { position: relative; background: #fff; border: 1px solid rgba(20,35,58,0.12); border-radius: 4px; padding: 36px 20px 30px; min-height: 256px; display: flex; flex-direction: column; align-items: center; text-align: center; transition: transform 0.35s var(--ease), box-shadow 0.35s ease, border-color 0.35s ease; }
.value-card:hover { transform: translateY(-8px); box-shadow: 0 18px 40px rgba(14,52,112,0.13); border-color: rgba(14,52,112,0.28); }
.value-card__num { position: absolute; top: 14px; left: 0; right: 0; text-align: center; font-family: var(--font-display); font-weight: 800; font-size: 84px; line-height: 1; color: rgba(14,52,112,0.05); letter-spacing: -0.04em; pointer-events: none; }
.icon-badge { position: relative; width: 58px; height: 58px; border-radius: 50%; background: linear-gradient(145deg, var(--navy-deep), var(--teal)); display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 18px rgba(14,52,112,0.22); }
.icon-badge svg { stroke: #fff; }
.icon-badge--rounded { border-radius: 14px; width: 56px; height: 56px; }
.value-card__title { position: relative; font-family: var(--font-display); font-weight: 700; font-size: clamp(15px, 1.45vw, 19px); letter-spacing: -0.01em; color: var(--ink); margin-top: 20px; white-space: nowrap; }
.tick { width: 26px; height: 3px; background: var(--accent); border-radius: 3px; margin-top: 12px; }
.value-card__text { position: relative; font-size: 13px; line-height: 1.58; color: var(--ink-3); margin-top: 14px; }

/* Callout (accent left rule) */
.callout { display: flex; align-items: flex-start; gap: 22px; margin-top: 40px; padding: 30px 34px; background: color-mix(in srgb, var(--accent) 9%, var(--paper)); border-left: 3px solid var(--accent); border-radius: 2px; }
.callout__tag { font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-ink); white-space: nowrap; padding-top: 4px; }
.callout__text { font-family: var(--font-display); font-weight: 500; font-size: clamp(17px, 1.8vw, 22px); line-height: 1.42; letter-spacing: -0.01em; color: #1F2E42; max-width: 70ch; }

/* Lens card (on navy) */
.lens-card { position: relative; background: rgba(255,255,255,0.04); border: 1px solid rgba(244,241,235,0.16); border-radius: 6px; padding: 34px 30px; transition: transform 0.35s var(--ease), background 0.35s ease, border-color 0.35s ease; }
.lens-card:hover { transform: translateY(-6px); background: rgba(255,255,255,0.07); border-color: rgba(92,200,222,0.5); }
.lens-card__title { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.01em; color: var(--cream); margin-top: 22px; }
.lens-card__sub { font-size: 12px; font-weight: 600; letter-spacing: 0.04em; color: var(--sky); margin-top: 4px; }
.lens-card__quote { font-family: var(--font-display); font-style: italic; font-size: 16px; line-height: 1.5; color: rgba(244,241,235,0.86); margin-top: 16px; }

/* Approach note banner */
.approach-note { display: flex; align-items: center; gap: 16px; margin-top: 26px; padding: 22px 28px; background: color-mix(in srgb, var(--accent) 13%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent); border-radius: 6px; }
.approach-note p { font-family: var(--font-display); font-weight: 500; font-size: clamp(15px, 1.6vw, 19px); line-height: 1.45; color: var(--cream); }
.approach-note svg { flex-shrink: 0; stroke: var(--accent); }

/* Method steps */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); align-items: stretch; }
.step { position: relative; padding: 30px 26px; border-left: 1px solid rgba(244,241,235,0.14); }
.step:first-child { padding-left: 0; border-left: 0; }
.step:last-child { padding-right: 0; }
.step__head { display: flex; align-items: center; gap: 14px; }
.step__ring { width: 46px; height: 46px; border-radius: 50%; border: 1.5px solid var(--accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: var(--navy); }
.step__ring svg { stroke: var(--accent); }
.step__kicker { font-family: var(--font-display); font-weight: 800; font-size: 13px; letter-spacing: 0.16em; color: var(--accent); }
.step h4 { font-size: 16px; font-weight: 600; color: var(--cream); margin-top: 18px; }
.step p { font-size: 13.5px; line-height: 1.58; color: rgba(244,241,235,0.66); margin-top: 8px; }
.step__arrow { position: absolute; top: 53px; right: -1px; transform: translateY(-50%); color: rgba(92,200,222,0.55); font-size: 18px; }
.step:last-child .step__arrow { display: none; }
.cycle-note { display: flex; align-items: center; gap: 10px; margin-top: 18px; font-size: 13px; color: rgba(244,241,235,0.6); }
.cycle-note svg { stroke: var(--sky); flex-shrink: 0; }

/* Practice card (image + body + leader) */
.practice-card { display: flex; flex-direction: column; background: #fff; border: 1px solid rgba(20,35,58,0.12); border-radius: 5px; overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; height: 100%; }
.practice-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(14,52,112,0.12); border-color: rgba(14,52,112,0.26); }
.practice-card__media { height: 188px; overflow: hidden; background: var(--navy-deep); position: relative; }
.practice-card__media img { width: 100%; height: 100%; object-fit: cover; }
.practice-card__body { padding: 26px 26px 28px; display: flex; flex-direction: column; flex: 1; }
.practice-card__title { font-family: var(--font-display); font-weight: 600; font-size: 21px; line-height: 1.18; letter-spacing: -0.01em; color: var(--ink); }
.practice-card__tagline { font-family: var(--font-display); font-style: italic; font-size: 14.5px; color: var(--accent-ink); margin-top: 7px; }
.practice-card__desc { font-size: 14px; line-height: 1.6; color: #50606F; margin-top: 14px; flex: 1; }
.practice-card__foot { margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(20,35,58,0.12); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.practice-card__leader span { font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #8A94A1; }
.practice-card__leader div { font-size: 14px; font-weight: 600; color: var(--ink); margin-top: 3px; }
.link-arrow { font-size: 12.5px; font-weight: 700; color: var(--navy); white-space: nowrap; transition: color 0.2s ease; }
.link-arrow:hover { color: var(--accent); }

/* Capability card (top accent rule) */
.cap-card { background: #fff; border: 1px solid rgba(20,35,58,0.12); border-radius: 6px; padding: 38px 34px; border-top: 3px solid var(--accent); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.cap-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(14,52,112,0.1); }
.cap-card h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.01em; color: var(--ink); margin-top: 22px; }
.cap-card p { font-size: 14.5px; line-height: 1.62; color: #50606F; margin-top: 12px; }

/* Differentiator grid (hairline cells) */
.diff-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(20,35,58,0.14); border: 1px solid rgba(20,35,58,0.14); }
.diff { background: var(--paper-2); padding: 36px 30px; }
.diff__n { font-family: var(--font-body); font-size: 13px; color: var(--accent-ink); }
.diff h3 { font-family: var(--font-display); font-weight: 500; font-size: 21px; letter-spacing: -0.01em; color: var(--ink); margin-top: 14px; }
.diff p { font-size: 14px; line-height: 1.6; color: #50606F; margin-top: 10px; }

/* Proof card (on navy) */
.proof-card { border: 1px solid rgba(244,241,235,0.16); border-radius: 4px; overflow: hidden; transition: transform 0.3s ease, border-color 0.3s ease; }
.proof-card:hover { transform: translateY(-5px); border-color: var(--accent); }
.proof-card__media { height: 200px; overflow: hidden; background: #07203a; }
.proof-card__media img { width: 100%; height: 100%; object-fit: cover; }
.proof-card__body { padding: 26px 30px 30px; }
.proof-card__kicker { display: flex; align-items: center; gap: 10px; }
.proof-card__kicker b { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.proof-card__kicker span { font-size: 11px; color: rgba(244,241,235,0.5); }
.proof-card__title { font-family: var(--font-display); font-weight: 500; font-size: 22px; line-height: 1.25; color: var(--cream); margin-top: 12px; }
.proof-card__meta { font-size: 13.5px; color: rgba(244,241,235,0.6); margin-top: 14px; }

/* News card (light) */
.news-card { display: block; background: #fff; border: 1px solid rgba(20,35,58,0.12); border-radius: 4px; overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; height: 100%; }
.news-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(14,52,112,0.12); border-color: rgba(14,52,112,0.26); }
.news-card__media { height: 200px; overflow: hidden; background: var(--navy-deep); }
.news-card__media img { width: 100%; height: 100%; object-fit: cover; }
.news-card__body { padding: 24px 26px 28px; }
.news-card__kicker { display: flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; }
.news-card__kicker b { color: var(--accent-ink); font-weight: 600; }
.news-card__kicker span { color: #9aa3ad; }
.news-card__title { font-family: var(--font-display); font-weight: 600; font-size: 19px; line-height: 1.24; letter-spacing: -0.01em; color: var(--ink); margin-top: 12px; }
.news-card__excerpt { font-size: 14px; line-height: 1.55; color: var(--ink-4); margin-top: 10px; }

/* ============================ SPOTLIGHT ============================ */
.spotlight { display: grid; grid-template-columns: 1.05fr 0.95fr; border-radius: 5px; overflow: hidden; background: var(--navy-11); border: 1px solid rgba(244,241,235,0.14); }
.spotlight__media { min-height: 420px; position: relative; overflow: hidden; background: #07203a; }
.spotlight__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 42%; }
.spotlight__body { padding: clamp(36px, 4vw, 64px); display: flex; flex-direction: column; justify-content: center; }
.spotlight__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(26px, 2.8vw, 40px); line-height: 1.1; letter-spacing: -0.02em; color: var(--cream); max-width: 18ch; }
.spotlight__stats { display: flex; flex-wrap: wrap; gap: 26px; margin-top: 32px; padding-top: 28px; border-top: 1px solid rgba(244,241,235,0.16); }
.spotlight__stat b { font-family: var(--font-display); font-weight: 700; font-size: 30px; letter-spacing: -0.02em; color: var(--cream); display: block; }
.spotlight__stat span { font-size: 12.5px; color: rgba(244,241,235,0.6); margin-top: 4px; display: block; }

/* ============================ SYSTEMS (radial) ============================ */
.systems__copy { max-width: 760px; margin: 0 auto; text-align: center; }
.systems__eyebrow { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.systems__eyebrow span:first-child, .systems__eyebrow span:last-child { width: 24px; height: 1px; background: var(--accent); }
.systems__eyebrow b { font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 0.24em; color: rgba(244,241,235,0.72); text-transform: uppercase; }
.radial { position: relative; width: 100%; max-width: 660px; margin: 60px auto 0; aspect-ratio: 1 / 1; }
.radial > svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.radial__core { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 23%; height: 23%; border-radius: 50%; background: radial-gradient(circle at 35% 30%, var(--teal), var(--navy-deep) 72%); border: 1px solid rgba(43,166,196,0.5); box-shadow: 0 0 0 10px rgba(43,166,196,0.08), 0 18px 40px rgba(0,0,0,0.35); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; z-index: 2; }
.radial__core b { font-family: var(--font-display); font-weight: 800; font-size: clamp(12px, 1.4vw, 17px); line-height: 1.05; color: #fff; letter-spacing: -0.01em; }
.radial__core span { width: 22px; height: 2px; background: var(--accent); border-radius: 2px; margin-top: 8px; }
.radial__node { position: absolute; transform: translate(-50%,-50%); width: 25%; display: flex; flex-direction: column; align-items: center; gap: 9px; text-align: center; animation: cgaFloat 7s ease-in-out infinite; }
.radial__node .dot { width: 50px; height: 50px; border-radius: 50%; background: var(--navy-11); border: 1px solid rgba(43,166,196,0.5); display: flex; align-items: center; justify-content: center; }
.radial__node .dot svg { stroke: var(--sky); }
.radial__node span { font-family: var(--font-body); font-weight: 700; font-size: 12px; line-height: 1.25; color: var(--cream); }

/* ============================ CLIENTS ============================ */
.clients-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(20,35,58,0.13); border: 1px solid rgba(20,35,58,0.13); }
.clients-cell { background: var(--paper-2); padding: 30px 32px; }
.clients-cell__label { font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 16px; }

/* ============================ PEOPLE ============================ */
.people-tier { display: flex; align-items: center; gap: 12px; margin: 0 0 30px; }
.people-tier b { font-family: var(--font-body); font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--navy); }
.people-tier .line { flex: 1; height: 1px; background: rgba(20,35,58,0.14); }
.principal { display: grid; grid-template-columns: 150px 1fr; gap: 26px; align-items: start; }
.principal__photo { aspect-ratio: 4/5; border-radius: 3px; overflow: hidden; background: var(--navy); }
.principal__photo img { width: 100%; height: 100%; object-fit: cover; }
.principal__role { font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-ink); }
.principal__name { font-family: var(--font-display); font-weight: 600; font-size: 25px; letter-spacing: -0.015em; color: var(--ink); margin-top: 8px; }
.principal__org { font-size: 13.5px; font-weight: 600; color: #50606F; margin-top: 3px; }
.principal__bio { font-size: 14px; line-height: 1.6; color: var(--ink-4); margin-top: 14px; }
.mgr { display: grid; grid-template-columns: 120px 1fr; gap: 24px; align-items: start; }
.mgr__photo { aspect-ratio: 1/1; border-radius: 3px; overflow: hidden; background: var(--navy); }
.mgr__photo img { width: 100%; height: 100%; object-fit: cover; }
.mgr__role { font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-ink); }
.mgr__name { font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -0.01em; color: var(--ink); margin-top: 7px; }
.mgr p { font-size: 13px; line-height: 1.55; color: var(--ink-4); margin-top: 8px; }
.specialist__photo { aspect-ratio: 1/1; border-radius: 3px; overflow: hidden; background: var(--navy); margin-bottom: 14px; }
.specialist__photo img { width: 100%; height: 100%; object-fit: cover; }
.specialist h4 { font-family: var(--font-display); font-weight: 500; font-size: 18px; color: var(--ink); }
.specialist p { font-size: 12.5px; line-height: 1.5; color: var(--ink-4); margin-top: 5px; }

/* ============================ OFFICES ============================ */
.offices-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; border-top: 1px solid rgba(20,35,58,0.14); padding-top: 44px; }
.office__region { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-ink); }
.office__city { font-family: var(--font-display); font-weight: 500; font-size: 23px; color: var(--ink); margin-top: 10px; }
.office__addr { font-size: 13.5px; line-height: 1.62; color: var(--ink-4); margin-top: 12px; }

/* ============================ CTA + FOOTER ============================ */
.cta { background: var(--navy); color: var(--paper); }
.cta__inner { max-width: var(--maxw); margin: 0 auto; padding: 110px 48px; text-align: center; }
.cta__eyebrow { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.cta__eyebrow span:first-child, .cta__eyebrow span:last-child { width: 24px; height: 1px; background: var(--accent); }
.cta__eyebrow b { font-family: var(--font-body); font-size: 11px; font-weight: 500; letter-spacing: 0.24em; color: rgba(244,241,235,0.72); text-transform: uppercase; }
.cta__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 4.4vw, 58px); line-height: 1.08; letter-spacing: -0.02em; color: var(--cream); max-width: 20ch; margin: 0 auto; }
.cta__actions { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; margin-top: 40px; }
.socials { display: flex; align-items: center; justify-content: center; gap: 14px; margin-top: 34px; }
.socials__label { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(244,241,235,0.5); }
.social { width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(244,241,235,0.3); display: inline-flex; align-items: center; justify-content: center; color: var(--paper); transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease; }
.social:hover { background: var(--accent); border-color: var(--accent); color: #1A0E06; }

.site-footer { background: var(--navy-deep); color: rgba(244,241,235,0.7); }
.cta .site-footer, .site-footer--in-cta { border-top: 1px solid rgba(244,241,235,0.14); }
.site-footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 32px 48px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.site-footer__brand { display: flex; align-items: center; gap: 12px; color: var(--paper); }
.site-footer__brand img.pin { height: 26px; width: auto; }
.site-footer__brand img.mark { height: 17px; width: auto; }
.site-footer__brand .rule { width: 1px; height: 24px; background: rgba(244,241,235,0.34); }
.site-footer__brand b { font-family: var(--font-body); font-weight: 700; font-size: 10px; letter-spacing: 0.18em; }
.site-footer__meta { font-size: 12px; color: rgba(244,241,235,0.55); }

/* ============================ PAGE HERO (interior pages) ============================ */
.page-hero { background: var(--navy-deep); color: var(--paper); position: relative; overflow: hidden; }
.page-hero__inner { max-width: var(--maxw); margin: 0 auto; padding: 84px 48px; position: relative; z-index: 1; }
.page-hero__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(38px, 5.2vw, 68px); line-height: 1.02; letter-spacing: -0.03em; color: var(--cream); max-width: 20ch; }
.page-hero__lead { font-size: 18px; line-height: 1.62; color: rgba(244,241,235,0.8); max-width: 60ch; margin-top: 24px; }
.page-hero__bg { position: absolute; inset: 0; opacity: 0.22; }
.page-hero__bg img { width: 100%; height: 100%; object-fit: cover; }

/* ============================ TABS ============================ */
.tabs { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 44px; }
.tab-btn { font-size: 13px; font-weight: 600; letter-spacing: 0.02em; padding: 11px 22px; border-radius: 100px; border: 1px solid rgba(20,35,58,0.2); color: var(--ink-2); background: transparent; transition: all 0.2s ease; }
.tab-btn:hover { border-color: rgba(20,35,58,0.5); }
.tab-btn.is-active { background: var(--navy); color: #fff; border-color: var(--navy); }
.tab-panel { display: none; }
.tab-panel.is-active { display: block; animation: cgaUp 0.5s var(--ease) both; }

/* ============================ FORMS ============================ */
.form { display: grid; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); }
.field .req { color: var(--accent-ink); }
.field input, .field select, .field textarea { font-family: var(--font-body); font-size: 15px; color: var(--ink); background: #fff; border: 1px solid rgba(20,35,58,0.2); border-radius: 3px; padding: 13px 15px; transition: border-color 0.2s ease, box-shadow 0.2s ease; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--navy); box-shadow: 0 0 0 3px rgba(21,74,150,0.12); }
.field textarea { min-height: 140px; resize: vertical; }
.field--file input { padding: 10px; background: #fff; }
.consent { display: flex; align-items: flex-start; gap: 12px; font-size: 13.5px; line-height: 1.55; color: var(--ink-2); }
.consent input { margin-top: 3px; width: 18px; height: 18px; flex-shrink: 0; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note { font-size: 13px; color: var(--muted); line-height: 1.6; }
.form-panel { background: #fff; border: 1px solid rgba(20,35,58,0.12); border-radius: 8px; padding: clamp(28px, 4vw, 48px); }
.alert { padding: 16px 20px; border-radius: 4px; font-size: 14.5px; line-height: 1.5; margin-bottom: 8px; }
.alert--ok { background: color-mix(in srgb, var(--teal) 12%, #fff); border: 1px solid color-mix(in srgb, var(--teal) 40%, #fff); color: #0d5568; }
.alert--err { background: color-mix(in srgb, var(--accent) 12%, #fff); border: 1px solid color-mix(in srgb, var(--accent) 40%, #fff); color: var(--accent-ink); }

/* Contact detail list */
.contact-details { display: grid; gap: 22px; }
.contact-detail b { display: block; font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 6px; }
.contact-detail a, .contact-detail span { font-size: 16px; color: var(--ink); }

/* ============================ PRACTICE DETAIL ============================ */
.what-we-do { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 40px; }
.wwd-item { display: flex; align-items: flex-start; gap: 14px; padding: 16px 0; border-bottom: 1px solid rgba(20,35,58,0.1); }
.wwd-item svg { flex-shrink: 0; stroke: var(--accent); margin-top: 2px; }
.wwd-item span { font-size: 15.5px; line-height: 1.5; color: var(--ink-2); }
.win { border: 1px solid rgba(244,241,235,0.16); border-radius: 5px; padding: 30px 32px; transition: transform 0.3s ease, border-color 0.3s ease; }
.win:hover { transform: translateY(-4px); border-color: var(--accent); }
.win__tag { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.win__title { font-family: var(--font-display); font-weight: 500; font-size: 20px; line-height: 1.25; color: var(--cream); margin-top: 12px; }
.win__desc { font-size: 14px; line-height: 1.6; color: rgba(244,241,235,0.7); margin-top: 12px; }
.leader-band { display: grid; grid-template-columns: 160px 1fr; gap: 34px; align-items: center; }
.leader-band__photo { aspect-ratio: 1/1; border-radius: 4px; overflow: hidden; background: var(--navy); }
.leader-band__photo img { width: 100%; height: 100%; object-fit: cover; }

/* ============================ POST / ARTICLE ============================ */
.article { max-width: 760px; margin: 0 auto; }
.article__meta { font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 14px; }
.article__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(30px, 4vw, 50px); line-height: 1.08; letter-spacing: -0.02em; color: var(--ink); }
.article__body { font-size: 17px; line-height: 1.7; color: var(--ink-2); margin-top: 28px; }
.article__body h2 { font-family: var(--font-display); font-size: 28px; margin: 34px 0 14px; color: var(--ink); }
.article__body h3 { font-family: var(--font-display); font-size: 22px; margin: 28px 0 12px; color: var(--ink); }
.article__body p { margin-bottom: 18px; }
.article__body a { color: var(--navy); text-decoration: underline; }
.article__body img { border-radius: 4px; margin: 24px 0; }
.article__body ul, .article__body ol { margin: 0 0 18px 22px; }
.article__body li { margin-bottom: 8px; }
.article__body blockquote { border-left: 3px solid var(--accent); padding-left: 22px; margin: 24px 0; font-family: var(--font-display); font-style: italic; font-size: 21px; color: #1F2E42; }

/* Follow strip */
.follow-strip { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.follow-strip h3 { font-family: var(--font-display); font-weight: 700; font-size: clamp(22px, 2.4vw, 32px); color: var(--cream); }

/* ============================ REVEAL / MOTION ============================ */
@keyframes cgaFloat { 0%, 100% { transform: translateY(0) scale(1.02); } 50% { transform: translateY(-14px) scale(1.05); } }
@keyframes cgaUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.cga-pre { opacity: 0; transform: translateY(28px); }
.cga-in { opacity: 1 !important; transform: none !important; transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
@media (prefers-reduced-motion: reduce) {
  .cga-pre { opacity: 1; transform: none; }
  img, .radial__node { animation: none !important; }
  html { scroll-behavior: auto; }
}

/* ============================ UTILITIES ============================ */
.mt-14 { margin-top: 14px; }
.mt-20 { margin-top: 20px; }
.mt-26 { margin-top: 26px; }
.mt-30 { margin-top: 30px; }
.mt-34 { margin-top: 34px; }
.mt-40 { margin-top: 40px; }
.text-center { text-align: center; }
.note-italic { font-size: 13px; line-height: 1.6; color: var(--muted); font-style: italic; margin-top: 26px; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 1024px) {
  :root { --pad: 84px; --gutter: 32px; }
  .cols-5 { grid-template-columns: repeat(3, 1fr); }
  .cols-4 { grid-template-columns: repeat(2, 1fr); }
  .whoweare { grid-template-columns: 1fr; gap: 40px; }
  .whoweare__aside { position: static; }
  .spotlight { grid-template-columns: 1fr; }
  .spotlight__media { min-height: 280px; }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .step { border-left: 0; padding-left: 0; }
  .step__arrow { display: none; }
}
@media (max-width: 860px) {
  .site-header__inner { padding: 12px 24px; }
  .nav-toggle { display: inline-flex; }
  .main-nav { position: fixed; inset: 0 0 0 auto; width: min(320px, 82vw); flex-direction: column; align-items: flex-start; gap: 4px; background: var(--header-bg); padding: 88px 28px 28px; box-shadow: -12px 0 40px rgba(20,35,58,0.18); transform: translateX(100%); transition: transform 0.3s var(--ease); z-index: 60; }
  .main-nav.is-open { transform: translateX(0); }
  .main-nav a { padding: 12px 0; font-size: 16px; width: 100%; border-bottom: 1px solid rgba(20,35,58,0.08); }
  .main-nav a.btn--navy, .main-nav .menu-item-cta > a { margin-top: 10px; border-bottom: 0; }
  body.nav-open { overflow: hidden; }
  .nav-scrim { position: fixed; inset: 0; background: rgba(14,52,112,0.4); opacity: 0; pointer-events: none; transition: opacity 0.3s ease; z-index: 55; }
  .nav-scrim.is-open { opacity: 1; pointer-events: auto; }
}
@media (max-width: 720px) {
  .cols-2, .cols-3, .cols-4, .cols-5, .card-grid.cols-2, .card-grid.cols-3, .card-grid.cols-4, .card-grid.cols-5,
  .diff-grid, .clients-grid, .stat-row__grid, .offices-grid, .what-we-do, .form-row, .leader-band, .principal, .mgr, .steps { grid-template-columns: 1fr; }
  .value-card__title { white-space: normal; }
  .stat { border-right: 0; border-bottom: 1px solid rgba(244,241,235,0.14); padding: 22px 0; }
  .diff, .clients-cell { border-bottom: 1px solid rgba(20,35,58,0.12); }
  .principal__photo, .mgr__photo { max-width: 200px; }
  .hero__inner, .hero__media, .stat-row { padding-left: 24px; padding-right: 24px; }
  .site-header__inner, .hero__inner { padding-left: 24px; padding-right: 24px; }
  .cta__inner { padding: 72px 24px; }
}
