/* ================================================================
   WANDER NO LONGER FERAL CAT NETWORK — Shared Stylesheet
   ================================================================ */

/* ── 1. CSS Custom Properties (Light Mode) ── */
:root {
  --yellow:        #FFD700;
  --yellow-bright: #FFE835;
  --yellow-deep:   #F5C400;
  --pink:          #FF3D9A;
  --pink-light:    #FF7EC4;
  --pink-pale:     #FFD6EC;
  --purple:        #6B1FA8;
  --purple-deep:   #4A0E7A;
  --purple-mid:    #8B35C8;
  --purple-light:  #C084F5;
  --white:         #FFFFFF;
  --off-white:     #FFFEF5;
  --ink:           #1A0A2E;
  --ink-soft:      #3D1F5C;
  --card-bg:       #FFFFFF;
  --page-bg:       #FFFBEA;
  --input-bg:      #FFFFFF;
  --input-border:  rgba(107,31,168,0.3);
  --radius-xl:     28px;
  --radius-lg:     20px;
  --radius-md:     14px;
  --radius-pill:   999px;
  --shadow-yellow: 0 8px 30px rgba(255,215,0,0.45);
  --shadow-pink:   0 8px 30px rgba(255,61,154,0.4);
  --shadow-purple: 0 8px 30px rgba(107,31,168,0.35);
  --shadow-card:   0 6px 24px rgba(107,31,168,0.15);
  --transition-fast: 0.16s ease-out;
  --transition-med:  0.26s ease-out;
  --focus-ring: 0 0 0 3px rgba(255,61,154,0.6);
  --nav-bg:        var(--purple-deep);
  --footer-border: rgba(107,31,168,0.25);
  --deco-dot:      rgba(107,31,168,0.06);
}

/* ── 2. Dark Mode Variables ── */
[data-theme="dark"] {
  --page-bg:       #0D0118;
  --card-bg:       #1A0830;
  --white:         #1A0830;
  --off-white:     #0D0118;
  --ink:           #F0E6FF;
  --ink-soft:      #C084F5;
  --input-bg:      #1A0830;
  --input-border:  rgba(192,132,245,0.4);
  --shadow-card:   0 6px 24px rgba(0,0,0,0.4);
  --shadow-yellow: 0 8px 30px rgba(255,215,0,0.3);
  --shadow-pink:   0 8px 30px rgba(255,61,154,0.25);
  --shadow-purple: 0 8px 30px rgba(107,31,168,0.5);
  --footer-border: rgba(192,132,245,0.2);
  --deco-dot:      rgba(192,132,245,0.04);
}

