/* TaylorGahm.com — shared base */
:root{
  --ink:#111;
  --text:#3a3a38;
  --mute:#8a8a82;
  --line:#e4e3dd;
  --line-2:#cbc9bf;
  --bg:#faf9f5;
  --bg-2:#f1f0ea;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{font-family:var(--sans);font-weight:300;font-size:15px;line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ───── NAV (dark, sticky — single source of truth) ───── */
nav.top{position:fixed;top:0;left:0;right:0;padding:28px 48px;display:flex;justify-content:space-between;align-items:center;z-index:50;background:#0a0908;border-bottom:1px solid rgba(241,237,228,.12)}
nav.top .mark{display:inline-flex;align-items:center;gap:0;font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;color:#f1ede4;-webkit-tap-highlight-color:transparent;text-decoration:none}
nav.top .mark-avatar{display:none}
nav.top .mark-logo{height:22px;width:auto;display:block;pointer-events:none;user-select:none;-webkit-user-drag:none}
nav.top ul{list-style:none;display:flex;gap:36px;margin:0;padding:0}
nav.top ul a{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:400;color:#f1ede4;opacity:.72;transition:opacity .25s}
nav.top ul a:hover,nav.top ul a.active{opacity:1;color:#f1ede4}
nav.top ul a.active{border-bottom:1.5px solid #f1ede4;padding-bottom:5px}
nav.top .nav-end{display:flex;align-items:center;gap:14px}
nav.top .nav-cta{display:inline-block;background:#f1ede4;color:#0a0908;padding:11px 22px;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;border:1px solid #f1ede4;transition:background .25s,color .25s,border-color .25s}
nav.top .nav-cta:hover{background:transparent;color:#f1ede4}
nav.top .nav-cta-outline{display:inline-block;background:transparent;color:#f1ede4;padding:11px 22px;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;border:1px solid rgba(241,237,228,.45);text-decoration:none;transition:border-color .25s,color .25s}
nav.top .nav-cta-outline:hover,nav.top .nav-cta-outline.active{background:transparent;border-color:#f1ede4;color:#f1ede4}
nav.top .burger{display:none;width:28px;height:18px;flex-direction:column;justify-content:space-between;background:transparent;border:0;cursor:pointer;padding:0;z-index:110;position:relative}
nav.top .burger span{display:block;height:1px;background:#f1ede4;width:100%;transition:transform .3s,opacity .3s}
body.menu-open nav.top .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open nav.top .burger span:nth-child(2){opacity:0}
body.menu-open nav.top .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(min-width:821px){nav.top ul{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}}
@media(max-width:820px){
  nav.top{padding:14px 18px}
  nav.top ul{display:none}
  nav.top .mark-logo{height:24px}
  nav.top .nav-cta,nav.top .nav-cta-outline{display:none}
  nav.top .burger{display:flex;width:20px;height:11px}
  body.menu-open nav.top .burger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
  body.menu-open nav.top .burger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
  body.menu-open nav.top .burger{visibility:hidden;pointer-events:none}
  body.menu-open nav.top .mark{opacity:0;pointer-events:none}
}

/* ───── MOBILE MENU PANEL ───── */
.mobile-panel{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:100;
  transform:translateY(-100%);
  transition:transform .42s cubic-bezier(.7,0,.2,1);
  display:flex;flex-direction:column;
  padding:24px 28px 40px;
  overflow-y:auto;
  visibility:hidden;
}
body.menu-open .mobile-panel{transform:translateY(0);visibility:visible}
body.menu-open{overflow:hidden}
.mobile-panel .panel-close{
  position:absolute;top:14px;right:14px;z-index:112;
  background:transparent;border:0;
  width:44px;height:44px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
  font-family:var(--serif,"Cormorant Garamond",Georgia,serif);
}
.mobile-panel .panel-close .x{font-size:32px;line-height:1;font-weight:300}
.mobile-panel .panel-nav{
  flex:1;
  display:flex;flex-direction:column;justify-content:center;
  gap:2px;padding:40px 0;
}
.mobile-panel .panel-nav a{
  display:block;padding:12px 0;
  font-family:var(--serif,"Cormorant Garamond",Georgia,serif);
  font-size:40px;font-weight:300;
  letter-spacing:-.018em;line-height:1.08;
  color:var(--ink);text-decoration:none;
}
.mobile-panel .panel-nav a.active{font-style:italic}
.mobile-panel .panel-foot{
  display:flex;flex-direction:column;gap:22px;
}
.mobile-panel .mobile-cta{
  padding:18px 24px;
  border:1px solid var(--ink);
  background:var(--ink);color:#f1ede4;
  text-align:center;text-decoration:none;
  font-family:var(--sans,"Inter",system-ui,sans-serif);
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
}
.mobile-panel .panel-sig{
  display:flex;flex-direction:column;gap:4px;text-align:center;
}
.mobile-panel .panel-sig-name{
  font-family:var(--serif,"Cormorant Garamond",Georgia,serif);
  font-size:15px;font-style:italic;color:var(--mute);letter-spacing:-.003em;
}
.mobile-panel .panel-sig-role{
  font-family:var(--sans,"Inter",system-ui,sans-serif);
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);
}
@media(max-height:680px){
  .mobile-panel .panel-nav a{font-size:32px;padding:8px 0}
  .mobile-panel .panel-nav{padding:28px 0}
}

/* ───── MEDIA HERO — overlay (shared across all pages) ───── */
.hero-film{
  position:relative;
  min-height:86vh;
  display:flex;align-items:flex-end;
  padding:0 48px 90px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-film .media{
  position:absolute;inset:0;z-index:0;
  background:var(--bg-2);
}
.hero-film .media img,
.hero-film .media video,
.hero-film .media iframe{
  width:100%;height:100%;
  object-fit:cover;display:block;border:0;
}
.hero-film .media .placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--mute);
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  background:
    repeating-linear-gradient(45deg, transparent 0 14px, rgba(139,138,130,.07) 14px 28px),
    var(--bg-2);
}
.hero-film::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(8,8,7,.22) 0%, rgba(8,8,7,0) 38%, rgba(8,8,7,.85) 100%);
}
.hero-film .wrap{
  position:relative;z-index:2;
  max-width:1360px;margin:0 auto;width:100%;
  padding-top:180px;
}
.hero-film .eyebrow{
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;
  color:#d9d5c9;margin-bottom:30px;
  display:flex;flex-wrap:wrap;gap:14px 22px;
}
.hero-film .eyebrow span{white-space:nowrap}
.hero-film .eyebrow .dot{color:rgba(241,237,228,.3)}
.hero-film .eyebrow .here{color:#f1ede4}
.hero-film .eyebrow a{opacity:.85}
.hero-film .eyebrow a:hover{opacity:1}
.hero-film h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(42px,5.4vw,82px);line-height:1.06;letter-spacing:-.018em;
  color:#f1ede4;max-width:1180px;margin-bottom:36px;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
}
.hero-film h1 em{font-style:italic;font-weight:300}
.hero-film .sub{
  font-size:15.5px;line-height:1.65;color:#e2ddd0;
  max-width:780px;opacity:.95;min-height:77px;
  text-shadow:0 1px 12px rgba(0,0,0,.4);
}
@media(max-width:900px){
  .hero-film{padding:0 22px 56px;min-height:78vh}
  .hero-film .wrap{padding-top:120px}
  .hero-film .eyebrow{font-size:9.5px;gap:10px 16px;margin-bottom:22px}
  .hero-film h1{font-size:clamp(34px,8vw,52px);margin-bottom:24px}
  .hero-film .sub{font-size:14px;line-height:1.6}
}
@media(max-width:480px){
  .hero-film{min-height:70vh;padding:0 18px 44px}
  .hero-film .wrap{padding-top:100px}
  .hero-film h1{font-size:32px}
}

/* ───── LEGACY PAGE HERO (kept for compat) ───── */
.page-hero{padding:180px 48px 90px;max-width:1360px;margin:0 auto}
.page-hero .eyebrow{
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);margin-bottom:30px;
  display:flex;flex-wrap:wrap;gap:14px 22px;
}
.page-hero .eyebrow span{white-space:nowrap}
.page-hero .eyebrow .dot{color:var(--line-2)}
.page-hero .eyebrow .here{color:var(--ink)}
.page-hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(38px,5vw,74px);line-height:1.08;letter-spacing:-.018em;
  color:var(--ink);max-width:1180px;margin-bottom:36px;
}
.page-hero h1 em{font-style:italic;font-weight:300}
.page-hero .sub{font-size:15px;line-height:1.65;color:var(--text);max-width:760px;opacity:.88}
@media(max-width:900px){.page-hero{padding:110px 22px 50px}}

/* ───── SECTION ───── */
.sec{padding:120px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto}
.sec .num{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:18px}
.sec h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.2vw,44px);line-height:1.15;letter-spacing:-.012em;
  max-width:820px;margin-bottom:56px;
}
@media(max-width:900px){.sec{padding:90px 22px}}

/* ───── FOOTER ───── */
.site-footer{
  background:var(--ink);color:#a09d95;
  padding:90px 48px 50px;
}
.site-footer a{color:#a09d95;text-decoration:none}
.site-footer a:hover{color:#f1ede4}
.footer-grid{
  max-width:1360px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  padding-bottom:70px;border-bottom:1px solid rgba(241,237,228,.12);
}
.footer-col{display:flex;flex-direction:column;gap:14px}
.footer-head{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(241,237,228,.35);font-weight:500;margin-bottom:6px;
}
.footer-col a,.footer-col span{font-size:14px;letter-spacing:.01em;line-height:1.5}
.footer-contact{text-align:right;align-items:flex-end}
.footer-contact a,.footer-contact span{text-transform:none;letter-spacing:0}
.footer-base{
  max-width:1360px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:16px;
  padding-top:36px;
  font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
}
.footer-mark{color:#f1ede4;font-weight:500}
.footer-line{color:rgba(241,237,228,.3);font-style:italic;letter-spacing:.04em;text-transform:none;font-family:var(--serif);font-size:13px}
.footer-copy{color:rgba(241,237,228,.25)}
@media(max-width:720px){
  .site-footer{padding:60px 22px 40px}
  .footer-grid{grid-template-columns:1fr;gap:44px}
  .footer-contact{text-align:left;align-items:flex-start}
  .footer-base{flex-direction:column;gap:10px}
}

/* ───── SERVICES ───── */
.services{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line)}
.service{padding:56px 48px 60px 0;border-bottom:1px solid var(--line)}
.service:nth-child(2n){padding-left:48px;border-left:1px solid var(--line)}
.service .no{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:20px}
.service h3{font-family:var(--serif);font-weight:400;font-size:30px;line-height:1.1;letter-spacing:-.008em;margin-bottom:16px}
.service p{font-size:13.5px;line-height:1.7;color:var(--text)}
@media(max-width:820px){
  .services{grid-template-columns:1fr}
  .service,.service:nth-child(2n){padding:40px 0;border-left:none}
}

/* ───── CASE CARDS ───── */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line)}
.case{background:var(--bg);padding:44px 32px 48px;display:flex;flex-direction:column;min-height:260px;transition:background .3s}
.case:hover{background:var(--bg-2)}
.case .tag{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:20px}
.case h4{font-family:var(--serif);font-weight:400;font-size:24px;line-height:1.15;letter-spacing:-.006em;margin-bottom:14px}
.case p{font-size:13px;line-height:1.65;color:var(--text);flex:1;margin-bottom:22px}
.case .more{font-size:10px;letter-spacing:.26em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px;align-self:flex-start}
@media(max-width:900px){.cases{grid-template-columns:1fr}}

/* ───── QUOTES ───── */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:56px}
.quote{border-top:1px solid var(--line);padding-top:28px}
.quote blockquote{font-family:var(--serif);font-weight:400;font-style:italic;font-size:20px;line-height:1.4;color:var(--ink);margin-bottom:22px;letter-spacing:-.005em}
.quote cite{font-style:normal;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);line-height:1.6;display:block}
.quote cite b{color:var(--ink);font-weight:500;display:block;margin-bottom:4px}
@media(max-width:900px){.quotes{grid-template-columns:1fr;gap:40px}}

/* ───── CTA BAND ───── */
.cta-band{padding:140px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto}
.cta-band h2{font-family:var(--serif);font-weight:300;font-size:clamp(32px,3.6vw,52px);line-height:1.12;letter-spacing:-.014em;max-width:920px;margin-bottom:40px}
.cta-band h2 em{font-style:italic}
.cta-band a.link{font-size:11px;letter-spacing:.28em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px}
@media(max-width:900px){.cta-band{padding:90px 22px}}

/* ───── TRUST BAR (directly under hero) ───── */
.trust-bar{padding:56px 48px 60px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto}
.trust-bar .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:28px}
.trust-bar .row{display:flex;flex-wrap:wrap;align-items:center;gap:32px 56px}
.trust-bar .row img{height:26px;width:auto;max-width:150px;object-fit:contain;filter:brightness(0);opacity:.38;transition:opacity .25s}
.trust-bar .row img:hover{opacity:.72}
@media(max-width:820px){.trust-bar{padding:40px 22px}.trust-bar .row{gap:22px 36px}.trust-bar .row img{height:20px;max-width:110px}}

