
:root{
  --bg:#ffffff;
  --card:#ffffff;
  --card2:#ffffff;
  --text:#0b1220;
  --muted:#5b667a;
  --accent:#28bacb;
  --accent2:#28bacb;
  --border:rgba(10,20,30,.12);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;color:var(--text);background:#f6fbfc;}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 10px}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--accent),#1aa8b8);display:flex;align-items:center;justify-content:center;font-weight:800}
.brand-title{font-weight:700}
.brand-sub{font-size:12px;color:var(--muted)}
.nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#1aa8b8);font-weight:700;border:1px solid rgba(0,0,0,.2)}
.btn.secondary{background:rgba(255,255,255,.08);border:1px solid var(--border);font-weight:600}
.btn.small{padding:8px 10px;border-radius:12px;font-size:13px}
.muted{color:var(--muted)}
.hero{padding:34px 0 10px}
.hero-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:16px;align-items:stretch}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr}}
.card{background:linear-gradient(180deg,var(--card) 0%, var(--card2) 100%);border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:0 10px 24px rgba(10,20,30,.10)}
.h1{font-size:34px;line-height:1.15;margin:0 0 10px}
.h2{font-size:18px;margin:0 0 10px}
.p{margin:0 0 12px;color:var(--muted);line-height:1.6}
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.kpi{padding:12px;border-radius:18px;border:1px solid var(--border);background:rgba(255,255,255,.04)}
.kpi b{display:block;font-size:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:900px){.grid3{grid-template-columns:1fr}}
.form{display:grid;gap:10px}
.input, select, textarea{width:100%;padding:14px 14px;border-radius:16px;border:1px solid var(--border);background:rgba(10,20,30,.03);color:var(--text);outline:none;font-size:16px}

label{font-size:14px;color:var(--muted);font-weight:600}

.row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:700px){.row{grid-template-columns:1fr}}
.badge{display:inline-flex;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(40,186,203,.10);font-size:12px;color:#0b5f69}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}
.table th{color:var(--muted);font-weight:600}
.footer{border-top:1px solid var(--border);background:rgba(255,255,255,.92);backdrop-filter:blur(10px);margin-top:28px}
.footer-inner{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 10px;flex-wrap:wrap}
.footer-title{font-weight:700}
.notice{padding:12px;border:1px solid rgba(40,186,203,.25);background:rgba(40,186,203,.10);border-radius:16px}
.success{padding:12px;border:1px solid rgba(40,186,203,.25);background:rgba(40,186,203,.10);border-radius:16px}
.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
hr.sep{border:none;border-top:1px solid var(--border);margin:14px 0}


/* Mobile comfort */
.hero{padding:18px 0 10px}
.h1{font-size:32px}
@media (max-width:520px){
  .h1{font-size:26px}
  .topbar-inner{padding:10px 8px}
  .nav{gap:10px}
  .card{padding:14px;border-radius:18px}
  .table th,.table td{padding:9px;font-size:13px}
}

/* Progress bar */
.progress-wrap{margin-top:12px}
.progress-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;flex-wrap:wrap}
.progress{height:12px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid var(--border);overflow:hidden}
.progress > .bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),#1aa8b8)}
.progress-meta{font-size:13px;color:var(--muted)}

/* Sticky donate CTA on mobile */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:20;
  padding:10px 14px;background:rgba(6,18,13,.78);backdrop-filter:blur(12px);
  border-top:1px solid var(--border);display:none;
}
.sticky-cta .inner{max-width:1100px;margin:0 auto;display:flex;gap:10px;align-items:center;justify-content:space-between}
@media (max-width:900px){
  .sticky-cta{display:block}
  body{padding-bottom:72px}
}


/* ===== Landing UI v2 (banner + mobile-friendly) ===== */
.brand .logo-img{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.06);padding:6px;object-fit:contain;border:1px solid var(--border)}
.banner-wrap{padding:14px 0 8px}
.banner{
  border-radius:26px;
  overflow:hidden;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  box-shadow:0 18px 40px rgba(0,0,0,.38);
}
.banner-img{
  width:100%;
  height:210px;
  display:block;
  background:url('banner.svg') center/cover no-repeat;
}
@media (max-width:700px){
  .banner-img{height:170px}
  .h1{font-size:28px}
}
.banner-body{padding:16px}
.cta-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:20;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--border);
  padding:10px 12px;
}
.cta-inner{max-width:1100px;margin:0 auto;display:flex;gap:10px}
.cta-inner a{flex:1}
.cta-spacer{height:64px}
.progress{
  height:12px;border-radius:999px;border:1px solid var(--border);
  background:rgba(255,255,255,.05);overflow:hidden
}
.progress > div{height:100%;background:linear-gradient(90deg,var(--accent),#1aa8b8);width:0%}
.donor-cards{display:grid;gap:10px}
.donor-card{
  display:flex;justify-content:space-between;gap:10px;align-items:flex-start;
  padding:12px;border-radius:18px;border:1px solid var(--border);
  background:rgba(255,255,255,.04)
}
.donor-left{min-width:0}
.donor-name{font-weight:700}
.donor-meta{font-size:12px;color:var(--muted);margin-top:2px}
.donor-right{text-align:right}
.donor-amount{font-weight:700}
.donor-right .badge{margin-top:6px}
.small-link{font-size:13px;color:var(--muted);text-decoration:underline;text-underline-offset:3px}


/* ===== Responsive Nav ===== */
.nav-toggle{display:none}
.hamburger{
  display:none;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
}
@media (max-width:820px){
  .nav{display:none; width:100%;}
  .nav.open{display:flex;flex-direction:column;align-items:stretch;gap:10px;padding:10px 0}
  .topbar-inner{flex-wrap:wrap}
  .hamburger{display:inline-flex;align-items:center;gap:8px}
  .nav a{padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid var(--border)}
  .nav a.btn{background:linear-gradient(135deg,var(--accent),#1aa8b8);border:none}
  .nav a.muted{background:rgba(255,255,255,.02)}
}

.iconbtn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:14px;
  border:1px solid var(--border);
  background:rgba(10,20,30,.03);
  cursor:pointer;font-weight:800;color:#0b5f69;
}
.iconbtn:active{transform:translateY(1px)}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
@media (max-width:820px){.pay-grid{grid-template-columns:1fr}}
.qris-box img{width:100%;height:auto;border-radius:18px;border:1px solid var(--border);background:#fff}
