:root {
  --bg: #fffaf8;
  --bg-soft: #fff1f4;
  --surface: rgba(255,255,255,0.78);
  --text: #1a1a1a;
  --muted: #5f5f68;
  --line: rgba(29, 29, 31, 0.12);

  /* Brand */
  --fuchsia: #d93973; 
  --fuchsia-dark: #b52b5c;
  --hotpink: #ff2f92;
  --blue: #1146b3;

  --shadow: 0 16px 40px rgba(64, 33, 47, 0.12);
  --radius: 24px;
  --radius-sm: 16px;
  --container: min(1120px, calc(100% - 2rem));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Manrope", system-ui, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #fffaf8 0%, #fff7fb 100%);
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }

:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 3px;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: -3rem;
  background: #fff;
  padding: .75rem 1rem;
  z-index: 999;
  border-radius: 12px;
  box-shadow: var(--shadow);
}
.skip-link:focus { top: 1rem; }

.container { width: var(--container); margin-inline: auto; }
.section { padding: 5rem 0; }
.section-label {
  margin: 0 0 .5rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .84rem;
  font-weight: 800;
  color: var(--fuchsia);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(18px);
  background: rgba(255, 250, 248, 0.85);
  border-bottom: 1px solid rgba(255,255,255,0.3);
}
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 74px;
  gap: 1rem;
}
.brand {
  display: inline-flex;
  gap: .75rem;
  align-items: center;
}
.brand-mark {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: linear-gradient(135deg, #ffe3ec, #fff);
  box-shadow: var(--shadow);
}
.brand small { display: block; color: var(--muted); }

.site-nav ul {
  display: flex;
  gap: 1rem;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.site-nav a { font-weight: 800; color: #30303a; }
.nav-toggle {
  display: none;
  border: 1px solid var(--line);
  background: #fff;
  padding: .7rem 1rem;
  border-radius: 999px;
}

/* HERO */
.hero {
  position: relative;
  overflow: hidden;
  min-height: 92vh;
  display: grid;
  align-items: center;
  background:
    linear-gradient(180deg, rgba(255,250,248,0.12), rgba(255,250,248,0.92)),
    linear-gradient(110deg, rgba(217,59,115,.12), rgba(17,70,179,.08)),
    url('../img/background.jpg') center/cover no-repeat;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 10%, rgba(255,255,255,0.72), transparent 35%),
    radial-gradient(circle at 90% 20%, rgba(255,227,236,0.55), transparent 30%);
}
.hero-grid {
  width: var(--container);
  margin-inline: auto;
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 1.5rem;
  align-items: center;
}
.eyebrow {
  margin: 0 0 .5rem;
  font-weight: 900;
  color: var(--fuchsia-dark);
}
.hero h1 {
  margin: 0;
  font-size: clamp(2.3rem, 5vw, 4.7rem);
  line-height: 1.05;
  display: flex;
  flex-direction: column;
}
.hero h1 .hero-title-location {
  font-size: .7em;
}
.hero-title-accent { color: var(--hotpink); }
.lead {
  font-size: 1.08rem;
  max-width: 66ch;
  color: #2f2f37;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin: 1.5rem 0 1rem;
}
.hero-actions--secondary { margin-top: 0; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: .9rem 1.25rem;
  border-radius: 999px;
  font-weight: 900;
  border: 1px solid transparent;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover { transform: translateY(-1px); }

.btn-primary {
  color: #fff;
  background: linear-gradient(135deg, var(--fuchsia), var(--fuchsia-dark));
  box-shadow: 0 16px 30px rgba(181, 43, 92, 0.28);
}
.btn-secondary {
  background: rgba(255,255,255,0.88);
  border-color: rgba(26,26,26,0.10);
}
.btn-tertiary {
  background: rgba(255,255,255,0.72);
  border-color: rgba(26,26,26,0.08);
}

.pill {
  padding: .55rem .9rem;
  border-radius: 999px;
  font-size: .95rem;
  font-weight: 800;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(255,255,255,0.8);
}

.hero-card,
.card,
.glass-card,
.mission-quote,
.qr-card {
  background: var(--surface);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
}
.hero-card { padding: 1.25rem; }
.hero-card__top {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  margin-bottom: .8rem;
}
.pill-light { background: rgba(255,255,255,0.54); }
.hero-card h2 { margin: 0 0 1rem; font-size: 1.5rem; }
.hero-locations {
  margin: 1rem 0 0;
  padding: .9rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,0.65);
  border: 1px solid rgba(26,26,26,0.06);
  color: #2f2f37;
}
.text-link { color: var(--blue); font-weight: 900; display: inline-block; margin-top: 1rem; }

/* LAYOUT GRIDS */
.two-col,
.mission-grid,
.donate-grid { display: grid; gap: 1.5rem; grid-template-columns: 1.1fr .9fr; align-items: start; }
.cards-3 { display: grid; gap: 1rem; grid-template-columns: repeat(3, 1fr); }

.glass-card,
.card,
.qr-card,
.mission-quote { padding: 1.5rem; }
.feature-list { padding-left: 1.2rem; margin: 0; }
.feature-list li + li { margin-top: .55rem; }

.alt-bg {
  background: linear-gradient(180deg, rgba(255,255,255,0.45), rgba(255,241,244,0.70));
}

/* Program day blocks */
.day-blocks {
  margin-top: 1.5rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}
.day-block {
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(26,26,26,.07);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
}
.day-block h3 { margin: 0 0 .75rem; }
.day-block ul { margin: 0; padding-left: 1.2rem; }
.day-block li + li { margin-top: .5rem; }
.day-badge {
  display: inline-flex;
  align-items: center;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: rgba(217,59,115,.10);
  color: var(--fuchsia);
  font-weight: 900;
  margin-right: .35rem;
}

/* Mission */
.mission-section {
  background: linear-gradient(125deg, rgba(255,214,227,0.45), rgba(255,255,255,0.88));
}
.mission-quote {
  display: grid;
  align-content: center;
  gap: .5rem;
}
.mission-quote p {
  margin: 0;
  font-size: clamp(1.15rem, 3vw, 1.75rem);
  line-height: 1.3;
  font-weight: 900;
}
.mission-quote span { color: var(--muted); }

/* Carousel */
.carousel {
  margin-top: 1.25rem;
  overflow-x: auto;
  padding-bottom: .5rem;
  scroll-snap-type: x mandatory;
}
.carousel-track {
  display: flex;
  gap: 1rem;
  padding: .25rem .1rem;
}
.carousel-item {
  margin: 0;
  scroll-snap-align: start;
  min-width: min(560px, 85vw);
  border-radius: var(--radius);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow);
}
.carousel-item img {
  width: 100%;
  height: 340px;
  object-fit: cover;
}
.carousel-item figcaption {
  padding: .85rem 1rem;
  font-weight: 800;
}

/* Donate */
.donate-section {
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(255,241,244,0.95));
}
.donate-link { margin-top: .75rem; }
.qr-card { text-align: center; }
.qr-card img {
  margin: 0 auto 1rem;
  border-radius: 24px;
  background: #fff;
  padding: .8rem;
}

