:root{
  --bg:#fbfaf6;
  --bg-tint:#f3f0e8;
  --panel:#ffffff;
  --blue:#3A84C5;
  --blue-soft:#5a93cc;
  --blue-deep:#23597f;
  --gold:#D59F00;
  --gold-soft:#b88600;
  --ink:#14202c;
  --navy:#16283a;
  --muted:#5b6875;
  --line:rgba(22,40,58,.12);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Albert Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:#fff}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.05;letter-spacing:-.01em}

/* ---------- atmosphere ---------- */
.glow{position:fixed;inset:0;z-index:0;pointer-events:none}
.glow::after{
  content:"";position:absolute;bottom:-25%;right:-12%;
  width:820px;height:820px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,132,197,.07) 0%,transparent 64%);
}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.content{position:relative;z-index:2}

/* ---------- nav ---------- */
header{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  background:linear-gradient(to bottom,rgba(251,250,246,.92),rgba(251,250,246,.7));
  border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:92px}
nav a[aria-label]{display:inline-flex;align-items:center}
nav img{height:120px;width:auto;display:block}
.nav-links{display:flex;gap:38px;align-items:center}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.86rem;letter-spacing:.04em;
  text-transform:uppercase;transition:color .25s}
.nav-links a:hover{color:var(--navy)}
.btn{font-family:'Albert Sans',system-ui,sans-serif;font-weight:500;font-size:.9rem;letter-spacing:.01em;
  text-decoration:none;display:inline-flex;align-items:center;gap:.5em;border-radius:2px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s,border-color .25s}
/* arrow that nudges on hover */
.btn .arr{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);will-change:transform}
.btn:hover .arr{transform:translateX(4px)}
/* gold shine sweep */
.btn-gold{background:var(--gold);color:var(--navy);padding:.72em 1.5em;font-weight:600;
  box-shadow:0 0 0 rgba(213,159,0,0)}
.btn-gold::before{content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg);transition:left .6s ease;pointer-events:none}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(213,159,0,.32)}
.btn-gold:hover::before{left:140%}
.nav-links a.btn-gold{color:var(--navy)}
.btn-ghost{border:1px solid var(--line);color:var(--navy);padding:.72em 1.5em;background:transparent}
.btn-ghost:hover{border-color:var(--blue);background:rgba(58,132,197,.07);transform:translateY(-2px)}
@media(max-width:760px){.nav-links a:not(.btn){display:none}}

/* ---------- hero ---------- */
.hero{padding:120px 0 110px;position:relative;overflow:hidden}
.sunrays{position:absolute;top:-180px;right:-160px;width:680px;height:680px;z-index:0;
  pointer-events:none;opacity:.5;
  background:repeating-conic-gradient(from 0deg,
    rgba(213,159,0,.13) 0deg,rgba(213,159,0,.13) 2.2deg,
    transparent 2.2deg,transparent 9deg);
  -webkit-mask:radial-gradient(circle,#000 7%,rgba(0,0,0,.5) 30%,transparent 62%);
  mask:radial-gradient(circle,#000 7%,rgba(0,0,0,.5) 30%,transparent 62%);
  animation:spin 60s linear infinite;will-change:transform}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.hero .wrap{position:relative;z-index:2}
@media(max-width:760px){.sunrays{width:440px;height:440px;top:-120px;right:-140px;opacity:.35}}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hero-headline{font-size:clamp(2.9rem,7vw,5.6rem);max-width:14ch;color:var(--navy);
  font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.05;letter-spacing:-.01em}
.hero-headline .word{display:inline-block;opacity:0;transform:translateY(28px);
  animation:rise .9s cubic-bezier(.2,.7,.2,1) both;will-change:transform,opacity}
.hero-headline em{font-style:italic;color:var(--blue)}
.sun-accent{color:var(--gold)}
.hero p.lede{font-size:1.18rem;color:var(--muted);max-width:52ch;margin:34px 0 42px;font-weight:300;
  opacity:0;animation:rise .9s .85s cubic-bezier(.2,.7,.2,1) both}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:rise .9s 1s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ---------- stat ribbon ---------- */
.ribbon{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-tint),transparent)}
.ribbon .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-top:46px;padding-bottom:46px}
.stat{position:relative;padding-left:22px}
.stat::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--gold),transparent)}
.stat .num{font-family:'Fraunces',Georgia,serif;font-size:2.7rem;font-weight:600;color:var(--navy);line-height:1}
.stat .num span{color:var(--gold)}
.stat .num .cnum{color:var(--navy)}
.stat .lab{font-size:.82rem;color:var(--muted);margin-top:10px;letter-spacing:.02em}
@media(max-width:760px){.ribbon .wrap{grid-template-columns:repeat(2,1fr);gap:34px 20px}}

