/* ============================================================
   Saket Tulsan — Personal Site
   Production stylesheet. Mobile-first; breakpoints at 720, 1024.
   Built on the Thinkbridge Partners design system tokens.
============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500&family=Source+Serif+4:opsz,wght@8..60,300;8..60,400;8..60,500;8..60,600&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* COLORS */
  --tb-navy-900:#00132C; --tb-navy-800:#011F43; --tb-navy-700:#0A2A55;
  --tb-navy-500:#41618F; --tb-navy-300:#8FA6C2; --tb-navy-200:#B8C7DB;
  --tb-navy-100:#DCE5F0; --tb-navy-050:#F1F4F9;
  --tb-ivory-050:#FBFAF7; --tb-ivory-100:#F5F3EE; --tb-ivory-200:#E9E6DE;
  --tb-ink-900:#14171C; --tb-ink-700:#353A44; --tb-ink-500:#6B7280;
  --tb-ink-400:#9AA1AE; --tb-ink-300:#C8CCD3; --tb-ink-100:#ECEEF1;
  --tb-gold-700:#8C6A1F; --tb-gold-500:#B89149; --tb-gold-200:#E8D9B4;

  --bg-page:var(--tb-ivory-050);
  --bg-surface:#FFF;
  --bg-alt:var(--tb-ivory-100);
  --bg-inverse:var(--tb-navy-800);
  --bg-inverse-2:var(--tb-navy-900);
  --fg-1:var(--tb-ink-900);
  --fg-2:var(--tb-ink-700);
  --fg-3:var(--tb-ink-500);
  --border-1:var(--tb-ink-300);
  --border-2:var(--tb-ink-100);

  /* TYPE */
  --font-display:"Cormorant Garamond","Times New Roman",Georgia,serif;
  --font-serif:"Source Serif 4","Source Serif Pro",Georgia,serif;
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
}

/* ============================================================ RESET */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-serif);font-size:17px;line-height:1.6;color:var(--fg-1);background:var(--bg-page);font-feature-settings:"kern" 1,"liga" 1,"onum" 1}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0}
h1,h2,h3,h4,h5,h6,p,figure,blockquote{margin:0}
::selection{background:var(--tb-gold-200);color:var(--tb-navy-900)}
section[id]{scroll-margin-top:calc(var(--site-header-h,64px) + 16px)}

/* ============================================================ TYPE */
.h1{font-family:var(--font-display);font-weight:300;font-size:clamp(40px,7vw,76px);line-height:1.05;letter-spacing:-0.025em;text-wrap:balance}
.h2{font-family:var(--font-display);font-weight:300;font-size:clamp(32px,5vw,60px);line-height:1.05;letter-spacing:-0.02em;text-wrap:balance}
.h3{font-family:var(--font-display);font-weight:400;font-size:clamp(24px,3.6vw,36px);line-height:1.1;letter-spacing:-0.015em}
.h4{font-family:var(--font-display);font-weight:400;font-size:clamp(22px,2.6vw,28px);line-height:1.2;letter-spacing:-0.01em;color:var(--tb-navy-800)}
.lead{font-family:var(--font-serif);font-size:clamp(16px,1.7vw,19px);line-height:1.7;color:var(--fg-2)}
em{font-style:italic}

.eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-navy-800);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor;opacity:0.7}
.eyebrow.light{color:var(--tb-navy-200)}
.eyebrow.gold{color:var(--tb-gold-500)}

.editorial-rule{display:block;border:0;border-top:1px solid var(--tb-navy-800);width:48px;margin:0 0 24px}
.editorial-rule.light{border-top-color:var(--tb-gold-500)}

.mono{font-family:var(--font-mono)}
.uppercase{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:0.18em;font-size:11px;font-weight:500}

/* ============================================================ LAYOUT */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
@media(min-width:720px){.container{padding:0 40px}}
@media(min-width:1024px){.container{padding:0 48px}}

