:root{
  --ink: #1A3A3A;
  --ink-soft: #2B4A48;
  --parchment: #F5EFE6;
  --parchment-deep: #ECE3D3;
  --terracotta: #C76B3C;
  --terracotta-deep: #A8542B;
  --sage: #7A8B6F;
  --gold: #E8A23D;
  --cream-text: #F5EFE6;
  --max-w: 1180px;
  --display: 'Fraunces', serif;
  --hand: 'Caveat', cursive;
  --sans: 'Inter', -apple-system, sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family: var(--sans);
  color: var(--ink);
  background: var(--parchment);
  line-height: 1.6;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
.wrap{max-width:var(--max-w); margin:0 auto; padding:0 32px;}

/* ---------- NAV ---------- */
header{
  position: fixed; top:0; left:0; right:0; z-index: 100;
  background: rgba(245,239,230,0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(26,58,58,0.08);
}
nav{
  max-width: var(--max-w); margin: 0 auto; padding: 18px 32px;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{display:flex; align-items:center; gap:12px;}
.brand-mark{
  width:40px; height:44px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.brand-mark img{width:100%; height:100%; object-fit:contain;}
.brand-mark svg{width:34px; height:34px; padding:3px; border-radius:50%; background:var(--ink);}
.brand-text{font-family:var(--display); font-weight:600; font-size:18px; letter-spacing:-0.01em;}
.brand-text span{display:block; font-family:var(--sans); font-weight:400; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--sage); margin-top:1px;}

.nav-links{display:flex; gap:28px; align-items:center;}
.nav-links a{
  font-size:14.5px; font-weight:500; color:var(--ink-soft);
  position:relative; padding:4px 0;
}
.nav-links a.active{color:var(--terracotta);}
.nav-links a::after{
  content:''; position:absolute; left:0; right:0; bottom:0; height:1.5px;
  background: var(--terracotta); transform:scaleX(0); transform-origin:right;
  transition: transform .25s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{transform:scaleX(1); transform-origin:left;}
.nav-cta{
  background: var(--terracotta); color:var(--cream-text) !important;
  padding:10px 20px; border-radius:100px; font-weight:500;
}
.nav-cta::after{display:none;}
.nav-cta:hover{background:var(--terracotta-deep);}
.menu-toggle{display:none; background:none; border:none; cursor:pointer; padding:8px;}
.menu-toggle svg{width:24px; height:24px; stroke:var(--ink);}

@media (max-width: 900px){
  .nav-links{
    display:none; position:fixed; top:73px; left:0; right:0; bottom:0;
    background:var(--parchment); flex-direction:column; align-items:flex-start;
    padding:32px; gap:8px; overflow-y:auto;
  }
  .nav-links.open{display:flex;}
  .nav-links a{font-size:18px; padding:12px 0; width:100%;}
  .menu-toggle{display:block;}
  .nav-cta{margin-top:12px;}
}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero{
  position:relative; min-height:56vh; display:flex; align-items:flex-end;
  background: var(--ink); color:var(--cream-text); overflow:hidden;
  padding: 140px 0 64px;
}
.page-hero-bg{position:absolute; inset:-15% 0 -15% 0; opacity:0.32; will-change:transform;}
.page-hero-bg img{width:100%; height:130%; object-fit:cover;}
.page-hero-bg::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(26,58,58,0.55) 0%, var(--ink) 96%);
}
.page-hero-inner{position:relative; z-index:2; max-width:var(--max-w); margin:0 auto; padding:0 32px;}
.page-eyebrow{
  font-size:13px; letter-spacing:0.1em; text-transform:uppercase;
  color: var(--gold); margin-bottom: 18px; font-weight:500;
  display:inline-flex; align-items:center; gap:10px;
}
.page-eyebrow::before{content:''; width:28px; height:1px; background:var(--gold);}
.page-hero h1{
  font-family:var(--display); font-weight:500; font-size: clamp(34px, 4.6vw, 54px);
  line-height:1.06; letter-spacing:-0.01em; max-width:760px;
}
.page-hero p{font-size:16.5px; color:rgba(245,239,230,0.78); max-width:560px; margin-top:18px;}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0; transform:translateY(28px); transition: opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1; transform:translateY(0);}
.reveal-stagger > *{opacity:0; transform:translateY(20px); transition: opacity .6s ease, transform .6s ease;}
.reveal-stagger.in > *{opacity:1; transform:translateY(0);}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s;}
.reveal-stagger.in > *:nth-child(6){transition-delay:.55s;}