/* ---------- section base ---------- */
section{padding:110px 0}
.sec-eyebrow{color:var(--blue);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;margin-bottom:18px}
.reveal{opacity:0;transform:translateY(34px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
  will-change:transform,opacity}
.reveal.in{opacity:1;transform:none}

/* ---------- mission ---------- */
.mission{display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:center}
.mission h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:0;color:var(--navy)}
.mission .body{font-size:1.12rem;color:#3f4b57;font-weight:300}
.mission .body p+p{margin-top:22px}
.mission .body strong{color:var(--navy);font-weight:600}
.pull{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:1.5rem;color:var(--blue-deep);
  border-left:2px solid var(--gold);padding-left:24px;margin:6px 0 0;line-height:1.4}
@media(max-width:860px){.mission{grid-template-columns:1fr;gap:40px}}

/* ---------- programs ---------- */
.programs{background:linear-gradient(180deg,transparent,var(--bg-tint),transparent)}
.prog-head{max-width:62ch;margin-bottom:64px}
.prog-head h2{font-size:clamp(2rem,4vw,3rem);color:var(--navy)}
.prog-head p{color:var(--muted);margin-top:18px;font-size:1.1rem}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:860px){.cards{grid-template-columns:1fr}}
.card{position:relative;background:var(--panel);
  border:1px solid var(--line);border-radius:6px;padding:42px 38px;overflow:hidden;
  box-shadow:0 1px 2px rgba(22,40,58,.04),0 18px 40px rgba(22,40,58,.06);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s}
.card:hover{transform:translateY(-6px);border-color:rgba(58,132,197,.45);
  box-shadow:0 1px 2px rgba(22,40,58,.05),0 28px 56px rgba(22,40,58,.12)}
.card::after{content:"";position:absolute;top:0;right:0;width:160px;height:160px;
  background:radial-gradient(circle at top right,rgba(213,159,0,.16),transparent 70%);
  opacity:0;transition:opacity .4s}
.card:hover::after{opacity:1}
.card .tag{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);
  font-weight:600;display:inline-block;margin-bottom:18px}
.card h3{font-size:1.6rem;margin-bottom:14px;color:var(--navy)}
.card p{color:var(--muted);font-size:1.02rem}
.card .hl{color:var(--blue-deep);font-weight:500}
.card-foot{margin-top:26px;padding-top:22px;border-top:1px solid var(--line);
  font-size:.95rem;color:#3f4b57;display:flex;align-items:baseline;gap:.5em}
.card-foot b{font-family:'Fraunces',Georgia,serif;color:var(--gold);font-size:1.3rem;font-weight:600}

/* ---------- year in review ---------- */
.review h2{font-size:clamp(2rem,4vw,3rem);max-width:16ch;margin-bottom:14px;color:var(--navy)}
.review .sub{color:var(--muted);font-size:1.1rem;max-width:54ch;margin-bottom:60px}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.timeline::before{content:"";position:absolute;top:9px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),var(--gold),transparent);
  transform:scaleX(0);transform-origin:left center;
  transition:transform 1.4s cubic-bezier(.65,.05,.2,1)}
.timeline.drawn::before{transform:scaleX(1)}
.tl{padding:0 18px 0 0;position:relative}
.tl .dot{width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--blue);
  position:relative;z-index:2;margin-bottom:24px;
  transform:scale(0);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
