
:root{
  --bg:#f6f8f7;
  --surface:#ffffff;
  --surface-2:#eef4ef;
  --text:#1f2d2a;
  --muted:#5f726b;
  --line:#dbe5df;
  --accent:#78be3d;
  --accent-2:#e53c57;
  --shadow:0 18px 50px rgba(25,38,34,.08);
  --radius:24px;
  --radius-sm:16px;
  --container:min(1160px, calc(100% - 2rem));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}
h1,h2,h3,h4{line-height:1.1;margin:0 0 1rem}
h1{font-size:clamp(2.3rem, 5vw, 4.5rem)}
h2{font-size:clamp(1.7rem, 3vw, 2.3rem)}
h3{font-size:1.2rem}
ul{margin:0;padding-left:1.2rem}
.container{width:var(--container);margin:0 auto}
.narrow{max-width:820px}
.section{padding:4.5rem 0}
.section-alt{background:linear-gradient(180deg,#f0f6f1 0%, rgba(240,246,241,0) 100%)}
.section-head{margin-bottom:1.5rem}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  background:rgba(120,190,61,.12);
  color:#3a6d15;
  border:1px solid rgba(120,190,61,.2);
  border-radius:999px;
  padding:.4rem .8rem;
  font-size:.9rem;
  font-weight:700;
  margin-bottom:1rem;
}
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  left:1rem;top:1rem;width:auto;height:auto;background:#fff;padding:.8rem 1rem;border-radius:12px;z-index:1000;
}
.site-header{
  position:sticky;top:0;z-index:100;
  backdrop-filter:saturate(180%) blur(20px);
  background:rgba(246,248,247,.84);
  border-bottom:1px solid rgba(219,229,223,.7);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:1rem 0;
}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:800;letter-spacing:.01em}
.brand span{font-size:1rem}
.site-nav{display:flex;gap:1rem;align-items:center}
.site-nav a{
  color:var(--muted);font-weight:600;padding:.55rem .8rem;border-radius:999px;transition:.2s ease
}
.site-nav a:hover,.site-nav a.is-active{background:#fff;color:var(--text);box-shadow:var(--shadow)}
.nav-toggle{
  display:none;border:0;background:#fff;border-radius:12px;padding:.65rem;box-shadow:var(--shadow)
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);margin:4px 0}

