
:root{
  --bg:#0b2a40;        /* deep blue */
  --bg-alt:#0f3550;
  --fg:#0e2233;        /* dark text */
  --muted:#577089;
  --accent:#f0b556;    /* gold like the angels in logo */
  --paper:#ffffff;
  --ring:0 0 0 3px rgba(21,61,111,.25);
  /* Sticky header sizing + in-page anchor offset */
  --header-height:84px;
  --header-offset:108px;
}

*{box-sizing:border-box}
html,body{margin:0}
html{scroll-padding-top:var(--header-offset)}
body{
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Noto Sans",Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--fg);
  background:#f7fafc;
}

/* helpers */
.container{max-width:1040px;margin:auto;padding:0 16px}
.sr-only{position:absolute;left:-9999px}
.center{text-align:center}
.btn-row{display:flex;gap:.75rem;flex-wrap:wrap}
.btn{display:inline-block;padding:.65rem 1rem;border-radius:999px;border:2px solid transparent;text-decoration:none;font-weight:600}
.btn-primary{background:var(--accent);color:#1a1a1a}
.btn-secondary{background:#fff;border-color:#d7dee6;color:#0b2540}
.btn-outline{background:transparent;border-color:#d7dee6;color:var(--fg);border-width:2px}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}

/* header */
.site-header{background:#fff;position:sticky;top:0;z-index:10;border-bottom:1px solid #e6edf4}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.2rem 0;min-height:var(--header-height)}
.brand{display:flex;gap:.6rem;align-items:center;color:inherit;text-decoration:none}
.brand-mark{
  width:76px;
  height:76px;
  border-radius:14px;
  /* allow the scaled logo to breathe (prevents bottom/top cropping) */
  overflow:visible;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}
.brand-logo{
  width:100%;
  height:100%;
  object-fit:contain;
  /* This PNG has extra transparent padding; zoom + nudge prevents "cut off" while keeping it readable */
  transform:translateY(-1px) scale(1.32);
}
.brand-text strong{display:block;font-size:1rem}
.brand-text em{font-style:normal;color:var(--muted);font-size:.85rem}

.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:#0b2540;text-decoration:none;font-weight:600}
.nav a:hover{text-decoration:underline}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem}

/* hero */
.hero{background:radial-gradient(1200px 600px at 50% -200px, var(--bg), var(--bg-alt));color:#e9f1f8}
/* tighter vertical rhythm so the logo doesn't feel like it's floating in a sea of blue */
.hero-inner{padding:18px 0 28px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.hero h1{font-size:clamp(1.8rem, 2.6vw + 1rem, 3rem);margin:0}
.lead{color:#c8d6e3;margin:0}

.hero-logo{
  /* Responsive, capped size: avoids "out of control" on wide screens while staying strong on mobile */
  width:clamp(130px, 13vw, 175px);
  height:auto;
  margin:0;
  display:block;
  opacity:.95;
  filter:drop-shadow(0 10px 24px rgba(0,0,0,.25));
  /* Reduce apparent empty blue space caused by transparent padding in the logo file */
  transform:translateY(-6px) scale(1.15);
}

/* sections */
.section{padding:56px 0;background:#fff}
.section.alt{background:#f3f7fb}
.section-head{margin-bottom:24px}
.section-head h2{margin:.2rem 0 0}
/* prevent section titles from being hidden when navigating via #hash links */
section[id]{scroll-margin-top:var(--header-offset)}
.cards{display:grid;gap:16px}
.cards.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cards.three{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:#fff;border:1px solid #e5edf4;border-radius:16px;padding:16px}
.card .icon{font-size:28px}

/* angels */
.angels{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.angel{position:relative;padding:16px;border:1px solid #e5edf4;border-radius:16px;background:#fff}
.badge{position:absolute;top:-10px;left:-10px;background:var(--accent);color:#1a1a1a;font-weight:700;border-radius:999px;width:36px;height:36px;display:grid;place-items:center}

/* contact */
.contact-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.info{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.info .icon{font-size:22px}
.info h3{margin:0;font-size:1rem;line-height:1.25}
.info p{margin:.15rem 0 0;color:var(--muted)}
.info a{color:inherit}
.contact-form label{display:block;margin-bottom:.6rem;font-weight:600}
.contact-form input,.contact-form textarea{
  width:100%;padding:.65rem .8rem;border:1px solid #cdd8e4;border-radius:10px;background:#fff;color:var(--fg)
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;box-shadow:var(--ring)}
.form-note{color:#6c7f93;font-size:.875rem}

/* donate */
.donate{background:linear-gradient(180deg,#fff, #f7fafc)}
.donate h2{text-align:center;margin-top:0}
.donate p{text-align:center}
.donate .btn-row{justify-content:center}

/* footer */
.site-footer{background:#0b1f34;color:#d0d9e3;padding:22px 0}
.footer-grid{display:grid;gap:12px;align-items:center;grid-template-columns:1fr auto 1fr}
.footer-nav a{color:#d0d9e3;margin:0 .5rem;text-decoration:none}
.footer-nav a:hover{text-decoration:underline}
.copy{text-align:right}

/* small screens */
@media (max-width: 860px){
  .nav{display:none}
  .nav.open{display:flex;flex-direction:column;position:absolute;right:16px;top:var(--header-height);background:#fff;border:1px solid #e5edf4;border-radius:12px;padding:8px;box-shadow:0 10px 30px rgba(0,0,0,.06)}
  .nav-toggle{display:block;color:#0b2540}
  .footer-grid{grid-template-columns:1fr}
  .copy{text-align:left}
  .hero-inner{align-items:center;text-align:center}
}

/* accessibility + misc */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:#fff;border:2px solid var(--accent);padding:6px;border-radius:8px;z-index:1000}
