/* =====================================================================
   The League of Friends of the Yeovil Hospitals (Charity 220038)
   Design pack: Heritage Trust  ·  Palette: Cream & Heritage Gold
   ===================================================================== */

:root{
  --ink:      #1F1A14;
  --soft:     #FBF7EE;
  --accent:   #B08850;
  --accent-2: #7A5A2E;
  --charcoal: #2C2620;
  --grey:     #6B6358;
  --hairline: #E5DDD0;
  --hairline-strong: #D5C9B2;
  --measure: 68ch;
  --header-h: 76px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html, body{ background:var(--soft); color:var(--ink); }
body{
  margin:0;
  font-family:'Work Sans', ui-sans-serif, system-ui, -apple-system, sans-serif;
  font-size:17px;
  line-height:1.62;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--accent-2); text-decoration:underline; text-decoration-thickness:1px; text-underline-offset:3px; }
a:hover{ color:var(--ink); }
button{ font-family:inherit; }

/* Focus */
:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:2px;
}

/* Typography utilities */
.font-display{ font-family:'Tenor Sans', Georgia, 'Times New Roman', serif; font-weight:400; line-height:1.08; letter-spacing:-0.005em; }
.font-mono{ font-family:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; }

/* Eyebrow label */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:0.85rem;
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:28px;
  height:1px;
  background:var(--accent);
}
.eyebrow--centered{ justify-content:center; }
.eyebrow--light{ color:var(--soft); }
.eyebrow--light::before{ background:var(--soft); }

/* Pull-quote */
.pull-quote{
  font-family:'Tenor Sans', Georgia, serif;
  font-style:italic;
  font-size:clamp(1.5rem, 2.6vw, 2.1rem);
  line-height:1.32;
  color:var(--ink);
  margin:2.25rem 0;
  padding-left:2.5rem;
  position:relative;
  max-width:54ch;
}
.pull-quote::before{
  content:"\201C";
  position:absolute;
  left:0;
  top:-0.2em;
  font-size:4em;
  line-height:1;
  color:var(--accent);
  font-family:'Tenor Sans', serif;
}
.pull-quote cite{
  display:block;
  margin-top:0.85rem;
  font-style:normal;
  font-size:0.72em;
  font-family:'JetBrains Mono', monospace;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
}

/* Drop cap */
.drop-cap::first-letter{
  font-family:'Tenor Sans', Georgia, serif;
  float:left;
  font-size:4.1em;
  line-height:0.85;
  padding:0.06em 0.12em 0 0;
  margin-right:6px;
  color:var(--accent-2);
  font-weight:400;
}

/* Glass card */
.glass-card{
  background:rgba(255,255,255,0.62);
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
  border:1px solid rgba(229,221,208,0.85);
  border-radius:6px;
  padding:24px;
  box-shadow:0 14px 40px -28px rgba(31,26,20,0.32);
}

/* Organic blob */
.organic-shape{
  border-radius:71% 29% 64% 36% / 41% 60% 40% 59%;
  background:rgba(176,136,80,0.10);
  pointer-events:none;
}
.organic-shape--alt{ border-radius:34% 66% 39% 61% / 62% 43% 57% 38%; }

/* Hairline rule used widely */
.hr-rule{
  border:0;
  border-top:1px solid var(--hairline);
  margin:0;
}

/* Skip link */
.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  background:var(--ink);
  color:var(--soft);
  padding:12px 16px;
  z-index:200;
  text-decoration:none;
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  letter-spacing:0.08em;
}
.skip-link:focus{ left:16px; top:16px; }

/* ---------- Header (top hide-on-scroll-down) ---------- */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:90;
  background:rgba(251,247,238,0.94);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transform:translateY(0);
  transition:transform 380ms var(--ease), border-color 200ms ease, background 200ms ease;
}
.site-header.is-hidden{ transform:translateY(-110%); }
.site-header.has-shadow{ border-bottom-color:var(--hairline); }
.header-inner{
  max-width:1320px;
  margin:0 auto;
  padding:0 24px;
  height:var(--header-h);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}
.brand-mark{
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--ink);
}
.brand-mark img{ width:38px; height:38px; }
.brand-wordmark{
  font-family:'Tenor Sans', serif;
  font-size:14px;
  letter-spacing:0.06em;
  line-height:1.1;
  max-width:160px;
}
.brand-wordmark span{ display:block; color:var(--grey); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; margin-top:2px; font-family:'JetBrains Mono', monospace; }
.primary-nav{ display:flex; align-items:center; justify-content:center; gap:28px; }
.primary-nav a{
  font-family:'Work Sans', sans-serif;
  font-size:14.5px;
  font-weight:500;
  letter-spacing:0.01em;
  text-decoration:none;
  color:var(--ink);
  position:relative;
  padding:6px 0;
}
.primary-nav a[aria-current="page"]::after,
.primary-nav a:hover::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height:1px;
  background:var(--accent);
}
.primary-nav a[aria-current="page"]{ color:var(--accent-2); }
.header-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:11px 20px;
  background:var(--ink);
  color:var(--soft);
  text-decoration:none;
  font-size:13.5px;
  letter-spacing:0.04em;
  border-radius:2px;
  transition:background 180ms ease, transform 180ms ease;
}
.header-cta:hover{ background:var(--accent-2); color:var(--soft); transform:translateY(-1px); }
.hamburger{
  display:none;
  background:transparent;
  border:1px solid var(--hairline);
  width:44px; height:44px;
  border-radius:2px;
  font-size:18px;
  color:var(--ink);
  cursor:pointer;
}

