/* South Adama MK Church — Dark theme CMS */
:root{
  --bg:#0a0e1a;
  --bg-2:#0f1424;
  --panel:#141a2e;
  --panel-2:#1a2138;
  --border:#23304d;
  --text:#e6ecff;
  --muted:#8b97b8;
  --primary:#6366f1;
  --primary-2:#818cf8;
  --green:#10b981;
  --red:#ef4444;
  --amber:#f59e0b;
  --blue:#3b82f6;
  --pink:#ec4899;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}
a{color:var(--primary-2);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- LOGIN ---------- */
.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 600px at 30% -10%, #1e1b4b 0%, transparent 60%), radial-gradient(900px 500px at 80% 110%, #312e81 0%, transparent 60%), var(--bg)}
.login-wrap{display:grid;grid-template-columns:1fr 1fr;width:min(960px,95vw);min-height:520px;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:var(--panel)}
.login-cover{position:relative;background:linear-gradient(135deg,#4338ca,#0f172a);display:flex;align-items:center;justify-content:center;color:#fff;overflow:hidden}
.login-cover-blur{position:absolute;inset:0;background-image:url('assets/logo.jpg');background-size:cover;background-position:center;opacity:.25;filter:blur(14px)}
.login-cover-text{position:relative;text-align:center;padding:24px}
.login-cover-text h1{font-size:36px;margin:0 0 8px;letter-spacing:1px}
.login-cover-text p{margin:0;opacity:.85}
.login-card{padding:48px 40px;display:flex;flex-direction:column;justify-content:center;background:var(--panel)}
.login-card h2{margin:0 0 4px;font-size:24px}
.login-card .muted{margin:0 0 20px;color:var(--muted)}
.login-card label{display:block;margin:14px 0 6px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.login-card input{width:100%;padding:12px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;transition:border-color .2s}
.login-card input:focus{outline:none;border-color:var(--primary)}
.login-footer{margin:24px 0 0;text-align:center;color:var(--muted);font-size:12px}

/* ---------- APP SHELL ---------- */
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.brand{display:flex;align-items:center;gap:12px;padding:8px 8px 20px;border-bottom:1px solid var(--border);margin-bottom:14px}
.brand-logo{width:44px;height:44px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.brand-logo img{width:100%;height:100%;object-fit:contain;padding:3px}
.login-logo{width:120px;height:120px;border-radius:24px;background:#fff;padding:10px;object-fit:contain;margin:0 auto 16px;display:block;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.brand-title{font-weight:700}
.brand-sub{font-size:11px;color:var(--muted)}
.nav{display:flex;flex-direction:column;gap:4px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--text);transition:background .2s,transform .2s}
.nav-link:hover{background:var(--panel-2);text-decoration:none;transform:translateX(2px)}
.nav-link .ico{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;background:var(--panel-2);border-radius:6px;font-size:12px;color:var(--primary-2)}
.nav-link.logout{margin-top:auto;color:var(--red)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{padding:18px}
.topbar-cover{position:relative;height:120px;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,#312e81,#0f172a)}
.cover-blur{position:absolute;inset:0;background:radial-gradient(circle at 20% 50%, rgba(99,102,241,.5), transparent 50%), radial-gradient(circle at 80% 50%, rgba(236,72,153,.4), transparent 50%);filter:blur(20px)}
.cover-blur::after{content:"";position:absolute;inset:0;background-image:url('assets/logo.jpg');background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.10;filter:blur(2px)}
.cover-content{position:relative;padding:24px;height:100%;display:flex;flex-direction:column;justify-content:center}
.cover-content h1{margin:0;font-size:24px}
.cover-content p{margin:4px 0 0;color:var(--muted)}

.content{padding:0 18px 18px;display:flex;flex-direction:column;gap:18px}
.footer{padding:18px;text-align:center;color:var(--muted);border-top:1px solid var(--border);margin-top:auto;font-size:12px}

/* ---------- CARDS / STATS ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.stats-grid.small{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;animation:slideUp .5s ease both}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(99,102,241,.12),transparent 60%);pointer-events:none}
.stat-ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--panel-2);color:var(--primary-2)}
.stat-num{font-size:24px;font-weight:700}
.stat-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.c1 .stat-ico{color:#818cf8} .c2 .stat-ico{color:#3b82f6} .c3 .stat-ico{color:#ec4899}
.c4 .stat-ico{color:#10b981} .c5 .stat-ico{color:#f59e0b} .c6 .stat-ico{color:#ef4444}
.c7 .stat-ico{color:#06b6d4} .c8 .stat-ico{color:#a855f7}

.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.quick{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:12px;color:var(--text);transition:.25s}
.quick:hover{transform:translateY(-2px);border-color:var(--primary);text-decoration:none}
.quick span{width:36px;height:36px;border-radius:10px;background:var(--panel-2);color:var(--primary-2);display:flex;align-items:center;justify-content:center}

.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card h3{margin:0 0 14px;font-size:16px}
.card h4{margin:18px 0 8px}

/* ---------- FORMS ---------- */
.form .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .grid2 .full{grid-column:1/-1}
.form label{display:block;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.form input,.form select,.form textarea{width:100%;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--primary)}
.form-actions{display:flex;gap:10px;margin-top:16px}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font-size:13px;transition:.2s;text-decoration:none}
.btn:hover{background:var(--border);text-decoration:none;transform:translateY(-1px)}
.btn.sm{padding:6px 10px;font-size:12px}
.btn.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));border-color:transparent}
.btn.btn-primary:hover{filter:brightness(1.1)}
.btn.btn-block{width:100%;justify-content:center;margin-top:14px;padding:12px}
.btn.danger{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444);border-color:transparent}

/* ---------- TABLES ---------- */
.page-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.search{display:flex;gap:8px;flex:1;max-width:480px}
.search input{flex:1;padding:10px 12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;color:var(--text)}

.table-card{padding:0;overflow:hidden}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}
.table th{background:var(--panel-2);font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600}
.table tr:hover{background:var(--panel-2)}
.table td.empty{text-align:center;color:var(--muted);padding:32px}
.actions{display:flex;gap:6px;flex-wrap:wrap}

.avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:var(--panel-2)}
.avatar.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:700}