.section{padding:80px 0}
@media(min-width:720px){.section{padding:104px 0}}
@media(min-width:1024px){.section{padding:140px 0}}
.section--alt{background:var(--bg-alt);border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2)}
.section--dark{background:var(--tb-navy-900);color:#fff;border-top:1px solid var(--tb-navy-700)}
.section--dark .h2,.section--dark .h3{color:#fff}

.section-label{display:flex;align-items:baseline;gap:24px;font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;padding-bottom:16px;border-bottom:1px solid var(--border-1);margin-bottom:48px}
.section-label .num{color:var(--tb-gold-700)}
.section--dark .section-label{color:var(--tb-navy-200);border-bottom-color:rgba(255,255,255,0.18)}
.section--dark .section-label .num{color:var(--tb-gold-500)}
@media(min-width:1024px){.section-label{margin-bottom:56px}}

/* Two-column editorial: title left, body right */
.editorial{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:1024px){.editorial{grid-template-columns:1fr 1.6fr;gap:96px;align-items:start}}
.editorial__title-col{position:relative}
@media(min-width:1024px){.editorial__title-col{position:sticky;top:64px}}

/* ============================================================ HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(0,19,44,0.92);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid rgba(255,255,255,0.10);padding:14px 0}
body{padding-top:var(--site-header-h,64px)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.wordmark{display:inline-flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.wordmark__name{font-family:var(--font-display);font-weight:400;font-size:22px;line-height:1;color:#fff;letter-spacing:-0.01em;text-decoration:none}
.wordmark__name:hover{color:var(--tb-gold-200)}
.wordmark__role{font-family:var(--font-sans);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-navy-200);font-weight:500;text-decoration:none}
.wordmark__role:hover{color:var(--tb-gold-200)}
.site-nav{display:none;align-items:center;gap:24px}
@media(min-width:1024px){.site-nav{display:flex}}
.site-nav a{font-family:var(--font-sans);font-size:13px;font-weight:500;color:rgba(255,255,255,0.7);letter-spacing:0.02em;padding-bottom:3px;border-bottom:1px solid transparent;transition:color 200ms ease,border-color 200ms ease}
.site-nav a:hover{color:#fff;border-bottom-color:#fff}
.site-nav .sep{width:1px;height:14px;background:rgba(255,255,255,0.18)}
.site-nav .cta{color:#fff;border-bottom:1px solid #fff}
.menu-toggle{display:inline-flex;align-items:center;gap:8px;background:none;border:0;color:#fff;font-family:var(--font-sans);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;padding:8px 4px}
@media(min-width:1024px){.menu-toggle{display:none}}
.menu-toggle__bars{display:inline-block;width:18px;height:10px;position:relative}
.menu-toggle__bars::before,.menu-toggle__bars::after{content:"";position:absolute;left:0;right:0;height:1px;background:#fff}
.menu-toggle__bars::before{top:2px}
.menu-toggle__bars::after{bottom:2px}
.mobile-menu{display:none;border-top:1px solid rgba(255,255,255,0.12);margin-top:14px;padding:16px 0 8px}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;display:grid;gap:6px;text-align:center}
.mobile-menu a{display:block;font-family:var(--font-sans);font-size:15px;color:#fff;padding:12px 16px;border-radius:3px;text-align:center;transition:background 200ms ease,color 200ms ease}
.mobile-menu a:hover,.mobile-menu a:focus-visible{background:rgba(255,255,255,0.08);color:var(--tb-gold-200);outline:none}
.mobile-menu a[aria-current="true"]{background:rgba(184,145,73,0.16);color:var(--tb-gold-200)}

/* ============================================================ HERO */
.hero{background:var(--tb-navy-900);color:#fff;position:relative;overflow:hidden}
.hero__grid-bg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px);background-size:80px 80px;-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%)}
.hero__inner{position:relative;display:grid;grid-template-columns:1fr;gap:48px;padding-top:64px;padding-bottom:80px}
@media(min-width:1024px){.hero__inner{grid-template-columns:1.3fr 1fr;gap:64px;padding-top:96px;padding-bottom:96px;min-height:88vh;align-items:center}}
.hero__copy{display:flex;flex-direction:column;justify-content:center}
.hero__title{margin-top:24px;color:#fff;max-width:880px}
.hero__title em{font-weight:300;font-style:italic;color:var(--tb-gold-200)}
.hero__lead{margin-top:28px;font-family:var(--font-serif);font-size:clamp(16px,1.7vw,19px);line-height:1.65;color:var(--tb-navy-200);max-width:620px}
.hero__ctas{margin-top:36px;display:flex;flex-wrap:wrap;gap:14px}
.hero__meta{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.12);display:grid;grid-template-columns:1fr;gap:12px;font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-navy-300)}
@media(min-width:720px){.hero__meta{grid-template-columns:1fr auto}}
.hero__meta .status{color:var(--tb-gold-500)}
.hero__aside{display:flex;flex-direction:column;gap:24px}
@media(min-width:1024px){.hero__aside{border-left:1px solid rgba(255,255,255,0.08);padding-left:48px}}
.portrait{position:relative;width:100%;aspect-ratio:1/1;background:linear-gradient(180deg,var(--tb-navy-800),var(--tb-navy-700));border:1px solid rgba(255,255,255,0.15)}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.index-card{padding:32px 32px 26px;border:1px solid rgba(255,255,255,0.14);background:rgba(0,19,44,0.45)}
.index-card__label{font-family:var(--font-sans);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;color:var(--tb-gold-500);font-weight:500;margin-bottom:20px}
.index-card__quote{font-family:var(--font-display);font-weight:300;font-size:clamp(24px,2.6vw,30px);line-height:1.25;color:#fff;letter-spacing:-0.015em}
.index-card__quote em{font-style:italic;color:var(--tb-gold-200)}
.index-card__foot{margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.10);font-family:var(--font-mono);font-size:11px;color:var(--tb-navy-300);letter-spacing:0.04em}

/* ============================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-sans);font-size:14px;font-weight:500;letter-spacing:0.02em;padding:14px 22px;border-radius:2px;border:1px solid transparent;cursor:pointer;transition:background 200ms ease,color 200ms ease,border-color 200ms ease;line-height:1;text-decoration:none}
.btn--primary{background:var(--tb-navy-800);color:#fff;border-color:var(--tb-navy-800)}
.btn--primary:hover{background:var(--tb-navy-700);border-color:var(--tb-navy-700)}
.btn--primary-light{background:#fff;color:var(--tb-navy-800);border-color:#fff}
.btn--primary-light:hover{background:var(--tb-gold-200);border-color:var(--tb-gold-200)}
.btn--secondary{background:transparent;color:var(--tb-navy-800);border-color:var(--tb-navy-800)}
.btn--secondary:hover{background:var(--tb-navy-800);color:#fff}
.btn--secondary-light{background:transparent;color:#fff;border-color:rgba(255,255,255,0.4)}
.btn--secondary-light:hover{border-color:#fff}

/* ============================================================ TRUSTED BAR */
.trusted{background:var(--bg-page);border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);padding:24px 0}
.trusted__inner{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
@media(min-width:720px){.trusted__inner{grid-template-columns:auto 1fr;gap:40px}}
.trusted__intro{font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;line-height:1.6;max-width:200px}
.trusted__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--border-2);border-left:1px solid var(--border-2)}
@media(min-width:720px){.trusted__grid{grid-template-columns:repeat(3,1fr);border-top:0;border-left:1px solid var(--border-2)}}
@media(min-width:1024px){.trusted__grid{grid-template-columns:repeat(6,1fr)}}
.company{padding:14px 18px;border-right:1px solid var(--border-2);border-bottom:1px solid var(--border-2);display:flex;flex-direction:column;justify-content:center;min-height:64px;color:inherit;transition:background 200ms ease}
@media(min-width:720px){.company{border-bottom:0}}
.company--link:hover{background:var(--bg-surface)}
.company__name{font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--tb-navy-800);letter-spacing:-0.005em;line-height:1.1}
.company__name sup{font-size:10px;margin-left:5px;color:var(--tb-gold-700);font-weight:400}
.company__note{font-family:var(--font-sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-3);margin-top:6px}