/* Mobile menu drawer */
.mobile-drawer{
  position:fixed;
  inset:0;
  background:var(--soft);
  z-index:95;
  padding:88px 28px 40px;
  transform:translateY(-100%);
  transition:transform 360ms var(--ease);
  overflow-y:auto;
  display:flex; flex-direction:column;
  visibility:hidden;
}
.mobile-drawer.is-open{ transform:translateY(0); visibility:visible; }
.mobile-drawer a{
  display:block;
  padding:14px 0;
  border-bottom:1px solid var(--hairline);
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--ink);
  text-decoration:none;
}
.mobile-drawer .secondary{
  margin-top:24px;
  display:grid;
  gap:8px;
}
.mobile-drawer .secondary a{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--grey);
  border-bottom:none;
  padding:6px 0;
}

@media (max-width: 900px){
  .primary-nav, .header-cta{ display:none; }
  .hamburger{ display:inline-flex; align-items:center; justify-content:center; margin-left:auto; }
  .header-inner{ grid-template-columns:auto auto; }
  .brand-wordmark{ font-size:13px; max-width:200px; }
}

/* ---------- Generic page scaffolding ---------- */
main{ padding-top:var(--header-h); }
.container{ max-width:1240px; margin:0 auto; padding:0 24px; }
.container--narrow{ max-width:880px; }
.container--wide{ max-width:1400px; }

section{ padding:64px 0; }
.section-tight{ padding:48px 0; }
.section-lg{ padding:96px 0; }
.section-dark{
  background:var(--charcoal);
  color:var(--soft);
}
.section-dark a{ color:var(--soft); }
.section-dark .eyebrow{ color:var(--accent); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 24px;
  font-size:14.5px;
  letter-spacing:0.02em;
  text-decoration:none;
  border-radius:2px;
  font-weight:500;
  cursor:pointer;
  border:1px solid transparent;
  transition:background 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms ease;
}
.btn-primary{
  background:var(--ink);
  color:var(--soft);
}
.btn-primary:hover{ background:var(--accent-2); color:var(--soft); transform:translateY(-1px); }
.btn-secondary{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn-secondary:hover{ background:var(--ink); color:var(--soft); }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--hairline);
}
.btn-ghost:hover{ border-color:var(--ink); }
.btn-accent{
  background:var(--accent);
  color:var(--ink);
}
.btn-accent:hover{ background:var(--accent-2); color:var(--soft); }
.btn-block{ width:100%; justify-content:center; }

/* ---------- Hero (typographic) ---------- */
.hero-type{
  position:relative;
  min-height:80vh;
  padding:120px 0 80px;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-type__blob{
  position:absolute;
  width:62vmin;
  height:62vmin;
  right:-12vmin;
  top:6vmin;
  z-index:0;
}
.hero-type__blob--2{
  width:38vmin; height:38vmin;
  left:-10vmin; bottom:-10vmin;
  background:rgba(176,136,80,0.07);
}
.hero-type__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,260px);
  gap:48px;
  align-items:end;
}
.hero-type h1{
  font-family:'Tenor Sans', Georgia, serif;
  font-weight:400;
  font-size:clamp(3.4rem, 6.5vw, 7.4rem);
  line-height:1.02;
  letter-spacing:-0.012em;
  margin:0.4em 0 0.5em;
  color:var(--ink);
  max-width:18ch;
}
.hero-type__lede{
  font-size:1.12rem;
  max-width:46ch;
  color:var(--ink);
  margin-bottom:1.6rem;
}
.hero-type__ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:1.6rem;
}
.hero-type__meta{
  border-left:1px solid var(--hairline-strong);
  padding-left:24px;
  display:grid;
  gap:18px;
}
.hero-type__meta dt{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:4px;
}
.hero-type__meta dd{
  margin:0;
  font-family:'Tenor Sans', serif;
  font-size:1.15rem;
  color:var(--ink);
}

@media (max-width: 800px){
  .hero-type{ min-height:auto; padding:96px 0 56px; }
  .hero-type__grid{ grid-template-columns:1fr; gap:32px; }
  .hero-type__meta{ border-left:none; border-top:1px solid var(--hairline-strong); padding:24px 0 0; }
}