.timeline.drawn .tl .dot{transform:scale(1)}
.tl:last-child .dot{border-color:var(--gold);background:var(--gold)}
.tl .q,.tl h4,.tl p{opacity:0;transform:translateY(12px);
  transition:opacity .6s ease,transform .6s ease}
.timeline.drawn .tl .q{transition-delay:.15s}
.timeline.drawn .tl h4{transition-delay:.22s}
.timeline.drawn .tl p{transition-delay:.29s}
.timeline.drawn .tl .q,.timeline.drawn .tl h4,.timeline.drawn .tl p{opacity:1;transform:none}
.timeline.drawn .tl:nth-child(1) .dot{transition-delay:.15s}
.timeline.drawn .tl:nth-child(2) .dot{transition-delay:.45s}
.timeline.drawn .tl:nth-child(2) .q{transition-delay:.5s}
.timeline.drawn .tl:nth-child(2) h4{transition-delay:.57s}
.timeline.drawn .tl:nth-child(2) p{transition-delay:.64s}
.timeline.drawn .tl:nth-child(3) .dot{transition-delay:.75s}
.timeline.drawn .tl:nth-child(3) .q{transition-delay:.8s}
.timeline.drawn .tl:nth-child(3) h4{transition-delay:.87s}
.timeline.drawn .tl:nth-child(3) p{transition-delay:.94s}
.timeline.drawn .tl:nth-child(4) .dot{transition-delay:1.05s}
.timeline.drawn .tl:nth-child(4) .q{transition-delay:1.1s}
.timeline.drawn .tl:nth-child(4) h4{transition-delay:1.17s}
.timeline.drawn .tl:nth-child(4) p{transition-delay:1.24s}
.tl .q{font-family:'Fraunces',Georgia,serif;color:var(--gold-soft);font-size:.95rem;font-weight:600;
  letter-spacing:.05em;margin-bottom:8px}
.tl h4{font-family:'Fraunces',Georgia,serif;font-size:1.15rem;font-weight:600;margin-bottom:8px;color:var(--navy)}
.tl p{font-size:.92rem;color:var(--muted)}
@media(max-width:860px){
  .timeline{grid-template-columns:1fr;gap:30px}
  .timeline::before{top:0;bottom:0;left:5px;right:auto;width:1px;height:auto;
    background:linear-gradient(180deg,var(--blue),var(--gold));
    transform:scaleY(0);transform-origin:top center}
  .timeline.drawn::before{transform:scaleY(1)}
  .tl{padding:0 0 0 30px}
  .tl .dot{position:absolute;left:0;top:2px;margin:0}
}

/* ---------- cta band ---------- */
.band{position:relative;text-align:center;padding:120px 0;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent,rgba(58,132,197,.05),transparent)}
.band h2{font-size:clamp(2.2rem,5vw,3.8rem);max-width:18ch;margin:0 auto 22px;position:relative;color:var(--navy)}
.band h2 em{font-style:italic;color:var(--gold)}
.band p{color:var(--muted);font-size:1.15rem;max-width:46ch;margin:0 auto 40px;position:relative}
.band .hero-cta{justify-content:center;animation:none;opacity:1}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:64px 0 50px;background:var(--bg-tint)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;align-items:start}
footer img{height:56px;width:auto;margin-bottom:20px;display:block}
footer .desc{color:var(--muted);font-size:.96rem;max-width:38ch}
.foot-col h5{font-family:'Albert Sans',system-ui,sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue-deep);margin-bottom:18px}
.foot-col a,.foot-col address{display:block;color:var(--muted);text-decoration:none;font-size:.96rem;
  font-style:normal;line-height:1.9;transition:color .25s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-bottom{margin-top:54px;padding-top:26px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  color:#8b96a1;font-size:.84rem}
.badge{display:inline-flex;align-items:center;gap:.5em;color:var(--muted);font-size:.84rem;
  border:1px solid var(--line);border-radius:40px;padding:.4em 1em}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:40px}}

