/* ==========================================================================
   CCAS — Clean Cooking Association of Somalia
   Shared stylesheet · Eco-green palette · No copies from any reference site.
   ========================================================================== */

/* ---------- 1. Tokens ---------- */
:root{
  /* Greens (the heart of the brand) */
  --g-deep:    #0E2818; /* deep forest, almost black-green */
  --g-rich:    #1F4D32; /* rich forest */
  --g-mid:     #3C7D4A; /* vibrant sector green */
  --g-leaf:    #6BA83D; /* leaf green from logo */
  --g-sage:    #A4C77E; /* soft sage for highlights */
  --g-mist:    #DCEAD0; /* pale mint for backgrounds */
  --g-soft:    #E8F2D8; /* even paler mint card bg */

  /* Warm neutrals (paper, cream, parchment — for backgrounds & cards) */
  --paper:     #FBF8EC; /* paper card */
  --ivory:     #F4F0E1; /* main page background */
  --sand:      #EAE3CD; /* sand divider */
  --bone:      #D9D3BC; /* bone neutral */

  /* Earth accents (used sparingly for CTAs and the flame) */
  --terracotta:#C7541F; /* clay terracotta — CCAS flame */
  --terra-deep:#9F4119;
  --amber:     #D4A044; /* warm amber — used on dark hero only */
  --clay-soft: #F0E0D0;

  /* Ink */
  --ink:       #0E1B14;
  --ink-soft:  #3D4A40;
  --ink-mute:  #5C6B5F;

  /* Effects */
  --grad-leaf: linear-gradient(120deg, var(--g-mid) 0%, var(--g-leaf) 100%);
  --grad-warm: linear-gradient(90deg, var(--terracotta) 0%, var(--g-leaf) 100%);
  --shadow-s:  0 1px 2px rgba(14,40,24,.06);
  --shadow-m:  0 8px 24px rgba(14,40,24,.10);
  --shadow-l:  0 32px 80px rgba(14,40,24,.18);
  --pill:      999px;
  --r-md:      14px;
  --r-lg:      22px;
}