/* Floating glass cards on hero */
.hero-floating{
  margin-top:-40px;
  position:relative;
  z-index:3;
}
.hero-floating-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  max-width:1080px;
  margin:0 auto;
}
@media(max-width:680px){ .hero-floating-grid{ grid-template-columns:1fr; } }
.hero-floating .glass-card .stat-num{
  font-family:'Tenor Sans', serif;
  font-size:clamp(2rem, 4.2vw, 3rem);
  display:block;
  line-height:1;
  color:var(--accent-2);
}
.hero-floating .glass-card p{ margin:8px 0 0; color:var(--ink); font-size:0.95rem; }

/* ---------- Page heading block (inner pages) ---------- */
.page-heading{
  padding:64px 0 56px;
  border-bottom:1px solid var(--hairline);
}
.page-heading h1{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(2.6rem, 5vw, 4.6rem);
  line-height:1.06;
  margin:0.5em 0 0.6em;
  max-width:24ch;
}
.page-heading .standfirst{
  font-size:1.18rem;
  max-width:62ch;
  color:var(--grey);
}

/* Breadcrumb */
.breadcrumb{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--grey);
}
.breadcrumb a{
  color:var(--grey);
  text-decoration:none;
  border-bottom:1px solid transparent;
}
.breadcrumb a:hover{ color:var(--accent-2); border-bottom-color:var(--accent); }
.breadcrumb-sep{ margin:0 0.6em; color:var(--hairline-strong); }

/* ---------- Stats strip ---------- */
.stat-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
}
.stat-strip .stat{
  padding:36px 28px;
  border-right:1px solid var(--hairline);
}
.stat-strip .stat:last-child{ border-right:none; }
.stat-strip .counter{
  font-family:'Tenor Sans', serif;
  font-size:clamp(2.4rem, 4.4vw, 3.4rem);
  line-height:1;
  color:var(--accent-2);
  display:block;
}
.stat-strip .stat-label{
  display:block;
  margin-top:12px;
  font-size:0.92rem;
  color:var(--grey);
  max-width:30ch;
}
@media(max-width:780px){
  .stat-strip{ grid-template-columns:repeat(2,1fr); }
  .stat-strip .stat:nth-child(2){ border-right:none; }
  .stat-strip .stat:nth-child(1),
  .stat-strip .stat:nth-child(2){ border-bottom:1px solid var(--hairline); }
}

/* ---------- Value cards (mission overview) ---------- */
.values-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:24px;
}
.value-card{
  grid-column:span 4;
  background:transparent;
  padding:32px 28px;
  border:1px solid var(--hairline);
  border-radius:4px;
}
.value-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.55rem;
  line-height:1.18;
  margin:14px 0 12px;
}
.value-card p{ color:var(--grey); margin:0; }
.value-card.value-card--accent{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--ink);
}
.value-card.value-card--accent p{ color:rgba(31,26,20,0.84); }
.value-card.value-card--wide{ grid-column:span 6; }
.value-card.value-card--narrow{ grid-column:span 3; }
.value-card.value-card--right{ text-align:right; }
.value-card.value-card--right .eyebrow{ justify-content:flex-end; }
.value-card.value-card--right .eyebrow::before{ display:none; }
.value-card.value-card--right .eyebrow::after{
  content:"";
  display:inline-block;
  width:28px; height:1px; background:var(--accent);
  margin-left:0.85rem;
}
@media(max-width:980px){
  .value-card, .value-card.value-card--wide, .value-card.value-card--narrow{ grid-column:span 6; }
}
@media(max-width:620px){
  .value-card, .value-card.value-card--wide, .value-card.value-card--narrow{ grid-column:span 12; }
}

/* ---------- Programmes grid ---------- */
.programme-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.programme-card{
  border-top:1px solid var(--ink);
  padding-top:18px;
  display:block;
  text-decoration:none;
  color:var(--ink);
}
.programme-card img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:2px;
  margin-top:14px;
}
.programme-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.45rem;
  margin:16px 0 8px;
  line-height:1.18;
}
.programme-card p{ color:var(--grey); margin:0 0 12px; font-size:0.96rem; }
.programme-card .read-more{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--accent-2);
  border-bottom:1px solid var(--accent);
}
.programme-card:hover h3{ color:var(--accent-2); }
@media(max-width:900px){ .programme-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .programme-grid{ grid-template-columns:1fr; } }