/* ── 3. Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 6px; }

.skip-nav {
  position: absolute; left: -9999px; top: 0.5rem; z-index: 999;
  padding: 0.5rem 1rem; background: var(--pink); color: #fff;
  font-weight: 700; border-radius: var(--radius-pill); font-size: 0.9rem;
}
.skip-nav:focus { left: 1rem; }

body {
  font-family: 'Nunito', system-ui, sans-serif;
  background-color: var(--page-bg);
  background-image:
    radial-gradient(circle at 10% 5%, rgba(255,215,0,0.28) 0%, transparent 40%),
    radial-gradient(circle at 90% 20%, rgba(255,61,154,0.15) 0%, transparent 35%),
    radial-gradient(circle at 50% 80%, rgba(107,31,168,0.1) 0%, transparent 50%);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  transition: background-color 0.3s ease, color 0.3s ease;
}

[data-theme="dark"] body {
  background-image:
    radial-gradient(circle at 10% 5%, rgba(74,14,122,0.4) 0%, transparent 40%),
    radial-gradient(circle at 90% 20%, rgba(255,61,154,0.08) 0%, transparent 35%),
    radial-gradient(circle at 50% 80%, rgba(107,31,168,0.15) 0%, transparent 50%);
}

body::before {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(circle, var(--deco-dot) 1px, transparent 1px);
  background-size: 32px 32px;
}

body::after {
  content: "";
  position: fixed;
  top: 50%;
  left: 50%;
  width: min(68vmin, 600px);
  height: min(68vmin, 600px);
  transform: translate(-50%, -50%) scale(1);
  background-image: url('photos/WnlFcn-logo-2.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  border-radius: 50%;
  opacity: 0.07;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: 0;
  animation: logo-breathe 10s ease-in-out infinite;
}

[data-theme="dark"] body::after {
  mix-blend-mode: screen;
  opacity: 0.1;
}

@keyframes logo-breathe {
  0%, 100% { transform: translate(-50%, -50%) scale(1);    opacity: 0.07; }
  50%       { transform: translate(-50%, -50%) scale(1.06); opacity: 0.11; }
}

[data-theme="dark"] body::after { animation: logo-breathe-dark 10s ease-in-out infinite; }
@keyframes logo-breathe-dark {
  0%, 100% { transform: translate(-50%, -50%) scale(1);    opacity: 0.1; }
  50%       { transform: translate(-50%, -50%) scale(1.06); opacity: 0.15; }
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

body > header, body > footer {
  max-width: 1120px; margin: 0 auto;
  padding-left: 1.25rem; padding-right: 1.25rem;
  position: relative; z-index: 1;
}

main {
  max-width: 1120px; margin: 0 auto;
  padding: 1.5rem 1.25rem 3rem;
  position: relative; z-index: 1;
}

/* ── 4. Loading Screen ── */
#page-loader {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--purple-deep);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 1.2rem;
  transition: opacity 0.5s ease-out, visibility 0.5s ease-out;
}
#page-loader.fade-out { opacity: 0; visibility: hidden; }
.loader-cat {
  font-size: 3.5rem;
  animation: loaderBounce 0.8s ease-in-out infinite alternate;
}
.loader-bar {
  width: 200px; height: 6px;
  background: rgba(255,255,255,0.15); border-radius: 999px; overflow: hidden;
}
.loader-bar-fill {
  height: 100%; width: 0; border-radius: inherit;
  background: linear-gradient(90deg, var(--pink), var(--yellow-bright));
  animation: loaderFill 1.2s ease-out forwards;
}
.loader-text {
  font-family: 'Fredoka One', cursive;
  font-size: 1rem; color: var(--yellow-bright); letter-spacing: 0.05em;
}
@keyframes loaderBounce {
  from { transform: translateY(0) rotate(-5deg); }
  to   { transform: translateY(-12px) rotate(5deg); }
}
@keyframes loaderFill {
  0%   { width: 0; }
  100% { width: 100%; }
}