/* ---------- 2. Reset & base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--ivory);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .15s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;color:inherit}

/* Selection */
::selection{background:var(--g-leaf);color:#fff}

/* ---------- 3. Admin bar ---------- */
.admin{
  position:fixed;top:0;left:0;right:0;z-index:9998;
  background:var(--g-deep);color:#fff;padding:9px 18px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-family:'Inter';font-size:13px;
  box-shadow:0 1px 0 rgba(255,255,255,.06), 0 8px 24px rgba(0,0,0,.18);
}
.admin .lg{display:flex;align-items:center;gap:8px;font-weight:700;font-family:'Manrope';font-size:13.5px;letter-spacing:.4px}
.admin .lg .d{width:13px;height:13px;border-radius:50%;background:var(--grad-warm)}
.admin .grow{flex:1}
.admin button{background:rgba(255,255,255,.1);color:#fff;padding:6px 13px;border-radius:var(--pill);font-size:12px;font-weight:600;border:1px solid rgba(255,255,255,.16);display:inline-flex;align-items:center;gap:6px;transition:background .15s}
.admin button:hover{background:rgba(255,255,255,.2)}
.admin button.go{background:var(--terracotta);border-color:var(--terracotta)}
.admin button.green{background:var(--g-mid);border-color:var(--g-mid)}
.admin .status{font-size:11.5px;opacity:.85;font-family:'JetBrains Mono';letter-spacing:.04em}

body{padding-top:50px}

/* ---------- 4. Header (sticky) ---------- */
.header{
  position:sticky;top:50px;z-index:90;
  background:rgba(244,240,225,.92);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bone);
}
.header-row{
  max-width:1400px;margin:0 auto;padding:16px 32px;
  display:flex;align-items:center;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  background:var(--paper);border-radius:11px;border:1px solid var(--bone);flex-shrink:0;
}
.brand-name{font-family:'Manrope';font-weight:800;font-size:21px;color:var(--terracotta);letter-spacing:-.5px;line-height:1}
.brand-sub{font-family:'Inter';font-weight:600;font-size:10.5px;color:var(--g-mid);letter-spacing:.6px;text-transform:uppercase;margin-top:3px}

.nav{display:flex;gap:2px;flex:1;margin-left:32px}
.nav a{
  font-family:'Inter';font-weight:500;font-size:14.5px;
  padding:9px 14px;border-radius:9px;color:var(--g-deep);transition:all .15s;position:relative;
}
.nav a:hover{background:var(--g-soft)}
.nav a.active{color:var(--terracotta)}
.nav a.active::after{
  content:"";position:absolute;bottom:-19px;left:14px;right:14px;height:2px;background:var(--terracotta);
}

.header-ctas{display:flex;gap:10px;align-items:center}
.lang{display:inline-flex;background:var(--g-soft);border-radius:var(--pill);padding:3px;font-family:'JetBrains Mono';font-size:10px;font-weight:600;letter-spacing:.1em}
.lang button{padding:5px 10px;border-radius:var(--pill);color:var(--g-deep);opacity:.6;text-transform:uppercase}
.lang button.active{background:var(--g-mid);color:#fff;opacity:1}

.btn-pill{
  padding:11px 22px;border-radius:var(--pill);
  font-family:'Inter';font-weight:600;font-size:13px;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .2s;letter-spacing:.02em;
}
.btn-pill.outline{border:1.5px solid var(--g-deep);color:var(--g-deep)}
.btn-pill.outline:hover{background:var(--g-deep);color:var(--g-mist)}
.btn-pill.solid-g{background:var(--g-mid);color:#fff}
.btn-pill.solid-g:hover{background:var(--g-deep)}
.btn-pill.solid-g .dot{width:8px;height:8px;border-radius:50%;background:var(--terracotta)}
.btn-pill.solid-t{background:var(--terracotta);color:#fff}
.btn-pill.solid-t:hover{background:var(--terra-deep);transform:translateY(-1px);box-shadow:var(--shadow-m)}
.btn-pill.solid-t .dot{width:8px;height:8px;border-radius:50%;background:#fff}
.btn-pill.ghost{color:var(--g-deep)}
.btn-pill.ghost:hover{background:var(--g-soft)}

/* mobile menu trigger */
.menu-toggle{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--bone);background:var(--paper);align-items:center;justify-content:center}
.menu-toggle span{display:block;width:18px;height:2px;background:var(--g-deep);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--g-deep)}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}

/* ---------- 5. Footer ---------- */
.footer{background:var(--g-deep);color:#fff;padding:84px 32px 28px;position:relative;overflow:hidden}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-warm)}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:48px}
.footer h4{font-family:'Manrope';font-weight:700;font-size:13px;color:#fff;margin-bottom:18px;letter-spacing:.06em;text-transform:uppercase}
.footer ul{list-style:none;font-size:14px}
.footer ul li{margin-bottom:10px;color:rgba(255,255,255,.65)}
.footer ul a:hover{color:var(--g-leaf)}
.footer-brand .brand-name{color:var(--g-leaf)}
.footer-brand .brand-sub{color:rgba(255,255,255,.5)}
.footer-brand .brand-mark{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.65);line-height:1.65;margin-top:18px;max-width:300px}
.footer-bot{margin-top:60px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}
.social{display:flex;gap:8px}
.social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .15s}
.social a:hover{background:var(--g-mid)}

/* ---------- 6. Section base ---------- */
.section{padding:120px 32px;position:relative}
.section-inner{max-width:1400px;margin:0 auto}
.section.alt{background:var(--paper)}
.section.green-deep{background:var(--g-deep);color:#fff}
.section.green-rich{background:var(--g-rich);color:#fff}
.section.mist{background:var(--g-mist)}

.eyebrow{
  font-family:'JetBrains Mono';font-size:12px;font-weight:500;color:var(--g-mid);
  letter-spacing:.2em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:14px;margin-bottom:22px;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--g-mid)}
.section.green-deep .eyebrow,.section.green-rich .eyebrow{color:var(--g-sage)}
.section.green-deep .eyebrow::before,.section.green-rich .eyebrow::before{background:var(--g-sage)}

.section-title{
  font-family:'Playfair Display',serif;font-weight:400;font-size:60px;line-height:1.07;
  color:var(--g-deep);margin-bottom:22px;letter-spacing:-1.4px;max-width:920px;
}
.section-title em{font-style:italic;color:var(--terracotta)}
.section.green-deep .section-title,.section.green-rich .section-title{color:#fff}
.section.green-deep .section-title em,.section.green-rich .section-title em{color:var(--g-leaf)}

.section-lead{
  font-size:18px;color:var(--ink-soft);max-width:700px;line-height:1.65;margin-bottom:60px;
}
.section.green-deep .section-lead,.section.green-rich .section-lead{color:rgba(255,255,255,.78)}

.divider-grad{height:3px;background:var(--grad-warm)}

/* ---------- 7. Page hero (used on every interior page) ---------- */
.page-hero{
  background:var(--g-deep);color:#fff;padding:140px 32px 100px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(107,168,61,.18) 0%,transparent 70%);
}
.page-hero-inner{max-width:1400px;margin:0 auto;position:relative;z-index:2;display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end}
.page-hero .eyebrow{color:var(--g-sage)}
.page-hero .eyebrow::before{background:var(--g-sage)}
.page-hero h1{font-family:'Playfair Display',serif;font-weight:400;font-size:78px;line-height:1.02;letter-spacing:-2px;margin-bottom:28px}
.page-hero h1 em{font-style:italic;color:var(--g-leaf)}
.page-hero p{font-size:19px;color:rgba(255,255,255,.78);max-width:560px;line-height:1.65}
.breadcrumb{font-family:'JetBrains Mono';font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.18em;text-transform:uppercase;margin-bottom:24px}
.breadcrumb a:hover{color:var(--g-leaf)}
.breadcrumb span{margin:0 10px;opacity:.5}

/* ---------- 8. Cards (universal) ---------- */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.card{
  background:var(--paper);border:1px solid var(--bone);border-radius:var(--r-lg);padding:32px 28px;
  transition:all .3s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-warm);transform:scaleX(0);transform-origin:left;transition:transform .35s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .num{font-family:'JetBrains Mono';font-size:11px;color:var(--terracotta);letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px}
.card .icon{
  width:56px;height:56px;border-radius:13px;background:var(--g-mid);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;margin-bottom:22px;
  transition:transform .35s;
}
.card:nth-child(2n) .icon{background:var(--g-leaf)}
.card:nth-child(3n) .icon{background:var(--g-deep)}
.card:hover .icon{transform:rotate(-6deg) scale(1.06)}
.card h3{font-family:'Manrope';font-weight:700;font-size:22px;color:var(--g-deep);margin-bottom:12px;line-height:1.25}
.card p{font-size:15px;color:var(--ink-soft);line-height:1.65;margin-bottom:20px}
.card .link{color:var(--terracotta);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;transition:gap .2s;font-family:'Inter';letter-spacing:.04em}
.card .link:hover{gap:10px}

/* ---------- 9. Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.13s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.21s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.29s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.37s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.45s}

/* ---------- 10. Edit mode ---------- */
body.edit-mode [data-edit]{outline:2px dashed var(--terracotta);outline-offset:3px;border-radius:4px;cursor:text}
body.edit-mode [data-edit]:hover{outline-color:var(--terra-deep);background:rgba(199,84,31,.08)}
body.edit-mode [data-edit]:focus{outline:2px solid var(--terracotta);background:rgba(199,84,31,.06)}

/* ---------- 11. Toast & modal ---------- */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(160%);background:var(--g-deep);color:#fff;padding:14px 24px;border-radius:var(--pill);font-family:'Inter';font-weight:600;font-size:13.5px;z-index:10000;transition:transform .3s;box-shadow:var(--shadow-l)}
.toast.show{transform:translateX(-50%) translateY(0)}
.modal{position:fixed;inset:0;background:rgba(14,40,24,.7);display:none;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(8px)}
.modal.open{display:flex}
.modal-box{background:var(--paper);color:var(--ink);border-radius:18px;padding:34px 38px;max-width:520px;width:90%;box-shadow:var(--shadow-l);position:relative}
.modal-box h3{font-family:'Playfair Display',serif;font-size:26px;color:var(--g-deep);margin-bottom:14px;font-weight:400}
.modal-box p{font-size:14.5px;color:var(--ink-soft);line-height:1.6}
.modal-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:var(--g-soft);color:var(--g-deep);display:flex;align-items:center;justify-content:center;font-size:20px}

/* ---------- 12. Forms ---------- */
.field{margin-bottom:20px}
.field label{display:block;font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px;font-weight:500}
.field input,.field select,.field textarea{
  width:100%;padding:14px 18px;border:1px solid var(--bone);border-radius:12px;
  font-size:14.5px;background:var(--paper);color:var(--ink);outline:none;transition:border-color .15s, box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--g-mid);box-shadow:0 0 0 3px rgba(60,125,74,.12)}
.field textarea{min-height:130px;resize:vertical}
.field .help{margin-top:6px;font-size:12px;color:var(--ink-mute)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.row3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.checkbox-row{display:flex;gap:12px;align-items:start;padding:12px 0;font-size:14px;color:var(--ink-soft)}
.checkbox-row input{width:18px;height:18px;margin-top:3px;flex-shrink:0;accent-color:var(--g-mid)}

/* ---------- 13. Stats ---------- */
.stats-bar{padding:80px 32px}
.stats-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:42px}
.sb-num{font-family:'Playfair Display',serif;font-size:84px;color:var(--g-leaf);line-height:1;letter-spacing:-2px;font-weight:400}
.sb-num em{color:var(--terracotta);font-style:normal}
.sb-lbl{font-size:14px;color:rgba(255,255,255,.85);margin-top:14px;line-height:1.5;max-width:240px}
.sb-div{height:2px;width:38px;background:var(--terracotta);margin:18px 0 12px}
.section.green-deep .sb-lbl{color:rgba(255,255,255,.85)}

/* ---------- 14. Mission ---------- */
.mission-grid{display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:center}
.mv-img{
  aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,var(--g-mist) 0%,var(--g-leaf) 100%);
  box-shadow:var(--shadow-l);
  display:flex;align-items:center;justify-content:center;font-size:120px;
  position:relative;
}
.mv-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(14,40,24,.3) 100%)}
.mv-pair{display:grid;gap:24px;margin-top:30px}
.mv-card{background:var(--paper);padding:32px 30px;border-radius:18px;border:1px solid var(--bone)}
.mv-card h4{font-family:'JetBrains Mono';font-size:11px;color:var(--terracotta);letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px;font-weight:500}
.mv-card p{font-family:'Playfair Display',serif;font-size:22px;line-height:1.45;color:var(--g-deep);font-weight:400}
.mv-card.green{background:var(--g-deep);color:#fff;border-color:var(--g-deep)}
.mv-card.green p{color:#fff}
.mv-card.green h4{color:var(--g-sage)}

/* ---------- 15. Resource cards ---------- */
.res-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:42px;background:var(--paper);padding:14px 16px;border-radius:var(--pill);box-shadow:var(--shadow-m);border:1px solid var(--bone)}
.res-search{flex:1;min-width:240px;border:none;outline:none;background:transparent;font-size:14.5px;color:var(--g-deep);padding:6px 14px}
.res-search::placeholder{color:var(--ink-mute)}
.chip{background:transparent;color:var(--g-deep);font-weight:600;font-size:13px;padding:8px 16px;border-radius:var(--pill);transition:all .15s;font-family:'Inter'}
.chip:hover{background:var(--g-soft)}
.chip.active{background:var(--g-deep);color:#fff}
.res-card{background:var(--paper);border-radius:18px;overflow:hidden;border:1px solid var(--bone);transition:all .3s;cursor:pointer}
.res-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.res-thumb{aspect-ratio:1.7/1;background:linear-gradient(135deg,var(--g-mist) 0%,var(--paper) 100%);display:flex;align-items:center;justify-content:center;font-size:46px;color:var(--g-deep);position:relative}
.res-tag{position:absolute;top:14px;left:14px;background:var(--g-deep);color:#fff;padding:5px 11px;border-radius:6px;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.16em;text-transform:uppercase}
.res-body{padding:22px 24px}
.res-title{font-family:'Manrope';font-weight:700;font-size:17px;color:var(--g-deep);line-height:1.35;margin-bottom:10px}
.res-meta{font-family:'JetBrains Mono';font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase}
.res-act{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:18px;border-top:1px solid var(--bone)}
.res-dl{color:var(--terracotta);font-weight:600;font-size:12.5px;display:inline-flex;gap:6px;letter-spacing:.04em}

/* ---------- 16. Events ---------- */
.ev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.ev{background:var(--paper);border-radius:18px;padding:34px 32px;border:1px solid var(--bone);display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;transition:all .3s}
.ev:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.ev-date{background:var(--g-mid);color:#fff;border-radius:14px;padding:18px 14px;text-align:center;width:88px}
.ev-date .d{font-family:'Playfair Display',serif;font-size:42px;line-height:1;font-weight:400}
.ev-date .m{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-top:6px}
.ev-body h3{font-family:'Manrope';font-weight:700;font-size:21px;color:var(--g-deep);margin-bottom:8px}
.ev-meta{font-family:'JetBrains Mono';font-size:11px;color:var(--ink-mute);letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.ev-body p{font-size:14.5px;color:var(--ink-soft);line-height:1.6;margin-bottom:16px}
.ev-link{font-size:13px;color:var(--terracotta);font-weight:600;display:inline-flex;align-items:center;gap:6px;letter-spacing:.04em}

/* ---------- 17. News ---------- */
.news-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:24px}
.nc{background:var(--paper);border-radius:18px;overflow:hidden;border:1px solid var(--bone);display:flex;flex-direction:column;transition:all .3s;cursor:pointer}
.nc:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.nc-thumb{aspect-ratio:1.6/1;background:linear-gradient(135deg,var(--g-mist),var(--g-leaf));display:flex;align-items:center;justify-content:center;font-size:50px;color:rgba(14,40,24,.4)}
.nc.feat .nc-thumb{aspect-ratio:1.5/1;background:linear-gradient(135deg,var(--g-deep),var(--g-rich));color:rgba(255,255,255,.4);font-size:64px}
.nc-body{padding:26px 28px;flex:1;display:flex;flex-direction:column}
.nc-tag{font-family:'JetBrains Mono';font-size:11px;color:var(--terracotta);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.nc-title{font-family:'Manrope';font-weight:700;font-size:19px;color:var(--g-deep);line-height:1.3;margin-bottom:10px}
.nc.feat .nc-title{font-size:28px;font-family:'Playfair Display',serif;font-weight:400}
.nc-dek{font-size:14.5px;color:var(--ink-soft);line-height:1.6;flex:1;margin-bottom:16px}
.nc-foot{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink-mute);font-family:'JetBrains Mono'}

/* ---------- 18. Membership packages ---------- */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pkg{background:rgba(255,255,255,.05);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:36px 32px;transition:all .3s}
.pkg:hover{transform:translateY(-6px);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.pkg.featured{background:linear-gradient(180deg,rgba(107,168,61,.18),rgba(107,168,61,.02));border-color:var(--g-leaf)}
.pkg-tag{font-family:'JetBrains Mono';font-size:10.5px;color:var(--g-leaf);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px;font-weight:500}
.pkg.featured .pkg-tag{color:var(--terracotta)}
.pkg-name{font-family:'Manrope';font-weight:700;font-size:24px;margin-bottom:6px;color:#fff}
.pkg-price{font-family:'Playfair Display',serif;font-size:32px;font-weight:400;color:#fff;margin-bottom:20px}
.pkg-price small{font-size:13px;color:rgba(255,255,255,.55);font-family:'Inter';margin-left:6px}
.pkg ul{list-style:none;font-size:14px}
.pkg li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);display:flex;gap:10px;align-items:start;color:rgba(255,255,255,.85)}
.pkg li::before{content:"✓";color:var(--g-leaf);font-weight:700;flex-shrink:0;margin-top:1px}
.pkg-cta{margin-top:22px;display:block;width:100%;background:#fff;color:var(--g-deep);padding:13px;border-radius:var(--pill);font-weight:600;font-size:13px;letter-spacing:.04em;transition:all .2s;text-align:center}
.pkg-cta:hover{background:var(--g-leaf);color:#fff;transform:translateY(-1px)}
.pkg.featured .pkg-cta{background:var(--terracotta);color:#fff}
.pkg.featured .pkg-cta:hover{background:var(--terra-deep)}

/* ---------- 19. Donate card ---------- */
.donate-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center;max-width:1280px;margin:0 auto}
.donate-impact{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px}
.di{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:22px 20px}
.di .v{font-family:'Playfair Display',serif;font-size:32px;color:var(--g-leaf);font-weight:400;line-height:1}
.di .l{font-size:12.5px;color:rgba(255,255,255,.75);margin-top:8px;line-height:1.4}
.donate-card{background:rgba(255,255,255,.06);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:34px 30px}
.dc-title{font-family:'Manrope';font-weight:700;font-size:20px;margin-bottom:20px;color:#fff}
.dc-toggle{display:flex;background:rgba(255,255,255,.06);border-radius:var(--pill);padding:4px;margin-bottom:18px}
.dc-toggle button{flex:1;padding:9px;color:#fff;border-radius:var(--pill);font-size:13px;font-weight:600;opacity:.6;transition:all .15s}
.dc-toggle button.active{background:var(--terracotta);opacity:1}
.amt{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.amt-btn{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);color:#fff;padding:14px 6px;border-radius:10px;font-family:'Manrope';font-weight:700;font-size:16px;transition:all .15s}
.amt-btn:hover,.amt-btn.sel{background:var(--terracotta);border-color:var(--terracotta)}
.dc-submit{width:100%;background:#fff;color:var(--g-deep);padding:15px;border-radius:var(--pill);font-weight:600;font-size:13.5px;letter-spacing:.04em;margin-top:6px;transition:all .15s}
.dc-submit:hover{background:var(--g-leaf);color:#fff}
.dc-meth{font-family:'JetBrains Mono';font-size:10.5px;color:rgba(255,255,255,.55);text-align:center;margin-top:14px;letter-spacing:.16em}

/* ---------- 20. Newsletter ---------- */
.nl-section{padding:110px 32px;text-align:center;background:linear-gradient(120deg,var(--g-mist) 0%,var(--clay-soft) 100%)}
.nl-inner{max-width:680px;margin:0 auto}
.nl-title{font-family:'Playfair Display',serif;font-weight:400;font-size:46px;line-height:1.1;color:var(--g-deep);margin-bottom:14px;letter-spacing:-1.2px}
.nl-lead{font-size:17px;color:var(--ink-soft);margin-bottom:30px}
.nl-form{display:flex;background:var(--paper);border-radius:var(--pill);padding:6px;box-shadow:var(--shadow-m);max-width:520px;margin:0 auto}
.nl-form input{flex:1;border:none;outline:none;padding:0 22px;font-size:15px;background:transparent;color:var(--g-deep)}
.nl-form button{background:var(--g-deep);color:#fff;padding:14px 26px;border-radius:var(--pill);font-weight:600;font-size:13.5px;letter-spacing:.04em;transition:background .15s}
.nl-form button:hover{background:var(--terracotta)}

/* ---------- 21. Partners strip ---------- */
.pt-section{padding:84px 32px;background:var(--paper);border-top:1px solid var(--bone);border-bottom:1px solid var(--bone)}
.pt-label{text-align:center;font-family:'JetBrains Mono';font-size:11px;color:var(--ink-mute);letter-spacing:.22em;text-transform:uppercase;margin-bottom:32px}
.pt-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:54px;max-width:1200px;margin:0 auto}
.pt{font-family:'Manrope';font-weight:700;font-size:17px;color:var(--ink-mute);text-align:center;opacity:.7;transition:all .2s}
.pt:hover{opacity:1;color:var(--g-deep)}
.pt small{display:block;font-size:11px;font-weight:500;letter-spacing:.06em;margin-top:3px;color:var(--ink-mute);text-transform:uppercase}

/* ---------- 22. Mobile responsive ---------- */
@media (max-width:1080px){
  .nav{display:none}
  .menu-toggle{display:flex}
  .header-row{padding:14px 22px}
  .section{padding:80px 24px}
  .section-title,.page-hero h1{font-size:46px;letter-spacing:-1px}
  .donate-grid,.mission-grid,.page-hero-inner{grid-template-columns:1fr;gap:48px}
  .card-grid-3,.card-grid-2,.card-grid-4,.pkg-grid,.ev-grid,.news-grid,.stats-grid,.donate-impact{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .card-grid-3,.card-grid-2,.card-grid-4,.pkg-grid,.ev-grid,.news-grid,.stats-grid,.donate-impact,.row2,.row3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .section-title,.page-hero h1{font-size:36px}
  .header-ctas .btn-pill{display:none}
  .header-ctas .btn-pill.solid-t{display:inline-flex}
  .lang{display:none}
  .section{padding:64px 20px}
  .page-hero{padding:80px 22px 60px}
}

/* ==========================================================================
   FILM — Chapter system (Verdant Witness · native canvas scenes)
   ========================================================================== */
:root{
  --vw-fg-1: #061A0F;
  --vw-fg-2: #0E2818;
  --vw-leaf: #8FE05A;
  --vw-mint: #C9E5B0;
  --vw-ember:#C7541F;
  --vw-ember-2:#FF9846;
}

/* The film container — overrides ivory body bg with deep forest */
.film{
  background:#06120A;
  color:#fff;
  position:relative;
  overflow:hidden;
}

/* Each chapter is a viewport-tall panel with its own canvas */
.chapter{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:120px 80px;
  isolation:isolate;
}
.chapter .ch-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:0;
  pointer-events:none;
  /* small filmic vignette via box-shadow inset */
}
.chapter::after{
  /* film grain via blend — pure CSS (no media) */
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%, rgba(0,0,0,0) 30%, rgba(0,0,0,0.55) 100%);
  z-index:1;
  mix-blend-mode:multiply;
}

/* Smooth fade between chapters via crossfade overlay layer */
.chapter::before{
  content:"";
  position:absolute;
  left:0;right:0;top:-1px;height:140px;
  background:linear-gradient(180deg, var(--vw-fg-1) 0%, transparent 100%);
  z-index:2;
  pointer-events:none;
  opacity:.85;
}
.chapter:first-of-type::before{display:none}

/* Chapter content */
.ch-content{
  position:relative;
  z-index:3;
  max-width:1280px;
  margin:0 auto;
  width:100%;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:80px;
  align-items:start;
  opacity:0;
  transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.8,.2,1), transform 1s cubic-bezier(.2,.8,.2,1);
}
.ch-content.lit{opacity:1;transform:translateY(0)}

.ch-content .ch-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--vw-mint);
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:32px;
}
.ch-content .ch-eyebrow::before{
  content:"";
  width:32px;height:1px;background:var(--vw-mint);
}

.ch-content .ch-headline{
  font-family:'Playfair Display',serif;
  font-weight:400;
  font-size:clamp(48px, 5.4vw, 96px);
  line-height:1.02;
  letter-spacing:-1.5px;
  color:#fff;
  margin-bottom:28px;
}
.ch-content .ch-headline em{
  font-style:italic;
  color:var(--vw-leaf);
  font-weight:400;
  text-shadow:0 0 60px rgba(143,224,90,.25);
}
.ch-content .ch-headline em.ember{color:var(--vw-ember-2);text-shadow:0 0 60px rgba(199,84,31,.32)}

.ch-content .ch-lead{
  font-size:17px;
  color:rgba(255,255,255,.78);
  max-width:560px;
  line-height:1.65;
  margin-bottom:36px;
}

.ch-stats{
  display:flex;
  flex-direction:column;
  gap:28px;
  padding:24px 0 0;
}
.ch-stats .ch-stat{
  border-left:2px solid var(--vw-mint);
  padding:6px 0 6px 22px;
}
.ch-stats .ch-stat .lbl-mini{
  font-family:'JetBrains Mono',monospace;
  font-size:10.5px;
  letter-spacing:.22em;
  color:var(--vw-mint);
  text-transform:uppercase;
  margin-bottom:8px;
}
.ch-stats .ch-stat .num-big{
  font-family:'Playfair Display',serif;
  font-size:62px;
  line-height:1;
  color:#fff;
  font-weight:400;
}
.ch-stats .ch-stat .num-big .unit{
  font-size:22px;
  color:rgba(255,255,255,.55);
  margin-left:6px;
  font-style:italic;
}
.ch-stats .ch-stat .lbl-desc{
  font-size:14px;
  color:rgba(255,255,255,.7);
  margin-top:10px;
  line-height:1.5;
  max-width:380px;
}

/* Chapter CTA pill (terracotta single CTA color) */
.ch-cta{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:14px 14px 14px 28px;
  border-radius:var(--pill);
  background:var(--vw-ember);
  color:#fff;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  transition:transform .25s, box-shadow .25s, background .25s;
  margin-top:8px;
}
.ch-cta:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(199,84,31,.45);background:#d96838}
.ch-cta .arrow{
  width:30px;height:30px;border-radius:50%;background:#fff;color:var(--vw-ember);
  display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;
}

/* Hopeful chapter (the way out) — light register override */
.chapter.bright{
  --vw-fg-1: #DCEAD0;
  --vw-fg-2: #7BA46C;
}
.chapter.bright .ch-content .ch-headline{color:#0E2818}
.chapter.bright .ch-content .ch-eyebrow{color:#1F4D32}
.chapter.bright .ch-content .ch-eyebrow::before{background:#1F4D32}
.chapter.bright .ch-content .ch-lead{color:rgba(14,40,24,.78)}
.chapter.bright .ch-stats .ch-stat{border-left-color:#1F4D32}
.chapter.bright .ch-stats .ch-stat .lbl-mini{color:#1F4D32}
.chapter.bright .ch-stats .ch-stat .num-big{color:#0E2818}
.chapter.bright .ch-stats .ch-stat .num-big .unit{color:rgba(14,40,24,.5)}
.chapter.bright .ch-stats .ch-stat .lbl-desc{color:rgba(14,40,24,.7)}
.chapter.bright::before{background:linear-gradient(180deg,#06120A 0%, transparent 100%);opacity:.5}

/* ===== Six doors (programmes preview, immersive cards) ===== */
.chapter.doors-ch{padding:140px 60px}
.doors-ch .ch-content{display:block}
.doors-ch .ch-head{
  display:grid;grid-template-columns:1.2fr .8fr;gap:60px;margin-bottom:60px;align-items:end;
}
.doors-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.door{
  position:relative;
  min-height:340px;
  border-radius:14px;
  overflow:hidden;
  padding:28px 28px 32px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  color:#fff;
  text-decoration:none;
  isolation:isolate;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
  border:1px solid rgba(255,255,255,.08);
}
.door::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg, var(--door-c1, #1F4D32) 0%, var(--door-c2, #06120A) 100%);
  transition:filter .5s;
}
.door::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at 80% 18%, rgba(255,220,170,.16) 0%, transparent 55%);
  pointer-events:none;
}
.door > *{position:relative;z-index:2}
.door .door-num{
  font-family:'Playfair Display',serif;font-style:italic;
  position:absolute;top:18px;left:24px;
  font-size:84px;color:rgba(255,255,255,.15);
  line-height:1;
  z-index:1;
}
.door .door-tag{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--vw-mint);margin-bottom:8px;
}
.door h3{
  font-family:'Playfair Display',serif;font-weight:400;font-size:28px;line-height:1.15;margin-bottom:8px;color:#fff;
}
.door p{font-size:13.5px;color:rgba(255,255,255,.7);line-height:1.6;margin-bottom:18px}
.door .door-arrow{
  align-self:flex-start;
  width:34px;height:34px;border-radius:50%;border:1px solid var(--vw-ember);
  display:flex;align-items:center;justify-content:center;color:var(--vw-ember);font-size:14px;
  transition:background .25s, color .25s, transform .35s;
}
.door:hover{transform:translateY(-4px)}
.door:hover::before{filter:brightness(1.15)}
.door:hover .door-arrow{background:var(--vw-ember);color:#fff;transform:translateX(4px)}

/* Door tints (paired with chapter palette) */
.door.d-policy{--door-c1:#3E5832;--door-c2:#0F1F12}
.door.d-market{--door-c1:#5C3422;--door-c2:#1A0E08}
.door.d-research{--door-c1:#264252;--door-c2:#0A1820}
.door.d-skills{--door-c1:#5C4424;--door-c2:#1A0E08}
.door.d-partners{--door-c1:#2A4530;--door-c2:#0E1F14}
.door.d-awareness{--door-c1:#522C2C;--door-c2:#1A0E08}

/* ===== The Mission chapter (about-us preview) ===== */
.chapter.mission-ch .ch-content{grid-template-columns:1.1fr .9fr}
.mission-ch .mv-pair{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.mission-ch .mv-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;padding:22px;backdrop-filter:blur(10px);
}
.mission-ch .mv-card h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--vw-mint);
  text-transform:uppercase;margin-bottom:12px;
}
.mission-ch .mv-card p{font-size:14px;color:rgba(255,255,255,.85);line-height:1.6}
.mission-ch .mv-card.green{background:rgba(143,224,90,.06);border-color:rgba(143,224,90,.18)}

/* ===== Voices chapter ===== */
.chapter.voices-ch .ch-content{grid-template-columns:.9fr 1.1fr}
.voices-portrait{
  position:relative;border-radius:14px;overflow:hidden;
  aspect-ratio:3/4;width:100%;
  background:
    radial-gradient(ellipse at 55% 42%, rgba(255,220,180,.5) 0%, transparent 55%),
    radial-gradient(ellipse at 45% 95%, rgba(130,40,28,.6) 0%, transparent 60%),
    linear-gradient(180deg,#3A1E14 0%, #14080A 100%);
  border:1px solid rgba(255,255,255,.08);
}
.voices-portrait::after{
  content:"PORTRAIT FRAME — TO BE COMMISSIONED";
  position:absolute;left:18px;top:18px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  color:rgba(255,255,255,.4);
}
.voices-quote{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:400;
  font-size:clamp(36px, 3.6vw, 56px);line-height:1.15;color:#fff;
}
.voices-meta{margin-top:32px;display:flex;align-items:center;gap:16px}
.voices-meta-rule{width:30px;height:1px;background:var(--vw-mint)}
.voices-meta-name{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--vw-mint);
}

/* ===== Final CTA chapter ===== */
.chapter.cta-ch{padding:180px 80px;text-align:center}
.cta-ch .ch-content{display:block;text-align:center}
.cta-ch .ch-headline{font-size:clamp(56px, 6vw, 112px);margin:0 auto 32px;max-width:1100px}
.cta-ch .ch-row{display:inline-flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-top:28px}
.cta-ch .ch-row .ch-cta-outline{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 28px;border-radius:var(--pill);
  border:1px solid rgba(255,255,255,.32);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  transition:background .25s, border-color .25s;
}
.cta-ch .ch-row .ch-cta-outline:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.6)}

/* ===== Live counter typography ===== */
.live-counter{
  font-family:'JetBrains Mono',monospace;
  font-size:clamp(54px, 5.6vw, 110px);
  font-weight:700;color:#fff;
  letter-spacing:-.02em;
  text-shadow:0 0 60px rgba(199,84,31,.18);
  margin:8px 0 6px;
  font-variant-numeric:tabular-nums;
}

/* ===== Scroll progress rail (right) ===== */
.scroll-rail{
  position:fixed;right:24px;top:0;bottom:0;width:2px;
  z-index:40;pointer-events:none;
  display:flex;flex-direction:column;align-items:center;
  opacity:0;transition:opacity .5s;
}
body.intro-done .scroll-rail{opacity:.85}
.scroll-rail-track{position:absolute;left:0;right:0;top:18%;bottom:18%;background:rgba(255,255,255,.10)}
.scroll-rail-fill{position:absolute;left:0;right:0;top:18%;bottom:18%;background:var(--vw-leaf);
  transform-origin:top center;transform:scaleY(0);transition:transform .15s linear}

/* ===== Floating chapter pill (bottom-right) ===== */
.ch-pill{
  position:fixed;right:32px;bottom:32px;z-index:41;
  display:inline-flex;align-items:center;gap:14px;
  padding:12px 20px;border-radius:var(--pill);
  background:rgba(6,18,10,.72);
  border:1px solid rgba(143,224,90,.35);
  color:#fff;backdrop-filter:blur(14px);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;cursor:pointer;
  opacity:0;transform:translateY(14px);transition:opacity .4s, transform .4s;
}
.ch-pill.show{opacity:1;transform:translateY(0)}
.ch-pill:hover{border-color:rgba(143,224,90,.7)}
.ch-pill .ch-pill-num{color:var(--vw-leaf);font-weight:700}
.ch-pill .ch-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--vw-leaf);box-shadow:0 0 12px rgba(143,224,90,.6)}

/* ===== Chapter table-of-contents overlay (opens via pill click) ===== */
.ch-toc{
  position:fixed;inset:0;z-index:60;
  background:rgba(6,18,10,.92);backdrop-filter:blur(28px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .35s, visibility .35s;
}
.ch-toc.open{opacity:1;visibility:visible}
.ch-toc-list{display:flex;flex-direction:column;gap:14px;width:min(560px, 92vw)}
.ch-toc-list a{
  display:flex;align-items:center;gap:18px;padding:14px 18px;
  border:1px solid rgba(255,255,255,.10);border-radius:14px;
  color:#fff;text-decoration:none;
  transition:border-color .2s, background .2s, transform .25s;
}
.ch-toc-list a:hover{border-color:rgba(143,224,90,.6);background:rgba(143,224,90,.06);transform:translateX(4px)}
.ch-toc-list a .num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--vw-leaf);letter-spacing:.18em;width:36px}
.ch-toc-list a .name{font-family:'Playfair Display',serif;font-size:24px;font-style:italic}

/* ===== Film footer (simplified, dark forest) ===== */
.film-footer{
  background:#06120A;color:rgba(255,255,255,.7);
  padding:80px 80px 36px;
  border-top:1px solid rgba(255,255,255,.06);
  position:relative;z-index:5;
}
.film-footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;max-width:1400px;margin:0 auto 48px;
}
.film-footer h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:var(--vw-mint);text-transform:uppercase;margin-bottom:16px;
}
.film-footer ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.film-footer ul a{color:rgba(255,255,255,.7);font-size:14px}
.film-footer ul a:hover{color:#fff}
.film-footer-brand p{font-size:13px;line-height:1.6;color:rgba(255,255,255,.55);margin-top:14px;max-width:380px}
.film-footer-bot{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid rgba(255,255,255,.06);padding-top:24px;
  font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.18em;
  color:rgba(255,255,255,.5);text-transform:uppercase;
  max-width:1400px;margin:0 auto;
}

/* ===== Smooth section transitions (entire film) ===== */
@media (prefers-reduced-motion: no-preference){
  .film{scroll-behavior:smooth}
}

/* ===== Responsive ===== */
@media (max-width:1080px){
  .chapter{padding:80px 32px}
  .ch-content{grid-template-columns:1fr;gap:40px}
  .ch-stats{flex-direction:row;flex-wrap:wrap}
  .ch-stats .ch-stat{flex:1 1 280px}
  .doors-grid{grid-template-columns:repeat(2,1fr)}
  .doors-ch .ch-head{grid-template-columns:1fr;gap:18px}
  .film-footer{padding:60px 32px 28px}
  .film-footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .scroll-rail{display:none}
}
@media (max-width:640px){
  .chapter{padding:64px 22px;min-height:auto}
  .doors-grid{grid-template-columns:1fr}
  .ch-pill{right:18px;bottom:18px;padding:10px 14px;font-size:10px;letter-spacing:.18em}
  .film-footer-grid{grid-template-columns:1fr}
  .cta-ch{padding:96px 24px}
  .voices-portrait{aspect-ratio:1/1}
}

/* When the intro hasn't been entered yet, hide film completely */
body:not(.intro-done) .film{display:none}
body:not(.intro-done) .scroll-rail,
body:not(.intro-done) .ch-pill{display:none}

/* ==========================================================================
   FILM PAGE — Dark-forest theme override for deep-dive pages
   Applied via <body class="film-page">
   Reuses verdant-witness tokens; transforms the existing layout to match
   the cinematic register of the front-page film.
   ========================================================================== */
body.film-page{
  background:#06120A;
  color:#fff;
}
body.film-page .admin{transform:translateY(0)}

/* ===== Film header (small, contextual, no top-nav listing) ===== */
.film-header{
  position:relative;
  z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 44px;
  background:transparent;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.film-header .fh-mark{
  display:inline-flex;align-items:center;gap:14px;color:#fff;text-decoration:none;
  transition:opacity .25s;
}
.film-header .fh-mark:hover{opacity:.85}
.film-header .fh-mark svg{filter:drop-shadow(0 0 12px rgba(143,224,90,.18))}
.film-header .fh-mark-name{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(201,229,176,.8);
  letter-spacing:.22em;text-transform:uppercase;line-height:1.4;
}
.film-header .fh-mark-name strong{
  display:block;font-family:'Manrope',sans-serif;font-weight:700;font-size:14px;
  color:#fff;letter-spacing:.06em;margin-bottom:2px;
}
.film-header .fh-back{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.22em;color:rgba(255,255,255,.7);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;text-decoration:none;
  padding:10px 18px;border-radius:var(--pill);
  border:1px solid rgba(255,255,255,.18);
  transition:background .25s, border-color .25s, color .25s;
}
.film-header .fh-back:hover{background:rgba(143,224,90,.06);border-color:rgba(143,224,90,.4);color:#fff}
.film-header .fh-back .arrow{font-size:14px}
.film-header .fh-donate{
  display:inline-flex;align-items:center;gap:12px;
  padding:11px 14px 11px 22px;border-radius:var(--pill);
  background:var(--terracotta);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  transition:transform .25s, box-shadow .25s, background .25s;
  text-decoration:none;
}
.film-header .fh-donate:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(199,84,31,.45);background:#d96838}
.film-header .fh-donate .arrow{
  width:24px;height:24px;border-radius:50%;background:#fff;color:var(--terracotta);
  display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;
}
.film-header .fh-row{display:inline-flex;align-items:center;gap:16px}

/* ===== Page hero on dark-forest pages ===== */
body.film-page .page-hero{
  position:relative;
  background:linear-gradient(180deg, #06120A 0%, #0E2818 100%);
  padding:120px 80px 100px;
  overflow:hidden;
  color:#fff;
}
body.film-page .page-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 90%, rgba(143,224,90,.10) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(199,84,31,.08) 0%, transparent 60%);
  pointer-events:none;
}
body.film-page .page-hero-inner{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:end;
}
body.film-page .breadcrumb{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.22em;color:rgba(255,255,255,.45);text-transform:uppercase;margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
body.film-page .breadcrumb a{color:rgba(255,255,255,.45)}
body.film-page .breadcrumb a:hover{color:#fff}
body.film-page .eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:#C9E5B0;text-transform:uppercase;margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
body.film-page .eyebrow::before{content:"";width:30px;height:1px;background:#C9E5B0}
body.film-page .page-hero h1{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(56px, 6vw, 104px);letter-spacing:-1.5px;line-height:1;
  color:#fff;margin-bottom:0;
}
body.film-page .page-hero h1 em{
  font-style:italic;color:#8FE05A;font-weight:400;
  text-shadow:0 0 60px rgba(143,224,90,.25);
}
body.film-page .page-hero p{
  font-size:17px;line-height:1.65;color:rgba(255,255,255,.78);max-width:520px;
}

/* ===== Sections on dark-forest pages ===== */
body.film-page .section{
  background:transparent;
  padding:120px 80px;
  position:relative;
}
body.film-page .section-inner{max-width:1280px;margin:0 auto}
body.film-page .section-title{
  font-family:'Playfair Display',serif;font-weight:400;
  color:#fff;letter-spacing:-1px;
}
body.film-page .section-title em{font-style:italic;color:#8FE05A;font-weight:400}
body.film-page .section-lead{color:rgba(255,255,255,.78)}

/* Programmes pillar layout in dark theme */
body.film-page .pp{
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:80px 0;
}
body.film-page .pp:last-child{border-bottom:none}
body.film-page .pp-side{position:sticky;top:120px}
body.film-page .pp-side .num{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:#C9E5B0;letter-spacing:.22em;text-transform:uppercase;
}
body.film-page .pp-side .icon{
  width:64px;height:64px;border-radius:14px;
  background:linear-gradient(135deg, rgba(143,224,90,.15), rgba(199,84,31,.15));
  border:1px solid rgba(143,224,90,.25);
  display:flex;align-items:center;justify-content:center;font-size:30px;
  margin:14px 0 20px;
}
body.film-page .pp-side h2{
  font-family:'Playfair Display',serif;font-weight:400;font-size:44px;
  color:#fff;line-height:1.1;letter-spacing:-1px;margin-bottom:14px;
}
body.film-page .pp-side p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.65}
body.film-page .pp-body h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:#C9E5B0;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  margin:40px 0 16px;
}
body.film-page .pp-body h4:first-child{margin-top:0}
body.film-page .pp-body ul{list-style:none;display:grid;gap:12px;padding:0;margin:0}
body.film-page .pp-body ul li{
  display:flex;gap:14px;padding:18px 22px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);
  border-radius:14px;align-items:start;
  transition:border-color .25s, background .25s;
}
body.film-page .pp-body ul li:hover{
  border-color:rgba(143,224,90,.25);
  background:rgba(143,224,90,.05);
}
body.film-page .pp-body ul li::before{
  content:"";width:8px;height:8px;border-radius:50%;background:#8FE05A;
  margin-top:8px;flex:0 0 auto;
}
body.film-page .pp-body ul li strong{
  display:block;font-family:'Manrope',sans-serif;font-weight:700;
  color:#fff;margin-bottom:4px;font-size:15.5px;
}
body.film-page .pp-body ul li span{font-size:14px;color:rgba(255,255,255,.75);line-height:1.55}

/* Cards in dark theme */
body.film-page .card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;padding:28px;
  color:#fff;text-decoration:none;
  transition:border-color .25s, background .25s, transform .35s;
  display:flex;flex-direction:column;gap:8px;
}
body.film-page .card:hover{
  border-color:rgba(143,224,90,.35);
  background:rgba(143,224,90,.05);
  transform:translateY(-3px);
}
body.film-page .card .num{
  font-family:'JetBrains Mono',monospace;font-size:10.5px;
  color:#C9E5B0;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;
}
body.film-page .card .icon{font-size:30px;margin:6px 0 14px;display:block}
body.film-page .card h3{
  font-family:'Playfair Display',serif;font-weight:400;font-size:24px;
  color:#fff;margin-bottom:8px;line-height:1.2;
}
body.film-page .card p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.6;margin-bottom:14px}
body.film-page .card .link{font-family:'JetBrains Mono',monospace;font-size:11px;color:#C7541F;letter-spacing:.18em;text-transform:uppercase;margin-top:auto}

/* Footer on dark pages — reuse film-footer styling on .footer */
body.film-page .footer{
  background:#06120A;color:rgba(255,255,255,.7);
  padding:80px 80px 36px;
  border-top:1px solid rgba(255,255,255,.06);
}
body.film-page .footer h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:#C9E5B0;text-transform:uppercase;margin-bottom:16px;
}
body.film-page .footer ul a{color:rgba(255,255,255,.7)}
body.film-page .footer ul a:hover{color:#fff}
body.film-page .footer-brand p{color:rgba(255,255,255,.55)}
body.film-page .footer-bot{
  border-top:1px solid rgba(255,255,255,.06);
  color:rgba(255,255,255,.5);
}

/* Btn-pill recolour for dark theme */
body.film-page .btn-pill.outline{
  background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.32);
}
body.film-page .btn-pill.outline:hover{background:rgba(143,224,90,.06);border-color:rgba(143,224,90,.5)}
body.film-page .btn-pill.solid-t{
  background:var(--terracotta);color:#fff;border:none;
}
body.film-page .btn-pill.solid-t:hover{background:#d96838;box-shadow:0 14px 40px rgba(199,84,31,.45)}

/* Hide any old top-nav listing on film pages */
body.film-page .header,
body.film-page .nav{display:none}

/* Donate page — three-tier specific */
body.film-page .donate-tiers{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;
  max-width:1280px;margin:0 auto;padding:60px 0;
}
body.film-page .dt{
  position:relative;
  background:linear-gradient(180deg, rgba(20,46,32,.4) 0%, rgba(8,22,14,.6) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;padding:40px 32px 32px;
  display:flex;flex-direction:column;
  overflow:hidden;
  isolation:isolate;
}
body.film-page .dt::before{
  content:"";position:absolute;left:0;right:0;bottom:0;height:60%;z-index:0;
  background:radial-gradient(ellipse at 50% 100%, rgba(199,84,31,.20) 0%, transparent 70%);
  pointer-events:none;
}
body.film-page .dt > *{position:relative;z-index:1}
body.film-page .dt-tag{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:#8FE05A;text-transform:uppercase;margin-bottom:14px;
}
body.film-page .dt-amt{
  font-family:'Playfair Display',serif;font-weight:400;font-size:96px;line-height:1;
  color:#fff;margin-bottom:6px;
}
body.film-page .dt-rule{width:32px;height:1px;background:var(--terracotta);margin:18px 0 14px}
body.film-page .dt-desc{font-size:14.5px;color:rgba(255,255,255,.78);line-height:1.6;margin-bottom:28px;flex:1}
body.film-page .dt-cta{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 22px;border-radius:var(--pill);
  background:var(--terracotta);color:#fff;text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  transition:background .25s, transform .25s, box-shadow .25s;
}
body.film-page .dt-cta:hover{background:#d96838;transform:translateY(-2px);box-shadow:0 14px 40px rgba(199,84,31,.45)}

body.film-page .donate-trust{
  text-align:center;padding:60px 0 80px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:center;align-items:center;gap:36px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:rgba(255,255,255,.55);text-transform:uppercase;
}
body.film-page .donate-trust .dot{width:4px;height:4px;border-radius:50%;background:rgba(143,224,90,.5)}

/* ===== Section page ambient (subtle leaf drift, behind hero) ===== */
.page-ambient{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1;
}

/* Responsive */
@media (max-width:1080px){
  body.film-page .page-hero{padding:80px 32px 60px}
  body.film-page .page-hero-inner{grid-template-columns:1fr;gap:36px}
  body.film-page .section{padding:80px 32px}
  body.film-page .pp{grid-template-columns:1fr;gap:32px}
  body.film-page .pp-side{position:static}
  body.film-page .donate-tiers{grid-template-columns:1fr;padding:40px 0}
  body.film-page .footer{padding:60px 32px 28px}
  body.film-page .film-header{padding:18px 22px}
  body.film-page .film-header .fh-mark-name{display:none}
}
@media (max-width:640px){
  body.film-page .page-hero h1{font-size:42px}
  body.film-page .pp-side h2{font-size:30px}
  body.film-page .dt-amt{font-size:64px}
  body.film-page .film-header{padding:14px 18px}
  body.film-page .film-header .fh-back{display:none}
}

/* ==========================================================================
   Real-photo bed layer for chapters
   <img class="ch-bg" src="..."> sits below the canvas; the canvas adds
   native motion (smoke / sparks / flame / leaves) over the photograph.
   ========================================================================== */
.chapter .ch-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:0;
  /* gentle grade so the photo never overpowers the type */
  filter:saturate(.95) contrast(1.05) brightness(.78);
  pointer-events:none;
}
.chapter .ch-canvas{
  z-index:1;
  mix-blend-mode:screen;          /* canvas sparks/flames add light over the photo */
}
/* Some chapters need multiply (smoke / dust scenes that should darken) */
.chapter[data-blend="multiply"] .ch-canvas{mix-blend-mode:multiply}
.chapter[data-blend="overlay"]  .ch-canvas{mix-blend-mode:overlay}
.chapter[data-blend="lighten"]  .ch-canvas{mix-blend-mode:lighten}
.chapter[data-blend="normal"]   .ch-canvas{mix-blend-mode:normal}
/* photo-bed dim overlay for legibility (gradient under content but over image) */
.chapter[data-bg-dim="strong"]::before{background:linear-gradient(180deg, rgba(6,18,10,.55) 0%, rgba(6,18,10,.85) 100%) !important;opacity:1 !important}
.chapter[data-bg-dim="medium"]::before{background:linear-gradient(180deg, rgba(6,18,10,.30) 0%, rgba(6,18,10,.70) 100%) !important;opacity:1 !important}

/* ==========================================================================
   Stronger photo-bed legibility — dark gradient layer between bg image and content
   ========================================================================== */
.chapter[data-bg-dim]::before{
  /* Override the small top-only fade with a left-to-right gradient so type column reads */
  height: 100% !important;
  top: 0 !important;
  background: linear-gradient(90deg,
    rgba(6,18,10,0.92) 0%,
    rgba(6,18,10,0.78) 30%,
    rgba(6,18,10,0.45) 55%,
    rgba(6,18,10,0.20) 100%
  ) !important;
  opacity: 1 !important;
}
.chapter[data-bg-dim="strong"]::before{
  background: linear-gradient(90deg,
    rgba(6,18,10,0.95) 0%,
    rgba(6,18,10,0.85) 35%,
    rgba(6,18,10,0.55) 65%,
    rgba(6,18,10,0.30) 100%
  ) !important;
}
/* For centered chapters (hero / cta) use radial dim instead */
.chapter.cta-ch[data-bg-dim]::before,
.chapter[data-center-dim]::before{
  background: radial-gradient(ellipse at center,
    rgba(6,18,10,0.55) 0%,
    rgba(6,18,10,0.85) 100%
  ) !important;
}

/* ==========================================================================
   SCROLLYTELLING — sticky animated narrative scenes
   <section class="story">
     <div class="story-frame">
       <div class="stage" data-stage="1"><img src="..."></div> ...
     </div>
     <div class="story-steps">
       <div class="story-step" data-step="1"><div class="story-card">...</div></div> ...
     </div>
   </section>
   ========================================================================== */
.story{
  position:relative;
  background:#06120A;
  color:#fff;
}
/* Each step is its own full-viewport panel: photo + canvas + content */
.story-step{
  position:relative;
  min-height:100vh;
  width:100%;
  display:flex;align-items:flex-end;
  padding:30vh 80px 12vh;
  overflow:hidden;
  isolation:isolate;
}
.story-step .stage{
  position:absolute;inset:0;
  z-index:0;
  pointer-events:none;
}
.story-step .stage img{
  width:100%;height:100%;object-fit:cover;
  animation:kenBurns 22s ease-in-out infinite alternate;
  filter:saturate(1.05) contrast(1.04) brightness(.85);
}
.story-step .stage-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  mix-blend-mode:screen;
  z-index:1;
}
.story-step::before{
  /* top fade — softer crossfade between consecutive panels */
  content:"";position:absolute;left:0;right:0;top:0;height:200px;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(6,18,10,.95) 0%, rgba(6,18,10,0) 100%);
}
.story-step::after{
  /* horizontal dim — keeps the type column readable across any photo */
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg, rgba(6,18,10,.92) 0%, rgba(6,18,10,.55) 45%, rgba(6,18,10,.20) 100%);
}
.story-step[data-side="right"]::after{
  background:linear-gradient(270deg, rgba(6,18,10,.92) 0%, rgba(6,18,10,.55) 45%, rgba(6,18,10,.20) 100%);
}
@keyframes kenBurns{
  0%   {transform:scale(1.04) translate(0,0)}
  50%  {transform:scale(1.10) translate(-1.5%, -1%)}
  100% {transform:scale(1.06) translate(1.2%, .8%)}
}
.story-card{
  pointer-events:auto;
  max-width:640px;
  background:rgba(6,18,10,.82);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:34px 38px;
  opacity:0;
  transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.8,.2,1), transform 1s cubic-bezier(.2,.8,.2,1);
}
.story-step.in .story-card{opacity:1;transform:translateY(0)}
.story-card .step-eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:#C9E5B0;margin-bottom:18px;
  display:flex;align-items:center;gap:14px;
}
.story-card .step-eyebrow::before{content:"";width:32px;height:1px;background:#C9E5B0}
.story-card h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(36px, 4vw, 60px);line-height:1.05;letter-spacing:-1.5px;color:#fff;margin-bottom:18px;
}
.story-card h2 em{font-style:italic;color:#8FE05A;font-weight:400;text-shadow:0 0 60px rgba(143,224,90,.32)}
.story-card h2 em.ember{color:#FF9846;text-shadow:0 0 60px rgba(255,152,70,.32)}
.story-card p{font-size:16px;line-height:1.65;color:rgba(255,255,255,.82);margin-bottom:18px}
.story-card p:last-child{margin-bottom:0}
.story-card .step-stat{
  font-family:'Playfair Display',serif;font-size:64px;line-height:1;color:#fff;
  margin:14px 0 6px;
}
.story-card .step-stat .unit{font-size:18px;color:rgba(255,255,255,.55);margin-left:8px;font-style:italic}
.story-card .step-cta{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 14px 14px 28px;border-radius:var(--pill);
  background:#C7541F;color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  margin-top:14px;text-decoration:none;
  transition:transform .25s, box-shadow .25s, background .25s;
}
.story-card .step-cta:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(199,84,31,.45);background:#d96838}
.story-card .step-cta .arrow{
  width:30px;height:30px;border-radius:50%;background:#fff;color:#C7541F;
  display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;
}

/* Step 1 vs 3 — alternate sides for variety */
.story-step[data-side="right"]{justify-content:flex-end;padding-right:80px}
.story-step[data-side="center"]{justify-content:center}

/* Stage progress indicator (optional bottom dots) */
.story-progress{
  position:fixed;left:50%;bottom:32px;transform:translateX(-50%);
  display:flex;gap:14px;z-index:50;
  opacity:0;transition:opacity .6s;
}
.story-progress.show{opacity:1}
.story-progress .dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.35);transition:all .35s;
}
.story-progress .dot.active{background:#8FE05A;transform:scale(1.4);box-shadow:0 0 14px rgba(143,224,90,.7)}

@media (max-width:780px){
  .story-step{padding:20vh 22px 50vh}
  .story-card{padding:24px 26px}
}

/* Story card needs to render above stage dim overlays */
.story-step .story-card{ position: relative; z-index: 3; }
.story-step[data-side="right"] .story-card{ margin-left: auto; }
.story-step[data-side="center"] .story-card{ margin-left: auto; margin-right: auto; }

/* ==========================================================================
   FILM-BLOCK — self-contained cinematic frame embedded inline in page flow.
   Markup:
     <section class="film-block" data-block="fire">
       <div class="fb-stage">
         <img class="fb-photo" src="...">
         <canvas class="fb-canvas" data-scene="..."></canvas>
       </div>
       <div class="fb-beats">
         <div class="fb-beat" data-beat="1">...</div>
         <div class="fb-beat" data-beat="2">...</div>
         <div class="fb-beat" data-beat="3">...</div>
       </div>
     </section>
   The visual stays anchored; only the text beat changes as user scrolls.
   ========================================================================== */
.film-block{
  /* Contained inline cinematic card — NOT a page background.
     Bounded width, bounded height, sits in normal page flow.
     The text beats auto-cycle every ~6s; user can also tap a dot. */
  position:relative;
  width:calc(100% - 32px);
  max-width:1100px;
  height:640px;
  margin:80px auto;
  border-radius:22px;
  overflow:hidden;
  isolation:isolate;
  box-shadow:0 30px 80px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.04) inset;
}
.film-block .fb-stage{
  position:absolute;
  inset:0;
  height:100%;
  width:100%;
  overflow:hidden;
  z-index:0;
}
.film-block .fb-photo{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.05) contrast(1.05) brightness(.78);
  animation:fbKenBurns 26s ease-in-out infinite alternate;
  z-index:0;
}
.film-block .fb-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:0;
  background:#06120A;
}
.film-block .fb-stage::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(6,18,10,.55) 0%, rgba(6,18,10,.10) 25%, rgba(6,18,10,.45) 75%, rgba(6,18,10,.95) 100%),
    linear-gradient(90deg, rgba(6,18,10,.30) 0%, rgba(6,18,10,0) 60%);
}
@keyframes fbKenBurns{
  0%   {transform:scale(1.02) translate(0,0)}
  50%  {transform:scale(1.10) translate(-1.5%, -1%)}
  100% {transform:scale(1.05) translate(1.5%, 1%)}
}
.film-block .fb-beats{
  /* All three beats stacked in the SAME spot inside the card; cross-fade by class */
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
}
.film-block .fb-beat{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;
  padding:48px 56px;
  opacity:0;
  transition:opacity 1.1s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.film-block .fb-beat .fb-card{
  pointer-events:auto;
  max-width:560px;
  background:rgba(6,18,10,.62);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  padding:28px 32px;
  transform:translateY(14px);
  transition:transform 1.1s cubic-bezier(.4,0,.2,1);
}
.film-block .fb-beat.live{opacity:1}
.film-block .fb-beat.live .fb-card{transform:translateY(0)}
.film-block .fb-beat[data-side="right"]{justify-content:flex-end}
.film-block .fb-beat[data-side="center"]{justify-content:center;text-align:center}
.film-block .fb-beat[data-side="center"] .fb-card{text-align:center}

.film-block .fb-eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:#C9E5B0;margin-bottom:18px;
  display:flex;align-items:center;gap:14px;
}
.film-block .fb-eyebrow::before{content:"";width:30px;height:1px;background:#C9E5B0}
.film-block[data-tone="ember"] .fb-eyebrow{color:#FFB14E}
.film-block[data-tone="ember"] .fb-eyebrow::before{background:#FFB14E}

.film-block h2{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(28px, 3vw, 42px);line-height:1.08;letter-spacing:-1px;color:#fff;margin-bottom:14px;
}
.film-block h2 em{font-style:italic;color:#8FE05A;font-weight:400;text-shadow:0 0 60px rgba(143,224,90,.32)}
.film-block h2 em.ember{color:#FF9846;text-shadow:0 0 60px rgba(255,152,70,.32)}

.film-block p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.84);margin-bottom:10px}
.film-block p:last-child{margin-bottom:0}
.film-block .fb-stat{
  font-family:'Playfair Display',serif;font-size:54px;line-height:1;color:#fff;
  margin:12px 0 8px;font-weight:400;
}
.film-block .fb-stat .unit{font-size:20px;color:rgba(255,255,255,.55);margin-left:8px;font-style:italic}

/* Beat progress dots — small, bottom-right of the inline card; clickable */
.film-block .fb-progress{
  position:absolute;
  right:24px;bottom:24px;z-index:4;
  display:flex;gap:10px;
  pointer-events:auto;
}
.film-block .fb-progress .dot{
  width:32px;height:3px;border-radius:2px;background:rgba(255,255,255,.30);transition:all .35s;
  cursor:pointer;border:none;padding:0;
}
.film-block .fb-progress .dot.active{background:#8FE05A;box-shadow:0 0 14px rgba(143,224,90,.5)}
.film-block .fb-progress .dot:hover{background:rgba(255,255,255,.5)}

/* Make sure the inline-card film-block stays small on tablet/phone */
@media (max-width:780px){
  .film-block{height:560px;margin:60px auto}
  .film-block .fb-beat{padding:32px 24px}
  .film-block .fb-card{padding:22px 24px;max-width:100%}
}

@media (max-width:780px){
  .film-block{height:270vh}
  .film-block .fb-beat{padding:0 22px}
  .film-block .fb-card{padding:24px 26px}
  .film-block h2{font-size:32px}
  .film-block .fb-stat{font-size:56px}
}

/* =====================================================================
   PAGE LAYOUTS — distinct per page (no shared chapter-scroll template)
   ===================================================================== */

/* --- Page-level shared shell (used by all deep-dive pages) --- */
body.dpage{
  background:#06120A;
  color:#fff;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
body.dpage .dpage-hero{
  padding:140px 80px 80px;
  max-width:1280px;margin:0 auto;
}
body.dpage .dpage-hero .breadcrumb{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:rgba(255,255,255,.45);text-transform:uppercase;margin-bottom:24px;
}
body.dpage .dpage-hero .breadcrumb a{color:rgba(255,255,255,.45)}
body.dpage .dpage-hero .breadcrumb a:hover{color:#fff}
body.dpage .dpage-hero h1{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(56px, 6vw, 104px);letter-spacing:-1.5px;line-height:1;
  color:#fff;margin-bottom:0;max-width:1100px;
}
body.dpage .dpage-hero h1 em{font-style:italic;color:#8FE05A;text-shadow:0 0 60px rgba(143,224,90,.25)}
body.dpage .dpage-hero h1 em.ember{color:#FF9846;text-shadow:0 0 60px rgba(255,152,70,.25)}
body.dpage .dpage-hero .lead{
  font-size:18px;line-height:1.65;color:rgba(255,255,255,.78);max-width:660px;margin-top:32px;
}
body.dpage .dpage-section{padding:100px 80px;max-width:1280px;margin:0 auto}
body.dpage .dpage-section.alt{background:rgba(255,255,255,.03);max-width:none;padding:100px 80px}
body.dpage .dpage-section.alt .inner{max-width:1280px;margin:0 auto}
body.dpage .dpage-eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:#C9E5B0;text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:14px;
}
body.dpage .dpage-eyebrow::before{content:"";width:30px;height:1px;background:#C9E5B0}
body.dpage h2.dpage-title{
  font-family:'Playfair Display',serif;font-weight:400;
  font-size:clamp(40px, 4vw, 64px);line-height:1.05;letter-spacing:-1px;color:#fff;margin-bottom:18px;
}
body.dpage h2.dpage-title em{font-style:italic;color:#8FE05A}
body.dpage .dpage-foot{
  background:#06120A;color:rgba(255,255,255,.7);
  padding:80px 80px 36px;border-top:1px solid rgba(255,255,255,.06);
}
body.dpage .dpage-foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;max-width:1400px;margin:0 auto 48px;
}
body.dpage .dpage-foot h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  color:#C9E5B0;text-transform:uppercase;margin-bottom:16px;
}
body.dpage .dpage-foot ul{list-style:none;display:flex;flex-direction:column;gap:8px;padding:0;margin:0}
body.dpage .dpage-foot ul a{color:rgba(255,255,255,.7);text-decoration:none;font-size:14px}
body.dpage .dpage-foot ul a:hover{color:#fff}
body.dpage .dpage-foot p{color:rgba(255,255,255,.55);font-size:13px;line-height:1.6;max-width:380px;margin-top:14px}
body.dpage .dpage-foot-bot{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid rgba(255,255,255,.06);padding-top:24px;
  font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.18em;
  color:rgba(255,255,255,.5);text-transform:uppercase;max-width:1400px;margin:0 auto;
}

/* --- Distinct page palettes (so each page reads different from the next) --- */
body.dpage[data-page="donate"]    .dpage-hero h1{color:#fff}
body.dpage[data-page="programmes"] .dpage-hero{background:linear-gradient(180deg, rgba(20,46,32,0) 0%, rgba(143,224,90,.04) 100%)}
body.dpage[data-page="about"]     .dpage-hero h1 em{color:#FFB14E;text-shadow:0 0 60px rgba(255,177,78,.25)}
body.dpage[data-page="members"]   .dpage-hero h1 em{color:#FF9846}
body.dpage[data-page="resources"] .dpage-hero h1 em{color:#7DC4FF;text-shadow:0 0 60px rgba(125,196,255,.25)}
body.dpage[data-page="events"]    .dpage-hero h1 em{color:#FFB14E}
body.dpage[data-page="news"]      .dpage-hero h1 em{color:#C9E5B0}
body.dpage[data-page="contact"]   .dpage-hero h1 em{color:#FF7DA3;text-shadow:0 0 60px rgba(255,125,163,.25)}

/* --- Tier cards (donate) --- */
.tier-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.tier{
  position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
  border-radius:18px;padding:38px 32px;display:flex;flex-direction:column;overflow:hidden;
  transition:transform .35s, border-color .35s, background .35s;
}
.tier:hover{transform:translateY(-4px);border-color:rgba(143,224,90,.4);background:rgba(143,224,90,.06)}
.tier::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:60%;z-index:0;
  background:radial-gradient(ellipse at 50% 100%, rgba(199,84,31,.2) 0%, transparent 70%);
  pointer-events:none;
}
.tier > *{position:relative;z-index:1}
.tier .tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:#8FE05A;text-transform:uppercase;margin-bottom:14px}
.tier .amt{font-family:'Playfair Display',serif;font-size:96px;line-height:1;color:#fff;margin-bottom:8px}
.tier .rule{width:32px;height:1px;background:#C7541F;margin:18px 0 14px}
.tier .desc{font-size:14.5px;color:rgba(255,255,255,.78);line-height:1.6;margin-bottom:28px;flex:1}
.tier .cta{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 22px;border-radius:999px;background:#C7541F;color:#fff;text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;transition:all .25s;
}
.tier .cta:hover{background:#d96838;transform:translateY(-2px);box-shadow:0 14px 40px rgba(199,84,31,.45)}
@media (max-width:1080px){.tier-row{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.tier-row{grid-template-columns:1fr}}

/* --- Programmes pillar rows (alternating photo/text) --- */
.pillar{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:120px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.pillar:last-child{border-bottom:none}
.pillar.flip{grid-template-columns:1fr 1fr;direction:rtl}
.pillar.flip > *{direction:ltr}
.pillar-vis{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;background:#0E2818;isolation:isolate}
.pillar-vis canvas{position:absolute;inset:0;width:100%;height:100%}
.pillar-vis::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.45) 100%);pointer-events:none}
.pillar-vis .num{
  position:absolute;left:24px;top:18px;z-index:2;
  font-family:'Playfair Display',serif;font-style:italic;
  color:rgba(255,255,255,.18);font-size:120px;line-height:1;
}
.pillar .num-mini{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:#C9E5B0;text-transform:uppercase;margin-bottom:14px}
.pillar h3{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(36px, 3.8vw, 56px);line-height:1.05;letter-spacing:-1px;color:#fff;margin-bottom:18px}
.pillar h3 em{font-style:italic;color:#8FE05A}
.pillar p{font-size:16.5px;line-height:1.65;color:rgba(255,255,255,.78);margin-bottom:18px}
.pillar ul{list-style:none;padding:0;margin:18px 0;display:grid;gap:10px}
.pillar ul li{padding-left:22px;position:relative;font-size:15px;color:rgba(255,255,255,.85);line-height:1.6}
.pillar ul li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:#8FE05A}
@media (max-width:980px){.pillar{grid-template-columns:1fr;gap:36px;padding:80px 0}.pillar.flip{grid-template-columns:1fr;direction:ltr}}

/* --- Timeline (about) --- */
.tl{position:relative;padding:60px 0 60px 60px}
.tl::before{content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;background:linear-gradient(180deg, rgba(143,224,90,.6) 0%, rgba(143,224,90,.1) 100%)}
.tl-item{position:relative;padding:0 0 64px;margin-left:0}
.tl-item::before{content:"";position:absolute;left:-54px;top:6px;width:18px;height:18px;border-radius:50%;background:#8FE05A;box-shadow:0 0 18px rgba(143,224,90,.6),inset 0 0 6px rgba(0,0,0,.4)}
.tl-item .yr{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:#C9E5B0;text-transform:uppercase;margin-bottom:8px}
.tl-item h3{font-family:'Playfair Display',serif;font-weight:400;font-size:28px;line-height:1.15;color:#fff;margin-bottom:8px}
.tl-item p{font-size:15px;color:rgba(255,255,255,.78);line-height:1.65;max-width:640px}

/* --- Member tier blocks --- */
.mbr-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.mbr-tier{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:38px 32px;transition:all .35s}
.mbr-tier:hover{transform:translateY(-3px);border-color:rgba(143,224,90,.4);background:rgba(143,224,90,.04)}
.mbr-tier .tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:#FF9846;text-transform:uppercase;margin-bottom:14px}
.mbr-tier .name{font-family:'Playfair Display',serif;font-size:32px;color:#fff;margin-bottom:14px}
.mbr-tier ul{list-style:none;padding:0;margin:18px 0 28px;display:grid;gap:8px}
.mbr-tier ul li{padding-left:20px;position:relative;font-size:14.5px;color:rgba(255,255,255,.82);line-height:1.55}
.mbr-tier ul li::before{content:"+";position:absolute;left:0;top:0;color:#8FE05A;font-weight:700}
.mbr-tier .cta{display:inline-flex;align-items:center;gap:12px;padding:13px 22px;border-radius:999px;background:#C7541F;color:#fff;text-decoration:none;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;transition:all .25s}
.mbr-tier .cta:hover{background:#d96838;transform:translateY(-1px)}
@media (max-width:1080px){.mbr-row{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.mbr-row{grid-template-columns:1fr}}

/* --- Resources grid --- */
.res-search{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:8px 12px 8px 24px;max-width:680px;margin:42px 0 32px}
.res-search input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-family:'Inter';font-size:15px;padding:10px 0}
.res-search input::placeholder{color:rgba(255,255,255,.4)}
.res-search button{background:#C7541F;color:#fff;border:none;padding:10px 22px;border-radius:999px;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;font-weight:600;transition:background .25s}
.res-search button:hover{background:#d96838}
.res-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.res-tabs button{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.78);font-family:'JetBrains Mono';font-size:11px;letter-spacing:.18em;padding:10px 18px;border-radius:999px;cursor:pointer;transition:all .25s;text-transform:uppercase}
.res-tabs button.active,.res-tabs button:hover{background:rgba(143,224,90,.12);border-color:rgba(143,224,90,.4);color:#fff}
.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.res{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:28px;transition:all .35s;cursor:pointer}
.res:hover{transform:translateY(-3px);border-color:rgba(125,196,255,.4);background:rgba(125,196,255,.05)}
.res .type{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:#7DC4FF;text-transform:uppercase;margin-bottom:14px}
.res h3{font-family:'Playfair Display',serif;font-weight:400;font-size:22px;line-height:1.2;color:#fff;margin-bottom:10px}
.res p{font-size:13.5px;color:rgba(255,255,255,.7);line-height:1.55;margin-bottom:14px}
.res .meta{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.45);text-transform:uppercase;display:flex;gap:14px}
.res .meta .dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.3);align-self:center}

/* --- Events agenda list --- */
.ev-list{display:flex;flex-direction:column;gap:18px;margin-top:42px}
.ev{display:grid;grid-template-columns:130px 1fr auto;gap:32px;align-items:center;padding:28px 32px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;transition:all .35s;text-decoration:none;color:inherit}
.ev:hover{transform:translateX(6px);border-color:rgba(255,177,78,.4);background:rgba(255,177,78,.05)}
.ev .date{text-align:center}
.ev .date .day{font-family:'Playfair Display',serif;font-size:54px;line-height:1;color:#FFB14E}
.ev .date .mo{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-top:6px}
.ev .body h3{font-family:'Playfair Display',serif;font-weight:400;font-size:24px;line-height:1.2;color:#fff;margin-bottom:6px}
.ev .body p{font-size:14px;color:rgba(255,255,255,.7);margin:0}
.ev .body .where{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:#C9E5B0;text-transform:uppercase;margin-top:10px}
.ev .arrow{font-size:24px;color:#FFB14E}
@media (max-width:780px){.ev{grid-template-columns:90px 1fr;gap:18px;padding:18px 22px}.ev .arrow{display:none}.ev .date .day{font-size:38px}}

/* --- News feed --- */
.news-feed{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;margin-top:42px}
.news-feed > .feature{grid-row:span 2}
.news-card{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:28px;display:flex;flex-direction:column;justify-content:flex-end;min-height:280px;overflow:hidden;text-decoration:none;color:inherit;transition:all .35s;isolation:isolate}
.news-card:hover{transform:translateY(-3px);border-color:rgba(201,229,176,.4)}
.news-card.feature{min-height:600px}
.news-card.feature::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg, rgba(6,18,10,.10) 0%, rgba(6,18,10,.85) 100%)}
.news-card.feature::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(135deg, #1F4D32 0%, #06120A 100%)}
.news-card > *{position:relative;z-index:1}
.news-card .cat{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:#8FE05A;text-transform:uppercase;margin-bottom:12px}
.news-card h3{font-family:'Playfair Display',serif;font-weight:400;font-size:22px;line-height:1.2;color:#fff;margin-bottom:12px}
.news-card.feature h3{font-size:42px;line-height:1.05}
.news-card p{font-size:13.5px;color:rgba(255,255,255,.7);margin-bottom:14px;line-height:1.55}
.news-card .when{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.5);text-transform:uppercase}
@media (max-width:980px){.news-feed{grid-template-columns:1fr 1fr}.news-feed .feature{grid-row:auto;grid-column:span 2}}
@media (max-width:640px){.news-feed{grid-template-columns:1fr}.news-feed .feature{grid-column:auto}.news-card.feature{min-height:380px}.news-card.feature h3{font-size:30px}}

/* --- Contact form --- */
.ct-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;margin-top:42px;align-items:start}
.ct-form{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:38px}
.ct-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.ct-form .field{display:flex;flex-direction:column;gap:6px}
.ct-form label{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:rgba(201,229,176,.8);text-transform:uppercase}
.ct-form input,.ct-form select,.ct-form textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#fff;padding:14px 18px;font-family:'Inter';font-size:15px;outline:none;transition:border-color .25s, background .25s}
.ct-form input:focus,.ct-form select:focus,.ct-form textarea:focus{border-color:rgba(255,125,163,.5);background:rgba(255,255,255,.06)}
.ct-form textarea{min-height:160px;resize:vertical;font-family:'Inter'}
.ct-form button{margin-top:8px;padding:16px;background:#FF7DA3;color:#06120A;border:none;border-radius:999px;font-family:'JetBrains Mono';font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:all .25s;width:100%}
.ct-form button:hover{background:#fa5d8c;transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,125,163,.35)}
.ct-info .ct-block{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:28px;margin-bottom:14px}
.ct-info .ct-block h4{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:#FF7DA3;text-transform:uppercase;margin-bottom:14px}
.ct-info .ct-block p,.ct-info .ct-block a{font-size:14.5px;color:rgba(255,255,255,.85);line-height:1.6;text-decoration:none;display:block;margin-bottom:6px}
.ct-info .ct-block a:hover{color:#fff}
@media (max-width:980px){.ct-grid{grid-template-columns:1fr}.ct-form .row{grid-template-columns:1fr}}

/* Responsive padding for distinct pages */
@media (max-width:1080px){
  body.dpage .dpage-hero{padding:100px 32px 60px}
  body.dpage .dpage-section{padding:70px 32px}
  body.dpage .dpage-section.alt{padding:70px 32px}
  body.dpage .dpage-foot{padding:60px 32px 28px}
  body.dpage .dpage-foot-grid{grid-template-columns:1fr 1fr;gap:36px}
  .film-block .fb-beat{padding:0 32px}
}
@media (max-width:640px){
  body.dpage .dpage-foot-grid{grid-template-columns:1fr}
}