/* ============================================================ PROFILE / ABOUT */
.profile__opener{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(22px,2.6vw,28px);line-height:1.35;color:var(--tb-navy-800);letter-spacing:-0.005em;margin-bottom:28px}
.profile__body p{margin-bottom:18px;font-family:var(--font-serif);font-size:17px;line-height:1.75;color:var(--fg-1);max-width:62ch}
.profile__body p.muted{color:var(--fg-2)}
.profile__meta{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-1);display:grid;grid-template-columns:auto 1fr;row-gap:10px;column-gap:20px;font-family:var(--font-sans);font-size:13px}
.profile__meta dt{color:var(--fg-3);letter-spacing:0.1em;text-transform:uppercase;font-size:10px;padding-top:2px}
.profile__meta dd{margin:0;color:var(--fg-1)}
.profile__intro{font-family:var(--font-serif);font-style:italic;font-size:16px;line-height:1.7;color:var(--fg-2);max-width:360px;margin-top:24px}
.pillars{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-1);display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:720px){.pillars{grid-template-columns:repeat(3,1fr);gap:28px}}
.pillar__num{font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;color:var(--tb-gold-700);margin-bottom:10px}
.pillar__title{font-family:var(--font-display);font-weight:400;font-size:22px;line-height:1.2;letter-spacing:-0.01em;color:var(--tb-navy-800);margin-bottom:8px}
.pillar__body{font-family:var(--font-serif);font-size:15px;line-height:1.55;color:var(--fg-2)}

/* ============================================================ IMPACT BAND */
.impact-head{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:48px}
@media(min-width:1024px){.impact-head{grid-template-columns:1fr 1.6fr;gap:96px;margin-bottom:64px}}
.impact-grid{display:grid;grid-template-columns:1fr;border-top:1px solid rgba(255,255,255,0.18);border-left:1px solid rgba(255,255,255,0.18)}
@media(min-width:720px){.impact-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.impact-grid{grid-template-columns:repeat(3,1fr)}}
.stat{padding:36px 28px 32px;border-right:1px solid rgba(255,255,255,0.18);border-bottom:1px solid rgba(255,255,255,0.18);min-height:240px;display:flex;flex-direction:column;justify-content:space-between}
.stat__num{font-family:var(--font-display);font-weight:300;font-size:clamp(48px,7vw,84px);line-height:1;letter-spacing:-0.025em;color:#fff;font-feature-settings:"lnum" 1,"tnum" 1}
.stat__label{font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--tb-gold-500);margin:24px 0 12px}
.stat__note{font-family:var(--font-serif);font-size:14px;line-height:1.55;color:var(--tb-navy-200)}
.impact-foot{margin-top:32px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;color:var(--tb-navy-300);display:grid;grid-template-columns:1fr;gap:6px}
@media(min-width:720px){.impact-foot{grid-template-columns:1fr auto}}

/* ============================================================ EXPERIENCE */
.engagement{display:grid;grid-template-columns:1fr;gap:24px;padding:48px 0;border-top:1px solid var(--border-1)}
@media(min-width:1024px){.engagement{grid-template-columns:180px 1fr;gap:64px;padding:64px 0}}
.engagement:last-child{border-bottom:1px solid var(--border-1)}
.engagement__meta-num{font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;color:var(--tb-gold-700);margin-bottom:16px}
.engagement__meta-row{font-family:var(--font-sans);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-3);font-weight:500;margin-bottom:6px}
.engagement__head{display:flex;align-items:baseline;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.engagement__company{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,4.2vw,40px);line-height:1.05;letter-spacing:-0.02em;color:var(--tb-navy-800)}
.engagement__company a{transition:color 200ms ease}
.engagement__company a:hover{color:var(--tb-gold-700)}
.engagement__company sup{font-size:14px;margin-left:6px;color:var(--tb-gold-700);font-weight:400}
.engagement__role{font-family:var(--font-sans);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--tb-gold-700);font-weight:500}
.engagement__blurb{font-family:var(--font-serif);font-style:italic;font-size:15px;line-height:1.6;color:var(--fg-3);margin-bottom:24px;max-width:62ch}
.engagement__chapter{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(22px,2.4vw,26px);line-height:1.3;letter-spacing:-0.01em;color:var(--tb-navy-800);margin-bottom:20px;max-width:30ch}
.engagement__body p{font-family:var(--font-serif);font-size:16px;line-height:1.7;color:var(--fg-1);max-width:62ch;margin-bottom:14px}
.outcomes{margin-top:28px;padding-top:24px;border-top:1px solid var(--border-2)}
.outcomes__head{font-family:var(--font-sans);font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-navy-800);margin-bottom:16px}
.outcomes ul{list-style:none;display:grid;gap:12px;max-width:70ch}
.outcomes li{font-family:var(--font-serif);font-size:15px;line-height:1.6;color:var(--fg-2);display:grid;grid-template-columns:24px 1fr;gap:14px}
.outcomes li .idx{font-family:var(--font-mono);font-size:11px;color:var(--tb-gold-700);padding-top:3px;letter-spacing:0.04em}
.tags{margin-top:24px;display:flex;flex-wrap:wrap;gap:8px}
.tag{font-family:var(--font-sans);font-size:11px;letter-spacing:0.06em;color:var(--fg-2);border:1px solid var(--border-1);padding:6px 12px;border-radius:999px;background:var(--bg-surface)}

