/*
 * Global stylesheet for the Knowledge Commons template.
 *
 * The :root token block below is the canonical source — these values are
 * mirrored in theme.json so the KMS style tokenizer can extract them.
 * Per-section CSS rules live further down; section components reference
 * these classes via className. No section file should introduce new
 * arbitrary inline styles — extend a token instead.
 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --amber:#C4922A;--amber-light:#d4a640;
  --dark:#1C2820;--dark-mid:#2d3d35;
  --bg:#F7F5F0;--bg-warm:#EFECE4;--bg-section:#E8E4DB;
  --text:#1a1a18;--text-mid:#4a4a46;--text-light:#7a7a74;
  --rule:#d8d4cc;
  --serif:'EB Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
[hidden]{display:none!important;}
[data-theme="dark"]{
  --amber:#D4A640;--amber-light:#E5BC5B;
  --dark:#283632;--dark-mid:#33433D;
  --bg:#0E1613;--bg-warm:#161F1B;--bg-section:#1A2520;
  --text:#F2EFE8;--text-mid:#C7C2B8;--text-light:#8A857C;
  --rule:#2A332E;
}
[data-theme="dark"] body{color-scheme:dark;}
[data-theme="dark"] img,[data-theme="dark"] .hp-media-tile-img{filter:grayscale(20%) brightness(.78);}
[data-theme="dark"] .hp-hero-bg::after{background:linear-gradient(135deg,rgba(8,14,12,.94) 0%,rgba(8,14,12,.82) 50%,rgba(8,14,12,.72) 100%);}
[data-theme="dark"] .about-hero::before{opacity:.08;}
[data-theme="dark"] .hp-media-tile-info{background:linear-gradient(0deg,rgba(0,4,2,.97) 0%,rgba(0,4,2,.82) 45%,rgba(0,4,2,.35) 80%,transparent 100%);}
[data-theme="dark"] .funding-bar-row + .funding-bar-row .funding-bar-fill{background:#5E6D5E;}
[data-theme="dark"] .funding-bar-row:nth-child(3) .funding-bar-fill{background:#4A5750;}
[data-theme="dark"] .funding-bar-row:nth-child(4) .funding-bar-fill{background:#3B4640;}
[data-theme="dark"] .funding-bar-row:nth-child(5) .funding-bar-fill{background:#2F3833;}
[data-theme="dark"] .chat-panel{background:var(--bg-section);border-color:var(--rule);}
[data-theme="dark"] .chat-msg.bot{background:var(--bg-warm);color:var(--text);}
[data-theme="dark"] .team-card{background:var(--bg-warm);}
[data-theme="dark"] .team-card-avatar{background:var(--dark);}
[data-theme="dark"] .partner-tile{background:var(--bg-warm);}
[data-theme="dark"] .hp-cat-card{background:var(--bg-warm);}
[data-theme="dark"] .hp-cat-card:nth-child(2n){background:var(--bg-section);}
[data-theme="dark"] .hp-cat-card:hover{background:var(--rule)!important;}
[data-theme="dark"] .search-overlay-inner{background:var(--bg);}
[data-theme="dark"] .refine-flyout{background:var(--bg-section);}
[data-theme="dark"] .tweaks-panel{background:var(--bg-section);border-color:var(--rule);}
[data-theme="dark"] .tweak-row select{background:var(--bg);color:var(--text);}
[data-theme="dark"] .funding-supporter{background:var(--bg-warm);}
[data-theme="dark"] .contrib-criterion{background:var(--bg-warm);}
[data-theme="dark"] .contrib-step{background:var(--bg-warm);}
[data-theme="dark"] .legal-prose .legal-callout,[data-theme="dark"] .legal-prose .legal-address{background:var(--bg-warm);color:var(--text-mid);}
[data-theme="dark"] .legal-table th{background:var(--bg-warm);}
html{transition:background-color .25s ease;}
body,.kc-nav,.kc-footer,.about-hero,.legal-hero,.funding-breakdown,.funding-policy,.contrib-criteria,.contrib-form-section,.event-cards-section,.hp-media-section,.about-team{transition:background-color .25s ease,color .25s ease,border-color .25s ease;}

/* ── NAV BROWSE DROPDOWN ── */
.nav-dropdown-wrap{position:relative;}
.nav-trigger{display:flex;align-items:center;gap:7px;}
.nav-trigger .nav-caret{font-size:12px;opacity:.7;line-height:1;transition:transform .2s ease,opacity .15s ease;}
.nav-trigger:hover .nav-caret{opacity:1;}
.nav-dropdown-wrap [aria-expanded="true"] .nav-caret{transform:rotate(180deg);opacity:1;}
.nav-dropdown{position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%);min-width:520px;background:var(--bg);border:1px solid var(--rule);box-shadow:0 12px 40px rgba(0,0,0,.10);z-index:160;display:grid;grid-template-columns:1fr 1fr;animation:fadeIn .15s ease;}
.nav-dropdown--single{min-width:280px;grid-template-columns:1fr;}
[data-theme="dark"] .nav-dropdown{background:var(--bg-section);box-shadow:0 12px 40px rgba(0,0,0,.45);}
.nav-dropdown-col{padding:36px 40px 40px;display:flex;flex-direction:column;}
.nav-dropdown-col + .nav-dropdown-col{border-left:1px solid var(--rule);}
.nav-dropdown-label{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light);margin-bottom:24px;display:block;}
.nav-dropdown-item{display:block;padding:14px 0;cursor:pointer;color:var(--text-mid)!important;background:none!important;border:none!important;text-align:left!important;font-family:var(--sans)!important;font-size:15px!important;font-weight:400!important;width:100%!important;transition:color .15s,padding-left .15s;letter-spacing:.005em;}
.nav-dropdown-item + .nav-dropdown-item{border-top:1px solid var(--rule);}
.nav-dropdown-item:hover{color:var(--amber)!important;padding-left:6px!important;}

/* ── CATEGORY PAGE HEADER ── */
.cat-page-hero{background:var(--dark);padding:72px 80px 48px;position:relative;overflow:hidden;}
.cat-page-hero::before{content:'';position:absolute;inset:0;background-image:url('assets/hero-section.jpg');background-size:cover;background-position:center 35%;opacity:.10;}
/* Uncapped (was max-width:1200 + margin auto) so the hero content aligns with
   the full-width filter bar + results below it. The cap left the hero ~40px more
   inset than its own body on wide screens ("gutter seems rather wide"). */
.cat-page-hero-inner{position:relative;z-index:1;}
.cat-page-hero-tag{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.cat-page-breadcrumb{font-size:12px;color:rgba(247,245,240,.4);font-weight:300;margin-bottom:24px;display:flex;gap:8px;align-items:center;}
.cat-page-breadcrumb a{color:rgba(247,245,240,.4);cursor:pointer;text-decoration:none;}
.cat-page-breadcrumb a:hover{color:rgba(247,245,240,.75);}
.cat-page-hero-title{font-family:var(--serif);font-size:clamp(44px,5vw,72px);font-weight:400;color:#F7F5F0;line-height:1.06;letter-spacing:-.025em;margin-bottom:24px;max-width:760px;}
.cat-page-hero-desc{font-family:var(--serif);font-size:19px;color:rgba(247,245,240,.7);line-height:1.65;font-style:italic;max-width:680px;margin-bottom:32px;}
.cat-page-hero-stats{display:flex;gap:48px;padding-top:28px;border-top:1px solid rgba(247,245,240,.12);flex-wrap:wrap;}
.cat-page-hero-stat{display:flex;flex-direction:column;gap:4px;}
.cat-page-hero-stat-num{font-family:var(--serif);font-size:36px;color:var(--amber);font-weight:400;line-height:1;letter-spacing:-.02em;}
.cat-page-hero-stat-label{font-size:11px;color:rgba(247,245,240,.5);font-weight:300;letter-spacing:.04em;}
/* Track the filter bar's horizontal gutter steps (80→48→28→20) so the hero
   content edge stays aligned with the tabs/results at every breakpoint. */
@media (max-width:1100px){.cat-page-hero{padding:64px 48px 44px;}}
@media (max-width:820px){.cat-page-hero{padding:56px 28px 40px;}}
@media (max-width:560px){.cat-page-hero{padding:40px 20px 32px;}}

/* ── PERSON PAGE ── */
.person-hero{background:var(--dark);padding:80px 80px 56px;position:relative;overflow:hidden;}
.person-hero::before{content:'';position:absolute;inset:0;background-image:url('assets/hero-section.jpg');background-size:cover;background-position:center 30%;opacity:.08;}
.person-hero-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:end;}
.person-breadcrumb{font-size:12px;color:rgba(247,245,240,.4);font-weight:300;margin-bottom:24px;display:flex;gap:8px;align-items:center;grid-column:1 / -1;}
.person-breadcrumb a{color:rgba(247,245,240,.4);cursor:pointer;text-decoration:none;}
.person-breadcrumb a:hover{color:rgba(247,245,240,.75);}
.person-portrait{width:240px;height:240px;border-radius:50%;background:linear-gradient(135deg,#33433D 0%,#1C2820 100%);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:88px;color:var(--amber);border:1px solid rgba(247,245,240,.15);font-weight:400;letter-spacing:-.02em;}
.person-portrait.org-mark{border-radius:6px;font-size:76px;letter-spacing:-.04em;}
.person-portrait.org-mark::after{content:'';position:absolute;inset:0;border:1px solid rgba(247,245,240,.05);border-radius:6px;pointer-events:none;}
.person-portrait.org-mark{position:relative;}
.person-portrait img{width:100%;height:100%;border-radius:50%;object-fit:cover;}
.person-hero-text{padding-bottom:8px;}
.person-eyebrow{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;display:block;}
.person-name{font-family:var(--serif);font-size:clamp(40px,4.5vw,64px);font-weight:400;color:#F7F5F0;line-height:1.04;letter-spacing:-.025em;margin-bottom:14px;}
.person-role{font-family:var(--serif);font-size:20px;color:rgba(247,245,240,.7);font-style:italic;line-height:1.4;}
.person-meta-bar{display:flex;gap:48px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(247,245,240,.14);flex-wrap:wrap;grid-column:1 / -1;}
.person-meta-item{display:flex;flex-direction:column;gap:4px;}
.person-meta-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,245,240,.4);}
.person-meta-value{font-size:14px;color:rgba(247,245,240,.88);font-weight:300;}
/* Person voice (TTS variant — bigger card with waveform) */
.person-voice-card{background:#fff;border:1px solid var(--rule);margin:36px 80px 0;padding:22px 28px;display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;}
[data-theme="dark"] .person-voice-card{background:var(--bg-warm);border-color:var(--rule);}
.person-voice-left{display:flex;align-items:center;gap:18px;}
.person-voice-play{width:54px;height:54px;border-radius:50%;background:var(--amber);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,transform .15s;}
.person-voice-play:hover{background:var(--amber-light);transform:scale(1.04);}
.person-voice-meta{display:flex;flex-direction:column;gap:3px;}
.person-voice-eyebrow{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);}
.person-voice-narrator{font-family:var(--serif);font-size:15px;color:var(--text);font-style:italic;}
.person-waveform{display:flex;gap:2px;align-items:center;height:46px;flex:1;cursor:pointer;}
.person-waveform-bar{flex:1;max-width:5px;background:var(--rule);transition:background .15s,height .2s;border-radius:1px;}
.person-waveform-bar.active{background:var(--amber);}
.person-waveform-bar.played{background:rgba(196,146,42,.35);}
.person-voice-right{display:flex;align-items:center;gap:14px;flex-shrink:0;}
.person-voice-time{font-size:12px;color:var(--text-light);font-weight:300;font-family:var(--sans);min-width:80px;text-align:right;}
.person-voice-select{font-size:11px;color:var(--text-mid);border:1px solid var(--rule);background:none;padding:5px 8px;cursor:pointer;font-family:var(--sans);}
[data-theme="dark"] .person-voice-select{background:var(--bg);color:var(--text);}
/* Person body */
.person-body{max-width:1200px;margin:0 auto;padding:48px 80px 64px;display:grid;grid-template-columns:260px 1fr;gap:72px;align-items:start;}
.person-bio{font-family:var(--serif);font-size:19px;color:var(--text);line-height:1.82;}
.person-bio p{margin-bottom:24px;}
.person-bio h2{font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-.02em;margin:40px 0 14px;color:var(--text);}
.person-bio blockquote{border-left:3px solid var(--amber);padding:6px 0 6px 24px;margin:32px 0;}
.person-bio blockquote p{font-size:21px;font-style:italic;color:var(--text-mid);margin-bottom:0;}
.person-side{position:sticky;top:120px;display:flex;flex-direction:column;gap:32px;}
.person-side-sec{}
.person-side-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--rule);display:block;}
.person-side-list{list-style:none;display:flex;flex-direction:column;gap:8px;}
.person-side-list li{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.5;}
.person-side-tags{display:flex;flex-wrap:wrap;gap:6px;}
.person-focus-tag{font-size:11px;letter-spacing:.04em;color:var(--text-mid);border:1px solid var(--rule);padding:4px 10px;font-family:var(--sans);}
.person-stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--rule);}
.person-stat-row:last-child{border-bottom:none;}
.person-stat-label{font-size:12px;color:var(--text-light);font-weight:300;}
.person-stat-value{font-family:var(--serif);font-size:18px;color:var(--text);font-weight:500;letter-spacing:-.01em;}
/* Person works section */
.person-works{background:var(--bg-section);padding:64px 80px;}
/* Org-anchored donate band wrapper — shares the unified person-* gutter scale
   so the donate card's edge aligns with every other section's content. */
.org-donate-band{max-width:1200px;margin:0 auto;padding:64px 80px;}
.person-works-inner{max-width:1200px;margin:0 auto;}
.person-works-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:32px;flex-wrap:wrap;gap:16px;}
.person-works-title{font-family:var(--serif);font-size:clamp(22px,4.5vw,32px);font-weight:400;color:var(--text);letter-spacing:-.02em;line-height:1.15;}
.person-works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.person-work-card{background:var(--bg);padding:24px 28px;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-height:160px;transition:background .15s;}
.person-work-card:hover{background:var(--bg-warm);}
.person-work-type{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);}
.person-work-title{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--text);line-height:1.3;}
.person-work-date{font-size:12px;color:var(--text-light);font-weight:300;margin-top:auto;}
/* Unified responsive gutters: 80px desktop -> 40px tablet (<=900) -> 20px phone (<=560),
   applied consistently to all full-bleed person-* sections (hero, body, voice, works). */
@media (max-width:900px){.person-hero{padding:56px 40px 40px;}.person-hero-inner{grid-template-columns:1fr;}.person-portrait{width:160px;height:160px;font-size:64px;}.person-body{grid-template-columns:1fr;padding:40px 40px;}.person-side{position:static;}.person-voice-card{margin:24px 40px 0;grid-template-columns:1fr;gap:16px;}.person-works{padding:48px 40px;}.person-works-grid{grid-template-columns:repeat(2,1fr);}.org-donate-band{padding:48px 40px;}}
@media (max-width:560px){.person-hero{padding:40px 20px 32px;}.person-body{padding:32px 20px;}.person-voice-card{margin:20px 20px 0;}.person-works{padding:40px 20px;}.person-works-grid{grid-template-columns:1fr;}.person-meta-bar{display:grid;grid-template-columns:1fr 1fr;gap:20px 24px;}.org-donate-band{padding:40px 20px;}}

/* ── EVENTS FILTERS ── */
.events-filters{padding:0 80px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.events-filter-tab{font-size:13px;font-weight:400;color:var(--text-mid);padding:14px 18px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:var(--sans);transition:color .15s;}
.events-filter-tab:first-child{padding-left:0;}
.events-filter-tab.active{color:var(--text);font-weight:500;border-bottom-color:var(--text);}
.events-filter-tab .count{font-size:11px;color:var(--text-light);font-weight:300;margin-left:4px;}
.events-filter-actions{margin-left:auto;display:flex;align-items:center;gap:10px;padding:8px 0;}
.events-empty{padding:80px 0;text-align:center;font-family:var(--serif);font-size:18px;color:var(--text-light);font-style:italic;}
.event-item.past{opacity:.7;}
.event-item.past .event-type-tag{color:var(--text-light);}
.event-past-badge{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light);border:1px solid var(--rule);padding:2px 8px;margin-left:10px;}

