/* =================================================================
   HAITI SCHOLARSHIPS — design system
   Field-journal editorial. Deep Haitian indigo + one clay accent
   on bone paper. Newsreader (display) + Inter (workhorse).
   ================================================================= */

/* Fonts: Sentient (editorial serif w/ character) + Switzer (humanist grotesque), via Fontshare. */
@import url('https://api.fontshare.com/v2/css?f[]=sentient@400,500,700&f[]=switzer@400,500,600,700&display=swap');

/* ---------- tokens ----------
   Palette pulled from the land of Haiti: jungle green + warm gold on
   ivory, with a single Haitian-coral accent. (Token names --blue/--clay
   are kept for plumbing; the values are green/coral.) */
:root{
  /* paper + ink — warm cream */
  --paper:      #f4efe1;   /* warm cream */
  --paper-2:    #e6dcc5;   /* deeper cream surface */
  --paper-3:    #fbf7ec;   /* lifted card */
  --ink:        #1b211a;   /* deep green-black */
  --ink-soft:   #4e554a;   /* muted text */
  --ink-faint:  #828a7b;   /* captions */
  --rule:       #dbd3bd;   /* hairline */
  --rule-soft:  #e7dfcb;

  /* dark fields: deep forest green (the brand) */
  --blue:       #1f3b2c;
  --blue-deep:  #14271d;
  --blue-mid:   #3c6b48;   /* mid green: links + accents on cream */
  --blue-tint:  #dfe7da;

  /* the accent is green itself; solid buttons use this deep green */
  --clay:       #25513a;
  --clay-deep:  #1a3c29;
  --clay-tint:  #dde7dc;

  --gold:       #bcd2ab;   /* soft sage, used only on dark green fields */

  --topo: url("assets/img/topography.svg");   /* mountains texture for dark sections */

  /* type */
  --serif: 'Sentient', ui-serif, Georgia, 'Times New Roman', serif;
  --sans:  'Switzer', ui-sans-serif, system-ui, -apple-system, sans-serif;

  /* fluid scale (1.25, 320–1280) */
  --s-1:  clamp(0.80rem, 0.78rem + 0.09vw, 0.86rem);
  --s0:   clamp(1.00rem, 0.95rem + 0.22vw, 1.15rem);
  --s1:   clamp(1.20rem, 1.10rem + 0.45vw, 1.45rem);
  --s2:   clamp(1.45rem, 1.27rem + 0.80vw, 1.95rem);
  --s3:   clamp(1.85rem, 1.55rem + 1.30vw, 2.70rem);
  --s4:   clamp(2.30rem, 1.85rem + 2.05vw, 3.70rem);
  --s5:   clamp(2.90rem, 2.20rem + 3.20vw, 5.10rem);
  --s6:   clamp(3.40rem, 2.30rem + 5.00vw, 7.00rem);

  /* spacing */
  --sp-2: .5rem;  --sp-3: .75rem; --sp-4: 1rem;  --sp-5: 1.5rem;
  --sp-6: 2rem;   --sp-7: 3rem;   --sp-8: 4rem;  --sp-9: 6rem;
  --sp-10: 8rem;  --sp-11: 11rem;

  --page: clamp(1.25rem, 6vw, 7rem);
  --measure: 64ch;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:var(--s0); line-height:1.65;
  font-weight:400; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:var(--clay-deep); text-decoration:none; }
a:hover{ color:var(--ink); }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.08;
  letter-spacing:-.015em; margin:0; font-optical-sizing:auto; }
::selection{ background:var(--clay); color:#fff; }
:focus-visible{ outline:2px solid var(--clay); outline-offset:3px; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; padding-inline:var(--page); }
.section{ padding-block:clamp(3.5rem,9vw,7rem); }
.measure{ max-width:var(--measure); }
.center{ margin-inline:auto; }

.eyebrow{
  font-family:var(--sans); font-size:var(--s-1); font-weight:600;
  text-transform:uppercase; letter-spacing:.18em; color:var(--clay-deep);
  display:inline-flex; align-items:center; gap:.6rem; margin:0 0 1.2rem;
}
.eyebrow::before{ content:""; width:1.8rem; height:2px; background:var(--clay); display:inline-block; }
.eyebrow.on-dark{ color:var(--gold); }
.eyebrow.on-dark::before{ background:var(--gold); }

.kicker{ /* numbered chapter marker */
  font-family:var(--sans); font-size:var(--s-1); font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint);
}

.lede{ font-family:var(--serif); font-weight:400; font-size:var(--s2);
  line-height:1.42; letter-spacing:-.01em; color:var(--ink); max-width:30ch; }
.prose{ max-width:var(--measure); }
.prose p{ margin:0 0 1.25em; }
.prose p:last-child{ margin-bottom:0; }
.muted{ color:var(--ink-soft); }
.serif{ font-family:var(--serif); }