/* ============================================================ PRACTICE */
.practice-grid{display:grid;grid-template-columns:1fr;border-top:1px solid var(--border-1);border-left:1px solid var(--border-1);background:var(--bg-surface)}
@media(min-width:720px){.practice-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.practice-grid{grid-template-columns:repeat(3,1fr)}}
.practice{padding:32px 28px;border-right:1px solid var(--border-1);border-bottom:1px solid var(--border-1);display:flex;flex-direction:column;min-height:280px;transition:background 200ms ease}
.practice:hover{background:var(--bg-page)}
.practice__num{font-family:var(--font-mono);font-size:11px;color:var(--tb-gold-700);margin-bottom:20px;letter-spacing:0.04em}
.practice__title{font-family:var(--font-display);font-weight:400;font-size:24px;line-height:1.15;letter-spacing:-0.01em;color:var(--tb-navy-800);margin-bottom:14px}
.practice__body{font-family:var(--font-serif);font-size:15px;line-height:1.6;color:var(--fg-2);flex:1;max-width:38ch}
.practice__keywords{margin-top:24px;padding-top:16px;border-top:1px solid var(--border-2);font-family:var(--font-sans);font-size:11px;letter-spacing:0.06em;color:var(--fg-3);display:flex;flex-wrap:wrap;gap:6px 14px}
.practice__keywords .sep{color:var(--border-1);margin:0 -6px}

/* ============================================================ PULL QUOTE */
.pullquote-section{padding:80px 0}
@media(min-width:1024px){.pullquote-section{padding:120px 0}}
.pullquote{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(24px,3.4vw,44px);line-height:1.25;letter-spacing:-0.015em;color:var(--tb-navy-800);border-left:2px solid var(--tb-gold-500);padding:8px 0 8px 28px;max-width:920px}
@media(min-width:720px){.pullquote{padding-left:40px}}
.pullquote__label{font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-gold-700);font-weight:500;margin-bottom:24px}