/* ── INDEX PAGES (Categories / Orgs / Contributors) ── */
.idx-header{padding:64px 80px 32px;border-bottom:1px solid var(--rule);}
.idx-eyebrow{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.idx-title{font-family:var(--serif);font-size:clamp(44px,5vw,64px);font-weight:400;color:var(--text);line-height:1.06;letter-spacing:-.025em;margin-bottom:18px;max-width:780px;}
.idx-desc{font-family:var(--serif);font-size:18px;color:var(--text-mid);line-height:1.6;font-style:italic;max-width:620px;margin-bottom:36px;}
.idx-search{display:flex;border-bottom:2px solid var(--text);padding:0 0 6px;align-items:center;gap:12px;max-width:560px;}
.idx-search svg{flex-shrink:0;color:var(--text-light);}
.idx-search input{background:none;border:none;outline:none;font-family:var(--serif);font-size:24px;color:var(--text);flex:1;letter-spacing:-.01em;padding:6px 0;}
.idx-search input::placeholder{color:var(--text-light);font-style:italic;}
.idx-search-clear{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:18px;padding:4px 8px;}
.idx-search-clear:hover{color:var(--text);}
.idx-count{font-size:12px;color:var(--text-light);font-weight:300;margin-top:14px;}
.idx-controls{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:16px;flex-wrap:wrap;}
.idx-sort{display:inline-flex;border:1px solid var(--rule);background:var(--bg);}
.idx-sort-btn{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.06em;color:var(--text-mid);background:none;border:none;cursor:pointer;padding:7px 14px;display:flex;align-items:center;gap:6px;transition:background .15s,color .15s;}
.idx-sort-btn + .idx-sort-btn{border-left:1px solid var(--rule);}
.idx-sort-btn:hover{color:var(--text);}
.idx-sort-btn.active{background:var(--dark);color:#F7F5F0;}
[data-theme="dark"] .idx-sort-btn.active{background:var(--amber);color:var(--dark);}
/* Card grid container — bind the grid to the same 80px gutter as .idx-header
   (this base rule was missing, so the grid bled edge-to-edge at >900px). */
.idx-body{padding:40px 80px 64px;}
.idx-empty{padding:80px 0;text-align:center;font-family:var(--serif);font-size:18px;color:var(--text-light);font-style:italic;}

.page-title-split{padding:64px 80px 40px;border-bottom:1px solid var(--rule);}
.page-title-split-inner{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-bottom:8px;}
.page-title-split-main{min-width:0;}
.page-title-split-label{margin-bottom:12px;}
.page-title-split-title{font-family:var(--serif);font-size:clamp(48px,5vw,72px);font-weight:400;color:var(--text);letter-spacing:-.03em;line-height:1;overflow-wrap:anywhere;}
.page-title-split-lead{font-family:var(--serif);font-size:16px;color:var(--text-mid);font-style:italic;max-width:320px;text-align:right;line-height:1.5;}
@media (max-width:900px){
  .page-title-split{padding:50px 36px 34px;}
  .page-title-split-inner{align-items:flex-start;flex-direction:column;gap:18px;}
  .page-title-split-title{font-size:clamp(44px,8vw,60px);}
  .page-title-split-lead{max-width:620px;text-align:left;}
}
@media (max-width:620px){
  .page-title-split{padding:38px 24px 28px;}
  .page-title-split-title{font-size:clamp(38px,13vw,52px);}
}

.cat-idx-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.cat-idx-card{background:var(--bg-warm);padding:32px 28px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:200px;transition:background .2s;}
.cat-idx-card:nth-child(2n){background:var(--bg-section);}
.cat-idx-card:hover{background:var(--rule)!important;}
.cat-idx-card-num{font-family:var(--serif);font-size:11px;color:var(--text-light);margin-bottom:12px;}
.cat-idx-card-name{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--text);line-height:1.2;margin-bottom:10px;letter-spacing:-.01em;}
.cat-idx-card-desc{font-size:13px;color:var(--text-mid);line-height:1.55;font-weight:300;}
.cat-idx-card-count{font-size:11px;color:var(--amber);font-weight:500;margin-top:14px;letter-spacing:.04em;}
@media (max-width:1100px){.cat-idx-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:900px){
  .idx-header{padding:48px 36px 30px;}
  .idx-title{font-size:clamp(40px,8vw,56px);}
  .idx-desc{margin-bottom:30px;}
  .idx-body{padding:40px 36px 64px;}
  .cat-idx-card{min-height:180px;padding:28px 24px;}
}
@media (max-width:620px){
  .idx-header{padding:36px 24px 26px;}
  .idx-title{font-size:clamp(36px,12vw,48px);margin-bottom:14px;}
  .idx-desc{font-size:17px;margin-bottom:26px;}
  .idx-search{max-width:none;}
  .idx-search input{font-size:22px;min-width:0;}
  .idx-controls{align-items:flex-start;flex-direction:column;gap:14px;}
  .idx-count{margin-top:8px;}
  .idx-sort{width:100%;}
  .idx-sort-btn{flex:1;justify-content:center;padding:9px 10px;}
  .idx-body{padding:32px 24px 56px;}
  .cat-idx-grid{grid-template-columns:1fr;}
  .cat-idx-card{min-height:0;padding:26px 22px;}
  .cat-idx-card-name{font-size:21px;}
}

.org-idx-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;}
.org-idx-card{background:var(--bg-warm);padding:32px;cursor:pointer;display:flex;flex-direction:column;gap:10px;transition:background .2s;}
.org-idx-card:nth-child(2n){background:var(--bg-section);}
.org-idx-card:hover{background:var(--rule)!important;}
.org-idx-type{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);}
.org-idx-name{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--text);letter-spacing:-.01em;line-height:1.2;}
.org-idx-meta-row{display:flex;gap:18px;font-size:12px;color:var(--text-light);font-weight:300;flex-wrap:wrap;}
.org-idx-meta-row span + span::before{content:'·';margin-right:18px;opacity:.4;}
.org-idx-blurb{font-size:14px;color:var(--text-mid);line-height:1.6;font-weight:300;margin-top:6px;}
.org-idx-foot{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;padding-top:14px;border-top:1px solid var(--rule);}
.org-idx-count{font-size:13px;color:var(--text);font-family:var(--serif);}
.org-idx-arrow{font-size:13px;color:var(--amber);font-weight:500;}
@media (max-width:780px){.org-idx-grid{grid-template-columns:1fr;}}

.ppl-idx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.ppl-idx-card{background:var(--bg-warm);padding:24px 22px;cursor:pointer;display:flex;gap:18px;align-items:flex-start;transition:background .2s;}
.ppl-idx-card:nth-child(2n){background:var(--bg-section);}
.ppl-idx-card:hover{background:var(--rule)!important;}
.ppl-idx-avatar{width:60px;height:60px;border-radius:50%;background:var(--dark);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;color:rgba(247,245,240,.65);flex-shrink:0;}
.ppl-idx-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;}
.ppl-idx-name{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--text);line-height:1.2;letter-spacing:-.01em;}
.ppl-idx-role{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);}
.ppl-idx-org{font-size:12px;color:var(--text-light);font-weight:300;}
.ppl-idx-bio{font-size:13px;color:var(--text-mid);line-height:1.55;font-weight:300;margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
@media (max-width:1100px){.ppl-idx-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.ppl-idx-grid{grid-template-columns:1fr;}}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;}

/* ── NAV ── */
header[data-kms-chrome="header"]{position:sticky;top:0;z-index:200;}
.kc-nav{position:relative;background:var(--bg);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 48px;height:58px;}
.kc-nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer;min-width:0;}
.kc-nav-logo-mark{width:32px;height:32px;background:var(--dark);border-radius:4px;display:flex;align-items:center;justify-content:center;}
.kc-nav-logo-mark span{color:var(--amber);font-family:var(--serif);font-weight:600;font-size:14px;}
.kc-nav-logo-text{font-size:13px;font-weight:500;color:var(--text);line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;}
.kc-nav-logo-sub{font-size:10px;color:var(--text-light);font-weight:300;display:block;}
.kc-nav-links{display:flex;align-items:center;gap:28px;list-style:none;flex-shrink:0;}
.kc-nav-links a,.kc-nav-links button{font-family:var(--sans);font-size:13px;font-weight:400;color:var(--text-mid);text-decoration:none;background:none;border:none;cursor:pointer;transition:color .15s;padding:0;}
.kc-nav-links a:hover,.kc-nav-links button:hover{color:var(--text);}
.kc-nav-links .search-btn{display:flex;align-items:center;gap:6px;color:var(--text);font-weight:500;}
.lang-btn{font-size:13px!important;color:var(--text-light)!important;border:1px solid var(--rule)!important;padding:6px 12px!important;border-radius:2px;display:flex!important;align-items:center;gap:8px;line-height:1;}
.lang-btn:hover{color:var(--text)!important;border-color:var(--text-mid)!important;}
.lang-btn .lang-flag{width:20px;height:15px;object-fit:cover;border-radius:2px;flex-shrink:0;display:block;}
.lang-btn .lang-code{letter-spacing:.04em;font-weight:500;}
.lang-btn .caret{font-size:11px;opacity:.7;line-height:1;transition:transform .2s ease;}
.lang-btn[aria-expanded="true"] .caret{transform:rotate(180deg);opacity:1;}
.lang-wrap{position:relative;}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--bg);border:1px solid var(--rule);box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:150;padding:6px 0;animation:fadeIn .15s ease;}
[data-theme="dark"] .lang-menu{background:var(--bg-section);box-shadow:0 8px 32px rgba(0,0,0,.45);}
.lang-menu-item{display:flex!important;align-items:center;justify-content:space-between;padding:9px 16px!important;cursor:pointer;font-family:var(--sans);font-size:13px;color:var(--text-mid)!important;background:none;border:none;width:100%;text-align:left;transition:background .15s,color .15s;}
.lang-menu-label{display:flex;align-items:center;gap:9px;}
.lang-menu-item .lang-flag{width:20px;height:15px;object-fit:cover;border-radius:2px;flex-shrink:0;display:block;}
.lang-menu-item:hover{background:var(--bg-warm);color:var(--text)!important;}
.lang-menu-item.active{color:var(--amber)!important;}
.lang-menu-item .lang-code{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light);font-weight:500;}
.lang-menu-item.active .lang-code{color:var(--amber);}
.theme-toggle{background:none!important;border:1px solid var(--rule)!important;width:30px;height:30px;border-radius:2px;cursor:pointer;display:flex!important;align-items:center;justify-content:center;color:var(--text-mid)!important;transition:color .15s,border-color .15s,transform .25s;padding:0!important;}
.theme-toggle:hover{color:var(--text)!important;border-color:var(--text-mid)!important;}
.theme-toggle svg{transition:transform .3s ease;}
.theme-toggle:hover svg{transform:rotate(15deg);}
/* Icon reflects the action: moon in light mode (→ go dark), sun in dark mode
   (→ go light). Swapped purely by CSS off the documentElement data-theme, so it
   is correct on first paint and on every toggle without JS. */
.theme-toggle .theme-icon-sun{display:none;}
[data-theme="dark"] .theme-toggle .theme-icon-moon{display:none;}
[data-theme="dark"] .theme-toggle .theme-icon-sun{display:block;}
.nav-active{color:var(--amber)!important;}
.kc-mobile-toggle{display:none;background:none;border:1px solid var(--rule);width:38px;height:34px;border-radius:2px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px;padding:0;flex-shrink:0;}
.kc-mobile-toggle span{width:16px;height:1px;background:var(--text);display:block;transition:transform .2s ease,opacity .15s ease;}
.kc-mobile-toggle[aria-expanded="true"] span:first-child{transform:translateY(5px) rotate(45deg);}
.kc-mobile-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.kc-mobile-toggle[aria-expanded="true"] span:last-child{transform:translateY(-5px) rotate(-45deg);}
.kc-mobile-menu{position:fixed;top:58px;left:0;right:0;z-index:99;background:var(--bg);border-bottom:1px solid var(--rule);box-shadow:0 16px 38px rgba(0,0,0,.12);max-height:calc(100vh - 58px);overflow:auto;}
[data-theme="dark"] .kc-mobile-menu{background:var(--bg-section);box-shadow:0 16px 38px rgba(0,0,0,.42);}
.kc-mobile-menu-inner{display:grid;gap:26px;padding:22px 24px 28px;}
.kc-mobile-search{display:flex;align-items:center;gap:10px;width:100%;border:1px solid var(--rule);background:var(--bg-warm);color:var(--text);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;padding:12px 14px;text-align:left;cursor:pointer;}
.kc-mobile-group{display:flex;flex-direction:column;gap:2px;}
.kc-mobile-label{font-size:10px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--amber);margin-bottom:8px;}
.kc-mobile-group a{display:block;padding:11px 0;border-bottom:1px solid var(--rule);font-size:16px;font-family:var(--serif);color:var(--text);text-decoration:none;line-height:1.25;}
.kc-mobile-group a:hover{color:var(--amber);}
.kc-mobile-controls{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-top:4px;}
.kc-mobile-controls .lang-wrap{margin-left:auto;}
.kc-mobile-controls .lang-menu{right:0;bottom:calc(100% + 8px);top:auto;}
body.kc-mobile-nav-open{overflow:hidden;}
@media (max-width:1080px){.kc-nav{padding:0 32px;}.kc-nav-links{gap:18px;}.nav-dropdown{min-width:460px;}}
@media (max-width:900px){
  .kc-nav{padding:0 24px;height:58px;}
  .kc-nav-logo{min-width:0;}
  .kc-nav-logo-mark{width:30px;height:30px;}
  .kc-nav-logo-text{max-width:calc(100vw - 118px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .kc-nav-logo-sub{overflow:hidden;text-overflow:ellipsis;}
  .kc-nav-links{display:none;}
  .kc-mobile-toggle{display:flex;}
}
@media (max-width:420px){
  .kc-nav{padding:0 16px;}
  .kc-mobile-menu-inner{padding:20px 16px 26px;}
  .kc-nav-logo-text{font-size:12px;max-width:calc(100vw - 104px);}
}

/* ── SEARCH OVERLAY ── */
.search-overlay{position:fixed;inset:0;z-index:300;display:flex;flex-direction:column;align-items:stretch;}
.search-overlay[hidden]{display:none;}
.search-overlay-backdrop{position:absolute;inset:0;background:rgba(28,40,32,0.45);backdrop-filter:blur(6px);}
.search-overlay-inner{position:relative;z-index:1;width:100%;max-height:60vh;overflow-y:auto;background:var(--bg);box-shadow:0 8px 40px rgba(0,0,0,.18);}
.search-overlay-top{border-bottom:1px solid var(--rule);padding:0 48px;display:flex;align-items:center;gap:16px;height:72px;}
.search-overlay-input{flex:1;background:none;border:none;outline:none;font-family:var(--serif);font-size:22px;color:var(--text);}
.search-overlay-input::placeholder{color:var(--text-light);}
.search-overlay-close{background:none;border:none;cursor:pointer;color:var(--text-light);font-size:22px;padding:8px;transition:color .15s;}
.search-overlay-close:hover{color:var(--text);}
.search-overlay-body{padding:40px 48px;display:grid;grid-template-columns:220px 1fr 240px;gap:64px;}
.so-section-label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:20px;}
.so-cat-list{list-style:none;}
.so-cat-item{font-family:var(--serif);font-size:22px;color:var(--text);padding:4px 0;cursor:pointer;transition:color .15s;display:block;}
.so-cat-item:hover{color:var(--amber);}
.so-topics{display:flex;flex-wrap:wrap;gap:8px;}
.so-topic{font-family:var(--sans);font-size:12px;color:var(--text-mid);padding:5px 12px;border:1px solid var(--rule);cursor:pointer;transition:border-color .15s,color .15s;background:none;}
.so-topic:hover{border-color:var(--text);color:var(--text);}
.so-recent-list{list-style:none;margin:0;padding:0;}
.so-recent-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--rule);cursor:pointer;color:var(--text-mid);font-size:13px;font-weight:300;transition:color .15s;}
.so-recent-item a{display:flex;align-items:center;gap:10px;color:inherit;text-decoration:none;width:100%;}
.so-recent-item:hover{color:var(--amber);}
.so-recent-item svg{flex-shrink:0;opacity:.4;}
.so-recent-empty{font-family:var(--sans);font-size:12px;color:var(--text-light);font-style:italic;padding:8px 0;}
.so-cat-list{margin:0;padding:0;}
.so-cat-item{text-decoration:none;}
.so-topic{text-decoration:none;display:inline-block;}
body.kc-search-open{overflow:hidden;}