/* ───── STATS BAR ───── */
.stats-bar{padding:72px 48px 80px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stats-bar .stat .num{font-family:var(--serif);font-weight:400;font-size:clamp(38px,4.2vw,58px);line-height:1;letter-spacing:-.018em;color:var(--ink);margin-bottom:16px}
.stats-bar .stat .num .mm{font-weight:400;font-size:.62em;letter-spacing:.03em;vertical-align:.04em;margin-left:.05em}
.stats-bar .stat .lbl{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);line-height:1.6}
@media(max-width:820px){.stats-bar{grid-template-columns:repeat(2,1fr);padding:56px 22px;gap:44px 20px}}
@media(max-width:480px){.stats-bar{gap:32px 16px;padding:44px 18px}.stats-bar .stat .num{font-size:34px;margin-bottom:10px}.stats-bar .stat .lbl{font-size:9px}}

/* ───── CONTRARIAN BLOCK ───── */
.contrarian{padding:140px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto}
.contrarian .num{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:22px}
.contrarian .pull{font-family:var(--serif);font-weight:300;font-size:clamp(34px,4.4vw,62px);line-height:1.1;letter-spacing:-.014em;max-width:1080px;margin-bottom:40px;color:var(--ink)}
.contrarian .pull em{font-style:italic;font-weight:300}
.contrarian .body{font-size:15.5px;line-height:1.75;color:var(--text);max-width:760px;margin-bottom:40px}
.contrarian .link{font-size:11px;letter-spacing:.28em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px}
@media(max-width:900px){.contrarian{padding:90px 22px}}

