/* ── Halal Fund — styles ──────────────────────────────────────── */
:root{
  --green:#0c7c59; --green-d:#0a5c43; --green-dd:#0c3b2e;
  --gold:#c9a227; --gold-l:#f3e6b3;
  --ink:#16231e; --muted:#6b7d75; --line:#e4ece8;
  --bg:#f4f8f6; --card:#ffffff;
  --paid:#0c7c59; --late:#c9821f; --due:#9aa6a0; --overdue:#d6453d; --pending:#2f74c0;
  --radius:16px; --shadow:0 6px 22px rgba(12,60,46,.08);
  --maxw:1080px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:'Hind Siliguri',system-ui,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.55; font-size:16px;
}
a{color:var(--green); text-decoration:none}
h1,h2,h3,h4{margin:0 0 .5em; line-height:1.25; color:var(--ink)}
h1{font-size:1.5rem} h2{font-size:1.2rem}

/* ── top bar ── */
.topbar{background:linear-gradient(120deg,var(--green-dd),var(--green));color:#fff;
  position:sticky;top:0;z-index:50;box-shadow:0 2px 14px rgba(0,0,0,.15)}
.topbar-in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;
  gap:14px;padding:12px 16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:1.15rem;margin-right:auto}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;
  background:rgba(255,255,255,.16);font-size:18px}
.hamburger{display:none;background:rgba(255,255,255,.14);border:0;color:#fff;font-size:20px;
  width:42px;height:42px;border-radius:10px;cursor:pointer}