.hero{
  position:relative;overflow:hidden;
  padding:6rem 0 4rem;
}
.hero-home{
  background:
    linear-gradient(120deg, rgba(255,255,255,.96) 25%, rgba(255,255,255,.78) 48%, rgba(255,255,255,.22) 100%),
    url('../images/raw/img_1567-crop-u150544.jpg') center/cover no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:auto -10% -20% auto;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle, rgba(229,60,87,.20), rgba(229,60,87,0));
}
.hero-grid{
  position:relative;display:grid;grid-template-columns:1.25fr .75fr;gap:2rem;align-items:end
}
.hero-copy{background:rgba(255,255,255,.82);padding:2rem;border-radius:32px;box-shadow:var(--shadow)}
.hero-copy p{font-size:1.08rem;color:#33433d}
.hero-card{
  background:rgba(255,255,255,.88);
  padding:1.5rem;border-radius:32px;box-shadow:var(--shadow);display:grid;gap:1rem
}
.hero-logo{width:100%;border-radius:18px;background:#fff;padding:1rem;border:1px solid var(--line)}
.hero-note{padding:1rem;border-radius:20px;background:var(--surface-2)}
.button-row{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.4rem}
.button{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:.8rem 1.1rem;border-radius:999px;font-weight:700;transition:.2s ease;
}
.button:hover{transform:translateY(-1px)}
.button-primary{background:linear-gradient(135deg,var(--accent), #95d25e);color:#18300f;box-shadow:var(--shadow)}
.button-secondary{background:#fff;border:1px solid var(--line)}
.text-link{font-weight:700;color:#305d15}
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.75rem
}
.stat{
  background:#fff;border:1px solid rgba(219,229,223,.8);border-radius:20px;padding:1rem;
}
.stat strong{display:block;font-size:1.1rem}
.stat span{color:var(--muted);font-size:.95rem}

.page-hero{
  position:relative;padding:5rem 0 2.5rem;
  background:
    radial-gradient(circle at top right, rgba(229,60,87,.14), transparent 28%),
    linear-gradient(180deg,#eef5ef 0%, rgba(238,245,239,.2) 100%);
}
.page-hero-event{
  background:
    linear-gradient(120deg, rgba(255,255,255,.95), rgba(255,255,255,.78)),
    var(--hero-image) center/cover no-repeat;
}
.page-hero .narrow{background:rgba(255,255,255,.75);padding:2rem;border-radius:32px;box-shadow:var(--shadow)}

.grid-2,.grid-3,.event-grid,.media-grid,.gallery-grid{
  display:grid;gap:1.25rem
}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.event-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.media-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.gallery-grid{grid-template-columns:repeat(3,minmax(0,1fr))}

.info-card,.panel-card,.download-card,.event-card,.media-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)
}
.info-card,.panel-card,.download-card{padding:1.5rem}
.download-card{display:grid;gap:.25rem;min-height:130px}
.download-card strong{font-size:1.15rem}
.download-card span{color:var(--muted)}
.split-panel{
  display:grid;grid-template-columns:1.1fr .9fr;gap:1.5rem;align-items:start
}
.chip-list{
  display:flex;flex-wrap:wrap;gap:.8rem
}
.chip-list span{
  background:#fff;border:1px solid var(--line);padding:.7rem .9rem;border-radius:999px;font-weight:600
}
.check-list{padding-left:1.1rem}
.check-list li{margin-bottom:.6rem}
.prose p,.prose li{color:#2e3d38}
.prose h2{margin-top:0}

.event-card{overflow:hidden}
.event-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.event-card-body{padding:1.2rem}
.event-year{display:inline-block;padding:.35rem .7rem;border-radius:999px;background:rgba(120,190,61,.12);font-size:.85rem;font-weight:700;margin-bottom:.7rem}

.gallery-item,.media-card{
  overflow:hidden;display:block
}
.gallery-item img,.media-card img{
  width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .35s ease
}
.gallery-item:hover img,.media-card:hover img,.event-card:hover img{transform:scale(1.04)}
.media-card span{display:block;padding:1rem;font-weight:600}
.logo-wall{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}
.supporter-list{
  list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem
}
.supporter-list li{
  padding:.8rem 1rem;border-radius:16px;background:var(--surface-2);font-weight:600
}
.legal-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}
.contact-form{display:grid;gap:.7rem}
.contact-form input,.contact-form textarea{
  width:100%;border:1px solid #cad7d0;border-radius:16px;padding:.9rem 1rem;font:inherit;background:#fff
}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid rgba(120,190,61,.25);border-color:var(--accent)}
.hp-field{position:absolute !important;left:-9999px !important}
.form-note{font-size:.92rem;color:var(--muted)}
.paypal-form{margin-top:.8rem}
.panel-card h2,.info-card h2{font-size:1.35rem}
.footer-grid{
  display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:1.25rem;padding:3rem 0 1rem
}
.site-footer{
  margin-top:2rem;background:#13201d;color:#d9e3de
}
.site-footer h3,.site-footer h4{color:#fff}
.footer-links{display:grid;gap:.6rem}
.footer-links a{color:#d9e3de}
.footer-bottom{padding:1rem 0 2rem;color:#a8bbb3;border-top:1px solid rgba(255,255,255,.08)}

@media (max-width: 980px){
  .hero-grid,.split-panel,.footer-grid,.grid-2,.grid-3,.event-grid,.media-grid,.gallery-grid{grid-template-columns:1fr}
  .stats,.supporter-list{grid-template-columns:1fr 1fr}
  .hero-copy,.hero-card,.page-hero .narrow{padding:1.5rem}
}
@media (max-width: 760px){
  .site-nav{
    position:absolute;left:1rem;right:1rem;top:72px;background:#fff;border:1px solid var(--line);
    border-radius:22px;box-shadow:var(--shadow);padding:1rem;display:none;flex-direction:column;align-items:stretch
  }
  .site-nav.is-open{display:flex}
  .site-nav a{padding:.85rem 1rem}
  .nav-toggle{display:block}
  .hero{padding-top:4.5rem}
  .stats,.supporter-list{grid-template-columns:1fr}
}