.partners {
  padding: 72px 0;
  background: #fff8fb;
}

.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 20px;
  align-items: stretch;
}

.partner-card {
  background: #ffffff;
  border: 1px solid rgba(210, 32, 110, 0.08);
  border-radius: 20px;
  min-height: 120px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 30px rgba(30, 20, 40, 0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.partner-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(30, 20, 40, 0.1);
}

.partner-card img {
  max-width: 100%;
  max-height: 72px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  filter: saturate(1);
}

@media (max-width: 640px) {
  .partners {
    padding: 56px 0;
  }

  .partners-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .partner-card {
    min-height: 110px;
    padding: 16px;
    border-radius: 16px;
  }

  .partner-card img {
    max-height: 56px;
  }
}

/* Footer */
.site-footer {
  padding: 2.5rem 0 3rem;
  background: #12131a;
  color: #f6f7fb;
}
.footer-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(2, 1fr);
}
.site-footer p { color: rgba(246,247,251,.75); }

/* Responsive */
@media (max-width: 1020px) {
  .hero-grid,
  .two-col,
  .mission-grid,
  .donate-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }
  .cards-3 { grid-template-columns: 1fr; }
  .day-blocks { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding-top: 3rem; }
}

@media (max-width: 760px) {
  .site-nav ul {
    position: absolute;
    right: 1rem;
    top: 70px;
    width: min(320px, calc(100% - 2rem));
    flex-direction: column;
    align-items: stretch;
    background: rgba(255,255,255,0.95);
    box-shadow: var(--shadow);
    border-radius: 24px;
    padding: 1rem;
    display: none;
  }
  .site-nav ul.open { display: flex; }
  .nav-toggle { display: inline-flex; }
  .section { padding: 4rem 0; }
  .carousel-item img { height: 280px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
  }
}