h2.display{ font-size:var(--s4); }
h2.big{ font-size:var(--s5); letter-spacing:-.025em; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55rem; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:var(--s-1);
  letter-spacing:.04em; text-transform:uppercase;
  padding:.95rem 1.6rem; border:1.5px solid transparent; border-radius:8px;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  line-height:1; white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn--clay{ background:var(--clay); color:var(--paper); }
.btn--clay:hover{ background:var(--clay-deep); color:var(--paper); }
.btn--ink{ background:var(--ink); color:var(--paper); }
.btn--ink:hover{ background:#000; color:var(--paper); }
.btn--cream{ background:var(--paper); color:var(--blue); }
.btn--cream:hover{ background:#fff; color:var(--blue-deep); }
.btn--green{ background:#2f7d4d; color:#fff; }
.btn--green:hover{ background:#27693f; color:#fff; }
.btn--outline{ border-color:var(--blue); color:var(--blue); background:transparent; }
.btn--outline:hover{ background:var(--blue); color:var(--paper-3); }
.btn--ghost-light{ border-color:rgba(255,255,255,.5); color:#fff; background:transparent; }
.btn--ghost-light:hover{ background:#fff; color:var(--blue-deep); border-color:#fff; }
.btn--glass{ background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.32);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }
.btn--glass:hover{ background:rgba(255,255,255,.92); color:var(--blue-deep); border-color:transparent; }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(3px); }
.btn-row{ display:flex; flex-wrap:wrap; gap:.9rem; }

/* link with underline grow */
.link-arrow{ font-family:var(--sans); font-weight:600; letter-spacing:.02em;
  color:var(--blue); display:inline-flex; gap:.4rem; align-items:center;
  border-bottom:2px solid var(--clay); padding-bottom:2px; }
.link-arrow:hover{ color:var(--clay-deep); }
.link-arrow .arr{ transition:transform .25s var(--ease); }
.link-arrow:hover .arr{ transform:translateX(4px); }

/* ====================================================================
   HEADER
   ==================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background:rgba(20,39,29,.30); -webkit-backdrop-filter:blur(16px) saturate(1.3);
  backdrop-filter:blur(16px) saturate(1.3); border-bottom:1px solid rgba(255,255,255,.12);
  transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease); }
.site-header.solid{
  background:rgba(244,239,225,.82); border-bottom-color:var(--rule);
  box-shadow:0 6px 26px -18px rgba(20,30,20,.45); }
/* full-width bar with generous breathing room */
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  padding:1.2rem var(--page); transition:padding .35s var(--ease); }
.site-header.solid .nav{ padding-block:.85rem; }

.brand{ display:flex; align-items:center; gap:.7rem; color:var(--ink); }
.brand:hover{ color:var(--ink); }
.brand .mark{ width:32px; height:32px; flex:none; color:#fff; transition:color .4s var(--ease); }
.brand .wm{ display:flex; flex-direction:column; line-height:1; }
.brand .wm b{ font-family:var(--serif); font-weight:700; font-size:1.15rem;
  letter-spacing:-.01em; color:#fff; transition:color .4s var(--ease); }
.brand .wm span{ font-family:var(--sans); font-size:.56rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.22em; color:rgba(255,255,255,.66); margin-top:.2rem;
  transition:color .4s var(--ease); }

/* solid state: dark text on light glass */
.site-header.solid .brand .mark{ color:var(--clay); }
.site-header.solid .brand .wm b{ color:var(--ink); }
.site-header.solid .brand .wm span{ color:var(--ink-faint); }
.site-header.solid .nav-links a{ color:var(--ink-soft); }
.site-header.solid .nav-links a:hover{ color:var(--ink); }
.site-header.solid .nav-toggle{ color:var(--ink); }

.nav-links{ display:flex; align-items:center; gap:1.5rem; list-style:none; margin:0; padding:0; }
.nav-links a{ font-family:var(--sans); font-size:.82rem; font-weight:500;
  letter-spacing:.02em; color:rgba(255,255,255,.86); position:relative; padding-block:.4rem; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:2px;
  background:var(--gold); transition:width .25s var(--ease); }
.site-header.solid .nav-links a::after{ background:var(--clay); }
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after{ width:100%; }
.nav-links a[aria-current="page"]{ color:#fff; }
.site-header.solid .nav-links a[aria-current="page"]{ color:var(--ink); }
.nav-cta{ padding:.72rem 1.35rem; background:var(--paper); border-color:transparent; }
.nav-links a.nav-cta{ color:var(--blue); }
.nav-links a.nav-cta::after{ display:none; }
.nav-cta:hover{ background:#fff; }
.nav-links a.nav-cta:hover{ color:var(--blue-deep); }
.site-header.solid .nav-cta{ background:var(--blue); }
.site-header.solid .nav-links a.nav-cta{ color:var(--paper); }
.site-header.solid .nav-cta:hover{ background:var(--blue-deep); }
.site-header.solid .nav-links a.nav-cta:hover{ color:var(--paper); }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:.4rem;
  color:#fff; }
.nav-toggle svg{ width:26px; height:26px; }

/* ====================================================================
   HERO (full-bleed)
   ==================================================================== */
.hero{ position:relative; height:100svh; min-height:33rem; max-height:52rem;
  display:flex; align-items:flex-end; overflow:hidden; background:var(--blue-deep); }
.hero__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.03); transform-origin:62% 42%; }
/* light scrim only: the glass card carries the text, photo stays open */
.hero__scrim{ position:absolute; inset:0;
  background:
    linear-gradient(to top, rgba(15,28,20,.5) 0%, rgba(15,28,20,0) 42%),
    linear-gradient(to bottom, rgba(15,28,20,.34) 0%, rgba(15,28,20,0) 22%); }
.hero__inner{ position:relative; z-index:2; width:100%;
  padding-bottom:clamp(2.5rem,6vh,4.5rem); }

/* reusable frosted green glass case */
.glass-card{ background:rgba(22,43,32,.52); -webkit-backdrop-filter:blur(22px) saturate(1.3);
  backdrop-filter:blur(22px) saturate(1.3); border:1px solid rgba(255,255,255,.17);
  border-radius:14px; box-shadow:0 30px 72px -32px rgba(0,0,0,.62); color:var(--paper); }
.hero__card{ max-width:35rem; padding:clamp(1.9rem,3.2vw,2.6rem) clamp(1.9rem,3.2vw,2.7rem); }
.hero__card .eyebrow{ margin-bottom:1rem; }
.hero h1{ color:#fcf9f1; font-size:clamp(2.3rem,1.3rem+3.2vw,3.6rem); font-weight:600;
  letter-spacing:-.02em; line-height:1.05; margin:0; }
.hero h1 em{ font-style:normal; color:var(--gold); white-space:nowrap; }
.hero__lede{ color:rgba(252,249,241,.85); font-family:var(--sans); font-size:1.02rem;
  line-height:1.5; margin:1.05rem 0 1.6rem; max-width:40ch; }
.hero .btn-row{ align-items:stretch; gap:.75rem; }
.hero .btn{ min-height:3rem; padding-block:0; }
.hero__cap{ position:absolute; right:var(--page); bottom:1.4rem; z-index:2;
  font-family:var(--sans); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(255,255,255,.5); }
.hero__scroll{ position:absolute; left:50%; transform:translateX(-50%); bottom:1.3rem; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.55rem; color:rgba(255,255,255,.55);
  font-family:var(--sans); font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; }
.hero__scroll .bar{ width:1px; height:40px; background:rgba(255,255,255,.25); position:relative; overflow:hidden; }
.hero__scroll .bar::after{ content:""; position:absolute; inset:0; transform:translateY(-100%);
  background:linear-gradient(var(--gold),transparent); animation:scrolldrop 2s var(--ease) infinite; }
@keyframes scrolldrop{ 0%{ transform:translateY(-100%) } 70%,100%{ transform:translateY(100%) } }
@media(max-width:640px){ .hero__scroll,.hero__cap{ display:none; } }

/* compact page header for interior pages */
.page-head{ position:relative; min-height:60vh; display:flex; align-items:flex-end;
  background:var(--blue-deep); color:var(--paper); overflow:hidden; }
.page-head__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-head__scrim{ position:absolute; inset:0;
  background:
    linear-gradient(to top, rgba(15,28,20,.55) 0%, rgba(15,28,20,0) 46%),
    linear-gradient(to bottom, rgba(15,28,20,.4) 0%, rgba(15,28,20,0) 24%); }
.page-head__inner{ position:relative; z-index:2; width:100%;
  padding-top:clamp(7rem,13vw,9rem); padding-bottom:clamp(2.5rem,6vh,4rem); }
.page-head__card{ max-width:42rem;
  padding:clamp(1.7rem,3vw,2.4rem) clamp(1.8rem,3vw,2.6rem); }
.page-head__card .eyebrow{ margin-bottom:.9rem; }
.page-head h1{ color:#fcf9f1; font-size:clamp(1.9rem,1.15rem+2.6vw,3.1rem); max-width:20ch;
  margin:0; line-height:1.08; }
.page-head__lede{ color:rgba(252,249,241,.84); font-family:var(--sans); font-size:1.02rem;
  max-width:46ch; line-height:1.5; margin-top:1rem; }

/* ====================================================================
   STAT BAND (deep blue)
   ==================================================================== */
.statband{ background:var(--blue); color:var(--paper); }
.statband .wrap{ padding-block:clamp(3rem,7vw,5rem); }
.statband__intro{ max-width:40ch; margin-bottom:2.6rem; }
.statband__intro h2{ color:#fff; font-size:var(--s3); }
.statband__intro p{ color:rgba(255,255,255,.72); margin:.8rem 0 0; }
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3rem);
  border-top:1px solid rgba(255,255,255,.18); padding-top:2.4rem; }
.stat__num{ font-family:var(--serif); font-weight:600; font-size:var(--s5);
  line-height:1; color:var(--gold); letter-spacing:-.02em; }
.stat__num small{ font-size:.42em; font-weight:600; vertical-align:.55em; margin-right:.1em; }
.stat__lab{ display:block; margin-top:.7rem; font-family:var(--sans); font-weight:600;
  font-size:.96rem; color:#fff; }
.stat__sub{ display:block; margin-top:.35rem; color:rgba(255,255,255,.62); font-size:.85rem; line-height:1.5; }
@media(max-width:680px){ .stats{ grid-template-columns:1fr; gap:2rem; } }

/* ====================================================================
   SPLIT / FEATURE rows
   ==================================================================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem);
  align-items:center; }
.split.narrow-text{ grid-template-columns:1.05fr .95fr; }
.split--rev .split__media{ order:2; }
.split__media figure{ margin:0; }
.split__media img{ width:100%; aspect-ratio:4/3; object-fit:cover;
  box-shadow:0 24px 50px -28px rgba(20,40,70,.5); }
.split__body h2{ font-size:var(--s4); margin-bottom:1.2rem; }
@media(max-width:860px){
  .split,.split.narrow-text{ grid-template-columns:1fr; gap:2rem; }
  .split--rev .split__media{ order:0; }
}

figcaption,.caption{ font-family:var(--sans); font-size:.74rem; letter-spacing:.04em;
  color:var(--ink-faint); margin-top:.7rem; text-transform:uppercase; line-height:1.5; }
.caption .who{ color:var(--ink-soft); }

/* ====================================================================
   FULL-BLEED PHOTO band w/ caption
   ==================================================================== */
.photoband{ position:relative; }
.photoband img{ width:100%; height:clamp(20rem,52vw,38rem); object-fit:cover; }
.photoband figcaption{ position:absolute; left:var(--page); bottom:1rem;
  color:rgba(255,255,255,.82); margin:0; text-shadow:0 1px 8px rgba(0,0,0,.6); }

/* ====================================================================
   PULL QUOTE
   ==================================================================== */
.quote{ background:var(--paper-2); border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); }
.quote .wrap{ padding-block:clamp(3.5rem,8vw,6rem); display:grid;
  grid-template-columns:minmax(0,1fr); }
.quote blockquote{ margin:0; max-width:24ch; }
.quote .mark{ font-family:var(--serif); font-size:5rem; line-height:.6; color:var(--clay);
  display:block; height:2.2rem; }
.quote blockquote p{ font-family:var(--serif); font-weight:500;
  font-size:clamp(1.45rem,1.1rem+1.4vw,2.15rem); line-height:1.28;
  letter-spacing:-.01em; color:var(--ink); margin:.6rem 0 1.5rem; max-width:24ch; }
.quote .mark{ font-size:3.4rem; height:1.4rem; }
.quote cite{ font-style:normal; font-family:var(--sans); font-size:.9rem; font-weight:600;
  letter-spacing:.04em; color:var(--ink-soft); }
.quote cite span{ display:block; color:var(--ink-faint); font-weight:400; margin-top:.2rem; }
@media(min-width:861px){
  .quote .wrap{ grid-template-columns:30% 1fr; gap:3rem; align-items:start; }
  .quote p{ max-width:none; }
  .quote blockquote{ max-width:none; }
}

/* ====================================================================
   CHAPTER heading (numbered)
   ==================================================================== */
.chapter-head{ display:flex; align-items:baseline; gap:1.2rem; margin-bottom:2.4rem;
  border-bottom:1px solid var(--rule); padding-bottom:1.4rem; }
.chapter-head .no{ font-family:var(--serif); font-size:var(--s2); color:var(--clay); font-weight:600; }
.chapter-head h2{ font-size:var(--s3); }

/* ====================================================================
   GALLERY (students)
   ==================================================================== */
.gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(.8rem,1.6vw,1.4rem); }
.gallery figure{ margin:0; position:relative; }
.gallery img{ width:100%; height:100%; object-fit:cover; }
.g-a{ grid-column:span 7; } .g-a img{ aspect-ratio:3/2; }
.g-b{ grid-column:span 5; } .g-b img{ aspect-ratio:3/2; }
.g-c{ grid-column:span 4; } .g-c img{ aspect-ratio:1/1; }
.g-d{ grid-column:span 4; } .g-d img{ aspect-ratio:1/1; }
.g-e{ grid-column:span 4; } .g-e img{ aspect-ratio:1/1; }
.gallery figcaption{ position:absolute; left:.8rem; bottom:.7rem; right:.8rem;
  color:#fff; margin:0; text-shadow:0 1px 6px rgba(0,0,0,.7); }
@media(max-width:760px){
  .g-a,.g-b{ grid-column:span 12; }
  .g-c,.g-d,.g-e{ grid-column:span 6; }
}

/* ====================================================================
   WAYS-TO-GIVE editorial list
   ==================================================================== */
.ways{ display:grid; gap:0; }
.way{ display:grid; grid-template-columns:auto 1fr auto; gap:1.6rem; align-items:start;
  padding:2rem 0; border-top:1px solid var(--rule); }
.way:last-child{ border-bottom:1px solid var(--rule); }
.way .wn{ display:grid; place-items:center; width:3rem; height:3rem; border-radius:11px;
  background:var(--clay-tint); color:var(--clay-deep); flex:none; }
.way .wn .ic{ width:1.4rem; height:1.4rem; }
.way h3{ font-family:var(--serif); font-size:var(--s2); font-weight:600; margin:0 0 .5rem; }
.way p{ margin:0; color:var(--ink-soft); max-width:60ch; }
.way .wcta{ align-self:center; }
@media(max-width:680px){
  .way{ grid-template-columns:auto 1fr; }
  .way .wcta{ grid-column:1/-1; margin-top:.5rem; }
}

/* ====================================================================
   CARDS (board, give tiers)
   ==================================================================== */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.5vw,2rem); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.2rem,2.5vw,2rem); }
@media(max-width:860px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .grid-3,.grid-2{ grid-template-columns:1fr; } }

.person{ border-top:2px solid var(--ink); padding-top:1.1rem; }
.person h3{ font-family:var(--serif); font-size:var(--s2); margin:0; }
.person .role{ font-family:var(--sans); font-size:.78rem; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--clay-deep); margin:.35rem 0 .8rem; }
.person p{ margin:0; color:var(--ink-soft); font-size:.95rem; }

/* give tier cards */
.tier{ background:var(--paper-3); border:1px solid var(--rule); padding:2rem 1.8rem;
  display:flex; flex-direction:column; border-radius:16px; }
.tier.feat{ background:var(--blue); color:var(--paper); border-color:var(--blue); }
.tier .amt{ font-family:var(--serif); font-size:var(--s4); font-weight:700; letter-spacing:-.02em;
  color:var(--clay); line-height:1; }
.tier.feat .amt{ color:var(--gold); }
.tier .amt small{ font-size:.34em; vertical-align:.6em; }
.tier .per{ font-family:var(--sans); font-size:.8rem; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink-faint); margin-top:.5rem; }
.tier.feat .per{ color:rgba(255,255,255,.7); }
.tier .what{ margin:1.1rem 0 1.6rem; color:var(--ink-soft); }
.tier.feat .what{ color:rgba(255,255,255,.85); }
.tier .btn{ margin-top:auto; align-self:flex-start; }