/* ── 5. Floating Paw Print Background ── */
.paw-bg {
  position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden;
}
.paw-float {
  position: absolute; bottom: -60px;
  font-size: 1.2rem; opacity: 0;
  animation: pawRise linear infinite;
  user-select: none; pointer-events: none;
  filter: saturate(0);
}
@keyframes pawRise {
  0%   { transform: translateY(0) rotate(0deg); opacity: 0; }
  8%   { opacity: 0.12; }
  88%  { opacity: 0.07; }
  100% { transform: translateY(-110vh) rotate(25deg); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .paw-float { animation: none !important; display: none; }
}

/* ── 6. Navigation ── */
.top-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 0.75rem;
  padding: 0.6rem 0.85rem 0.6rem 0.7rem; margin-bottom: 2rem;
  border-radius: var(--radius-pill);
  background: var(--purple-deep);
  border: 3px solid var(--yellow);
  box-shadow: var(--shadow-yellow), 0 0 0 6px rgba(255,215,0,0.08);
  position: sticky; top: 0.75rem; z-index: 100;
}
.brand {
  display: flex; align-items: center; gap: 0.7rem;
  text-decoration: none; flex-shrink: 0;
}
.brand-logo {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  background: radial-gradient(circle at 35% 25%, var(--yellow-bright) 0%, #FF9500 45%, var(--pink) 100%);
  border: 3px solid var(--yellow);
  box-shadow: 0 0 0 2px var(--purple-deep), 0 4px 14px rgba(0,0,0,0.4);
  overflow: hidden; display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
}
.brand-logo img {
  width: 100%; height: 100%; object-fit: cover; border-radius: 50%;
}
.brand-name { font-family: 'Fredoka One', cursive; font-size: 0.95rem; color: var(--yellow-bright); letter-spacing: 0.02em; line-height: 1.1; }
.brand-tagline { font-size: 0.68rem; color: var(--purple-light); font-weight: 600; }

.top-actions {
  display: flex; align-items: center; gap: 0.5rem;
  flex-wrap: nowrap;
}

/* ── 7. Hamburger Menu ── */
.hamburger {
  display: none; flex-direction: column; justify-content: center; align-items: center;
  gap: 5px; width: 40px; height: 40px; border-radius: var(--radius-md);
  background: rgba(255,255,255,0.08); border: 2px solid rgba(255,255,255,0.2);
  cursor: pointer; transition: background var(--transition-fast);
  flex-shrink: 0;
}
.hamburger:hover { background: rgba(255,215,0,0.15); border-color: var(--yellow); }
.hamburger span {
  display: block; width: 20px; height: 2px;
  background: var(--yellow-bright); border-radius: 2px;
  transition: transform var(--transition-med), opacity var(--transition-med);
}
.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav Overlay */
.nav-overlay {
  display: none; position: fixed; inset: 0; z-index: 99;
  background: rgba(10,2,25,0.6); backdrop-filter: blur(4px);
}
.nav-overlay.open { display: block; }

@media (max-width: 820px) {
  .hamburger { display: flex; }
  .top-bar { padding-right: 0.7rem; }
  .top-actions {
    display: none; position: fixed; top: 0; right: 0;
    height: 100vh; width: min(300px, 85vw);
    flex-direction: column; align-items: stretch; gap: 0.5rem;
    background: var(--purple-deep); padding: 5rem 1.2rem 2rem;
    border-left: 3px solid var(--yellow);
    box-shadow: -8px 0 40px rgba(0,0,0,0.5);
    z-index: 101; overflow-y: auto;
    transition: transform var(--transition-med);
    transform: translateX(100%);
  }
  .top-actions.open {
    display: flex; transform: translateX(0);
  }
  .top-actions .pill-link { width: 100%; justify-content: flex-start; font-size: 0.95rem; padding: 0.7rem 1rem; color: #fff; border-color: rgba(255,255,255,0.2); }
  .top-actions .pill-link:hover { color: var(--yellow-bright); border-color: var(--yellow); background: rgba(255,215,0,0.12); }
  .top-actions .btn-primary { width: 100%; justify-content: center; }
  .top-actions .dark-toggle { width: 100%; justify-content: center; color: #fff; border-color: rgba(255,255,255,0.2); }
}
@media (max-width: 820px) { main { padding-top: 1rem; } }

/* ── 8. Dark Mode Toggle ── */
.dark-toggle {
  font-family: 'Nunito', sans-serif; font-size: 0.8rem; font-weight: 700;
  padding: 0.45rem 0.85rem; border-radius: var(--radius-pill);
  border: 2px solid rgba(255,255,255,0.3); color: var(--yellow-bright);
  background: rgba(255,255,255,0.08); cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast);
  white-space: nowrap; min-height: 40px;
  display: inline-flex; align-items: center; gap: 0.35rem;
}
.dark-toggle:hover { background: rgba(255,215,0,0.15); border-color: var(--yellow); }

/* ── 9. Buttons ── */
.pill-link {
  font-family: 'Nunito', sans-serif; font-size: 0.8rem; font-weight: 700;
  padding: 0.45rem 1rem; border-radius: var(--radius-pill);
  border: 2px solid rgba(255,255,255,0.3); color: var(--purple-light);
  background: rgba(255,255,255,0.08); cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
  white-space: nowrap; min-height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  text-decoration: none;
}
.pill-link:hover { background: rgba(255,215,0,0.15); border-color: var(--yellow); color: var(--yellow-bright); transform: translateY(-1px); }

.btn-primary {
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.03em;
  padding: 0.6rem 1.4rem; border-radius: var(--radius-pill);
  border: 3px solid var(--yellow-deep);
  background: linear-gradient(135deg, var(--yellow-bright), var(--yellow-deep));
  color: var(--purple-deep); cursor: pointer; box-shadow: var(--shadow-yellow);
  display: inline-flex; align-items: center; gap: 0.4rem;
  transition: transform var(--transition-med), box-shadow var(--transition-med), filter var(--transition-med);
  white-space: nowrap; min-height: 44px; text-decoration: none;
}
.btn-primary .icon { font-size: 1.1rem; line-height: 1; }
.btn-primary:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 14px 35px rgba(255,215,0,0.6); filter: brightness(1.05); }
.btn-primary:active { transform: translateY(0) scale(0.98); }

.btn-pink {
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.03em;
  padding: 0.6rem 1.4rem; border-radius: var(--radius-pill);
  border: 3px solid #cc1f76;
  background: linear-gradient(135deg, var(--pink), #cc2277);
  color: #fff; cursor: pointer; box-shadow: var(--shadow-pink);
  display: inline-flex; align-items: center; gap: 0.4rem;
  transition: transform var(--transition-med), box-shadow var(--transition-med);
  white-space: nowrap; min-height: 44px; text-decoration: none;
}
.btn-pink:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 14px 35px rgba(255,61,154,0.5); }
.btn-pink:active { transform: translateY(0) scale(0.98); }

.btn-purple {
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.03em;
  padding: 0.6rem 1.4rem; border-radius: var(--radius-pill);
  border: 3px solid var(--purple);
  background: linear-gradient(135deg, var(--purple-mid), var(--purple-deep));
  color: #fff; cursor: pointer; box-shadow: var(--shadow-purple);
  display: inline-flex; align-items: center; gap: 0.4rem;
  transition: transform var(--transition-med), box-shadow var(--transition-med);
  white-space: nowrap; min-height: 44px; text-decoration: none;
}
.btn-purple:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 14px 40px rgba(107,31,168,0.5); }

