:root {
  --paper:#FAF8F3;
  --ink:#1B1A17;
  --muted:#6B6B62;
  --line:#E4DFD4;
  --accent:#B0785C;
  --accent-dark:#94614A;
  --card:#FFFDF8;
  --maxw:720px;
  --serif:'Newsreader', Georgia, 'Times New Roman', serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*, *::before, *::after { box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation:none !important; }
}
body {
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1, h2, h3 { font-family:var(--serif); font-weight:600; line-height:1.2; letter-spacing:-0.01em; margin:0; }
a { color:inherit; }
img { max-width:100%; display:block; }

.skip {
  position:absolute; left:-9999px; top:0;
  background:var(--ink); color:var(--paper);
  padding:10px 16px; border-radius:0 0 6px 0; z-index:100;
}
.skip:focus { left:0; }

:focus-visible { outline:2px solid var(--accent-dark); outline-offset:3px; border-radius:2px; }

/* Shared section rhythm */
.section {
  max-width:var(--maxw);
  margin:0 auto;
  padding:72px 28px;
  border-top:1px solid var(--line);
}
.label {
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  font-weight:600; color:var(--accent-dark); margin:0 0 20px;
}
.section h2 { font-size:30px; margin:0 0 20px; }
.prose { max-width:60ch; color:var(--ink); margin:0 0 16px; }
.prose:last-child { margin-bottom:0; }

.topbar {
  max-width:var(--maxw); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 28px; gap:16px;
}
.topbar .brand { font-family:var(--serif); font-weight:600; font-size:20px; text-decoration:none; }
.topbar ul { display:flex; gap:24px; list-style:none; margin:0; padding:0; }
.topbar a { color:var(--muted); text-decoration:none; font-size:14px; }
.topbar ul a:hover { color:var(--ink); }

.hero {
  max-width:var(--maxw); margin:0 auto;
  padding:80px 28px 72px; text-align:left;
}
.hero-eyebrow {
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  font-weight:600; color:var(--accent-dark); margin:0 0 24px;
}
.wordmark { font-size:clamp(64px, 12vw, 104px); line-height:0.95; margin:0; }
.wordmark .dot { color:var(--accent); }
.hero-lede {
  font-family:var(--serif); font-weight:400; font-size:clamp(22px, 3.4vw, 30px);
  line-height:1.35; color:var(--ink); margin:28px 0 0; max-width:22ch;
}

.portfolio { list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:8px 32px; }
.pf a {
  display:grid; grid-template-columns:120px 1fr; align-items:center; gap:20px;
  text-decoration:none; padding:20px 12px; border-radius:8px;
  transition:background .2s ease;
}
.pf a:hover { background:var(--card); }
.pf a:focus-visible { background:var(--card); }
.pf-logo { display:flex; align-items:center; justify-content:flex-start; height:34px; }
.pf-logo img {
  max-height:30px; width:auto; max-width:118px; object-fit:contain;
  opacity:.92; transition:opacity .2s ease;
}
.pf a:hover .pf-logo img, .pf a:focus-visible .pf-logo img { opacity:1; }
.pf-text { display:flex; flex-direction:column; }
.pf-name { font-family:var(--serif); font-weight:600; font-size:16px; color:var(--ink); letter-spacing:-0.01em; margin-bottom:2px; }
.pf a:hover .pf-name, .pf a:focus-visible .pf-name { color:var(--accent-dark); }
.pf-desc { display:block; font-size:14px; line-height:1.55; color:var(--muted); }

.note .prose { font-size:18px; }
.note .prose:first-child { color:var(--ink); }
.inline-link {
  display:inline-block; margin-top:24px;
  font-weight:500; color:var(--accent-dark); text-decoration:none;
  border-bottom:1px solid var(--line); padding-bottom:2px;
}
.inline-link:hover { border-bottom-color:var(--accent-dark); }

.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}
/* Donations — year tabs (pure CSS; works with JS off). Radios are the state,
   labels are the tabs, panels are the content. */