/* ledger (transparency) */
.ledger{ width:100%; border-collapse:collapse; font-family:var(--sans); }
.ledger th,.ledger td{ text-align:left; padding:1rem 1rem 1rem 0; border-bottom:1px solid var(--rule);
  vertical-align:top; }
.ledger th{ font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-faint); font-weight:600; }
.ledger td{ font-size:.96rem; }
.ledger td.year{ font-family:var(--serif); font-size:var(--s1); font-weight:600; color:var(--blue); }

.factbar{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule);
  border:1px solid var(--rule); }
.factbar div{ background:var(--paper-3); padding:1.5rem; }
.factbar dt{ font-family:var(--sans); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--ink-faint); font-weight:600; }
.factbar dd{ margin:.5rem 0 0; font-family:var(--serif); font-size:var(--s1); color:var(--ink); }
@media(max-width:680px){ .factbar{ grid-template-columns:1fr; } }

/* ====================================================================
   ACCOUNTABILITY / how it works steps
   ==================================================================== */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.2rem,3vw,2.4rem);
  counter-reset:step; }
.step{ position:relative; }
.step .sn{ font-family:var(--sans); font-size:.74rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--clay-deep); margin-bottom:.9rem; display:block;
  padding-bottom:.9rem; border-bottom:2px solid var(--clay); }