.mainnav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.mainnav a{color:#dff3ec;padding:8px 12px;border-radius:9px;font-weight:500;font-size:.95rem;position:relative}
.mainnav a:hover{background:rgba(255,255,255,.12);color:#fff}
.mainnav a.active{background:#fff;color:var(--green-d);font-weight:600}
.nav-badge{background:var(--gold);color:#3a2d00;border-radius:20px;padding:0 7px;font-size:.72rem;
  font-weight:700;margin-left:3px;vertical-align:middle}
.nav-user{display:flex;align-items:center;gap:10px;margin-left:8px;padding-left:12px;border-left:1px solid rgba(255,255,255,.22)}
.nav-name{font-size:.85rem;opacity:.92}
.nav-logout{background:rgba(255,255,255,.16);color:#fff !important;padding:7px 12px !important;border-radius:8px}
.nav-logout:hover{background:var(--overdue) !important}

/* ── layout ── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:20px 16px 40px;width:100%}
.sitefoot{text-align:center;color:var(--muted);font-size:.85rem;padding:26px 16px;border-top:1px solid var(--line)}
.foot-sub{font-size:.78rem;opacity:.8;margin-top:3px}

/* ── flash ── */
.flash{padding:12px 16px;border-radius:12px;margin-bottom:16px;font-weight:500;border:1px solid}
.flash-ok{background:#e7f6ef;border-color:#bfe6d4;color:#0a5c43}
.flash-err{background:#fdecea;border-color:#f5c6c2;color:#b3322a}

/* ── cards ── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
.card h2,.card h3{display:flex;align-items:center;gap:8px}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.muted{color:var(--muted)}
.hint{font-size:.85rem;color:var(--muted)}

/* ── stat grid ── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.stat .v{font-size:1.65rem;font-weight:700;color:var(--green-d);line-height:1.1}
.stat .k{color:var(--muted);font-size:.86rem;margin-top:4px}
.stat.accent{background:linear-gradient(135deg,var(--green),var(--green-d));border:0;color:#fff}
.stat.accent .v,.stat.accent .k{color:#fff}
.stat.gold{background:linear-gradient(135deg,#d9b63a,var(--gold));border:0}
.stat.gold .v,.stat.gold .k{color:#3a2d00}

/* ── countdown ── */
.countdown{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.cd-box{background:rgba(255,255,255,.16);border-radius:12px;padding:10px 14px;text-align:center;min-width:64px}
.cd-box .n{font-size:1.5rem;font-weight:700;line-height:1}
.cd-box .l{font-size:.72rem;opacity:.9}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;border:0;
  padding:11px 18px;border-radius:11px;font-weight:600;font-size:.95rem;cursor:pointer;
  font-family:inherit;transition:.15s;text-align:center;justify-content:center}
.btn:hover{background:var(--green-d)}
.btn.gold{background:var(--gold);color:#3a2d00}.btn.gold:hover{background:#b08e1d}
.btn.ghost{background:#eef4f1;color:var(--green-d)}.btn.ghost:hover{background:#dfeae5}
.btn.danger{background:var(--overdue)}.btn.danger:hover{background:#b3322a}
.btn.sm{padding:7px 12px;font-size:.85rem;border-radius:9px}
.btn.block{display:flex;width:100%}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* ── forms ── */
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:11px;
  font-family:inherit;font-size:1rem;background:#fbfdfc;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(12,124,89,.13)}
textarea{min-height:120px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:0 16px}

/* ── tables ── */
.tbl-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--line);background:#fff;-webkit-overflow-scrolling:touch}
table{border-collapse:collapse;width:100%;font-size:.92rem;min-width:520px}
th,td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
thead th{background:#f0f6f3;color:var(--green-d);font-weight:600;position:sticky;top:0}
tbody tr:hover{background:#f7fbf9}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tfoot td{font-weight:700;background:#0c3b2e;color:#fff;border:0}
tfoot td.num{color:var(--gold-l)}

/* ── status badges ── */
.badge{display:inline-block;padding:3px 10px;border-radius:30px;font-size:.78rem;font-weight:600;white-space:nowrap}
.st-paid{background:#e3f5ec;color:var(--paid)}
.st-late{background:#fcf0db;color:var(--late)}
.st-due{background:#eef0ef;color:#5f6e67}
.st-overdue{background:#fde7e5;color:var(--overdue)}
.st-pending{background:#e6f0fb;color:var(--pending)}
.st-future{background:#f3f1fa;color:#7a6fb0}
.pill{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.74rem;font-weight:600;background:#eef4f1;color:var(--green-d)}
.pill.admin{background:var(--gold-l);color:#6b5400}
.pill.suspended{background:#fde7e5;color:var(--overdue)}
.pill.left{background:#eceff1;color:#6b7d75}

/* grid cells (monthly) */
.cell-paid{color:var(--green-d);font-weight:600}
.cell-empty{color:#cfd8d4}
.cell-late{color:var(--late);font-weight:600}
td.clickable{cursor:pointer} td.clickable:hover{background:#eef6f1;outline:2px solid var(--green)}

/* ── login ── */
.auth{min-height:100vh;display:grid;place-items:center;padding:20px;
  background:linear-gradient(135deg,var(--green-dd),var(--green));}
.auth-card{background:#fff;border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.3);
  width:100%;max-width:400px;padding:34px 28px}
.auth-logo{text-align:center;margin-bottom:18px}
.auth-logo .m{display:inline-grid;place-items:center;width:62px;height:62px;border-radius:18px;
  background:linear-gradient(135deg,var(--green),var(--green-d));color:#fff;font-size:30px;margin-bottom:10px}
.auth-logo h1{font-size:1.4rem;margin:0}
.auth-logo p{color:var(--muted);margin:2px 0 0;font-size:.9rem}

/* ── rules ── */
.rules h3{color:var(--green-d);border-left:4px solid var(--gold);padding-left:10px;margin-top:22px}
.rules ul{margin:8px 0 8px;padding-left:22px}
.rules li{margin-bottom:6px}
.rules p{margin:8px 0}

/* ── misc ── */
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.tag-list{display:flex;gap:8px;flex-wrap:wrap}
.kv{display:grid;grid-template-columns:130px 1fr;gap:6px 14px;font-size:.95rem}
.kv dt{color:var(--muted)} .kv dd{margin:0;font-weight:500}
.info-line{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line)}
.info-line:last-child{border:0}
.copy-box{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#f0f6f3;
  border:1px dashed #bfe0d2;border-radius:12px;padding:12px 14px;margin:8px 0;font-weight:600}
.copy-box code{font-size:1.05rem;color:var(--green-d)}

/* ── modal ── */
.modal{position:fixed;inset:0;background:rgba(12,40,30,.55);display:none;place-items:center;z-index:100;padding:16px}
.modal.open{display:grid}
.modal-card{background:#fff;border-radius:18px;max-width:440px;width:100%;padding:24px;max-height:90vh;overflow:auto}

/* ── responsive ── */
@media(max-width:860px){
  .hamburger{display:block}
  .mainnav{display:none;width:100%;flex-direction:column;align-items:stretch;gap:2px;padding-top:10px}
  .mainnav.open{display:flex}
  .mainnav a{padding:12px 14px}
  .nav-user{margin:8px 0 0;padding:12px 0 0;border-left:0;border-top:1px solid rgba(255,255,255,.22);
    justify-content:space-between;width:100%}
  .grid2,.grid3{grid-template-columns:1fr}
  .stat .v{font-size:1.4rem}
  h1{font-size:1.3rem}
}
@media(max-width:480px){
  .wrap{padding:14px 12px 36px}
  .card{padding:16px}
  .kv{grid-template-columns:1fr}
  .kv dt{margin-top:6px}
}
@media print{
  .topbar,.sitefoot,.btn,.hamburger,.no-print{display:none !important}
  body{background:#fff} .card{box-shadow:none;border:1px solid #ccc}
}
