/* ============================================================
   CCAS — flow architecture (no sticky pinning, no fixed header).
   Each page = stack of normal-flow sections (scenes + editorials
   + interlinks). Brand wayfinding is woven into the page, not
   docked at the top.
   ============================================================ */
:root{
  --bg-1:#061A0F;
  --bg-2:#0E2818;
  --leaf:#8FE05A;
  --mint:#C9E5B0;
  --terracotta:#C7541F;
  --ember:#FF9846;
  --flame-blue:#4A8AC4;
  --dawn:#B4C482;
  --smoke:#B4AA9E;
  --pill:999px;
  --maxw:1320px;
  --pad:80px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg-1);color:#fff;font-family:"Inter",-apple-system,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
/* When jumping to #fragment, give the section breathing room from the
   top so the heading isn't kissing the top edge of the viewport. */
:target, [id^="charter"], [id^="bylaws"], [id^="audit"], [id^="latest"], [id^="subscribe"], [id^="pillars"], [id^="give"], [id^="archive"], [id^="contact"], [id^="assets"], [id^="work"], section[id]{scroll-margin-top:40px}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ------------ scroll progress rail (4px top edge) ------------ */
.scroll-rail{position:fixed;top:0;left:0;right:0;height:4px;z-index:100;pointer-events:none;background:linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.08), rgba(255,255,255,.04))}
.scroll-rail .fill{height:100%;width:0;background:linear-gradient(90deg, var(--terracotta), var(--ember) 50%, var(--leaf));box-shadow:0 0 14px rgba(255,152,70,.55), 0 0 28px rgba(143,224,90,.25);transition:width .12s linear}

/* ------------ brand corner mark (in flow, not fixed) ------------ */
.brand-corner{position:absolute;top:28px;left:36px;z-index:6;display:inline-flex;align-items:center;gap:14px;padding:6px 10px 6px 4px;border-radius:var(--pill);transition:opacity .3s ease}
.brand-corner:hover{opacity:.92}
.brand-corner img.brand-icon, .brand-corner svg{flex:0 0 auto;display:block;filter:drop-shadow(0 0 14px rgba(143,224,90,.22)) drop-shadow(0 0 22px rgba(199,84,31,.20));width:44px;height:auto}
.brand-corner svg .ember{fill:rgba(199,84,31,.8)}
.brand-corner svg .leaf{fill:rgba(143,224,90,.85)}
.brand-corner .name{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:rgba(201,229,176,.88);letter-spacing:.22em;text-transform:uppercase;line-height:1.45}
.brand-corner .name strong{display:block;font-family:'Manrope';font-weight:700;color:#fff;font-size:16.5px;letter-spacing:.06em;margin-bottom:3px}
@media (max-width:780px){
  .brand-corner{top:20px;left:18px;gap:10px}
  .brand-corner img.brand-icon, .brand-corner svg{width:36px}
  .brand-corner .name{font-size:10.5px}
  .brand-corner .name strong{font-size:13.5px}
}

/* Footer logo (the small flame+leaf next to the CCAS wordmark) */
.film-footer img.footer-icon{display:block;filter:drop-shadow(0 0 10px rgba(143,224,90,.18))}

/* ------------ vertical folio strip (right margin) ------------ */
.folio-strip{position:absolute;top:32px;right:30px;z-index:6;font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(201,229,176,.6);writing-mode:vertical-rl;transform:rotate(180deg)}
.folio-strip strong{color:var(--leaf)}

/* ------------ floating quiet donate (bottom-right, only after hero) ------------ */
.float-donate{position:fixed;bottom:30px;right:30px;z-index:60;
  display:inline-flex;align-items:center;gap:12px;padding:11px 12px 11px 22px;
  border-radius:var(--pill);background:rgba(199,84,31,.92);color:#fff;
  font-family:'JetBrains Mono';font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 12px 36px rgba(0,0,0,.45);
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:opacity .5s, transform .5s;}
.float-donate.shown{opacity:1;transform:translateY(0);pointer-events:auto}
.float-donate:hover{background:#d96838;transform:translateY(-2px)}
.float-donate .arr{width:26px;height:26px;border-radius:50%;background:#fff;color:var(--terracotta);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}

/* ------------ SCENE — full-bleed video section ------------ */
.scene{position:relative;width:100%;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;isolation:isolate}
/* Scene videos fade at their top + bottom so where they meet a
   non-video section there's no hard edge — the video itself
   dissolves into the surrounding forest. */
.scene > video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.65) 12%, #000 25%, #000 75%, rgba(0,0,0,.55) 92%, transparent 100%);
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.65) 12%, #000 25%, #000 75%, rgba(0,0,0,.55) 92%, transparent 100%);
}
/* Hero scenes keep a crisp top (page begins there) */
.scene-hero > video{
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 75%, rgba(0,0,0,.55) 92%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 75%, rgba(0,0,0,.55) 92%, transparent 100%);
}
.scene > .vignette{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(6,18,10,.55) 0%, rgba(6,18,10,.10) 35%, rgba(6,18,10,.10) 60%, rgba(6,18,10,.95) 100%),
    linear-gradient(90deg, rgba(6,18,10,.55) 0%, rgba(6,18,10,.10) 50%, rgba(6,18,10,.0) 100%)
}
/* Subtle bleed bands — the video mask-image above does most of the
   dissolving; these just deepen the very edge for a clean meeting. */
.scene::before{
  content:"";position:absolute;left:0;right:0;top:0;height:18vh;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(6,18,10,.35) 0%, rgba(6,18,10,0) 100%)
}
.scene::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:18vh;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(6,18,10,0) 0%, rgba(6,18,10,.35) 100%)
}
.scene-hero::before{display:none} /* hero opens crisp */
.scene > .fx{position:absolute;inset:0;z-index:2;pointer-events:none;width:100%;height:100%}
.scene > .scene-body{position:relative;z-index:3;padding:56px var(--pad) 96px;width:100%;max-width:var(--maxw);margin:0 auto}
.scene-hero{align-items:center}
.scene-hero .scene-body{padding:140px var(--pad) 110px}

.scene .folio{font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.scene .folio::before{content:"";width:34px;height:1px;background:var(--mint)}
.scene .folio strong{color:#fff;font-weight:500}

.scene h1, .scene h2{font-family:'Playfair Display',serif;font-weight:400;color:#fff;margin-bottom:24px;text-shadow:0 0 60px rgba(0,0,0,.7), 0 2px 8px rgba(0,0,0,.5)}
.scene h1{font-size:clamp(54px,6.4vw,108px);line-height:1.0;letter-spacing:-2.2px;max-width:880px}
.scene h2{font-size:clamp(44px,5.2vw,84px);line-height:1.04;letter-spacing:-1.8px;max-width:780px}
.scene h1 em, .scene h2 em{font-style:italic;color:var(--leaf);text-shadow:0 0 50px rgba(143,224,90,.4);font-weight:400}
.scene h1 em.ember, .scene h2 em.ember{color:var(--ember);text-shadow:0 0 50px rgba(255,152,70,.45)}
.scene h1 em.smoke, .scene h2 em.smoke{color:#E8C8A0;text-shadow:0 0 50px rgba(232,200,160,.45)}
.scene h1 em.mint, .scene h2 em.mint{color:var(--mint);text-shadow:0 0 50px rgba(201,229,176,.45)}

.scene .lead{font-size:18px;line-height:1.65;color:rgba(255,255,255,.94);max-width:620px;margin-bottom:30px;font-weight:300;text-shadow:0 0 18px rgba(0,0,0,.65), 0 1px 2px rgba(0,0,0,.5)}

.scene .cta-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:8px}

/* ------------ EDITORIAL — interlude in the film ------------ */
/* Editorials share the same cinematic register as scenes:
   ambient backdrop video (low opacity, blurred), atmospheric color wash,
   and seamless bleed gradients between scene → editorial → scene. */
.editorial{position:relative;padding:140px 0 150px;width:100%;overflow:hidden;isolation:isolate;background:transparent}
/* Bleed bands: top and bottom of every editorial cross-fade INTO neighbours
   instead of fading to a hard black. The next/previous section's video
   shows through these bands for ~30vh, so seams dissolve. */
.editorial::before{
  content:"";position:absolute;left:0;right:0;top:0;height:18vh;z-index:4;pointer-events:none;
  background:linear-gradient(180deg, rgba(6,18,10,.35) 0%, rgba(6,18,10,0) 100%)
}
.editorial::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:18vh;z-index:4;pointer-events:none;
  background:linear-gradient(180deg, rgba(6,18,10,0) 0%, rgba(6,18,10,.35) 100%)
}
.editorial > .atmo{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
/* Editorial atmo video fades at top + bottom too — so the next/prev
   section's video can flow into it without a hard rectangle edge. */
.editorial > .atmo video{position:absolute;inset:-8%;width:116%;height:116%;object-fit:cover;
  filter:blur(20px) saturate(.78) brightness(.62);
  opacity:.78;transform:scale(1.08);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.55) 12%, #000 28%, #000 72%, rgba(0,0,0,.55) 88%, transparent 100%);
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.55) 12%, #000 28%, #000 72%, rgba(0,0,0,.55) 88%, transparent 100%);
}
.editorial > .atmo .wash{position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 25% 20%, rgba(199,84,31,.12) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 85%, rgba(143,224,90,.10) 0%, transparent 55%),
    linear-gradient(180deg, rgba(6,18,10,.20) 0%, rgba(6,18,10,.45) 100%);
  mix-blend-mode:normal}