/* ---------- Donation campaign block ---------- */
.campaign-block{
  background:var(--charcoal);
  color:var(--soft);
  padding:80px 0;
}
.campaign-block .grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:center;
}
.campaign-block img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:2px;
}
.campaign-block h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(2rem, 3.6vw, 3rem);
  line-height:1.1;
  margin:18px 0 18px;
  color:var(--soft);
}
.campaign-block .lede{ color:rgba(251,247,238,0.78); }
.progress-rail{
  margin:24px 0 12px;
  height:6px;
  background:rgba(229,221,208,0.16);
  border-radius:3px;
  overflow:hidden;
  position:relative;
}
.progress-rail .progress-fill{
  height:100%;
  width:0;
  background:var(--accent);
  transition:width 1600ms var(--ease);
}
.progress-meta{
  display:flex;
  justify-content:space-between;
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.08em;
  color:rgba(251,247,238,0.72);
}
.progress-meta strong{ color:var(--soft); font-weight:500; }
@media(max-width:820px){ .campaign-block .grid{ grid-template-columns:1fr; gap:32px; } }

/* ---------- Volunteer dark section ---------- */
.volunteer-dark .roles{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.volunteer-dark .role-card{
  border-top:1px solid rgba(229,221,208,0.22);
  padding-top:18px;
}
.volunteer-dark .role-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.45rem;
  color:var(--soft);
  margin:14px 0 6px;
}
.volunteer-dark .role-card .commit{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--accent);
  display:block;
  margin-bottom:14px;
}
.volunteer-dark .role-card p{ color:rgba(251,247,238,0.74); }
@media(max-width:900px){ .volunteer-dark .roles{ grid-template-columns:1fr; } }

/* ---------- Story cards ---------- */
.stories-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.story-card{
  display:block;
  text-decoration:none;
  color:var(--ink);
}
.story-card img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  border-radius:2px;
}
.story-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.4rem;
  margin:18px 0 10px;
  line-height:1.2;
}
.story-card .who{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--grey);
  margin-bottom:6px;
}
.story-card p{ color:var(--grey); font-size:0.95rem; margin:0 0 12px; }
@media(max-width:880px){ .stories-grid{ grid-template-columns:1fr; } }

/* ---------- Bar chart (CSS-only) ---------- */
.bar-chart{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:16px;
  align-items:end;
  padding:24px 0 36px;
}
.bar-chart__y{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--grey);
  text-align:right;
  height:280px;
  padding-bottom:24px;
}
.bar-chart__plot{
  height:280px;
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:14px;
  align-items:end;
  border-bottom:1px solid var(--hairline);
  padding-bottom:0;
  position:relative;
}
.bar{
  background:var(--accent);
  position:relative;
  height:0;
  transition:height 1400ms var(--ease);
  border-radius:2px 2px 0 0;
}
.bar::after{
  content:attr(data-label);
  position:absolute;
  bottom:-24px;
  left:0; right:0;
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--grey);
  letter-spacing:0.08em;
}
.bar::before{
  content:attr(data-value);
  position:absolute;
  top:-22px;
  left:0; right:0;
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--accent-2);
}
@media(max-width:600px){
  .bar-chart{ grid-template-columns:48px 1fr; }
  .bar-chart__plot, .bar-chart__y{ height:220px; }
}

/* ---------- Events row ---------- */
.event-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.event-card{
  display:grid;
  grid-template-columns:96px 1fr;
  gap:18px;
  padding:24px 0;
  border-top:1px solid var(--ink);
  text-decoration:none;
  color:var(--ink);
}
.event-card .date{
  font-family:'Tenor Sans', serif;
}
.event-card .date .day{
  display:block;
  font-size:2.4rem;
  line-height:1;
  color:var(--accent-2);
}
.event-card .date .mo{
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  color:var(--grey);
  margin-top:6px;
  text-transform:uppercase;
}
.event-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.2rem;
  margin:0 0 6px;
  line-height:1.22;
}
.event-card .venue{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
  display:block;
  margin-bottom:8px;
}
.event-card p{ color:var(--grey); margin:0; font-size:0.92rem; }
@media(max-width:900px){ .event-row{ grid-template-columns:1fr; } }

/* ---------- News cards ---------- */
.news-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.news-card{
  text-decoration:none;
  color:var(--ink);
  display:block;
}
.news-card img{
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
}
.news-card .date-eyebrow{
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin:18px 0 8px;
}
.news-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.4rem;
  line-height:1.2;
  margin:0 0 10px;
}
.news-card p{ color:var(--grey); font-size:0.95rem; margin:0; }
.news-card:hover h3{ color:var(--accent-2); }
@media(max-width:880px){ .news-row{ grid-template-columns:1fr; } }