/* ============================================================ STANDING / CREDIBILITY */
.signals{list-style:none;border-top:1px solid var(--border-1)}
.signals li{padding:28px 0;border-bottom:1px solid var(--border-1);display:grid;grid-template-columns:1fr;gap:8px}
@media(min-width:720px){.signals li{grid-template-columns:auto 1fr;gap:40px;align-items:baseline}}
.signals__when{font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;color:var(--tb-gold-700);min-width:120px}
.signals__what{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.4vw,26px);line-height:1.2;letter-spacing:-0.01em;color:var(--tb-navy-800);margin-bottom:8px}
.signals__detail{font-family:var(--font-serif);font-size:15px;line-height:1.65;color:var(--fg-2);max-width:62ch}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:start}
@media(min-width:1024px){.contact-grid{grid-template-columns:1.4fr 1fr;gap:80px}}
.contact-title em{color:var(--tb-gold-200);font-weight:300;font-style:italic}
.contact-lead{margin-top:24px;font-family:var(--font-serif);font-size:clamp(16px,1.7vw,18px);line-height:1.7;color:var(--tb-navy-200);max-width:60ch}
.contact-ctas{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}
.directory{border:1px solid rgba(255,255,255,0.18);padding:28px 28px 22px;background:rgba(0,19,44,0.55)}
.directory__label{font-family:var(--font-sans);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;color:var(--tb-gold-500);font-weight:500;margin-bottom:20px}
.directory__rows{display:grid;gap:18px;margin-bottom:18px}
.directory__row{display:grid;grid-template-columns:90px 1fr;gap:14px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,0.10)}
.directory__row dt{font-family:var(--font-sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--tb-navy-300);padding-top:3px}
.directory__row dd{margin:0;font-family:var(--font-serif);font-size:15px;color:#fff;line-height:1.4}
.directory__row dd.mono{font-family:var(--font-mono);font-size:14px}
.directory__row dd a{border-bottom:1px solid rgba(255,255,255,0.4)}
.directory__row dd a:hover{border-bottom-color:#fff}
.directory__foot{font-family:var(--font-mono);font-size:10px;color:var(--tb-navy-300);letter-spacing:0.04em;display:flex;justify-content:space-between}
.directory__foot .available{color:var(--tb-gold-500)}

/* ============================================================ FOOTER */
.site-footer{background:var(--tb-navy-900);color:#fff;padding:48px 0 28px;border-top:1px solid rgba(255,255,255,0.08)}
.site-footer__cols{display:grid;grid-template-columns:1fr;gap:36px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,0.10)}
@media(min-width:720px){.site-footer__cols{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}}
.site-footer .wordmark__name{color:#fff}
.site-footer__about{font-family:var(--font-serif);font-size:14px;line-height:1.6;color:var(--tb-navy-200);margin-top:18px;max-width:360px}
.site-footer h4{font-family:var(--font-sans);font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--tb-navy-300);margin-bottom:18px}
.site-footer ul{list-style:none;display:grid;gap:10px}
.site-footer li{font-family:var(--font-serif);font-size:14px;color:#fff}
.site-footer li a{border-bottom:1px solid rgba(255,255,255,0.18);padding-bottom:1px;transition:border-color 200ms ease}
.site-footer li a:hover{border-bottom-color:#fff}
.site-footer__legal{padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:var(--font-sans);font-size:11px;color:var(--tb-navy-300);letter-spacing:0.06em}
.site-footer__legal .right{display:flex;gap:24px}
.site-footer__legal .v{color:var(--tb-gold-500)}

/* ============================================================ ENGAGEMENTS — JOURNEY */
.act{display:grid;grid-template-columns:1fr;gap:32px;padding:48px 0;border-top:1px solid var(--border-1);position:relative}
.act:first-of-type{border-top:0;padding-top:8px}
@media(min-width:1024px){.act{grid-template-columns:280px 1fr;gap:64px;padding:72px 0}}
.act__intro{position:relative}
@media(min-width:1024px){.act__intro{position:sticky;top:96px;align-self:start}}
.act__num{font-family:var(--font-sans);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:var(--tb-gold-700);font-weight:500;margin-bottom:6px}
.act__year{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);letter-spacing:0.04em;margin-bottom:18px}
.act__title{font-family:var(--font-display);font-weight:300;font-size:clamp(28px,3.6vw,44px);line-height:1.05;letter-spacing:-0.02em;color:var(--tb-navy-800);margin-bottom:18px}
.act__lede{font-family:var(--font-serif);font-size:15px;line-height:1.65;color:var(--fg-2);max-width:46ch}
.act--current .act__title::after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--tb-gold-500);margin-left:12px;vertical-align:middle;animation:livedot 2.4s ease-in-out infinite}
@keyframes livedot{0%,100%{opacity:0.4}50%{opacity:1}}

/* Vertical timeline rail on the milestones column */
.milestones{position:relative;display:grid;gap:32px;padding-left:24px;border-left:1px solid var(--border-1)}
@media(min-width:720px){.milestones{padding-left:32px;gap:36px}}
.milestone{position:relative;padding:24px 28px;background:var(--bg-surface);border:1px solid var(--border-1);border-radius:2px;transition:border-color 200ms ease,transform 200ms ease}
.milestone:hover{border-color:var(--tb-navy-800)}
.milestone__dot{position:absolute;left:-37px;top:32px;width:10px;height:10px;border-radius:50%;background:var(--bg-page);border:2px solid var(--tb-navy-800);z-index:1}
@media(min-width:720px){.milestone__dot{left:-45px}}
.milestone__dot--live{background:var(--tb-gold-500);border-color:var(--tb-gold-500);box-shadow:0 0 0 4px rgba(184,145,73,0.18)}
.milestone__where{font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:0.06em;color:var(--tb-navy-800);text-transform:uppercase;margin-bottom:12px;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}
.milestone__where a{color:var(--tb-navy-800);text-decoration:none;border-bottom:1px solid transparent;transition:border-color 200ms ease}
.milestone__where a:hover{border-bottom-color:var(--tb-navy-800)}
.milestone__where sup{font-size:10px;color:var(--tb-gold-700);margin-left:3px}
.milestone__loc{font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;color:var(--fg-3);text-transform:none;font-weight:400}
.milestone__what{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.4vw,26px);line-height:1.2;letter-spacing:-0.01em;color:var(--tb-navy-800);margin:0 0 12px;text-wrap:balance}
.milestone__why{font-family:var(--font-serif);font-size:15px;line-height:1.65;color:var(--fg-2);margin:0 0 14px;max-width:64ch}
.milestone__points{list-style:none;margin:0;padding:14px 0 0;border-top:1px solid var(--border-2);display:grid;gap:8px}
.milestone__points li{font-family:var(--font-serif);font-size:14px;line-height:1.55;color:var(--fg-2);padding-left:14px;position:relative;max-width:64ch}
.milestone__points li::before{content:"\2014";position:absolute;left:-2px;color:var(--tb-gold-700)}
.milestone--feature{border-color:var(--tb-navy-800);background:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-surface) 100%)}
.milestone--feature .milestone__what{color:var(--tb-navy-800)}

