/* ============================================================
   DORILL — stylesheet.
   Brand colors and fonts live in the variables right below.
   Change a color here and the whole site updates.
   ============================================================ */
:root{
  --accent:#ff7373;          /* signature red */
  --donate:#7966ad;          /* purple from the site's own palette */
  --pcard-1:#3BB8A7;         /* partner box 1 — teal   (exact, from export) */
  --pcard-2:#7966ad;         /* partner box 2 — purple (exact, from export) */
  --pcard-3:#f7931e;         /* partner box 3 — orange (exact, from export) */
  --eyebrow-accent:#FF7373;  /* small salmon sub-headings (exact, from export) */
  --accent-ink:#ffffff;      /* text on red      */
  --ink:#0b1408;             /* near-black       */
  --green:#65bb28;           /* secondary green  */
  --paper:#ffffff;
  --paper-soft:#f7f7f5;
  --line:rgba(11,20,8,.12);
  --radius:12px;
  --max:1180px;
  --font:'Raleway', -apple-system, 'Segoe UI', sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);font-size:17px;line-height:1.65;
  color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
/* Notched iPhones (viewport-fit=cover): keep content clear of the Dynamic
   Island / home bar in landscape. env() is 0 on devices without insets. */
@supports (padding: env(safe-area-inset-left)){
  .wrap{padding-left:calc(24px + env(safe-area-inset-left));padding-right:calc(24px + env(safe-area-inset-right))}
  .cc-wrap{left:calc(20px + env(safe-area-inset-left));bottom:calc(20px + env(safe-area-inset-bottom))}
  .hero-video-controls{right:calc(18px + env(safe-area-inset-right))}
}

h1,h2,h3{font-weight:800;line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
h3{font-size:1.2rem}
p{margin:0 0 1em}

.eyebrow{
  font-size:.78rem;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;opacity:.75;margin-bottom:.6rem;
}
.eyebrow.light{color:var(--accent);opacity:1}
#events-eyebrow{color:var(--eyebrow-accent);opacity:1}

.section{padding:88px 0}
.section-soft{background:var(--paper-soft)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:44px}
.narrow{max-width:780px}

/* Buttons */
.btn{
  display:inline-block;padding:.8rem 1.7rem;border-radius:999px;
  font-weight:800;font-size:.95rem;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,opacity .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-accent{background:var(--accent);color:var(--accent-ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-ghost{border-color:currentColor}
.btn-light{background:#fff;color:var(--ink)}
.btn-donate{background:var(--donate);color:#fff}
.btn-lg{font-size:1.05rem;padding:1rem 2.1rem}

/* ---------------- Top bar + header ---------------- */
#site-topbar{background:var(--ink);color:#fff;font-size:.85rem}
#site-topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:16px}
#site-topbar a{color:#fff;opacity:.9}
#site-topbar a:hover{color:var(--accent);opacity:1}
#site-topbar .ticker{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
#site-topbar .ticker strong{color:var(--accent);margin-right:.4em}

#site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
#site-header .wrap{display:flex;align-items:center;gap:28px;min-height:88px}
/* Anchor-link targets clear the sticky header */
section[id]{scroll-margin-top:100px}
#site-header .brand img{max-height:56px;width:auto}
/* Animated SVG logo in the header (desktop) */
#site-header .brand-logo{display:inline-flex;align-items:center}
#site-header .brand-logo--animated svg{height:52px;width:auto;display:block}
/* Pause the roll animation while hovering the logo (desktop) */
@media (min-width:821px){
  #site-header .brand:hover .brand-logo--animated .icons,
  #site-header .brand:hover .brand-logo--animated .i1,
  #site-header .brand:hover .brand-logo--animated .i2,
  #site-header .brand:hover .brand-logo--animated .i3,
  #site-header .brand:hover .brand-logo--animated .txt{
    animation-play-state:paused;
  }
}
.main-nav{margin-left:auto}
.main-nav ul{list-style:none;display:flex;gap:24px;margin:0;padding:0}
.main-nav a{
  font-weight:800;font-size:.85rem;letter-spacing:.07em;text-transform:uppercase;
  padding:.4rem 0;border-bottom:2px solid transparent;
}
.main-nav a:hover,.main-nav .current a{border-bottom-color:var(--accent)}
.nav-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:42px;height:42px;padding:0;position:relative;
}
.nav-toggle .hamburger,
.nav-toggle .hamburger::before,
.nav-toggle .hamburger::after{
  content:"";position:absolute;left:9px;width:24px;height:3px;border-radius:2px;
  background:var(--ink);transition:transform .25s ease,opacity .2s ease;
}
.nav-toggle .hamburger{top:50%;transform:translateY(-50%)}
.nav-toggle .hamburger::before{top:-8px}
.nav-toggle .hamburger::after{top:8px}
.nav-toggle[aria-expanded="true"] .hamburger{background:transparent}
.nav-toggle[aria-expanded="true"] .hamburger::before{transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .hamburger::after{transform:translateY(-8px) rotate(-45deg)}
.header-donate--mobile{display:none}
@media (max-width:1024px){
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:1rem 24px 1.4rem}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:2px}
  .main-nav a{display:block;padding:.6rem 0}
  .nav-toggle{display:block;margin-left:auto;order:2}
  .header-donate:not(.header-donate--mobile){display:none}
  .header-donate--mobile{
    display:inline-block;order:3;margin-left:10px;
    background:var(--donate);color:#fff;border:none;
    padding:.55rem 1.1rem;font-size:.9rem;
    animation:donate-pulse 2.2s ease-in-out infinite;
  }
}
@keyframes donate-pulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(121,102,173,.5)}
  50%{transform:scale(1.05);box-shadow:0 0 0 8px rgba(121,102,173,0)}
}

/* ---------------- Hero ---------------- */
#hero{
  position:relative;color:var(--ink);background:#fff right bottom/contain no-repeat;
  min-height:min(82vh,720px);display:flex;align-items:center;
}
.hero-inner{position:relative;max-width:560px;padding-top:90px;padding-bottom:90px;margin-right:auto}
.hero-inner .btn{margin-left:44px}
@media (max-width:1024px){
  #hero{
    position:relative;
    min-height:44vh;
    background-image:url('images/uploads/2026/05/hero-girl-mobile.png');
    background-size:cover;
    background-position:right center;
    background-repeat:no-repeat;
    padding-top:24px;
    padding-bottom:20px;
    align-items:center;
    display:flex;
    overflow:hidden;
  }
  /* "extracurricular" + "infrastructure" black with white halo for readability over the photo */
  .hero-green-m{
    color:var(--ink);
    text-shadow:0 1px 2px rgba(255,255,255,.9),0 0 6px rgba(255,255,255,.8);
  }
  .hero-inner{position:relative;z-index:1;padding-top:0;padding-bottom:0}
  .hero-inner .btn{margin-left:0}
  /* smaller hero buttons on mobile */
  .hero-btns .btn{padding:.62rem 1.15rem;font-size:.92rem}
  /* push buttons below girl's face on mobile (~58% down the hero) */
  .hero-btns{margin-top:auto;padding-top:clamp(120px,28vw,180px)}
  /* pull the Builders section right up against the hero */
  #hero + section,
  #hero + div{margin-top:0;padding-top:0}
}

/* Mobile-only highlighter (THIS IS + EXTRA) — plain text on desktop */
@media (max-width:1024px){
  .hl-m{
    background-image:linear-gradient(104deg,transparent 1%,var(--accent) 3%,var(--accent) 97%,transparent 99%);
    padding:.04em .14em;margin:0 .02em;
    -webkit-box-decoration-break:clone;box-decoration-break:clone;
  }
}

/* Highlighter effect on the word NOT */
.hl{
  background-image:linear-gradient(104deg,transparent 1%,var(--accent) 3%,var(--accent) 97%,transparent 99%);
  padding:.04em .14em;margin:0 .02em;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
}
.hero-head{text-transform:uppercase;font-weight:900;letter-spacing:-.01em;line-height:.98;margin:0 0 1rem}
.hero-not{
  font-weight:900;color:var(--donate);position:relative;display:inline-block;
  padding:0 .04em;
}
.hero-not::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;height:.13em;
  background:#3bb8a7;border-radius:2px;
}
@media (min-width:1025px){
  .hero-head{font-size:clamp(3.6rem,6.4vw,6.2rem)}
  .hero-inner{max-width:560px;padding-top:40px;margin-right:auto}
  #hero{background-position:right center}
}
.hero-btns{display:flex;gap:14px;flex-wrap:nowrap;margin-left:44px}
.hero-btns .btn{white-space:nowrap}
#hero h1{white-space:nowrap}
@media (max-width:1024px){
  .hero-head{font-size:clamp(1.9rem,8vw,2.8rem);line-height:1.05;overflow-wrap:break-word}
  .hero-btns{margin-left:0;flex-wrap:wrap}
  #hero h1{white-space:normal}
}
.hero-sub{font-size:clamp(1.05rem,1.9vw,1.5rem);font-weight:900;max-width:none;white-space:nowrap;margin:1rem 0 2rem;opacity:.95;line-height:1.2;text-transform:uppercase;letter-spacing:.01em}
@media (max-width:820px){
  .hero-overlay{background:rgba(255,255,255,.88)}
}

/* ---------------- Page hero (inner pages) ---------------- */
.page-hero{
  background:var(--ink) center/cover no-repeat;color:#fff;
  padding:96px 0;text-align:center;
}
.page-hero.has-image{
  min-height:520px;display:flex;align-items:center;justify-content:center;
  background-position:center 32%;
}
.page-hero h1{
  font-weight:800;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(2.1rem,4.5vw,3.4rem);
  text-shadow:0 2px 18px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.6);
}
.page-hero .eyebrow{justify-content:center;text-shadow:0 1px 8px rgba(0,0,0,.6)}
@media (max-width:820px){.page-hero.has-image{min-height:380px}}