.editorial > .atmo .grain{position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:3px 3px;
  mix-blend-mode:overlay;opacity:.4}
.editorial > .editorial-inner{position:relative;z-index:5;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

.editorial.dim > .atmo video{opacity:.32}
.editorial.dim > .atmo .wash{background:
  radial-gradient(ellipse at 25% 20%, rgba(143,224,90,.08) 0%, transparent 50%),
  radial-gradient(ellipse at 80% 85%, rgba(199,84,31,.06) 0%, transparent 55%),
  linear-gradient(180deg, rgba(6,18,10,.66) 0%, rgba(14,40,24,.85) 100%)}

.editorial .folio{font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint);margin-bottom:18px;display:flex;align-items:center;gap:14px}
.editorial .folio::before{content:"";width:34px;height:1px;background:var(--mint)}
.editorial .folio strong{color:#fff;font-weight:500}
.editorial > .editorial-inner > h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(40px,4.6vw,76px);line-height:1.04;letter-spacing:-1.5px;color:#fff;margin-bottom:20px;max-width:920px;text-shadow:0 0 40px rgba(0,0,0,.45)}
.editorial > .editorial-inner > h2 em{font-style:italic;color:var(--leaf);font-weight:400;text-shadow:0 0 40px rgba(143,224,90,.32)}
.editorial > .editorial-inner > h2 em.ember{color:var(--ember);text-shadow:0 0 40px rgba(255,152,70,.4)}
.editorial > .editorial-inner > .lead{font-size:18px;color:rgba(255,255,255,.88);max-width:680px;margin-bottom:54px;line-height:1.65}

/* ------------ pull quote (a moment-in-the-film) ------------ */
.pullquote{position:relative;margin:60px 0 60px;padding:40px 56px 36px 56px;max-width:920px;
  background:linear-gradient(135deg, rgba(143,224,90,.06) 0%, rgba(199,84,31,.04) 100%);
  border-radius:16px;border:1px solid rgba(143,224,90,.18);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 24px 60px rgba(0,0,0,.35)}
.pullquote::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;
  background:linear-gradient(180deg, transparent 0%, var(--leaf) 30%, var(--leaf) 70%, transparent 100%);
  border-radius:3px;box-shadow:0 0 24px rgba(143,224,90,.5)}
.pullquote p{font-family:'Playfair Display';font-style:italic;font-weight:400;font-size:clamp(26px,2.4vw,38px);line-height:1.3;color:#fff;margin-bottom:20px;letter-spacing:-.4px;text-shadow:0 0 30px rgba(0,0,0,.4)}
.pullquote p em{color:var(--leaf);font-style:italic;text-shadow:0 0 28px rgba(143,224,90,.4)}
.pullquote .src{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint)}

/* ------------ stats row (cinematic data overlay) ------------ */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:48px 60px;margin:50px 0 60px}
.stat{position:relative;padding-left:18px}
.stat::before{content:"";position:absolute;left:0;top:6px;bottom:30%;width:1px;
  background:linear-gradient(180deg, var(--leaf) 0%, transparent 100%);opacity:.55}