/* ── REFINE ── */
.refine-flyout{position:fixed;top:0;right:0;bottom:0;width:360px;background:var(--bg);z-index:200;box-shadow:-4px 0 32px rgba(0,0,0,.08);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);}
.refine-flyout[hidden]{display:none;}
.refine-flyout.open{transform:translateX(0);}
.refine-flyout-form{display:flex;flex-direction:column;flex:1;min-height:0;}
.refine-flyout-backdrop{position:fixed;inset:0;background:rgba(28,40,32,0.35);backdrop-filter:blur(2px);z-index:190;}
.refine-flyout-backdrop[hidden]{display:none;}
body.kc-flyout-open{overflow:hidden;}
.refine-flyout-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--rule);}
.refine-flyout-title{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text);}
.refine-close{background:none;border:none;cursor:pointer;color:var(--text-light);font-size:20px;}
.refine-body{flex:1;overflow-y:auto;padding:0 28px;}
.refine-section{border-bottom:1px solid var(--rule);padding:20px 0;}
.refine-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:none;border:none;padding:0;font-family:var(--sans);text-align:left;color:inherit;}
.refine-section-header.open{margin-bottom:16px;}
.refine-radio-item{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer;}
.refine-radio-item input{cursor:pointer;accent-color:var(--dark);width:14px;height:14px;}
.refine-radio-label{font-size:14px;color:var(--text-mid);font-weight:300;}
.refine-empty{font-size:13px;color:var(--text-light);font-style:italic;padding:8px 0;margin:0;}
.sr-org-count{color:var(--text-light);font-size:12px;}
.refine-section-label{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text);}
.refine-caret{font-size:12px;color:var(--text-light);transition:transform .2s;}
.refine-caret.open{transform:rotate(180deg);}
.refine-check-item{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer;}
.refine-check-item input{cursor:pointer;accent-color:var(--dark);width:14px;height:14px;}
.refine-check-label{font-size:14px;color:var(--text-mid);font-weight:300;}
.refine-footer{padding:20px 28px;border-top:1px solid var(--rule);}
.refine-done-btn{width:100%;background:var(--dark);color:#F7F5F0;border:none;padding:14px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.08em;cursor:pointer;}
.refine-done-btn:hover{background:var(--dark-mid);}
@media (max-width:900px){
  .search-overlay-inner{max-height:82vh;}
  .search-overlay-top{padding:0 28px;height:64px;}
  .search-overlay-input{font-size:20px;min-width:0;}
  .search-overlay-body{padding:28px;grid-template-columns:1fr 1fr;gap:32px;}
  .search-overlay-body > *:last-child{grid-column:1 / -1;}
}
@media (max-width:560px){
  .search-overlay-inner{max-height:100vh;}
  .search-overlay-top{padding:0 20px;height:60px;gap:10px;}
  .search-overlay-input{font-size:18px;}
  .search-overlay-body{padding:24px 20px 30px;grid-template-columns:1fr;gap:26px;}
  .so-cat-item{font-size:20px;}
  .refine-flyout{width:100%;max-width:none;}
  .refine-flyout-header{padding:20px;}
  .refine-body{padding:0 20px;}
  .refine-footer{padding:18px 20px;}
}

/* ── HERO ── */
/* Hero pulled up under the sticky 58px-tall .kc-nav so the background
   image bleeds behind the header instead of starting below it. The
   negative margin reclaims the header's flow space; the extra
   padding-top keeps the hero's text content visible below the header
   on first paint. Result: visible viewport (top:0 → 100dvh) is filled
   exactly by the hero, with the header overlaying its top 58px. */
.hp-hero{position:relative;margin-top:-58px;padding:calc(96px + 58px) 80px 88px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;overflow:hidden;min-height:100dvh;}
.hp-hero-bg{position:absolute;inset:0;background-image:url('assets/hero-section.jpg');background-size:cover;background-position:center 40%;}
.hp-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(24,34,28,.95) 0%,rgba(24,34,28,.88) 45%,rgba(18,27,22,.84) 100%);}
.hp-hero-left,.hp-hero-right{position:relative;z-index:1;}
.hp-hero-tag{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:28px;display:block;}
.hp-hero-title{font-family:var(--serif);font-size:clamp(52px,5vw,80px);font-weight:400;color:#F7F5F0;line-height:1.04;letter-spacing:-.02em;margin-bottom:28px;}
.hp-hero-title em{color:var(--amber);font-style:italic;}
.hp-hero-desc{font-size:15px;font-weight:300;color:rgba(247,245,240,.82);line-height:1.7;max-width:400px;margin-bottom:40px;}
.hp-hero-actions{display:flex;gap:16px;align-items:center;}
/* Note: .btn-primary + .btn-secondary collide with platform Tailwind
   defaults (`/static/dist/css/main.css` declares both with
   `border-radius:.5rem; padding:.5rem 1rem; transition-property:…`).
   KC main.css loads later so KC's properties win, but Tailwind's
   `border-radius` survives because KC doesn't unset it — that's why
   the prototype's sharp-cornered buttons render with rounded corners
   on the live site. Explicit `border-radius:0` brings the KC button
   back to the prototype's square look. */
.btn-primary{background:var(--amber);color:var(--dark);font-family:var(--sans);font-size:13px;font-weight:500;padding:12px 24px;border:none;border-radius:0;cursor:pointer;transition:background .2s;}
.btn-secondary{background:transparent;color:var(--text);font-family:var(--sans);font-size:13px;font-weight:500;padding:12px 24px;border:1px solid var(--text);border-radius:0;cursor:pointer;transition:background .2s,color .2s;}
.btn-secondary:hover{background:var(--text);color:var(--bg);}
.btn-primary:hover{background:var(--amber-light);}
.btn-ghost{color:rgba(247,245,240,.7);font-family:var(--sans);font-size:13px;background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .2s;}
.btn-ghost:hover{color:#F7F5F0;}
.hp-search-label{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,245,240,.6);margin-bottom:16px;display:block;}
/* `.hp-search-box` is a <button> (drives the search overlay); the prototype
   used a <div>. Buttons shrink to content, so without width:100% the rail
   renders narrower than its grid column. text-align:left + font:inherit reset
   the UA button defaults so children lay out exactly like the prototype div. */
.hp-search-box{display:flex;width:100%;text-align:left;font:inherit;border-bottom:1px solid rgba(247,245,240,.4);padding-bottom:2px;align-items:center;gap:12px;cursor:pointer;transition:border-color .2s;}
.hp-search-box:hover{border-color:rgba(247,245,240,.65);}
.hp-search-box-inner{flex:1;font-family:var(--serif);font-size:22px;color:rgba(247,245,240,.62);padding:10px 0;font-style:italic;}
.hp-search-btn{background:none;border:none;color:var(--amber);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;padding:10px 0;}
.hp-search-hint{margin-top:16px;font-size:12px;color:rgba(247,245,240,.55);font-weight:300;}
.hp-search-hint span{color:rgba(247,245,240,.72);margin:0 6px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;}
.hp-cats{padding:0 80px;border-bottom:1px solid var(--rule);display:flex;overflow-x:auto;}
.hp-cat-item{font-size:12px;color:var(--text-mid);padding:16px 20px;white-space:nowrap;cursor:pointer;border-right:1px solid var(--rule);transition:color .15s;}
.hp-cat-item:first-child{padding-left:0;}
.hp-cat-item:hover{color:var(--text);}
.hp-cat-item.active{color:var(--amber);font-weight:500;}
.hp-cats-all{font-size:12px;color:var(--amber);padding:16px 0 16px 20px;margin-left:auto;cursor:pointer;white-space:nowrap;background:none;border:none;}
.hp-content{padding:72px 80px;}
.section-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:32px;display:flex;align-items:center;gap:16px;}
.section-label::after{content:'';flex:1;height:1px;background:var(--rule);}
.hp-lead{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:64px;padding-bottom:64px;border-bottom:1px solid var(--rule);cursor:pointer;}
.hp-lead:hover .hp-lead-title{color:var(--amber);}
.hp-lead-img{aspect-ratio:4/3;overflow:hidden;}
.hp-lead-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:filter .4s;}
.hp-lead:hover .hp-lead-img img{filter:grayscale(40%);}
.hp-lead-meta{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:16px;display:block;}
.hp-lead-title{font-family:var(--serif);font-size:clamp(32px,3vw,46px);font-weight:400;color:var(--text);line-height:1.12;letter-spacing:-.02em;margin-bottom:20px;transition:color .2s;}
.hp-lead-excerpt{font-size:15px;color:var(--text-mid);line-height:1.7;margin-bottom:24px;font-weight:300;}
.hp-lead-byline{font-size:12px;color:var(--text-light);font-weight:300;}
.hp-lead-byline strong{font-weight:500;color:var(--text-mid);}
.hp-list{display:grid;grid-template-columns:1fr 1fr 1fr;margin-bottom:64px;}
.hp-list-item{padding:28px 32px 28px 0;border-right:1px solid var(--rule);cursor:pointer;}
.hp-list-item:last-child{border-right:none;padding-right:0;}
.hp-list-item:not(:first-child){padding-left:32px;}
.hp-list-item:hover .hp-list-title{color:var(--amber);}
.hp-list-type{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:10px;display:block;}
.hp-list-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--text);line-height:1.2;margin-bottom:10px;transition:color .2s;letter-spacing:-.01em;}
.hp-list-meta{font-size:11px;color:var(--text-light);font-weight:300;}
.hp-strip{background:var(--dark);margin:0 -80px 64px;padding:56px 80px;display:grid;grid-template-columns:320px 1fr;gap:64px;align-items:center;}
.hp-strip-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:12px;display:block;}
.hp-strip-heading{font-family:var(--serif);font-size:32px;font-weight:400;color:#F7F5F0;line-height:1.2;letter-spacing:-.02em;}
.hp-strip-items{display:flex;flex-direction:column;}
.hp-strip-item{display:flex;gap:24px;padding:18px 0;border-bottom:1px solid rgba(247,245,240,.1);cursor:pointer;}
.hp-strip-item:first-child{border-top:1px solid rgba(247,245,240,.1);}
.hp-strip-item:hover .hp-strip-item-title{color:var(--amber);}
.hp-strip-item-num{font-family:var(--serif);font-size:13px;color:rgba(247,245,240,.25);flex-shrink:0;min-width:24px;padding-top:2px;}
.hp-strip-item-title{font-family:var(--serif);font-size:18px;color:rgba(247,245,240,.85);line-height:1.3;margin-bottom:4px;transition:color .2s;}
.hp-strip-item-meta{font-size:11px;color:rgba(247,245,240,.4);font-weight:300;}

/* ── SEARCH RESULTS ── */
.sr-header{padding:56px 80px 36px;border-bottom:1px solid var(--rule);}
.sr-title{font-family:var(--serif);font-size:13px;color:var(--text-light);font-style:italic;margin-bottom:12px;}
.sr-search-inline{display:flex;border-bottom:2px solid var(--text);padding-bottom:6px;gap:16px;align-items:center;margin-bottom:16px;max-width:1100px;}
.sr-search-inline input{background:none;border:none;font-family:var(--serif);font-size:clamp(28px,4vw,38px);color:var(--text);outline:none;flex:1;min-width:0;width:100%;padding:0;letter-spacing:-.02em;}
.sr-search-inline button{background:none;border:none;cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);font-family:var(--sans);white-space:nowrap;}
.sr-count{font-size:13px;color:var(--text-light);font-weight:300;}
.sr-filters{padding:0 80px;display:flex;align-items:center;border-bottom:1px solid var(--rule);gap:4px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:thin;}
.sr-filter-tabs{display:flex;align-items:center;gap:4px;flex:0 1 auto;}
.sr-filter-tab{font-size:13px;font-weight:400;color:var(--text-mid);padding:14px 18px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s;font-family:var(--sans);white-space:nowrap;flex:0 0 auto;}
.sr-filter-tab:first-child{padding-left:0;}
.sr-filter-tab.active{color:var(--text);font-weight:500;border-bottom-color:var(--text);}
.sr-filter-actions{margin-left:auto;display:flex;align-items:center;gap:10px;flex:0 0 auto;}
.sr-filter-count{font-size:12px;color:var(--text-light);font-weight:300;margin-right:8px;white-space:nowrap;}
.sr-refine-btn{font-size:12px;color:var(--text-mid);background:none;border:1px solid var(--rule);cursor:pointer;display:flex;align-items:center;gap:6px;font-family:var(--sans);height:32px;padding:0 14px;transition:border-color .15s,color .15s,background .15s;}
.sr-refine-btn:hover{border-color:var(--text);color:var(--text);}
.sr-refine-btn.active{background:var(--dark);color:#F7F5F0;border-color:var(--dark);}
.sr-refine-btn .sr-refine-count{background:var(--amber);color:var(--dark);font-weight:600;font-size:10px;padding:1px 6px;border-radius:10px;}
.sr-viewtoggle{display:inline-flex;border:1px solid var(--rule);height:32px;}
.sr-viewtoggle button{background:none;border:none;padding:0 10px;cursor:pointer;color:var(--text-light);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;}
.sr-viewtoggle button + button{border-left:1px solid var(--rule);}
.sr-viewtoggle button:hover{color:var(--text);}
.sr-viewtoggle button.active{background:var(--dark);color:#F7F5F0;}
.sr-body{padding:56px 80px 0;}
/* List view */
.sr-result{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,340px);gap:48px;padding:44px 0;border-bottom:1px solid var(--rule);cursor:pointer;align-items:start;}
.sr-result:first-child{padding-top:0;}
.sr-result:hover .sr-result-title{color:var(--amber);}
.sr-result-type{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:12px;display:block;}
.sr-result-title{font-family:var(--serif);font-size:clamp(26px,3vw,34px);font-weight:400;color:var(--text);line-height:1.15;margin-bottom:14px;letter-spacing:-.01em;transition:color .2s;overflow-wrap:anywhere;}
.sr-result-excerpt{font-size:16px;color:var(--text-mid);line-height:1.65;margin-bottom:16px;font-weight:300;}
.sr-result-meta{font-size:12px;color:var(--text-light);font-weight:300;display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.sr-result-dot{opacity:.4;}
.sr-result-tag{font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light);text-decoration:none;}
.sr-result-tag:hover{color:var(--amber);}
.sr-result-thumb{aspect-ratio:4/3;overflow:hidden;background:var(--bg-warm);}
.sr-result-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(25%);transition:filter .3s,transform .6s;}
.sr-result:hover .sr-result-thumb img{filter:grayscale(0%);transform:scale(1.03);}
.sr-thumb-placeholder{width:100%;height:100%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;font-size:10px;color:rgba(0,0,0,.2);font-style:italic;}
/* Grid view */
.sr-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:40px 32px;padding-bottom:80px;}
.sr-grid-card{cursor:pointer;display:flex;flex-direction:column;}
.sr-grid-card:hover .sr-result-title{color:var(--amber);}
.sr-grid-thumb{aspect-ratio:4/3;overflow:hidden;background:var(--bg-warm);margin-bottom:20px;}
.sr-grid-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(25%);transition:filter .3s,transform .6s;}
.sr-grid-card:hover .sr-grid-thumb img{filter:grayscale(0%);transform:scale(1.03);}
.sr-grid-card .sr-result-title{font-size:24px;margin-bottom:10px;}
.sr-grid-card .sr-result-excerpt{font-size:14px;margin-bottom:12px;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;}
@media (max-width:1100px){
  .sr-header{padding:48px 48px 30px;}
  .sr-filters{padding:0 48px;}
  .sr-body{padding:46px 48px 0;}
  .sr-result{grid-template-columns:minmax(0,1fr) minmax(190px,280px);gap:34px;}
  .sr-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:820px){
  .sr-header{padding:38px 28px 26px;}
  .sr-search-inline{gap:12px;}
  .sr-filters{padding:0 28px;align-items:center;}
  .sr-filter-tab{font-size:12px;padding:13px 12px;}
  .sr-filter-count{display:none;}
  .sr-viewtoggle{display:none;}
  .sr-body{padding:36px 28px 0;}
  .sr-result{grid-template-columns:1fr;gap:18px;padding:34px 0;}
  .sr-result-thumb{order:-1;aspect-ratio:16/9;}
  .sr-result-excerpt{font-size:15px;}
}
@media (max-width:560px){
  .sr-header{padding:30px 20px 22px;}
  .sr-title{font-size:12px;margin-bottom:10px;}
  .sr-search-inline{display:grid;grid-template-columns:1fr;gap:10px;border-bottom:0;padding-bottom:0;}
  .sr-search-inline input{border-bottom:2px solid var(--text);padding-bottom:8px;font-size:30px;}
  .sr-search-inline button{justify-self:start;border:1px solid var(--rule);padding:9px 14px;}
  .sr-count{font-size:12px;line-height:1.45;}
  .sr-filters{padding:0 20px;align-items:stretch;flex-wrap:wrap;overflow-x:hidden;}
  .sr-filter-tabs{order:1;display:flex;flex-wrap:wrap;gap:0;flex:1 0 100%;}
  .sr-filter-tab{order:1;font-size:11px;padding:12px 8px;letter-spacing:.01em;}
  .sr-filter-actions{order:2;flex:1 0 100%;margin-left:0;padding:12px 0;border-top:1px solid var(--rule);}
  .sr-refine-btn{padding:8px 12px;}
  .sr-body{padding:30px 20px 0;}
  .sr-result{padding:30px 0;}
  .sr-result-title{font-size:26px;}
  .sr-result-meta{gap:6px;}
  .sr-grid{grid-template-columns:1fr;gap:34px;padding-bottom:58px;}
}