/* ---------- Testimonials carousel ---------- */
.testimonial-region{
  position:relative;
}
.testimonial-track{
  display:grid;
  position:relative;
}
.testimonial-slide{
  grid-column:1;
  grid-row:1;
  padding:0 8%;
  opacity:0;
  transition:opacity 600ms var(--ease);
  pointer-events:none;
}
.testimonial-slide.is-active{ opacity:1; pointer-events:auto; }
.testimonial-slide blockquote{
  font-family:'Tenor Sans', serif;
  font-style:italic;
  font-size:clamp(1.4rem, 2.6vw, 2rem);
  line-height:1.36;
  margin:0 0 24px;
  text-align:center;
  max-width:60ch;
  margin-left:auto;
  margin-right:auto;
}
.testimonial-slide .attribution{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}
.testimonial-slide .attribution img{
  width:48px; height:48px;
  border-radius:50%;
  object-fit:cover;
}
.testimonial-slide .attribution .name{ font-family:'Tenor Sans', serif; font-size:1.05rem; display:block; }
.testimonial-slide .attribution .who{ font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.12em; color:var(--grey); text-transform:uppercase; }
.testimonial-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:36px;
  padding:0 4%;
}
.testimonial-arrow{
  width:44px; height:44px;
  background:transparent;
  border:1px solid var(--hairline-strong);
  border-radius:50%;
  cursor:pointer;
  color:var(--ink);
  transition:background 180ms ease, border-color 180ms ease;
}
.testimonial-arrow:hover{ background:var(--ink); color:var(--soft); border-color:var(--ink); }
.testimonial-dots{ display:flex; gap:8px; }
.testimonial-dot{
  background:transparent;
  border:1px solid var(--hairline-strong);
  width:10px; height:10px;
  border-radius:50%;
  padding:0;
  cursor:pointer;
}
.testimonial-dot[aria-current="true"]{ background:var(--accent); border-color:var(--accent); }
.sr-live{
  position:absolute;
  left:-9999px;
  width:1px; height:1px;
  overflow:hidden;
}

/* ---------- Partners marquee ---------- */
.partner-marquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.partner-track{
  display:flex;
  gap:64px;
  align-items:center;
  width:max-content;
  animation:marquee 38s linear infinite;
}
.partner-track img{
  width:160px;
  height:48px;
  object-fit:contain;
  opacity:0.78;
  filter:saturate(0.4);
}
@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
@media(prefers-reduced-motion:reduce){
  .partner-track{ animation:none; }
}

/* ---------- Newsletter card ---------- */
.newsletter-card{
  max-width:760px;
  margin:0 auto;
  padding:36px;
  text-align:center;
}
.newsletter-card h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(1.6rem, 2.6vw, 2.2rem);
  margin:8px 0 12px;
}
.newsletter-card p{ color:var(--grey); max-width:50ch; margin:0 auto 22px; }
.newsletter-form{
  display:flex;
  gap:10px;
  max-width:520px;
  margin:0 auto;
}
.newsletter-form input{
  flex:1;
  padding:14px 16px;
  border:1px solid var(--hairline-strong);
  background:var(--soft);
  font:inherit;
  border-radius:2px;
}
.newsletter-form input:focus{
  outline:none;
  border-color:var(--accent);
}
@media(max-width:520px){
  .newsletter-form{ flex-direction:column; }
}

/* ---------- Footer (big-type community farewell) ---------- */
.site-footer{
  background:var(--soft);
  border-top:1px solid var(--hairline);
  padding:96px 0 40px;
  position:relative;
}
.footer-headline{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(2.2rem, 4.5vw, 3.8rem);
  line-height:1.06;
  max-width:24ch;
  margin:0 0 64px;
  color:var(--ink);
}
.footer-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:32px;
  border-top:1px solid var(--hairline);
  padding-top:48px;
}
.footer-grid h4{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--accent-2);
  margin:0 0 18px;
}
.footer-grid ul{ list-style:none; padding:0; margin:0; }
.footer-grid li{ margin-bottom:10px; }
.footer-grid a{
  color:var(--ink);
  text-decoration:none;
  font-size:14px;
}
.footer-grid a:hover{ color:var(--accent-2); border-bottom:1px solid var(--accent); }
.footer-col{ grid-column:span 2; }
.footer-col--wide{ grid-column:span 4; }
.footer-col--brand{ grid-column:span 4; }
.footer-brand-line{
  font-family:'Tenor Sans', serif;
  font-size:1.18rem;
  line-height:1.4;
  color:var(--ink);
  margin-bottom:18px;
}
.footer-meta{
  font-size:13.5px;
  color:var(--grey);
  line-height:1.7;
}
.footer-meta strong{ color:var(--ink); font-weight:500; }
.footer-newsletter{
  margin-top:32px;
}
.footer-newsletter input{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--hairline-strong);
  background:transparent;
  font:inherit;
  border-radius:2px;
}
.footer-newsletter button{
  margin-top:10px;
}
.footer-base{
  border-top:1px solid var(--hairline);
  margin-top:64px;
  padding-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  justify-content:space-between;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--grey);
}
.footer-base a{ color:var(--grey); text-decoration:none; }
.footer-base a:hover{ color:var(--ink); }
.footer-socials{
  display:flex;
  gap:14px;
}
.footer-socials a{
  font-size:16px;
  width:38px; height:38px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--hairline-strong);
  border-radius:50%;
  color:var(--ink);
  transition:background 180ms ease, color 180ms ease;
}
.footer-socials a:hover{ background:var(--ink); color:var(--soft); border-color:var(--ink); }