/* Payment method buttons */
.btn-venmo {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.02em;
  padding: 0.7rem 1.4rem; border-radius: var(--radius-pill); min-height: 48px;
  border: 3px solid #008CFF; background: #3D95CE; color: #fff;
  cursor: pointer; width: 100%; text-decoration: none;
  transition: transform var(--transition-med), filter var(--transition-med);
}
.btn-venmo:hover { transform: translateY(-2px); filter: brightness(1.1); }

.btn-cashapp {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.02em;
  padding: 0.7rem 1.4rem; border-radius: var(--radius-pill); min-height: 48px;
  border: 3px solid #00C244; background: #00C244; color: #fff;
  cursor: pointer; width: 100%; text-decoration: none;
  transition: transform var(--transition-med), filter var(--transition-med);
}
.btn-cashapp:hover { transform: translateY(-2px); filter: brightness(1.1); }

.btn-zelle {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.02em;
  padding: 0.7rem 1.4rem; border-radius: var(--radius-pill); min-height: 48px;
  border: 3px solid #6B2FBB; background: #6B2FBB; color: #fff;
  cursor: pointer; width: 100%; text-decoration: none;
  transition: transform var(--transition-med), filter var(--transition-med);
}
.btn-zelle:hover { transform: translateY(-2px); filter: brightness(1.1); }

.btn-wishlist {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.02em;
  padding: 0.7rem 1.4rem; border-radius: var(--radius-pill); min-height: 48px;
  border: 3px solid #FF9900; background: linear-gradient(135deg, #FF9900, #e67e00); color: #fff;
  cursor: pointer; width: 100%; text-decoration: none;
  transition: transform var(--transition-med), filter var(--transition-med);
}
.btn-wishlist:hover { transform: translateY(-2px); filter: brightness(1.1); }

/* Disabled state */
.btn-disabled, [data-pending="true"] {
  opacity: 0.5; cursor: not-allowed; pointer-events: none;
}