/* ── SHARED CONTENT PAGE ── */
.cp-breadcrumb{font-size:12px;color:var(--text-light);font-weight:300;display:flex;align-items:center;gap:8px;margin-bottom:32px;}
.cp-breadcrumb a{color:var(--text-light);text-decoration:none;cursor:pointer;transition:color .15s;}
.cp-breadcrumb a:hover{color:var(--amber);}
.cp-eyebrow{display:flex;align-items:baseline;flex-wrap:wrap;margin-bottom:18px;}
.cp-type-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);display:inline-flex;align-items:center;gap:8px;}
.cp-kicker{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mid);display:inline-block;}
.cp-eyebrow .cp-kicker::before{content:'·';margin:0 10px;color:var(--text-light);font-weight:400;}
.cp-title{font-family:var(--serif);font-size:clamp(36px,4vw,58px);font-weight:400;color:var(--text);line-height:1.08;letter-spacing:-.025em;margin-bottom:16px;}
.cp-subtitle{font-family:var(--serif);font-size:19px;font-style:italic;color:var(--text-mid);line-height:1.45;margin-bottom:24px;}
/* AI-Suggest summary lede (transcript-only pages). Sans body paragraph, distinct
   from the italic serif deck above it; constrained to a readable measure. */
.cp-lede{font-family:var(--sans);font-size:16px;color:var(--text-mid);line-height:1.6;max-width:660px;margin:-6px 0 24px;}
.cp-meta-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-light);font-weight:300;flex-wrap:wrap;margin-bottom:0;}
.cp-meta-row strong{font-weight:500;color:var(--text-mid);}
.cp-meta-dot{opacity:.4;}
.share-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--rule);padding:5px 12px;cursor:pointer;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mid);transition:border-color .15s,color .15s;}
.share-trigger:hover{border-color:var(--text);color:var(--text);}
.share-popup{position:absolute;top:calc(100% + 6px);left:0;background:white;border:1px solid var(--rule);box-shadow:0 4px 20px rgba(0,0,0,.1);z-index:50;min-width:148px;}
.share-popup-btn{display:block;width:100%;text-align:left;padding:9px 16px;background:none;border:none;font-family:var(--sans);font-size:12px;color:var(--text-mid);cursor:pointer;transition:background .1s,color .1s;}
.share-popup-btn:hover{background:var(--bg-warm);color:var(--text);}
.share-wrap{position:relative;display:inline-flex;}
[data-theme="dark"] .share-popup{background:var(--bg-warm);border-color:var(--rule);}
.meta-label-sm{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:4px;}
.meta-value-sm{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.5;}

/* ── MORE FROM SECTION ── */
.more-from{background:var(--bg-section);padding:56px 48px;}
.more-from-inner{max-width:1200px;margin:0 auto;}
.more-from-title{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--text);margin-bottom:40px;letter-spacing:-.01em;}
.more-from-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.mf-card{cursor:pointer;}
.mf-card:hover .mf-card-title{color:var(--amber);}
.mf-card-img{aspect-ratio:16/9;overflow:hidden;margin-bottom:16px;background:var(--bg-warm);}
.mf-card-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);}
.mf-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;color:rgba(0,0,0,.2);font-style:italic;}
.mf-card-type{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.mf-card-title{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--text);line-height:1.25;margin-bottom:8px;transition:color .2s;}
.mf-card-excerpt{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* ── PUBLICATION TEMPLATE ── */
.pub-wrap{max-width:1200px;margin:0 auto;padding:48px;}
.pub-header{border-bottom:1px solid var(--rule);padding-bottom:32px;margin-bottom:48px;}
.pub-body{display:grid;grid-template-columns:280px 1fr;gap:64px;margin-bottom:80px;}
.pub-left{}
.pub-cover{width:100%;margin-bottom:0;overflow:hidden;}
.pub-cover img{width:100%;display:block;filter:grayscale(100%);}
.pub-download-btn{width:100%;background:var(--dark);color:#F7F5F0;border:none;padding:13px 0;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s;margin-bottom:28px;}
.pub-download-btn:hover{background:var(--dark-mid);}
.pub-meta-stack{display:flex;flex-direction:column;gap:20px;}
.pub-right{}
.pub-abstract-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:16px;}
.pub-abstract-body{font-family:var(--serif);font-size:18px;color:var(--text-mid);line-height:1.75;margin-bottom:40px;}
.pub-topics{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.pub-topic-tag{font-size:11px;color:var(--text-mid);padding:4px 10px;border:1px solid var(--rule);font-weight:300;cursor:pointer;text-decoration:none;display:inline-block;transition:border-color .15s,color .15s;}
.pub-topic-tag:hover{border-color:var(--amber);color:var(--amber);}
/* Publication detail responsive: the 280px·1fr body had no breakpoints, so the
   abstract column was crushed (~100px) and overflowed on tablet/phone. Collapse
   to a single column (cover/meta stack above the abstract) and step gutters. */
@media (max-width:900px){
  .pub-wrap{padding:40px;}
  .pub-body{grid-template-columns:minmax(0,720px);gap:32px;}
  .pub-left{max-width:340px;}
}
@media (max-width:560px){
  .pub-wrap{padding:32px 20px;}
}

/* ── ARTICLE TEMPLATE ── */
.art-wrap{max-width:1400px;margin:0 auto;}
.art-header-section{padding:48px 48px 40px;border-bottom:1px solid var(--rule);}
.art-hero-img{width:100%;aspect-ratio:21/7;overflow:hidden;background:var(--bg-warm);}
.art-hero-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(15%);}
.art-hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;color:rgba(0,0,0,.2);font-style:italic;background:repeating-linear-gradient(135deg,var(--bg-warm) 0px,var(--bg-warm) 12px,var(--bg-section) 12px,var(--bg-section) 14px);}
.tts-bar{background:white;border-bottom:1px solid var(--rule);padding:0 48px;display:flex;align-items:center;gap:20px;height:52px;position:sticky;top:58px;z-index:90;}
.tts-native{display:none;}
.tts-play-btn{width:30px;height:30px;background:var(--dark);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;}
.tts-play-btn:hover{background:var(--dark-mid);}
.tts-play-btn:disabled{opacity:.35;cursor:not-allowed;}
.tts-label{font-size:12px;font-weight:500;color:var(--text-mid);letter-spacing:.02em;}
.tts-bar-progress{flex:1;height:2px;background:var(--rule);position:relative;cursor:pointer;}
.tts-bar-fill{position:absolute;left:0;top:0;bottom:0;background:var(--dark);width:0;}
[data-theme="dark"] .tts-bar-fill{background:var(--amber);}
.tts-time{font-size:11px;color:var(--text-light);font-weight:300;white-space:nowrap;}
.tts-speed{font-size:11px;color:var(--text-mid);border:1px solid var(--rule);background:none;padding:3px 8px;cursor:pointer;font-family:var(--sans);}
/* Dark mode: the bar hardcodes a white background, which leaves light text
   invisible and the play chip dark-on-dark. Flip the surface + chip so the
   token-driven text/borders read correctly. */
[data-theme="dark"] .tts-bar{background:var(--bg-section);}
[data-theme="dark"] .tts-play-btn{background:var(--amber);}
[data-theme="dark"] .tts-play-btn svg{fill:var(--dark);}
.art-body-cols{display:grid;grid-template-columns:200px minmax(0,680px) 180px;gap:64px;padding:56px 48px 80px;justify-content:center;max-width:1400px;margin:0 auto;align-items:start;}
.prose{font-family:var(--serif);}
.prose p{font-size:19px;line-height:1.82;color:var(--text);margin-bottom:28px;}
/* `scroll-margin-top` keeps anchor jumps from landing behind the sticky
   header (58px) + sticky TTS bar (52px) when a TOC link is clicked. The
   value matches the sticky sidebar offset so the active heading aligns
   with the active TOC entry. */
.prose h1{font-family:var(--serif);font-size:34px;font-weight:400;color:var(--text);letter-spacing:-.02em;margin:56px 0 20px;line-height:1.12;scroll-margin-top:130px;}
.prose h2{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--text);letter-spacing:-.02em;margin:52px 0 18px;line-height:1.18;scroll-margin-top:130px;}
.prose h3{font-family:var(--serif);font-size:23px;font-weight:400;color:var(--text);letter-spacing:-.01em;margin:40px 0 14px;line-height:1.24;scroll-margin-top:130px;}
.prose .toc-link{display:none;}
.prose h1 .toc-link,.prose h2 .toc-link,.prose h3 .toc-link{display:none!important;}
.prose ul{margin-bottom:28px;padding-left:24px;}
.prose ul li{font-size:19px;line-height:1.72;color:var(--text);margin-bottom:8px;}
.prose blockquote{border-left:3px solid var(--amber);margin:40px 0;padding:8px 0 8px 28px;}
.prose blockquote p{font-size:22px;font-style:italic;color:var(--text-mid);margin-bottom:0;}
.prose-rule{border:none;border-top:1px solid var(--rule);margin:48px 0;}
/* Sticky sidebars on article detail. Offset clears the sticky site
   header (58px) + the TTS bar (52px, sticky at top:58px) with a small
   visual gap. `align-self:start` keeps each sidebar at its grid row's
   top instead of stretching to fill, which is required for sticky to
   take effect inside a CSS grid. The TOC also caps its height + scrolls
   internally so long contents never collide with the bottom of the
   viewport. Mirrors the legal-page TOC pattern (line 1094 below). */
.art-meta-sidebar{padding-top:4px;position:sticky;top:130px;align-self:start;}
.art-meta-sidebar-entry{padding-bottom:14px;margin-bottom:14px;}
.art-meta-sidebar-entry.has-divider{border-bottom:1px solid var(--rule);margin-bottom:20px;padding-bottom:20px;}
.art-toc-sidebar{padding-top:4px;position:sticky;top:130px;align-self:start;max-height:calc(100vh - 150px);overflow-y:auto;}
.art-toc-sidebar-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:12px;display:block;padding-bottom:10px;border-bottom:1px solid var(--rule);}
.toc-item{display:block;font-size:13px;color:var(--text-mid);font-weight:300;padding:8px 0 8px 12px;cursor:pointer;text-decoration:none;transition:color .15s,border-color .15s;border-left:2px solid var(--rule);margin-bottom:2px;}
.toc-item:hover{color:var(--text);border-left-color:var(--text);}
.toc-item.active{color:var(--amber);border-left-color:var(--amber);font-weight:400;}
.art-sidebar-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);padding-bottom:12px;border-bottom:1px solid var(--rule);margin-bottom:16px;}
.art-sidebar-sec{margin-bottom:36px;}

/* ── Article detail responsive ──
   The 3-column body (meta · prose · toc), the 3-col related grid and the 48px
   gutters had no breakpoints, so at narrow widths the prose column collapsed
   to ~0 and the page overflowed. Collapse to a single reading column on
   tablet/phone (drop the floating TOC), reduce gutters, reflow the grids. */
@media (max-width:900px){
  .art-header-section{padding:40px 40px 32px;}
  .tts-bar{padding:0 40px;}
  .art-body-cols{grid-template-columns:minmax(0,720px);gap:36px;padding:40px 40px 64px;max-width:none;}
  .art-meta-sidebar{position:static;top:auto;}
  .art-toc-sidebar{display:none;}
  .more-from{padding:48px 40px;}
  .more-from-grid{grid-template-columns:repeat(2,1fr);gap:24px;}
}
@media (max-width:560px){
  .art-header-section{padding:32px 20px 26px;}
  .tts-bar{padding:0 20px;gap:12px;}
  .art-body-cols{padding:32px 20px 56px;}
  .more-from{padding:40px 20px;}
  .more-from-grid{grid-template-columns:1fr;}
}

/* ── VIDEO TEMPLATE ── */
.vid-wrap{max-width:1200px;margin:0 auto;padding:48px 48px 0;}
.vid-header{border-bottom:1px solid var(--rule);padding-bottom:36px;margin-bottom:0;}
.vid-player-area{background:#0a0e0c;margin:0;position:relative;}
.vid-player-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.vid-player{width:100%;aspect-ratio:16/9;background:#0a0e0c;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.vid-native{width:100%;height:100%;object-fit:contain;background:#0a0e0c;}
.vid-player .plyr{width:100%;height:100%;--plyr-color-main:var(--amber);}
.vid-player .plyr__video-wrapper{height:100%;background:#0a0e0c;}
.vid-player .plyr video{width:100%;height:100%;object-fit:contain;}
.vid-player-thumb{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.vid-play-circle{width:64px;height:64px;background:rgba(196,146,42,.9);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;}
.vid-play-circle:hover{background:var(--amber);}
.vid-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(0,0,0,.7) 0%,transparent 100%);padding:16px 20px 12px;display:flex;align-items:center;gap:12px;}
.vid-ctrl-btn{background:none;border:none;cursor:pointer;color:white;padding:4px;display:flex;align-items:center;}
.vid-progress{flex:1;height:3px;background:rgba(255,255,255,.25);cursor:pointer;position:relative;}
.vid-progress-fill{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--amber);}
.vid-ctrl-time{font-size:12px;color:rgba(255,255,255,.8);font-family:var(--sans);font-weight:300;white-space:nowrap;}
.vid-below{display:grid;grid-template-columns:260px 1fr;gap:56px;padding:40px 0 64px;border-bottom:1px solid var(--rule);max-width:1200px;margin:0 auto;padding-left:48px;padding-right:48px;}
.vid-meta-col{display:flex;flex-direction:column;gap:24px;}
.vid-desc-col{font-family:var(--serif);font-size:18px;color:var(--text-mid);line-height:1.75;font-style:italic;}
.vid-share{display:flex;gap:8px;margin-top:8px;}
/* Video detail responsive: the below-player body was a fixed 260px·1fr (desc
   column crushed) and the full-bleed player area's negative margin was pinned
   to the 48px gutter. Collapse the body to one column and keep the player's
   negative margin == wrap padding at each breakpoint. */
@media (max-width:900px){
  .vid-wrap{padding:40px 40px 0;}
  .vid-player-inner{padding:0 40px;}
  .vid-below{grid-template-columns:minmax(0,720px);gap:32px;padding-left:40px;padding-right:40px;}
}
@media (max-width:560px){
  .vid-wrap{padding:32px 20px 0;}
  .vid-player-inner{padding:0 20px;}
  .vid-below{padding-left:20px;padding-right:20px;}
}

/* ── AUDIO TEMPLATE ── */
.aud-wrap{max-width:1200px;margin:0 auto;padding:48px;}
.aud-header{border-bottom:1px solid var(--rule);padding-bottom:32px;margin-bottom:40px;}
.aud-player{border:1px solid var(--rule);background:white;padding:24px;margin-bottom:24px;}
[data-theme="dark"] .aud-player{background:var(--bg-section);border-color:var(--rule);}
.aud-native{display:none;}
.aud-player-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:16px;}
.aud-player-controls{display:flex;align-items:center;gap:16px;}
.aud-play-btn{width:44px;height:44px;background:var(--amber);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;transition:background .2s;}
.aud-play-btn:hover{background:var(--amber-light);}
.aud-waveform{flex:1;height:36px;background:var(--bg-warm);position:relative;overflow:hidden;cursor:pointer;}
.aud-waveform-fill{position:absolute;left:0;top:0;bottom:0;background:rgba(196,146,42,.15);border-right:2px solid var(--amber);transition:width .5s linear;}
.aud-time{font-size:12px;color:var(--text-light);font-family:var(--sans);font-weight:300;white-space:nowrap;}
.aud-body{display:grid;grid-template-columns:240px 1fr;gap:56px;max-width:1200px;margin:0 auto;padding:48px 48px 64px;}
.aud-meta-col{display:flex;flex-direction:column;gap:24px;}
.aud-right-col{display:flex;flex-direction:column;gap:0;}
.transcript-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0;padding-bottom:12px;border-bottom:1px solid var(--rule);}
.transcript-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);}
.transcript-lang-select{font-family:var(--sans);font-size:12px;border:1px solid var(--rule);background:none;padding:4px 8px;color:var(--text-mid);cursor:pointer;}
.transcript-line{display:flex;gap:16px;padding:14px 12px;border-bottom:1px solid var(--rule);cursor:pointer;transition:background .15s;border-radius:2px;}
.transcript-line.active{background:rgba(196,146,42,.1);border-bottom-color:rgba(196,146,42,.2);}
.transcript-line:hover:not(.active){background:rgba(0,0,0,.02);}
.transcript-play-btn{width:28px;height:28px;border-radius:50%;background:var(--amber);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;}
.transcript-play-btn:hover{background:var(--amber-light);}
.transcript-line.active .transcript-play-btn{background:var(--amber);}
.transcript-time{font-size:11px;color:var(--amber);font-weight:500;font-family:var(--sans);padding-top:2px;min-width:36px;opacity:.8;}
.transcript-text{font-size:15px;color:var(--text-mid);line-height:1.65;font-weight:300;}
.transcript-line.active .transcript-text{color:var(--text);font-weight:400;}
/* Audio body collapse: the 240px meta + 1fr player/transcript grid overflows
   on narrow viewports (the right column is pushed off-screen). Collapse to a
   single column ≤900 (meta stacks above the player + transcript) and step the
   gutters down — mirrors the video `.vid-below` treatment. */