.step h3{ font-family:var(--serif); font-size:var(--s1); font-weight:600; margin:0 0 .55rem; }
.step p{ margin:0; color:var(--ink-soft); font-size:.95rem; }
@media(max-width:860px){ .steps{ grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .steps{ grid-template-columns:1fr; } }

/* ====================================================================
   DONATE band CTA
   ==================================================================== */
.cta-band{ background:var(--clay); color:#fff; position:relative; overflow:hidden; }
.cta-band.blue{ background:var(--blue); }
.cta-band .wrap{ padding-block:clamp(3.5rem,8vw,6rem); position:relative; z-index:2; }
.cta-band h2{ color:#fff; font-size:var(--s5); max-width:16ch; }
.cta-band p{ color:rgba(255,255,255,.88); max-width:48ch; margin:1.2rem 0 2rem; font-size:var(--s1); }

/* ====================================================================
   FORM
   ==================================================================== */
.form{ display:grid; gap:1.3rem; max-width:38rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field label{ font-family:var(--sans); font-size:.78rem; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-soft); }
.field input,.field textarea{ font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--paper-3); border:1px solid var(--rule); border-radius:2px; padding:.85rem 1rem; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-tint); }
.field textarea{ min-height:9rem; resize:vertical; }

/* ====================================================================
   FOOTER
   ==================================================================== */
.site-footer{ background:var(--blue-deep); color:rgba(255,255,255,.72); }
.site-footer .wrap{ padding-block:clamp(3.5rem,7vw,5.5rem); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; }
.foot-brand .mark{ width:40px; height:40px; color:var(--gold); }
.foot-brand b{ display:block; font-family:var(--serif); font-size:1.4rem; color:#fff; margin:.8rem 0 .4rem; }
.foot-brand p{ margin:.4rem 0 0; font-size:.9rem; line-height:1.6; max-width:32ch; }
.foot-col h4{ font-family:var(--sans); font-size:.74rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:rgba(255,255,255,.5); margin:0 0 1rem; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.foot-col a{ color:rgba(255,255,255,.8); font-size:.92rem; }
.foot-col a:hover{ color:var(--gold); }
.foot-col address{ font-style:normal; font-size:.92rem; line-height:1.7; color:rgba(255,255,255,.8); }
.socials{ display:flex; gap:.7rem; margin-top:1.2rem; }
.socials a{ width:38px; height:38px; border:1px solid rgba(255,255,255,.25); border-radius:50%;
  display:grid; place-items:center; color:#fff; transition:.25s var(--ease); }
.socials a:hover{ background:var(--gold); border-color:var(--gold); color:var(--blue-deep); }
.socials svg{ width:17px; height:17px; }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem;
  margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.14);
  font-size:.8rem; color:rgba(255,255,255,.55); }
.foot-bottom .badge{ font-family:var(--sans); letter-spacing:.04em; }
@media(max-width:860px){ .foot-top{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:520px){ .foot-top{ grid-template-columns:1fr; } }

/* ====================================================================
   MOBILE NAV
   ==================================================================== */
@media(max-width:940px){
  .nav-toggle{ display:inline-flex; }
  .nav-links{ position:fixed; top:0; right:0; height:100vh; height:100dvh; width:min(82vw,360px);
    background:var(--blue-deep); flex-direction:column; align-items:flex-start; justify-content:center;
    gap:1.4rem; padding:2rem 2.2rem; transform:translateX(105%); transition:transform .35s var(--ease);
    box-shadow:-30px 0 60px -20px rgba(0,0,0,.5); overflow-y:auto; }
  body.nav-open .nav-links{ transform:translateX(0); }
  .nav-links a{ color:rgba(255,255,255,.85); font-size:1.1rem; }
  .nav-links a:hover{ color:var(--gold); }
  .nav-links a::after{ background:var(--gold); }
  .nav-links a.nav-cta{ background:var(--paper); color:var(--blue); border-radius:8px;
    padding:.85rem 1.6rem; margin-top:.4rem; }
  .nav-links a.nav-cta:hover{ color:var(--blue); }
  body.nav-open{ overflow:hidden; }
  .nav-scrim{ position:fixed; inset:0; background:rgba(15,28,46,.5); opacity:0; visibility:hidden;
    transition:.3s var(--ease); z-index:55; }
  body.nav-open .nav-scrim{ opacity:1; visibility:visible; }
}

/* ====================================================================
   REVEAL animation
   ==================================================================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
/* progressive enhancement: if JS never runs, never hide content */
html:not(.js) .reveal{ opacity:1 !important; transform:none !important; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none; }
  .btn:hover{ transform:none; }
}

/* small util */
.mt-0{ margin-top:0; } .mt-6{ margin-top:var(--sp-6); } .mt-8{ margin-top:var(--sp-8); }
.maxw-58{ max-width:58ch; }
.divider{ height:1px; background:var(--rule); border:0; margin:0; }

/* ====================================================================
   "WHAT IT COSTS" — the multiplication chain (replaces flat stat band)
   ==================================================================== */
.costs{ background:var(--blue); color:var(--paper); position:relative; overflow:hidden; }
.costs::before{ /* faint topographic texture, a nod to the mountains */
  content:""; position:absolute; inset:0; opacity:.5; pointer-events:none;
  background:var(--topo) center/760px repeat; mix-blend-mode:soft-light; }
.costs__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(2rem,5vw,4.5rem); align-items:center;
  padding-block:clamp(3.5rem,8vw,6.5rem); }
.costs__say .eyebrow{ color:var(--gold); }
.costs__say h2{ color:#fff; font-size:var(--s4); line-height:1.07; margin:.4rem 0 0; max-width:15ch; }
.costs__say p{ color:rgba(255,255,255,.74); margin:1.2rem 0 0; max-width:44ch; }
.costs__say .btn-row{ margin-top:1.9rem; }
@media(max-width:820px){ .costs__grid{ grid-template-columns:1fr; gap:2.4rem; } }

/* the tuition "receipt" */
.receipt{ background:var(--paper-3); color:var(--ink); border-radius:8px; max-width:30rem;
  padding:1.7rem 1.9rem 1.8rem; box-shadow:0 34px 80px -34px rgba(0,0,0,.65); position:relative;
  justify-self:end; width:100%; }
.receipt__head{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem;
  padding-bottom:1rem; border-bottom:2px solid var(--ink); }
.receipt__org{ font-family:var(--serif); font-weight:700; font-size:1.18rem; letter-spacing:-.01em; }
.receipt__sub{ font-family:var(--sans); font-size:.62rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-faint); white-space:nowrap; }
.receipt__lines{ margin:0; }
.receipt__row{ display:flex; align-items:baseline; gap:.7rem; padding:.95rem 0;
  border-bottom:1px solid var(--rule-soft); }
.receipt__row dt{ font-family:var(--sans); font-size:.96rem; color:var(--ink-soft); white-space:nowrap; }
.receipt__lead{ flex:1; align-self:center; border-bottom:2px dotted var(--rule); height:0; }
.receipt__row dd{ margin:0; font-family:var(--serif); font-weight:700; font-size:1.55rem;
  color:var(--blue); letter-spacing:-.01em; line-height:1; }
.receipt__total{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem;
  margin-top:1rem; }
.receipt__total span{ font-family:var(--sans); font-size:.66rem; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-faint); }
.receipt__total strong{ font-family:var(--serif); font-weight:700; font-size:1.4rem; color:var(--ink); }
.receipt__note{ margin:1.1rem 0 0; font-family:var(--sans); font-size:.74rem; color:var(--ink-faint);
  display:flex; align-items:center; gap:.5rem; }