/* ── 10. Section Utilities ── */
section { margin-bottom: 3rem; }
.section-label {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.74rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--white); background: var(--purple); padding: 0.2rem 0.75rem;
  border-radius: var(--radius-pill); margin-bottom: 0.5rem;
}
.section-title { font-family: 'Fredoka One', cursive; font-size: 1.7rem; color: var(--ink); margin-bottom: 0.7rem; line-height: 1.15; }
.section-intro { font-size: 0.97rem; color: var(--ink-soft); max-width: 40rem; margin-bottom: 1.5rem; font-weight: 600; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.78rem; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--white); background: var(--pink); padding: 0.25rem 0.8rem;
  border-radius: var(--radius-pill); margin-bottom: 0.8rem; box-shadow: var(--shadow-pink);
}

/* ── 11. Card Base ── */
.card {
  border-radius: var(--radius-lg); background: var(--card-bg);
  border: 3px solid rgba(107,31,168,0.2); padding: 1rem 1.1rem;
  box-shadow: var(--shadow-card); position: relative; overflow: hidden;
  transition: transform var(--transition-med), box-shadow var(--transition-med), border-color var(--transition-med);
}
.card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 5px;
  background: linear-gradient(90deg, var(--pink), var(--yellow));
}
.card:hover { transform: translateY(-4px) rotate(0.3deg); box-shadow: 0 16px 36px rgba(107,31,168,0.22); border-color: var(--purple-mid); }

/* Striped top border helper */
.stripe-top::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 6px;
  background: repeating-linear-gradient(90deg, var(--yellow) 0px, var(--yellow) 20px, var(--pink) 20px, var(--pink) 40px, var(--purple-mid) 40px, var(--purple-mid) 60px);
}

/* ── 12. Forms ── */
.form-group { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.form-label {
  font-size: 0.82rem; font-weight: 800; color: var(--ink-soft); letter-spacing: 0.04em; text-transform: uppercase;
}
.form-input, .form-select, .form-textarea {
  font-family: 'Nunito', sans-serif; font-size: 0.95rem; font-weight: 600;
  padding: 0.65rem 1rem; border-radius: var(--radius-md);
  border: 2px solid var(--input-border); background: var(--input-bg); color: var(--ink);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--purple); box-shadow: 0 0 0 3px rgba(107,31,168,0.15); outline: none;
}
.form-textarea { resize: vertical; min-height: 100px; }
.form-select { appearance: none; cursor: pointer; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } }

/* ── 13. Donation Amount Toggle ── */
.donate-type-tabs {
  display: flex; gap: 0; margin-bottom: 1.5rem;
  border-radius: var(--radius-pill); overflow: hidden;
  border: 3px solid var(--purple); width: fit-content;
}
.donate-tab {
  font-family: 'Fredoka One', cursive; font-size: 0.95rem; letter-spacing: 0.03em;
  padding: 0.55rem 1.5rem; border: none; cursor: pointer;
  background: var(--card-bg); color: var(--purple);
  transition: background var(--transition-fast), color var(--transition-fast);
  min-height: 44px;
}
.donate-tab.active { background: var(--purple); color: #fff; }

.amount-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.6rem;
  margin-bottom: 1.2rem;
}
@media (max-width: 500px) { .amount-grid { grid-template-columns: repeat(2, 1fr); } }
.amount-btn {
  font-family: 'Fredoka One', cursive; font-size: 1.1rem;
  padding: 0.65rem 0.5rem; border-radius: var(--radius-md);
  border: 3px solid rgba(107,31,168,0.25); background: var(--card-bg);
  color: var(--ink); cursor: pointer; text-align: center;
  transition: all var(--transition-fast);
}
.amount-btn:hover { border-color: var(--purple); color: var(--purple); }
.amount-btn.selected { border-color: var(--purple); background: var(--purple); color: #fff; box-shadow: var(--shadow-purple); }
.amount-custom {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 1rem; font-weight: 700; color: var(--ink-soft);
  margin-bottom: 1.2rem;
}
.amount-custom input {
  font-family: 'Fredoka One', cursive; font-size: 1.1rem;
  padding: 0.6rem 1rem; border-radius: var(--radius-md);
  border: 2px solid var(--input-border); background: var(--input-bg); color: var(--ink);
  width: 140px;
}

/* Payment methods grid */
.payment-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-top: 1.2rem; }
@media (max-width: 500px) { .payment-grid { grid-template-columns: 1fr; } }