@media (max-width:900px){
  .aud-body{grid-template-columns:minmax(0,1fr);gap:32px;padding:40px 40px 56px;}
}
@media (max-width:560px){
  .aud-body{gap:24px;padding:32px 20px 48px;}
}

/* ── EVENTS ── */
.events-header{padding:64px 80px 40px;border-bottom:1px solid var(--rule);}
.events-header-top{display:flex;justify-content:space-between;align-items:end;margin-bottom:8px;}
.events-page-title{font-family:var(--serif);font-size:clamp(48px,5vw,72px);font-weight:400;color:var(--text);letter-spacing:-.03em;line-height:1;}
.events-page-desc{font-family:var(--serif);font-size:16px;color:var(--text-mid);font-style:italic;max-width:320px;text-align:right;line-height:1.5;}
.events-body{padding:0 80px 80px;}
.event-item{display:grid;grid-template-columns:100px 1fr 220px;gap:40px;padding:36px 0;border-bottom:1px solid var(--rule);cursor:pointer;}
.event-item:first-child{padding-top:40px;}
.event-item:hover .event-title{color:var(--amber);}
.event-date-block{text-align:center;padding-top:4px;}
.event-date-day{font-family:var(--serif);font-size:52px;font-weight:400;color:var(--text);line-height:1;letter-spacing:-.03em;}
.event-date-month{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-top:4px;}
.event-date-year{font-size:11px;color:var(--text-light);font-weight:300;}
.event-type-tag{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;display:block;}
.event-title{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--text);line-height:1.18;margin-bottom:12px;letter-spacing:-.01em;transition:color .2s;}
.event-desc{font-size:14px;color:var(--text-mid);font-weight:300;line-height:1.65;margin-bottom:12px;}
.event-location{font-size:12px;color:var(--text-light);font-weight:300;display:flex;align-items:center;gap:6px;}
.event-img{aspect-ratio:16/9;overflow:hidden;}
.event-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);display:block;}
.event-img-placeholder{width:100%;height:100%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;font-size:10px;color:rgba(0,0,0,.2);font-style:italic;}

/* EVENT DETAIL */
.evd-header{background:var(--dark);padding:80px 80px 64px;position:relative;overflow:hidden;}
.evd-header::before{content:'';position:absolute;inset:0;background-image:url('assets/hero-section.jpg');background-size:cover;background-position:center;opacity:.15;}
.evd-header-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:end;}
.evd-type{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:24px;display:block;}
.evd-title{font-family:var(--serif);font-size:clamp(36px,4vw,60px);font-weight:400;color:#F7F5F0;line-height:1.08;letter-spacing:-.025em;margin-bottom:24px;}
.evd-subtitle{font-family:var(--serif);font-size:18px;font-style:italic;color:rgba(247,245,240,.6);line-height:1.5;}
.evd-info-card{background:rgba(247,245,240,.06);border:1px solid rgba(247,245,240,.12);padding:28px;}
.evd-info-row{padding:12px 0;border-bottom:1px solid rgba(247,245,240,.08);}
.evd-info-row:last-child{border-bottom:none;}
.evd-info-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,245,240,.35);margin-bottom:4px;}
.evd-info-value{font-size:14px;color:rgba(247,245,240,.85);font-weight:300;}
/* `display:block` is required for `margin-top` + `width:100%` to take
   effect — the KC partial renders this as an `<a>` (inline by default),
   not the `<button>` the prototype uses. Without it, the register CTA
   ends up flush against the info card and shrinks to its content. */
.evd-register-btn{display:block;width:100%;box-sizing:border-box;background:var(--amber);color:var(--dark);border:none;border-radius:0;padding:14px;font-family:var(--sans);font-size:13px;font-weight:500;text-align:center;text-decoration:none;cursor:pointer;margin-top:16px;transition:background .2s;}
.evd-register-btn:hover{background:var(--amber-light);}
.evd-body{padding:72px 80px;display:grid;grid-template-columns:1fr 340px;gap:96px;}
.evd-breadcrumb{font-size:12px;color:rgba(247,245,240,.4);font-weight:300;margin-bottom:32px;display:flex;align-items:center;gap:8px;}
.evd-breadcrumb a{color:rgba(247,245,240,.4);text-decoration:none;cursor:pointer;transition:color .15s;}
.evd-breadcrumb a:hover{color:rgba(247,245,240,.7);}
/* Event detail responsive. Header (`1fr 360px`), body (`1fr 340px`) and the
   "more events" grid (`repeat(3,1fr)`) were all fixed with 80px gutters and no
   media queries — the info card / sidebar were pushed off-screen (~201px
   overflow at 390) and the prose column crushed to one word per line. Collapse
   each to a single column ≤900 and step the gutters down. */
@media (max-width:900px){
  .evd-header{padding:56px 40px 40px;}
  .evd-header-inner{grid-template-columns:1fr;gap:32px;align-items:stretch;}
  .evd-body{padding:48px 40px;grid-template-columns:1fr;gap:40px;}
}
@media (max-width:560px){
  .evd-header{padding:40px 20px 32px;}
  .evd-body{padding:36px 20px;}
}
/* NOTE: the `.event-cards-*` responsive overrides live AFTER their base rules
   (search "more-events responsive") — placing them here would be shadowed by
   the later base declarations, since media queries don't raise specificity. */

/* ── FOOTER ── */
.kc-footer{background:var(--dark);padding:56px 48px;border-top:2px solid var(--amber);}
.kc-footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:start;gap:56px;}
.kc-footer-about{max-width:320px;}
.kc-footer-brand{font-family:var(--serif);font-size:18px;color:rgba(247,245,240,.9);margin-bottom:8px;}
.kc-footer-copy{font-size:12px;color:rgba(247,245,240,.35);font-weight:300;}
.kc-footer-tagline{margin-top:6px;}
.kc-footer-social{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;}
.kc-footer-links{display:flex;gap:48px;}
.kc-footer-col{display:flex;flex-direction:column;gap:10px;min-width:130px;}
.kc-footer-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,245,240,.35);margin-bottom:4px;}
.kc-footer-link{font-size:13px;color:rgba(247,245,240,.5);text-decoration:none;font-weight:300;cursor:pointer;transition:color .15s;}
.kc-footer-link:hover{color:rgba(247,245,240,.8);}
@media (max-width:900px){
  .kc-footer{padding:44px 24px;}
  .kc-footer-inner{display:grid;grid-template-columns:1fr;gap:34px;}
  .kc-footer-about{max-width:none;}
  .kc-footer-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;}
}
@media (max-width:640px){
  .kc-footer{padding:38px 20px;}
  .kc-footer-links{grid-template-columns:1fr;gap:26px;}
  .kc-footer-col{gap:8px;}
  .kc-footer-link{font-size:14px;padding:2px 0;}
}

/* ── ABOUT PAGE ── */
.about-hero{background:var(--dark);padding:88px 48px 72px;position:relative;overflow:hidden;}
.about-hero::before{content:'';position:absolute;inset:0;background-image:url('assets/hero-section.jpg');background-size:cover;background-position:center 30%;opacity:.12;}
.about-hero-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;}
.about-hero-tag{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:24px;display:block;}
.about-hero-title{font-family:var(--serif);font-size:clamp(44px,5vw,70px);font-weight:400;color:#F7F5F0;line-height:1.06;letter-spacing:-.025em;margin-bottom:24px;}
.about-hero-lead{font-family:var(--serif);font-size:19px;color:rgba(247,245,240,.75);line-height:1.7;font-style:italic;}
.about-body{max-width:1200px;margin:0 auto;padding:72px 48px;}
.about-grid{display:grid;grid-template-columns:280px 1fr;gap:80px;margin-bottom:72px;}
.about-prose{font-family:var(--serif);font-size:19px;color:var(--text);line-height:1.8;}
.about-prose p{margin-bottom:28px;}
.about-prose h2{font-size:26px;font-weight:400;letter-spacing:-.02em;color:var(--text);margin:44px 0 18px;line-height:1.2;}
.about-stat-block{display:flex;flex-direction:column;gap:36px;padding-top:8px;}
.about-stat{border-top:1px solid var(--rule);padding-top:20px;}
.about-stat-num{font-family:var(--serif);font-size:52px;font-weight:400;color:var(--amber);line-height:1;letter-spacing:-.03em;}
.about-stat-label{font-size:13px;color:var(--text-mid);font-weight:300;margin-top:4px;line-height:1.4;}
.about-team{background:var(--bg-section);padding:56px 48px;}
.about-team-inner{max-width:1200px;margin:0 auto;}
.about-team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:40px;}
.team-card{background:var(--bg);padding:24px;}
.team-card-avatar{width:72px;height:72px;border-radius:50%;background:var(--dark);margin-bottom:16px;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;color:rgba(247,245,240,.6);}
.team-card-name{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--text);margin-bottom:4px;}
.team-card-role{font-size:12px;color:var(--amber);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;}
.team-card-bio{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.6;}
.about-partners{max-width:1200px;margin:0 auto;padding:56px 48px;}
.about-partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:36px;}
.partner-tile{background:var(--bg-warm);padding:28px 32px;display:flex;flex-direction:column;gap:8px;}
.partner-tile{min-width:0;}
.partner-tile-name{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--text);overflow-wrap:anywhere;}
/* Allow long, unbroken type tokens (e.g. raw UPPER_SNAKE category keys) to wrap
   so they don't force the grid track wider than the viewport on mobile. */
.partner-tile-type{font-size:11px;color:var(--text-light);font-weight:300;letter-spacing:.06em;text-transform:uppercase;overflow-wrap:anywhere;}
/* About page responsive. The page shipped with NO media queries — the hero
   (1fr 1fr), the stats+prose grid (280px 1fr), the team grid (4-up) and the
   partners grid (3-up) never collapsed, overflowing ~824px at 390. Collapse
   each and step the section gutters 48→40→20. */
@media (max-width:900px){
  .about-hero{padding:64px 40px 48px;}
  .about-hero-inner{grid-template-columns:1fr;gap:32px;}
  .about-body{padding:48px 40px;}
  .about-grid{grid-template-columns:1fr;gap:40px;margin-bottom:48px;}
  .about-team{padding:48px 40px;}
  .about-team-grid{grid-template-columns:repeat(2,1fr);gap:20px;}
  .about-partners{padding:48px 40px;}
  .about-partners-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .about-hero{padding:40px 20px 32px;}
  .about-body{padding:36px 20px;}
  .about-grid{gap:32px;}
  .about-team{padding:40px 20px;}
  .about-team-grid{grid-template-columns:1fr;}
  .about-partners{padding:40px 20px;}
  .about-partners-grid{grid-template-columns:1fr;}
}

/* ── CHAT WIDGET ── */
.chat-widget{position:fixed;bottom:28px;right:28px;z-index:500;display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.chat-bubble-btn{width:52px;height:52px;border-radius:50%;background:var(--dark);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.2);transition:background .2s,transform .15s;}
.chat-bubble-btn:hover{background:var(--dark-mid);transform:scale(1.05);}
.chat-bubble-btn svg{flex-shrink:0;}
.chat-panel{width:340px;background:white;border:1px solid var(--rule);box-shadow:0 8px 40px rgba(0,0,0,.14);display:flex;flex-direction:column;border-radius:4px;overflow:hidden;max-height:520px;}
.chat-panel-header{background:var(--dark);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.chat-panel-title{font-size:13px;font-weight:500;color:#F7F5F0;letter-spacing:.02em;}
.chat-panel-sub{font-size:11px;color:rgba(247,245,240,.45);font-weight:300;}
.chat-panel-close{background:none;border:none;cursor:pointer;color:rgba(247,245,240,.5);font-size:18px;line-height:1;padding:0;}
.chat-panel-close:hover{color:rgba(247,245,240,.9);}
.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px;}
.chat-msg{max-width:88%;font-size:13px;line-height:1.6;padding:10px 14px;border-radius:2px;}
.chat-msg.bot{background:var(--bg-warm);color:var(--text);align-self:flex-start;}
.chat-msg.user{background:var(--dark);color:rgba(247,245,240,.9);align-self:flex-end;}
.chat-msg.typing{color:var(--text-light);font-style:italic;}
.chat-input-row{border-top:1px solid var(--rule);display:flex;align-items:center;padding:10px 14px;gap:8px;flex-shrink:0;}
.chat-input{flex:1;background:none;border:none;outline:none;font-family:var(--sans);font-size:13px;color:var(--text);}
.chat-input::placeholder{color:var(--text-light);}
.chat-send-btn{background:var(--amber);border:none;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;}
.chat-send-btn:hover{background:var(--amber-light);}
.chat-send-btn:disabled{opacity:.4;cursor:default;}
.tweaks-panel{position:fixed;bottom:24px;right:24px;background:white;border:1px solid var(--rule);border-radius:4px;padding:20px;width:230px;z-index:200;box-shadow:0 4px 24px rgba(0,0,0,.08);}
.tweaks-panel h4{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:16px;}
.tweak-row{margin-bottom:14px;}
.tweak-row label{display:block;font-size:12px;color:var(--text-mid);margin-bottom:6px;}
.tweak-row select{width:100%;font-size:12px;padding:5px 8px;border:1px solid var(--rule);border-radius:2px;background:var(--bg);font-family:var(--sans);}

/* ── TAG CHIPS ── */
.kc-tag{display:inline-block;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mid);padding:3px 9px;border:1px solid var(--rule);cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap;font-family:var(--sans);}
.kc-tag:hover{border-color:var(--amber);color:var(--amber);}
.kc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}

/* ── EVENT CARDS (upcoming) ── */
.event-cards-section{background:var(--dark);padding:72px 48px;}
.event-cards-inner{max-width:1200px;margin:0 auto;}
.event-cards-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:28px;}
.event-cards-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);}
/* Fill the row by card count: auto-fit collapses empty tracks, so 2 cards become
   two equal full-width columns (no dangling empty 3rd column), 3 become three,
   and a narrow viewport drops to a single column — no hardcoded counts. */