/* ───── TOMBSTONES (big number right, label under) ───── */
.tombstones{max-width:1360px;margin:0 auto;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(2,1fr)}
.tombstone{padding:56px 48px 60px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);display:grid;grid-template-columns:1fr auto;gap:40px;align-items:start;transition:background .3s}
.tombstone:nth-child(2n){border-right:none}
.tombstone:nth-last-child(-n+2){border-bottom:none}
.tombstone:hover{background:var(--bg-2)}
.tombstone .left .tag{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:16px}
.tombstone .left h4{font-family:var(--serif);font-weight:400;font-size:32px;line-height:1.1;letter-spacing:-.008em;margin-bottom:14px}
.tombstone .left p{font-size:13.5px;line-height:1.65;color:var(--text);max-width:420px;margin-bottom:22px}
.tombstone .left .more{font-size:10px;letter-spacing:.26em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px;display:inline-block}
.tombstone .right{text-align:right;min-width:180px}
.tombstone .right .metric{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4vw,54px);line-height:1;letter-spacing:-.018em;color:var(--ink);margin-bottom:10px;white-space:nowrap}
.tombstone .right .unit{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--mute);line-height:1.5;max-width:180px;margin-left:auto}
@media(max-width:820px){
  .tombstones{grid-template-columns:1fr}
  .tombstone{padding:42px 22px;border-right:none;grid-template-columns:1fr;gap:24px}
  .tombstone .right{text-align:left;min-width:0}
  .tombstone .right .unit{margin-left:0}
}