.giving-tabs { margin-top:10px; }
.giving-year { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.giving-tablist { display:flex; flex-wrap:wrap; gap:2px; border-bottom:1px solid var(--line); margin-bottom:22px; }
.giving-tablist label {
  font-family:var(--serif); font-size:17px; color:var(--muted);
  padding:8px 15px; cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:color .15s ease, border-color .15s ease;
}
.giving-tablist label:hover { color:var(--ink); }
.giving-panel { display:none; }
.giving-panel table { width:100%; border-collapse:collapse; font-size:15px; }
.giving-panel td { text-align:left; padding:11px 14px 11px 0; vertical-align:top; border-top:1px solid var(--line); }
.giving-panel tr:first-child td { border-top:0; }
.giving-panel td.amt { white-space:nowrap; color:var(--ink); width:120px; }
.giving-panel td a { color:var(--accent-dark); text-decoration:none; border-bottom:1px solid var(--line); }
.giving-panel td a:hover { border-bottom-color:var(--accent-dark); }
/* reveal the checked year's panel */
#gy-2026:checked ~ #gp-2026,
#gy-2025:checked ~ #gp-2025,
#gy-2024:checked ~ #gp-2024,
#gy-2023:checked ~ #gp-2023,
#gy-2022:checked ~ #gp-2022,
#gy-2021:checked ~ #gp-2021,
#gy-2020:checked ~ #gp-2020 { display:block; }
/* highlight the active year's tab */
#gy-2026:checked ~ .giving-tablist label[for="gy-2026"],
#gy-2025:checked ~ .giving-tablist label[for="gy-2025"],
#gy-2024:checked ~ .giving-tablist label[for="gy-2024"],
#gy-2023:checked ~ .giving-tablist label[for="gy-2023"],
#gy-2022:checked ~ .giving-tablist label[for="gy-2022"],
#gy-2021:checked ~ .giving-tablist label[for="gy-2021"],
#gy-2020:checked ~ .giving-tablist label[for="gy-2020"] { color:var(--ink); border-bottom-color:var(--accent); }
/* keyboard focus ring on the focused year's tab */
#gy-2026:focus-visible ~ .giving-tablist label[for="gy-2026"],
#gy-2025:focus-visible ~ .giving-tablist label[for="gy-2025"],
#gy-2024:focus-visible ~ .giving-tablist label[for="gy-2024"],
#gy-2023:focus-visible ~ .giving-tablist label[for="gy-2023"],
#gy-2022:focus-visible ~ .giving-tablist label[for="gy-2022"],
#gy-2021:focus-visible ~ .giving-tablist label[for="gy-2021"],
#gy-2020:focus-visible ~ .giving-tablist label[for="gy-2020"] { outline:2px solid var(--accent-dark); outline-offset:2px; border-radius:2px; }

.cta {
  display:inline-block; margin-top:20px;
  font-family:var(--serif); font-size:22px; font-weight:500;
  color:var(--ink); text-decoration:none;
  border-bottom:2px solid var(--accent); padding-bottom:3px;
  transition:color .2s ease, border-color .2s ease;
}
.cta:hover { color:var(--accent-dark); border-bottom-color:var(--accent-dark); }

.footer { border-top:1px solid var(--line); margin-top:8px; }
.footer-inner {
  max-width:var(--maxw); margin:0 auto; padding:40px 28px;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px;
  font-size:14px; color:var(--muted);
}
.footer-brand { font-family:var(--serif); font-size:16px; color:var(--ink); }
.footer-links { display:flex; gap:20px; }
.footer-links a { color:var(--muted); text-decoration:none; }
.footer-links a:hover { color:var(--ink); }

.js .reveal { opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
.reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity:1; transform:none; transition:none; }
}

@media (max-width: 640px) {
  body { font-size:16px; }
  .topbar { flex-direction:column; align-items:flex-start; gap:12px; padding:20px; }
  .topbar ul { gap:18px; flex-wrap:wrap; }
  .hero { padding:48px 20px 56px; }
  .section { padding:56px 20px; }
  .section h2 { font-size:26px; }
  .portfolio { grid-template-columns:1fr; gap:0; }
  .pf a { grid-template-columns:96px 1fr; gap:16px; padding:16px 8px; }
  .giving-tablist label { font-size:16px; padding:8px 11px; }
  .giving-panel table { font-size:14px; }
  .giving-panel td { padding:10px 10px 10px 0; }
  .giving-panel td.amt { width:96px; }
  .footer-inner { flex-direction:column; align-items:flex-start; gap:10px; }
}