.receipt__note::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--blue-mid); flex:none; }
.receipt__stamp{ position:absolute; top:1.5rem; right:-.5rem; transform:rotate(7deg);
  font-family:var(--sans); font-size:.58rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--clay-deep); border:2px solid var(--clay-deep); border-radius:5px; padding:.28rem .5rem;
  opacity:.62; line-height:1.15; text-align:center; max-width:6.4rem; }

/* ====================================================================
   INTRO LOADER — book flipping pages
   ==================================================================== */
.loader{ position:fixed; inset:0; z-index:200; display:grid; place-items:center;
  background:var(--blue-deep); transition:opacity .7s var(--ease), visibility .7s var(--ease); }
.loader[hidden]{ display:grid; }            /* keep displayed; we fade via .done */
.loader.done{ opacity:0; visibility:hidden; pointer-events:none; }
.loader__inner{ display:flex; flex-direction:column; align-items:center; gap:1.6rem;
  transform:translateY(-2vh); }
.loader__wm{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,1rem+2vw,2.3rem);
  letter-spacing:.01em; color:var(--paper); min-height:1.45em; text-align:center; }
.loader__wm .tw1{ color:var(--paper); }
.loader__wm .tw2{ color:var(--gold); }
.loader__wm .caret{ display:inline-block; color:var(--gold); font-weight:300;
  margin-left:.02em; transform:translateY(.02em); animation:caretblink 1.05s steps(1,end) infinite; }