/* ── 14. Newsletter Signup ── */
.newsletter-block {
  border-radius: var(--radius-xl); background: var(--purple-deep);
  border: 3px solid var(--yellow-bright);
  box-shadow: var(--shadow-yellow); padding: 1.8rem 2rem;
  position: relative; overflow: hidden;
}
.newsletter-block::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 5px;
  background: repeating-linear-gradient(90deg, var(--yellow) 0px, var(--yellow) 20px, var(--pink) 20px, var(--pink) 40px, var(--purple-mid) 40px, var(--purple-mid) 60px);
}
.newsletter-title { font-family: 'Fredoka One', cursive; font-size: 1.3rem; color: var(--yellow-bright); margin-bottom: 0.4rem; }
.newsletter-body { font-size: 0.88rem; font-weight: 600; color: var(--purple-light); margin-bottom: 1rem; }
.newsletter-form { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.newsletter-input {
  flex: 1; min-width: 200px; font-family: 'Nunito', sans-serif; font-size: 0.95rem; font-weight: 600;
  padding: 0.65rem 1rem; border-radius: var(--radius-pill);
  border: 2px solid rgba(255,215,0,0.3); background: rgba(255,255,255,0.1); color: #fff;
}
.newsletter-input::placeholder { color: rgba(255,255,255,0.5); }
.newsletter-input:focus { border-color: var(--yellow); outline: none; box-shadow: 0 0 0 3px rgba(255,215,0,0.2); }

/* ── 15. Transparency Section ── */
.transparency-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 0.75rem; }
@media (max-width: 840px) { .transparency-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 500px) { .transparency-grid { grid-template-columns: 1fr; } }
.transparency-card {
  border-radius: var(--radius-lg); background: var(--card-bg);
  border: 2px solid rgba(107,31,168,0.2); padding: 1rem;
  box-shadow: var(--shadow-card); text-align: center;
}
.trans-bar-wrap { width: 100%; height: 10px; background: rgba(107,31,168,0.1); border-radius: 999px; overflow: hidden; margin: 0.5rem 0; }
.trans-bar { height: 100%; border-radius: inherit; transition: width 1.2s cubic-bezier(0.19,1,0.22,1); }
.trans-pct { font-family: 'Fredoka One', cursive; font-size: 1.4rem; color: var(--pink); }
.trans-label { font-size: 0.75rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }

/* ── 16. Map Block ── */
.map-block {
  border-radius: var(--radius-xl); overflow: hidden;
  border: 3px solid var(--yellow);
  box-shadow: var(--shadow-yellow);
  position: relative;
}
.map-block iframe { display: block; width: 100%; border: none; }
.map-overlay-badge {
  position: absolute; top: 1rem; left: 1rem;
  background: var(--purple-deep); border: 2px solid var(--yellow);
  color: var(--yellow-bright); font-weight: 700; font-size: 0.82rem;
  padding: 0.3rem 0.8rem; border-radius: var(--radius-pill);
  pointer-events: none;
}