/* Light hero (Get Involved): photo on white, dark text, action buttons */
.page-hero--light{
  background:#fff center bottom/contain no-repeat;color:var(--ink);
  min-height:100vh;display:flex;align-items:flex-start;justify-content:center;
  text-align:center;padding:72px 24px 0;
}
.page-hero--light h1{
  color:var(--ink);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.1rem,4.5vw,3.4rem);text-shadow:none;
}
.page-hero--light .hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:1.4rem}
@media (max-width:820px){.page-hero--light{min-height:78vh}}
.page-hero h1{color:#fff;margin:0}

/* ---------------- Partner cards ----------------
   Desktop: original full-bleed edge-to-edge band (square, no gaps).
   Mobile: softened rounded cards with spacing. */
.partner-full{width:100%}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.p-card{
  color:#fff;padding:64px 50px 50px;
  display:flex;flex-direction:column;gap:16px;min-height:380px;
}
.p-card:nth-child(1){background:var(--pcard-1)}
.p-card:nth-child(2){background:var(--pcard-2)}
.p-card:nth-child(3){background:var(--pcard-3)}
.p-card h3{color:#fff;font-size:2rem;margin:0;line-height:1.1}
.p-head{display:flex;align-items:center;gap:16px}
.p-card p{flex:1;margin:0;opacity:.92}
.p-icon{font-size:2.6rem;line-height:1;flex:0 0 auto}
.p-card .btn{align-self:flex-start;border-color:#fff;color:#fff;background:transparent}
.p-card .btn:hover{background:#fff;color:var(--ink)}
@media (max-width:1024px){
  .partner-full{padding:36px 16px}
  .cards-3{grid-template-columns:1fr;gap:16px}
  .p-card{
    min-height:0;padding:32px 28px;gap:12px;border-radius:18px;
    box-shadow:0 14px 38px rgba(95,79,138,.18);
  }
}

/* ---------------- Program tiles ---------------- */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tile{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--ink);display:block;aspect-ratio:3/4}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85;transition:transform .4s ease}
.tile:hover img{transform:scale(1.05)}
.tile-tag{position:absolute;top:14px;left:14px;background:var(--accent);color:var(--accent-ink);font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .7rem;border-radius:999px}
.tile-body{position:absolute;inset:auto 0 0 0;padding:20px;color:#fff;background:linear-gradient(to top,rgba(8,10,6,.92),rgba(8,10,6,0))}
.tile-body h3{color:#fff;margin:0 0 .3rem}
.tile-body p{font-size:.85rem;margin:0 0 .6rem;opacity:.9;line-height:1.45}
.tile-view{font-size:.75rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}

/* ---------------- Cards (events, news) ---------------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.card-body{padding:20px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-body h3{margin:.2rem 0 0;font-size:1.02rem;line-height:1.4}
.card-body p{font-size:.9rem;margin:.3rem 0 0;opacity:.75}
.card-meta{font-size:.83rem;opacity:.65}
.badge{display:inline-flex;align-self:flex-start;background:var(--accent);color:var(--accent-ink);font-weight:800;font-size:.75rem;letter-spacing:.05em;padding:.28rem .7rem;border-radius:999px;margin-top:-36px;position:relative}

/* ---------------- Method ---------------- */
.method{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.method-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.method-gallery img{border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover;width:100%}
.method-gallery img:nth-child(2){transform:translateY(20px)}
.stats{display:flex;gap:48px;margin-top:2rem}
.stat-num{font-size:2.6rem;font-weight:800;line-height:1}
.stat-label{font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.65}

/* ---------------- Campaigns ---------------- */
.camp-list{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.camp{display:flex;align-items:center;justify-content:space-between;gap:20px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px}
.camp h3{margin:0;font-size:1.02rem;line-height:1.4}

/* ---------------- CTA ---------------- */
#cta{background:var(--ink);color:#fff;text-align:center;padding:96px 24px}
#cta h2{color:#fff;text-transform:uppercase;max-width:20ch;margin:0 auto 2rem}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------------- Detail page ---------------- */
.detail-img{border-radius:var(--radius);margin-bottom:2rem;width:100%;max-height:460px;object-fit:cover}
.back{margin-top:3rem}

/* ---------------- Footer ---------------- */
#site-footer{background:var(--ink);color:rgba(255,255,255,.8);padding:72px 0 30px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:44px}
#site-footer h4{color:#fff;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 1rem}
#site-footer ul{list-style:none;margin:0;padding:0}
#site-footer li{margin-bottom:.5rem}
#site-footer a:hover{color:var(--accent)}
.footer-logo{max-height:54px;width:auto;margin-bottom:1.1rem;display:block;margin-left:0}
.socials{display:flex;gap:12px;margin-top:1rem}
.socials a{width:40px;height:40px;border:1px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center}
.socials svg{width:19px;height:19px}
.socials a:hover{border-color:var(--accent);color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:22px;font-size:.82rem;opacity:.7}

/* ---------------- Misc / responsive ---------------- */
.empty{opacity:.7}
.timeline{border-left:3px solid var(--accent);padding-left:28px;display:grid;gap:26px;margin:2rem 0}
.timeline h3{margin:0}
.timeline .year{font-weight:800;color:var(--accent)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.team-card img{aspect-ratio:9/10;object-fit:cover;width:100%}
.team-card .card-body h3{font-size:1.05rem}

@media (max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3,.team-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .section{padding:62px 0}
  .cards-3{grid-template-columns:1fr}
  .method{grid-template-columns:1fr;gap:40px}
  .camp-list{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .grid-4,.grid-3,.team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .stats{gap:28px}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important}
  html{scroll-behavior:auto}
}


/* ---------------- Interactive circle (Dorill Method) ---------------- */
.circle-widget{position:relative;width:min(440px,90vw);aspect-ratio:1;margin:0 auto}
.circle-ring{position:absolute;inset:8%;border:2px dashed rgba(50,25,104,.34);border-radius:50%}
.circle-center{
  position:absolute;inset:22%;border-radius:50%;overflow:hidden;
  display:flex;align-items:flex-end;justify-content:center;background:var(--ink);
  box-shadow:0 10px 30px rgba(11,20,8,.25);
}
.circle-center img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85;transition:opacity .25s ease}
.circle-title{
  position:relative;color:#fff;font-weight:900;font-size:.85rem;text-align:center;
  text-transform:uppercase;letter-spacing:.06em;padding:0 18px 20px;
  text-shadow:0 2px 8px rgba(0,0,0,.6);
}
.circle-node{
  position:absolute;transform:translate(-50%,-50%);
  background:#000;border:2px solid #000;border-radius:999px;color:#fff;
  font-family:var(--font);font-weight:800;font-size:.74rem;letter-spacing:.03em;
  padding:.45rem .9rem;cursor:pointer;white-space:nowrap;z-index:2;
  transition:background .15s ease,transform .15s ease,border-color .15s ease;
}
.circle-node:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translate(-50%,-50%) scale(1.06)}
.circle-node.active{background:var(--accent);border-color:var(--accent);color:#fff;transform:translate(-50%,-50%) scale(1.06)}
.circle-node.pos-0{left:50%;top:6%}
.circle-node.pos-1{left:96%;top:50%}
.circle-node.pos-2{left:50%;top:94%}
.circle-node.pos-3{left:4%;top:50%}
.circle-node.pos-4{left:85%;top:18%}
.circle-node.pos-5{left:85%;top:82%}
.circle-node.pos-6{left:15%;top:82%}
.circle-node.pos-7{left:15%;top:18%}
@media (max-width:560px){.circle-node{font-size:.66rem;padding:.35rem .7rem}}

/* ---------------- Horizontal timeline (Our Story) ---------------- */
.timeline-h{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin-top:3.2rem}
.timeline-h > div{position:relative;padding-top:38px}
.timeline-h .year{font-weight:800;color:var(--accent);display:block;margin-bottom:.3rem}
.timeline-h h3{margin:0 0 .4rem;font-size:1.02rem}
.timeline-h p{font-size:.9rem;opacity:.8;margin:0}

/* ---------------- NYC borough map ---------------- */
.nyc-section{background:var(--ink);color:#fff;padding:96px 0;position:relative;overflow:hidden}
.nyc-bg{position:absolute;inset:-4% -2%;z-index:0;opacity:.22;filter:grayscale(1);pointer-events:none}
.nyc-bg svg{width:100%;height:100%}
.nyc-section .wrap{position:relative;z-index:1}
.nyc-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}
.nyc-section h2{color:#fff;text-transform:uppercase}
.nyc-map svg{width:100%;height:auto;display:block}
.nyc-map .borough{
  fill:rgba(255,255,255,.14);stroke:rgba(255,255,255,.55);stroke-width:1.5;
  cursor:pointer;transition:fill .2s ease;
}
.nyc-map .borough:hover{fill:rgba(255,225,0,.45)}
.nyc-map .borough.selected{fill:var(--accent);stroke:var(--accent)}
.nyc-caption{
  margin-top:1.2rem;font-weight:800;font-size:1.05rem;min-height:1.6em;
  color:var(--accent);text-align:center;letter-spacing:.03em;
}
@media (max-width:820px){.nyc-grid{grid-template-columns:1fr;gap:40px}}


/* ---------------- "Top" button ---------------- */
#to-top{
  position:fixed;right:22px;bottom:22px;z-index:90;
  background:var(--accent);color:var(--accent-ink);
  border:none;border-radius:999px;padding:.7rem 1.1rem;
  font-family:var(--font);font-weight:800;font-size:.85rem;cursor:pointer;
  box-shadow:0 6px 20px rgba(11,20,8,.25);
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .25s ease,transform .25s ease;
}
#to-top.show{opacity:1;transform:none;pointer-events:auto}
#to-top:hover{transform:translateY(-2px)}

/* ---------------- Find Your Match (Get Involved) ---------------- */
.match-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.match-form label{display:block;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin:1.3rem 0 .4rem}
.match-form select{
  width:100%;padding:.8rem 1rem;border:2px solid var(--line);border-radius:10px;
  font-family:var(--font);font-size:1rem;background:#fff;
}
.match-form button{margin-top:1.6rem}
.match-result{
  background:var(--paper-soft);border-radius:var(--radius);padding:38px 34px;
  border-top:6px solid var(--accent);
}
.match-result .eyebrow{color:var(--eyebrow-accent);opacity:1}
.match-result h2{margin:.2rem 0 .8rem;text-transform:uppercase}
@media (max-width:820px){.match-grid{grid-template-columns:1fr}}

/* ---------------- Our Community slider ---------------- */
.community-slider{position:relative;overflow:hidden;border-radius:var(--radius)}
.community-track{display:flex;transition:transform .45s ease}
.community-track img{width:33.333%;flex:0 0 33.333%;aspect-ratio:4/3;object-fit:cover;padding:0 8px;border-radius:18px}
.community-nav{display:flex;gap:10px;justify-content:center;margin-top:18px}
.community-nav button{
  background:#fff;border:2px solid var(--ink);border-radius:999px;width:44px;height:44px;
  font-size:1.1rem;font-weight:800;cursor:pointer;font-family:var(--font);
}
.community-nav button:hover{background:var(--accent);border-color:var(--accent)}
@media (max-width:820px){.community-track img{width:100%;flex:0 0 100%}}

/* ---------------- Support: raised bar ---------------- */
.raised-box{background:var(--paper-soft);border-radius:var(--radius);padding:42px 38px}
.raised-amount{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:900;line-height:1}
.raised-amount small{font-size:.45em;font-weight:800;opacity:.6}
.raised-bar{height:18px;border-radius:999px;background:rgba(11,20,8,.1);margin:1.4rem 0 .6rem;overflow:hidden}
.raised-fill{height:100%;width:0;background:var(--accent);border-radius:999px;transition:width 1.2s ease}
.raised-meta{display:flex;justify-content:space-between;font-weight:700;font-size:.9rem;opacity:.75}

/* ---------------- Support: invest options ---------------- */
.invest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.invest-card{
  border:2px solid var(--line);border-radius:var(--radius);padding:36px 30px;
  display:flex;flex-direction:column;gap:14px;background:#fff;
}
.invest-card:nth-child(1){border-top:6px solid var(--pcard-1)}
.invest-card:nth-child(2){border-top:6px solid var(--pcard-2)}
.invest-card:nth-child(3){border-top:6px solid var(--pcard-3)}
.invest-card p{flex:1;margin:0;opacity:.8}
.invest-card .btn{align-self:flex-start}
@media (max-width:820px){.invest-grid{grid-template-columns:1fr}}

/* ---------------- Support: allocation donut ---------------- */
.donut-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.donut-wrap{position:relative;max-width:380px;margin:0 auto;width:100%}
.donut-wrap svg{width:100%;height:auto;display:block}
.donut-seg{cursor:pointer;transition:opacity .2s ease,stroke-width .2s ease}
.donut-seg:hover,.donut-seg.active{stroke-width:34}
.donut-center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;pointer-events:none;padding:0 56px;
}
.donut-center .pct{font-size:2.4rem;font-weight:900;line-height:1}
.donut-center .lbl{font-weight:700;font-size:.9rem;opacity:.75;margin-top:.3rem}
.donut-legend{list-style:none;margin:0;padding:0}
.donut-legend li{display:flex;align-items:center;gap:12px;padding:.55rem 0;font-weight:700;cursor:pointer}
.donut-legend .dot{width:16px;height:16px;border-radius:4px;flex:0 0 16px}
.donut-legend .pcttxt{margin-left:auto;font-weight:900}
@media (max-width:820px){.donut-grid{grid-template-columns:1fr}}


/* ------- About: "Born from the Lower East Side" + skyline ------- */
.les-section{background:var(--ink);color:#fff;padding:110px 0 130px;position:relative;overflow:hidden}
.les-hasbg{background-size:cover;background-position:center;padding-top:150px;padding-bottom:160px}
.les-hasbg .les-splash{opacity:.16}
/* text legibility without darkening the whole image: soft shadow on text only */
.les-hasbg h2,.les-hasbg p{text-shadow:0 2px 18px rgba(0,0,0,.55)}
.les-splash{position:absolute;top:-60px;right:-120px;width:min(760px,85%);z-index:0;opacity:.5;pointer-events:none;transform:rotate(-6deg)}
.les-splash svg{width:100%;height:auto;display:block}
.les-skyline{position:absolute;left:0;right:0;bottom:-4px;z-index:0;opacity:.35;pointer-events:none}
.les-skyline svg{width:100%;height:auto;display:block}
.les-section .wrap{position:relative;z-index:1}
.les-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.les-section h2{color:#fff;text-transform:uppercase;font-size:clamp(1.9rem,3.8vw,2.9rem)}
.les-section p{opacity:.92}
.stat-figure{position:relative}
.stat-figure > img{width:100%;border-radius:var(--radius);display:block}
.stat-chips{position:absolute;right:-18px;bottom:-26px;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.stat-chip{
  background:var(--accent);color:var(--accent-ink);border-radius:12px;
  padding:16px 20px;box-shadow:0 10px 26px rgba(0,0,0,.35);
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
}
.stat-chip:nth-child(2){background:var(--donate)} .stat-chip:nth-child(2) .num,.stat-chip:nth-child(2) .lab{color:#fff}
.stat-chip:nth-child(3){background:var(--pcard-1);color:#fff}
.stat-chip .num{font-weight:900;font-size:2.6rem;line-height:1;letter-spacing:-.02em}
.stat-chip .lab{font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}
@media (max-width:820px){
  .les-grid{grid-template-columns:1fr;gap:64px}
  .stat-chips{position:static;flex-direction:row;flex-wrap:wrap;margin-top:14px}
}

/* ------- Our Work: Saturday Arts feature + journey CTA ------- */
.feature-split{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.feature-imgs{display:grid;gap:18px}
.feature-imgs img{width:100%;border-radius:var(--radius);aspect-ratio:16/10;object-fit:cover}
@media (max-width:820px){.feature-split{grid-template-columns:1fr;gap:36px}}

.journey{
  position:relative;background:var(--ink) center/cover no-repeat;color:#fff;
  text-align:center;padding:130px 24px;
}
.journey::before{content:"";position:absolute;inset:0;background:rgba(8,10,6,.6)}
.journey > *{position:relative}
.journey h2{color:#fff;text-transform:uppercase;max-width:18ch;margin:0 auto 2rem}
.journey-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}


/* ------- Get Involved: looping muted video hero ------- */
.page-hero--video{position:relative;overflow:hidden}
.hero-video-wrap{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-video-wrap iframe{
  /* Oversized + centered = "object-fit: cover" for an iframe (16:9) */
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:max(100vw,177.78vh);height:max(100vh,56.25vw);border:0;
}
.page-hero--video .wrap{position:relative;z-index:2}
@media (prefers-reduced-motion:reduce){
  .hero-video-wrap{display:none}  /* photo fallback shows instead */
}


/* ------- Animated donate button (homepage hero) ------- */
.btn-donate-anim{
  position:relative;overflow:hidden;
  transition:background .3s ease,color .3s ease,transform .2s ease,box-shadow .3s ease;
}
.btn-donate-anim::after{
  content:"";position:absolute;top:0;bottom:0;left:-75%;width:50%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);
}
.btn-donate-anim:hover{
  background:var(--donate);color:#fff;
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 12px 26px rgba(121,102,173,.45);
}
.btn-donate-anim:hover::after{animation:btn-shine .7s ease}
@keyframes btn-shine{to{left:125%}}

/* ------- Footer newsletter ------- */
.newsletter{margin-top:1.6rem}
.newsletter form{display:flex;gap:8px}
.newsletter input{
  flex:1;min-width:0;padding:.65rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.08);color:#fff;font-family:var(--font);font-size:.9rem;
}
.newsletter input::placeholder{color:rgba(255,255,255,.55)}
.newsletter .btn{padding:.65rem 1.2rem;font-size:.85rem}
.newsletter-thanks{margin:.6rem 0 0;font-weight:700;color:var(--accent);min-height:1.2em}

/* ------- Events calendar ------- */
.cal{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:56px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.cal-head h3{margin:0;font-size:1.3rem;text-transform:uppercase}
.cal-nav{display:flex;gap:8px}
.cal-nav button{
  background:#fff;border:2px solid var(--ink);border-radius:999px;width:40px;height:40px;
  font-size:1rem;font-weight:800;cursor:pointer;font-family:var(--font);
}
.cal-nav button:hover{background:var(--accent);border-color:var(--accent)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;opacity:.6;text-align:center;padding:.3rem 0}
.cal-day{
  min-height:86px;border:1px solid var(--line);border-radius:10px;padding:6px;
  font-size:.78rem;display:flex;flex-direction:column;gap:4px;background:#fff;
}
.cal-day .d{font-weight:800;opacity:.7}
.cal-day.other{background:var(--paper-soft);opacity:.55}
.cal-day.today{border-color:var(--accent);box-shadow:inset 0 0 0 2px var(--accent)}
.cal-day.today .d{color:var(--ink);opacity:1}
.cal-evt{
  display:block;background:var(--accent);color:var(--accent-ink);border-radius:6px;
  padding:3px 6px;font-weight:700;line-height:1.25;font-size:.7rem;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cal-evt:hover{background:var(--donate);color:#fff}
@media (max-width:680px){
  .cal{padding:14px}
  .cal-day{min-height:54px;padding:4px}
  .cal-evt{font-size:0;padding:0;height:8px;width:8px;border-radius:50%;align-self:flex-start}
}


/* ------- Events page: single-row slider ------- */
.events-slider{position:relative;overflow:hidden}
.events-track{display:flex;transition:transform .45s ease}
.events-track .card{flex:0 0 33.333%;max-width:33.333%;margin:0 10px 0 0;box-sizing:border-box}
.events-nav{display:flex;gap:10px;justify-content:center;margin-top:18px}
.events-nav button{
  background:#fff;border:2px solid var(--ink);border-radius:999px;width:44px;height:44px;
  font-size:1.1rem;font-weight:800;cursor:pointer;font-family:var(--font);
}
.events-nav button:hover{background:var(--accent);border-color:var(--accent)}
@media (max-width:820px){.events-track .card{flex:0 0 100%;max-width:100%}}


/* ------- About: Problem -> Response flow ------- */
.flow-box{
  border:2px solid var(--ink);border-radius:var(--radius);
  padding:36px 34px;background:#fff;
}
.flow-box h2{margin-top:0}
.flow-box ul{margin:0;padding-left:1.2em}
.flow-box li{margin-bottom:.4em;font-weight:600}
.flow-problem{border-top:8px solid var(--pcard-3)}
.flow-response{border-top:8px solid var(--pcard-1);background:var(--paper-soft)}
.flow-response p{margin:0;font-weight:600}
.flow-arrow{
  display:flex;justify-content:center;color:var(--donate);
  margin:14px 0;
}
.flow-arrow svg{width:54px;height:54px}


/* ===== Buttons: extra large ===== */
.btn-xl{font-size:1.25rem;padding:1.15rem 2.8rem;letter-spacing:.02em}
.w900{font-weight:900}

/* ===== Animated stats band ===== */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat2{
  text-align:center;padding:34px 18px;border-radius:var(--radius);
  background:var(--paper-soft);transition:transform .2s ease,box-shadow .2s ease;cursor:default;
}
.stat2:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(11,20,8,.12)}
.stat2-num{font-size:clamp(2.4rem,4vw,3.4rem);font-weight:900;line-height:1;color:var(--donate)}
.stat2:nth-child(2) .stat2-num{color:var(--pcard-1)}
.stat2:nth-child(3) .stat2-num{color:var(--pcard-3)}
.stat2:nth-child(4) .stat2-num{color:var(--accent)}
.stat2-label{font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;margin-top:.5rem;opacity:.8}
@media (max-width:820px){.stats-band{grid-template-columns:1fr 1fr}}

/* ===== Voices testimonials ===== */
.voices-section{background:var(--donate);color:#fff;padding:88px 0}
.voices-section h2{color:#fff;text-align:center;text-transform:uppercase;margin-bottom:40px}
.voices-slider{overflow:hidden;max-width:760px;margin:0 auto}
.voices-track{display:flex;transition:transform .5s ease}
.voice{flex:0 0 100%;text-align:center;margin:0;padding:0 24px}
.voice-icon{
  display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;
  border-radius:50%;background:var(--accent);color:var(--accent-ink);font-size:1.6rem;margin-bottom:20px;
}
.voice blockquote{font-size:clamp(1.3rem,2.6vw,1.9rem);font-weight:800;line-height:1.3;margin:0 0 16px}
.voice figcaption{font-weight:700;opacity:.85;letter-spacing:.03em}
.voices-dots{display:flex;gap:10px;justify-content:center;margin-top:28px}
.voices-dots button{width:12px;height:12px;border-radius:50%;border:none;background:rgba(255,255,255,.4);cursor:pointer}
.voices-dots button.active{background:var(--accent)}

/* ===== Choose Your Impact ===== */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.impact-card{
  border:2px solid var(--line);border-radius:var(--radius);padding:36px 30px;
  display:flex;flex-direction:column;gap:14px;text-align:center;background:#fff;
}
.impact-card:nth-child(1){border-top:8px solid var(--pcard-2)}
.impact-card:nth-child(2){border-top:8px solid var(--pcard-1)}
.impact-card:nth-child(3){border-top:8px solid var(--pcard-3)}
.impact-card h3{margin:0;text-transform:uppercase;font-size:1.15rem}
.impact-card p{flex:1;margin:0;opacity:.8}
.impact-amt{font-weight:900;font-size:1.5rem;color:var(--donate)}
.impact-card .btn{align-self:center}
@media (max-width:820px){.impact-grid{grid-template-columns:1fr}}

/* ===== Build With Us (parallax) ===== */
.build-section{position:relative;color:#fff;overflow:hidden;text-align:center}
.build-bg{
  position:absolute;inset:0;z-index:0;
  background:url('../images/build-with-us.jpg') center/cover fixed no-repeat;
}
/* dark filter removed so the image pops */
.build-inner{position:relative;z-index:1;padding:130px 24px}
.build-section h2{color:#fff;text-transform:uppercase;font-size:clamp(2.2rem,4.6vw,3.4rem);margin:0 0 14px;text-shadow:0 2px 16px rgba(0,0,0,.55)}
.build-sub{font-weight:800;font-size:1.1rem;margin:0 0 14px;text-shadow:0 1px 10px rgba(0,0,0,.6)}
.build-text{max-width:60ch;margin:0 auto 28px;opacity:.98;text-shadow:0 1px 10px rgba(0,0,0,.6)}
.build-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
@media (max-width:820px){.build-bg{background-attachment:scroll}}

/* ===== Trusted By marquee ===== */
.partners-section{padding-bottom:40px}
.partners-marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.partners-track{display:flex;gap:30px;width:max-content;animation:marquee 48s linear infinite}
.partners-track:hover{animation-play-state:paused}
.partners-marquee .logo{
  flex:0 0 auto;height:96px;min-width:120px;display:flex;align-items:center;justify-content:center;
  padding:0 24px;background:transparent;border:none;border-radius:12px;
}
.partners-marquee .logo-chip{background:#2a2a2a;border-radius:12px;padding:0 22px}
.partners-marquee .logo img{max-height:58px;max-width:180px;width:auto;display:block}
.partners-marquee .logo-text{font-weight:800;color:var(--ink);opacity:.7;text-align:center;font-size:.95rem;line-height:1.25}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== CTA subheading ===== */
.cta-sub{max-width:54ch;margin:-1rem auto 2rem;opacity:.92;font-size:1.1rem}

/* ===== About: Dorill Approach (green, animated) ===== */
.approach{background:#ff7373;color:#fff;padding:96px 0}
.approach h2{color:#fff;text-transform:uppercase;margin-bottom:.6rem}
.approach-flow{font-weight:800;letter-spacing:.04em;opacity:.92;margin-bottom:2.4rem;font-size:1.05rem}
.approach-list{display:grid;gap:14px;max-width:880px}
.approach-list li{list-style:none;font-size:clamp(1.05rem,2vw,1.3rem);opacity:0;transform:translateY(12px);animation:approach-in .6s ease forwards}
.approach-list .lead{font-weight:900;margin-right:.4em;animation:approach-hue 6s linear infinite}
@keyframes approach-in{to{opacity:1;transform:none}}
@keyframes approach-hue{
  0%{color:var(--accent)}25%{color:#fff}50%{color:var(--pcard-3)}75%{color:#bfeacb}100%{color:var(--accent)}
}

/* ===== About: Board of Trustees grid ===== */
.board-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.board-card{text-align:center}
.board-card img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:12px;margin-bottom:10px}
.board-photo-link{display:block;position:relative;border-radius:12px;overflow:hidden}
.board-photo-link img{margin-bottom:10px;transition:transform .3s ease,filter .3s ease}
.board-photo-link:hover img{transform:scale(1.04);filter:brightness(.92)}
.board-card .bn{font-weight:800;font-size:.95rem;line-height:1.2}
.board-card .br{font-size:.8rem;font-weight:700;color:var(--donate);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.board-card .br-role{font-size:.8rem;opacity:.65;margin-top:1px}
.board-li-btn{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:.32rem .7rem;border-radius:999px;background:#0a66c2;color:#fff;font-size:.74rem;font-weight:700;text-decoration:none;transition:background .2s ease,transform .2s ease}
.board-li-btn:hover{background:#004182;transform:translateY(-1px)}
.board-li-btn svg{display:block}
@media (max-width:820px){.board-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.board-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== About: Vision borough list (dark green) ===== */
.vision{
  position:relative;color:#fff;padding:96px 0;overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(247,147,30,.35), transparent 42%),
    radial-gradient(circle at 88% 8%, rgba(59,184,167,.40), transparent 45%),
    radial-gradient(circle at 78% 92%, rgba(255,115,115,.34), transparent 46%),
    linear-gradient(135deg, #5f4f8a 0%, #7966ad 48%, #3bb8a7 100%);
}
.vision h2{color:#fff;text-transform:uppercase}
.vision-list{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:2rem}
.vision-boro{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:12px;overflow:hidden}
.vision-boro > button{
  width:100%;text-align:left;background:none;border:none;color:#fff;cursor:pointer;
  font-family:var(--font);font-weight:900;font-size:1rem;text-transform:uppercase;letter-spacing:.04em;
  padding:18px 18px;display:flex;justify-content:space-between;align-items:center;
}
.vision-boro > button .chev{transition:transform .2s ease;color:var(--accent)}
.vision-boro.open > button .chev{transform:rotate(90deg)}
.vision-areas{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 18px}
.vision-boro.open .vision-areas{max-height:400px;padding-bottom:16px}
.vision-areas li{list-style:none;padding:.32rem 0;opacity:.9;border-top:1px solid rgba(255,255,255,.1)}
@media (max-width:980px){.vision-list{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.vision-list{grid-template-columns:1fr}}

/* ===== Leadership apply + full-width join button ===== */
.leadership-apply{text-align:center;margin-top:40px}
.join-band{background:var(--ink);text-align:center;padding:64px 24px}

/* ===== Our Work: filters, day timeline, youth voices ===== */
.filters{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;margin-bottom:36px}
.filters .f{display:flex;flex-direction:column;gap:6px}
.filters label{font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;opacity:.7}
.filters select{padding:.7rem 1rem;border:2px solid var(--line);border-radius:10px;font-family:var(--font);font-size:.95rem;background:#fff;min-width:160px}
.filters .clear{align-self:flex-end;background:none;border:2px solid var(--ink);border-radius:999px;padding:.6rem 1.4rem;font-weight:800;font-family:var(--font);cursor:pointer}
.filters .clear:hover{background:var(--accent);border-color:var(--accent)}

.day-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px}
.day-row{display:flex;gap:18px;padding:16px 0;border-bottom:1px dashed var(--line);align-items:baseline}
.day-row .t{font-weight:900;color:var(--donate);min-width:90px}
.day-row .w{font-weight:600}
@media (max-width:680px){.day-grid{grid-template-columns:1fr}}

.youth-voices{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.youth-q{background:var(--paper-soft);border-left:6px solid var(--accent);border-radius:12px;padding:28px 26px}
.youth-q blockquote{margin:0 0 10px;font-weight:700;font-size:1.05rem;line-height:1.4}
.youth-q cite{opacity:.7;font-style:normal;font-weight:700;font-size:.88rem}
@media (max-width:820px){.youth-voices{grid-template-columns:1fr}}


/* ===== Page hero subtitle ===== */
.page-hero-sub{font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.85rem;opacity:.85;margin:.6rem 0 0}

/* ===== Co-founders / board thumbnails (5-col) ===== */
.cofounders-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:1.5rem}
.cofounders-grid .board-card img{aspect-ratio:1/1;border-radius:50%}
/* Ramos Family photo cards in the auto-loop carousel (mixed orientations -> square crop) */
.board-card.cofounder-photo img{aspect-ratio:1/1;border-radius:12px;margin-bottom:0}
@media (max-width:820px){.cofounders-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.cofounders-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== Events: ways-to-get-involved buttons (brand colors) ===== */
.ways-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}
.way-btn{
  display:inline-block;padding:.9rem 2rem;border-radius:999px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;color:#fff;transition:transform .15s ease,filter .15s ease;
}
.way-btn:hover{transform:translateY(-3px);filter:brightness(1.08)}
.way-teal{background:var(--pcard-1)}
.way-purple{background:var(--pcard-2)}
.way-orange{background:var(--pcard-3)}
.way-green{background:var(--green)}

/* ===== RSVP modal ===== */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(11,20,8,.6);display:flex;align-items:center;justify-content:center;padding:24px}
.modal-overlay[hidden]{display:none}
.modal{background:#fff;border-radius:var(--radius);padding:38px 34px;max-width:440px;width:100%;position:relative;max-height:90vh;overflow:auto}
.modal h3{margin:0 0 1.2rem;text-transform:uppercase}
.modal-close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--ink)}
.modal label{display:block;font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:1rem}
.modal input{display:block;width:100%;margin-top:.4rem;padding:.7rem .9rem;border:2px solid var(--line);border-radius:10px;font-family:var(--font);font-size:1rem}
.modal .btn{width:100%;margin-top:.4rem}
.rsvp-note{margin:.8rem 0 0;font-weight:700;color:var(--green);min-height:1.2em;text-align:center}

/* ===== News: categories, quick takes, connect ===== */
.news-cats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.news-cat{background:#fff;border:2px solid var(--line);border-radius:999px;padding:.5rem 1.2rem;font-weight:800;font-family:var(--font);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}
.news-cat:hover{border-color:var(--accent)}
.news-cat.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.quicktakes{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.quicktake{background:var(--paper-soft);border-radius:var(--radius);padding:28px 30px;display:flex;gap:16px;align-items:flex-start}
.quicktake i{color:var(--donate);font-size:1.4rem;margin-top:3px}
.quicktake p{margin:0;font-weight:700;font-size:1.05rem;line-height:1.4}
@media (max-width:680px){.quicktakes{grid-template-columns:1fr}}
.connect-section{background:var(--donate);color:#fff;padding:88px 0}
.connect-section h2{color:#fff;text-transform:uppercase}
.connect-form{display:flex;gap:10px;justify-content:center;max-width:480px;margin:1.6rem auto 0;flex-wrap:wrap}
.connect-form input{flex:1;min-width:220px;padding:.8rem 1.1rem;border-radius:999px;border:none;font-family:var(--font);font-size:1rem}
.connect-note{margin-top:1rem;font-weight:700;color:var(--accent);min-height:1.2em}

/* ===== Support: donor story + final CTA ===== */
.donor-story{text-align:center;position:relative;padding-top:20px}
.donor-quote-mark{font-size:5rem;line-height:0;color:var(--accent);font-weight:900;display:block;margin-bottom:1rem}
.donor-story blockquote{font-size:clamp(1.3rem,3vw,2rem);font-weight:800;line-height:1.35;margin:0 0 1rem;max-width:24ch;margin-inline:auto}
.donor-story cite{font-style:normal;font-weight:700;opacity:.7}
.support-finalcta{background:var(--ink);color:#fff;text-align:center;padding:96px 24px}
.support-finalcta h2{color:#fff;text-transform:uppercase;max-width:18ch;margin:0 auto 2rem}


/* Homepage hero text hard-left on laptops, sitting in the white space */
@media (min-width:1100px){
  #hero .hero-inner{margin-left:0;padding-left:72px}
  #hero .wrap{max-width:1280px}
}


/* Voices arrows + quote marks */
.voices-stage{position:relative;display:flex;align-items:center;justify-content:center;gap:8px}
.voices-arrow{
  flex:0 0 auto;width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.55);
  background:transparent;color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease;
}
.voices-arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.voice blockquote{position:relative}
.qmark{font-size:2.4rem;font-weight:900;color:var(--accent);line-height:0;vertical-align:-.15em;padding:0 .08em}
@media (max-width:600px){.voices-arrow{width:40px;height:40px;font-size:1.3rem}}

/* GET INVOLVED hero full width (image fills, cropping is fine) */
.page-hero--video,.page-hero--light{background-size:cover !important;background-position:center !important}


/* ===== Board of Trustees carousel ===== */
.board-carousel{position:relative;display:flex;align-items:center;gap:10px;margin-top:1.5rem}
.board-viewport{overflow:hidden;flex:1}
.board-track{display:flex;transition:transform .5s ease}
.board-track .board-card{flex:0 0 20%;max-width:20%;padding:0 10px;box-sizing:border-box}
.board-carousel .board-card .bn{white-space:nowrap;overflow:visible}
@media (max-width:820px){.board-carousel .board-card .bn{white-space:normal;word-break:break-word;font-size:.8rem;overflow:hidden}}
.board-arrow{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;border:2px solid var(--ink);
  background:#fff;color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease;
}
.board-arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
@media (max-width:820px){.board-track .board-card{flex:0 0 33.333%;max-width:33.333%}}
@media (max-width:520px){.board-track .board-card{flex:0 0 50%;max-width:50%}}

@media (max-width:1024px){.hero-sub{white-space:normal}}

/* Partner card amount line */
.p-amount{font-weight:900;font-size:1.35rem;color:#fff;margin:.2rem 0 .4rem}


/* Exciting animated header Donate (desktop) */
.header-donate{
  position:relative;overflow:hidden;background:var(--donate);color:#fff;border:none;cursor:pointer;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease,background .25s ease;
}
.header-donate::before{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.6),transparent);
  transform:skewX(-20deg);transition:none;
}
@media (hover:hover){
  .header-donate:hover{
    transform:translateY(-3px) scale(1.07) rotate(-1deg);
    box-shadow:0 14px 30px rgba(121,102,173,.5);
    background:linear-gradient(120deg,var(--donate),#9a7fd1);
    animation:donate-wiggle .5s ease;
  }
  .header-donate:hover::before{animation:donate-sheen .8s ease}
}
@keyframes donate-sheen{to{left:140%}}
@keyframes donate-wiggle{
  0%,100%{transform:translateY(-3px) scale(1.07) rotate(-1deg)}
  35%{transform:translateY(-4px) scale(1.09) rotate(1.5deg)}
  70%{transform:translateY(-3px) scale(1.07) rotate(-1.5deg)}
}


/* ===== Dorill Approach: flip cards ===== */
.approach-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:1.4rem}
.flip-card{
  perspective:1200px;height:180px;cursor:pointer;
  opacity:0;transform:translateY(12px);animation:approach-in .6s ease forwards;
}
.flip-inner{
  position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,.2,.2,1);
  transform-style:preserve-3d;
}
.flip-card:hover .flip-inner,
.flip-card:focus .flip-inner,
.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{
  position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  padding:24px;text-align:center;
}
.flip-front{background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.5)}
.flip-word{font-weight:900;font-size:1.8rem;text-transform:uppercase;letter-spacing:.02em;color:#fff}
.flip-back{background:#fff;color:var(--ink);transform:rotateY(180deg)}
.flip-back p{margin:0;font-weight:700;font-size:1.02rem;line-height:1.4}
@media (max-width:820px){
  .approach-cards{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px;
    padding-bottom:10px;
  }
  .approach-cards::-webkit-scrollbar{display:none}
  .flip-card{
    flex:0 0 78%;
    scroll-snap-align:center;
    height:200px;
  }
}

/* ===== Our Story timeline: horizontal scroll on mobile ===== */
.timeline-h{
  display:flex;overflow-x:auto;gap:18px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;padding-bottom:14px;
}
.timeline-h::-webkit-scrollbar{height:6px}
.timeline-h::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.timeline-h > div{flex:0 0 280px;scroll-snap-align:center}
@media (max-width:820px){
  .timeline-h > div{flex:0 0 78%}
}

/* ===== Problem/Response background video ===== */
.flow-section{position:relative;overflow:hidden;color:#fff}
.flow-video{position:absolute;inset:0;z-index:0;pointer-events:none;background:#0b1408}
.flow-video iframe{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:max(100vw,177.78vh);height:max(100vh,56.25vw);border:0;
}
.flow-section::after{content:"";position:absolute;inset:0;z-index:1;background:rgba(11,20,8,.62);pointer-events:none}
.flow-content{position:relative;z-index:2}
.flow-video-controls{position:absolute;top:18px;right:18px;z-index:3;display:flex;gap:8px}
.flow-video-controls button{
  width:42px;height:42px;border-radius:50%;border:2px solid rgba(255,255,255,.65);
  background:rgba(0,0,0,.35);color:#fff;font-size:.95rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease;
}
.flow-video-controls button:hover{background:var(--donate);border-color:var(--donate)}
/* flow boxes sit on the video: transparent, pushed right, smaller */
.flow-section .flow-content{max-width:560px;margin-left:auto;margin-right:0}
.flow-section .flow-box{
  background:rgba(255,255,255,.10);color:#fff;border:2px solid rgba(255,255,255,.4);
  padding:24px 26px;backdrop-filter:blur(2px);
}
.flow-section .flow-box h2{color:#fff;font-size:1.4rem}
.flow-section .flow-box ul{font-size:.95rem}
.flow-section .flow-box li{font-weight:600;margin-bottom:.3em}
.flow-section .flow-response{background:rgba(255,255,255,.10)}
.flow-section .flow-response p{font-size:.95rem;margin:0}
.flow-section .flow-arrow{color:#fff}
.flow-section .flow-arrow svg{width:42px;height:42px}
.heading-accent{color:#0b1408}


/* Topbar "Get Tickets" round orange button */
#site-topbar .wrap > a,
#site-topbar .wrap > .topbar-tickets{
  background:var(--accent);color:#fff;border-radius:999px;
  padding:.32rem 1.1rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.03em;font-size:.78rem;white-space:nowrap;border:none;
  transition:filter .15s ease,transform .15s ease;
  cursor:pointer;font-family:inherit;line-height:1.4;
}
#site-topbar .wrap > a:hover,
#site-topbar .wrap > .topbar-tickets:hover{filter:brightness(1.08);transform:translateY(-1px);color:#fff;opacity:1}
@media (max-width:600px){
  #site-topbar .wrap > a,
  #site-topbar .wrap > .topbar-tickets{font-size:.66rem;padding:.3rem .8rem}
  #site-topbar .ticker{font-size:.72rem}
}


/* First timeline item: purple firework "spark" marker */
.timeline-h .tl-spark::before{
  content:none !important;display:none !important;
}
@media (max-width:900px){.timeline-h .tl-spark::before{left:-44px;top:-4px}}

/* ===== Funraise donate modal (colorful, dynamic) ===== */
.fr-modal{
  position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(circle at 30% 20%, rgba(121,102,173,.96), rgba(59,184,167,.94) 55%, rgba(247,147,30,.92));
  animation:fr-fade-in .3s ease;
}
.fr-modal[hidden]{display:none}
@keyframes fr-fade-in{from{opacity:0}to{opacity:1}}
.fr-modal-inner{
  position:relative;width:100%;max-width:560px;max-height:92vh;background:#fff;
  border-radius:22px;box-shadow:0 30px 90px rgba(0,0,0,.55);
  animation:fr-pop .45s cubic-bezier(.34,1.56,.64,1);
  display:flex;flex-direction:column;overflow:visible;
}
@keyframes fr-pop{0%{transform:scale(.8) translateY(30px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
/* playful banner above the form */
.fr-modal-inner::before{
  content:"\2728  Your Gift Builds The City We Deserve  \2728";
  display:block;flex:0 0 auto;text-align:center;font-weight:900;color:#fff;font-size:.92rem;
  letter-spacing:.02em;padding:14px 46px 13px;
  background:linear-gradient(100deg,var(--donate),var(--pcard-1));
  border-radius:22px 22px 0 0;
}
.fr-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:0 0 22px 22px}
/* let the Funraise form flow from the top and report its real height */
.fr-scroll > div{width:100%}
.fr-scroll iframe,.fr-scroll [id^="fr-"]{margin-left:auto !important;margin-right:auto !important;max-width:100% !important}
/* GIANT animated X */
.fr-modal-close{
  position:absolute;top:-18px;right:-18px;z-index:5;width:56px;height:56px;border-radius:50%;
  border:4px solid #fff;background:var(--accent);color:#fff;font-size:2rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-weight:700;
  box-shadow:0 8px 24px rgba(0,0,0,.35);transition:transform .2s ease,background .2s ease;
}
.fr-modal-close:hover{transform:rotate(90deg) scale(1.12);background:var(--donate)}
@media (max-width:560px){
  .fr-modal{padding:0;align-items:stretch}
  .fr-modal-inner{max-width:none;width:100%;height:100dvh;max-height:100dvh;border-radius:0}
  .fr-modal-inner::before{border-radius:0}
  /* fill the panel below the banner and top-align the form so there is no gap */
  .fr-scroll{border-radius:0;display:flex;flex-direction:column}
  .fr-scroll > div{flex:1 1 auto}
  .fr-modal-close{top:8px;right:8px;width:46px;height:46px;font-size:1.7rem}
}

/* ===== About: Mission & Vision flip cards ===== */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.mv-card{perspective:1400px;height:320px;cursor:pointer}
.mv-inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d}
.mv-card:hover .mv-inner,.mv-card:focus .mv-inner{transform:rotateY(180deg)}
.mv-front,.mv-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);overflow:hidden}
.mv-front{background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end;padding:28px}
.mv-front-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,20,8,.1),rgba(11,20,8,.72))}
.mv-eyebrow{position:relative;color:#fff;font-weight:900;font-size:1.6rem;text-transform:uppercase;letter-spacing:.02em}
.mv-hint{position:relative;color:rgba(255,255,255,.85);font-weight:700;font-size:.8rem;margin-top:.4rem}
.mv-back{transform:rotateY(180deg);color:#fff;padding:32px;display:flex;flex-direction:column;justify-content:center}
.mv-back h3{color:#fff;margin:0 0 .6rem;text-transform:uppercase}
.mv-back p{margin:0 0 .6rem;font-size:.96rem;line-height:1.5;opacity:.96}
.mv-back-teal{background:var(--pcard-1)}
.mv-back-purple{background:var(--pcard-2)}
.mv-back-red{background:#ff7373}
/* Why We Exist: full-width flip card spanning both columns */
.mv-card-wide{grid-column:1 / -1;height:300px}
.mv-card-wide .mv-eyebrow{font-size:1.9rem}
.mv-card-wide .mv-back{padding:30px 40px}
.mv-card-wide .mv-back p{font-size:1rem;max-width:none}
.mv-card-wide .mv-back .why-big{font-size:1.25rem;font-weight:900;margin:.2rem 0 .5rem}
@media (max-width:820px){.mv-grid{grid-template-columns:1fr}.mv-card{height:300px}.mv-card-wide{height:auto;min-height:360px}.mv-card-wide .mv-back{padding:24px}}

/* ===== About: Invest in the Future ===== */
.invest-section{position:relative;background-size:cover;background-position:center;color:#fff;padding:110px 24px}
.invest-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(121,102,173,.92),rgba(59,184,167,.82))}
.invest-inner{position:relative;max-width:760px;margin:0 auto;text-align:center}
.invest-eyebrow{display:inline-block;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.9rem;background:rgba(255,255,255,.18);padding:.4rem 1rem;border-radius:999px;margin-bottom:1.2rem}
.invest-section h2{color:#fff;text-transform:uppercase;font-size:clamp(1.8rem,4vw,2.8rem);margin:0 0 1rem}
.invest-section p{font-size:1.08rem;line-height:1.6;opacity:.97;max-width:62ch;margin:0 auto .9rem}
.invest-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:2rem}

/* ===== About: unified invest buttons + scroll reveal ===== */
.btn-invest{
  background:var(--donate);color:#fff;border:none;font-size:1.05rem;padding:1rem 2rem;
  border-radius:999px;font-weight:800;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
}
.btn-invest:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 14px 30px rgba(121,102,173,.45);filter:brightness(1.06)}
.btn-invest-red{background:var(--accent);color:#fff}
.btn-invest-white{background:#fff;color:var(--ink)}
.btn-invest-white:hover{background:#fff;color:var(--ink)}
.reveal-on-scroll{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal-on-scroll.is-visible{opacity:1;transform:none}
.reveal-on-scroll.invest-btns .btn-invest{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal-on-scroll.is-visible.invest-btns .btn-invest{opacity:1;transform:none}
.reveal-on-scroll.is-visible.invest-btns .btn-invest:nth-child(2){transition-delay:.12s}
.reveal-on-scroll.is-visible.invest-btns .btn-invest:nth-child(3){transition-delay:.24s}

/* Parallax background for the invest section */
.invest-parallax{background-attachment:fixed}
@media (max-width:820px){.invest-parallax{background-attachment:scroll}}

/* ===== Mission/Vision text emphasis ===== */
.mv-back mark{background:rgba(255,255,255,.28);color:#fff;padding:.02em .22em;border-radius:4px;font-weight:700}
.mv-back strong{color:#fff;font-weight:900}

/* ===== Timeline ===== */
/* Desktop: all milestones fit on screen, connected by a dotted line, no arrows. */
.timeline-wrap{display:flex;align-items:stretch;gap:0;max-width:1100px;margin:2rem auto 0}
.timeline-arrow{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;border:2px solid var(--ink);
  background:#fff;color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;
  display:none;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease;
  align-self:center;
}
.timeline-arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.timeline-wrap .timeline-h{
  display:flex;flex:1;gap:0;margin:0;padding:0;position:relative;
  grid-template-columns:none;overflow:visible;
}
/* dotted line running through every event */
.timeline-wrap .timeline-h::before{
  content:"";position:absolute;left:0;right:0;top:34px;height:0;
  border-top:3px dotted var(--donate);display:block;z-index:0;
}
.timeline-wrap .timeline-h > div{
  flex:1 1 0;min-width:0;scroll-snap-align:start;padding:0 12px;text-align:center;
  position:relative;z-index:1;padding-top:58px;
}
/* the dot on the line for each event */
.timeline-wrap .timeline-h > div::after{
  content:"";position:absolute;top:25px;left:50%;transform:translateX(-50%);
  width:18px;height:18px;border-radius:50%;background:var(--donate);
  border:4px solid #fff;box-shadow:0 0 0 2px var(--donate);z-index:2;
}
.timeline-wrap .timeline-h .year{font-size:1.4rem;color:var(--accent);display:block;margin-bottom:.25rem}
.timeline-wrap .timeline-h h3{font-size:.98rem;margin:0 0 .35rem}
.timeline-wrap .timeline-h p{font-size:.82rem;opacity:.82;margin:0}
/* first item (the spark) gets the same purple dot as the rest, for consistency */
.timeline-wrap .tl-spark::after{
  content:"" !important;display:block !important;
}

/* Mobile: horizontal scroll, one card at a time, arrows visible. */
@media (max-width:820px){
  .timeline-wrap{gap:8px;align-items:center}
  .timeline-arrow{display:flex}
  .timeline-wrap .timeline-h{
    overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .timeline-wrap .timeline-h::-webkit-scrollbar{display:none}
  .timeline-wrap .timeline-h::before{top:auto;bottom:0;left:6%;right:6%;border-top:3px dotted var(--donate)}
  .timeline-wrap .timeline-h > div{flex:0 0 100%;padding-top:14px;padding-bottom:34px}
  .timeline-wrap .timeline-h > div::after{top:auto;bottom:-9px}
  .timeline-wrap .tl-spark::after{bottom:-13px;top:auto}
  .timeline-wrap .timeline-h .year{font-size:1.6rem}
  .timeline-wrap .timeline-h h3{font-size:1.05rem}
  .timeline-wrap .timeline-h p{font-size:.9rem}
}

/* ===== Why We Exist ===== */
.why-title{font-size:clamp(2.4rem,6vw,4.2rem);font-weight:900;text-transform:uppercase;line-height:1;margin:0 0 1.2rem;color:var(--donate);letter-spacing:-.01em}
.why-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.why-eyebrow{color:#fff;background:var(--donate)}
.why-lead{font-size:1.15rem}
.why-big{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;line-height:1.2;margin:1rem 0}
.why-section mark{background:var(--accent);color:var(--accent-ink);padding:.04em .25em;border-radius:5px}
.why-section strong{color:var(--donate)}
.why-image{border-radius:var(--radius);min-height:340px;background-size:cover;background-position:center}
@media (max-width:820px){.why-grid{grid-template-columns:1fr}.why-image{min-height:220px}}

/* ===== Why Partners Invest (intersection grid) ===== */
.partners-invest{background:var(--ink);color:#fff;border-radius:0}
.intersect-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:2rem 0}
.intersect-chip{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:14px;
  padding:24px 16px;text-align:center;transition:transform .2s ease,background .2s ease,border-color .2s ease;
}
.intersect-chip:hover{transform:translateY(-5px);background:var(--donate);border-color:var(--donate)}
.intersect-chip i{font-size:1.8rem;color:var(--accent);margin-bottom:.6rem;display:block;transition:color .2s ease}
.intersect-chip:hover i{color:#fff}
.intersect-chip span{font-weight:800;font-size:.92rem}
.partners-invest-note{max-width:760px;font-size:1.05rem;line-height:1.6;opacity:.95;text-wrap:balance}
.partners-invest-note-top{margin:1rem 0 2rem}
.partners-invest-note strong{color:var(--accent)}
@media (max-width:820px){.intersect-grid{grid-template-columns:1fr 1fr}}

/* ===== Leadership "Connect with" buttons ===== */
.btn-connect{
  display:inline-block;margin-top:.5rem;background:var(--donate);color:#fff;border:none;
  padding:.55rem 1.1rem;border-radius:999px;font-weight:800;font-size:.88rem;
  transition:transform .2s ease,filter .2s ease;
}
.btn-connect:hover{transform:translateY(-2px);filter:brightness(1.08)}

/* ===== A Message From The Ramos Family ===== */
.founder-message{background:var(--paper-soft)}
.founder-inner{
  max-width:780px;margin:0 auto;text-align:center;position:relative;padding:48px 28px;
  background:#fff;border-radius:var(--radius);box-shadow:0 18px 50px rgba(11,20,8,.08);
}
.founder-mark{
  display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;
  background:var(--donate);color:#fff;font-size:1.5rem;margin-bottom:1rem;
}
.founder-eyebrow{display:inline-block;background:var(--donate);color:#fff;margin-bottom:1.4rem}
.founder-inner p{font-size:1.15rem;line-height:1.6;margin:0 0 .7rem;color:var(--ink)}
.founder-inner p strong{color:var(--donate)}
.founder-inner mark{background:var(--accent);color:var(--accent-ink);padding:.04em .25em;border-radius:5px}
.founder-btn{margin-top:1.6rem}

/* ===== Why We Exist: interactive image hover ===== */
.why-image-interactive{position:relative;cursor:pointer;overflow:hidden}
.why-image-overlay{
  position:absolute;inset:0;display:flex;align-items:flex-end;
  background:linear-gradient(180deg,transparent 40%,rgba(121,102,173,.88));
  opacity:0;transition:opacity .35s ease;padding:24px;
}
.why-image-interactive:hover .why-image-overlay,
.why-image-interactive:focus .why-image-overlay{opacity:1}
.why-image-overlay span{color:#fff;font-weight:900;font-size:1.2rem;line-height:1.3;
  transform:translateY(10px);transition:transform .35s ease}
.why-image-interactive:hover .why-image-overlay span,
.why-image-interactive:focus .why-image-overlay span{transform:none}

/* ===== Inquiry form modal (on-site, branded) ===== */
.inq-modal{
  position:fixed;inset:0;z-index:1001;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(circle at 25% 15%, rgba(121,102,173,.95), rgba(59,184,167,.93) 55%, rgba(247,147,30,.9));
  animation:inq-fade .3s ease;
}
.inq-modal[hidden]{display:none}
@keyframes inq-fade{from{opacity:0}to{opacity:1}}
.inq-inner{
  position:relative;width:100%;max-width:460px;max-height:92vh;overflow-y:auto;overflow-x:hidden;background:#fff;
  border-radius:22px;box-shadow:0 30px 90px rgba(0,0,0,.5);padding:34px 28px 30px;
  animation:inq-pop .45s cubic-bezier(.34,1.56,.64,1);
}
@keyframes inq-pop{0%{transform:scale(.85) translateY(24px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
.inq-close{
  position:absolute;top:12px;right:12px;width:42px;height:42px;border-radius:50%;
  border:3px solid #fff;background:var(--accent);color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.25);
  transition:transform .2s ease,background .2s ease;z-index:3;
}
.inq-close:hover{transform:rotate(90deg) scale(1.1);background:var(--donate)}
.inq-head{text-align:center;margin-bottom:1.2rem}
.inq-spark{font-size:1.6rem;display:block;margin-bottom:.3rem}
.inq-title{margin:0 0 .3rem;color:var(--donate);font-size:1.4rem;text-transform:uppercase;letter-spacing:.01em}
.inq-sub{margin:0;font-size:.92rem;opacity:.75}
.inq-field{display:block;margin-bottom:14px}
.inq-field span{display:block;font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;color:var(--ink)}
.inq-field input,.inq-field textarea{
  width:100%;box-sizing:border-box;border:2px solid transparent;border-radius:12px;
  padding:12px 14px;font-family:var(--font);font-size:1rem;background:var(--paper-soft);
  transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;
}
.inq-field:nth-child(1) input:focus{border-color:var(--pcard-2);background:#fff;box-shadow:0 0 0 4px rgba(121,102,173,.16)}
.inq-field:nth-child(2) input:focus{border-color:var(--pcard-1);background:#fff;box-shadow:0 0 0 4px rgba(59,184,167,.16)}
.inq-field:nth-child(3) input:focus{border-color:var(--pcard-3);background:#fff;box-shadow:0 0 0 4px rgba(247,147,30,.16)}
.inq-field textarea:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px rgba(255,115,115,.16);outline:none}
.inq-field input:focus{outline:none}
.inq-field textarea{resize:vertical;min-height:90px}
.inq-submit{
  position:relative;width:100%;margin-top:6px;border:none;cursor:pointer;
  background:linear-gradient(100deg,var(--donate),var(--pcard-1));color:#fff;
  padding:14px;border-radius:999px;font-weight:900;font-size:1.05rem;font-family:var(--font);
  text-transform:uppercase;letter-spacing:.03em;overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
  background-size:200% auto;
}
.inq-submit:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 14px 30px rgba(121,102,173,.4);background-position:right center;animation:inq-shimmer 1.5s linear infinite}
@keyframes inq-shimmer{0%{background-position:0% center}100%{background-position:200% center}}
.inq-submit .inq-spinner{
  display:none;position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;
  border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:inq-spin .7s linear infinite;
}
@keyframes inq-spin{to{transform:rotate(360deg)}}
.inq-submit.is-loading .inq-submit-label{opacity:0}
.inq-submit.is-loading .inq-spinner{display:block}
.inq-submit.is-loading{pointer-events:none}
.inq-error{color:#c0392b;font-weight:700;font-size:.88rem;margin:.6rem 0 0;text-align:center}
.inq-thanks{text-align:center;padding:20px 6px;animation:inq-fade .4s ease}
.inq-thanks-check{
  width:72px;height:72px;border-radius:50%;background:var(--pcard-1);color:#fff;font-size:2.2rem;
  display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;
  animation:inq-pop-check .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes inq-pop-check{0%{transform:scale(0)}100%{transform:scale(1)}}
.inq-thanks h3{margin:0 0 .5rem;color:var(--donate);text-transform:uppercase}
.inq-thanks-msg{font-size:1.02rem;line-height:1.5;margin:0;color:var(--ink)}
@media (max-width:560px){
  .inq-modal{padding:0}
  .inq-inner{max-width:none;width:100%;height:100dvh;max-height:100dvh;border-radius:0;padding-top:54px}
  .inq-close{top:12px;right:12px}
}

/* ===== Scroll-spy section navigator (About page) ===== */
.section-nav{
  position:fixed;left:0;top:50%;transform:translate(-110%,-50%);z-index:900;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--line);border-left:none;border-radius:0 16px 16px 0;
  padding:14px 16px 14px 14px;box-shadow:0 12px 40px rgba(11,20,8,.14);
  opacity:0;transition:transform .45s cubic-bezier(.34,1.4,.64,1),opacity .35s ease;
  max-width:230px;
}
.section-nav.is-visible{transform:translate(0,-50%);opacity:1}
.section-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.section-nav a{
  display:block;text-decoration:none;color:var(--ink);opacity:.55;
  font-weight:700;font-size:.74rem;line-height:1.25;letter-spacing:.01em;
  padding:5px 10px;border-radius:8px;border-left:3px solid transparent;
  transition:all .22s ease;white-space:normal;
}
.section-nav a:hover{opacity:.9;background:rgba(121,102,173,.08)}
.section-nav a.active{
  opacity:1;color:var(--donate);font-size:.92rem;font-weight:900;
  border-left-color:var(--donate);background:rgba(121,102,173,.1);
}
/* desktop toggle arrow hidden (only used on mobile) */
.section-nav-toggle{display:none}

/* ===== Desktop: HIDE/SHOW MENU tab on the right edge of the left-side menu ===== */
@media (min-width:1101px){
  .section-nav{overflow:visible}
  /* collapsed state: slide the menu off the left edge, but leave the 34px tab peeking */
  .section-nav.is-collapsed{transform:translate(calc(-100% + 34px),-50%);opacity:1}
  .section-nav.is-collapsed.is-visible{transform:translate(calc(-100% + 34px),-50%);opacity:1}
  .section-nav-toggle{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    position:absolute;right:-34px;top:50%;transform:translateY(-50%);
    width:34px;min-height:104px;border:1px solid var(--line);border-left:none;
    background:rgba(255,255,255,.97);color:var(--donate);
    border-radius:0 12px 12px 0;cursor:pointer;
    box-shadow:4px 0 14px rgba(11,20,8,.12);transition:background .2s ease;
    padding:0;
  }
  .section-nav-toggle:hover{background:#fff}
  /* hide the hardcoded "MENU" text; we generate the label via ::after */
  .section-nav-toggle .section-nav-toggle-label{display:none}
  .section-nav-toggle .section-nav-toggle-arrow{
    line-height:1;display:inline-block;
    font-size:0;  /* hide the hardcoded glyph; show only ::before */
  }
  .section-nav-toggle::after{
    content:"HIDE MENU";
    writing-mode:vertical-rl;transform:rotate(180deg);
    font-size:.5rem;font-weight:900;letter-spacing:.1em;
  }
  /* default (expanded): arrow points LEFT (tuck it away) */
  .section-nav:not(.is-collapsed) .section-nav-toggle-arrow::before{content:"\2039";font-size:1.25rem;font-weight:900}
  /* collapsed: flip label to SHOW MENU and arrow to RIGHT */
  .section-nav.is-collapsed .section-nav-toggle::after{content:"SHOW MENU"}
  .section-nav.is-collapsed .section-nav-toggle-arrow::before{content:"\203A";font-size:1.25rem;font-weight:900}
}
/* Mobile: small panel on the RIGHT, collapsed off-screen with a pull-out arrow */
@media (max-width:1100px){
  .section-nav{
    left:auto;right:0;top:50%;width:180px;max-width:180px;
    transform:translate(100%,-50%);          /* panel hidden off the right edge */
    border-radius:14px 0 0 14px;border:1px solid var(--line);border-right:none;
    padding:10px 10px 10px 14px;opacity:1;
    transition:transform .4s cubic-bezier(.34,1.4,.64,1);
    /* keep the arrow tab visible even when the panel is off-screen */
    overflow:visible;
  }
  .section-nav.is-visible{transform:translate(100%,-50%)}   /* stays tucked until opened */
  .section-nav.is-open{transform:translate(0,-50%)}         /* arrow tap slides it in, any scroll position */
  .section-nav ul{margin-top:0}
  .section-nav a{font-size:.68rem;padding:4px 8px}
  .section-nav a.active{font-size:.8rem}
  /* the pull-out arrow tab — sits on the screen's right edge, left of the panel */
  .section-nav-toggle{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    position:absolute;left:-34px;top:50%;transform:translateY(-50%);
    width:34px;min-height:64px;border:1px solid var(--line);border-right:none;
    background:rgba(255,255,255,.97);color:var(--donate);
    border-radius:12px 0 0 12px;cursor:pointer;
    box-shadow:-4px 0 14px rgba(11,20,8,.12);transition:transform .3s ease;
  }
  .section-nav-toggle-label{font-size:.42rem;font-weight:900;letter-spacing:.08em;writing-mode:vertical-rl;transform:rotate(180deg)}
  .section-nav-toggle-arrow{font-size:1.2rem;font-weight:900;line-height:1}
  .section-nav.is-open .section-nav-toggle-arrow{transform:rotate(180deg);display:inline-block}
  /* keep the tab visible at all times, including while scrolling */
  .section-nav.is-scrolling:not(.is-open){opacity:1;pointer-events:auto}
}
@media (max-width:560px){
  .section-nav{max-width:164px}
  .section-nav a{font-size:.64rem}
  .section-nav a.active{font-size:.74rem}
}

/* ===== New additions (v38) ===== */

/* Orange stat chip (2018 Building the Movement Since) */
.stat-chip-orange{background:var(--pcard-3)}
.stat-chip-orange .num{color:#fff}
.stat-chip-orange .lab{color:rgba(255,255,255,.95)}

/* Orange flip card back */
.mv-back-orange{background:#f7931e;color:#fff}
.mv-back-orange mark{background:rgba(255,255,255,.25);color:#fff}

/* 2-column mv-grid for Problem/Response */
.mv-grid-2col{grid-template-columns:1fr 1fr;grid-template-rows:auto}
@media(max-width:680px){.mv-grid-2col{grid-template-columns:1fr}}

/* Brain icon highlighted chip */
.intersect-chip-active{background:#7966ad!important}
.intersect-chip-active i,.intersect-chip-active span{color:#fff!important}

/* Watch Our Story video modal */
.video-modal{
  position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.85);
}
.video-modal[hidden]{display:none}
.video-modal-inner{position:relative;width:min(90vw,860px);background:#111;border-radius:18px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.7)}
.video-modal-close{
  position:absolute;top:12px;right:14px;z-index:10;
  background:var(--accent);color:#fff;border:none;border-radius:50%;
  width:38px;height:38px;font-size:1.3rem;cursor:pointer;font-weight:900;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s ease;
}
.video-modal-close:hover{transform:scale(1.1)}
.video-modal-player{position:relative;aspect-ratio:16/9}
.video-modal-player iframe,.video-modal-player #story-yt-player{width:100%;height:100%;position:absolute;inset:0}
.video-modal-controls{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:12px;z-index:5;
}
.vid-ctrl-btn{
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  border:2px solid rgba(255,255,255,.4);color:#fff;border-radius:50%;
  width:46px;height:46px;font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s ease,transform .15s ease;
}
.vid-ctrl-btn:hover{background:var(--donate);transform:scale(1.08)}


/* ===== OUR WORK PAGE ===== */
.ow-hero{position:relative;overflow:hidden}
.ow-hero-img{height:480px;background-size:cover;background-position:center;position:relative}
.ow-hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(121,102,173,.7) 0%,rgba(59,184,167,.55) 100%)}
.ow-hero-inner{position:absolute;inset:0;display:flex;align-items:center;height:480px}
.ow-hero-inner h1{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.3);max-width:720px;line-height:1.1}
.ow-hero-teal{color:#c2e9e7}
.ow-stats-band{background:var(--paper-soft);padding:44px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ow-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.ow-stat{border-radius:16px;padding:1.5rem 1rem;box-shadow:0 8px 22px rgba(95,79,138,.16)}
.ow-stat:nth-child(1){background:var(--donate)}
.ow-stat:nth-child(2){background:var(--pcard-1)}
.ow-stat:nth-child(3){background:var(--pcard-3)}
.ow-stat:nth-child(4){background:var(--accent)}
.ow-stat-num{display:block;font-size:clamp(2rem,5vw,3rem);font-weight:900;color:#fff;line-height:1}
.ow-stat-label{display:block;font-size:.85rem;color:rgba(255,255,255,.95);font-weight:700;letter-spacing:.05em;margin-top:4px}
@media(max-width:680px){.ow-stats-grid{grid-template-columns:repeat(2,1fr)}}

/* Program spotlight details list */
.spotlight-details{list-style:none;padding:0;margin:0 0 1.5rem}
.spotlight-details li{display:flex;align-items:center;gap:10px;padding:.45em 0;border-bottom:1px solid var(--line);font-weight:600}
.spotlight-details li:last-child{border:none}
.spotlight-details i{color:var(--donate);width:18px;text-align:center}

/* I AM finder */
.iam-finder{background:var(--paper-soft);border-radius:var(--radius);padding:2.5rem;margin-bottom:1rem}
.iam-intro{font-size:1.3rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--donate);margin:0 0 1.2rem}
.iam-options{display:flex;flex-wrap:wrap;gap:14px}
.iam-btn{
  background:#fff;border:2px solid var(--line);border-radius:999px;
  padding:.75rem 1.5rem;font-family:var(--font);font-weight:800;font-size:1rem;
  cursor:pointer;display:flex;align-items:center;gap:8px;
  transition:all .2s ease;color:var(--ink);
}
.iam-btn:hover{background:var(--donate);color:#fff;border-color:var(--donate);transform:translateY(-2px)}
.iam-btn i{font-size:.95rem}
.iam-result{padding-top:.5rem}
.iam-reset{background:none;border:none;cursor:pointer;font-weight:700;color:var(--donate);font-family:var(--font);font-size:.95rem;padding:0 0 1rem;display:flex;align-items:center;gap:6px}
.iam-result-btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:1.2rem}

/* Vertical timeline */
.vtl{position:relative;padding-left:80px;max-width:680px;margin:2rem auto 0}
.vtl::before{content:"";position:absolute;left:54px;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--donate),var(--pcard-1));border-radius:2px}
.vtl-item{display:flex;align-items:flex-start;gap:0;margin-bottom:2.2rem;position:relative;opacity:0;transform:translateX(-24px);transition:opacity .5s ease,transform .5s ease}
.vtl-item.is-visible{opacity:1;transform:none}
.vtl-time{position:absolute;left:-80px;top:10px;font-weight:900;font-size:.88rem;color:var(--donate);width:70px;text-align:right}
.vtl-dot{position:absolute;left:-29px;top:10px;width:14px;height:14px;border-radius:50%;background:var(--donate);border:3px solid #fff;box-shadow:0 0 0 2px var(--donate);flex-shrink:0;z-index:1}
.vtl-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:.7rem 1.1rem;font-weight:700;font-size:.95rem;box-shadow:0 2px 8px rgba(0,0,0,.06);flex:1}

/* Artistic disciplines */
.disciplines-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:2.5rem}
.disc-card{background:#fff;border-radius:var(--radius);padding:1.8rem 1.4rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.07);border-top:4px solid var(--disc-color);opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.disc-card.is-visible{opacity:1;transform:none}
.disc-card:hover{transform:translateY(-4px);box-shadow:0 6px 24px rgba(0,0,0,.12)}
.disc-icon{font-size:2rem;color:var(--disc-color);margin-bottom:.7rem}
.disc-card h3{font-size:1.05rem;margin:0 0 .4rem;color:var(--ink)}
.disc-card p{font-size:.85rem;color:rgba(11,20,8,.6);margin:0;line-height:1.4}
@media (max-width:820px){
  .disciplines-grid{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px;
    padding-bottom:10px;
  }
  .disciplines-grid::-webkit-scrollbar{display:none}
  .disc-card{flex:0 0 72%;scroll-snap-align:center}
}

/* Stories of Impact slider */
.impact-slider{margin-top:2rem;position:relative;overflow:hidden}
.impact-track{display:flex;transition:transform .4s ease}
.impact-slide{min-width:100%;padding:2.5rem;background:#fff;border-radius:var(--radius);box-shadow:0 2px 16px rgba(0,0,0,.07);text-align:center}
.impact-slide blockquote{font-size:1.2rem;font-style:italic;color:var(--ink);margin:0 0 1rem;line-height:1.6;font-weight:600}
.impact-slide cite{font-weight:800;color:var(--donate);font-style:normal;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase}
.impact-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:1.2rem}
.impact-prev,.impact-next{background:var(--donate);color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}
.impact-prev:hover,.impact-next:hover{transform:scale(1.1)}
.impact-dots{display:flex;gap:8px}
.impact-dot{width:10px;height:10px;border-radius:50%;background:var(--line);border:none;cursor:pointer;transition:background .2s}
.impact-dot.active{background:var(--donate)}

/* What We Measure */
.ow-measure-section{background:linear-gradient(135deg,var(--donate) 0%,var(--pcard-1) 100%);color:#fff}
.ow-measure-head{color:#fff;text-align:center;margin-bottom:2.5rem}
@media(max-width:820px){
  .ow-measure-head{text-align:left}
  .ow-measure-section .eyebrow{text-align:left}
}
.measure-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.measure-item{
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.25);
  border-radius:var(--radius);padding:1.8rem 1.4rem;display:flex;flex-direction:column;
  align-items:center;gap:.7rem;text-align:center;
  opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease;
  backdrop-filter:blur(4px);
}
.measure-item.is-visible{opacity:1;transform:none}
.measure-item:hover{background:rgba(255,255,255,.22);transform:translateY(-4px)}
.measure-icon{color:#fff;line-height:1;display:inline-flex}
.measure-icon svg{display:block}
.measure-label{font-weight:800;font-size:1rem;color:#fff}
@media (max-width:820px){
  .measure-grid{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px;
    padding-bottom:10px;
  }
  .measure-grid::-webkit-scrollbar{display:none}
  .measure-item{flex:0 0 70%;scroll-snap-align:center}
}

/* Our Work CTA */
.ow-cta{position:relative;padding:100px 24px;text-align:center}
.ow-cta-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.ow-cta-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.ow-cta h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1rem}
.ow-cta p{color:rgba(255,255,255,.88);font-size:1.1rem;line-height:1.7;margin-bottom:2rem}
.ow-cta-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}


/* ===== NEWS PAGE ===== */
.news-ceo-section{background:linear-gradient(135deg,#f9f5ff 0%,#e8f9f7 100%)}
.news-ceo-wrap{display:flex;align-items:flex-start;gap:2.5rem;flex-wrap:wrap}
.news-ceo-badge{background:var(--donate);color:#fff;border-radius:var(--radius);padding:1.2rem 1.6rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:120px;text-align:center;font-weight:800;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0}
.news-ceo-badge i{font-size:2rem}
.news-ceo-body{flex:1}
.news-ceo-quote{font-size:1.35rem;font-weight:800;font-style:italic;color:var(--donate);line-height:1.45;margin:0 0 .6rem}
.news-ceo-attr{display:block;font-weight:700;font-size:.9rem;margin-bottom:1.2rem;opacity:.8}

.news-youth-section{background:linear-gradient(135deg,var(--pcard-3) 0%,var(--accent) 100%);padding:80px 0}
.news-youth-slider{margin-top:2rem;overflow:hidden;border-radius:var(--radius)}
.news-youth-track{display:flex;transition:transform .4s ease}
.news-youth-slide{min-width:100%;padding:2.5rem;background:rgba(255,255,255,.12);border-radius:var(--radius);text-align:center;border:1px solid rgba(255,255,255,.2)}
.news-youth-slide blockquote{font-size:1.25rem;font-style:italic;font-weight:700;color:#fff;margin:0 0 1rem;line-height:1.55}
.news-youth-slide cite{color:rgba(255,255,255,.75);font-weight:800;font-style:normal;letter-spacing:.06em;text-transform:uppercase;font-size:.85rem}
.news-youth-section .impact-prev,.news-youth-section .impact-next{background:rgba(255,255,255,.2);margin-top:.8rem}
.news-youth-section .impact-dot{background:rgba(255,255,255,.35)}
.news-youth-section .impact-dot.active{background:#fff}

.inequality-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:2rem 0}
.ineq-stat{background:var(--paper-soft);border-radius:var(--radius);padding:1.8rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.ineq-stat.is-visible{opacity:1;transform:none}
.ineq-num{font-size:2.4rem;font-weight:900;color:var(--donate)}
.ineq-label{font-size:.88rem;font-weight:700;color:rgba(11,20,8,.65);text-align:center}
@media(max-width:680px){.inequality-stats{grid-template-columns:1fr}}

.partner-spot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:2rem}
.partner-spot-card{background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.07);opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.partner-spot-card.is-visible{opacity:1;transform:none}
.partner-spot-card:hover{transform:translateY(-4px)}
.ps-icon{font-size:2rem;color:var(--donate);margin-bottom:.7rem}
.partner-spot-card h3{margin:0 0 .4rem}
.partner-spot-card p{margin:0;font-size:.9rem;opacity:.75}
@media(max-width:820px){
  .partner-spot-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:14px;padding-bottom:10px}
  .partner-spot-grid::-webkit-scrollbar{display:none}
  .partner-spot-card{flex:0 0 78%;scroll-snap-align:center}
}

/* News featured article cards */
.news-featured-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:2.5rem}
@media(max-width:680px){.news-featured-cards{grid-template-columns:1fr}}
.nfc{display:flex;flex-direction:column;border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.1);text-decoration:none;color:var(--ink);transition:transform .2s ease,box-shadow .2s ease}
.nfc:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.15)}
.nfc-img{height:200px;background-size:cover;background-position:center;position:relative}
.nfc-outlet{position:absolute;top:12px;left:12px;background:var(--donate);color:#fff;border-radius:999px;padding:.25rem .8rem;font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.nfc-body{padding:1.4rem;background:#fff;flex:1;display:flex;flex-direction:column;gap:.6rem}
.nfc-title{margin:0;font-weight:900;font-size:1rem;line-height:1.35;color:var(--ink)}
.nfc-desc{margin:0;font-size:.88rem;line-height:1.55;opacity:.72;flex:1}
.nfc-read{font-weight:800;font-size:.82rem;color:var(--donate);letter-spacing:.03em}

.news-civic-section{background:var(--ink);padding:80px 0}

.data-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:2rem}
.data-card{background:var(--paper-soft);border-radius:var(--radius);padding:2rem;opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.data-card.is-visible{opacity:1;transform:none}
.data-icon{font-size:2rem;color:var(--donate);margin-bottom:.7rem}
.data-card h3{margin:0 0 .4rem}
.data-card p{font-size:.9rem;opacity:.75;margin-bottom:1rem}

.video-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:2rem}
.video-card{border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.09);background:#fff;opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.video-card.is-visible{opacity:1;transform:none}
.video-thumb{aspect-ratio:16/9;background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center}
.vid-play-btn{background:rgba(255,255,255,.85);border:none;border-radius:50%;width:56px;height:56px;font-size:1.2rem;cursor:pointer;color:var(--donate);display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease}
.vid-play-btn:hover{background:#fff;transform:scale(1.12)}
.video-card h3{padding:.8rem 1rem .3rem;margin:0}
.video-card p{padding:0 1rem 1rem;margin:0;font-size:.88rem;opacity:.7}

.quicktakes-new{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:2rem}
.qt-new{background:var(--paper-soft);border-left:4px solid var(--donate);border-radius:0 var(--radius) var(--radius) 0;padding:1.4rem 1.4rem 1.2rem;opacity:0;transform:translateX(-16px);transition:opacity .5s ease,transform .5s ease}
.qt-new.is-visible{opacity:1;transform:none}
.qt-new i{font-size:1.3rem;margin-bottom:.5rem;display:block}
.qt-new p{margin:0;font-weight:700;line-height:1.5}

.news-partner-cta{background:linear-gradient(135deg,var(--donate) 0%,var(--pcard-1) 100%);padding:80px 0}
.npc-inner{display:flex;flex-wrap:wrap;gap:2.5rem;align-items:flex-start}
.npc-btns{display:flex;flex-wrap:wrap;gap:12px;align-self:flex-end}
@media(max-width:820px){.npc-inner{flex-direction:column}}

/* ===== EVENTS PAGE ===== */
.ev-hero{min-height:540px;display:flex;align-items:flex-end;position:relative}
.ev-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.35) 60%,transparent 100%)}
.ev-hero-inner{position:relative;z-index:1;padding-bottom:60px;padding-top:120px}
.ev-hero-inner h1{color:#fff;font-size:clamp(2rem,5vw,3.6rem);text-shadow:0 2px 12px rgba(0,0,0,.4);margin-bottom:.7rem}
.ev-hero-sub{color:rgba(255,255,255,.88);max-width:640px;font-size:1.05rem;line-height:1.65;margin-bottom:2rem}
.ev-hero-btns{display:flex;flex-wrap:wrap;gap:14px}
.btn-ghost-white{border-color:rgba(255,255,255,.7);color:#fff}
.btn-ghost-white:hover{background:rgba(255,255,255,.15)}

/* Gala postcard design */
.gala-card{margin-top:2rem}
.gala-envelope{display:flex;gap:2.5rem;align-items:flex-start;flex-wrap:wrap;padding:2.5rem;background:linear-gradient(135deg,#f9f5ff,#e8f9f7);border-radius:24px;box-shadow:0 4px 24px rgba(0,0,0,.1);margin-bottom:2rem}
.gala-postcards{display:flex;gap:-12px;flex-direction:column;gap:8px;width:220px;flex-shrink:0}
.gala-pc{border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.18);border:4px solid #fff}
.gala-pc img{width:100%;height:120px;object-fit:cover}
.gala-pc-1{transform:rotate(-3deg)}
.gala-pc-2{transform:rotate(1.5deg);z-index:1}
.gala-pc-3{transform:rotate(-1deg)}
.gala-letter{flex:1;background:#fff;border-radius:16px;padding:2.2rem 2rem;box-shadow:0 2px 16px rgba(0,0,0,.1);font-family:var(--font);position:relative;border-top:6px solid #f7931e}
.gala-script{font-size:1.6rem;color:#f7931e;font-style:italic;font-weight:700;margin-bottom:.4rem}
.gala-title{font-size:1.4rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em;line-height:1.2;margin:0 0 .6rem;color:var(--ink)}
.gala-title em{color:#f7931e;font-style:italic;font-family:Georgia,serif;text-transform:none}
.gala-sub{color:rgba(11,20,8,.6);font-size:.95rem;margin-bottom:1.4rem}
.gala-details{display:flex;flex-direction:column;gap:.7rem}
.gala-detail{display:flex;align-items:flex-start;gap:.7rem;font-size:.95rem;font-weight:600}
.gala-detail i{color:#f7931e;margin-top:3px;width:16px}
.gala-progress-wrap{margin-bottom:1.5rem}
.gala-progress-label{font-weight:800;margin-bottom:.5rem;font-size:1rem}
.gala-progress-bar{background:var(--line);border-radius:999px;height:14px;overflow:hidden}
.gala-progress-fill{background:linear-gradient(to right,var(--donate),var(--pcard-1));height:100%;border-radius:999px;transition:width 1.2s cubic-bezier(.34,1.4,.64,1)}
.gala-btns{display:flex;flex-wrap:wrap;gap:12px}
@media(max-width:820px){.gala-envelope{flex-direction:column}.gala-postcards{flex-direction:row;width:100%}.gala-pc img{height:90px}}

/* Why attend */
.why-attend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:2.5rem;text-align:left}
.why-item{display:flex;align-items:center;gap:12px;background:#fff;border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:0 2px 8px rgba(0,0,0,.07);font-weight:700;font-size:1rem;opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease}
.why-item.is-visible{opacity:1;transform:none}
.why-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.1)}
.why-spark{color:#f0b429;font-size:1.3rem;flex-shrink:0}

/* Sponsor section */
.ev-sponsor-section{background:var(--ink);padding:80px 0}
.sponsor-benefits{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:2rem 0}
.sponsor-benefit{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:1rem;opacity:0;transform:translateX(-16px);transition:opacity .4s ease,transform .4s ease}
.sponsor-benefit.is-visible{opacity:1;transform:none}
.sponsor-benefit i{color:var(--pcard-1);font-size:1.1rem}
.sponsor-btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:2rem}

/* Sponsorship grid */
.sponsor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:2rem}
@media(max-width:820px){.sponsor-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.sponsor-grid{grid-template-columns:1fr}}
.sponsor-card{background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;border-top:5px solid var(--sc-color);box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;gap:1rem;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.sponsor-card.is-visible{opacity:1;transform:none}
.sponsor-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.12)}
.sc-featured{background:linear-gradient(135deg,#fff8ee,#fff)}
.sc-level{font-weight:900;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;color:var(--sc-color)}
.sc-amt{font-size:1.8rem;font-weight:900;color:var(--ink)}
@media(max-width:820px){
  .sponsor-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:14px;padding-bottom:10px}
  .sponsor-grid::-webkit-scrollbar{display:none}
  .sponsor-card{flex:0 0 75%;scroll-snap-align:center}
}

/* Sponsor benefit flip cards */
.spons-flip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:2.5rem}
@media(max-width:1024px){.spons-flip-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.spons-flip-grid{grid-template-columns:repeat(2,1fr)}}
.spons-flip-card{perspective:900px;height:140px;cursor:pointer}
.spons-flip-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d}
.spons-flip-card:hover .spons-flip-inner,
.spons-flip-card:focus .spons-flip-inner,
.spons-flip-card.flipped .spons-flip-inner{transform:rotateY(180deg)}
.spons-flip-front,.spons-flip-back{
  position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  padding:1rem;text-align:center;flex-direction:column;gap:.6rem;
}
.spons-flip-front{background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.3)}
.spons-flip-front i{font-size:1.6rem;color:var(--pcard-1)}
.spons-flip-front span{font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:#fff;line-height:1.25}
.spons-flip-back{background:#fff;color:var(--ink);transform:rotateY(180deg)}
.spons-flip-back p{margin:0;font-size:.82rem;line-height:1.45;font-weight:600;color:var(--ink)}

/* Gallery scroll */
.gallery-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.gallery-scroll::-webkit-scrollbar{height:6px}
.gallery-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.gallery-scroll img{width:300px;height:220px;object-fit:cover;border-radius:var(--radius);flex-shrink:0;scroll-snap-align:start}

/* Bring your team */
.team-events-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:1rem;text-align:left}
.te-item{background:var(--paper-soft);border-radius:var(--radius);padding:1rem 1.2rem;font-weight:700;display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.te-item.is-visible{opacity:1;transform:none}
.te-item i{color:var(--donate)}

/* Final CTA */
.ev-final-cta{position:relative;background-size:cover;background-position:center;padding:100px 24px;text-align:center}
.ev-final-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72)}
.ev-final-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.ev-final-inner h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1rem}
.ev-final-inner p{color:rgba(255,255,255,.88);font-size:1.05rem;line-height:1.7;margin-bottom:2rem}
.ev-final-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}


/* ===== GET INVOLVED PAGE ===== */
.gi-hero{min-height:520px;display:flex;align-items:flex-end;position:relative;background-size:cover;background-position:center}
.gi-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.3) 60%,transparent 100%)}
.gi-hero-inner{position:relative;z-index:1;padding-bottom:60px;padding-top:120px}
.gi-hero-inner h1{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4);margin-bottom:.5rem}
.gi-hero-sub{color:rgba(255,255,255,.85);font-size:1.05rem;line-height:1.6;margin:0}

.gi-join-section{background:linear-gradient(135deg,#f9f5ff,#e8f9f7)}
.gi-join-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* Quiz */
.quiz-wrap{background:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:0 2px 16px rgba(0,0,0,.08);max-width:680px}
.quiz-step{display:none}
.quiz-step.active{display:block}
.quiz-q{font-size:1.25rem;font-weight:800;margin:0 0 1.5rem;color:var(--donate)}
.quiz-opts{display:flex;flex-direction:column;gap:12px}
.quiz-opt{background:var(--paper-soft);border:2px solid var(--line);border-radius:999px;padding:.85rem 1.5rem;font-family:var(--font);font-weight:700;font-size:1rem;cursor:pointer;text-align:left;transition:all .2s ease;color:var(--ink)}
.quiz-opt:hover{background:var(--donate);color:#fff;border-color:var(--donate);transform:translateX(6px)}
.quiz-progress{display:flex;gap:8px;margin-top:1.5rem;justify-content:center}
.qp-dot{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .2s}
.qp-dot.active{background:var(--donate)}
.quiz-result{padding-top:.5rem}
.qr-inner{background:linear-gradient(135deg,#f9f5ff,#e8f9f7);border-radius:var(--radius);padding:1.8rem;margin-bottom:1.2rem}
.qr-inner h3{margin:0 0 .5rem;color:var(--donate)}
.qr-inner p{margin:0 0 1.2rem}

/* Shared list style */
.gi-list{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.6rem}
.gi-list li{display:flex;align-items:center;gap:.7rem;font-weight:600}
.gi-list i{color:var(--pcard-1);font-size:.9rem}

/* Volunteer cards */
.volunteer-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin:2rem 0}
.vol-card{background:#fff;border-radius:var(--radius);padding:2rem 1.4rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.07);opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.vol-card.is-visible{opacity:1;transform:none}
.vol-card:hover{transform:translateY(-4px)}
.vol-icon{font-size:2rem;color:var(--donate);display:block;margin-bottom:.7rem}
.vol-card h3{margin:0 0 .4rem}
.vol-card p{margin:0;font-size:.9rem;opacity:.75}

/* Feature split reversed */
.feature-split-rev{flex-direction:row-reverse}
@media(max-width:820px){.feature-split-rev{flex-direction:column}}

/* Community grid */
.gi-community-section{background:var(--paper-soft)}
.gi-community-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:2rem}
.gi-comm-item{background:#fff;border-radius:var(--radius);padding:1rem 1.3rem;display:flex;align-items:center;gap:12px;font-weight:700;box-shadow:0 1px 6px rgba(0,0,0,.06);opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.gi-comm-item.is-visible{opacity:1;transform:none}
.gi-comm-item i{color:var(--donate);font-size:1.1rem;width:20px;text-align:center}
.gi-comm-btns{display:flex;flex-wrap:wrap;gap:12px}

/* Corp experiences */
.corp-exp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:2rem 0}
.corp-exp{background:var(--paper-soft);border-radius:var(--radius);padding:1.2rem 1.3rem;display:flex;align-items:center;gap:12px;font-weight:700;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.corp-exp.is-visible{opacity:1;transform:none}
.corp-exp i{color:var(--donate);font-size:1.1rem;width:20px;text-align:center}

/* People / Why Join slider */
.gi-people-section{background:var(--donate);padding:88px 0}
.why-join-slider{overflow:hidden;border-radius:var(--radius);margin-top:1rem}
.why-join-track{display:flex;transition:transform .4s ease}
.wj-slide{min-width:100%;display:grid;grid-template-columns:260px 1fr;background:rgba(255,255,255,.1);border-radius:var(--radius);border:1px solid rgba(255,255,255,.2);overflow:hidden}
@media(max-width:680px){.wj-slide{grid-template-columns:1fr}}
.wj-photo{background-size:cover;background-position:center;min-height:240px}
@media(max-width:680px){.wj-photo{height:180px}}
.wj-content{padding:2.2rem;display:flex;flex-direction:column;justify-content:center;gap:.8rem}
.wj-content blockquote{font-size:1.15rem;font-style:italic;font-weight:700;color:#fff;margin:0;line-height:1.55}
.wj-content cite{color:rgba(255,255,255,.7);font-style:normal;font-weight:800;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase}
.wj-controls{margin-top:1.2rem;justify-content:center}
.gi-people-section .impact-prev,.gi-people-section .impact-next{background:rgba(255,255,255,.2)}
.gi-people-section .impact-dot{background:rgba(255,255,255,.35)}
.gi-people-section .impact-dot.active{background:#fff}

/* Open Opportunities */
.opps-list{display:flex;flex-direction:column;gap:20px;margin-top:2rem}
.opp-item{background:#fff;border-radius:var(--radius);padding:1.8rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;box-shadow:0 2px 12px rgba(0,0,0,.07);border-left:5px solid var(--donate);opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.opp-item.is-visible{opacity:1;transform:none}
.opp-info{flex:1}
.opp-tag{background:var(--donate);color:#fff;border-radius:999px;padding:.2rem .75rem;font-size:.75rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;display:inline-block;margin-bottom:.5rem}
.opp-info h3{margin:0 0 .3rem}
.opp-info p{margin:0;font-size:.9rem;opacity:.75}
.opp-btns{display:flex;flex-wrap:wrap;gap:10px}

/* Get Involved final CTA */
.gi-final-cta{position:relative;background-size:cover;background-position:center;padding:100px 24px;text-align:center}
.gi-final-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.gi-final-inner{position:relative;z-index:1;max-width:840px;margin:0 auto}
.gi-final-inner h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:.8rem}
.gi-final-inner p{color:rgba(255,255,255,.88);font-size:1.05rem;line-height:1.7;margin-bottom:2rem}
.gi-final-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}


/* ===== GET INVOLVED v2 ===== */

/* Join the Movement */
.gi-join-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
@media(max-width:820px){.gi-join-grid{grid-template-columns:1fr}}
.gi-join-btns{display:flex;flex-direction:column;gap:14px}
.gi-join-btn{text-align:center;font-size:1rem!important;padding:.9rem 1.8rem!important}
.gi-btn-purple{background:var(--donate);color:#fff}
.gi-btn-teal{background:var(--pcard-1);color:#fff}
.gi-btn-orange{background:var(--pcard-3);color:#fff}
.gi-btn-light{background:var(--paper-soft);color:var(--ink);border:2px solid var(--line)}
.gi-btn-light:hover{background:var(--ink);color:#fff}

/* Pathway finder */
.pathway-finder{max-width:780px}
.pathway-options{display:flex;flex-wrap:wrap;gap:12px}
.pathway-btn{
  background:#fff;border:2px solid var(--line);border-radius:var(--radius);
  padding:.75rem 1.3rem;font-family:var(--font);font-weight:700;font-size:.95rem;
  cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;color:var(--ink);
}
.pathway-btn:hover{background:var(--donate);color:#fff;border-color:var(--donate);transform:translateY(-2px)}
.pb-ic{display:inline-flex;align-items:center;margin-right:8px;vertical-align:-3px}
.pb-ic svg{display:block}
.li-ic{display:inline-flex;align-items:center;margin-right:10px;vertical-align:-3px;color:var(--donate)}
.li-ic svg{display:block}
.ctag-ic{display:inline-flex;align-items:center;margin-right:6px;vertical-align:-2px}
.ctag-ic svg{display:block}
.pathway-back{background:none;border:none;cursor:pointer;font-weight:700;color:var(--donate);font-family:var(--font);font-size:.95rem;padding:0 0 1rem;display:flex;align-items:center;gap:6px}
.pr-box{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:0 2px 16px rgba(0,0,0,.08)}
.pr-box h3{margin:0 0 .5rem;color:var(--donate)}
.pr-box p{margin:0 0 1.5rem}
.pr-btns{display:flex;flex-wrap:wrap;gap:12px}

/* Artistic Coach two-col */
.coach-two-col{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:1.5rem 0}
@media(max-width:680px){.coach-two-col{grid-template-columns:1fr}}
.coach-col-head{font-weight:900;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--donate);margin:0 0 .8rem}
.coach-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}
.coach-list li{font-weight:600;font-size:1rem}

/* Career / Workshop tags */
.career-two-col,.workshop-two-col,.partner-two-col{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:0 0 2rem}
@media(max-width:680px){.career-two-col,.workshop-two-col,.partner-two-col{grid-template-columns:1fr}}
.career-col-head{font-weight:900;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--donate);margin:0 0 .8rem}
.career-tags{display:flex;flex-wrap:wrap;gap:8px}
.ctag{background:var(--paper-soft);border:1px solid var(--line);border-radius:999px;padding:.35rem .9rem;font-weight:700;font-size:.85rem;color:var(--ink);display:inline-flex;align-items:center;gap:5px}
.ctag-teal{background:rgba(59,184,167,.12);border-color:var(--pcard-1);color:#2a867a}
.ctag-orange{background:rgba(247,147,30,.12);border-color:var(--pcard-3);color:#b36216}

/* Volunteer roles grid */
.vol-roles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.vol-role{background:var(--paper-soft);border-radius:var(--radius);padding:1rem 1.3rem;display:flex;align-items:center;gap:10px;font-weight:700;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.vol-role.is-visible{opacity:1;transform:none}
.vol-role i{color:var(--donate);font-size:1.1rem;width:20px;text-align:center}
.vol-role:hover{background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08)}

/* Corporate section */
.gi-corporate-section{background:var(--ink);padding:88px 0}
.corp-offer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.corp-offer-item{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:1.1rem 1.3rem;display:flex;align-items:center;gap:10px;font-weight:700;color:#fff;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.corp-offer-item.is-visible{opacity:1;transform:none}
.corp-offer-item i{color:var(--pcard-1);font-size:1.1rem;width:20px}
.corp-offer-item:hover{background:rgba(255,255,255,.15)}

/* People tabs */
.people-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2rem;border-bottom:2px solid var(--line);padding-bottom:0}
.ptab{background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:.7rem 1.2rem;font-family:var(--font);font-weight:800;font-size:.88rem;cursor:pointer;color:rgba(11,20,8,.55);letter-spacing:.04em;text-transform:uppercase;transition:all .2s ease}
.ptab:hover{color:var(--donate)}
.ptab.active{color:var(--donate);border-bottom-color:var(--donate)}
.people-panel{display:none}
.people-panel.active{display:block}
.wj-slide2{display:grid;grid-template-columns:320px 1fr;border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 20px rgba(0,0,0,.1)}
@media(max-width:820px){.wj-slide2{grid-template-columns:1fr}}
.wj-photo2{background-size:cover;background-position:center;min-height:300px}
@media(max-width:820px){.wj-photo2{height:200px}}
.wj-content2{padding:2.5rem;background:var(--paper-soft);display:flex;flex-direction:column;justify-content:center;gap:1rem}
.wj-content2 blockquote{font-size:1.2rem;font-style:italic;font-weight:800;color:var(--donate);margin:0;line-height:1.5}
.wj-content2 cite{font-style:normal;font-weight:900;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(11,20,8,.55)}
.wj-content2 p{margin:0;font-size:.95rem;line-height:1.6;opacity:.8}

/* Build the City final CTA */
.gi-you-can{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem .8rem;margin:1rem 0 1.5rem}
.gi-you-can span{color:rgba(255,255,255,.9);font-size:1.1rem;font-weight:700}
.gi-you-can span::after{content:" "}


/* ===== SUPPORT PAGE ===== */

/* Hero */
.sp-hero{min-height:580px;display:flex;align-items:center;position:relative;background-size:cover;background-position:center}
.sp-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(121,102,173,.82) 0%,rgba(0,0,0,.55) 100%)}
.sp-hero-inner{position:relative;z-index:1;padding:80px 0}
.sp-hero-inner h1{color:#fff;font-size:clamp(2.2rem,5vw,3.8rem);text-shadow:0 2px 16px rgba(0,0,0,.3);margin-bottom:.5rem}
.sp-hero-sub{color:#fff;font-size:1.3rem;margin:.5rem 0 .4rem}
.sp-hero-body{color:rgba(255,255,255,.88);font-size:1.05rem;max-width:580px;line-height:1.65;margin-bottom:2rem}
.sp-hero-btns{display:flex;flex-wrap:wrap;gap:14px}

/* Progress meter */
.sp-progress-section{background:var(--paper-soft)}
.sp-campaign-name{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1.5rem}
.sp-evo{color:var(--donate)}
.sp-art{color:var(--pcard-1)}
.sp-progress-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 4px 24px rgba(0,0,0,.1)}
.sp-progress-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:2rem}
@media(max-width:680px){.sp-progress-stats{grid-template-columns:repeat(2,1fr)}}
.sp-pstat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.3rem}
.sp-pnum{font-size:clamp(1.4rem,3vw,2rem);font-weight:900;color:var(--donate)}
.sp-pnum-gray{color:rgba(11,20,8,.4)}
.sp-pnum-teal{color:var(--pcard-1)}
.sp-pnum-sm{font-size:1rem}
.sp-plabel{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.6}
.sp-pstat-raised .sp-pnum{color:var(--donate)}
.sp-bar-wrap{margin-bottom:2rem}
.sp-bar{background:var(--line);border-radius:999px;height:18px;overflow:hidden;margin-bottom:.5rem}
.sp-bar-fill{height:100%;background:linear-gradient(to right,var(--donate),var(--pcard-1));border-radius:999px;transition:width 1.4s cubic-bezier(.34,1.4,.64,1)}
.sp-bar-labels{display:flex;justify-content:space-between;font-size:.78rem;font-weight:700;opacity:.55}
.sp-progress-btns{display:flex;flex-wrap:wrap;gap:12px}

/* Why This Matters */
.sp-why-section{background:var(--ink);padding:88px 0}
.sp-challenge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin:2rem 0}
.sp-challenge-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:1.2rem 1.4rem;display:flex;align-items:flex-start;gap:12px;color:rgba(255,255,255,.88);font-weight:600;font-size:.95rem;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.sp-challenge-item.is-visible{opacity:1;transform:none}
.sp-challenge-item i{color:#ff7373;margin-top:2px;flex-shrink:0}
.sp-challenge-response{background:rgba(59,184,167,.15);border-color:var(--pcard-1)}
.sp-challenge-response i{color:var(--pcard-1)}
.sp-why-conclusion{color:#fff;font-size:1.5rem;font-weight:900;text-align:center;margin-top:2.5rem;font-style:italic}

/* What Your Gift Makes Possible */
.sp-impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:2.5rem}
@media(max-width:820px){.sp-impact-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.sp-impact-grid{grid-template-columns:1fr}}
.sp-impact-card{background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;border-top:5px solid var(--ic-color);box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;gap:1rem;text-align:center;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.sp-impact-card.is-visible{opacity:1;transform:none}
.sp-impact-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.12)}
.sp-ic-featured{background:linear-gradient(135deg,#f9f5ff,#fff);border-width:6px}
.sp-ic-amt{font-size:2rem;font-weight:900;color:var(--ic-color)}
.sp-ic-desc{font-size:.95rem;color:rgba(11,20,8,.7);flex:1}
.sp-ic-btn{background:var(--ic-color);color:#fff;border-radius:999px;padding:.65rem 1.4rem;font-size:.9rem;width:100%;cursor:pointer;border:none;font-family:var(--font);font-weight:800;transition:opacity .15s}
.sp-ic-btn:hover{opacity:.88}
.sp-ic-btn-accent{background:var(--accent)!important}

/* Meet The Movement */
.movement-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2rem;border-bottom:2px solid var(--line);padding-bottom:0}
.mvtab{background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:.7rem 1.2rem;font-family:var(--font);font-weight:800;font-size:.85rem;cursor:pointer;color:rgba(11,20,8,.5);letter-spacing:.04em;text-transform:uppercase;transition:all .2s}
.mvtab:hover{color:var(--donate)}
.mvtab.active{color:var(--donate);border-bottom-color:var(--donate)}
.mvpanel{display:none}
.mvpanel.active{display:block}
.mv-story-card{display:grid;grid-template-columns:280px 1fr;border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.09)}
@media(max-width:820px){.mv-story-card{grid-template-columns:1fr}}
.mv-story-photo{background-size:cover;background-position:center;min-height:280px;position:relative}
@media(max-width:820px){.mv-story-photo{height:200px}}
.mv-story-name{position:absolute;bottom:12px;left:12px;background:var(--donate);color:#fff;border-radius:999px;padding:.3rem .9rem;font-weight:800;font-size:.82rem}
.mv-story-content{padding:2.2rem;background:var(--paper-soft);display:flex;flex-direction:column;gap:.9rem}
.mv-story-content blockquote{font-size:1.15rem;font-style:italic;font-weight:800;color:var(--donate);margin:0;line-height:1.45}
.mv-story-content cite{font-style:normal;font-weight:900;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;opacity:.6}
.mv-story-content p{margin:0;font-size:.95rem;line-height:1.6;opacity:.8}

/* Investment Levels */
.sp-invest-section{background:var(--paper-soft)}
.invest-levels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:2.5rem}
.il-card{background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;border-top:5px solid var(--il-color);box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;gap:.8rem;position:relative;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}
.il-card.is-visible{opacity:1;transform:none}
.il-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.12)}
.il-card-featured{background:linear-gradient(135deg,#fff8ee,#fff);border-width:6px;box-shadow:0 4px 24px rgba(247,147,30,.2)}
.il-badge{position:absolute;top:-12px;right:16px;background:var(--pcard-3);color:#fff;border-radius:999px;padding:.25rem .85rem;font-size:.72rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}
.il-icon{font-size:1.8rem;color:var(--il-color)}
.il-title{font-weight:900;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--il-color)}
.il-range{font-size:1.5rem;font-weight:900;color:var(--ink)}
.il-tagline{font-style:italic;font-size:.92rem;color:rgba(11,20,8,.6)}
.il-benefits{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;flex:1}
.il-benefits li{font-size:.88rem;font-weight:600;color:rgba(11,20,8,.75);padding-left:1.1em;position:relative}
.il-benefits li::before{content:"✓";position:absolute;left:0;color:var(--il-color);font-weight:900}
.il-btn{background:var(--il-color);color:#fff;border-radius:999px;padding:.65rem 1.4rem;font-size:.88rem;width:100%;cursor:pointer;border:none;font-family:var(--font);font-weight:800;transition:opacity .15s}
.il-btn:hover{opacity:.88}
.il-btn-accent{background:var(--accent)!important}

/* Corporate section */
.sp-corporate-section{background:var(--ink);padding:88px 0}
.sp-corp-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
@media(max-width:820px){.sp-corp-grid{grid-template-columns:1fr}}
.sp-corp-list{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:.7rem}
.sp-corp-list li{color:rgba(255,255,255,.88);font-weight:600;display:flex;align-items:center;gap:10px}
.sp-corp-list i{color:var(--pcard-1)}
.sp-corp-btns{display:flex;flex-wrap:wrap;gap:12px}
.sp-corp-logos{overflow:hidden}
.sp-logo-marquee{display:flex;gap:16px;overflow:hidden;flex-wrap:wrap}
.sp-logo-marquee .logo img{max-height:36px;filter:brightness(0) invert(1);opacity:.6}
.sp-logo-marquee .logo-text{color:rgba(255,255,255,.5);font-weight:700;font-size:.85rem}

/* Thermometer */
.sp-thermo-section{background:linear-gradient(135deg,#f9f5ff,#e8f9f7)}
.sp-thermo-pct{color:var(--donate)}
.sp-thermo-wrap{display:flex;gap:3rem;align-items:flex-end;justify-content:center;height:280px;position:relative}
.sp-thermo-tube{width:60px;background:rgba(11,20,8,.08);border-radius:30px 30px 0 0;position:relative;height:100%;overflow:visible;flex-shrink:0}
.sp-thermo-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,var(--donate),var(--pcard-1));border-radius:30px 30px 0 0;transition:height 1.6s cubic-bezier(.34,1.4,.64,1)}
.sp-thermo-bulb{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);width:40px;height:40px;background:var(--donate);border-radius:50%;border:4px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.sp-thermo-labels{display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:0 0 0 1rem;position:relative}
.sp-tlabel{font-weight:800;font-size:.88rem;color:rgba(11,20,8,.6);position:absolute;left:0;white-space:nowrap}
.sp-tlabel-current{color:var(--donate);font-size:1rem}

/* Wall of Belief */
.sp-wall-section{background:var(--paper)}
.wall-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2rem;border-bottom:2px solid var(--line)}
.wtab{background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:.65rem 1.1rem;font-family:var(--font);font-weight:800;font-size:.82rem;cursor:pointer;color:rgba(11,20,8,.5);letter-spacing:.04em;text-transform:uppercase;transition:all .2s}
.wtab:hover{color:var(--donate)}
.wtab.active{color:var(--donate);border-bottom-color:var(--donate)}
.wpanel{display:none;animation:fadeIn .3s ease}
.wpanel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.wall-names{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:1.5rem}
.wall-names span,.wall-name-tag{background:var(--paper-soft);border:1px solid var(--line);border-radius:999px;padding:.4rem 1.1rem;font-weight:700;font-size:.88rem}
.wall-cta{margin-top:1rem;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-weight:700;opacity:.7}

/* Roadmap */
.sp-future-section{background:var(--paper-soft)}
.sp-roadmap{position:relative;padding-left:140px;max-width:760px;margin:0 auto}
.sp-roadmap::before{content:"";position:absolute;left:116px;top:12px;bottom:12px;width:4px;background:linear-gradient(to bottom,var(--donate),var(--pcard-1));border-radius:2px}
.sp-rm-item{display:flex;align-items:flex-start;margin-bottom:3rem;position:relative;opacity:0;transform:translateX(-20px);transition:opacity .5s ease,transform .5s ease}
.sp-rm-item.is-visible{opacity:1;transform:none}
.sp-rm-final{margin-bottom:0}
.sp-rm-year{position:absolute;left:-140px;top:10px;font-weight:900;font-size:1.1rem;color:var(--donate);width:110px;text-align:right;padding-right:8px}
.sp-rm-dot{position:absolute;left:-33px;top:10px;width:18px;height:18px;border-radius:50%;background:var(--donate);border:4px solid var(--paper-soft);box-shadow:0 0 0 3px var(--donate);flex-shrink:0;z-index:1}
.sp-rm-content{background:#fff;border-radius:var(--radius);padding:1.4rem 1.6rem;box-shadow:0 2px 12px rgba(0,0,0,.07);flex:1}
.sp-rm-content h3{margin:0 0 .4rem;font-size:1.1rem;color:var(--donate)}
.sp-rm-content p{margin:0;font-size:.92rem;opacity:.75;line-height:1.55}

/* Final CTA */
.sp-final-cta{position:relative;background-size:cover;background-position:center;padding:100px 24px;text-align:center}
.sp-final-overlay{position:absolute;inset:0;background:rgba(0,0,0,.58)}
.sp-final-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.sp-final-inner h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1.5rem;letter-spacing:.03em}
.sp-commitments{margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.2rem}
.sp-commitments p{color:rgba(255,255,255,.9);font-size:1.1rem;font-weight:600;margin:0}
.sp-final-tagline{color:rgba(255,255,255,.88);font-size:1.15rem;font-weight:700;margin-bottom:2.5rem}
.sp-final-tagline strong{color:var(--pcard-1)}
.sp-final-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}


/* ===== ZIG-ZAG HORIZONTAL TIMELINE (static, compact) ===== */
.zztl-outer{
  width:100%;overflow-x:auto;overflow-y:visible;
  padding:0 24px;
  scrollbar-width:thin;
  scrollbar-color:var(--line) transparent;
}
.zztl-outer::-webkit-scrollbar{height:4px}
.zztl-outer::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}

.zztl-track{
  display:flex;
  align-items:center;
  min-height:200px;          /* compact total height */
  padding:8px 40px;
  position:relative;
  width:max-content;
}

/* Horizontal centre line */
.zztl-track::before{
  content:"";
  position:absolute;
  left:0;right:0;
  top:50%;transform:translateY(-50%);
  height:4px;
  background:linear-gradient(to right,var(--donate),var(--pcard-1),var(--pcard-3),var(--accent),var(--donate));
  border-radius:2px;
  z-index:0;
}

/* Each stop — sits centered on the line */
.zztl-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:120px;
  flex-shrink:0;
  position:relative;
  z-index:1;
  margin:0 6px;
}

/* above: card on top, stem, then node (dot+time) right on the line */
.zztl-above{
  justify-content:center;
}
/* below: node (time+dot) on the line, stem, card below */
.zztl-below{
  justify-content:center;
}

.zztl-card{
  background:#fff;
  border-radius:8px;
  padding:.45rem .65rem;
  font-weight:700;
  font-size:.75rem;
  text-align:center;
  box-shadow:0 2px 8px rgba(0,0,0,.1);
  border-top:3px solid var(--zc);
  line-height:1.3;
  width:112px;
}
.zztl-below .zztl-card{
  border-top:none;
  border-bottom:3px solid var(--zc);
}

.zztl-stem{
  width:2px;
  height:16px;         /* short stem so section is compact */
  background:var(--zc);
  flex-shrink:0;
}

/* node wraps dot + time so they sit together on the line */
.zztl-node{
  display:flex;
  flex-direction:column;
  align-items:center;
  position:relative;
  z-index:2;
}

.zztl-dot{
  width:14px;height:14px;
  border-radius:50%;
  background:var(--zc);
  border:3px solid #fff;
  box-shadow:0 0 0 2px var(--zc);
  flex-shrink:0;
}

.zztl-time{
  font-weight:900;
  font-size:.68rem;
  color:var(--zc);
  white-space:nowrap;
  letter-spacing:.03em;
  line-height:1.2;
  /* time sits just outside the dot, not overlapping */
  padding:2px 0;
}

/* ABOVE: card → stem → node(dot+time) */
.zztl-above .zztl-card{order:1}
.zztl-above .zztl-stem{order:2}
.zztl-above .zztl-node{order:3}
/* dot first, then time below */
.zztl-above .zztl-dot{order:1}
.zztl-above .zztl-time{order:2}

/* BELOW: node(time+dot) → stem → card */
.zztl-below .zztl-node{order:1}
.zztl-below .zztl-stem{order:2}
.zztl-below .zztl-card{order:3}
/* time first, then dot */
.zztl-below .zztl-time{order:1}
.zztl-below .zztl-dot{order:2}


/* ===== FORM POPUP MODAL (Register Today) ===== */
.form-modal{
  position:fixed;inset:0;z-index:9000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.7);padding:20px;
}
.form-modal[hidden]{display:none}
.form-modal-inner{
  position:relative;width:min(92vw,720px);max-height:92vh;
  background:#fff;border-radius:20px;overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.5);
  display:flex;flex-direction:column;
  animation:formPop .25s cubic-bezier(.34,1.4,.64,1);
}
@keyframes formPop{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}
.form-modal-close{
  position:absolute;top:12px;right:14px;z-index:10;
  background:var(--accent);color:#fff;border:none;border-radius:50%;
  width:38px;height:38px;font-size:1.4rem;font-weight:900;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s ease;
}
.form-modal-close:hover{transform:scale(1.1)}
.form-modal-head{
  padding:1.6rem 1.8rem 1rem;
  background:linear-gradient(135deg,var(--donate),var(--pcard-1));
  color:#fff;
}
.form-modal-head h3{margin:0 0 .3rem;color:#fff;font-size:1.3rem;padding-right:2rem}
.form-modal-head p{margin:0;color:rgba(255,255,255,.9);font-size:.92rem}
.form-modal-body{flex:1;overflow:hidden;background:#f7f7f7}
.form-modal-body iframe{width:100%;height:70vh;border:none;display:block}


/* ===== SATURDAY ARTS REGISTRATION FORM ===== */
.reg-modal-inner{width:min(94vw,640px);max-height:94vh}
.reg-modal-body{overflow-y:auto;padding:1.5rem 1.8rem 2rem;background:#fff}
.reg-info{background:var(--paper-soft);border-radius:12px;padding:1rem 1.2rem;margin-bottom:1.2rem}
.reg-info ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.reg-info li{font-size:.88rem;color:var(--ink);display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.reg-info i{color:var(--donate);margin-top:3px;flex-shrink:0}

/* Document buttons row */
.reg-docs{margin-bottom:1.5rem}
.reg-docs-label{display:block;font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(11,20,8,.6);margin-bottom:.6rem}
.reg-docs-row{display:flex;flex-wrap:nowrap;gap:7px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.reg-doc-btn{
  flex:0 0 auto;
  background:var(--donate);color:#fff;
  border-radius:999px;
  padding:.4rem .8rem;
  font-size:.72rem;font-weight:700;
  white-space:nowrap;
  text-decoration:none;
  transition:opacity .15s,transform .15s;
}
.reg-doc-btn:hover{opacity:.85;transform:translateY(-1px)}
.reg-docs-note{display:block;font-size:.72rem;font-style:italic;color:rgba(11,20,8,.5);margin-top:.5rem}

/* Form fields */
.reg-form{display:flex;flex-direction:column;gap:1rem}
.reg-field{display:flex;flex-direction:column;gap:.35rem}
.reg-field label{font-weight:700;font-size:.85rem;color:var(--ink)}
.reg-field .req{color:var(--accent)}
.reg-field input,.reg-field select{
  font-family:var(--font);
  font-size:.95rem;
  padding:.7rem .9rem;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:#fff;
  color:var(--ink);
  transition:border-color .15s;
}
.reg-field input:focus,.reg-field select:focus{outline:none;border-color:var(--donate)}
.reg-submit{margin-top:.5rem;cursor:pointer}
.reg-submit:disabled{opacity:.6;cursor:default}
.reg-form-status{padding:.9rem 1.1rem;border-radius:10px;font-size:.9rem;font-weight:600;line-height:1.45}
.reg-status-success{background:rgba(59,184,167,.15);color:var(--dark-teal,#2a867a);border:1px solid var(--pcard-1)}
.reg-status-error{background:rgba(255,115,115,.12);color:#cc5a5a;border:1px solid var(--accent)}


/* ===== Monday.com embed in registration modal ===== */
.reg-embed-wrap{
  border-radius:12px;
  overflow:hidden;
  box-shadow:5px 5px 56px 0px rgba(0,0,0,0.25);
  background:#fff;
}
.reg-embed-wrap iframe{
  width:100%;
  height:70vh;
  min-height:500px;
  border:0;
  display:block;
}
@media (max-width:600px){
  .reg-embed-wrap iframe{height:75vh;min-height:440px}
}

/* ===== CEO WORKSHOP BLOCK ===== */
.ceo-workshop-block{margin-top:3rem;background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:0 2px 16px rgba(0,0,0,.08);border-left:5px solid var(--donate)}
.ceo-workshop-eyebrow{font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.5rem}
.ceo-workshop-block h3{margin:0 0 .7rem;font-size:1.3rem;color:var(--donate)}
.ceo-workshop-block p{margin:0 0 1.5rem;font-size:.95rem;opacity:.8;line-height:1.6}
.ceo-topics{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.5rem}
.ceo-topic{background:var(--paper-soft);border:1.5px solid var(--line);border-radius:999px;padding:.45rem 1rem;font-size:.8rem;font-weight:700;cursor:default;display:flex;align-items:center;gap:7px;transition:background .2s,border-color .2s,color .2s}
.ceo-topic:hover{background:var(--donate);border-color:var(--donate);color:#fff}
.ceo-topic i{color:var(--donate);font-size:.85rem}
.ceo-topic:hover i{color:#fff}

/* ===== CORPORATE DYNAMIC CARDS ===== */
.corp-dynamic-card{background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:1.6rem 1.4rem;border-top:4px solid var(--cdc);opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease,background .2s ease,box-shadow .2s ease}
.corp-dynamic-card.is-visible{opacity:1;transform:none}
.corp-dynamic-card:hover{background:rgba(255,255,255,.15);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.cdc-icon{font-size:2rem;color:var(--cdc);margin-bottom:.8rem}
.corp-dynamic-card h4{margin:0 0 .5rem;color:#fff;font-size:1rem}
.corp-dynamic-card p{margin:0;font-size:.85rem;color:rgba(255,255,255,.8);line-height:1.5}

/* ===== DYNAMIC ANIMATED BULLET LISTS ===== */
.anim-list{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.7rem}
.anim-list li{display:flex;align-items:center;gap:12px;font-weight:600;font-size:1rem;opacity:0;transform:translateX(-20px);transition:opacity .4s ease,transform .4s ease,color .2s}
.anim-list li.is-visible{opacity:1;transform:none}
.anim-list li:hover{color:var(--accent)}
.anim-list li i{color:var(--pcard-1);font-size:1.1rem;transition:color .2s,transform .2s;flex-shrink:0}
.anim-list li:hover i{color:var(--accent);transform:scale(1.2)}
.anim-list li span{transition:text-decoration .1s}
.anim-list li:hover span{text-decoration:underline}
/* dark bg version */
.anim-list-light li{color:rgba(255,255,255,.9)}
.anim-list-light li:hover{color:#fff}

/* ===== SUPPORT HERO MOBILE PADDING ===== */
@media(max-width:680px){
  .sp-hero-inner{padding:60px 20px 50px}
  .sp-hero-inner h1{font-size:2rem}
}

/* ===== COMMITMENTS PARAGRAPH STYLE ===== */
.sp-commitments-para{color:rgba(255,255,255,.92);font-size:1.1rem;font-weight:600;line-height:1.8;margin-bottom:1.5rem;max-width:600px;margin-left:auto;margin-right:auto}


/* ===== NEWS: Facebook social card (Quick Takes) ===== */
.fb-social-card{display:flex;gap:0;margin-top:2rem;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.09);border:1px solid var(--line);max-width:680px;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease,box-shadow .25s ease}
.fb-social-card.is-visible{opacity:1;transform:none}
.fb-social-card:hover{box-shadow:0 10px 32px rgba(0,0,0,.14)}
.fb-social-thumb{position:relative;flex:0 0 180px;display:block;overflow:hidden}
.fb-social-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.fb-social-thumb:hover img{transform:scale(1.06)}
.fb-social-badge{position:absolute;left:10px;bottom:10px;width:34px;height:34px;border-radius:50%;background:#1877f2;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.fb-social-body{flex:1;padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.7rem;min-width:0}
.fb-social-meta{display:flex;align-items:center;gap:7px;color:#1877f2;font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.fb-social-meta-icon{flex:0 0 auto}
.fb-social-headline{margin:0;font-weight:800;font-size:1rem;line-height:1.4;color:var(--ink)}
.fb-social-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:auto}
.fb-act{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:700;text-decoration:none;border-radius:8px;padding:.4rem .8rem;transition:background .2s ease,color .2s ease,transform .2s ease}
.fb-act svg{display:block}
.fb-act-like{background:#eef3ff;color:#1877f2}
.fb-act-like:hover{background:#1877f2;color:#fff;transform:translateY(-1px)}
.fb-act-share{background:#eef3ff;color:#1877f2}
.fb-act-share:hover{background:#1877f2;color:#fff;transform:translateY(-1px)}
.fb-act-read{margin-left:auto;color:var(--accent);font-weight:800}
.fb-act-read:hover{text-decoration:underline}
@media(max-width:560px){
  .fb-social-card{flex-direction:column;max-width:none}
  .fb-social-thumb{flex:0 0 auto;height:180px}
  .fb-act-read{margin-left:0}
}

/* ===== Ramos Family Gallery (about.html) ===== */
.ramos-gallery-section{padding-top:0;overflow:hidden}
.ramos-gallery-section .wrap{margin-bottom:1.5rem}
.ramos-gallery-heading{margin-top:.25rem}
.ramos-gallery-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--accent) transparent;padding-bottom:12px}
.ramos-gallery-scroll-wrap::-webkit-scrollbar{height:4px}
.ramos-gallery-scroll-wrap::-webkit-scrollbar-track{background:transparent}
.ramos-gallery-scroll-wrap::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}
.ramos-gallery-track{display:flex;gap:16px;padding:0 var(--gutter,40px);width:max-content}
.ramos-gallery-item{flex:0 0 auto;width:340px;height:260px;border-radius:14px;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.12)}
.ramos-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.ramos-gallery-item:hover img{transform:scale(1.04)}
@media(max-width:820px){
  .ramos-gallery-track{padding:0 20px;gap:12px}
  .ramos-gallery-item{width:260px;height:200px}
}
@media(max-width:520px){
  .ramos-gallery-item{width:220px;height:170px}
}

/* ===== Ramos Legacy paragraph ===== */
.ramos-legacy{font-style:italic;opacity:.85;margin-top:1.25rem;border-left:3px solid var(--accent);padding-left:1rem}

/* ===== Tareake Pull-Quote (our-work.html) ===== */
.pull-quote-section{background:var(--ink);padding:72px 0}
.featured-pullquote{position:relative;max-width:820px;margin:0 auto;padding:0;border:none;text-align:center}
.featured-pullquote .pq-mark{display:block;font-size:2.5rem;color:var(--accent);margin-bottom:1rem;opacity:.6}
.featured-pullquote p{font-size:1.2rem;line-height:1.75;color:rgba(255,255,255,.92);font-weight:500;margin:0 0 1.5rem}
.featured-pullquote cite{display:block;font-size:.9rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-style:normal}
@media(max-width:820px){
  .featured-pullquote p{font-size:1rem}
  .pull-quote-section{padding:52px 0}
}

/* ===== Events headings — left-align on mobile ===== */
.events-section-h2{text-align:center}
@media(max-width:820px){.events-section-h2{text-align:left}}

/* ===== Support page headings/intros — left-align on mobile ===== */
.support-h2-center,.support-p-center{text-align:center}
@media(max-width:820px){
  .support-h2-center,.support-p-center{text-align:left}
  .support-p-center{margin-left:0;margin-right:0}
}

/* ===== Monday.com Application Popup ===== */
.monday-modal{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:9100;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}
.monday-modal[hidden]{display:none}
.monday-modal-inner{background:#fff;border-radius:18px;position:relative;width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.monday-modal-heading{margin:0;padding:1.2rem 1.5rem;font-size:1.1rem;font-weight:800;background:var(--accent);color:#fff;flex:0 0 auto}
.monday-modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:1.6rem;line-height:1;cursor:pointer;color:#fff;z-index:1;padding:0}
.monday-modal-close:hover{opacity:.75}
.monday-iframe-wrap{flex:1;overflow:hidden;min-height:500px}
.monday-iframe-wrap iframe{width:100%;height:100%;min-height:500px;display:block;border:0}
@media(max-width:600px){
  .monday-modal-inner{max-height:95vh;border-radius:12px}
  .monday-iframe-wrap{min-height:420px}
  .monday-iframe-wrap iframe{min-height:420px}
}

/* ============================================================
   COOKIE CONSENT bubble (bottom-left, mobile + desktop)
   ============================================================ */
.cc-wrap{position:fixed;left:20px;bottom:20px;z-index:9500;font-family:var(--font)}
.cc-wrap *{box-sizing:border-box}

/* ---- Full panel ---- */
.cc-panel{
  position:relative;width:340px;max-width:calc(100vw - 40px);
  background:#fff;border:1px solid var(--line);
  border-radius:20px;padding:20px 20px 18px;
  box-shadow:0 18px 50px rgba(95,79,138,.28);
  transform-origin:bottom left;
}
.cc-wrap.cc-collapsed .cc-panel{display:none}
.cc-wrap.cc-open .cc-panel{display:block}
/* bounce-in only on first run */
.cc-wrap.cc-firstrun.cc-open .cc-panel{animation:ccBounceIn .7s cubic-bezier(.18,1.25,.4,1) both}
@keyframes ccBounceIn{
  0%{opacity:0;transform:translateY(40px) scale(.6)}
  60%{opacity:1;transform:translateY(-10px) scale(1.04)}
  80%{transform:translateY(2px) scale(.99)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

.cc-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.cc-head h4{margin:0;font-size:1.08rem;font-weight:900;color:var(--ink)}
.cc-cookie{display:inline-flex;color:#caa96a}
.cc-panel p{margin:0 0 14px;font-size:.86rem;line-height:1.5;color:#444}
.cc-saved-note{color:#555}

.cc-actions{display:flex;gap:10px}
.cc-btn{
  flex:1;border:none;border-radius:11px;padding:11px 12px;cursor:pointer;
  font-family:var(--font);font-weight:800;font-size:.84rem;line-height:1.1;
  transition:transform .15s ease,filter .15s ease;
}
.cc-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.cc-btn:active{transform:translateY(0)}
/* Equal visual weight — both filled, brand colors, same size (no nudging) */
.cc-btn-all{background:var(--donate);color:#fff}
.cc-btn-nec{background:var(--pcard-1);color:#fff}

/* close (cookie + x) top-right */
.cc-close{
  position:absolute;top:-12px;right:-12px;width:40px;height:40px;
  border:1px solid var(--line);background:#fff;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:#caa96a;
  box-shadow:0 6px 18px rgba(95,79,138,.22);transition:transform .2s ease}
.cc-close:hover{transform:rotate(8deg) scale(1.08)}
.cc-close-x{position:absolute;font-size:1rem;font-weight:900;color:var(--donate);
  top:-2px;right:4px;background:#fff;border-radius:50%;width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;line-height:1;
  box-shadow:0 1px 4px rgba(0,0,0,.15)}

/* collapse arrow row on saved panel */
.cc-collapse{
  margin-top:12px;width:100%;background:none;border:none;cursor:pointer;
  font-family:var(--font);font-weight:800;font-size:.74rem;letter-spacing:.04em;
  color:var(--donate);opacity:.85;display:flex;align-items:center;justify-content:center;gap:6px;
  text-transform:uppercase;transition:opacity .15s ease}
.cc-collapse:hover{opacity:1}
.cc-collapse-arrow{font-size:.9rem;line-height:1}

/* ---- Tiny collapsed tab (cookie icon) ---- */
.cc-tab{
  width:52px;height:52px;border-radius:50%;cursor:pointer;
  border:1px solid var(--line);background:#fff;color:#caa96a;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 10px 28px rgba(95,79,138,.28);
  transition:transform .25s cubic-bezier(.34,1.4,.64,1)}
.cc-tab:hover{transform:scale(1.12) rotate(-6deg)}
.cc-wrap.cc-collapsed .cc-tab{display:flex;animation:ccTabPop .4s cubic-bezier(.18,1.25,.4,1) both}
@keyframes ccTabPop{0%{opacity:0;transform:scale(.4)}100%{opacity:1;transform:scale(1)}}

/* ---- Mobile ---- */
@media (max-width:520px){
  .cc-wrap{left:12px;bottom:12px;right:12px}
  .cc-panel{width:100%;max-width:none;padding:18px 16px 16px}
  .cc-actions{flex-direction:column}
  .cc-btn{padding:13px}
  .cc-tab{width:48px;height:48px}
}

/* ============================================================
   HERO VIDEO BACKGROUND (YouTube) + red bubble controls
   ============================================================ */
.hero-has-video{position:relative;overflow:hidden}
.hero-video{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  opacity:0;transition:opacity .8s ease;overflow:hidden;
}
.hero-video.is-ready{opacity:1}
/* The YouTube iframe is scaled to COVER the hero (no letterbox bars).
   200% sizing centered keeps a 16:9 video filling wide/tall heroes. */
.hero-video iframe{
  position:absolute;top:50%;left:50%;
  width:max(177.78vh,100%);height:max(56.25vw,100%);
  min-width:100%;min-height:100%;
  transform:translate(-50%,-50%);
  border:0;pointer-events:none;
}
/* keep the bg image as a fallback until the video is ready / on mobile */

/* Overlays must sit above the video */
.sp-hero-overlay,.ow-hero-overlay{z-index:1}
.sp-hero-inner,.ow-hero-inner{z-index:2}

/* Red bubble controls, top-right of the video */
.hero-video-controls{
  position:absolute;top:18px;right:18px;z-index:3;
  display:flex;gap:10px;
}
.hvc-btn{
  width:52px;height:52px;border-radius:50%;cursor:pointer;border:none;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(255,115,115,.5);
  font-size:1.15rem;line-height:1;
  transition:transform .2s cubic-bezier(.34,1.4,.64,1),background .2s ease;
}
.hvc-btn:hover{transform:scale(1.12);background:#ff5a5a}
.hvc-btn:active{transform:scale(.96)}
.hvc-ic{display:none}
/* Default state: playing + muted -> show pause icon and muted icon */
.hero-video-controls[data-state-play="playing"] .hvc-pause{display:inline}
.hero-video-controls[data-state-play="paused"] .hvc-play{display:inline}
.hero-video-controls[data-state-mute="muted"] .hvc-muted{display:inline}
.hero-video-controls[data-state-mute="unmuted"] .hvc-unmuted{display:inline}
.hvc-play{margin-left:3px}

/* "Hide All Text to Watch Video" theater button (below the round controls) */
.hero-video-controls{flex-direction:column;align-items:flex-end}
.hvc-theater-btn{
  margin-top:4px;border:none;cursor:pointer;
  background:var(--accent);color:#fff;border-radius:999px;
  padding:9px 16px;font-family:var(--font);font-weight:800;font-size:.78rem;
  letter-spacing:.02em;white-space:nowrap;
  box-shadow:0 6px 20px rgba(255,115,115,.5);
  transition:transform .2s cubic-bezier(.34,1.4,.64,1),background .2s ease;
}
.hvc-theater-btn:hover{transform:scale(1.05);background:#ff5a5a}
.hvc-theater-btn:active{transform:scale(.97)}

/* Theater mode active: clear the hero for unobstructed viewing.
   The .is-theater class is placed on the OUTER hero (.sp-hero / .ow-hero). */
.sp-hero.is-theater .sp-hero-overlay,
.ow-hero.is-theater .ow-hero-overlay{opacity:0;pointer-events:none;transition:opacity .3s ease}
.sp-hero.is-theater .sp-hero-inner,
.ow-hero.is-theater .ow-hero-inner{opacity:0;pointer-events:none;transition:opacity .3s ease}
/* hide the play/pause button, KEEP mute (so users can hear it) + the theater toggle */
.sp-hero.is-theater [data-hv-playpause],
.ow-hero.is-theater [data-hv-playpause]{display:none}

/* ===== About hero video treatment ===== */
.about-hero{position:relative;overflow:hidden}
/* Native self-hosted video: cover the hero, sit behind overlay/content */
.hero-video-el{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
  opacity:0;transition:opacity .8s ease;pointer-events:none;
}
.about-hero.is-ready .hero-video-el{opacity:1}
/* Keep the video fully visible in theater mode regardless of ready-state timing */
.about-hero.is-theater .hero-video-el{opacity:1}
/* "View Full Video" link under the controls */
.hvc-fullvideo-link{
  margin-top:6px;display:inline-block;text-align:center;
  color:#fff;font-family:var(--font);font-weight:800;font-size:.74rem;
  letter-spacing:.04em;text-transform:uppercase;text-decoration:underline;
  text-underline-offset:3px;opacity:.92;transition:opacity .15s ease;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
}
.hvc-fullvideo-link:hover{opacity:1}
.about-hero-overlay{position:absolute;inset:0;z-index:1;background:rgba(11,20,8,.5);transition:opacity .3s ease}
.about-hero .les-splash{z-index:2}
.about-hero .wrap{z-index:2}
.about-hero .hero-video-controls{z-index:4}
/* Theater mode on About: hide text grid, splash, the bg image filter, and the bg image itself */
.about-hero.is-theater .les-grid,
.about-hero.is-theater .les-splash{opacity:0;pointer-events:none;transition:opacity .3s ease}
.about-hero.is-theater .about-hero-overlay{opacity:0;pointer-events:none}
.about-hero.is-theater{background-image:none !important}
.about-hero.is-theater [data-hv-playpause]{display:none}
/* swap the theater button label when theater is on */
.hero-video-controls[data-theater="on"] .hvc-theater-label{font-size:0}
.hero-video-controls[data-theater="on"] .hvc-theater-label::after{content:"Show Text";font-size:.78rem}

@media (max-width:600px){
  .hvc-theater-btn{font-size:.68rem;padding:8px 12px}
}

@media (max-width:600px){
  .hero-video-controls{top:12px;right:12px;gap:8px}
  .hvc-btn{width:44px;height:44px;font-size:1rem}
}

/* ============================================================
   PROGRAM POPUP (Our Work) — fits without scrollbars
   ============================================================ */
.pgm-modal{position:fixed;inset:0;z-index:9600;display:flex;align-items:center;justify-content:center;padding:20px}
.pgm-modal[hidden]{display:none}
.pgm-backdrop{position:absolute;inset:0;background:rgba(11,20,8,.72);backdrop-filter:blur(3px);animation:pgmFade .25s ease both}
@keyframes pgmFade{from{opacity:0}to{opacity:1}}
.pgm-card{
  position:relative;z-index:1;background:#fff;border-radius:20px;overflow:hidden;
  width:min(860px,100%);max-height:calc(100vh - 40px);
  display:grid;grid-template-columns:1fr 1.1fr;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  animation:pgmPop .3s cubic-bezier(.2,1.2,.4,1) both;
}
@keyframes pgmPop{from{opacity:0;transform:translateY(22px) scale(.96)}to{opacity:1;transform:none}}
.pgm-img{min-height:100%}
.pgm-img img{width:100%;height:100%;object-fit:cover;display:block}
.pgm-body{padding:34px 32px;display:flex;flex-direction:column;justify-content:center;gap:12px}
.pgm-tag{align-self:flex-start;background:var(--accent);color:#fff;font-size:.7rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.pgm-title{margin:0;font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.15;color:var(--ink)}
.pgm-desc{margin:0;font-size:.98rem;line-height:1.6;color:#444}
.pgm-register{align-self:flex-start;margin-top:8px}
.pgm-close{
  position:absolute;top:12px;right:12px;z-index:2;width:40px;height:40px;border-radius:50%;
  border:none;background:#fff;color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(0,0,0,.25);transition:transform .15s ease}
.pgm-close:hover{transform:scale(1.1) rotate(90deg)}

/* Mobile: stack, cap image height so text always fits without scroll */
@media (max-width:700px){
  .pgm-modal{padding:14px}
  .pgm-card{grid-template-columns:1fr;width:100%;max-height:calc(100vh - 28px)}
  .pgm-img{min-height:0;max-height:34vh}
  .pgm-img img{max-height:34vh}
  .pgm-body{padding:22px 20px;overflow:auto}
  .pgm-title{font-size:1.35rem}
  .pgm-desc{font-size:.92rem}
}

/* Event popup extras (meta line + action buttons + calendar menu) */
.evm-meta{margin:0;font-size:.85rem;font-weight:800;color:var(--donate);letter-spacing:.02em}
.evm-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;align-items:center}
.evm-cal-wrap{position:relative}
.evm-cal-menu{
  position:absolute;bottom:calc(100% + 8px);left:0;z-index:3;min-width:190px;
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:6px;
  box-shadow:0 14px 40px rgba(0,0,0,.22);
}
.evm-cal-menu button{
  display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--font);font-weight:700;font-size:.9rem;color:var(--ink);
  padding:10px 12px;border-radius:9px;
}
.evm-cal-menu button:hover{background:var(--paper-soft)}
@media (max-width:700px){
  .evm-actions{gap:8px}
  .evm-actions .btn{padding:.6rem 1rem;font-size:.85rem}
}