@keyframes caretblink{ 0%,48%{opacity:1} 49%,100%{opacity:0} }

/* open book, tilted in 3D; pages turn right-to-left like reading */
.flipbook{ perspective:1300px; width:132px; height:92px; }
.book3d{ position:relative; width:132px; height:88px; transform:rotateX(18deg);
  transform-style:preserve-3d; }
.book3d .page{ position:absolute; top:0; bottom:0; width:50%;
  background:linear-gradient(165deg,#fffdf7,#ece0ca); }
.book3d .page.l{ left:0; border-radius:5px 1px 1px 5px;
  box-shadow:inset -8px 0 12px -7px rgba(70,45,30,.35), 0 14px 22px -12px rgba(0,0,0,.5); }
.book3d .page.r{ right:0; border-radius:1px 5px 5px 1px;
  box-shadow:inset 8px 0 12px -7px rgba(70,45,30,.35), 0 14px 22px -12px rgba(0,0,0,.5); }
.book3d .spine{ position:absolute; left:50%; top:-2px; bottom:-2px; width:3px; margin-left:-1.5px;
  background:var(--clay); border-radius:2px; z-index:8; }
.leaf{ position:absolute; top:1px; height:86px; left:50%; width:50%;
  transform-origin:left center; transform-style:preserve-3d; transform:rotateY(0deg);
  animation:pageturn 3s var(--ease) infinite; z-index:7; }
.leaf b{ position:absolute; inset:0; backface-visibility:hidden; display:block; }
.leaf .f{ background:linear-gradient(120deg,#fffefb,#efe5d1); border-radius:1px 5px 5px 1px;
  box-shadow:0 12px 18px -9px rgba(0,0,0,.4); }
.leaf .b{ background:linear-gradient(-120deg,#fbf3e2,#e6dac1); border-radius:5px 1px 1px 5px;
  transform:rotateY(180deg); }
.leaf .f::after{ /* faint text lines */
  content:""; position:absolute; left:15%; right:11%; top:26%; height:48%;
  background:repeating-linear-gradient(transparent 0 5px, rgba(120,80,55,.16) 5px 6px); }
.leaf.l1{ animation-delay:0s; } .leaf.l2{ animation-delay:.55s; }
.leaf.l3{ animation-delay:1.1s; } .leaf.l4{ animation-delay:1.65s; }
@keyframes pageturn{
  0%   { transform:rotateY(0deg); }
  38%  { transform:rotateY(-179deg); }
  100% { transform:rotateY(-179deg); }
}
@media (prefers-reduced-motion: reduce){
  .leaf{ animation:none; }
  .book3d{ transform:rotateX(14deg); }
  .loader__wm{ animation:none; opacity:1; }
}

/* ====================================================================
   ICONS
   ==================================================================== */
.ic{ width:1.5rem; height:1.5rem; display:block; }
.ic-xl{ width:clamp(5.5rem,11vw,9rem); height:auto; display:block; }

/* ====================================================================
   PROGRESSION (numbered nodes joined by a line)
   ==================================================================== */
.psteps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.1rem,2.6vw,2.2rem); }
.pstep__top{ display:flex; align-items:center; margin-bottom:1.1rem; }
.pstep__badge{ flex:none; width:2.7rem; height:2.7rem; border-radius:50%; display:grid;
  place-items:center; font-family:var(--serif); font-weight:700; font-size:1.1rem;
  color:var(--paper); background:var(--blue); }
.pstep__line{ flex:1; height:2px; background:var(--rule); margin-left:.5rem; }
.pstep.is-last .pstep__line{ background:linear-gradient(90deg,var(--rule),transparent); }
.pstep h3{ font-family:var(--serif); font-size:var(--s1); font-weight:600; margin:0 0 .5rem; }
.pstep p{ margin:0; color:var(--ink-soft); font-size:.95rem; line-height:1.5; }
@media(max-width:860px){ .psteps{ grid-template-columns:1fr 1fr; gap:1.8rem 1.4rem; } }
@media(max-width:480px){ .psteps{ grid-template-columns:1fr; } .pstep__line{ display:none; } }

/* ====================================================================
   CTA band with icon
   ==================================================================== */
.cta-band__grid{ display:grid; grid-template-columns:1fr auto; align-items:center;
  gap:clamp(2rem,5vw,4rem); }
.cta-band__icon{ color:rgba(255,255,255,.18); }
.cta-band__icon .ic-xl{ width:clamp(6rem,13vw,12rem); }
@media(max-width:780px){ .cta-band__grid{ grid-template-columns:1fr; } .cta-band__icon{ display:none; } }

/* ====================================================================
   STATEMENT block (text + big faint icon)
   ==================================================================== */
.statement{ display:grid; grid-template-columns:1fr auto; align-items:center;
  gap:clamp(2rem,6vw,5rem); }
.statement__icon{ color:var(--blue); opacity:.13; }
.statement__icon .ic-xl{ width:clamp(6rem,12vw,11rem); }
@media(max-width:780px){ .statement{ grid-template-columns:1fr; } .statement__icon{ display:none; } }

/* ====================================================================
   BOARD avatar (monogram)
   ==================================================================== */
.person__av{ width:3.1rem; height:3.1rem; border-radius:50%; background:var(--blue);
  color:var(--paper); display:grid; place-items:center; font-family:var(--serif);
  font-weight:700; font-size:1.05rem; letter-spacing:.01em; margin-bottom:1rem; }