/* ---------- SECTION SCAFFOLDING ---------- */
section{padding: 96px 0;}
.section-head{max-width:640px; margin-bottom:52px;}
.eyebrow{
  font-size:13px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--terracotta); margin-bottom:14px; display:block;
}
h2{
  font-family:var(--display); font-weight:500; font-size:clamp(28px,3.4vw,42px);
  line-height:1.1; letter-spacing:-0.01em;
}
h3{font-family:var(--display); font-weight:500;}
.lede{font-size:17px; color:var(--ink-soft); margin-top:16px; max-width:560px;}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:100px; font-weight:500; font-size:15px;
  transition: all .25s ease; cursor:pointer; border:1.5px solid transparent;
}
.btn-primary{background:var(--terracotta); color:var(--cream-text);}
.btn-primary:hover{background:var(--terracotta-deep); transform:translateY(-2px);}
.btn-ghost{border-color:rgba(245,239,230,0.35); color:var(--cream-text);}
.btn-ghost:hover{border-color:var(--cream-text); background:rgba(245,239,230,0.08);}
.btn-ghost-dark{border-color:rgba(26,58,58,0.3); color:var(--ink);}
.btn-ghost-dark:hover{border-color:var(--ink); background:rgba(26,58,58,0.06);}

/* ---------- PARALLAX IMAGE PANELS ---------- */
.parallax-img{overflow:hidden; border-radius:20px; position:relative;}
.parallax-img img{
  width:100%; height:130%; object-fit:cover; display:block;
  position:relative; top:-15%; will-change:transform;
}

/* ---------- WORK CARDS ---------- */
.work-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:28px;}
.work-card{
  background:var(--parchment-deep); border-radius:20px; overflow:hidden;
  position:relative; min-height:340px; display:flex; flex-direction:column; justify-content:flex-end;
  transition: transform .4s ease;
}
.work-card:hover{transform:translateY(-6px);}
.work-card-img{position:absolute; inset:0;}
.work-card-img img{width:100%; height:120%; object-fit:cover; transition: transform .6s ease; will-change:transform;}
.work-card:hover .work-card-img img{transform:scale(1.06);}
.work-card-img::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(26,58,58,0) 30%, rgba(20,38,38,0.92) 100%);
}
.work-card-body{position:relative; z-index:2; padding:28px; color:var(--cream-text);}
.work-card-tag{
  font-size:12px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--gold); margin-bottom:8px; display:block;
}
.work-card h3{font-weight:500; font-size:23px; margin-bottom:8px;}
.work-card p{font-size:14.5px; color:rgba(245,239,230,0.75); margin-bottom:14px;}
.work-card-link{font-size:13.5px; font-weight:500; color:var(--cream-text); display:inline-flex; align-items:center; gap:6px;}
.work-card-link svg{width:14px; height:14px; transition: transform .25s ease;}
.work-card:hover .work-card-link svg{transform:translateX(4px);}

/* ---------- INFO / DEPARTMENT CARDS ---------- */
.info-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px;}
.info-card{
  background:var(--parchment-deep); border-radius:16px; padding:26px 28px;
  border:1px solid rgba(26,58,58,0.08);
}
.info-card h3{font-size:18px; margin-bottom:10px; color:var(--ink);}
.info-card p{font-size:14.5px; color:var(--ink-soft); margin-bottom:12px;}
.info-meta{
  display:flex; align-items:center; gap:8px; font-size:13px; color:var(--sage);
  font-weight:500;
}
.info-meta svg{width:15px; height:15px; flex-shrink:0;}

/* ---------- STAT GRID (reusable) ---------- */
.stat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
.stat-card{background:var(--parchment-deep); border-radius:16px; padding:24px; text-align:center;}
.stat-num{font-family:var(--display); font-size:32px; font-weight:500; color:var(--terracotta);}
.stat-label{font-size:13px; color:var(--ink-soft); margin-top:6px; line-height:1.4;}