@media(max-width:980px){
  .footer-col, .footer-col--wide, .footer-col--brand{ grid-column:span 6; }
}
@media(max-width:560px){
  .footer-col, .footer-col--wide, .footer-col--brand{ grid-column:span 12; }
  .footer-headline{ margin-bottom:36px; }
}

/* ---------- Reveal animation ---------- */
.reveal{
  opacity:0;
  transform:translateY(16px);
  transition:opacity 700ms var(--ease), transform 700ms var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .progress-fill{ transition:none; }
  .bar{ transition:none; height:auto !important; }
  .site-header{ transition:none; }
}

/* ---------- Modal (deception) ---------- */
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:300;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity 220ms ease;
}
.modal-backdrop.is-open{ opacity:1; pointer-events:auto; }
.modal-card{
  background:var(--soft);
  border-left:4px solid var(--accent);
  border-radius:2px;
  padding:36px 36px 32px;
  max-width:520px;
  width:100%;
  box-shadow:0 30px 80px -20px rgba(31,26,20,0.45);
  transform:translateY(12px);
  transition:transform 260ms var(--ease);
}
.modal-backdrop.is-open .modal-card{ transform:translateY(0); }
.modal-card h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.65rem;
  margin:0 0 12px;
  line-height:1.18;
  padding-right:24px;
}
.modal-card p{ color:var(--grey); margin:0 0 14px; }
.modal-card p:last-of-type{ margin-bottom:24px; }
.modal-card .receipt-ref{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.08em;
  background:rgba(176,136,80,0.10);
  padding:8px 12px;
  border-radius:2px;
  display:inline-block;
  color:var(--accent-2);
  margin-bottom:18px;
}
.modal-card .close{
  position:absolute;
  top:14px; right:14px;
  background:transparent;
  border:1px solid var(--hairline);
  width:36px; height:36px;
  border-radius:50%;
  cursor:pointer;
  color:var(--ink);
}
.modal-card{ position:relative; }
.modal-card .btn{ margin-top:4px; }

/* ---------- Forms ---------- */
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.form-field{ display:flex; flex-direction:column; gap:6px; }
.form-field--full{ grid-column:span 2; }
.form-field label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--accent-2);
}
.form-field input,
.form-field select,
.form-field textarea{
  padding:13px 14px;
  font:inherit;
  background:var(--soft);
  border:1px solid var(--hairline-strong);
  border-radius:2px;
  color:var(--ink);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--accent);
}
.form-field textarea{ min-height:140px; resize:vertical; }
.form-field .hint{ color:var(--grey); font-size:12.5px; }
.checkbox-row{ display:flex; gap:10px; align-items:flex-start; font-size:14px; color:var(--grey); }
@media(max-width:680px){
  .form-grid{ grid-template-columns:1fr; }
  .form-field--full{ grid-column:span 1; }
}

/* ---------- Donate tiles ---------- */
.amount-tiles{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.amount-tile{
  background:transparent;
  border:1px solid var(--hairline-strong);
  padding:18px 8px;
  font-family:'Tenor Sans', serif;
  font-size:1.6rem;
  color:var(--ink);
  cursor:pointer;
  border-radius:2px;
  position:relative;
}
.amount-tile:hover{ border-color:var(--accent); }
.amount-tile.is-selected{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--ink);
}
.amount-tile.is-selected::after{
  content:"\f00c";
  font-family:'Font Awesome 6 Free';
  font-weight:900;
  position:absolute;
  top:8px; right:10px;
  font-size:12px;
  color:var(--accent-2);
}
.amount-tile .impact{
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--grey);
  margin-top:8px;
}
.amount-tile.is-selected .impact{ color:var(--accent-2); }
.toggle-row{
  display:inline-flex;
  border:1px solid var(--hairline-strong);
  border-radius:2px;
  overflow:hidden;
  margin-top:10px;
}
.toggle-row button{
  padding:10px 18px;
  background:transparent;
  border:none;
  font:inherit;
  cursor:pointer;
  color:var(--grey);
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.1em;
  text-transform:uppercase;
}
.toggle-row button.is-active{ background:var(--ink); color:var(--soft); }
@media(max-width:520px){
  .amount-tiles{ grid-template-columns:repeat(2,1fr); }
}

/* ---------- FAQ accordion ---------- */
.faq-item{
  border-top:1px solid var(--hairline);
  padding:0;
}
.faq-item:last-child{ border-bottom:1px solid var(--hairline); }
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:22px 56px 22px 0;
  font-family:'Tenor Sans', serif;
  font-size:1.25rem;
  color:var(--ink);
  position:relative;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"\2b";
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  font-family:'Font Awesome 6 Free';
  font-weight:900;
  color:var(--accent);
  font-size:14px;
  transition:transform 220ms ease;
}
.faq-item[open] summary::after{ content:"\f068"; }
.faq-item .answer{
  padding:0 0 26px;
  color:var(--grey);
  max-width:68ch;
}