.event-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:2px;}
.event-card{background:rgba(247,245,240,.04);border:1px solid rgba(247,245,240,.08);padding:28px 24px;cursor:pointer;transition:background .2s;display:flex;flex-direction:column;min-height:200px;}
.event-card:hover{background:rgba(247,245,240,.08);}
.event-card-type{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;}
.event-card-date{font-family:var(--serif);font-size:13px;color:rgba(247,245,240,.4);margin-bottom:10px;font-style:italic;}
.event-card-title{font-family:var(--serif);font-size:19px;font-weight:400;color:rgba(247,245,240,.88);line-height:1.25;margin-bottom:auto;padding-bottom:20px;transition:color .2s;}
.event-card:hover .event-card-title{color:var(--amber);}
.event-card-footer{border-top:1px solid rgba(247,245,240,.08);padding-top:14px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.event-card-location{font-size:12px;color:rgba(247,245,240,.4);font-weight:300;display:flex;align-items:center;gap:5px;}
.event-card-format{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(247,245,240,.35);border:1px solid rgba(247,245,240,.12);padding:2px 8px;}
/* more-events responsive — MUST follow the base rules above: media queries don't
   raise specificity, so an earlier-in-file @media is shadowed by these later base
   declarations. Step the section gutter down to match the footer/body (48→40→20),
   and stack the head (label + "view all" link) vertically on mobile, where the
   long localized strings were cramped side-by-side. */
@media (max-width:900px){
  .event-cards-section{padding:56px 40px;}
}
@media (max-width:560px){
  .event-cards-section{padding:40px 20px;}
  .event-cards-head{flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:22px;}
}

/* ── CATEGORIES SECTION ── */
.hp-categories{}
.hp-cat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.hp-cat-card{background:var(--bg-warm);padding:28px 24px;cursor:pointer;transition:background .2s;min-height:140px;display:flex;flex-direction:column;justify-content:space-between;}
.hp-cat-card:nth-child(2n){background:var(--bg-section);}
.hp-cat-card:hover{background:var(--rule)!important;}
.hp-cat-card-num{font-family:var(--serif);font-size:11px;color:var(--text-light);margin-bottom:10px;}
.hp-cat-card-name{font-family:var(--serif);font-size:17px;font-weight:400;color:var(--text);line-height:1.3;}
.hp-cat-card-count{font-size:11px;color:var(--amber);font-weight:500;margin-top:10px;letter-spacing:.04em;}

/* ── MEDIA MASONRY ── */
.media-equal-tiles{background:var(--dark);padding:72px 80px;}
.media-empty{text-align:center;padding:80px 0;color:rgba(247,245,240,.3);font-family:var(--serif);font-size:22px;font-style:italic;}
.hp-media-section{background:var(--dark);padding:72px 80px;margin-bottom:0;}
.hp-media-inner{}
.hp-media-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:32px;}
.hp-media-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);}
.hp-media-heading{font-family:var(--serif);font-size:30px;font-weight:400;color:#F7F5F0;letter-spacing:-.02em;}
.hp-media-masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.hp-media-tile{position:relative;overflow:hidden;cursor:pointer;background:rgba(247,245,240,.05);aspect-ratio:4/3;}
.hp-media-tile-placeholder{position:absolute;inset:0;width:100%;height:100%;background:rgba(247,245,240,.06);display:flex;align-items:center;justify-content:center;font-size:10px;color:rgba(255,255,255,.12);font-style:italic;font-family:monospace;overflow:hidden;}
.hp-media-tile-img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(35%) brightness(.82);transition:filter .3s,transform .6s;}
.hp-media-tile:hover .hp-media-tile-img{filter:grayscale(0%) brightness(.72);transform:scale(1.04);}
.hp-media-tile-info{position:absolute;bottom:0;left:0;right:0;padding:22px 20px 20px;background:linear-gradient(0deg,rgba(10,18,14,.97) 0%,rgba(10,18,14,.82) 45%,rgba(10,18,14,.35) 80%,transparent 100%);opacity:0;transition:opacity .22s;}
.hp-media-tile:hover .hp-media-tile-info{opacity:1;}
.hp-media-tile-type{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:6px;}
.hp-media-tile-title{font-family:var(--serif);font-size:16px;color:#F7F5F0;line-height:1.3;}
.hp-media-tile-dur{font-size:11px;color:rgba(247,245,240,.7);margin-top:4px;}
.media-tile-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px;}
.media-tile-tag{font-size:9px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:rgba(247,245,240,.6);border:1px solid rgba(247,245,240,.25);padding:2px 6px;}
.hp-media-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:rgba(196,146,42,.92);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:2;}
.hp-media-tile:hover .hp-media-play{opacity:1;}
@media (max-width:1100px){.hp-media-masonry{grid-template-columns:repeat(3,1fr);}}
@media (max-width:720px){.hp-media-masonry{grid-template-columns:repeat(2,1fr);}}
@media (max-width:900px){
  .media-equal-tiles{padding:56px 36px;}
  .media-equal-tiles .hp-media-tile-info,.media-equal-tiles .hp-media-play{opacity:1;}
}
@media (max-width:620px){
  .media-equal-tiles{padding:44px 24px;}
  .media-equal-tiles .hp-media-masonry{grid-template-columns:1fr;}
  .media-equal-tiles .hp-media-tile{aspect-ratio:16/10;}
  .media-empty{padding:56px 0;font-size:19px;}
}

/* ── HOMEPAGE: SECTION SCAFFOLDING ── */
.hp-section{padding:96px 80px;}
.hp-section + .hp-section{border-top:1px solid var(--rule);}
.hp-section-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:48px;}
.hp-section-eyebrow{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;display:block;}
.hp-section-heading{font-family:var(--serif);font-size:clamp(34px,3vw,48px);font-weight:400;color:var(--text);line-height:1.1;letter-spacing:-.02em;max-width:680px;}
.hp-section-sub{font-family:var(--serif);font-size:16px;color:var(--text-mid);font-style:italic;max-width:380px;text-align:right;line-height:1.5;flex-shrink:0;padding-bottom:8px;}
.hp-section-link{display:inline-flex;align-items:center;justify-content:center;background:none;border:1px solid var(--rule);color:var(--text-mid);font-family:var(--sans);font-size:12px;letter-spacing:.06em;padding:9px 18px;cursor:pointer;white-space:nowrap;text-decoration:none;transition:border-color .15s,color .15s;}
.hp-section-link:hover{border-color:var(--text);color:var(--text);}
.hp-deepdives .hp-section-link{border-color:rgba(247,245,240,.2);color:rgba(247,245,240,.6);}
.hp-deepdives .hp-section-link:hover{border-color:rgba(247,245,240,.5);color:rgba(247,245,240,.9);}
.hp-media-head .hp-section-link{border-color:rgba(247,245,240,.15);color:rgba(247,245,240,.5);padding:7px 16px;}
.hp-media-head .hp-section-link:hover{border-color:rgba(247,245,240,.5);color:rgba(247,245,240,.9);}

/* ── 2. START EXPLORING ── */
.hp-start-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.hp-start-card{background:var(--bg-warm);padding:32px 28px 28px;cursor:pointer;display:flex;flex-direction:column;min-height:220px;transition:background .2s;position:relative;}
.hp-start-card:nth-child(2n){background:var(--bg-section);}
.hp-start-card:hover{background:var(--dark);color:#F7F5F0;}
.hp-start-card:hover .hp-start-card-desc{color:rgba(247,245,240,.7);}
.hp-start-card:hover .hp-start-card-arrow{color:var(--amber);transform:translateX(4px);}
.hp-start-card:hover .hp-start-card-icon{color:var(--amber);}
.hp-start-card-icon{color:var(--text);margin-bottom:24px;transition:color .2s;}
.hp-start-card-label{font-family:var(--serif);font-size:22px;font-weight:400;color:inherit;line-height:1.2;margin-bottom:10px;}
.hp-start-card-desc{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.55;margin-bottom:auto;transition:color .2s;}
.hp-start-card-arrow{font-size:14px;color:var(--text-light);margin-top:20px;transition:color .2s,transform .2s;align-self:flex-start;}

/* ── 3. FEATURED THEME ── */
.hp-featured{background:var(--bg-warm);}
.hp-featured-block{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:64px;align-items:start;cursor:pointer;}
.hp-featured-img{aspect-ratio:5/6;overflow:hidden;}
.hp-featured-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);transition:filter .4s,transform .8s;}
.hp-featured-block:hover .hp-featured-img img{filter:grayscale(0%);transform:scale(1.02);}
.hp-featured-tag{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.hp-featured-title{font-family:var(--serif);font-size:clamp(38px,3.4vw,56px);font-weight:400;line-height:1.05;letter-spacing:-.02em;margin-bottom:20px;color:var(--text);transition:color .2s;}
.hp-featured-block:hover .hp-featured-title{color:var(--amber);}
.hp-featured-tagline{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--text-mid);line-height:1.5;margin-bottom:24px;}
.hp-featured-blurb{font-size:14px;color:var(--text-mid);line-height:1.7;font-weight:300;margin-bottom:32px;max-width:520px;}
.hp-featured-anchors-label{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:16px;display:block;}
.hp-featured-anchors{display:flex;flex-direction:column;border-top:1px solid var(--rule);}
.hp-featured-anchor{display:grid;grid-template-columns:24px 1fr auto;gap:18px;padding:16px 0;border-bottom:1px solid var(--rule);align-items:center;cursor:pointer;}
.hp-featured-anchor:hover .hp-featured-anchor-title{color:var(--amber);}
.hp-featured-anchor-num{font-family:var(--serif);font-size:13px;color:var(--text-light);}
.hp-featured-anchor-title{font-family:var(--serif);font-size:18px;color:var(--text);line-height:1.3;transition:color .2s;}
.hp-featured-anchor-meta{font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.06em;text-transform:uppercase;}

/* ── 4. PATHS ── */
.hp-paths-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:64px;}
.hp-path-lane{}
.hp-path-lane-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--text);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--text);display:flex;align-items:baseline;justify-content:space-between;gap:12px;}
.hp-path-lane-count{font-size:11px;color:var(--text-light);font-family:var(--sans);font-weight:400;letter-spacing:.04em;}
.hp-path-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--rule);cursor:pointer;transition:padding .2s;}
.hp-path-item:hover{padding-left:6px;}
.hp-path-item:hover .hp-path-item-name{color:var(--amber);}
.hp-path-item-name{font-size:15px;color:var(--text);font-weight:400;line-height:1.4;transition:color .2s;}
.hp-path-item-meta{font-size:11px;color:var(--text-light);font-weight:300;flex-shrink:0;}
.hp-path-empty{padding:14px 0;border-bottom:1px solid var(--rule);font-family:var(--serif);font-size:16px;color:var(--text-light);font-style:italic;}

/* ── 5. VOICES ── */
.hp-voices-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;}
.hp-voice-card{cursor:pointer;}
.hp-voice-portrait{aspect-ratio:1;background:var(--dark);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:64px;color:rgba(247,245,240,.55);font-style:italic;letter-spacing:-.02em;margin-bottom:20px;transition:background .3s;overflow:hidden;}
.hp-voice-card:hover .hp-voice-portrait{background:var(--amber);color:var(--dark);}
.hp-voice-name{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--text);margin-bottom:4px;line-height:1.2;}
.hp-voice-role{font-size:11px;color:var(--amber);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px;}
.hp-voice-blurb{font-size:13px;color:var(--text-mid);line-height:1.6;font-weight:300;margin-bottom:18px;}
.hp-voice-work{font-size:12px;color:var(--text-light);padding-top:14px;border-top:1px solid var(--rule);}
.hp-voice-work strong{font-weight:500;color:var(--text);font-style:normal;}
.hp-voice-card:hover .hp-voice-work strong{color:var(--amber);}

/* ── 6. FORMAT CHIPS ── */
.hp-formats-chips{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;}
.hp-formats-chip{background:none;border:1px solid rgba(247,245,240,.2);color:rgba(247,245,240,.6);font-family:var(--sans);font-size:12px;letter-spacing:.04em;padding:7px 16px;cursor:pointer;transition:border-color .15s,background .15s,color .15s;}
.hp-formats-chip:hover{border-color:rgba(247,245,240,.5);color:rgba(247,245,240,.9);}
.hp-formats-chip.active{background:var(--amber);border-color:var(--amber);color:var(--dark);font-weight:500;}

/* ── 7. DEEP DIVES ── */
.hp-deepdives{background:var(--dark);padding:96px 80px;}
.hp-deepdives-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:48px;}
.hp-deepdives-head .hp-section-eyebrow{color:var(--amber);}
.hp-deepdives-head .hp-section-heading{color:#F7F5F0;}
.hp-deepdives-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.hp-deepdive-card{cursor:pointer;display:flex;flex-direction:column;}
.hp-deepdive-img{aspect-ratio:4/5;overflow:hidden;margin-bottom:24px;}
.hp-deepdive-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(50%) brightness(.85);transition:filter .4s,transform .8s;}
.hp-deepdive-card:hover .hp-deepdive-img img{filter:grayscale(0%) brightness(1);transform:scale(1.03);}
.hp-deepdive-label{font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;display:block;}
.hp-deepdive-title{font-family:var(--serif);font-size:28px;font-weight:400;color:#F7F5F0;line-height:1.2;letter-spacing:-.01em;margin-bottom:14px;transition:color .2s;}
.hp-deepdive-card:hover .hp-deepdive-title{color:var(--amber);}
.hp-deepdive-excerpt{font-size:14px;color:rgba(247,245,240,.7);line-height:1.65;font-weight:300;margin-bottom:16px;}
.hp-deepdive-byline{font-size:11px;color:rgba(247,245,240,.4);font-weight:300;}
.hp-deepdive-byline strong{font-weight:500;color:rgba(247,245,240,.7);}

@media (max-width:1180px){
  .hp-hero{padding:calc(48px + 58px) 56px 80px;gap:56px;}
  .hp-content,.hp-section,.hp-deepdives,.hp-media-section{padding-left:56px;padding-right:56px;}
  .hp-cats{padding:0 56px;}
  .hp-strip{margin-left:-56px;margin-right:-56px;padding-left:56px;padding-right:56px;grid-template-columns:260px 1fr;gap:44px;}
  .hp-cat-cards,.hp-start-grid,.hp-voices-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hp-media-masonry{grid-template-columns:repeat(3,1fr);}
  .hp-paths-grid{gap:40px;}
  .hp-deepdives-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;}
  .hp-featured-block{gap:48px;}
}
@media (max-width:920px){
  .hp-hero{grid-template-columns:1fr;min-height:100vh;padding:calc(44px + 58px) 36px 64px;gap:48px;}
  .hp-hero-right{display:none;}
  .hp-hero-title{font-size:clamp(44px,10vw,68px);}
  .hp-hero-desc{max-width:620px;margin-bottom:30px;}
  .hp-content,.hp-section,.hp-deepdives,.hp-media-section{padding:60px 36px;}
  .hp-cats{padding:0 36px;}
  .hp-lead{grid-template-columns:1fr;gap:30px;margin-bottom:48px;padding-bottom:48px;}
  .hp-list{grid-template-columns:1fr;margin-bottom:48px;border-top:1px solid var(--rule);}
  .hp-list-item,.hp-list-item:not(:first-child){padding:22px 0;border-right:none;border-bottom:1px solid var(--rule);}
  .hp-strip{margin:0 -36px 48px;padding:44px 36px;grid-template-columns:1fr;gap:30px;}
  .hp-section-head,.hp-deepdives-head,.hp-media-head{align-items:flex-start;flex-direction:column;gap:18px;margin-bottom:34px;}
  .hp-section-sub{max-width:680px;text-align:left;padding-bottom:0;}
  .hp-featured-block{grid-template-columns:1fr;gap:34px;}
  .hp-featured-img{aspect-ratio:16/10;}
  .hp-featured-anchor{grid-template-columns:22px 1fr;gap:14px;}
  .hp-featured-anchor-meta{grid-column:2;justify-self:start;}
  .hp-paths-grid{grid-template-columns:1fr;gap:40px;}
  .hp-voices-grid{gap:34px;}
  .hp-media-masonry{grid-template-columns:repeat(2,1fr);}
  .hp-media-tile-info,.hp-media-play{opacity:1;}
  .hp-deepdives-grid{grid-template-columns:1fr;gap:40px;}
  .hp-deepdive-img{aspect-ratio:16/10;}
  .events-header{padding:48px 36px 32px;}
  .events-header-top{flex-direction:column;align-items:flex-start;gap:10px;}
  .events-page-desc{text-align:left;max-width:560px;}
  .events-body{padding:0 36px 60px;}
  .event-item{grid-template-columns:84px 1fr 160px;gap:24px;}
}
@media (max-width:620px){
  .hp-hero{padding:calc(40px + 58px) 24px 60px;}
  .hp-hero-title{font-size:clamp(40px,13vw,56px);}
  .hp-hero-actions{align-items:flex-start;flex-direction:column;}
  .hp-search-box{align-items:flex-start;flex-direction:column;gap:4px;}
  .hp-search-box-inner{font-size:19px;padding-bottom:0;}
  .hp-search-hint a{display:inline-block;margin:4px 8px 0 0;}
  .hp-cats{padding:0 24px;}
  .hp-content,.hp-section,.hp-deepdives,.hp-media-section{padding:48px 24px;}
  .hp-cat-cards,.hp-start-grid,.hp-voices-grid,.hp-media-masonry{grid-template-columns:1fr;}
  .hp-start-card{min-height:0;padding:28px 24px;}
  .hp-cat-card{min-height:118px;}
  .hp-strip{margin-left:-24px;margin-right:-24px;padding:40px 24px;}
  .hp-strip-item{gap:16px;}
  .hp-media-head a,.hp-section-link{white-space:normal;}
  .hp-formats-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;}
  .hp-formats-chip{flex:0 0 auto;}
  .hp-featured-title{font-size:clamp(34px,11vw,46px);}
  .hp-featured-tagline{font-size:18px;}
  .hp-featured-anchor{grid-template-columns:1fr;}
  .hp-featured-anchor-num,.hp-featured-anchor-meta{grid-column:auto;}
  .hp-voice-portrait{font-size:54px;}
  .events-header{padding:40px 24px 28px;}
  .events-body{padding:0 24px 48px;}
  .event-item{grid-template-columns:56px 1fr;gap:16px;}
  .event-img{grid-column:1 / -1;aspect-ratio:16/9;margin-top:6px;}
}

/* ── SEARCH ORG FILTER ── */
/* Org flyout (reuses refine-flyout base + radio styling) */
.refine-radio-item{display:flex;align-items:center;gap:10px;padding:10px 0;cursor:pointer;border-bottom:1px solid var(--rule);}
.refine-radio-item:last-child{border-bottom:none;}
.refine-radio-item input{cursor:pointer;accent-color:var(--dark);width:14px;height:14px;}
.refine-radio-label{font-size:14px;color:var(--text-mid);font-weight:300;}
.refine-radio-item input:checked + .refine-radio-label{color:var(--text);font-weight:500;}

