/* ===== Tokens (exact Variant values) ===== */
:root{
  --gold:#FFC107;
  --gold-deep:#E0A800;
  --navy:#001F3F;
  --navy-2:#06294D;
  --cream:#FDFBF7;
  --ink:#19222F;
  --muted:#5B6675;
  --line:#E8E2D6;
  --maxw:1180px;
  --pad:clamp(18px,5vw,52px);
  --f:"Nunito",system-ui,sans-serif;
  --d:"Fraunces",Georgia,serif;
  --shadow:0 22px 50px -22px rgba(0,31,63,.4);
}
*{margin:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;font-optical-sizing:auto}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.center{text-align:center}
em{font-style:italic}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--f);font-weight:800;font-size:.92rem;padding:13px 24px;border-radius:100px;border:0;cursor:pointer;transition:transform .15s ease,background .2s ease,color .2s ease}
.btn-gold{background:var(--gold);color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.btn-gold:hover{background:#fff;transform:translateY(-2px)}
.btn-heart .ph{font-size:1.05em}
.btn-mission{display:inline-flex;align-items:center;gap:12px;margin-top:clamp(28px,4vw,46px);background:var(--gold);color:var(--navy);font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:clamp(.82rem,1vw,.98rem);padding:18px 36px;border-radius:2px;transition:transform .18s ease,background .2s ease}
.btn-mission:hover{background:#fff;transform:translateY(-2px)}
.btn-learn{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;font-weight:800;text-transform:uppercase;letter-spacing:.07em;font-size:.76rem;color:var(--navy);padding:0;background:none}
.btn-learn:hover{color:var(--gold-deep);gap:12px}
.btn-outline-dark{display:inline-flex;align-items:center;gap:8px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;font-size:.76rem;color:var(--navy);border:2px solid var(--navy);padding:12px 22px;border-radius:3px;transition:.18s;white-space:nowrap}
.btn-outline-dark:hover{background:var(--navy);color:#fff}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:var(--navy);transition:background .25s ease,box-shadow .25s ease}
.site-header.shrink{box-shadow:0 8px 26px -16px rgba(0,0,0,.7)}
.header-row{display:flex;align-items:center;gap:22px;padding-block:14px;transition:padding-block .25s ease}
.site-header.shrink .header-row{padding-block:7px}
.brand{display:inline-flex;align-items:center;perspective:600px}
.brand .logo{height:44px;width:auto;display:block;overflow:visible;transition:height .25s ease}
.site-header.shrink .brand .logo{height:36px}
.logo .spin{transform-box:view-box;transform-origin:46px 46px;animation:globespin 16s linear infinite}
.logo .mer{will-change:transform}
@keyframes globespin{to{transform:rotateY(360deg)}}
.nav{display:flex;gap:30px;margin-left:24px}
.nav a{font-weight:700;color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}
.nav a:hover{color:var(--gold)}
.hdr-search{margin-left:auto;background:none;border:0;color:#fff;cursor:pointer;font-size:1.25rem;display:grid;place-items:center;padding:4px}
.hdr-search:hover{color:var(--gold)}
.menu-toggle{display:none;margin-left:auto;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.menu-toggle span{width:26px;height:3px;background:#fff;border-radius:3px}

/* ===== 1 · Hero ===== */
.hero-v{position:relative;min-height:calc(100vh - 74px);display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;left:0;right:0;top:-10%;bottom:-10%;z-index:0;overflow:hidden;will-change:transform}
.hero-bg-img{position:absolute;inset:0;background-image:url('../assets/photos/hawks-4k.webp');background-size:cover;background-position:62% 42%;will-change:transform}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;z-index:0;background:var(--navy)}
.hero-v::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background-image:linear-gradient(90deg,rgba(0,18,40,.66) 0%,rgba(0,18,40,.3) 50%,rgba(0,18,40,.12) 100%),linear-gradient(0deg,rgba(0,18,40,.42),transparent 48%)}
.hero-v-inner{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:clamp(40px,8vh,90px) var(--pad)}
.hero-v-h1{font-family:var(--d);font-style:italic;font-weight:900;color:#fff;font-size:clamp(2.8rem,11.5vw,8.5rem);line-height:.96;letter-spacing:-.01em;max-width:13ch;text-shadow:0 6px 40px rgba(0,20,45,.2)}
.hero-v-h1 em{color:var(--gold);font-style:italic}
.scroll-cue{position:absolute;z-index:2;right:clamp(20px,5vw,60px);bottom:40px;color:var(--gold);font-size:2.1rem;animation:bob 1.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ===== 2 · R.E.A.D. values (collapsible) ===== */
.read{background:var(--navy);color:#fff;padding:clamp(58px,8vw,96px) 0}
.read-inner{max-width:760px;margin:0 auto}
.read-eyebrow{font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--gold);font-size:.8rem;margin-bottom:14px}
.read-title{font-family:var(--d);font-style:italic;font-weight:600;color:#fff;font-size:clamp(2rem,4vw,3.2rem);margin-bottom:clamp(22px,3vw,38px)}
.read-title em{color:var(--gold)}
.read-acc{border-top:1px solid rgba(255,255,255,.14)}
.racc{border-bottom:1px solid rgba(255,255,255,.14)}
.racc-head{display:flex;align-items:center;gap:clamp(16px,3vw,28px);width:100%;background:none;border:0;cursor:pointer;padding:clamp(18px,2.6vw,26px) 4px;text-align:left;font-family:var(--f)}
.racc-letter{font-family:var(--d);font-style:italic;font-weight:900;color:var(--gold);font-size:clamp(2.3rem,5vw,3.3rem);line-height:1;width:1.15em;flex-shrink:0;transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.racc-word{flex:1;font-family:var(--d);font-style:italic;font-weight:600;font-size:clamp(1.4rem,2.6vw,2rem);color:#fff;transition:color .2s ease}
.racc-head:hover .racc-word{color:var(--gold)}
.racc-head:hover .racc-letter{transform:translateY(-4px)}
.racc-ico{position:relative;width:22px;height:22px;flex-shrink:0}
.racc-ico::before,.racc-ico::after{content:"";position:absolute;background:var(--gold);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.racc-ico::before{top:50%;left:0;right:0;height:2.5px;transform:translateY(-50%)}
.racc-ico::after{left:50%;top:0;bottom:0;width:2.5px;transform:translateX(-50%)}
.racc.open .racc-ico::after{transform:translateX(-50%) rotate(90deg);opacity:0}
.racc-body{max-height:0;overflow:hidden;transition:max-height .45s ease}
.racc.open .racc-body{max-height:220px}
.racc-body p{color:#c4d0df;font-size:1.05rem;line-height:1.6;max-width:54ch;padding:0 0 clamp(22px,2.6vw,28px) clamp(54px,9vw,90px)}

/* ===== 3 · Founder's vision ===== */
.vision{background:var(--cream);padding:clamp(64px,9vw,108px) 0}
.vision-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(34px,5vw,72px);align-items:center}
.vision-photo{margin:0;border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}
.vision-photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.eyebrow-gold{font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--gold-deep);font-size:.8rem;margin-bottom:22px}
.eyebrow-gold.center{text-align:center}
.vision-quote{font-family:var(--d);font-style:italic;font-weight:500;color:var(--navy);font-size:clamp(1.85rem,3.4vw,3.1rem);line-height:1.12;letter-spacing:-.01em}
.vision-quote em{color:var(--gold-deep)}
.vision-attr{margin-top:26px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);font-size:.86rem}

/* ===== 4 · R·E·A·D band (giant stacked words) ===== */
.readband{position:relative;background:var(--navy);overflow:hidden;padding:clamp(40px,6vw,72px) 0}
.rb-watermark{position:absolute;left:-2%;top:50%;transform:translateY(-50%);font-family:var(--d);font-style:italic;font-weight:900;color:rgba(255,255,255,.045);font-size:min(78vh,150vw);line-height:.7;pointer-events:none;z-index:0}
.readband-stack{position:relative;z-index:1;padding-inline:var(--pad)}
.rbw{font-family:var(--d);font-style:italic;font-weight:900;text-transform:uppercase;color:#fff;font-size:clamp(2.8rem,13vw,11rem);line-height:.84;letter-spacing:-.01em;white-space:nowrap;margin:0}
.rbw b{color:var(--gold);font-weight:900}
.rbw-2{margin-left:clamp(36px,16vw,360px)}
.rbw-4{margin-left:clamp(18px,9vw,200px)}

/* ===== 5 · Programs ===== */
.programs{background:#fff;padding:clamp(64px,9vw,108px) 0}
.prog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(34px,4vw,54px);flex-wrap:wrap}
.prog-title{font-family:var(--d);font-style:italic;font-weight:600;color:var(--navy);font-size:clamp(2rem,3.6vw,3rem)}
.prog-title em{color:var(--gold-deep)}
.prog-head p{color:var(--muted);margin-top:8px;font-size:1.05rem}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px)}
.prog-card{display:flex;flex-direction:column}
.prog-photo{border-radius:8px;overflow:hidden;aspect-ratio:4/5;background:var(--cream);box-shadow:var(--shadow)}
.prog-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.prog-card:hover .prog-photo img{transform:scale(1.05)}
.prog-card h3{font-family:var(--d);font-style:italic;font-weight:700;text-transform:uppercase;color:var(--gold-deep);font-size:clamp(1.35rem,2.1vw,1.8rem);margin:22px 0 10px}
.prog-card p{color:var(--muted);margin-bottom:16px;flex:1}

/* ===== 6 · Marquee ===== */
.marquee{background:var(--gold);overflow:hidden;padding-block:clamp(18px,2.8vw,36px)}
.marquee-track{display:inline-flex;white-space:nowrap;animation:marquee 30s linear infinite;will-change:transform}
.marquee-track span{font-family:var(--d);font-style:italic;font-weight:700;text-transform:uppercase;color:var(--navy);font-size:clamp(1.7rem,3.8vw,3rem)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== 7 · Donate ===== */
.donate{background:var(--navy);color:#fff;padding:clamp(64px,9vw,108px) 0}
.donate-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:center}
.donate-h{font-family:var(--d);font-style:italic;font-weight:900;color:#fff;font-size:clamp(2.5rem,5vw,4.4rem);line-height:.98;letter-spacing:-.01em}
.donate-h em{color:var(--gold)}
.donate-copy>p{color:#c4d0df;font-size:1.06rem;margin-top:24px;max-width:46ch}
.charity{display:flex;align-items:center;gap:10px;margin-top:30px;font-weight:800;color:#fff}
.charity .ph{color:var(--gold);font-size:1.4rem}
.donate-card{background:#fff;border-radius:16px;padding:28px;color:var(--ink);box-shadow:var(--shadow)}
.give-toggle{display:flex;background:#EEF0F4;border-radius:100px;padding:5px;margin-bottom:22px}
.give-toggle button{flex:1;border:0;background:none;padding:13px;border-radius:100px;font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;color:var(--muted);cursor:pointer;transition:.18s}
.give-toggle button.active{background:var(--navy);color:#fff}
.amounts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
.amounts button{border:1.5px solid #E2E6EC;background:#fff;padding:22px 0;border-radius:10px;font-family:var(--f);font-weight:800;font-size:1.3rem;color:var(--navy);cursor:pointer;transition:.15s}
.amounts button:hover{border-color:var(--gold)}
.amounts button.active{border-color:var(--navy);background:var(--navy);color:#fff}
.custom-label{font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--muted);margin-bottom:10px}
.custom-field{display:flex;align-items:center;gap:8px;border-bottom:2px solid #E2E6EC;padding-bottom:10px;margin-bottom:26px}
.custom-field span{font-size:1.3rem;font-weight:800;color:var(--muted)}
.custom-field input{flex:1;border:0;font-family:var(--f);font-size:1.15rem;font-weight:700;color:var(--navy);outline:none}
.btn-complete{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--gold);color:var(--navy);font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:18px;border-radius:8px;transition:.18s}
.btn-complete:hover{background:var(--gold-deep);transform:translateY(-2px)}

/* ===== 8 · Impact stories ===== */
.stories{background:var(--cream);padding:clamp(64px,9vw,108px) 0}
.stories-title{font-family:var(--d);font-style:italic;font-weight:600;color:var(--navy);font-size:clamp(2.2rem,4vw,3.4rem);margin:6px 0 clamp(34px,4vw,52px)}
.stories-title em{color:var(--gold-deep)}
.stories-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,3vw,34px)}
.story-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:36px 34px;box-shadow:var(--shadow)}
.story-card .ph{color:var(--gold);font-size:2.4rem;margin-bottom:14px;display:block}
.story-card p{font-family:var(--d);font-style:italic;font-size:clamp(1.2rem,1.9vw,1.55rem);line-height:1.32;color:var(--navy)}
.story-card footer{margin-top:20px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;color:var(--muted)}

/* ===== 9 · Get involved ===== */
.involved{background:#fff;padding:clamp(40px,6vw,70px) 0 clamp(64px,9vw,108px)}
.involved-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,34px)}
.inv-card{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:34px 30px;display:flex;flex-direction:column;align-items:flex-start;transition:.2s}
.inv-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.inv-icon{display:block;margin-bottom:14px}
.inv-icon img{width:82px;height:82px;display:block;object-fit:contain}
.inv-card h3{font-family:var(--d);font-style:italic;font-weight:700;color:var(--navy);font-size:1.55rem;margin-bottom:10px}
.inv-card p{color:var(--muted);margin-bottom:18px;flex:1}
.inv-nudge{display:inline-flex;flex-direction:column;gap:1px;margin:0 0 clamp(18px,2.5vw,32px) 10px;transform:rotate(-3deg);transform-origin:left center;font-family:"Caveat",cursive;line-height:.95;pointer-events:none;-webkit-user-select:none;user-select:none}
.inv-nudge-lead{font-weight:700;color:var(--gold-deep);font-size:clamp(2.1rem,3.6vw,3.1rem)}
.inv-nudge-sub{display:inline-flex;align-items:flex-start;gap:10px;font-weight:700;color:var(--navy);font-size:clamp(1.35rem,2.3vw,1.95rem);opacity:.88}
.inv-nudge-arrow{flex:none;width:clamp(52px,5.8vw,80px);height:auto;stroke:var(--gold-deep);fill:none;margin-top:-2px}

/* ===== 10 · Newsletter ===== */
.newsletter{background:var(--cream);padding:clamp(56px,8vw,96px) 0;text-align:center}
.news-inner{max-width:640px;margin:0 auto}
.news-title{font-family:var(--d);font-style:italic;font-weight:600;color:var(--navy);font-size:clamp(2rem,3.6vw,3rem)}
.news-title em{color:var(--gold-deep)}
.news-inner>p{color:var(--muted);margin:14px 0 26px;font-size:1.06rem}
.news-form{display:flex;gap:10px;max-width:480px;margin:0 auto}
.news-form input{flex:1;border:1.5px solid var(--line);border-radius:100px;padding:15px 22px;font-family:var(--f);font-size:1rem;background:#fff}
.news-form input:focus{outline:none;border-color:var(--gold)}
.news-form .btn-gold{border-radius:100px;padding:15px 28px}
.news-fine{margin-top:16px;font-size:.82rem;color:var(--muted)}

/* ===== Footer ===== */
.site-footer{background:var(--navy);color:#aebccf;padding:clamp(50px,7vw,76px) var(--pad) 30px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;max-width:var(--maxw);margin:0 auto;padding:0}
.footer-brand .logo{height:50px;width:auto;margin-bottom:16px;display:block}
.footer-brand p{font-size:.95rem;max-width:34ch}
.footer-col h4{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.footer-col a,.footer-col span{display:block;color:#aebccf;margin-bottom:11px;font-size:.95rem}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;max-width:var(--maxw);margin:36px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);font-size:.84rem;color:#8595ac}
.footer-bottom .ph{color:var(--gold)}
.footer-bottom a:hover{color:var(--gold)}

/* ===== Scroll progress bar ===== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;background:linear-gradient(90deg,var(--gold),var(--gold-deep));box-shadow:0 0 8px rgba(255,193,7,.6);transition:width .08s linear}

/* ===== Scroll reveals (classes added by JS) ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
.rbw{opacity:0;transform:translateX(-12%);transition:opacity .8s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.rbw.from-right{transform:translateX(12%)}
.rbw.is-visible{opacity:1;transform:none}

/* ===== Impact line (donate) ===== */
.impact-line{min-height:1.2em;margin:-8px 0 18px;font-family:var(--d);font-style:italic;font-size:1.02rem;line-height:1.3;color:var(--gold-deep);transition:opacity .25s ease}
.impact-line b{font-style:normal;font-weight:800;color:var(--navy)}

/* ===== Impact by the numbers ===== */
.stats{background:var(--navy);color:#fff;padding:clamp(56px,8vw,90px) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,40px);text-align:center}
.stat{display:flex;flex-direction:column;align-items:center;gap:10px}
.stat-num{font-family:var(--d);font-style:italic;font-weight:900;color:var(--gold);font-size:clamp(2.8rem,5.5vw,4.6rem);line-height:.9;font-variant-numeric:tabular-nums}
.stat p{color:#c4d0df;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;max-width:16ch}

/* ===== Community board ===== */
.board{position:relative;overflow-x:clip;background:#F6EFE0;border-top:1px solid var(--line);padding:clamp(56px,8vw,100px) 0 clamp(64px,9vw,110px)}
.board-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap;margin-bottom:clamp(20px,2.4vw,30px)}
.board-head .eyebrow-gold{margin-bottom:14px}
.board-title{font-family:var(--d);font-style:italic;font-weight:600;color:var(--navy);font-size:clamp(2.4rem,5vw,4rem);line-height:1.02;letter-spacing:-.01em}
.board-title em{color:var(--gold-deep)}
.board-intro{color:var(--muted);margin-top:14px;max-width:54ch;font-size:1.05rem}
.btn-pin{display:inline-flex;align-items:center;gap:10px;background:var(--gold);color:var(--navy);font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;padding:14px 26px;border:0;border-radius:100px;cursor:pointer;box-shadow:0 12px 24px -10px rgba(224,168,0,.75);transition:transform .15s ease,background .2s ease;flex-shrink:0}
.btn-pin:hover{background:var(--gold-deep);transform:translateY(-2px)}
.btn-pin .ph{font-size:1.15em}
.pin-note{margin:0 0 26px;font-size:.95rem;line-height:1.5;color:var(--navy);background:rgba(255,193,7,.16);border-left:3px solid var(--gold);padding:12px 16px;border-radius:8px;max-width:64ch}
.pin-note[hidden]{display:none}

.board-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(30px,3.6vw,46px)}
.board-filters button{background:#fff;border:1.5px solid var(--line);color:var(--navy);font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;padding:9px 17px;border-radius:100px;cursor:pointer;transition:.18s}
.board-filters button:hover{border-color:var(--gold)}
.board-filters button.active{background:var(--navy);border-color:var(--navy);color:#fff}

.board-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(30px,3.4vw,48px) clamp(20px,2.2vw,30px);align-items:start}

.flyer{position:relative;background:#fff;border-radius:14px;padding:26px 22px 22px;box-shadow:0 18px 36px -20px rgba(0,31,63,.5);transform:rotate(var(--rot,0deg));transition:transform .28s cubic-bezier(.2,.7,.2,1),box-shadow .28s ease;cursor:pointer;text-align:center}
.flyer:hover,.flyer:focus-visible{transform:rotate(0deg) translateY(-6px) scale(1.02);box-shadow:0 30px 56px -22px rgba(0,31,63,.6);z-index:5;outline:none}
.rot-a{--rot:-3deg}.rot-b{--rot:2.4deg}.rot-c{--rot:-1.6deg}.rot-d{--rot:2.8deg}
.flyer.theme-cream{background:#FBF4E4}
.flyer.theme-blue{background:#E3EBF5}

.flyer-ic{display:block;color:var(--navy);font-size:2.3rem;line-height:1;margin-bottom:10px}
.flyer-h{font-family:var(--d);font-weight:800;color:var(--navy);line-height:1.04;margin-bottom:6px}
.flyer-h .l1,.flyer-h .l2{display:block;text-transform:uppercase;font-size:1.45rem;letter-spacing:.005em}
.flyer-h .script{font-family:"Caveat",cursive;text-transform:none;color:var(--gold-deep);font-weight:700;font-size:2.3rem;line-height:.82;letter-spacing:0}
.flyer-ribbon{display:block;background:var(--gold);color:var(--navy);font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.09em;font-size:.64rem;padding:6px 0;margin:10px -22px 12px}
.flyer-sub{color:var(--muted);font-size:.9rem;line-height:1.46;margin:10px auto 14px;max-width:28ch}
.flyer-meta{font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.66rem;color:var(--navy);margin-bottom:8px}
.flyer-info{background:rgba(0,31,63,.055);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:10px;margin-bottom:14px;text-align:left}
.theme-cream .flyer-info{background:rgba(255,255,255,.6)}
.theme-blue .flyer-info{background:rgba(255,255,255,.6)}
.flyer-info .row{display:flex;align-items:center;gap:10px}
.flyer-info .ph{color:var(--navy);font-size:1.2rem;flex-shrink:0}
.flyer-info .t{font-size:.78rem;color:var(--navy);line-height:1.32}
.flyer-info b{display:block;font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:.72rem}
.flyer-feats{display:flex;justify-content:space-between;gap:6px;margin-bottom:14px}
.flyer-feats div{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em;color:var(--navy);line-height:1.2}
.flyer-feats .ph{font-size:1.4rem;color:var(--navy)}
.flyer-tag{font-family:"Caveat",cursive;color:var(--navy);font-size:1.3rem;font-weight:700;line-height:1.05;margin-top:6px}
.flyer-tag .ph{color:var(--gold);font-size:.82em;vertical-align:-2px}

/* banded variants */
.flyer-band{background:var(--navy);margin:-26px -22px 14px;padding:20px 18px 16px;border-radius:14px 14px 0 0}
.flyer-band .flyer-ic{color:var(--gold)}
.flyer-band .flyer-h{margin:0}
.flyer-band .flyer-h .l1{color:#fff}
.flyer-band .flyer-h .script,.flyer-band .flyer-h .l2.gold{color:var(--gold)}
.flyer-foot{background:var(--navy);margin:14px -22px -22px;padding:16px 18px 18px;border-radius:0 0 14px 14px}
.flyer-foot .flyer-info{background:rgba(255,255,255,.08);margin-bottom:10px}
.flyer-foot .flyer-info .ph,.flyer-foot .flyer-info .t,.flyer-foot .flyer-info b{color:#fff}
.flyer-foot .flyer-tag{color:var(--gold);margin:0}

/* pins & tape */
.pin{position:absolute;top:-12px;left:50%;width:22px;height:22px;border-radius:50%;transform:translateX(-50%);background:radial-gradient(circle at 38% 30%,#FFE48F,var(--gold) 46%,var(--gold-deep) 100%);box-shadow:0 6px 10px -2px rgba(0,0,0,.45),inset 0 -2px 3px rgba(0,0,0,.22);z-index:6}
.pin::after{content:"";position:absolute;top:5px;left:6px;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.6)}
.tape{position:absolute;top:-10px;left:50%;width:78px;height:26px;transform:translateX(-50%) rotate(-4deg);background:rgba(222,198,138,.5);border:1px solid rgba(210,184,120,.4);box-shadow:0 2px 6px rgba(0,0,0,.1);z-index:6}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:28px;background:rgba(0,18,40,.72)}
.lb.open{display:flex}
.lb-stage{width:100%;max-width:400px}
.lb-stage .flyer{transform:none;cursor:default;width:100%;box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}
.lb-stage .flyer:hover{transform:none}
.lb-close{position:absolute;top:18px;right:26px;background:none;border:0;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer}
.lb-close:hover{color:var(--gold)}

@media(max-width:1040px){.board-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.board-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.board-grid{grid-template-columns:1fr;max-width:340px;margin-inline:auto}}

/* ===== Cinematic hero intro ===== */
.hero-sheen{position:absolute;top:0;bottom:0;left:0;width:55%;z-index:1;pointer-events:none;background:linear-gradient(110deg,transparent,rgba(255,216,110,.22),transparent);opacity:0}
@media (prefers-reduced-motion: no-preference){
  .hero-v-h1 .hw{display:inline-block;opacity:0;transform:translateY(48px);animation:heroWord .85s cubic-bezier(.2,.75,.25,1) both;animation-delay:calc(var(--i,0)*.08s + .25s)}
  .btn-mission{opacity:0;animation:heroRise .8s ease both;animation-delay:1s}
  .hero-bg-img{animation:kenburns 24s ease-in-out infinite alternate}
  .hero-sheen{animation:heroSheen 1.7s cubic-bezier(.3,.5,.4,1) 1s both}
}
@keyframes heroWord{to{opacity:1;transform:none}}
@keyframes heroRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes kenburns{from{transform:scale(1.03)}to{transform:scale(1.15) translate(-1.6%,-1.2%)}}
@keyframes heroSheen{0%{opacity:0;transform:translateX(-90%) skewX(-16deg)}25%{opacity:1}100%{opacity:0;transform:translateX(300%) skewX(-16deg)}}

/* ===== Gallery wall ===== */
.gallery{background:#fff;padding:clamp(56px,8vw,100px) 0 clamp(30px,5vw,56px)}
.gallery .stories-title{margin:6px 0 clamp(30px,4vw,48px)}
.gallery-grid{columns:3 250px;column-gap:14px}
.gphoto{display:block;width:100%;margin:0 0 14px;padding:0;border:0;background:none;position:relative;border-radius:12px;overflow:hidden;cursor:pointer;break-inside:avoid;box-shadow:0 14px 30px -18px rgba(0,31,63,.5)}
.gphoto img{width:100%;display:block;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.gphoto-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.9rem;background:linear-gradient(0deg,rgba(0,31,63,.5),rgba(0,31,63,.12) 60%);opacity:0;transition:opacity .3s ease}
.gphoto:hover img,.gphoto:focus-visible img{transform:scale(1.07)}
.gphoto:hover .gphoto-ov,.gphoto:focus-visible .gphoto-ov{opacity:1}
.lb-stage img{display:block;max-width:100%;max-height:82vh;width:auto;margin:0 auto;border-radius:12px;box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}

/* ===== Micro-interactions ===== */
.btn-gold,.btn-mission,.btn-complete,.btn-pin{position:relative;overflow:hidden;isolation:isolate}
.btn-gold::after,.btn-mission::after,.btn-complete::after,.btn-pin::after{content:"";position:absolute;top:0;left:-80%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);transition:left .6s cubic-bezier(.3,.5,.4,1);z-index:-1}
.btn-gold:hover::after,.btn-mission:hover::after,.btn-complete:hover::after,.btn-pin:hover::after{left:140%}

/* ===== Mentorship video band ===== */
.videoband{position:relative;min-height:clamp(420px,72vh,660px);display:flex;align-items:flex-end;overflow:hidden;background:var(--navy)}
.videoband-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.videoband::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(0deg,rgba(0,18,40,.88),rgba(0,18,40,.1) 55%,rgba(0,18,40,.4)),linear-gradient(90deg,rgba(0,18,40,.55),transparent 62%)}
.videoband-inner{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:clamp(34px,6vw,72px) var(--pad)}
.videoband .eyebrow-gold{color:var(--gold);margin-bottom:14px}
.videoband-h{font-family:var(--d);font-style:italic;font-weight:600;color:#fff;font-size:clamp(1.9rem,4.4vw,3.5rem);line-height:1.06;max-width:20ch;text-shadow:0 4px 30px rgba(0,15,35,.4)}
.videoband-h em{color:var(--gold)}

/* ===== Scroll-stacking cards (Programs / Lives transformed / Real moments) ===== */
.stack{position:relative;z-index:1}
.stack-card{position:sticky;top:84px;border-radius:28px;overflow:hidden;box-shadow:0 -16px 50px -22px rgba(0,31,63,.55);min-height:clamp(460px,74vh,720px);max-height:calc(100vh - 84px);display:flex;flex-direction:column;justify-content:center;will-change:transform}
.stack-card:nth-child(2){top:100px;max-height:calc(100vh - 100px)}
.stack-card:nth-child(3){top:116px;max-height:calc(100vh - 116px)}
.stack-card:last-child{position:static;max-height:none}
.stack-card > .wrap{width:100%}
/* keep the pinned programs/get-involved cards within the visible area so their
   bottom (descriptions + Learn-more links) is never clipped by the next card */
#programs,#involved{padding-block:clamp(20px,4vh,56px)}
#programs .prog-head{margin-bottom:clamp(12px,2vh,34px)}
#programs .prog-photo{aspect-ratio:auto;height:clamp(120px,17vh,250px)}
@media(max-width:760px){
  /* Keep the desktop stacking on phones, but give each pinned card a full-screen
     runway and fit it to the viewport — so the next card doesn't slide up until
     you've had a full screen to read the current one. (stories/board are the
     last card in their stack → already static, so board's tall list scrolls.) */
  .stack-card{top:64px;min-height:calc(100svh - 64px);max-height:calc(100svh - 64px);justify-content:flex-start;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:18px;border-radius:18px 18px 0 0}
  .programs.stack-card{padding-block:clamp(24px,5vw,40px)}
  #programs .prog-head{margin-bottom:14px}
  /* On phones, reclaim vertical space so each card's "Learn more" lands in view
     while the card is pinned: hide the section intro paragraph + the secondary
     "View all initiatives" button (both stay on desktop). */
  #programs .prog-head p,#programs .prog-head .btn-outline-dark{display:none}
  /* pinning sections become a free-scrolling horizontal swipe so each fits ~one screen and can collapse */
  #programs .prog-grid,#involved .involved-grid{display:flex;gap:14px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;max-width:none;margin:0;padding:2px 2px 16px;scrollbar-width:none}
  #programs .prog-grid::-webkit-scrollbar,#involved .involved-grid::-webkit-scrollbar{display:none}
  #programs .prog-card,#involved .inv-card{flex:0 0 74%;margin:0}
  #programs .prog-photo{aspect-ratio:auto;height:clamp(120px,18vh,170px)}
  #programs .prog-photo img{object-position:center 18%}
  #programs .prog-card h3{margin:16px 0 8px}
}

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

/* ===== Responsive ===== */
@media(max-width:900px){
  .nav{display:none}
  .menu-toggle{display:flex}
  .hdr-search{display:none}
  .header-row{gap:12px}
  .brand .logo{height:36px}
  .header-row .btn-heart{margin-left:auto;padding:11px 18px;font-size:.8rem;gap:6px}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--navy);flex-direction:column;padding:18px var(--pad);gap:16px}
  .read-cols{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .vision-grid,.donate-grid,.stories-grid{grid-template-columns:1fr}
  .vision-photo{max-width:440px}
  .prog-grid,.involved-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .readband-row{justify-content:center;gap:26px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:540px){
  .read-cols{grid-template-columns:1fr}
  .amounts{grid-template-columns:1fr 1fr}
  .news-form{flex-direction:column}
  .stats-grid{gap:34px 16px}
  .stat-num{font-size:clamp(2rem,9vw,2.8rem)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px}
}
/* Mobile tweaks */
@media(max-width:600px){
  .hero-v{min-height:clamp(520px,150vw,700px)}
  .hero-video{object-position:56% 38%}
  .hero-v-h1{font-size:clamp(2.6rem,9.5vw,3.4rem)}
  .hero-sheen{display:none}
  .gallery-grid{columns:2 140px;column-gap:10px}
  .gphoto{margin-bottom:10px}
  .flyer{transform:none}
}

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

/* ===== TEAM PAGE ("Our Team" + A Mentor's Story) ===== */
.team-intro{background:var(--cream);padding:clamp(54px,8vw,96px) 0 clamp(34px,5vw,56px);text-align:center}
.team-intro .eyebrow-gold{margin-bottom:16px}
.team-title{font-family:var(--d);font-style:italic;font-weight:600;color:var(--navy);font-size:clamp(2.2rem,5.4vw,3.7rem);line-height:1.03;letter-spacing:-.01em}
.team-title em{color:var(--gold-deep)}
.team-lede{max-width:58ch;margin:20px auto 0;color:var(--muted);font-size:clamp(1rem,1.4vw,1.12rem);line-height:1.6}
.team-section{background:var(--cream);padding:0 0 clamp(60px,9vw,104px)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:clamp(20px,3vw,32px);max-width:940px;margin:0 auto}
.team-card{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.team-photo{margin:0;overflow:hidden;background:var(--navy)}
.team-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;display:block}
.team-body{padding:clamp(20px,2.4vw,28px)}
.team-name{font-family:var(--d);font-style:italic;font-weight:700;color:var(--navy);font-size:clamp(1.5rem,2.4vw,2rem);line-height:1.05}
.team-role{margin-top:8px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-deep);font-size:.74rem}
.team-bio{margin-top:14px;color:var(--muted);font-size:.97rem;line-height:1.55}
.mentor{background:var(--navy);color:#fff;padding:clamp(62px,9vw,108px) 0}
.mentor .wrap{max-width:820px}
.mentor .eyebrow-gold{color:var(--gold);text-align:center;margin-bottom:14px}
.mentor-title{font-family:var(--d);font-style:italic;font-weight:600;color:#fff;font-size:clamp(2.4rem,5.6vw,4rem);text-align:center;line-height:1;margin-bottom:clamp(28px,4vw,46px)}
.mentor-title em{color:var(--gold)}
.mentor-body p{font-size:clamp(1.02rem,1.5vw,1.18rem);line-height:1.72;color:#dfe7f0;margin-bottom:1.25em}
.mentor-attr{margin-top:6px;font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:.9rem}
.mentor-book{margin-top:clamp(28px,4vw,44px);background:rgba(255,255,255,.05);border:1px solid rgba(255,193,7,.4);border-radius:12px;padding:clamp(22px,3vw,32px);text-align:center}
.mentor-book .ph{color:var(--gold);font-size:1.7rem}
.mentor-book p{font-family:var(--d);font-style:italic;font-size:clamp(1.15rem,2vw,1.5rem);color:#fff;line-height:1.3;margin:10px 0 0}
.mentor-book strong{color:var(--gold);font-weight:700}
@media(max-width:560px){.team-grid{grid-template-columns:1fr;max-width:360px}}

/* donation modal — brand wrapper around the embedded Zeffy form */
.zmodal{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(0,18,40,.78);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.zmodal.open{display:flex}
.zmodal-panel{position:relative;width:min(560px,96vw);max-height:94vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--cream);border-radius:18px;padding:30px 26px 22px;box-shadow:0 40px 90px -30px rgba(0,0,0,.6)}
.zmodal-close{position:absolute;top:12px;right:16px;background:none;border:0;color:var(--muted);font-size:2.1rem;line-height:1;cursor:pointer;transition:color .15s}
.zmodal-close:hover{color:var(--navy)}
.zmodal-head{text-align:center;margin-bottom:18px}
.zmodal-eyebrow{font-family:var(--f);font-weight:800;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--gold-deep);margin:0 0 6px}
.zmodal-title{font-family:var(--d);font-style:italic;font-weight:900;color:var(--navy);font-size:clamp(1.7rem,4vw,2.3rem);line-height:1;margin:0}
.zmodal-sub{font-family:var(--f);color:var(--muted);font-size:.95rem;line-height:1.4;margin:10px auto 0;max-width:40ch}
.zmodal-stage{min-height:520px}
.zmodal-iframe{display:block;width:100%;height:72vh;min-height:560px;border:0;border-radius:10px;background:#fff}
.zmodal-fallback{text-align:center;font-family:var(--f);font-size:.85rem;color:var(--muted);margin:14px 0 2px}
.zmodal-fallback a{color:var(--gold-deep);font-weight:700}
.zmodal-fallback a:hover{color:var(--navy)}
@media(max-width:760px){
  .zmodal{padding:0}
  .zmodal-panel{width:100vw;max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;border-radius:0;padding:24px 16px 16px}
  .zmodal-iframe{height:78vh}
}

/* Get Involved lead-capture form (inside the shared .zmodal shell) */
.lead-panel{width:min(440px,96vw)}
.lead-form{display:flex;flex-direction:column;gap:13px;text-align:left;margin-top:2px}
.lead-form label{display:flex;flex-direction:column;gap:6px;font-family:var(--f);font-weight:800;font-size:.76rem;letter-spacing:.04em;text-transform:uppercase;color:var(--navy)}
.lead-form .opt{font-weight:600;color:var(--muted);text-transform:none;letter-spacing:0}
.lead-form input,.lead-form select,.lead-form textarea{font-family:var(--f);font-size:1rem;font-weight:400;color:var(--navy);text-transform:none;letter-spacing:0;background:#fff;border:1.5px solid rgba(0,31,63,.16);border-radius:10px;padding:11px 13px;transition:border-color .15s,box-shadow .15s}
.lead-form select{cursor:pointer}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,193,7,.25)}
.lead-form textarea{resize:vertical;min-height:72px}
.lead-row{display:flex;gap:12px}
.lead-row label{flex:1;min-width:0}
.lead-submit{width:100%;justify-content:center;margin-top:4px;border:0;cursor:pointer}
.lead-submit[disabled]{opacity:.7;cursor:default}
.lead-status{font-family:var(--f);font-size:.9rem;text-align:center;margin:2px 0 0}
.lead-status.err{color:#c0392b}
.lead-thanks{font-family:var(--f);color:var(--navy);font-size:1.02rem;line-height:1.5;text-align:center;padding:12px 6px 8px}
.lead-thanks .ph{color:var(--gold-deep);font-size:1.6rem;display:block;margin-bottom:8px}
@media(max-width:760px){.lead-panel{height:auto;max-height:94vh;border-radius:0}}
@media(max-width:520px){.lead-row{flex-direction:column;gap:13px}}

/* Donate perk — "$20+ gets a tee" callout in the donate copy column */
.donate-perk{display:flex;gap:12px;align-items:flex-start;margin-top:22px;padding:14px 16px;background:rgba(255,193,7,.14);border:1px solid rgba(255,193,7,.55);border-radius:14px}
.donate-perk > .ph{font-size:1.7rem;color:var(--gold);flex:none;margin-top:1px}
.donate-perk b{display:block;font-family:var(--f);font-weight:800;color:#fff;font-size:1rem;margin-bottom:3px}
.donate-perk span{display:block;font-family:var(--f);font-size:.9rem;color:#c4d0df;line-height:1.5}
.donate-perk a{color:var(--gold);font-weight:800;text-decoration:underline;white-space:nowrap}
.donate-perk a:hover{color:#fff}

/* Claim-your-shirt CTA inside the donate popup (cream panel → dark text) */
.zmodal-claim{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 12px;margin-top:14px;padding:13px 16px;background:rgba(255,193,7,.14);border:1px solid rgba(255,193,7,.55);border-radius:12px;text-align:center}
.zmodal-claim span{font-family:var(--f);font-weight:700;color:var(--navy);font-size:.95rem}
.zmodal-claim-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--f);font-weight:800;color:var(--navy);background:var(--gold);padding:9px 16px;border-radius:999px;font-size:.92rem;transition:background .15s}
.zmodal-claim-btn:hover{background:var(--gold-deep)}
.zmodal-claim-btn .ph{font-size:1.1rem}

/* Donate popup = fixed-height flex column so the claim CTA is a permanent footer:
   always visible, sits BELOW the Zeffy iframe (never overlaps its fields), no scroll.
   Scoped to #zeffyModal so the short lead/claim modals keep their auto height. */
#zeffyModal .zmodal-panel{display:flex;flex-direction:column;height:min(96vh,940px);overflow:hidden;padding:20px 24px 16px}
#zeffyModal .zmodal-head,#zeffyModal .zmodal-fallback,#zeffyModal .zmodal-claim{flex:none}
#zeffyModal .zmodal-head{margin-bottom:8px}
#zeffyModal .zmodal-title{font-size:clamp(1.4rem,3vw,1.95rem)}
#zeffyModal .zmodal-sub{margin-top:5px;font-size:.9rem}
#zeffyModal .zmodal-stage{flex:1 1 auto;min-height:0}
#zeffyModal .zmodal-iframe{height:100%;min-height:0}
#zeffyModal .zmodal-claim{margin-top:10px}
#zeffyModal .zmodal-fallback{margin:8px 0 0}
@media(max-width:760px){#zeffyModal .zmodal-panel{height:100vh;height:100dvh;padding:18px 16px 14px}}

/* R.E.A.D. program photo — frame the faces (tall group shot in a short strip) */
#programs .prog-photo img.prog-faces{object-position:center 22%}
