:root{
  --bg:#fffdf8; --ink:#1b1b1b; --ink-soft:#3a3a3a;
  --brand:#2a7a78; --brand-2:#7a5fa0; --card:#ffffff;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
img{max-width:100%;height:auto;display:block}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;background:#000;color:#fff;padding:.5rem 1rem}

.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 2rem;max-width:1100px;margin:0 auto}
.brand{font-family:Marcellus,serif;font-weight:800;font-size:1.25rem;line-height:1.1;text-decoration:none;color:var(--ink)}
.brand span{font-weight:400;color:var(--brand-2)}
.menu{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.menu a{color:var(--ink);text-decoration:none;font-weight:600}
.nav-toggle{display:none}

.hero{position:relative;background:linear-gradient(180deg,#e6f3ff,#f1eaff 60%,transparent 100%);padding-bottom:3rem}
.hero-inner{max-width:1100px;margin:2rem auto 0;padding:2rem}
.hero h1{font-family:Marcellus,serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1.1;margin:0 0 1rem}
.lead{font-size:1.125rem;color:var(--ink-soft);max-width:60ch}
.cta-row{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}

.btn{display:inline-block;border:2px solid var(--brand);padding:.7rem 1rem;border-radius:999px;text-decoration:none;color:#fff;background:var(--brand);font-weight:700;box-shadow:var(--shadow)}
.btn:hover{transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--brand)}

.wave{height:40px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.8))}

.section{padding:3rem 1.5rem}
.section.alt{background:linear-gradient(180deg,rgba(138,180,248,.08),transparent)}
.container{max-width:1100px;margin:0 auto}

.grid2{display:grid;grid-template-columns:1.2fr .8fr;gap:1.5rem}

.card{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:1.25rem}
.card.soft{background:#fbfbff}

.checklist{padding:0;margin:0;list-style:none}
.checklist li{padding-left:1.5rem;position:relative;margin:.25rem 0}
.checklist li::before{content:'✧';position:absolute;left:.25rem;top:0;color:var(--brand-2)}

.embed{aspect-ratio:16/9;background:#fff;border:1px solid #eaeaea;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.embed iframe{width:100%;height:100%;border:0}

/* ---------- Masonry gallery (CSS columns) ---------- */
.gallery{
  column-count: 3;       /* desktop */
  column-gap: 1rem;
}
@media (max-width:980px){
  .gallery{ column-count: 2; }   /* tablet */
}
@media (max-width:620px){
  .gallery{ column-count: 1; }   /* mobile */
}

/* Tiles flow into columns; avoid breaking across columns */
.gallery figure{
  display: inline-block;         /* required for columns flow */
  width: 100%;
  margin: 0 0 1rem;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;

  position: relative;
  overflow: hidden;
  background:#fff;
  border-radius:10px;
  box-shadow: var(--shadow);
}

.gallery img{
  width:100%;
  height:auto;
  display:block;
  transition: transform .4s ease;
}

/* Hover overlay caption */
.gallery figure>figcaption{
  position:absolute;
  left:0; bottom:0; width:100%;
  padding:.5rem .6rem;
  background:rgba(0,0,0,.5);
  color:#fff;
  font-size:.85rem;
  font-style:italic;
  text-align:center;
  line-height:1.4;
  opacity:0;
  transition:opacity .4s ease;
  margin-top:0;
}

.gallery figure:hover img{ transform: scale(1.03); }
.gallery figure:hover>figcaption{ opacity:1; }

/* Always show captions on touch devices (no hover) */
@media (hover:none){
  .gallery figure>figcaption{ opacity:1; }
}

/* ---------- Rest of layout ---------- */
.donate-grid{display:flex;gap:.75rem;flex-wrap:wrap}

.footer{padding:2rem 1.5rem;border-top:1px solid #eee;background:#faf9ff}
.footer-grid{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.social{display:flex;gap:.75rem;list-style:none;margin:0;padding:0}
.social a{text-decoration:none;font-weight:700;color:var(--brand-2)}

form label{display:block;font-weight:600;margin:.5rem 0 .25rem}
input,textarea{width:100%;padding:.7rem;border:1px solid #ddd;border-radius:10px;font:inherit}
.form-note{font-size:.9rem;color:var(--ink-soft)}

/* ---------- Mobile nav tweaks ---------- */
@media (max-width:820px){
  .grid2{grid-template-columns:1fr}
  .menu{display:none}
  .nav-toggle{display:inline-block;background:transparent;border:2px solid var(--ink);padding:.35rem .6rem;border-radius:8px}
  .menu.open{display:flex;flex-direction:column;align-items:flex-start;padding:1rem 0}
}