/* ── CHAT ENHANCEMENTS ── */
.chat-panel.wide{width:520px;}
.chat-suggested{padding:4px 16px 12px;display:flex;flex-wrap:wrap;gap:6px;}
.chat-suggested-q{font-size:12px;color:var(--text-mid);padding:5px 11px;border:1px solid var(--rule);background:none;cursor:pointer;font-family:var(--sans);text-align:left;transition:border-color .15s,color .15s;line-height:1.4;border-radius:2px;}
.chat-suggested-q:hover{border-color:var(--amber);color:var(--amber);}
.chat-wide-toggle{background:none;border:none;cursor:pointer;color:rgba(247,245,240,.4);padding:2px;transition:color .15s;display:flex;align-items:center;}
.chat-wide-toggle:hover{color:rgba(247,245,240,.85);}

.page-enter{animation:fadeIn .18s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}
.so-enter{animation:soFade .18s ease;}
@keyframes soFade{from{opacity:0;}to{opacity:1;}}

/* ── SCROLL REVEAL ANIMATIONS (varied) ── */
[data-anim]{opacity:0;will-change:opacity,transform,filter;transition:opacity .7s ease,transform .8s cubic-bezier(.2,.7,.25,1),filter .8s ease;}
[data-anim].is-visible{opacity:1;transform:none;filter:none;}
[data-anim="fade-up"]{transform:translateY(34px);}
[data-anim="fade-down"]{transform:translateY(-22px);}
[data-anim="fade-left"]{transform:translateX(40px);}
[data-anim="fade-right"]{transform:translateX(-40px);}
[data-anim="zoom-in"]{transform:scale(.94);}
[data-anim="rise"]{transform:translateY(48px) scale(.985);}
[data-anim="blur-in"]{filter:blur(10px);transform:translateY(20px);}
[data-anim="tilt-in"]{transform:translateY(28px) rotate(-1.2deg);transform-origin:left top;}
[data-anim="curtain"]{clip-path:inset(0 0 100% 0);transform:none;opacity:1;transition:clip-path 1s cubic-bezier(.2,.7,.25,1);}
[data-anim="curtain"].is-visible{clip-path:inset(0 0 0 0);}
/* Stagger containers — children animate one after another */
[data-anim-stagger] > *{opacity:0;will-change:opacity,transform;transition:opacity .55s ease,transform .65s cubic-bezier(.2,.7,.25,1);}
[data-anim-stagger].is-visible > *{opacity:1;transform:none;transition-delay:calc(var(--idx,0)*70ms);}
[data-anim-stagger="up"] > *{transform:translateY(28px);}
[data-anim-stagger="up-soft"] > *{transform:translateY(14px);}
[data-anim-stagger="left"] > *{transform:translateX(30px);}
[data-anim-stagger="zoom"] > *{transform:scale(.92);}
[data-anim-stagger="tilt"] > *{transform:translateY(22px) rotate(.6deg);transform-origin:bottom left;}
@media (prefers-reduced-motion: reduce){
  [data-anim],[data-anim-stagger] > *{opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important;transition:none!important;}
}

/* ── LEGAL / LONG-FORM PAGES (shared by Impressum, Terms, Cookies, Accessibility) ── */
.legal-hero{background:var(--bg-warm);padding:72px 48px 56px;border-bottom:1px solid var(--rule);}
.legal-hero-inner{max-width:1100px;margin:0 auto;}
.legal-hero-tag{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.legal-hero-title{font-family:var(--serif);font-size:clamp(38px,4vw,58px);font-weight:400;color:var(--text);line-height:1.08;letter-spacing:-.02em;margin-bottom:18px;max-width:780px;}
.legal-hero-lead{font-family:var(--serif);font-size:18px;color:var(--text-mid);line-height:1.6;font-style:italic;max-width:680px;}
.legal-meta{display:flex;gap:32px;margin-top:28px;flex-wrap:wrap;}
.legal-meta-item{font-size:12px;color:var(--text-light);font-weight:300;}
.legal-meta-item strong{color:var(--text-mid);font-weight:500;}
.legal-body{max-width:1100px;margin:0 auto;padding:64px 48px;display:grid;grid-template-columns:240px 1fr;gap:72px;align-items:start;}
.legal-toc{position:sticky;top:80px;}
.legal-toc-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:14px;}
.legal-toc ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.legal-toc a{font-size:13px;color:var(--text-mid);font-weight:300;text-decoration:none;cursor:pointer;line-height:1.5;display:block;border-left:1px solid var(--rule);padding:2px 0 2px 14px;transition:color .15s,border-color .15s;}
.legal-toc a:hover{color:var(--amber);border-left-color:var(--amber);}
.legal-prose{font-family:var(--serif);font-size:17px;color:var(--text);line-height:1.75;}
.legal-prose h2{font-family:var(--serif);font-size:26px;font-weight:400;letter-spacing:-.02em;color:var(--text);margin:48px 0 14px;line-height:1.2;scroll-margin-top:80px;}
.legal-prose h2:first-child{margin-top:0;}
.legal-prose h3{font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);margin:28px 0 10px;}
.legal-prose p{margin-bottom:18px;}
.legal-prose ul,.legal-prose ol{margin:0 0 18px 24px;}
.legal-prose li{margin-bottom:8px;}
.legal-prose a{color:var(--text);border-bottom:1px solid var(--amber);text-decoration:none;}
.legal-prose a:hover{color:var(--amber);}
.legal-prose .legal-callout{background:var(--bg-warm);border-left:3px solid var(--amber);padding:18px 22px;margin:24px 0;font-size:15px;font-style:italic;color:var(--text-mid);font-family:var(--serif);}
.legal-prose .legal-address{background:var(--bg-warm);padding:24px 28px;margin:18px 0;font-family:var(--sans);font-size:14px;line-height:1.7;font-style:normal;color:var(--text);}
.legal-prose .legal-address strong{font-weight:500;display:block;margin-bottom:4px;}
.legal-prose dl{margin:0 0 18px 0;}
.legal-prose dt{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light);margin-top:14px;}
.legal-prose dd{font-size:16px;margin-left:0;color:var(--text);}
.legal-table{width:100%;border-collapse:collapse;margin:18px 0;font-family:var(--sans);font-size:13px;}
.legal-table th,.legal-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--rule);vertical-align:top;}
.legal-table th{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light);background:var(--bg-warm);}
.legal-table td{color:var(--text-mid);font-weight:300;line-height:1.55;}
/* Legal archetype responsive. The body already collapses to one column ≤900,
   but the 48px hero/body gutter never stepped down — too wide on mobile, wasting
   reading width. Step gutters 48→40→20 and tighten the collapsed TOC↔prose gap. */
@media (max-width:900px){
  .legal-hero{padding:56px 40px 40px;}
  .legal-body{grid-template-columns:1fr;gap:36px;padding:48px 40px;}
  .legal-toc{position:static;}
}
@media (max-width:560px){
  .legal-hero{padding:40px 20px 32px;}
  .legal-body{padding:36px 20px;gap:28px;}
}

/* ── FUNDING & TRANSPARENCY ── */
.funding-breakdown{background:var(--bg-section);padding:64px 48px;}
.funding-breakdown-inner{max-width:1100px;margin:0 auto;}
.funding-breakdown-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:36px;flex-wrap:wrap;}
.funding-breakdown-title{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--text);letter-spacing:-.02em;}
.funding-breakdown-year{font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--rule);padding:6px 12px;background:var(--bg);}
.funding-bars{display:flex;flex-direction:column;gap:18px;}
.funding-bar-row{display:grid;grid-template-columns:200px 1fr 80px;gap:20px;align-items:center;}
.funding-bar-label{font-size:14px;color:var(--text);font-weight:400;}
.funding-bar-track{background:var(--bg);height:32px;position:relative;overflow:hidden;}
.funding-bar-fill{height:100%;background:var(--amber);transition:width .4s;}
.funding-bar-pct{font-family:var(--serif);font-size:18px;color:var(--text);font-weight:500;text-align:right;letter-spacing:-.01em;}
.funding-bar-row + .funding-bar-row .funding-bar-fill{background:var(--dark);}
.funding-bar-row:nth-child(3) .funding-bar-fill{background:var(--dark-mid);}
.funding-bar-row:nth-child(4) .funding-bar-fill{background:var(--text-light);}
.funding-bar-row:nth-child(5) .funding-bar-fill{background:var(--text-mid);}
.funding-total{margin-top:32px;padding-top:24px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:baseline;}
.funding-total-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);}
.funding-total-amount{font-family:var(--serif);font-size:34px;font-weight:400;color:var(--text);letter-spacing:-.02em;}
.funding-supporters{max-width:1100px;margin:0 auto;padding:64px 48px;}
.funding-supporters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:32px;}
.funding-supporter{background:var(--bg-warm);padding:24px 28px;display:flex;flex-direction:column;gap:6px;}
.funding-supporter-name{font-family:var(--serif);font-size:17px;color:var(--text);}
.funding-supporter-tier{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);}
.funding-supporter-detail{font-size:12px;color:var(--text-light);font-weight:300;line-height:1.5;margin-top:4px;}
.funding-policy{background:var(--dark);padding:64px 48px;color:#F7F5F0;}
.funding-policy-inner{max-width:900px;margin:0 auto;}
.funding-policy-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.funding-policy-title{font-family:var(--serif);font-size:34px;font-weight:400;color:#F7F5F0;line-height:1.2;letter-spacing:-.02em;margin-bottom:24px;}
.funding-policy-text{font-family:var(--serif);font-size:18px;color:rgba(247,245,240,.78);line-height:1.7;margin-bottom:18px;}
.funding-reports{max-width:1100px;margin:0 auto;padding:64px 48px;}
.funding-reports-list{display:flex;flex-direction:column;gap:0;margin-top:32px;border-top:1px solid var(--rule);}
.funding-report-row{display:grid;grid-template-columns:140px 1fr 120px 40px;gap:20px;padding:20px 0;border-bottom:1px solid var(--rule);align-items:center;cursor:pointer;transition:background .15s;}
.funding-report-row:hover{background:var(--bg-warm);}
.funding-report-year{font-family:var(--serif);font-size:22px;color:var(--amber);font-weight:500;letter-spacing:-.01em;}
.funding-report-title{font-family:var(--serif);font-size:17px;color:var(--text);}
.funding-report-format{font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.08em;text-transform:uppercase;}
.funding-report-arrow{font-size:18px;color:var(--text-light);text-align:right;}

/* ── CONTRIBUTE / SUBMIT MATERIALS ── */
.contrib-criteria{background:var(--bg-section);padding:64px 48px;}
.contrib-criteria-inner{max-width:1100px;margin:0 auto;}
.contrib-criteria-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:36px;}
.contrib-criterion{background:var(--bg);padding:28px 32px;display:flex;flex-direction:column;gap:10px;}
.contrib-criterion-num{font-family:var(--serif);font-size:13px;color:var(--amber);font-weight:500;letter-spacing:.04em;}
.contrib-criterion-title{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--text);line-height:1.3;}
.contrib-criterion-desc{font-size:14px;color:var(--text-mid);font-weight:300;line-height:1.6;}
.contrib-process{max-width:1100px;margin:0 auto;padding:64px 48px;}
.contrib-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:36px;}
.contrib-step{background:var(--bg-warm);padding:28px 24px;position:relative;display:flex;flex-direction:column;gap:10px;min-height:180px;}
.contrib-step-num{font-family:var(--serif);font-size:42px;color:var(--amber);font-weight:400;line-height:1;letter-spacing:-.03em;}
.contrib-step-title{font-family:var(--serif);font-size:17px;font-weight:400;color:var(--text);line-height:1.3;margin-top:8px;}
.contrib-step-desc{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.55;margin-top:auto;}
.contrib-form-section{background:var(--dark);padding:72px 48px;}
.contrib-form-inner{max-width:780px;margin:0 auto;}
.contrib-form-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:18px;display:block;}
.contrib-form-title{font-family:var(--serif);font-size:38px;font-weight:400;color:#F7F5F0;line-height:1.15;letter-spacing:-.02em;margin-bottom:14px;}
.contrib-form-lead{font-family:var(--serif);font-size:17px;color:rgba(247,245,240,.7);line-height:1.6;font-style:italic;margin-bottom:40px;}
.contrib-form{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.contrib-field{display:flex;flex-direction:column;gap:8px;}
.contrib-field.full{grid-column:1 / -1;}
.contrib-field label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(247,245,240,.55);}
.contrib-field label .req{color:var(--amber);margin-left:4px;}
.contrib-field input,.contrib-field select,.contrib-field textarea{background:rgba(247,245,240,.04);border:1px solid rgba(247,245,240,.15);padding:12px 14px;font-family:var(--sans);font-size:14px;color:#F7F5F0;outline:none;transition:border-color .15s,background .15s;font-weight:300;}
.contrib-field input:focus,.contrib-field select:focus,.contrib-field textarea:focus{border-color:var(--amber);background:rgba(247,245,240,.06);}
.contrib-field textarea{resize:vertical;min-height:120px;font-family:var(--sans);}
.contrib-field-help{font-size:12px;color:rgba(247,245,240,.4);font-weight:300;font-style:italic;line-height:1.5;}
.contrib-checkboxes{display:flex;flex-direction:column;gap:10px;}
.contrib-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;}
.contrib-check input{margin-top:4px;accent-color:var(--amber);width:14px;height:14px;cursor:pointer;}
.contrib-check span{font-size:13px;color:rgba(247,245,240,.78);font-weight:300;line-height:1.5;}
.contrib-check span a{color:var(--amber);text-decoration:underline;text-underline-offset:3px;}
.contrib-form-submit{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:24px;border-top:1px solid rgba(247,245,240,.1);flex-wrap:wrap;gap:16px;}
.contrib-submit-note{font-size:12px;color:rgba(247,245,240,.45);font-weight:300;font-style:italic;max-width:380px;line-height:1.5;}
.contrib-submit-btn{background:var(--amber);color:var(--dark);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;padding:14px 28px;border:none;cursor:pointer;transition:background .2s;}
.contrib-submit-btn:hover{background:var(--amber-light);}
.contrib-confirmation{background:rgba(196,146,42,.08);border:1px solid var(--amber);padding:32px;text-align:center;color:#F7F5F0;}
.contrib-confirmation-title{font-family:var(--serif);font-size:24px;color:var(--amber);margin-bottom:10px;}
.contrib-confirmation-text{font-size:14px;color:rgba(247,245,240,.75);font-weight:300;line-height:1.6;}
@media (max-width:780px){.contrib-form{grid-template-columns:1fr;}.funding-supporters-grid{grid-template-columns:1fr;}.contrib-criteria-grid{grid-template-columns:1fr;}.contrib-process-grid{grid-template-columns:repeat(2,1fr);}.funding-bar-row{grid-template-columns:1fr;}.funding-report-row{grid-template-columns:80px 1fr 30px;}.funding-report-format{display:none;}}
/* Contribute section gutters + extra-narrow grid collapse. The 780px rule above
   only collapses the grids; section gutters stayed at 48–72px and the process
   grid stayed 2-up down to the smallest screens. Step gutters 48/72→40→20 and
   drop the process grid to a single column ≤560. (Placed after the base rules so
   the overrides win — media queries don't raise specificity.) */
@media (max-width:780px){
  .contrib-criteria,.contrib-process{padding:48px 40px;}
  .contrib-form-section{padding:56px 40px;}
}
@media (max-width:560px){
  .contrib-criteria,.contrib-process,.contrib-form-section{padding:40px 20px;}
  .contrib-process-grid{grid-template-columns:1fr;}
}
/* Funding section gutters — the 780px rule collapses the funding grids but the
   section padding stayed 48-64px. Step 64/48→40→20 (hero uses .legal-hero, fixed
   in the legal pass). */
@media (max-width:780px){
  .funding-breakdown,.funding-supporters,.funding-policy,.funding-reports{padding:48px 40px;}
}
@media (max-width:560px){
  .funding-breakdown,.funding-supporters,.funding-policy,.funding-reports{padding:40px 20px;}
}
/* ── Pagination ─────────────────────────────────────────────────────
   Used by KC search and events pages (and any future paginated index).
   Driven by `public/blocks/knowledge_commons/pagination/pagination.html`. */
.kc-pagination{display:flex;align-items:center;justify-content:center;gap:18px;padding:32px 80px 48px;border-top:1px solid var(--rule);background:var(--bg);}
.kc-pagination-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--text);padding:10px 16px;color:var(--text);text-decoration:none;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--kc-btn-radius,0);transition:background .15s,color .15s;}
.kc-pagination-btn:hover{background:var(--text);color:var(--bg);}
.kc-pagination-btn.is-disabled{border-color:var(--rule);color:var(--text-light);cursor:not-allowed;pointer-events:none;}
.kc-pagination-info{font-family:var(--sans);font-size:13px;color:var(--text-mid);letter-spacing:.02em;}
.kc-pagination-count{color:var(--text-light);}
@media (max-width:780px){.kc-pagination{padding:24px 24px 36px;flex-wrap:wrap;gap:12px;}.kc-pagination-info{order:-1;width:100%;text-align:center;}}
/* ── Article header action row (Share + accessibility trigger) ───── */
.cp-actions-row{display:inline-flex;align-items:center;gap:8px;}
.cp-actions-row .a11y-trigger{color:var(--text-mid);width:30px;height:30px;border:1px solid var(--rule);}
.cp-actions-row .a11y-trigger:hover{color:var(--text);border-color:var(--text);background:transparent;}
/* ── Reading-mode hooks (KC-specific) ─────────────────────────────
   Triggered by `html.a11y-reading-mode` (set by static/shared/accessibility.js).
   Strips KC chrome and recentres the article body for distraction-free reading. */