/* ---------- Timeline ---------- */
.timeline{
  position:relative;
  padding-left:32px;
}
.timeline::before{
  content:"";
  position:absolute;
  left:8px;
  top:8px;
  bottom:8px;
  width:1px;
  background:var(--hairline-strong);
}
.timeline-item{
  position:relative;
  padding:0 0 36px 24px;
  display:grid;
  grid-template-columns:100px 1fr;
  gap:24px;
}
.timeline-item::before{
  content:"";
  position:absolute;
  left:-28px;
  top:10px;
  width:11px; height:11px;
  border-radius:50%;
  background:var(--accent);
  border:2px solid var(--soft);
  box-shadow:0 0 0 1px var(--accent);
}
.timeline-item .year{
  font-family:'Tenor Sans', serif;
  font-size:1.6rem;
  color:var(--accent-2);
  line-height:1;
}
.timeline-item .body h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.18rem;
  margin:0 0 6px;
}
.timeline-item .body p{
  color:var(--grey);
  margin:0;
  font-size:0.96rem;
}
@media(max-width:600px){
  .timeline-item{ grid-template-columns:1fr; gap:6px; }
}

/* ---------- Trustee grid ---------- */
.trustee-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
}
.trustee-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:2px;
}
.trustee-card h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.2rem;
  margin:14px 0 4px;
}
.trustee-card .role{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--accent);
  display:block;
  margin-bottom:8px;
}
.trustee-card p{ color:var(--grey); font-size:0.92rem; margin:0; }
.trustee-email{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:11.5px;
  color:var(--accent-2);
  text-decoration:none;
  margin-bottom:10px;
  word-break:break-all;
}
.trustee-email:hover{ color:var(--ink); border-bottom:1px solid var(--accent); }
.trustee-list{
  list-style:none;
  padding:0;
  margin:18px 0 0;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px 32px;
  max-width:64ch;
}
.trustee-list li{ font-size:0.92rem; color:var(--grey); }
.trustee-list strong{ color:var(--ink); font-weight:500; }
.trustee-list a{ color:var(--accent-2); text-decoration:none; }
.trustee-list a:hover{ color:var(--ink); border-bottom:1px solid var(--accent); }
@media(max-width:880px){ .trustee-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .trustee-list{ grid-template-columns:1fr; } }
@media(max-width:520px){ .trustee-grid{ grid-template-columns:1fr; } }

/* ---------- Theory of change (3 blocks + arrows) ---------- */
.theory-of-change{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:18px;
  align-items:stretch;
  margin:48px 0;
}
.toc-block{
  background:rgba(176,136,80,0.10);
  border-left:3px solid var(--accent);
  padding:28px;
}
.toc-block .label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--accent-2);
  display:block;
  margin-bottom:14px;
}
.toc-block h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.3rem;
  line-height:1.2;
  margin:0 0 8px;
}
.toc-block p{ color:var(--grey); margin:0; font-size:0.95rem; }
.toc-arrow{
  align-self:center;
  font-size:22px;
  color:var(--accent);
}
@media(max-width:860px){
  .theory-of-change{ grid-template-columns:1fr; }
  .toc-arrow{ transform:rotate(90deg); justify-self:center; }
}

/* ---------- In-page CTA strip ---------- */
.cta-strip{
  border:1px solid var(--hairline);
  padding:48px;
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:32px;
  align-items:center;
  background:rgba(255,255,255,0.5);
}
.cta-strip h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(1.4rem, 3vw, 2rem);
  margin:8px 0 12px;
  line-height:1.18;
}
.cta-strip p{ color:var(--grey); margin:0; max-width:46ch; }
.cta-strip .actions{
  display:flex; gap:14px; justify-content:flex-end; flex-wrap:wrap;
}
@media(max-width:780px){
  .cta-strip{ grid-template-columns:1fr; padding:32px; }
  .cta-strip .actions{ justify-content:flex-start; }
}

/* ---------- In-short box (legal) ---------- */
.in-short{
  background:rgba(176,136,80,0.10);
  border-left:3px solid var(--accent);
  padding:28px 32px;
  margin:24px 0 48px;
}
.in-short h2{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--accent-2);
  margin:0 0 14px;
}
.in-short ul{ margin:0; padding-left:18px; color:var(--ink); }
.in-short li{ margin-bottom:6px; }

