:root {
  --bg: #8ef5c8;
  --panel: #c2f0ff;
  --panel-2: #a5c3fa;
  --text: #f7f9fa;
  --muted: #f7f9fa;
  --brand: #4cc38a;
  --brand-700: #18794e;
  --danger: #ff6b6b;
  --border: #223041;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: linear-gradient(180deg, var(--panel-2), var(--bg));
  color: var(--text);
}
.topbar { padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--panel-2); position: sticky; top: 0; z-index: 10; }
.topbar h1 { font-size: 18px; margin: 0; }
.layout { max-width: 1100px; margin: 0 auto; padding: 12px; }
.controls { display: grid; gap: 10px; grid-template-columns: 1fr; }
.search { display: flex; gap: 8px; }
input[type="text"], input[type="email"], select {
  width: 100%; padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border); background: #0c121b; color: var(--text);
}
.primary { background: var(--brand); color: #052e1c; border: 1px solid var(--brand-700); padding: 10px 14px; border-radius: 8px; font-weight: 600; cursor: pointer; }
.primary:hover { filter: brightness(1.05); }
.secondary { background: transparent; color: var(--text); border: 1px solid var(--border); padding: 10px 14px; border-radius: 8px; cursor: pointer; }
.filters { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; font-size: 14px; color: var(--muted); }
.map-list { display: grid; grid-template-columns: 1.2fr 1fr; gap: 12px; margin-top: 12px; }
.map { height: 70vh; border: 1px solid var(--border); border-radius: 10px; background: #0d1420; }
.list { height: 70vh; overflow: auto; border: 1px solid var(--border); border-radius: 10px; background: var(--panel); padding: 8px; }
.card { border: 1px solid var(--border); border-radius: 10px; padding: 10px; background: #0e1724; margin-bottom: 8px; }
.row { display: flex; gap: 8px; align-items: center; }
.row.end { justify-content: flex-end; }
.muted { color: var(--muted); font-size: 14px; }
.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 12px; background: #102234; border: 1px solid var(--border); color: var(--muted); }
.modal { position: fixed; inset: 0; display: grid; place-items: center; background: rgba(0,0,0,.5); }
.modal.hidden { display: none; }
.modal-card { width: min(520px, calc(100vw - 24px)); background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px; }
.status { min-height: 20px; font-size: 14px; }
.donate { color: var(--brand); text-decoration: none; font-weight: 600; }
@media (max-width: 900px) { .map-list { grid-template-columns: 1fr; } .map, .list { height: 50vh; } }

/* Google Maps InfoWindow dark theme overrides */
.gm-style .gm-style-iw-c { background: #0e1724; color: var(--text); border: 1px solid var(--border); border-radius: 10px; }
.gm-style .gm-style-iw-d { color: var(--text); }
.gm-style .gm-ui-hover-effect { filter: invert(1); }
.gm-style .gm-style-iw-t::after { background: #0e1724; }