html.a11y-reading-mode header[data-kms-chrome="header"],
html.a11y-reading-mode .kc-page > main > nav,
html.a11y-reading-mode body > nav:first-of-type,
html.a11y-reading-mode .kc-footer,
html.a11y-reading-mode footer,
html.a11y-reading-mode .art-meta-sidebar,
html.a11y-reading-mode .art-toc-sidebar,
html.a11y-reading-mode .more-from,
html.a11y-reading-mode .cp-actions-row{display:none!important;}
/* TTS bar stays visible in reading mode (so the headphones button has a
   target to play into); restyled as a floating bottom-center pill. */
html.a11y-reading-mode .tts-bar{position:fixed;bottom:1.5rem;left:50%;top:auto;transform:translateX(-50%);width:auto;max-width:560px;border-radius:9999px;border:1px solid var(--rule);padding:8px 18px;height:auto;box-shadow:0 12px 36px rgba(0,0,0,.45);z-index:90;}
/* Recentre the article header so the title respects the prose column. */
html.a11y-reading-mode .art-body-cols{grid-template-columns:minmax(0,86ch);max-width:none;padding:48px 24px 80px;justify-content:center;margin:0 auto;}
html.a11y-reading-mode .art-header-section{padding:32px 24px 24px;border-bottom:0;max-width:86ch;margin:0 auto;}
html.a11y-reading-mode .art-hero-img{max-width:86ch;margin:0 auto;aspect-ratio:auto;height:auto;background:transparent;}
html.a11y-reading-mode .art-hero-img img{aspect-ratio:21/9;border-radius:8px;}
html.a11y-reading-mode .cp-breadcrumb,
html.a11y-reading-mode .cp-type-label{display:none;}
html.a11y-reading-mode .cp-title{font-size:clamp(32px,4vw,52px);}
html.a11y-reading-mode .prose{font-size:calc(19px * var(--a11y-font-scale,1));max-width:none;}
/* ── High contrast (KC-specific bumps over the bundled palette) ─── */
html.a11y-high-contrast .prose,
html.a11y-high-contrast .cp-title,
html.a11y-high-contrast .kc-block-title{color:#000;}
html.a11y-high-contrast[data-theme="dark"] .prose,
html.a11y-high-contrast[data-theme="dark"] .cp-title,
html.a11y-high-contrast[data-theme="dark"] .kc-block-title{color:#fff;}

/* ═════════════════════════════════════════════════════════════
   Homepage block additions (iterations 1+2+3) — hero 3rd CTA,
   featured-collection metadata + paired actions, paths lane
   descriptions, voices marquee, deep-dives marquee, media-tile org
   attribution, footer relationship line, plus the three new section
   types: orgs.founding_grid, support.pathways_block (Support
   Spotlight, cream/warm), governance.principles_block.
   ═════════════════════════════════════════════════════════════ */
.hp-hero-actions{flex-wrap:wrap;row-gap:10px;}
.btn-ghost-light{color:rgba(247,245,240,.7);}
.btn-ghost-light:hover{color:rgba(247,245,240,.92);}
.hp-featured-title a{color:inherit;text-decoration:none;}
.hp-featured-block:hover .hp-featured-title a{color:var(--amber);}
.hp-featured-metadata{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mid);margin:-12px 0 22px;line-height:1.6;}
.hp-featured-actions{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-top:28px;}
.hp-featured-primary{font-size:13px;font-weight:500;color:#F7F5F0;background:var(--dark);padding:11px 22px;cursor:pointer;text-decoration:none;letter-spacing:.02em;transition:background .15s,color .15s;display:inline-block;}
.hp-featured-primary:hover{background:var(--amber);color:var(--dark);}
[data-theme="dark"] .hp-featured-primary{background:var(--amber);color:var(--dark);}
[data-theme="dark"] .hp-featured-primary:hover{background:var(--amber-light);}
.hp-featured-secondary{display:inline-block;font-size:13px;color:var(--text-mid);font-weight:400;border-bottom:1px solid var(--rule);padding-bottom:3px;transition:color .15s,border-color .15s;cursor:pointer;text-decoration:none;}
.hp-featured-secondary:hover{color:var(--amber);border-bottom-color:var(--amber);}
.hp-path-lane-desc{font-family:var(--serif);font-size:14px;color:var(--text-mid);font-style:italic;line-height:1.55;margin:-8px 0 18px;}
.hp-media-subheading{font-family:var(--serif);font-size:15px;color:rgba(247,245,240,.6);font-style:italic;line-height:1.5;margin-top:8px;max-width:560px;}
.hp-media-tile-org{font-size:11px;color:rgba(247,245,240,.55);font-weight:300;margin-top:4px;letter-spacing:.02em;}
.hp-section-eyebrow{font-size:12px;}
.hp-section-sub{font-size:17px;line-height:1.55;}
.hp-voice-name{font-size:23px;}
.hp-voice-blurb{font-size:14px;}
.hp-cat-card-name{font-size:19px;}

/* Marquee primitives (shared by Voices + Deep Dives) */
.hp-marquee{position:relative;}
.hp-marquee-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;padding:4px 4px 16px;margin:0 -4px;}
.hp-marquee-track::-webkit-scrollbar{display:none;}
.hp-marquee-track > *{scroll-snap-align:start;flex-shrink:0;}
.hp-marquee-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:var(--bg);border:1px solid var(--rule);color:var(--text);font-family:var(--serif);font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;box-shadow:0 4px 16px rgba(0,0,0,.06);padding:0;}
.hp-marquee-btn:hover{background:var(--amber);border-color:var(--amber);color:var(--dark);}
.hp-marquee-btn-left{left:-20px;}
.hp-marquee-btn-right{right:-20px;}
.hp-marquee-dark .hp-marquee-btn{background:var(--dark);border-color:rgba(247,245,240,.18);color:rgba(247,245,240,.85);}
.hp-marquee-dark .hp-marquee-btn:hover{background:var(--amber);border-color:var(--amber);color:var(--dark);}
@media (max-width:720px){.hp-marquee-btn{display:none;}}
.hp-voices-track > .hp-voice-card{width:260px;}
.hp-orgs-track > .hp-org-card{width:320px;}
.hp-orgs-cta{margin-top:32px;display:flex;justify-content:center;}
.hp-voice-credentials{font-family:var(--serif);font-size:13px;color:var(--text-mid);font-style:italic;line-height:1.4;margin-top:-8px;margin-bottom:14px;}
.hp-voice-contributions{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light);padding-top:14px;border-top:1px solid var(--rule);margin-top:6px;}
.hp-deepdives-sub{font-family:var(--serif);font-size:16px;color:rgba(247,245,240,.7);font-style:italic;line-height:1.6;margin-top:14px;max-width:560px;}
.hp-deepdives-note{font-size:12px;color:rgba(247,245,240,.5);font-style:italic;margin-top:10px;max-width:560px;}
.hp-deepdives-track > .hp-deepdive-card{width:340px;display:flex;flex-direction:column;}
.hp-deepdive-link{display:flex;flex-direction:column;color:inherit;text-decoration:none;cursor:pointer;}
.hp-deepdive-sources{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:rgba(247,245,240,.55);margin:-6px 0 14px;}
.hp-deepdive-secondary{display:inline-block;margin-top:14px;font-size:12px;color:rgba(247,245,240,.55);border-bottom:1px solid rgba(247,245,240,.18);padding-bottom:2px;text-decoration:none;align-self:flex-start;transition:color .15s,border-color .15s;}
.hp-deepdive-secondary:hover{color:var(--amber);border-bottom-color:var(--amber);}

/* B1 — Participating Organizations grid */
.hp-orgs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.hp-org-card{background:var(--bg-warm);padding:28px 26px;display:flex;flex-direction:column;gap:20px;border:1px solid transparent;transition:background .2s,border-color .2s;}
.hp-org-card:nth-child(2n){background:var(--bg-section);}
.hp-org-card:hover{background:var(--bg);border-color:var(--rule);}
[data-theme="dark"] .hp-org-card{background:var(--bg-warm);}
[data-theme="dark"] .hp-org-card:nth-child(2n){background:var(--bg-section);}
[data-theme="dark"] .hp-org-card:hover{background:var(--bg);border-color:var(--rule);}
.hp-org-card-head{display:flex;gap:14px;align-items:center;}
.hp-org-mark{width:44px;height:44px;background:var(--dark);color:var(--amber);font-family:var(--serif);font-size:16px;font-weight:400;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-.01em;}
.hp-org-name{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--text);line-height:1.25;margin:0;}
.hp-org-name a{color:inherit;text-decoration:none;}
.hp-org-name a:hover{color:var(--amber);}
.hp-org-location{font-size:11px;color:var(--text-light);font-weight:300;letter-spacing:.02em;margin-top:3px;}
.hp-org-focus{display:flex;flex-wrap:wrap;gap:6px;}
.hp-org-chip{font-size:10px;letter-spacing:.04em;color:var(--text-mid);border:1px solid var(--rule);padding:3px 9px;font-family:var(--sans);}
.hp-org-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.04em;}
.hp-org-meta-item{font-family:var(--sans);}
.hp-org-actions{display:flex;flex-direction:column;gap:6px;margin-top:auto;padding-top:14px;border-top:1px solid var(--rule);}
.hp-org-action-primary{font-size:13px;color:var(--text);font-weight:500;text-decoration:none;letter-spacing:.01em;cursor:pointer;transition:color .15s;}
.hp-org-action-primary:hover{color:var(--amber);}
.hp-org-action-secondary{font-size:12px;color:var(--text-mid);font-weight:400;text-decoration:none;text-underline-offset:3px;cursor:pointer;transition:color .15s;}
.hp-org-action-secondary:hover{color:var(--amber);text-decoration:underline;}
.hp-org-action-tertiary{font-size:11px;color:var(--text-light);font-weight:300;text-decoration:none;cursor:pointer;transition:color .15s;}
.hp-org-action-tertiary:hover{color:var(--text-mid);}
.hp-orgs-empty{padding:48px 0;text-align:center;font-family:var(--serif);font-size:16px;color:var(--text-light);font-style:italic;}
@media (max-width:1100px){.hp-orgs-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:720px){.hp-orgs-grid{grid-template-columns:1fr;}}

/* B2 — Support Spotlight (cream/warm section + single spotlight card) */
.hp-support-section{background:var(--bg-warm);color:var(--text);padding:96px 80px;}
.hp-support-section .hp-section-eyebrow{color:var(--amber);}
.hp-support-section .hp-section-heading{color:var(--text);max-width:600px;}
.hp-support-inner{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:80px;align-items:start;max-width:1200px;margin:0 auto;}
.hp-support-copy{display:flex;flex-direction:column;gap:18px;}
.hp-support-sub{font-family:var(--serif);font-size:18px;color:var(--text-mid);font-style:italic;line-height:1.55;max-width:560px;margin-top:4px;}
.hp-support-trust{font-size:13px;color:var(--text-light);font-style:italic;line-height:1.6;margin-top:10px;max-width:560px;}
.hp-support-actions{display:flex;gap:20px;align-items:center;flex-wrap:wrap;align-self:flex-start;margin-top:14px;}
.hp-support-cta{align-self:flex-start;}
.hp-support-tertiary{font-size:13px;color:var(--text-mid);font-weight:400;text-decoration:none;border-bottom:1px solid var(--rule);padding-bottom:3px;cursor:pointer;transition:color .15s,border-color .15s;}
.hp-support-tertiary:hover{color:var(--amber);border-bottom-color:var(--amber);}
.hp-support-rotation-link{display:inline-block;font-size:13px;color:var(--text-light);font-weight:400;text-decoration:none;margin-top:14px;align-self:flex-start;border-bottom:1px solid transparent;transition:color .15s,border-color .15s;cursor:pointer;}
.hp-support-rotation-link:hover{color:var(--amber);border-bottom-color:var(--amber);}
.hp-spotlight-card{background:#fff;border:1px solid var(--rule);box-shadow:0 10px 30px rgba(28,40,32,.08);padding:32px 32px 28px;display:flex;flex-direction:column;gap:14px;max-width:480px;}
[data-theme="dark"] .hp-spotlight-card{background:var(--bg);border-color:var(--rule);box-shadow:0 10px 30px rgba(0,0,0,.35);}
.hp-spotlight-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);}
.hp-spotlight-name{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--text);line-height:1.15;letter-spacing:-.01em;margin:0;}
.hp-spotlight-location{font-size:12px;color:var(--text-mid);letter-spacing:.02em;}
.hp-spotlight-focus{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.hp-spotlight-chip{font-size:11px;letter-spacing:.04em;color:var(--text-mid);border:1px solid var(--rule);padding:4px 10px;font-family:var(--sans);}
.hp-spotlight-collection{margin-top:12px;padding-top:18px;border-top:1px solid var(--rule);display:flex;flex-direction:column;gap:4px;}
.hp-spotlight-collection-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);}
.hp-spotlight-collection-name{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--text);line-height:1.25;}
.hp-spotlight-stats{font-size:12px;color:var(--text-light);font-weight:300;letter-spacing:.02em;margin-top:2px;}
.hp-spotlight-next{display:flex;flex-direction:column;gap:2px;padding-top:18px;margin-top:14px;border-top:1px solid var(--rule);}
.hp-spotlight-next-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);}
.hp-spotlight-next-name{font-family:var(--serif);font-size:15px;color:var(--text-mid);font-style:italic;}
.hp-support-links{display:flex;flex-direction:column;gap:12px;align-items:flex-start;margin-top:18px;}
.hp-spotlight-support{margin-top:8px;padding-top:20px;border-top:1px solid var(--rule);display:flex;flex-direction:column;gap:16px;}
.hp-spotlight-support-copy{font-family:var(--serif);font-size:14px;color:var(--text-mid);font-style:italic;line-height:1.6;margin:0;}
.hp-spotlight-donate{width:100%;}
.hp-spotlight-donate .db-inner{max-width:none;}
.hp-spotlight-cta{align-self:flex-start;}
@media (max-width:1100px){.hp-support-inner{grid-template-columns:1fr;gap:48px;}.hp-spotlight-card{max-width:none;}}
@media (max-width:720px){.hp-support-section{padding:64px 28px;}}

/* B3 — Governance & Stewardship principles */
.hp-governance-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.hp-governance-card{background:var(--bg-warm);padding:32px 26px;display:flex;flex-direction:column;gap:10px;}
.hp-governance-card:nth-child(2n){background:var(--bg-section);}
[data-theme="dark"] .hp-governance-card{background:var(--bg-warm);}
[data-theme="dark"] .hp-governance-card:nth-child(2n){background:var(--bg-section);}
.hp-governance-num{font-family:var(--serif);font-size:11px;color:var(--amber);font-weight:500;letter-spacing:.08em;margin-bottom:4px;}
.hp-governance-title{font-family:var(--serif);font-size:21px;font-weight:400;color:var(--text);line-height:1.25;margin:0 0 4px;}
.hp-governance-body{font-size:14px;color:var(--text-mid);line-height:1.6;font-weight:300;}
.hp-governance-closing{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--text-mid);line-height:1.65;max-width:720px;margin:36px 0 0;}
.hp-governance-actions{display:flex;flex-wrap:wrap;gap:18px 32px;margin-top:36px;padding-top:24px;border-top:1px solid var(--rule);}
.hp-governance-action{font-size:13px;color:var(--text-mid);font-weight:400;text-decoration:none;letter-spacing:.01em;cursor:pointer;transition:color .15s;border-bottom:1px solid transparent;padding-bottom:2px;}
.hp-governance-action:hover{color:var(--amber);border-bottom-color:var(--amber);}
@media (max-width:1100px){.hp-governance-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:720px){.hp-governance-grid{grid-template-columns:1fr;}}

/* Footer relationship line */
.kc-footer-relationship{font-style:italic;color:rgba(247,245,240,.45);}

/* org hero: real logo (no monogram box) when the org has one; collapse the
   portrait column when there's neither a logo nor a monogram. */
.person-portrait--logo{background:none;border:none;border-radius:8px;}
.person-portrait--logo img{object-fit:contain;border-radius:8px;}
.person-hero-inner--no-portrait{grid-template-columns:1fr;}
@media (min-width: 901px) {
  .person-works .person-works-inner > .idx-body[data-kms-variant="people_grid"] {
    padding-left: 0;
  }
}