:root{
  --bg:#071022;
  --card:#0b1220;
  --muted:#9aa4b2;
  --accent:#10b981;
  --glass: rgba(255,255,255,0.03);
  --maxw:1100px;
  --radius:12px;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  color-scheme: dark;
}
*{box-sizing:border-box}
body{
  margin:0;
  background: linear-gradient(180deg,#041126 0%, #071022 100%);
  color:#e6eef6;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
.container{width:95%;max-width:var(--maxw);margin:0 auto;padding:24px;}
.site-header{border-bottom:1px solid rgba(255,255,255,0.03);background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent)}
.header-inner{display:flex;align-items:center;gap:16px;justify-content:space-between;}
.brand{font-weight:800;font-size:18px;color:#fff;text-decoration:none}
.nav a{color:var(--muted);margin:0 8px;text-decoration:none}
.actions{display:flex;gap:8px}
.btn{background:var(--accent);border:none;color:#022;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--muted)}

.hero{padding:28px 0;text-align:center}
.hero h1{font-size:32px;margin:0 0 12px}
.lede{color:var(--muted);margin:0 0 16px;max-width:900px;margin-left:auto;margin-right:auto}

.search-row{display:flex;justify-content:center;gap:8px;margin-top:10px}
.search-row input[type=search]{width:60%;min-width:220px;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.04);background:var(--glass);color:inherit}
.search-row button{padding:12px 16px;border-radius:10px}

.muted-note{color:var(--muted);text-align:center;margin-top:8px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-top:18px;align-items:start}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,0.02);display:flex;flex-direction:column;min-height:240px}
.card h3{margin:0 0 6px}
.card p{margin:6px 0;color:var(--muted);font-size:14px}
.card .meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.card .meta small{color:var(--muted)}
.card .actions{display:flex;gap:8px}

.card img.card-img{width:100%;height:180px;object-fit:cover;border-radius:8px;margin-bottom:12px}
.card img.logo{width:140px;height:80px;object-fit:contain;background:rgba(255,255,255,0.02);padding:8px;border-radius:8px;margin-bottom:12px}

/* product detail hero */
.product-hero{width:100%;max-height:520px;object-fit:contain;border-radius:10px;display:block;margin-bottom:18px}

/* NGO beneficiaries grid in projects */
.beneficiaries-grid .card{min-height:160px;padding:12px;}

/* small helpers */
.featured h2{margin-top:0}
.empty{padding:30px;text-align:center;color:var(--muted)}
.hidden{display:none}

.site-footer{margin-top:auto;padding:24px 0;border-top:1px solid rgba(255,255,255,0.03);text-align:left;color:var(--muted);font-size:14px}
.footer-columns{display:flex;gap:28px;justify-content:space-between;align-items:flex-start}
.footer-nav a{display:block;color:var(--muted);text-decoration:none;margin:6px 0}

/* filters */
.filter-row{display:flex;gap:8px;justify-content:center;margin-top:12px;flex-wrap:wrap}
.filter-row select{padding:8px;border-radius:8px;background:var(--glass);border:1px solid rgba(255,255,255,0.04);color:inherit}

/* responsive */
@media (max-width:720px){
  .search-row input[type=search]{width:100%}
  .footer-columns{flex-direction:column;gap:12px}
  .hero h1{font-size:22px}
  .card img.card-img{height:140px}
  .card img.logo{width:100px;height:56px}
}

/* --- Signup modal (append to bottom of assets/css/style.css) --- */
.omg-modal-backdrop{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(2,6,23,0.70);
  z-index: 99999; /* very high so it sits above everything */
  padding: 20px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
.omg-modal {
  width:100%;
  max-width:720px;
  border-radius:14px;
  padding:22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  box-shadow: 0 12px 40px rgba(2,6,23,0.6);
  color: #e6eef6; /* keep site text color */
  border: 1px solid rgba(255,255,255,0.04);
}
.omg-modal h2 { margin:0 0 8px; font-size:22px; color:#fff; }
.omg-modal p.lede { color:var(--muted); margin:8px 0 14px; font-size:15px; max-width:100%; }
.omg-modal .controls { display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
.omg-modal input[type="text"], .omg-modal input[type="email"]{
  width:100%; padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.04); background: var(--glass); color:inherit;
  margin-top:6px;
}
.omg-modal label{ display:block; margin-top:8px; font-size:13px; color:var(--muted) }
.omg-modal .btn { padding:10px 14px; border-radius:8px; cursor:pointer; font-weight:600 }
.omg-modal .btn-primary { background:var(--accent); color:#022; border:none; }
.omg-modal .btn-ghost { background:transparent; border:1px solid rgba(255,255,255,0.06); color:var(--muted); }
.omg-modal .muted-note { color:var(--muted); font-size:13px; margin-top:10px; }
.hide { display:none !important; }