[data-theme="dark"] .milestone{background:var(--bg-surface);border-color:var(--border-1)}
[data-theme="dark"] .milestone:hover{border-color:var(--tb-gold-500)}
[data-theme="dark"] .milestone__dot{background:var(--bg-page);border-color:var(--tb-gold-500)}
[data-theme="dark"] .milestone__where{color:var(--fg-1)}
[data-theme="dark"] .milestone__where a{color:var(--fg-1)}
[data-theme="dark"] .milestone__what{color:var(--fg-1)}
[data-theme="dark"] .act__title{color:var(--fg-1)}
[data-theme="dark"] .milestone--feature{background:linear-gradient(180deg,#102243 0%,var(--bg-surface) 100%);border-color:var(--tb-gold-500)}
[data-theme="dark"] .milestones{border-left-color:var(--border-1)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.001ms!important;animation-iteration-count:1!important;transition-duration:0.001ms!important;scroll-behavior:auto!important}
}

/* ============================================================ HEADER ACTIONS / THEME TOGGLE */
.site-header__right{display:flex;align-items:center;gap:14px}
.theme-toggle{width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,0.22);background:transparent;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1;padding:0;transition:border-color 200ms ease,background 200ms ease}
.theme-toggle:hover{border-color:#fff;background:rgba(255,255,255,0.08)}
.theme-toggle__icon--dark{display:none}
[data-theme="dark"] .theme-toggle__icon--light{display:none}
[data-theme="dark"] .theme-toggle__icon--dark{display:inline}

/* ============================================================ TRUSTED BAR (highlighted) */
.trusted{padding:40px 0}
.trusted__inner{gap:32px}
@media(min-width:720px){.trusted__inner{grid-template-columns:auto 1fr;gap:56px}}
.trusted__intro{display:flex;flex-direction:column;gap:6px;max-width:none}
.trusted__big{font-family:var(--font-display);font-weight:400;font-size:clamp(40px,7vw,72px);line-height:1;letter-spacing:-0.025em;color:var(--tb-navy-800)}
.trusted__big{font-style:italic}
.trusted__sub{font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.company__name{font-size:19px}
@media(min-width:1024px){.company__name{font-size:20px}}

/* ============================================================ PROFILE highlight */
.section--highlight{background:linear-gradient(180deg,var(--bg-alt) 0%,var(--bg-page) 100%);border-top:1px solid var(--border-2)}
.section--highlight .section-label{border-bottom-color:var(--tb-navy-800)}
.section--highlight .h2{position:relative}
.section--highlight .h2::after{content:"";display:block;width:64px;height:3px;background:var(--tb-gold-500);margin-top:18px}

/* ============================================================ DARK THEME */
[data-theme="dark"]{
  --bg-page:#0B1933;
  --bg-surface:#112344;
  --bg-alt:#0A1A33;
  --fg-1:#ECEEF1;
  --fg-2:#B8C7DB;
  --fg-3:#8FA6C2;
  --border-1:rgba(255,255,255,0.14);
  --border-2:rgba(255,255,255,0.07);
}
[data-theme="dark"] .editorial-rule{border-top-color:var(--tb-gold-500)}
[data-theme="dark"] .h2,[data-theme="dark"] .h3,[data-theme="dark"] .h4{color:var(--fg-1)}
[data-theme="dark"] .eyebrow{color:var(--tb-gold-500)}
[data-theme="dark"] .trusted__big{color:var(--fg-1)}
[data-theme="dark"] .company__name{color:var(--fg-1)}
[data-theme="dark"] .profile__opener{color:var(--fg-1)}
[data-theme="dark"] .pillar__title{color:var(--fg-1)}
[data-theme="dark"] .engagement__company{color:var(--fg-1)}
[data-theme="dark"] .engagement__chapter{color:var(--fg-1)}
[data-theme="dark"] .outcomes__head{color:var(--tb-gold-500)}
[data-theme="dark"] .practice__title{color:var(--fg-1)}
[data-theme="dark"] .pullquote{color:var(--fg-1)}
[data-theme="dark"] .signals__what{color:var(--fg-1)}
[data-theme="dark"] .tag{background:var(--bg-surface);border-color:var(--border-1);color:var(--fg-2)}
[data-theme="dark"] .practice-grid{background:var(--bg-surface)}
[data-theme="dark"] .practice:hover{background:var(--bg-alt)}
[data-theme="dark"] .company--link:hover{background:var(--bg-surface)}
[data-theme="dark"] .btn--secondary{color:var(--fg-1);border-color:var(--fg-1)}
[data-theme="dark"] .btn--secondary:hover{background:var(--fg-1);color:var(--tb-navy-900)}
[data-theme="dark"] .btn--primary{background:var(--tb-gold-500);color:var(--tb-navy-900);border-color:var(--tb-gold-500)}
[data-theme="dark"] .btn--primary:hover{background:var(--tb-gold-200);border-color:var(--tb-gold-200)}
[data-theme="dark"] .section--highlight{background:linear-gradient(180deg,#102243 0%,var(--bg-page) 100%);border-top-color:var(--border-2)}
[data-theme="dark"] .section--alt{background:var(--bg-alt)}
[data-theme="dark"] .section--dark{background:#00132C}
[data-theme="dark"] .hero{background:#00132C}
[data-theme="dark"] .site-footer{background:#00132C}
[data-theme="dark"] .section-label{border-bottom-color:var(--border-1);color:var(--fg-3)}
[data-theme="dark"] ::selection{background:var(--tb-gold-500);color:var(--tb-navy-900)}

/* ============================================================ RESPONSIVE FIXES
   Mobile alignment & overflow patches. Keep at end of file. */
html,body{overflow-x:hidden;max-width:100%}
img,svg{max-width:100%}

/* Allow long emails / URLs to wrap inside the directory card so it never
   pushes the page wider than the viewport. */
.directory{max-width:100%;overflow:hidden}
.directory__row{grid-template-columns:80px 1fr;column-gap:12px}
.directory__row dd,.directory__row dd a{overflow-wrap:anywhere;word-break:break-word;min-width:0;display:inline-block;max-width:100%}
.directory__row dd.mono{font-size:13px}
.directory__foot{flex-wrap:wrap;gap:8px 16px}

/* Hero meta: stop the wide-tracked status line from forcing horizontal scroll */
.hero__meta{overflow-wrap:anywhere}
.hero__meta>span{min-width:0}

/* Header wordmark wraps cleanly on narrow screens */
.site-header__inner{gap:12px}
.wordmark{min-width:0;flex:1 1 auto}
.wordmark__name{overflow-wrap:anywhere}

/* Trusted bar: company tile text shouldn't overflow */
.company__name,.company__note{overflow-wrap:anywhere;min-width:0}

/* Section padding tightens on the smallest screens so content breathes */
@media (max-width:480px){
  .section{padding:64px 0}
  .hero__inner{padding-top:48px;padding-bottom:64px}
  .hero__meta{font-size:10px;letter-spacing:0.18em}
  .directory{padding:24px 20px 18px}
  .directory__row{grid-template-columns:72px 1fr;column-gap:10px}
  .contact-ctas .btn,.hero__ctas .btn{flex:1 1 auto;justify-content:center}
  .pullquote{padding-left:20px}
}

/* CTA buttons: never overflow the screen on narrow viewports */
.btn{max-width:100%;overflow-wrap:anywhere}
.hero__ctas,.contact-ctas{max-width:100%}

/* Portrait: keep the new headshot centred on the face */
.portrait img{object-position:center 22%}

/* ============================================================ COMPANIES (replaces .trusted) */
.companies{padding:64px 0;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);background:var(--bg-page)}
@media(min-width:1024px){.companies{padding:88px 0}}
.companies__head{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:40px;align-items:end}
@media(min-width:1024px){.companies__head{grid-template-columns:1fr 1.4fr;gap:64px;margin-bottom:56px}}
.companies__big{display:block;font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(36px,5.4vw,60px);line-height:1;letter-spacing:-0.025em;color:var(--tb-navy-800)}
.companies__sub{display:block;margin-top:14px;font-family:var(--font-sans);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.companies__lede{font-family:var(--font-serif);font-size:clamp(15px,1.5vw,17px);line-height:1.7;color:var(--fg-2);max-width:54ch}
.companies__grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:560px){.companies__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.companies__grid{grid-template-columns:repeat(3,1fr);gap:16px}}
.company-card{display:flex;flex-direction:column;gap:10px;padding:24px 22px;background:var(--bg-surface);border:1px solid var(--border-1);border-radius:3px;color:inherit;text-decoration:none;transition:border-color 200ms ease,transform 200ms ease,box-shadow 200ms ease;min-height:160px}
.company-card:hover{border-color:var(--tb-navy-800);box-shadow:0 6px 24px -16px rgba(1,31,67,0.35)}
.company-card__brand{font-family:var(--font-display);font-weight:500;font-size:22px;line-height:1.15;color:var(--tb-navy-800);letter-spacing:-0.01em;margin-bottom:2px}
.company-card__brand--current{color:var(--tb-gold-700)}
.company-card__meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 12px;margin-top:0}
.company-card__role{font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:0.06em;color:var(--tb-navy-800);text-transform:uppercase}
.company-card__period{font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;color:var(--fg-3)}
.company-card__loc{font-family:var(--font-serif);font-size:14px;line-height:1.5;color:var(--fg-2);margin-top:auto}
.company-card--current{border-color:var(--tb-gold-500);background:linear-gradient(180deg,#FFFAEC 0%,var(--bg-surface) 60%)}
.company-card--current .company-card__role{color:var(--tb-gold-700)}
[data-theme="dark"] .company-card{background:var(--bg-surface);border-color:var(--border-1)}
[data-theme="dark"] .company-card:hover{border-color:var(--tb-gold-500)}
[data-theme="dark"] .company-card__brand,[data-theme="dark"] .company-card__role{color:var(--fg-1)}
[data-theme="dark"] .companies__big{color:var(--fg-1)}
[data-theme="dark"] .company-card--current{background:linear-gradient(180deg,#1d2a4a 0%,var(--bg-surface) 60%);border-color:var(--tb-gold-500)}
[data-theme="dark"] .company-card__brand--current{color:var(--tb-gold-500)}

/* ============================================================ ACTS — 3-COLUMN WORK LAYOUT */
.acts{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
@media(min-width:768px){.acts{grid-template-columns:1fr;gap:40px}}
@media(min-width:1100px){.acts{grid-template-columns:repeat(3,1fr);gap:28px}}
.act-col{display:flex;flex-direction:column;gap:18px;min-width:0}
.act-col__head{padding:0 4px 4px;border-bottom:1px solid var(--border-1);padding-bottom:20px;margin-bottom:6px}
.act-col__num{font-family:var(--font-sans);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:var(--tb-gold-700);font-weight:500;margin-bottom:6px}
.act-col__year{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);letter-spacing:0.04em;margin-bottom:14px}
.act-col__title{font-family:var(--font-display);font-weight:400;font-size:clamp(24px,2.6vw,30px);line-height:1.12;letter-spacing:-0.01em;color:var(--tb-navy-800);margin-bottom:14px;text-wrap:balance}
.act-col__lede{font-family:var(--font-serif);font-size:14.5px;line-height:1.6;color:var(--fg-2)}
.act-col--current .act-col__title::after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--tb-gold-500);margin-left:10px;vertical-align:middle;animation:livedot 2.4s ease-in-out infinite}
.act-col__cards{display:flex;flex-direction:column;gap:14px}
.ac{background:var(--bg-surface);border:1px solid var(--border-1);border-radius:3px;padding:18px 18px 16px;transition:border-color 200ms ease,transform 200ms ease;min-width:0;scroll-margin-top:calc(var(--site-header-h,64px) + 24px)}
.ac:hover{border-color:var(--tb-navy-800)}
.ac__brand{font-family:var(--font-display);font-weight:500;font-size:20px;line-height:1.15;letter-spacing:-0.005em;color:var(--tb-navy-800);margin-bottom:6px}
.ac__meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 8px;font-family:var(--font-sans);font-size:11px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;color:var(--tb-navy-700);margin-bottom:10px}
.ac__meta .ac__sep{color:var(--border-1);font-weight:400}
.ac__meta span:nth-child(3){color:var(--fg-3);font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;text-transform:none;font-weight:400}
.ac__why{font-family:var(--font-serif);font-size:14px;line-height:1.55;color:var(--fg-2);margin-bottom:12px}
.ac__points{list-style:none;margin:0;padding:12px 0 0;border-top:1px solid var(--border-2);display:grid;gap:6px}
.ac__points li{font-family:var(--font-serif);font-size:13.5px;line-height:1.5;color:var(--fg-2);padding-left:14px;position:relative}
.ac__points li::before{content:"\2014";position:absolute;left:-2px;color:var(--tb-gold-700)}
.ac--feature{border-color:var(--tb-navy-800);background:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-surface) 100%)}
.ac--current{border-color:var(--tb-gold-500);background:linear-gradient(180deg,#FFFAEC 0%,var(--bg-surface) 70%)}
[data-theme="dark"] .ac{background:var(--bg-surface);border-color:var(--border-1)}
[data-theme="dark"] .ac:hover{border-color:var(--tb-gold-500)}
[data-theme="dark"] .ac__brand,[data-theme="dark"] .ac__meta{color:var(--fg-1)}
[data-theme="dark"] .ac--current{background:linear-gradient(180deg,#1d2a4a 0%,var(--bg-surface) 70%)}
[data-theme="dark"] .act-col__title{color:var(--fg-1)}

/* ============================================================ H2 wide variant */
.h2--wide{font-size:clamp(28px,4.4vw,52px);text-wrap:balance}
@media(min-width:1100px){.h2--wide{white-space:nowrap}}

/* ============================================================ WORDMARK */
.wordmark{flex-wrap:nowrap;align-items:center;gap:12px;min-width:0}
.wordmark__role{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:560px){.wordmark__role{display:none}}
.nowrap{white-space:nowrap}

/* ============================================================ TIMELINE (Credibility) */
.timeline{list-style:none;position:relative;display:grid;gap:22px;padding:8px 0 8px 0;margin:0}
.timeline::before{content:"";position:absolute;left:14px;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0,var(--border-1) 8%,var(--border-1) 92%,transparent 100%)}
@media(min-width:1024px){
  .timeline{grid-template-columns:repeat(5,minmax(0,1fr));gap:0;padding:24px 0 8px;align-items:stretch}
  .timeline::before{left:0;right:0;top:42px;bottom:auto;height:1px;width:auto;background:linear-gradient(90deg,transparent 0,var(--border-1) 4%,var(--border-1) 96%,transparent 100%)}
  .timeline__item{display:flex;flex-direction:column}
  .timeline__card{flex:1}
}
.timeline__item{position:relative;padding-left:40px}
@media(min-width:1024px){.timeline__item{padding:0 10px}}
.timeline__item::before{content:"";position:absolute;left:9px;top:8px;width:11px;height:11px;border-radius:50%;background:var(--bg-page);border:2px solid var(--tb-navy-800);z-index:1}
@media(min-width:1024px){.timeline__item::before{left:50%;top:36px;transform:translateX(-50%)}}
.timeline__item--accent::before{background:var(--tb-gold-500);border-color:var(--tb-gold-500);box-shadow:0 0 0 4px rgba(184,145,73,0.18)}
.timeline__item--current::before{background:var(--tb-navy-800);border-color:var(--tb-navy-800);box-shadow:0 0 0 4px rgba(1,31,67,0.18)}
.timeline__year{font-family:var(--font-mono);font-size:12px;letter-spacing:0.06em;color:var(--tb-gold-700);margin-bottom:8px;font-weight:500}
@media(min-width:1024px){.timeline__year{text-align:center;margin-bottom:36px;min-height:18px;font-size:11px}}
.timeline__card{background:var(--bg-surface);border:1px solid var(--border-1);border-radius:3px;padding:18px 18px 16px;transition:border-color 200ms ease;min-height:0}
@media(min-width:1024px){.timeline__card{margin-top:8px;min-height:240px;padding:20px 18px 18px}}
@media(min-width:1024px){.timeline__year{padding:0 6px}}
@media(min-width:1024px){.timeline__item{padding:0 8px}}
.timeline__item:hover .timeline__card{border-color:var(--tb-navy-800)}
.timeline__item--accent .timeline__card{border-color:var(--tb-gold-500)}
.timeline__item--current .timeline__card{border-color:var(--tb-navy-800);background:linear-gradient(180deg,#FFFAEC 0%,var(--bg-surface) 70%)}
.timeline__what{font-family:var(--font-display);font-weight:500;font-size:clamp(16px,1.4vw,18px);line-height:1.25;color:var(--tb-navy-800);letter-spacing:-0.005em;margin-bottom:8px;text-wrap:balance}
.timeline__detail{font-family:var(--font-serif);font-size:13px;line-height:1.55;color:var(--fg-2)}
[data-theme="dark"] .timeline__card{background:var(--bg-surface);border-color:var(--border-1)}
[data-theme="dark"] .timeline__what{color:var(--fg-1)}
[data-theme="dark"] .timeline__item::before{background:var(--bg-page);border-color:var(--tb-gold-500)}
[data-theme="dark"] .timeline__item--current .timeline__card{background:linear-gradient(180deg,#1d2a4a 0%,var(--bg-surface) 70%)}

/* ============================================================ FIXED-HEADER SAFETY */
.hero__inner{padding-top:24px}
@media(min-width:1024px){.hero__inner{padding-top:48px}}

/* ============================================================ FOOTER WORDMARK: stack name + role cleanly, never truncate */
.site-footer .wordmark{flex-wrap:wrap;align-items:baseline;column-gap:10px;row-gap:4px}
.site-footer .wordmark__name{white-space:nowrap}
.site-footer .wordmark__role{white-space:normal;overflow:visible;text-overflow:clip;display:inline-block;max-width:100%}
@media(max-width:560px){.site-footer .wordmark__role{display:inline-block}}

/* ============================================================ BALANCED COLUMN RATIOS (reduce left-heavy whitespace) */
@media(min-width:1024px){
  .editorial{grid-template-columns:0.85fr 1.6fr;gap:72px}
  .impact-head{grid-template-columns:0.9fr 1.5fr;gap:72px}
  .companies__head{grid-template-columns:0.85fr 1.5fr;gap:56px}
}

/* ============================================================ RESPONSIVE LAYOUT FIXES
   (1) Acts: equalize column heads so all "first cards" align across the 3-column grid,
       regardless of title wrapping or lede length.
   (2) Timeline (Credibility): make 5-up cards stretch to the same height so the bottom
       edges align cleanly across the row.
============================================================ */
@media(min-width:1100px){
  .act-col__head{min-height:280px;display:flex;flex-direction:column}
}
@media(min-width:1024px){
  .timeline__item{height:100%}
  .timeline__card{flex:1 1 auto;height:100%}
}