/* ───── DE-RISK BLOCK ───── */
.derisk{padding:130px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:80px}
.derisk .num{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:22px}
.derisk h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3.4vw,48px);line-height:1.12;letter-spacing:-.012em;max-width:420px}
.derisk h2 em{font-style:italic}
.derisk ul{list-style:none;display:flex;flex-direction:column;gap:32px}
.derisk li{display:grid;grid-template-columns:30px 1fr;gap:22px;padding-bottom:30px;border-bottom:1px solid var(--line)}
.derisk li:last-child{border-bottom:none;padding-bottom:0}
.derisk li .n{font-size:10px;letter-spacing:.2em;color:var(--mute);padding-top:5px}
.derisk li h4{font-family:var(--serif);font-weight:400;font-size:22px;line-height:1.2;margin-bottom:10px}
.derisk li p{font-size:14px;line-height:1.7;color:var(--text);max-width:540px}
@media(max-width:900px){.derisk{grid-template-columns:1fr;gap:50px;padding:90px 22px}}

/* ───── PULL QUOTE (single, mid-page) ───── */
.pull-quote{padding:130px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto;text-align:center}
.pull-quote blockquote{font-family:var(--serif);font-weight:400;font-style:italic;font-size:clamp(28px,3.4vw,46px);line-height:1.22;letter-spacing:-.008em;color:var(--ink);max-width:1080px;margin:0 auto 34px}
.pull-quote cite{font-style:normal;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute);line-height:1.6;display:block}
.pull-quote cite b{color:var(--ink);font-weight:500;display:block;margin-bottom:4px}
@media(max-width:900px){.pull-quote{padding:90px 22px}}