.stat .v{font-family:'Playfair Display';font-size:clamp(46px,4.2vw,72px);font-weight:400;line-height:1;color:#fff;letter-spacing:-1.6px;margin-bottom:8px;text-shadow:0 0 30px rgba(0,0,0,.55)}
.stat .v em{font-style:italic;color:var(--leaf);text-shadow:0 0 36px rgba(143,224,90,.45)}
.stat .v em.ember{color:var(--ember);text-shadow:0 0 36px rgba(255,152,70,.5)}
.stat .l{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:var(--mint);text-transform:uppercase;margin-bottom:8px;line-height:1.5}
.stat .d{font-size:14px;color:rgba(255,255,255,.78);line-height:1.55;max-width:280px}

/* ------------ cards grid (cinematic glass treatment) ------------ */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-bottom:60px}
.card{position:relative;background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:32px;overflow:hidden;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 18px 48px rgba(0,0,0,.30);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .4s, background .4s, box-shadow .4s}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg, var(--terracotta) 0%, var(--leaf) 100%);opacity:0;transition:opacity .4s}
.card:hover{transform:translateY(-4px);border-color:rgba(143,224,90,.40);background:linear-gradient(180deg, rgba(143,224,90,.08) 0%, rgba(143,224,90,.02) 100%);box-shadow:inset 0 1px 0 rgba(143,224,90,.15), 0 24px 60px rgba(0,0,0,.45)}
.card:hover::before{opacity:.85}
.card .num{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:var(--mint);text-transform:uppercase;margin-bottom:14px}
.card h3{font-family:'Playfair Display',serif;font-weight:400;font-size:24px;line-height:1.2;color:#fff;margin-bottom:10px}
.card p{font-size:14.5px;color:rgba(255,255,255,.82);line-height:1.6;margin-bottom:16px}
.card .more{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:var(--leaf);text-transform:uppercase;border-bottom:1px solid rgba(143,224,90,.4);padding-bottom:2px;display:inline-block;transition:color .25s,border-color .25s}
.card .more:hover{color:#fff;border-color:#fff}

/* ------------ programme doors (used on programmes) ------------ */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:80px}
.door{display:block;position:relative;border-radius:18px;overflow:hidden;aspect-ratio:1.05/1;border:1px solid rgba(255,255,255,.08);transition:all .5s cubic-bezier(.2,.8,.2,1);background:#0c1f12}
.door::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(6,18,10,.05) 0%, rgba(6,18,10,.85) 100%);z-index:2;transition:opacity .5s}
.door .door-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;opacity:.85;transition:transform 1.2s cubic-bezier(.2,.8,.2,1),opacity .5s}
.door:hover{transform:translateY(-4px);border-color:rgba(143,224,90,.45)}
.door:hover .door-bg{transform:scale(1.06);opacity:1}
.door .door-body{position:absolute;left:0;right:0;bottom:0;padding:30px;z-index:3;color:#fff}
.door .door-num{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.24em;color:var(--mint);text-transform:uppercase;margin-bottom:14px}
.door h3{font-family:'Playfair Display',serif;font-style:italic;font-weight:400;font-size:32px;line-height:1.05;color:#fff;margin-bottom:8px}
.door p{font-size:13.5px;color:rgba(255,255,255,.82);line-height:1.6;max-width:280px}
@media (max-width:980px){.doors{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.doors{grid-template-columns:1fr}}

/* ------------ live counter strip ------------ */
.counter-strip{margin:0 auto 80px;padding:64px 50px;border-radius:20px;border:1px solid rgba(143,224,90,.18);background:linear-gradient(135deg,rgba(199,84,31,.06) 0%,rgba(143,224,90,.04) 100%);text-align:center;max-width:920px}
.counter-strip .lbl{font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint);margin-bottom:14px}
.counter-strip .v{font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,96px);line-height:1;letter-spacing:-2px;color:var(--ember);text-shadow:0 0 60px rgba(255,152,70,.35)}
.counter-strip .d{font-family:'Inter';font-size:14px;color:rgba(255,255,255,.72);margin:14px auto 0;max-width:540px}

/* ------------ CTAs ------------ */
.cta{display:inline-flex;align-items:center;gap:14px;padding:14px 14px 14px 28px;border-radius:var(--pill);font-family:'JetBrains Mono';font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;transition:transform .25s,box-shadow .25s,background .25s,border-color .25s,color .25s;white-space:nowrap}
.cta .arr{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.cta.primary{background:var(--terracotta);color:#fff}
.cta.primary .arr{background:#fff;color:var(--terracotta)}
.cta.primary:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(199,84,31,.45);background:#d96838}
.cta.ghost{background:rgba(255,255,255,.05);color:#fff;border:1px solid rgba(255,255,255,.18)}
.cta.ghost .arr{background:rgba(255,255,255,.10);color:#fff}
.cta.ghost:hover{background:rgba(143,224,90,.10);border-color:rgba(143,224,90,.55);color:var(--leaf)}
.cta.ghost:hover .arr{background:var(--leaf);color:var(--bg-1)}
.cta.leaf{background:rgba(143,224,90,.12);color:var(--leaf);border:1px solid rgba(143,224,90,.32)}
.cta.leaf .arr{background:var(--leaf);color:var(--bg-1)}
.cta.leaf:hover{background:rgba(143,224,90,.20);border-color:var(--leaf)}

/* a tiny inline link variant (used inside paragraphs) */
.ilink{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:var(--leaf);text-transform:uppercase;border-bottom:1px solid rgba(143,224,90,.4);padding-bottom:2px;transition:border-color .2s,color .2s}
.ilink:hover{border-color:var(--leaf);color:#fff}

/* ------------ CROSSLINK — interconnect to other pages ------------ */
.crosslink{position:relative;padding:140px var(--pad) 140px;max-width:var(--maxw);margin:0 auto}
.crosslink > .folio{font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint);margin-bottom:14px;display:flex;align-items:center;gap:14px}
.crosslink > .folio::before{content:"";width:34px;height:1px;background:var(--mint)}
.crosslink > h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(40px,4.4vw,72px);line-height:1.04;letter-spacing:-1.5px;color:#fff;margin-bottom:48px;max-width:880px}
.crosslink > h2 em{font-style:italic;color:var(--leaf)}
.crosslink-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.cross{display:block;padding:32px;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.02);transition:all .35s;position:relative;overflow:hidden}
.cross:hover{transform:translateY(-3px);border-color:rgba(143,224,90,.45);background:rgba(143,224,90,.05)}
.cross .num{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.24em;color:var(--mint);text-transform:uppercase;margin-bottom:12px}
.cross h3{font-family:'Playfair Display';font-style:italic;font-weight:400;font-size:30px;line-height:1.05;color:#fff;margin-bottom:12px}
.cross p{font-size:14px;color:rgba(255,255,255,.78);line-height:1.6;margin-bottom:18px}
.cross .more{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.24em;color:var(--leaf);text-transform:uppercase}
.cross::after{content:"→";position:absolute;top:32px;right:32px;font-family:'JetBrains Mono';font-size:18px;color:rgba(143,224,90,.4);transition:color .3s,transform .3s}
.cross:hover::after{color:var(--leaf);transform:translateX(4px)}

/* ------------ partner band ------------ */
.partner-band{padding:64px var(--pad);text-align:center;border-top:1px solid rgba(255,255,255,.06)}
.partner-band .lbl{font-family:'JetBrains Mono';font-size:10.5px;color:rgba(255,255,255,.4);letter-spacing:.22em;text-transform:uppercase;margin-bottom:24px}
.partner-band .row{display:flex;align-items:center;justify-content:center;gap:46px;flex-wrap:wrap}
.partner-band .partner{font-family:'Manrope';font-weight:600;font-size:13px;color:rgba(255,255,255,.55);letter-spacing:.04em}

/* ------------ footer ------------ */
.film-footer{background:#06100A;color:rgba(255,255,255,.82);padding:80px var(--pad) 36px;border-top:1px solid rgba(255,255,255,.06);position:relative;z-index:2}
.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';font-size:11px;letter-spacing:.22em;color:var(--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,.82);font-size:14px;transition:color .25s}
.film-footer ul a:hover{color:#fff}
.film-footer p{color:rgba(255,255,255,.7);font-size:13px;line-height:1.6;max-width:380px;margin-top:14px}
.film-footer-bot{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.06);padding-top:24px;font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:rgba(255,255,255,.62);text-transform:uppercase;max-width:1400px;margin:0 auto}

/* ------------ reveal-on-scroll ------------ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s cubic-bezier(.2,.8,.2,1), transform .55s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform}
.reveal.lit, .reveal.in{opacity:1;transform:translateY(0)}
/* Hard safety: if both JS observers and the safety timer fail (eg user
   has JS disabled), the section becomes visible after a CSS animation
   too — runs once on page-load. Pages can NEVER stay blank. */
@keyframes hardReveal { to { opacity:1; transform:translateY(0) } }
.reveal{ animation: hardReveal 0.01s 6s linear forwards }
.reveal.lit, .reveal.in{ animation:none }

/* ------------ responsive ------------ */
@media (max-width:1080px){
  :root{--pad:32px}
  .editorial,.crosslink{padding-left:32px;padding-right:32px}
  .scene .scene-body{padding-left:32px;padding-right:32px}
  .film-footer{padding:60px 32px 28px}
  .film-footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .partner-band{padding:48px 32px}
  .partner-band .row{gap:24px}
  .brand-corner{top:22px;left:22px}
  .folio-strip{top:22px;right:18px}
}
@media (max-width:640px){
  .scene-hero .scene-body{padding-top:120px;padding-bottom:80px}
  .scene h1{font-size:46px;letter-spacing:-1.4px}
  .scene h2{font-size:38px;letter-spacing:-1px}
  .editorial > h2, .crosslink > h2{font-size:36px;letter-spacing:-1px}
  .film-footer-grid{grid-template-columns:1fr}
  .float-donate{right:14px;bottom:14px;font-size:10px;padding:9px 12px 9px 18px}
  .folio-strip{display:none}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
}

/* ============================================================
   CHEMISTRY LAYER — section-bridging system
   1. Continuous-atmosphere canvas (drifts behind every section)
   2. Color-arc tint per section via data-tint
   3. Persistent grain across the whole film
   ============================================================ */

/* fixed canvas — particulate haze across the entire film */
.atmo-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:5;pointer-events:none;
  mix-blend-mode:screen;opacity:.78;
}
/* Ambient bed — sits BENEATH every section. Slow-moving radial
   gradients give non-video sections the same "living" quality as
   video ones, so the seam between video and no-video sections
   stops feeling like a cliff. Pure CSS, zero bandwidth. */
.film::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 22% 18%, rgba(199,84,31,.10) 0%, transparent 48%),
    radial-gradient(ellipse at 78% 82%, rgba(143,224,90,.08) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(232,200,160,.04) 0%, transparent 65%),
    linear-gradient(180deg, #06180D 0%, #0A2014 100%);
  animation:ambientDrift 38s ease-in-out infinite alternate;
}
@keyframes ambientDrift{
  0%   { background-position: 0% 0%,  100% 100%, 50% 50%, 0 0 }
  50%  { background-position: 12% 8%, 84% 92%,   46% 52%, 0 0 }
  100% { background-position: -6% 4%, 94% 88%,   54% 48%, 0 0 }
}
/* persistent grain layer over the whole film */
.film::after{
  content:"";position:fixed;inset:0;z-index:2;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.02) 1px, transparent 1px);
  background-size:3px 3px;mix-blend-mode:overlay;opacity:.35;
}

/* ensure scene/editorial bodies stay above the global atmo + grain */
.film > .scene{z-index:3}
.film > .editorial{z-index:3}
.film > .crosslink{z-index:3;background:transparent}
.film > .partner-band{z-index:3;background:transparent}
.film > .film-footer{z-index:3}

/* Color-arc tints — translucent so the fixed ambient bed (.film::before)
   and atmo canvas glow through every section. This is what makes the
   whole film read as one fabric rather than a stack of pages. */
[data-tint="forest"]{ --tint:#8FE05A; --tint-deep:rgba(14,40,24,.45); }
[data-tint="smoke"] { --tint:#E8C8A0; --tint-deep:rgba(58,46,38,.40); }
[data-tint="ember"] { --tint:#FF9846; --tint-deep:rgba(58,20,8,.42); }
[data-tint="flame"] { --tint:#4A8AC4; --tint-deep:rgba(14,32,48,.45); }
[data-tint="dawn"]  { --tint:#B4C482; --tint-deep:rgba(31,42,24,.40); }
[data-tint="ash"]   { --tint:#B4AA9E; --tint-deep:rgba(36,31,26,.40); }

/* Translucent tint overlay — the ambient bed underneath shows
   through so every section breathes the same air. */
.scene[data-tint], .editorial[data-tint]{
  background-color:var(--tint-deep);
}
.scene[data-tint] > .vignette,
.editorial[data-tint] > .atmo .wash{
  background-image:
    radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0) 0%, color-mix(in oklab, var(--tint) 14%, transparent) 60%, transparent 100%),
    linear-gradient(180deg, rgba(6,18,10,.55) 0%, rgba(6,18,10,.10) 35%, rgba(6,18,10,.10) 60%, rgba(6,18,10,.92) 100%);
}

/* Color-arc warming on em accents inside tinted sections */
[data-tint="ember"] h1 em, [data-tint="ember"] h2 em{ color:var(--ember);text-shadow:0 0 50px rgba(255,152,70,.45) }
[data-tint="flame"] h1 em, [data-tint="flame"] h2 em{ color:var(--flame-blue);text-shadow:0 0 50px rgba(74,138,196,.45) }
[data-tint="smoke"] h1 em, [data-tint="smoke"] h2 em{ color:#E8C8A0;text-shadow:0 0 50px rgba(232,200,160,.45) }
[data-tint="dawn"]  h1 em, [data-tint="dawn"]  h2 em{ color:var(--dawn);text-shadow:0 0 50px rgba(180,196,130,.45) }


/* ============================================================
   PER-PAGE ANATOMY — each page gets its own identity.
   <body data-page="about"> etc. scopes the overrides.
   Same chemistry, different breath.
   ============================================================ */

/* ---------- ABOUT — held wide, three long chapters, 8s ember pulse ---------- */
body[data-page="about"] .scene-hero{ min-height:100vh }
body[data-page="about"] .scene-hero > video{ filter:contrast(1.05) saturate(.95); animation:emberBreath 8s ease-in-out infinite }
body[data-page="about"] .scene h1{ max-width:980px; font-size:clamp(58px,6.6vw,116px) }
body[data-page="about"] .editorial{ padding:180px 0 200px } /* slow read */
body[data-page="about"] .doors{ display:none } /* about has no doors */
@keyframes emberBreath{ 0%,100%{filter:contrast(1.05) saturate(.95) brightness(1)} 50%{filter:contrast(1.08) saturate(1.05) brightness(1.06)} }

/* ---------- PROGRAMMES — six-door grid hero, 0.4s stagger ---------- */
body[data-page="programmes"] .prog-hero{
  position:relative;min-height:100vh;padding:140px var(--pad) 100px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:radial-gradient(ellipse at 30% 30%, rgba(143,224,90,.10) 0%, transparent 55%), transparent;
}
body[data-page="programmes"] .prog-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:980px;margin-bottom:24px }
body[data-page="programmes"] .prog-hero h1 em{ font-style:italic;color:var(--leaf) }
body[data-page="programmes"] .prog-hero .lead{ font-size:18px;line-height:1.65;color:rgba(255,255,255,.86);max-width:640px;margin-bottom:54px }
body[data-page="programmes"] .prog-doors{ display:grid;grid-template-columns:repeat(3,1fr);gap:14px }
body[data-page="programmes"] .prog-doors .door{ aspect-ratio:1.15/1 }
body[data-page="programmes"] .prog-doors .door:nth-child(1){animation:doorIn .9s .05s cubic-bezier(.2,.8,.2,1) both}
body[data-page="programmes"] .prog-doors .door:nth-child(2){animation:doorIn .9s .45s cubic-bezier(.2,.8,.2,1) both}
body[data-page="programmes"] .prog-doors .door:nth-child(3){animation:doorIn .9s .85s cubic-bezier(.2,.8,.2,1) both}
body[data-page="programmes"] .prog-doors .door:nth-child(4){animation:doorIn .9s 1.25s cubic-bezier(.2,.8,.2,1) both}
body[data-page="programmes"] .prog-doors .door:nth-child(5){animation:doorIn .9s 1.65s cubic-bezier(.2,.8,.2,1) both}
body[data-page="programmes"] .prog-doors .door:nth-child(6){animation:doorIn .9s 2.05s cubic-bezier(.2,.8,.2,1) both}
@keyframes doorIn{ from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@media (max-width:980px){ body[data-page="programmes"] .prog-doors{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ body[data-page="programmes"] .prog-doors{grid-template-columns:1fr} }

/* ---------- NEWS — dated strip hero, 1s tick ---------- */
body[data-page="news"] .news-hero{
  min-height:100vh;padding:140px var(--pad) 90px;
  background:linear-gradient(180deg, transparent 0%, #0a1f12 100%);
}
body[data-page="news"] .news-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:920px;margin-bottom:18px }
body[data-page="news"] .news-hero h1 em{ font-style:italic;color:var(--leaf) }
body[data-page="news"] .news-hero .lead{ font-size:17px;color:rgba(255,255,255,.82);max-width:580px;margin-bottom:54px }
body[data-page="news"] .news-strip{ border-top:1px solid rgba(255,255,255,.10);max-width:var(--maxw);margin:0 auto }
body[data-page="news"] .news-row{
  display:grid;grid-template-columns:140px 1fr 200px;gap:32px;align-items:center;
  padding:26px 0;border-bottom:1px solid rgba(255,255,255,.07);
  transition:background .25s,padding .25s;
}
body[data-page="news"] .news-row:hover{ background:rgba(143,224,90,.04);padding-left:14px }
body[data-page="news"] .news-row .date{ font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.18em;color:var(--mint);text-transform:uppercase }
body[data-page="news"] .news-row .ttl{ font-family:'Playfair Display';font-style:italic;font-size:24px;line-height:1.25;color:#fff }
body[data-page="news"] .news-row .tag{ font-family:'JetBrains Mono';font-size:10px;letter-spacing:.22em;color:rgba(255,255,255,.55);text-transform:uppercase;text-align:right }
body[data-page="news"] .tick-dot{ display:inline-block;width:6px;height:6px;background:var(--leaf);border-radius:50%;margin-right:10px;animation:newsTick 1s ease-in-out infinite }
@keyframes newsTick{ 0%,100%{opacity:.3;transform:scale(1)} 50%{opacity:1;transform:scale(1.4)} }
@media (max-width:780px){ body[data-page="news"] .news-row{grid-template-columns:1fr;gap:8px} body[data-page="news"] .news-row .tag{text-align:left} }

/* ---------- EVENTS — calendar river, 2s pulse ---------- */
body[data-page="events"] .events-hero{
  min-height:100vh;padding:140px var(--pad) 100px;
  background:radial-gradient(ellipse at 70% 40%, rgba(199,84,31,.12) 0%, transparent 55%), transparent;
}
body[data-page="events"] .events-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:920px;margin-bottom:24px }
body[data-page="events"] .events-hero h1 em{ font-style:italic;color:var(--ember) }
body[data-page="events"] .events-hero .lead{ font-size:17px;color:rgba(255,255,255,.85);max-width:600px;margin-bottom:50px }
body[data-page="events"] .calendar-river{ position:relative;max-width:960px;margin:0 auto;padding-left:68px }
body[data-page="events"] .calendar-river::before{
  content:"";position:absolute;left:30px;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg, transparent 0%, var(--ember) 8%, var(--ember) 92%, transparent 100%);
  opacity:.45;
}
body[data-page="events"] .ev-row{ position:relative;display:grid;grid-template-columns:130px 1fr 130px;gap:28px;align-items:center;padding:26px 0;border-bottom:1px solid rgba(255,255,255,.07) }
body[data-page="events"] .ev-row::before{
  content:"";position:absolute;left:-46px;top:50%;width:14px;height:14px;border-radius:50%;
  background:var(--ember);box-shadow:0 0 0 4px rgba(199,84,31,.14);transform:translateY(-50%);
  animation:evPulse 2s ease-in-out infinite;
}
body[data-page="events"] .ev-row .date{ font-family:'JetBrains Mono';font-size:11.5px;letter-spacing:.18em;color:var(--mint);text-transform:uppercase }
body[data-page="events"] .ev-row .date strong{ display:block;font-family:'Playfair Display';font-style:italic;font-size:32px;color:#fff;letter-spacing:-.5px;margin-top:4px }
body[data-page="events"] .ev-row .ttl{ font-family:'Playfair Display';font-style:italic;font-size:26px;line-height:1.25;color:#fff }
body[data-page="events"] .ev-row .ttl span{ display:block;font-family:'Inter';font-style:normal;font-size:14px;color:rgba(255,255,255,.7);margin-top:6px }
body[data-page="events"] .ev-row .place{ font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.22em;color:rgba(255,255,255,.55);text-transform:uppercase;text-align:right }
@keyframes evPulse{ 0%,100%{box-shadow:0 0 0 4px rgba(199,84,31,.14),0 0 0 0 rgba(199,84,31,.6)} 50%{box-shadow:0 0 0 4px rgba(199,84,31,.14),0 0 0 14px rgba(199,84,31,0)} }
@media (max-width:780px){ body[data-page="events"] .calendar-river{padding-left:40px} body[data-page="events"] .ev-row{grid-template-columns:1fr;gap:8px} body[data-page="events"] .ev-row .place{text-align:left} }

/* ---------- MEMBERS — portrait wall, 1.4s fade ---------- */
body[data-page="members"] .members-hero{
  min-height:100vh;padding:140px var(--pad) 110px;
  background:linear-gradient(180deg, transparent 0%, #0a1c11 100%);
}
body[data-page="members"] .members-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:980px;margin-bottom:18px }
body[data-page="members"] .members-hero h1 em{ font-style:italic;color:var(--leaf) }
body[data-page="members"] .members-hero .lead{ font-size:17px;color:rgba(255,255,255,.85);max-width:600px;margin-bottom:50px }
body[data-page="members"] .portrait-wall{ display:grid;grid-template-columns:repeat(6,1fr);gap:8px;max-width:var(--maxw);margin:0 auto }
body[data-page="members"] .portrait{
  position:relative;aspect-ratio:.78/1;border-radius:6px;overflow:hidden;
  background:linear-gradient(180deg, rgba(143,224,90,.08), rgba(199,84,31,.05));
  border:1px solid rgba(255,255,255,.06);
  animation:portraitFade 1.4s ease both;
}
body[data-page="members"] .portrait video{ position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.7;filter:saturate(.85) }
body[data-page="members"] .portrait::after{ content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 50%, rgba(6,18,10,.85) 100%) }
body[data-page="members"] .portrait .nm{ position:absolute;left:14px;right:14px;bottom:12px;z-index:2;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.18em;color:#fff;text-transform:uppercase }
body[data-page="members"] .portrait .nm em{ display:block;font-family:'Playfair Display';font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:var(--mint);margin-top:4px }
body[data-page="members"] .portrait:nth-child(2n){ animation-delay:.18s }
body[data-page="members"] .portrait:nth-child(3n){ animation-delay:.36s }
body[data-page="members"] .portrait:nth-child(5n){ animation-delay:.54s }
@keyframes portraitFade{ from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
@media (max-width:980px){ body[data-page="members"] .portrait-wall{grid-template-columns:repeat(4,1fr)} }
@media (max-width:640px){ body[data-page="members"] .portrait-wall{grid-template-columns:repeat(3,1fr)} }

/* ---------- DONATE — ember meter, 0.6s flicker ---------- */
body[data-page="donate"] .donate-hero{
  min-height:100vh;padding:140px var(--pad) 110px;
  background:radial-gradient(ellipse at 50% 70%, rgba(199,84,31,.16) 0%, transparent 55%), transparent;
}
body[data-page="donate"] .donate-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:980px;margin-bottom:24px }
body[data-page="donate"] .donate-hero h1 em{ font-style:italic;color:var(--ember);animation:emberFlicker .6s ease-in-out infinite }
body[data-page="donate"] .donate-hero .lead{ font-size:17px;color:rgba(255,255,255,.86);max-width:620px;margin-bottom:54px }
body[data-page="donate"] .ember-meter{
  position:relative;max-width:880px;margin:0 auto 60px;
  height:64px;border-radius:32px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,152,70,.30);
  overflow:hidden;
}
body[data-page="donate"] .ember-meter .fill{
  position:absolute;left:0;top:0;bottom:0;width:62%;
  background:linear-gradient(90deg, var(--terracotta), var(--ember));
  box-shadow:0 0 60px rgba(255,152,70,.55);
  animation:emberFlicker .6s ease-in-out infinite;
}
body[data-page="donate"] .ember-meter .lbl{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 28px;
  font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:#fff;text-transform:uppercase;z-index:2;
}
body[data-page="donate"] .tier-grid{ display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:var(--maxw);margin:0 auto 80px }
body[data-page="donate"] .tier{ padding:32px;border-radius:14px;border:1px solid rgba(255,152,70,.20);background:rgba(255,152,70,.04);transition:all .35s }
body[data-page="donate"] .tier:hover{ transform:translateY(-4px);border-color:var(--ember);background:rgba(255,152,70,.08) }
body[data-page="donate"] .tier .amt{ font-family:'Playfair Display';font-style:italic;font-size:42px;color:var(--ember);line-height:1;margin-bottom:8px }
body[data-page="donate"] .tier .ttl{ font-family:'JetBrains Mono';font-size:10px;letter-spacing:.22em;color:var(--mint);text-transform:uppercase;margin-bottom:12px }
body[data-page="donate"] .tier .desc{ font-size:13.5px;color:rgba(255,255,255,.78);line-height:1.55 }
@keyframes emberFlicker{ 0%,100%{opacity:1;filter:brightness(1)} 35%{opacity:.92;filter:brightness(1.08)} 70%{opacity:.96;filter:brightness(.96)} }
@media (max-width:980px){ body[data-page="donate"] .tier-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:560px){ body[data-page="donate"] .tier-grid{grid-template-columns:1fr} }

/* ---------- CONTACT — switchboard map, 3s ping ---------- */
body[data-page="contact"] .contact-hero{
  min-height:100vh;padding:140px var(--pad) 110px;
  background:radial-gradient(ellipse at 30% 50%, rgba(143,224,90,.10) 0%, transparent 60%), transparent;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  max-width:var(--maxw);margin:0 auto;
}
body[data-page="contact"] .contact-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,96px);line-height:1;letter-spacing:-2px;color:#fff;margin-bottom:24px }
body[data-page="contact"] .contact-hero h1 em{ font-style:italic;color:var(--leaf) }
body[data-page="contact"] .contact-hero .lead{ font-size:17px;color:rgba(255,255,255,.86);max-width:480px;margin-bottom:30px }
body[data-page="contact"] .contact-hero .pair{ font-family:'JetBrains Mono';font-size:13px;color:rgba(255,255,255,.85);letter-spacing:.04em;line-height:2 }
body[data-page="contact"] .contact-hero .pair strong{ display:inline-block;width:120px;color:var(--mint);font-weight:500;letter-spacing:.18em;font-size:10.5px;text-transform:uppercase }
body[data-page="contact"] .switchboard{ position:relative;aspect-ratio:360/460;border-radius:18px;overflow:hidden;border:1px solid rgba(143,224,90,.22);background:radial-gradient(ellipse at center, #143020 0%, #061A0F 100%);min-height:420px }
body[data-page="contact"] .switchboard .map-svg{ position:absolute;inset:0;width:100%;height:100%;opacity:.95 }
/* Pulse animation applied inside assets/somalia.svg via <style> on .map-pin-pulse */
@keyframes pinPing{ 0%,100%{r:4;opacity:1} 50%{r:14;opacity:.2} }
body[data-page="contact"] .contact-form{ max-width:760px;margin:0 auto;padding:60px var(--pad) 120px;display:grid;gap:18px }
body[data-page="contact"] .contact-form input, body[data-page="contact"] .contact-form textarea{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);border-radius:10px;
  padding:16px 18px;color:#fff;font-family:'Inter';font-size:15px;transition:border-color .25s,background .25s;
}
body[data-page="contact"] .contact-form textarea{ min-height:160px;resize:vertical }
body[data-page="contact"] .contact-form input:focus, body[data-page="contact"] .contact-form textarea:focus{ outline:none;border-color:var(--leaf);background:rgba(143,224,90,.06) }
body[data-page="contact"] .contact-form button{
  justify-self:flex-start;background:var(--terracotta);color:#fff;
  padding:15px 32px;border-radius:var(--pill);
  font-family:'JetBrains Mono';font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  transition:transform .25s,box-shadow .25s;
}
body[data-page="contact"] .contact-form button:hover{ transform:translateY(-2px);box-shadow:0 18px 48px rgba(199,84,31,.45);background:#d96838 }
body[data-page="contact"] .contact-note{ margin-top:12px;font-size:14px;line-height:1.55;color:rgba(255,255,255,.86) }
body[data-page="contact"] .contact-note:not(:empty){ padding:14px 18px;border-radius:10px;background:rgba(143,224,90,.08);border:1px solid rgba(143,224,90,.22) }
body[data-page="contact"] .contact-note strong{ color:var(--leaf);font-weight:500 }
@media (max-width:980px){ body[data-page="contact"] .contact-hero{grid-template-columns:1fr} }

/* ---------- RESOURCES — open shelf, hover-glow ---------- */
body[data-page="resources"] .lib-hero{
  min-height:100vh;padding:140px var(--pad) 110px;
  background:radial-gradient(ellipse at 70% 30%, rgba(143,224,90,.08) 0%, transparent 55%), transparent;
}
body[data-page="resources"] .lib-hero h1{ font-family:'Playfair Display';font-weight:400;font-size:clamp(54px,6.4vw,108px);line-height:1;letter-spacing:-2px;color:#fff;max-width:980px;margin-bottom:18px }
body[data-page="resources"] .lib-hero h1 em{ font-style:italic;color:var(--leaf) }
body[data-page="resources"] .lib-hero .lead{ font-size:17px;color:rgba(255,255,255,.85);max-width:620px;margin-bottom:54px }
body[data-page="resources"] .shelf{ display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:var(--maxw);margin:0 auto }
body[data-page="resources"] .book{
  position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  aspect-ratio:.72/1;padding:22px;border-radius:8px;
  background:linear-gradient(180deg, #1A2D1F 0%, #0A1C11 100%);
  border:1px solid rgba(255,255,255,.10);overflow:hidden;
  transition:transform .4s,border-color .4s,box-shadow .4s;
}
body[data-page="resources"] .book::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg, var(--leaf), var(--terracotta));opacity:.85;
}
body[data-page="resources"] .book:hover{ transform:translateY(-6px);border-color:var(--leaf);box-shadow:0 24px 60px rgba(143,224,90,.18) }
body[data-page="resources"] .book .typ{ font-family:'JetBrains Mono';font-size:10px;letter-spacing:.22em;color:var(--mint);text-transform:uppercase;margin-bottom:10px }
body[data-page="resources"] .book .ttl{ font-family:'Playfair Display';font-style:italic;font-size:22px;line-height:1.2;color:#fff;margin-bottom:10px }
body[data-page="resources"] .book .meta{ font-family:'JetBrains Mono';font-size:9.5px;letter-spacing:.18em;color:rgba(255,255,255,.55);text-transform:uppercase }
@media (max-width:980px){ body[data-page="resources"] .shelf{grid-template-columns:repeat(3,1fr)} }
@media (max-width:640px){ body[data-page="resources"] .shelf{grid-template-columns:repeat(2,1fr)} }

/* ============================================================
   SITE HEADER — premium floating glass nav with dropdowns
   Present on every page incl. the Earth landing. Two mega-menus
   (About / The Work) surface every page. Modern button styling.
   ============================================================ */
.sh-skip{position:fixed;top:-60px;left:18px;z-index:200;background:var(--leaf);color:#06180D;
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;letter-spacing:.08em;
  padding:12px 18px;border-radius:10px;transition:top .25s}
.sh-skip:focus{top:14px;outline:none}

.site-header{
  position:fixed;top:0;left:0;right:0;z-index:120; /* above the intro (100) */
  display:flex;justify-content:center;
  padding:18px clamp(14px,3vw,28px);
  pointer-events:none;
  transition:padding .4s cubic-bezier(.2,.8,.2,1), transform .45s cubic-bezier(.2,.8,.2,1), opacity .4s ease;
}
.site-header-inner{
  pointer-events:auto;width:100%;max-width:1200px;
  display:flex;align-items:center;gap:18px;
  padding:9px 9px 9px 18px;border-radius:20px;
  background:linear-gradient(180deg, rgba(12,30,18,.52), rgba(6,18,10,.46));
  backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 18px 50px rgba(0,0,0,.34);
  transition:max-width .45s cubic-bezier(.2,.8,.2,1), padding .35s ease,
             background .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.site-header.scrolled{padding-top:10px;padding-bottom:10px}
.site-header.scrolled .site-header-inner{
  max-width:1150px;
  background:linear-gradient(180deg, rgba(10,28,16,.82), rgba(6,18,10,.80));
  border-color:rgba(143,224,90,.18);
  box-shadow:0 1px 0 rgba(255,255,255,.07) inset, 0 22px 60px rgba(0,0,0,.5);
}

/* Brand */
.sh-brand{display:inline-flex;align-items:center;gap:13px;flex:0 0 auto;text-decoration:none}
.sh-brand img{display:block;width:40px;height:auto;filter:drop-shadow(0 0 12px rgba(143,224,90,.22)) drop-shadow(0 0 18px rgba(199,84,31,.16));transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.sh-brand:hover img{transform:rotate(-4deg) scale(1.06)}
.sh-brand-name strong{display:block;font-family:'Playfair Display',serif;font-weight:600;color:#fff;font-size:26px;letter-spacing:.05em;line-height:1}
.sh-brand-name em{display:block;font-family:'Manrope',sans-serif;font-style:normal;font-size:10px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:rgba(201,229,176,.82);margin-top:5px}

/* Nav — modern button pills */
.sh-nav{margin-left:auto;display:flex;align-items:center;gap:2px}
.sh-link{
  position:relative;display:inline-flex;align-items:center;gap:6px;
  font-family:'Manrope',sans-serif;font-weight:600;font-size:15px;letter-spacing:.005em;
  color:rgba(255,255,255,.86);padding:10px 15px;border-radius:13px;
  background:transparent;border:1px solid transparent;cursor:pointer;
  transition:color .22s, background .22s, border-color .22s, transform .2s;white-space:nowrap;text-decoration:none;
}
.sh-link:hover{color:#fff;background:rgba(143,224,90,.10);border-color:rgba(143,224,90,.18)}
.sh-link:focus-visible{outline:2px solid var(--leaf);outline-offset:2px}
.sh-link.active{color:var(--leaf);background:rgba(143,224,90,.12);border-color:rgba(143,224,90,.22)}
.sh-chev{transition:transform .28s cubic-bezier(.2,.8,.2,1);opacity:.7}

/* Dropdown */
.sh-item{position:relative}
.sh-menu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px) scale(.98);
  width:340px;padding:14px;border-radius:18px;
  background:linear-gradient(180deg, rgba(12,30,18,.96), rgba(6,18,10,.97));
  backdrop-filter:blur(24px) saturate(1.3);-webkit-backdrop-filter:blur(24px) saturate(1.3);
  border:1px solid rgba(143,224,90,.16);
  box-shadow:0 30px 70px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.05) inset;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .26s ease, transform .3s cubic-bezier(.2,.8,.2,1), visibility .26s;
  z-index:5;
}
/* hover bridge so the menu doesn't close in the 14px gap */
.sh-menu::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.sh-item:hover .sh-menu,
.sh-item.open .sh-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0) scale(1)}
.sh-item:hover .sh-chev,
.sh-item.open .sh-chev{transform:rotate(180deg)}
.sh-item:hover > .sh-trigger,
.sh-item.open > .sh-trigger{color:#fff;background:rgba(143,224,90,.10);border-color:rgba(143,224,90,.18)}

.sh-menu-lead{
  display:block;padding:14px 16px;border-radius:13px;margin-bottom:8px;text-decoration:none;
  background:linear-gradient(135deg, rgba(199,84,31,.14), rgba(143,224,90,.10));
  border:1px solid rgba(143,224,90,.18);transition:transform .2s, border-color .2s;
}
.sh-menu-lead:hover{transform:translateY(-1px);border-color:rgba(143,224,90,.4)}
.sh-menu-lead .mi-t{display:block;font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:#fff;line-height:1.1}
.sh-menu-lead .mi-d{display:block;font-size:12px;color:rgba(201,229,176,.78);margin-top:3px}
.sh-menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.sh-menu-grid a{
  display:block;padding:11px 13px;border-radius:11px;text-decoration:none;
  border:1px solid transparent;transition:background .2s, border-color .2s, transform .2s;
}
.sh-menu-grid a:hover{background:rgba(143,224,90,.10);border-color:rgba(143,224,90,.18);transform:translateY(-1px)}
.sh-menu-grid .mi-t{display:block;font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:#fff;line-height:1.2}
.sh-menu-grid .mi-d{display:block;font-size:11px;color:rgba(255,255,255,.55);margin-top:2px;line-height:1.3}

/* Donate — solid ember capsule */
.sh-donate{
  display:inline-flex;align-items:center;gap:8px;margin-left:10px;
  background:linear-gradient(180deg,#d96838,var(--terracotta));color:#fff;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:15px;
  padding:12px 22px;border-radius:13px;text-decoration:none;
  box-shadow:0 6px 18px rgba(199,84,31,.34);
  transition:transform .25s, box-shadow .25s, filter .25s;
}
.sh-donate:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(199,84,31,.5);filter:brightness(1.06);color:#fff}
.sh-donate .arr{transition:transform .25s}
.sh-donate:hover .arr{transform:translateX(3px)}

/* Hamburger */
.sh-burger{display:none;flex-direction:column;gap:5px;width:46px;height:46px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);border-radius:14px;cursor:pointer;align-items:center;justify-content:center;margin-left:auto;transition:background .2s,border-color .2s}
.sh-burger:hover{background:rgba(143,224,90,.10);border-color:rgba(143,224,90,.3)}
.sh-burger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .3s cubic-bezier(.2,.8,.2,1), opacity .25s}
.site-header.nav-open .sh-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-header.nav-open .sh-burger span:nth-child(2){opacity:0}
.site-header.nav-open .sh-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hide per-page corner mark + nudge folio strip when header present */
body:has(.site-header) .brand-corner{display:none}
body:has(.site-header) .folio-strip{top:104px}

/* Front-page intro: header is visible over the Earth landing.
   Hide the redundant intro-top brand/donate so there's no duplication. */
body.has-intro .intro-top{display:none}
/* keep header hidden only while preloader covers everything (first 1.5s) */
body.has-intro:not(.intro-done) .site-header{transform:translateY(0)}

/* Smart-hide on scroll-down */
.site-header.hidden-down{transform:translateY(-135%)}

/* Below 1200px the full org name is dropped so the nav keeps room;
   the larger "CCAS" wordmark stays. */
@media (max-width:1200px){ .sh-brand-name em{display:none} }
@media (max-width:1140px){
  .sh-link{padding:9px 12px;font-size:14px}
  .sh-donate{padding:11px 18px;font-size:14px}
  .sh-brand-name strong{font-size:23px}
}
@media (max-width:980px){
  /* in the mobile drawer the full name has room again */
  .sh-brand-name em{display:block}
  .sh-brand-name strong{font-size:24px}
  .site-header{padding:12px 14px}
  /* IMPORTANT: backdrop-filter on the inner bar makes it the containing
     block for the position:fixed drawer, trapping it inside the bar.
     Drop the blur on mobile so the drawer fills the whole screen. */
  .site-header-inner{backdrop-filter:none;-webkit-backdrop-filter:none;background:linear-gradient(180deg, rgba(10,28,16,.94), rgba(6,18,10,.92))}
  .sh-burger{display:flex;position:relative;z-index:122} /* keep the X above the open drawer */
  .sh-brand{position:relative;z-index:122}
  .sh-nav{
    position:fixed;top:0;right:0;bottom:0;width:min(86vw,380px);
    margin:0;flex-direction:column;align-items:stretch;gap:6px;
    background:linear-gradient(180deg, rgba(8,22,13,.99), rgba(6,18,10,.99));
    backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    padding:92px 20px 40px;overflow-y:auto;z-index:121;
    transform:translateX(106%);transition:transform .42s cubic-bezier(.2,.8,.2,1);
    border-left:1px solid rgba(143,224,90,.14);box-shadow:-30px 0 60px rgba(0,0,0,.5);
  }
  .site-header.nav-open .sh-nav{transform:translateX(0)}
  .sh-link{font-size:15px;padding:14px 16px;border-radius:13px;justify-content:space-between}
  .sh-item{position:static}
  /* dropdowns become inline expandable sections on mobile */
  .sh-menu{
    position:static;width:auto;transform:none !important;opacity:1;visibility:visible;pointer-events:auto;
    background:transparent;border:none;box-shadow:none;padding:4px 0 8px 8px;
    max-height:0;overflow:hidden;transition:max-height .38s ease;
  }
  /* override the desktop open/hover transform that shoves the menu off-screen */
  .sh-item.open .sh-menu, .sh-item:hover .sh-menu{transform:none !important}
  .sh-item.open .sh-menu{max-height:640px}
  .sh-menu::before{display:none}
  .sh-menu-grid{grid-template-columns:1fr}
  .sh-menu-lead{background:rgba(143,224,90,.08)}
  .sh-donate{margin-left:0;margin-top:10px;justify-content:center;padding:16px}
  .site-header.nav-open .sh-nav > *{animation:shItemIn .45s cubic-bezier(.2,.8,.2,1) both}
  .site-header.nav-open .sh-nav > *:nth-child(1){animation-delay:.04s}
  .site-header.nav-open .sh-nav > *:nth-child(2){animation-delay:.09s}
  .site-header.nav-open .sh-nav > *:nth-child(3){animation-delay:.14s}
  .site-header.nav-open .sh-nav > *:nth-child(4){animation-delay:.19s}
  .site-header.nav-open .sh-nav > *:nth-child(5){animation-delay:.24s}
  .site-header.nav-open .sh-nav > *:nth-child(6){animation-delay:.29s}
  .site-header.nav-open .sh-nav > *:nth-child(7){animation-delay:.34s}
  @keyframes shItemIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
  .site-header.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);z-index:-1}
}
@media (prefers-reduced-motion: reduce){
  .site-header,.site-header-inner,.sh-menu,.sh-nav,.sh-burger span,.sh-chev{transition:none !important;animation:none !important}
}

/* ============================================================
   DONATE — give widget (international primary + more options)
   ============================================================ */
body[data-page="donate"] .give-panel{
  max-width:760px;margin:8px auto 0;padding:30px 30px 28px;border-radius:20px;
  background:linear-gradient(180deg, rgba(255,152,70,.07), rgba(255,255,255,.03));
  border:1px solid rgba(255,152,70,.26);
  box-shadow:0 24px 60px rgba(0,0,0,.32);
}
body[data-page="donate"] .give-head{margin-bottom:20px}
body[data-page="donate"] .give-kicker{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint)}
body[data-page="donate"] .give-head h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(28px,3.4vw,40px);color:#fff;line-height:1.05;margin:8px 0 8px;letter-spacing:-.5px}
body[data-page="donate"] .give-head h2 em{font-style:italic;color:var(--ember)}
body[data-page="donate"] .give-head p{font-size:15px;color:rgba(255,255,255,.82);line-height:1.6;max-width:560px}

body[data-page="donate"] .give-amounts{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
body[data-page="donate"] .give-amt{
  font-family:'Playfair Display',serif;font-size:22px;font-style:italic;color:#fff;
  padding:12px 22px;border-radius:13px;cursor:pointer;
  background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.14);
  transition:border-color .2s, background .2s, transform .2s, color .2s;
}
body[data-page="donate"] .give-amt:hover{border-color:rgba(255,152,70,.5);transform:translateY(-1px)}
body[data-page="donate"] .give-amt.is-active{background:rgba(255,152,70,.16);border-color:var(--ember);color:#fff}
body[data-page="donate"] .give-custom{display:inline-flex;align-items:center;gap:4px;padding:0 16px}
body[data-page="donate"] .give-custom span{font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:rgba(255,255,255,.6)}
body[data-page="donate"] .give-custom input{width:88px;background:transparent;border:none;color:#fff;font-family:'Playfair Display',serif;font-style:italic;font-size:20px;padding:12px 0;outline:none}
body[data-page="donate"] .give-custom input::placeholder{color:rgba(255,255,255,.4)}
body[data-page="donate"] .give-custom:focus-within{border-color:var(--ember)}

body[data-page="donate"] .give-primary{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}
body[data-page="donate"] .give-btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;border-radius:14px;font-weight:600;transition:transform .2s, box-shadow .2s, filter .2s}
body[data-page="donate"] .give-card{
  flex:1 1 auto;justify-content:center;min-width:240px;
  background:linear-gradient(180deg,#d96838,var(--terracotta));color:#fff;
  font-family:'Inter',sans-serif;font-size:16px;padding:17px 24px;
  box-shadow:0 10px 28px rgba(199,84,31,.4);
}
body[data-page="donate"] .give-card:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(199,84,31,.55);filter:brightness(1.05)}
body[data-page="donate"] .give-card .arr{transition:transform .2s}
body[data-page="donate"] .give-card:hover .arr{transform:translateX(3px)}
body[data-page="donate"] .give-paypal{
  background:#fff;color:#003087;padding:17px 26px;font-size:18px;border:1.5px solid rgba(255,255,255,.5);
}
body[data-page="donate"] .give-paypal strong{font-weight:800;color:#003087}
body[data-page="donate"] .give-paypal em{font-weight:800;font-style:normal;color:#0070ba}
body[data-page="donate"] .give-paypal:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.3)}
body[data-page="donate"] .give-secure{display:flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;color:rgba(201,229,176,.72);margin:0 0 4px}

body[data-page="donate"] .give-more-toggle{
  display:inline-flex;align-items:center;gap:8px;margin-top:14px;
  background:transparent;border:none;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--mint);padding:8px 0;transition:color .2s;
}
body[data-page="donate"] .give-more-toggle:hover{color:#fff}
body[data-page="donate"] .gm-chev{transition:transform .3s cubic-bezier(.2,.8,.2,1)}
body[data-page="donate"] .give-more-toggle[aria-expanded="true"] .gm-chev{transform:rotate(180deg)}

body[data-page="donate"] .give-more{margin-top:14px;padding-top:20px;border-top:1px solid rgba(255,255,255,.10);animation:giveMoreIn .4s cubic-bezier(.2,.8,.2,1)}
@keyframes giveMoreIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
body[data-page="donate"] .give-more-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
body[data-page="donate"] .give-method{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:18px}
body[data-page="donate"] .gm-head{font-family:'Manrope',sans-serif;font-weight:700;font-size:15px;color:#fff;margin-bottom:4px;display:flex;align-items:baseline;gap:8px}
body[data-page="donate"] .gm-head span{font-family:'JetBrains Mono',monospace;font-weight:400;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(201,229,176,.6)}
body[data-page="donate"] .gm-note{font-size:12px;color:rgba(255,255,255,.6);margin:0 0 12px;line-height:1.5}
body[data-page="donate"] .gm-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-top:1px solid rgba(255,255,255,.06)}
body[data-page="donate"] .gm-row:first-of-type{border-top:none}
body[data-page="donate"] .gm-net{flex:0 0 auto;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ember);min-width:62px}
body[data-page="donate"] .gm-row code{flex:1;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:#fff;background:transparent;padding:0;word-break:break-all}
body[data-page="donate"] .gm-copy{flex:0 0 auto;font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mint);background:rgba(143,224,90,.08);border:1px solid rgba(143,224,90,.22);border-radius:7px;padding:5px 9px;cursor:pointer;transition:all .2s}
body[data-page="donate"] .gm-copy:hover{background:rgba(143,224,90,.18);color:#fff}
body[data-page="donate"] .gm-bank > div{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-top:1px solid rgba(255,255,255,.06)}
body[data-page="donate"] .gm-bank > div:first-child{border-top:none}
body[data-page="donate"] .gm-k{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(201,229,176,.6)}
body[data-page="donate"] .gm-v{font-size:13px;color:#fff;text-align:right}
body[data-page="donate"] .gm-foot{font-size:13px;color:rgba(255,255,255,.7);margin-top:16px;line-height:1.6}
body[data-page="donate"] .gm-foot a{color:var(--leaf);border-bottom:1px solid rgba(143,224,90,.4)}
@media (max-width:620px){
  body[data-page="donate"] .give-more-grid{grid-template-columns:1fr}
  body[data-page="donate"] .give-card{min-width:0;width:100%}
}

/* Per-page hero sections need the same stacking lift as .scene so they
   paint above the fixed ambient backdrop (.film::before). */
.film > .donate-hero,
.film > .contact-hero,
.film > .news-hero,
.film > .events-hero,
.film > .members-hero,
.film > .prog-hero,
.film > .lib-hero{position:relative;z-index:3}

/* library book download label */
body[data-page="resources"] .book .book-dl{ margin-top:10px;font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--leaf);opacity:.85 }
body[data-page="resources"] .book:hover .book-dl{ color:#fff;opacity:1 }

/* Returning visitor: skip the Earth intro with no flash */
html.skip-intro .intro, html.skip-intro .preloader{display:none !important}
html.skip-intro .film{opacity:1 !important}

/* ============================================================
   EXPLORE BAND — in-scroll navigation woven into the film
   ============================================================ */
.film > .explore-band{position:relative;z-index:3}
.explore-band{padding:120px var(--pad);background:transparent}
.explore-inner{max-width:var(--maxw);margin:0 auto}
.explore-head{margin-bottom:40px;max-width:760px}
.explore-kicker{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mint)}
.explore-head h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(34px,4.4vw,62px);line-height:1.05;letter-spacing:-1px;color:#fff;margin:12px 0 10px}
.explore-head h2 em{font-style:italic;color:var(--leaf)}
.explore-head p{font-size:16px;color:rgba(255,255,255,.78);line-height:1.6}
.explore-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.ex-chip{
  display:flex;flex-direction:column;gap:4px;padding:22px 20px;border-radius:16px;text-decoration:none;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.10);position:relative;overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, background .3s, box-shadow .3s;
}
.ex-chip::after{content:"→";position:absolute;top:18px;right:18px;font-family:'JetBrains Mono',monospace;font-size:15px;color:rgba(143,224,90,.4);transition:color .3s, transform .3s}
.ex-chip:hover{transform:translateY(-4px);border-color:rgba(143,224,90,.45);background:linear-gradient(180deg, rgba(143,224,90,.10), rgba(143,224,90,.03));box-shadow:0 18px 44px rgba(0,0,0,.32)}
.ex-chip:hover::after{color:var(--leaf);transform:translateX(3px)}
.ex-ic{font-size:22px;color:var(--leaf);line-height:1;margin-bottom:8px}
.ex-t{font-family:'Manrope',sans-serif;font-weight:700;font-size:17px;color:#fff;letter-spacing:.01em}
.ex-d{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.08em;color:rgba(201,229,176,.62);text-transform:uppercase}
.ex-chip.ex-accent{background:linear-gradient(180deg, rgba(199,84,31,.16), rgba(199,84,31,.05));border-color:rgba(255,152,70,.34)}
.ex-chip.ex-accent .ex-ic{color:var(--ember)}
.ex-chip.ex-accent::after{color:rgba(255,152,70,.6)}
.ex-chip.ex-accent:hover{border-color:var(--ember);background:linear-gradient(180deg, rgba(199,84,31,.24), rgba(199,84,31,.08))}
@media (max-width:1080px){ .explore-grid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:640px){ .explore-grid{grid-template-columns:repeat(2,1fr)} .explore-band{padding:80px var(--pad)} }