/* ── 17. Footer ── */
footer {
  border-top: 3px dashed var(--footer-border); padding-top: 1.5rem; margin-top: 2rem;
  font-size: 0.82rem; font-weight: 700; color: var(--ink-soft);
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  justify-content: space-between; align-items: center;
}
.footer-links { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.footer-links a { color: var(--purple); font-weight: 800; text-decoration: none; position: relative; }
.footer-links a::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: var(--pink); transition: width var(--transition-fast); }
.footer-links a:hover::after { width: 100%; }
.footer-links a:hover { color: var(--pink); }
[data-theme="dark"] .footer-links a { color: var(--purple-light); }
.footer-socials { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 0.4rem; }
.footer-socials a { display: inline-flex; align-items: center; gap: 0.3rem; padding: 0.25rem 0.7rem; border-radius: var(--radius-pill); border: 2px solid rgba(107,31,168,0.25); color: var(--purple); font-weight: 800; font-size: 0.78rem; text-decoration: none; background: var(--card-bg); transition: all var(--transition-fast); }
.footer-socials a:hover { background: var(--purple); color: #fff; border-color: var(--purple); }
[data-theme="dark"] .footer-socials a { color: var(--purple-light); border-color: rgba(192,132,245,0.3); background: rgba(255,255,255,0.04); }
[data-theme="dark"] .footer-socials a:hover { background: var(--purple-mid); color: #fff; }

/* ── 18. Mobile Sticky Donate Bar ── */
.mobile-donate-bar {
  display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
  background: var(--purple-deep); border-top: 3px solid var(--yellow);
  box-shadow: 0 -4px 20px rgba(0,0,0,0.4);
  padding: 0.6rem 1rem; gap: 0.75rem;
  align-items: center; justify-content: center;
}
.mobile-donate-bar .btn-primary { flex: 1; max-width: 280px; justify-content: center; }
@media (max-width: 820px) {
  .mobile-donate-bar { display: flex; }
  main { padding-bottom: 1.5rem; }
  body > footer { padding-bottom: 5.5rem; }
}

/* ── 19. Reveal Animation ── */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 0.65s ease-out, transform 0.65s ease-out; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── 20. Progress Bar ── */
.progress-wrap { margin-top: 0.9rem; }
.progress-label-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 0.78rem; font-weight: 700; color: var(--purple-light); margin-bottom: 0.3rem;
}
.progress-label-row strong { color: var(--yellow-bright); }
.progress-track {
  width: 100%; height: 12px; border-radius: 999px;
  background: rgba(255,255,255,0.12); border: 2px solid rgba(255,215,0,0.3);
  overflow: hidden; position: relative;
}
.progress-fill {
  height: 100%; width: 0; border-radius: inherit;
  background: linear-gradient(90deg, var(--pink), var(--yellow-bright));
  box-shadow: 0 0 14px rgba(255,215,0,0.7);
  transition: width 1.4s cubic-bezier(0.19,1,0.22,1);
}
.progress-glow {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2.5s infinite; pointer-events: none;
}
@keyframes shimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(300%); } }

/* ── 21. Accessibility & Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  .reveal, .progress-fill, .progress-glow, img,
  .btn-primary, .pill-link, .card { transition: none !important; animation: none !important; }
  .reveal { opacity: 1; transform: none; }
  #page-loader { display: none !important; }
  body::after, body::before { animation: none !important; }
  .loader-cat, .loader-bar-fill { animation: none !important; }
}

/* ── 21b. System dark mode fallback (before JS runs) ── */
@media (prefers-color-scheme: dark) {
  html:not([data-theme="light"]) {
    --page-bg:       #0D0118;
    --card-bg:       #1A0830;
    --white:         #1A0830;
    --off-white:     #0D0118;
    --ink:           #F0E6FF;
    --ink-soft:      #C084F5;
    --input-bg:      #1A0830;
    --input-border:  rgba(192,132,245,0.4);
    --shadow-card:   0 6px 24px rgba(0,0,0,0.4);
    --footer-border: rgba(192,132,245,0.2);
    --deco-dot:      rgba(192,132,245,0.04);
  }
}

/* ── 22. Image lazy loading ── */
img[loading="lazy"] { will-change: auto; }

/* ── 23. Utility classes ── */
.text-yellow { color: var(--yellow-bright); }
.text-pink   { color: var(--pink); }
.text-purple { color: var(--purple); }
.mt-1 { margin-top: 0.5rem; } .mt-2 { margin-top: 1rem; } .mt-3 { margin-top: 1.5rem; }
.mb-1 { margin-bottom: 0.5rem; } .mb-2 { margin-bottom: 1rem; }
.w-full { width: 100%; }
.text-center { text-align: center; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-wrap { display: flex; flex-wrap: wrap; gap: 0.75rem; }