/* ---------- DARK SECTION ---------- */
.dark-section{background:var(--ink); color:var(--cream-text); position:relative; overflow:hidden;}
.dark-section h2{color:var(--cream-text);}
.dark-section .lede{color:rgba(245,239,230,0.72);}
.dark-section::before{
  content:''; position:absolute; top:-20%; right:-10%; width:600px; height:600px;
  border-radius:50%; border:1px solid rgba(232,162,61,0.12);
}

/* ---------- CTA BAND ---------- */
.cta-band{
  background: var(--terracotta); color:var(--cream-text); text-align:center;
  padding:90px 0; position:relative; overflow:hidden;
}
.cta-band h2{color:var(--cream-text); margin-bottom:18px;}
.cta-band p{color:rgba(245,239,230,0.85); max-width:520px; margin:0 auto 36px; font-size:16.5px;}
.cta-band .btn-primary{background:var(--ink);}
.cta-band .btn-primary:hover{background:#0F2626;}
.cta-band .btn-ghost{border-color:rgba(245,239,230,0.4);}
.cta-actions{display:flex; gap:16px; flex-wrap:wrap; justify-content:center;}

/* ---------- DONOR CHIPS ---------- */
.donor-grid{display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin-top:40px;}
.donor-chip{
  border:1px solid rgba(26,58,58,0.16); border-radius:100px; padding:10px 22px;
  font-size:14px; font-weight:500; color:var(--ink-soft); background:var(--parchment-deep);
}

/* ---------- TIMELINE (story) ---------- */
.story-timeline{margin-top:36px; display:flex; flex-direction:column; gap:0;}
.story-row{
  display:grid; grid-template-columns:90px 1fr; gap:20px;
  padding:18px 0; border-top:1px solid rgba(245,239,230,0.12);
}
.story-row:last-child{border-bottom:1px solid rgba(245,239,230,0.12);}
.story-year{font-family:var(--display); font-weight:500; font-size:17px; color:var(--gold);}
.story-text{font-size:14.5px; color:rgba(245,239,230,0.78); line-height:1.55;}
.story-text strong{color:var(--cream-text); font-weight:500;}

/* ---------- PHOTO GRID ---------- */
.photo-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px;}
.photo-grid img{width:100%; height:220px; object-fit:cover; border-radius:14px;}
.photo-grid .tall{height:460px; grid-row:span 2;}

/* ---------- SIMPLE TABLE ---------- */
.data-table{width:100%; border-collapse:collapse; font-size:14px;}
.data-table th, .data-table td{
  padding:12px 16px; text-align:left; border-bottom:1px solid rgba(26,58,58,0.1);
}
.data-table th{
  font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:0.04em;
  color:var(--sage);
}
.data-table tr:last-child td{font-weight:600; border-bottom:none;}

/* ---------- FOOTER ---------- */
footer{background:#102525; color:rgba(245,239,230,0.7); padding:64px 0 32px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px;}
.footer-brand .brand-text{color:var(--cream-text);}
.footer-brand p{font-size:14px; margin-top:16px; max-width:280px; line-height:1.6;}
.footer-col h4{font-size:13px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase; color:var(--cream-text); margin-bottom:18px;}
.footer-col a{display:block; font-size:14px; margin-bottom:12px; color:rgba(245,239,230,0.65); transition:color .2s;}
.footer-col a:hover{color:var(--gold);}
.footer-bottom{
  border-top:1px solid rgba(245,239,230,0.12); padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:13px; color:rgba(245,239,230,0.45);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  .work-grid{grid-template-columns:1fr;}
  .info-grid{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:repeat(2,1fr);}
  .story-grid{grid-template-columns:1fr !important;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px;}
  .photo-grid{grid-template-columns:1fr 1fr;}
  .photo-grid .tall{height:220px; grid-row:auto;}
}
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal-stagger > *{animation:none !important; opacity:1 !important; transform:none !important;}
  .parallax-img img, .page-hero-bg, .work-card-img img{transform:none !important;}
}