.badge{display:inline-block;padding:4px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;font-size:11px;font-weight:600;color:var(--primary-2);font-family:monospace}
.pill{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--panel-2);border:1px solid var(--border);font-size:11px;color:var(--muted)}
.pill.green{background:rgba(16,185,129,.15);color:#34d399;border-color:rgba(16,185,129,.3)}
.pill.red{background:rgba(239,68,68,.15);color:#fca5a5;border-color:rgba(239,68,68,.3);animation:pulse 1.5s infinite}
.pill.gray{color:var(--muted)}

.alert{padding:10px 14px;border-radius:10px;margin-bottom:12px;font-size:13px}
.alert.error{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.alert.warn{background:rgba(245,158,11,.15);color:#fcd34d;border:1px solid rgba(245,158,11,.3)}
.alert.ok{background:rgba(16,185,129,.15);color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}

.muted{color:var(--muted)}
.small{font-size:12px}

.ministry-item{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;margin-bottom:10px}
.ministry-item summary{cursor:pointer;list-style:none}
.ministry-item summary::-webkit-details-marker{display:none}
.ministry-item summary::before{content:"▶";display:inline-block;margin-right:8px;color:var(--primary-2);transition:transform .2s}
.ministry-item[open] summary::before{transform:rotate(90deg)}

.profile-card .profile-head{display:flex;gap:20px;align-items:center;margin-bottom:20px}
.profile-photo{width:120px;height:120px;border-radius:16px;object-fit:cover;background:var(--panel-2)}
.profile-photo.placeholder{display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--muted);font-weight:700}
.profile-card .grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px;background:var(--panel-2);border-radius:10px}
.profile-card .grid2 div{padding:6px 0;border-bottom:1px solid var(--border)}

.family-list{list-style:none;padding:0;margin:8px 0}
.family-list li{padding:10px 14px;background:var(--panel-2);border-radius:8px;margin-bottom:6px}

.child-row{display:grid;grid-template-columns:1fr 120px 140px 140px 140px auto;gap:8px;align-items:end;padding:12px;background:var(--panel-2);border-radius:10px;margin-bottom:8px}
.child-row label{font-size:10px}
.child-row input,.child-row select{padding:8px}

@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* ---------- RESPONSIVE ---------- */
@media (max-width:880px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto;width:100%;display:flex;flex-direction:row;flex-wrap:wrap;gap:6px;padding:12px}
  .brand{width:100%;border:none;padding:6px 8px 12px;margin:0 0 8px}
  .nav{flex-direction:row;flex-wrap:wrap;gap:4px;width:100%}
  .nav-link{padding:8px 10px;font-size:12px}
  .nav-link.logout{margin:0}
  .login-wrap{grid-template-columns:1fr}
  .login-cover{display:none}
  .form .grid2,.profile-card .grid2{grid-template-columns:1fr}
  .child-row{grid-template-columns:1fr 1fr;gap:6px}
  .table{font-size:12px}
  .table th,.table td{padding:8px}
  .actions{flex-direction:column}
}

/* ---------- TITHE CHECKLIST ---------- */
.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin:18px 0}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.panel-head h3{margin:0 0 4px;font-size:18px}
.panel-head .muted{margin:0;font-size:13px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.3px}
.pill-paid{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.3)}
.pill-unpaid{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.checklist-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--panel-2);border:1px solid var(--border);border-left:3px solid #f87171;border-radius:10px;transition:transform .15s, border-color .15s}
.checklist-item:hover{transform:translateX(2px);border-left-color:#fbbf24}
.ci-info{min-width:0;flex:1}
.ci-name{font-weight:600;margin-bottom:2px}
.ci-meta{font-size:12px;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.ci-meta .tag{background:rgba(99,102,241,.18);color:#a5b4fc;padding:1px 8px;border-radius:999px;font-size:10px;font-weight:700}
.ci-action{margin:0}
.btn-success{background:#16a34a;color:#fff;border:none;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .15s}
.btn-success:hover{background:#15803d}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:500}
.btn-ghost:hover{background:var(--panel-2)}
.empty{padding:24px;text-align:center;color:var(--muted);font-style:italic;background:var(--panel-2);border-radius:10px}

@media (max-width:640px){
  .checklist-item{flex-direction:column;align-items:stretch}
  .ci-action{width:100%}
  .btn-success{width:100%}
}

.tithe-search{display:flex;gap:8px;margin:0 0 14px;flex-wrap:wrap}
.tithe-search input[type=text]{flex:1;min-width:220px;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:14px}
.tithe-search input[type=text]:focus{outline:none;border-color:var(--primary)}

/* ---------- TITHE TABLE ---------- */
.year-select{display:flex;align-items:center;gap:8px}
.year-select label{font-size:12px;color:var(--muted)}
.year-select select{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-weight:600;cursor:pointer}
.tithe-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px}
.tithe-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;min-width:880px}
.tithe-table th,.tithe-table td{padding:10px 8px;text-align:center;border-bottom:1px solid var(--border)}
.tithe-table thead th{background:var(--panel-2);font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0}
.tithe-table tbody tr:hover{background:rgba(99,102,241,.05)}
.tithe-table tbody tr:last-child td{border-bottom:none}
.member-col{text-align:left !important;min-width:200px;padding-left:14px !important}
.member-col .ci-name{font-weight:600;color:var(--text)}
.member-col .ci-meta{font-size:11px;color:var(--muted);margin-top:2px}
.th-current{color:#a5b4fc !important;background:rgba(99,102,241,.12) !important}
.td-current{background:rgba(99,102,241,.06)}
.month-cell{width:36px;height:36px;border-radius:8px;border:none;font-weight:700;font-size:14px;cursor:pointer;transition:transform .15s,filter .15s}
.month-cell:hover{transform:scale(1.08);filter:brightness(1.15)}
.month-cell.paid{background:rgba(34,197,94,.18);color:#4ade80;border:1px solid rgba(34,197,94,.4)}
.month-cell.unpaid{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.total-cell{font-weight:700;color:var(--text)}

.group-meta{display:flex;flex-wrap:wrap;gap:14px;padding:8px 0 12px;font-size:13px;color:var(--text)}
.group-meta strong{color:var(--muted);font-weight:600;margin-right:4px}

/* ---- Pagination ---- */
.pager{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:16px 0}
.pager .pg{padding:6px 12px;border:1px solid var(--border);border-radius:6px;color:var(--text);text-decoration:none;background:var(--card);font-size:13px;transition:all .15s}
.pager .pg:hover{border-color:var(--accent);color:var(--accent)}
.pager .pg.current{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.pager .pg.dots{border:0;background:transparent;cursor:default;color:var(--muted)}

/* ---- Member Picker (searchable, scales to 2000+) ---- */
.member-picker{position:relative;background:var(--input-bg,#1b1f2e);border:1px solid var(--border);border-radius:8px;padding:6px}
.mp-chips{display:flex;flex-wrap:wrap;gap:6px;min-height:0}
.mp-chips:not(:empty){padding:4px 4px 6px}
.mp-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:rgba(99,102,241,.18);color:var(--text);border-radius:14px;font-size:12px;border:1px solid rgba(99,102,241,.4)}
.mp-chip button{background:transparent;border:0;color:var(--text);cursor:pointer;font-size:14px;line-height:1;padding:0 2px}
.mp-chip button:hover{color:#ef4444}
.mp-search{width:100%;background:transparent;border:0;color:var(--text);padding:8px 6px;outline:none;font-size:14px}
.mp-list{position:absolute;left:0;right:0;top:100%;margin-top:4px;max-height:280px;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;z-index:50;box-shadow:0 8px 24px rgba(0,0,0,.45)}
.mp-row{padding:8px 12px;cursor:pointer;font-size:13px;color:var(--text);border-bottom:1px solid rgba(255,255,255,.04)}
.mp-row:hover{background:rgba(99,102,241,.15)}
.mp-row.is-selected{background:rgba(34,197,94,.18);font-weight:600}
.mp-row.is-selected::before{content:"✓ ";color:#22c55e}
.mp-empty{padding:10px 12px;color:var(--muted);font-size:13px;text-align:center}

.ministry-body{padding:8px 0}