/* ───── INLINE CTA (tighter than cta-band, for mid-page placements) ───── */
.cta-inline{padding:80px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto;display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:30px}
.cta-inline p{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.4vw,32px);line-height:1.2;max-width:720px;color:var(--ink)}
.cta-inline p em{font-style:italic}
.cta-inline a.link{font-size:11px;letter-spacing:.28em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px;white-space:nowrap}
@media(max-width:820px){.cta-inline{padding:60px 22px;flex-direction:column;align-items:flex-start}}

/* ───── WORK GRID (selected work — matches homepage layout) ───── */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:56px;max-width:1360px;margin-left:auto;margin-right:auto;padding:0 48px}
.work-card{display:block;border:1px solid var(--line);overflow:hidden;transition:border-color .3s;background:var(--bg)}
.work-card:hover{border-color:#aaa}
.work-card-image{width:100%;aspect-ratio:16/10;background:var(--bg-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:10px;color:var(--mute);letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--line);overflow:hidden}
.work-card-image span{font-size:9px;color:var(--line);letter-spacing:.15em;font-style:italic}
.wc-img-1{background:#f0ece8}
.wc-img-2{background:#ece8eb}
.wc-img-3{background:#e8ecf0}
.wc-img-4{background:#ebece8}
.wc-img-5{background:#f0ede8}
.wc-img-6{background:#e8f0ee}
.wc-img-7{background:#edeaf0}
.wc-img-8{background:#eef0e8}
.wc-img-9{background:#f0e8e8}
.work-card-content{padding:24px 28px;display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.work-card-info{flex:1;min-width:0}
.work-card-client{font-size:10px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.work-card-title{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);line-height:1.3}
.work-card-arrow{font-size:10px;color:var(--mute);margin-top:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.work-card-metric-block{flex-shrink:0;text-align:right}
.work-card-metric{font-family:var(--serif);font-size:34px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-.018em;margin-bottom:8px;white-space:nowrap}
.mm{font-size:.62em;letter-spacing:.03em;vertical-align:.04em;margin-left:.05em;font-weight:400}

/* ───── MINISTRY LOGO STRIP ───── */
.ministry-logos{padding:70px 48px 80px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto}
.ministry-logos .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:40px}
.ministry-logos .grid{display:flex;flex-wrap:wrap;align-items:center;gap:36px 64px}
.ministry-logos .grid img{height:28px;width:auto;max-width:170px;object-fit:contain;filter:brightness(0);opacity:.42;transition:opacity .25s}
.ministry-logos .grid img:hover{opacity:.78}
.ministry-logos .grid .wm{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:.01em;color:var(--ink);opacity:.52;transition:opacity .25s;line-height:1;white-space:nowrap}
.ministry-logos .grid .wm:hover{opacity:.88}
@media(max-width:820px){.ministry-logos{padding:48px 22px}.ministry-logos .grid{gap:24px 40px}.ministry-logos .grid img{height:22px;max-width:130px}.ministry-logos .grid .wm{font-size:18px}}

/* ───── THESIS / PEDIGREE CALLOUT ───── */
.callout{padding:140px 48px;border-top:1px solid var(--line);max-width:1360px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.callout .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);font-weight:500}
.callout .body p{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.4vw,32px);line-height:1.4;color:var(--ink);letter-spacing:-.008em;max-width:940px}
.callout .body p em{font-style:italic}
.callout .body p + p{margin-top:24px}
@media(max-width:900px){.callout{padding:90px 22px;grid-template-columns:1fr;gap:28px}}
.work-card-metric-sub{font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);line-height:1.3;white-space:nowrap}
@media(max-width:820px){
  .work-grid{grid-template-columns:1fr;padding:0 22px;margin-top:40px;gap:18px}
  .work-card-content{flex-direction:row;gap:16px;align-items:flex-end;padding:20px}
  .work-card-metric{font-size:26px}
  /* Logo-over-thumbnail pattern depends on hover to reveal the work; on mobile there's no hover so invert to the 'hovered' state: full-color thumbnail, no veil, no centered logo. The client name in the caption already identifies the piece. */
  .wc-logo-tile .wc-logo-bg{filter:none}
  .wc-logo-tile .wc-logo-veil{opacity:0}
  .wc-logo-tile .wc-logo-mark{display:none}
}
@media(max-width:480px){
  /* Phone: stack caption as a vertical hierarchy — title leads, metric subordinate */
  .work-card-content{flex-direction:column;align-items:flex-start;gap:10px;padding:18px}
  .work-card-metric-block{text-align:left}
  .work-card-metric{font-size:22px;margin-bottom:2px}
  .work-card-metric-sub{font-size:8.5px}
  .work-card-title{font-size:18px}
}

/* ───── BIO CALLOUT (pre-footer, all pages) ───── */
.bio-callout{
  max-width:1360px;margin:0 auto;
  padding:100px 48px 110px;
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:280px 1fr;gap:72px;align-items:center;
}
.bio-callout .portrait{
  width:280px;height:340px;
  background:var(--bg-2);
  border:1px solid var(--line);
  background-image:
    repeating-linear-gradient(45deg,transparent 0 14px,rgba(139,138,130,.07) 14px 28px);
  display:flex;align-items:flex-end;justify-content:center;
  font-size:9px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mute);padding:18px;
  background-size:cover;background-position:center;
}
.bio-callout .portrait.has-image{background-image:none;border:0}
.bio-callout .portrait img{width:100%;height:100%;object-fit:cover;display:block}
.bio-callout .bio-body .label{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);margin-bottom:20px;
}
.bio-callout .bio-body p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.2vw,30px);line-height:1.42;
  color:var(--ink);letter-spacing:-.008em;
  max-width:720px;margin-bottom:26px;
}
.bio-callout .bio-body p em{font-style:italic}
.bio-callout .bio-body .link{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink);border-bottom:1.5px solid var(--ink);
  padding-bottom:3px;font-weight:500;
  display:inline-block;
}
@media(max-width:820px){
  .bio-callout{grid-template-columns:1fr;gap:32px;padding:64px 22px 72px}
  .bio-callout .portrait{width:100%;max-width:260px;height:320px;margin:0 auto}
  .bio-callout .bio-body p{font-size:20px}
}

/* nav defined above — single source of truth */