/* ---------- Resource list ---------- */
.resource-list, .report-list{
  border-top:1px solid var(--hairline);
}
.resource-list .item, .report-list .item{
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:24px;
  align-items:center;
  padding:22px 0;
  border-bottom:1px solid var(--hairline);
}
.resource-list .year, .report-list .year{
  font-family:'Tenor Sans', serif;
  font-size:1.6rem;
  color:var(--accent-2);
  line-height:1;
}
.resource-list h3, .report-list h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.2rem;
  margin:0 0 4px;
  line-height:1.22;
}
.resource-list .meta, .report-list .meta{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
}
@media(max-width:680px){
  .resource-list .item, .report-list .item{ grid-template-columns:1fr; }
  .resource-list .actions, .report-list .actions{ justify-self:flex-start; }
}

/* ---------- Cookie banner ---------- */
.cookie-banner{
  position:fixed;
  bottom:24px;
  left:24px; right:24px;
  max-width:520px;
  background:var(--charcoal);
  color:var(--soft);
  padding:22px 26px;
  z-index:80;
  border-left:3px solid var(--accent);
  border-radius:2px;
  box-shadow:0 24px 60px -10px rgba(31,26,20,0.4);
  transform:translateY(20px);
  opacity:0;
  pointer-events:none;
  transition:opacity 320ms ease, transform 320ms var(--ease);
}
.cookie-banner.is-open{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.cookie-banner h3{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 8px;
}
.cookie-banner p{ font-size:14px; color:rgba(251,247,238,0.84); margin:0 0 16px; line-height:1.55; }
.cookie-banner .cookie-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner a{ color:var(--soft); border-bottom:1px solid var(--accent); }
.cookie-banner button{
  padding:10px 16px;
  border-radius:2px;
  font-family:'JetBrains Mono', monospace;
  font-size:11.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  cursor:pointer;
  border:1px solid var(--hairline);
}
.cookie-banner button.primary{ background:var(--accent); border-color:var(--accent); color:var(--ink); }
.cookie-banner button.ghost{ background:transparent; color:var(--soft); }
@media(max-width:560px){
  .cookie-banner{ left:12px; right:12px; bottom:12px; padding:18px; }
}

/* ---------- Article body ---------- */
.article-body{ max-width:68ch; font-size:1.04rem; color:var(--ink); }
.article-body h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.65rem;
  margin:2em 0 0.6em;
  line-height:1.2;
}
.article-body h3{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:1.25rem;
  margin:1.6em 0 0.4em;
}
.article-body p{ margin:0 0 1.1em; }
.article-body figure{ margin:2em 0; }
.article-body figcaption{
  font-family:'JetBrains Mono', monospace;
  font-size:11.5px;
  letter-spacing:0.08em;
  color:var(--grey);
  margin-top:10px;
}

/* ---------- 404 ---------- */
.four-oh-four{
  min-height:80vh;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  align-items:center;
  gap:64px;
  padding:140px 0 80px;
}
.four-oh-four h1{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(3rem, 6vw, 5rem);
  line-height:1.04;
  margin:0.4em 0;
}
.four-oh-four .suggestions{
  margin-top:36px;
  display:grid;
  gap:12px;
}
.four-oh-four .suggestions a{
  border-top:1px solid var(--hairline);
  padding:14px 0;
  text-decoration:none;
  color:var(--ink);
  font-family:'Tenor Sans', serif;
  font-size:1.1rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.four-oh-four .suggestions a:last-child{ border-bottom:1px solid var(--hairline); }
.four-oh-four .suggestions a:hover{ color:var(--accent-2); }
.four-oh-four img{
  width:100%;
  border-radius:2px;
  aspect-ratio:3/4;
  object-fit:cover;
}
@media(max-width:860px){
  .four-oh-four{ grid-template-columns:1fr; }
}

/* ---------- Misc ---------- */
.center-text{ text-align:center; }
.muted{ color:var(--grey); }
.divider{ border-top:1px solid var(--hairline); margin:64px 0; }
.lead{ font-size:1.18rem; max-width:62ch; color:var(--grey); }

/* Programme detail anchor sections */
.programme-detail{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  padding:64px 0;
  border-bottom:1px solid var(--hairline);
  align-items:center;
}
.programme-detail img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}
.programme-detail h2{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:clamp(1.8rem, 3.6vw, 2.6rem);
  line-height:1.1;
  margin:8px 0 16px;
}
.programme-detail .meta-row{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  margin-top:18px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--grey);
}
.programme-detail .meta-row strong{ color:var(--ink); font-weight:500; }
.programme-detail.reverse{ grid-template-columns:1fr 1fr; }
.programme-detail.reverse .copy{ order:2; }
.programme-detail.reverse img{ order:1; }
@media(max-width:880px){
  .programme-detail, .programme-detail.reverse{ grid-template-columns:1fr; }
  .programme-detail.reverse .copy{ order:initial; }
  .programme-detail.reverse img{ order:initial; }
}

/* Aside / sidebar */
.aside{
  background:rgba(176,136,80,0.08);
  padding:24px 26px;
  border-left:3px solid var(--accent);
  margin:24px 0;
  font-size:0.96rem;
}
.aside h3{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--accent-2);
  margin:0 0 10px;
}
