:root{
  /* Brand */
  --ink:#0E1F3D;
  --primary:#1B3A6B;
  --primary-600:#234a86;
  --primary-700:#16315c;
  --royal:#2E5AAC;
  --gold:#BF9B30;
  --gold-soft:#F3E9CC;
  --gold-deep:#9A7A1E;

  /* Neutrals */
  --paper:#F4F6FA;
  --surface:#FFFFFF;
  --surface-2:#FAFBFD;
  --line:#E4E9F2;
  --line-strong:#D2DAE8;
  --muted:#5B6B85;
  --muted-2:#8A98B0;

  /* Semantic */
  --green:#1F8A5B; --green-soft:#E3F4EC;
  --teal:#0E8C9B; --teal-soft:#DFF3F5;
  --amber:#C77D11; --amber-soft:#FCEFD9;
  --red:#C0392B; --red-soft:#FBE7E4;
  --slate:#64748B; --slate-soft:#EDF0F5;

  /* Lifecycle */
  --lc-visitor:#94A3B8;
  --lc-soul:#BF9B30;
  --lc-newmember:#0E8C9B;
  --lc-member:#1B3A6B;

  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(14,31,61,.06), 0 1px 3px rgba(14,31,61,.04);
  --shadow:0 4px 16px rgba(14,31,61,.07), 0 1px 4px rgba(14,31,61,.05);
  --shadow-lg:0 18px 48px rgba(14,31,61,.14);
  --sans:'Poppins', system-ui, sans-serif;
  --serif:'Poppins', system-ui, sans-serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:14px;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#C9D3E2;border-radius:20px;border:2px solid var(--paper)}
::-webkit-scrollbar-thumb:hover{background:#B3C0D4}

/* ===== App shell ===== */
.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh;background:var(--paper)}

/* ===== Sidebar ===== */
.sidebar{background:linear-gradient(180deg,#16315c 0%,#0E1F3D 100%);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;width:264px;flex:none}
.brand{padding:22px 22px 18px;display:flex;gap:13px;align-items:center;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-mark{
  width:42px;height:42px;border-radius:11px;flex:none;
  background:linear-gradient(145deg,var(--gold) 0%, var(--gold-deep) 100%);
  display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:21px;color:#1B3A6B;
  box-shadow:0 4px 12px rgba(191,155,48,.4);
}
.brand-mark:has(img){background:#fff;padding:5px}
.brand-mark img{width:100%;height:100%;object-fit:contain;display:block;border-radius:7px}
.brand-text .bt-name{font-family:var(--serif);font-weight:600;font-size:15.5px;letter-spacing:.2px;line-height:1.15}
.brand-text .bt-sub{font-size:10.5px;color:#A9B8D6;letter-spacing:.4px;text-transform:uppercase;margin-top:3px}

.nav{padding:14px 12px;flex:1;overflow-y:auto}
.nav-label{font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:#6E80A8;padding:14px 12px 7px;font-weight:600}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:10px;
  color:#C2CFE6;font-weight:500;font-size:13.5px;margin-bottom:2px;transition:.15s;position:relative;
}
.nav-item svg{width:18px;height:18px;flex:none;opacity:.85}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:rgba(46,90,172,.32);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;background:var(--gold);border-radius:0 3px 3px 0}
.nav-item .badge-count{margin-left:auto;background:var(--gold);color:#1B3A6B;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:20px;font-family:var(--mono)}
.nav-item.alert .badge-count{background:#E8624A;color:#fff}

.sidebar-foot{padding:16px 18px;border-top:1px solid rgba(255,255,255,.08);font-family:var(--serif);font-size:12px;font-style:italic;color:#90A2C6;text-align:center;line-height:1.5}

/* ===== Topbar ===== */
.main{display:flex;flex-direction:column;min-width:0;overflow-x:hidden;background:var(--paper)}
/* sidebar-overlay: hidden by default, shown as fixed overlay on mobile */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:199}
.topbar{
  background:var(--surface);border-bottom:1px solid var(--line);
  padding:0 30px;height:72px;display:flex;align-items:center;gap:20px;
  position:sticky;top:0;z-index:30;
}
.tb-context{min-width:0}
.tb-eyebrow{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.tb-title{font-family:var(--serif);font-size:23px;font-weight:600;line-height:1.1;margin-top:1px}
.tb-spacer{flex:1}
.tb-search{
  display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:10px;padding:9px 14px;width:280px;color:var(--muted-2);transition:.15s;
}
.tb-search:focus-within{border-color:var(--royal);box-shadow:0 0 0 3px rgba(46,90,172,.12);background:#fff}
.tb-search svg{width:16px;height:16px;flex:none}
.tb-search input{border:none;background:none;outline:none;font-family:inherit;font-size:13.5px;color:var(--ink);width:100%}
.tb-action{
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:var(--muted);
  border:1px solid var(--line);background:var(--surface-2);position:relative;transition:.15s;
}
.tb-action:hover{border-color:var(--line-strong);color:var(--primary);background:#fff}
.tb-action svg{width:18px;height:18px}
.tb-action .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:#E8624A;border:1.5px solid #fff}
.tb-user{display:flex;align-items:center;gap:11px;padding:6px 7px 6px 14px;border-radius:11px;border:1px solid var(--line);background:var(--surface-2)}
.tb-user .u-name{font-weight:600;font-size:13px;line-height:1.2}
.tb-user .u-role{font-size:11px;color:var(--gold-deep);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.u-avatar{width:36px;height:36px;border-radius:9px;background:linear-gradient(145deg,var(--royal),var(--primary));color:#fff;display:grid;place-items:center;font-weight:600;font-size:13.5px;flex:none}

/* ===== Content ===== */
.content{padding:28px 30px 48px;max-width:1400px;width:100%;margin:0 auto}
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.section-head h2{font-family:var(--serif);font-size:21px;font-weight:600}
.section-head .sub{color:var(--muted);font-size:13px;margin-top:3px}
.head-actions{display:flex;gap:10px;align-items:center}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 17px;border-radius:10px;font-weight:600;font-size:13px;transition:.15s;border:1px solid transparent;white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--primary-600);box-shadow:var(--shadow)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#1B3A6B;font-weight:700;box-shadow:0 4px 12px rgba(191,155,48,.3)}
.btn-gold:hover{filter:brightness(1.05)}
.btn-ghost{background:var(--surface);color:var(--primary);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--royal);background:var(--surface-2)}
.btn-sm{padding:7px 13px;font-size:12px}

/* ===== Cards ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-pad{padding:20px 22px}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:17px 22px;border-bottom:1px solid var(--line)}
.card-head h3{font-family:var(--serif);font-size:16px;font-weight:600}
.card-head .ch-sub{font-size:12px;color:var(--muted);margin-top:1px}
.card-head a{font-size:12.5px;color:var(--royal);font-weight:600;display:inline-flex;align-items:center;gap:4px}
.card-head a svg{width:14px;height:14px}

/* ===== KPI tags ===== */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 19px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:.18s}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--line-strong)}
.kpi::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,var(--primary))}
.kpi-top{display:flex;align-items:center;justify-content:space-between}
.kpi-ico{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--accent-soft,var(--slate-soft));color:var(--accent,var(--primary))}
.kpi-ico svg{width:19px;height:19px}
.kpi-trend{font-size:11.5px;font-weight:700;font-family:var(--mono);display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px}
.kpi-trend.up{color:var(--green);background:var(--green-soft)}
.kpi-trend.down{color:var(--red);background:var(--red-soft)}
.kpi-trend.flat{color:var(--slate);background:var(--slate-soft)}
.kpi-val{font-family:var(--sans);font-size:30px;font-weight:700;letter-spacing:-.5px;margin-top:14px;line-height:1}
.kpi-label{font-size:12.5px;color:var(--muted);margin-top:5px;font-weight:500}

/* ===== Badges ===== */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.badge .pip{width:6px;height:6px;border-radius:50%;background:currentColor}
.b-visitor{color:var(--slate);background:var(--slate-soft)}
.b-soul{color:var(--gold-deep);background:var(--gold-soft)}
.b-newmember{color:var(--teal);background:var(--teal-soft)}
.b-member{color:var(--primary);background:#E5ECF8}
.b-followup{color:var(--amber);background:var(--amber-soft)}
.b-contacted{color:var(--royal);background:#E5ECF8}
.b-visited{color:var(--teal);background:var(--teal-soft)}
.b-completed{color:var(--green);background:var(--green-soft)}
.b-pending{color:var(--amber);background:var(--amber-soft)}
.b-approved{color:var(--green);background:var(--green-soft)}
.b-rejected{color:var(--red);background:var(--red-soft)}
.b-baptism{color:#7A3FB0;background:#F0E7FA}

/* ===== Grids ===== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.stack{display:flex;flex-direction:column;gap:18px}
.mt{margin-top:18px}

/* ===== Lifecycle funnel ===== */
.funnel{display:flex;flex-direction:column;gap:11px}
.funnel-row{display:grid;grid-template-columns:140px 1fr 56px;align-items:center;gap:14px}
.funnel-label{display:flex;align-items:center;gap:9px;font-weight:600;font-size:13px}
.funnel-dot{width:11px;height:11px;border-radius:3px;flex:none}
.funnel-track{height:30px;background:var(--surface-2);border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.funnel-fill{height:100%;border-radius:7px;display:flex;align-items:center;padding-left:12px;color:#fff;font-weight:600;font-size:12px;font-family:var(--mono);transition:width 1s cubic-bezier(.4,0,.2,1)}
.funnel-pct{font-family:var(--mono);font-weight:600;font-size:13px;text-align:right;color:var(--muted)}

/* ===== Charts (SVG) ===== */
.chart-wrap{padding:8px 4px 0}
.chart-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.leg{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);font-weight:500}
.leg .sw{width:11px;height:11px;border-radius:3px}

.barlist{display:flex;flex-direction:column;gap:13px}
.barlist-row{display:grid;grid-template-columns:165px 1fr 40px;align-items:center;gap:13px}
.barlist-name{font-size:12.5px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.barlist-track{height:9px;background:var(--surface-2);border-radius:20px;overflow:hidden}
.barlist-fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--royal),var(--primary))}
.barlist-val{font-family:var(--mono);font-size:12.5px;font-weight:600;text-align:right;color:var(--muted)}

/* ===== Tables ===== */
.table-wrap{overflow-x:auto}
#memberListEl{max-height:calc(100vh - 320px);overflow-y:auto;border:1px solid var(--line);border-radius:var(--radius,8px)}
#attendanceEl .table-wrap{max-height:420px;overflow-y:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;font-size:10.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted-2);font-weight:600;padding:11px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface-2)}
.t-name{font-weight:600}
.t-sub{font-size:11.5px;color:var(--muted-2)}
.t-mono{font-family:var(--mono);font-size:12.5px}
.icon-btn{width:30px;height:30px;border-radius:8px;display:inline-grid;place-items:center;color:var(--muted);border:1px solid var(--line);background:var(--surface)}
.icon-btn:hover{color:var(--primary);border-color:var(--line-strong);background:var(--surface-2)}
.icon-btn svg{width:15px;height:15px}
.icon-btn.call:hover{color:var(--green);border-color:var(--green)}
.icon-btn.danger:hover{color:var(--red);border-color:var(--red)}

/* ===== Follow-up queue ===== */
.queue-item{display:flex;align-items:center;gap:13px;padding:13px 22px;border-bottom:1px solid var(--line)}
.queue-item:last-child{border-bottom:none}
.queue-item:hover{background:var(--surface-2)}
.q-av{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-weight:600;font-size:13px;color:#fff;flex:none}
.q-info{flex:1;min-width:0}
.q-name{font-weight:600;font-size:13.5px}
.q-meta{font-size:11.5px;color:var(--muted);display:flex;gap:8px;align-items:center;margin-top:2px}
.q-actions{display:flex;gap:6px}

/* ===== Stepper form ===== */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 22px;box-shadow:var(--shadow-sm)}
.step{display:flex;align-items:center;gap:11px;flex:1;position:relative}
.step:not(:last-child)::after{content:"";flex:1;height:2px;background:var(--line);margin:0 4px}
.step.done:not(:last-child)::after{background:var(--gold)}
.step-num{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;background:var(--surface-2);color:var(--muted-2);border:2px solid var(--line);flex:none;font-family:var(--mono)}
.step.active .step-num{background:var(--primary);color:#fff;border-color:var(--primary)}
.step.done .step-num{background:var(--gold);color:#1B3A6B;border-color:var(--gold)}
.step-txt .st-k{font-size:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted-2);font-weight:600}
.step-txt .st-t{font-size:13px;font-weight:600;line-height:1.1}
.step.active .st-t{color:var(--primary)}

.form-panel{display:none}
.form-panel.active{display:block;animation:fade .3s ease}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12px;font-weight:600;color:var(--ink)}
.field label .req{color:var(--red)}
.field .hint{font-size:11px;color:var(--muted-2)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:13.5px;padding:11px 13px;border:1px solid var(--line-strong);
  border-radius:10px;background:var(--surface);color:var(--ink);outline:none;transition:.15s;width:100%;
}
.field textarea{resize:vertical;min-height:84px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--royal);box-shadow:0 0 0 3px rgba(46,90,172,.12)}
.fieldset-title{font-family:var(--serif);font-size:15px;font-weight:600;margin:4px 0 14px;display:flex;align-items:center;gap:9px}
.fieldset-title .fnum{width:24px;height:24px;border-radius:7px;background:var(--gold-soft);color:var(--gold-deep);display:grid;place-items:center;font-size:12px;font-weight:700}

/* segmented control */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.seg button{padding:7px 14px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--muted)}
.seg button.on{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}

.counter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.counter{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center}
.counter .c-lab{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.counter .c-ctrl{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:10px}
.counter .c-val{font-family:var(--mono);font-size:22px;font-weight:600;min-width:34px}
.counter .c-btn{width:30px;height:30px;border-radius:8px;background:var(--surface);border:1px solid var(--line-strong);font-size:18px;color:var(--primary);display:grid;place-items:center;line-height:1}
.counter .c-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

.form-foot{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}

/* ===== Tabs (admin) ===== */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px}
.tab{padding:11px 18px;font-weight:600;font-size:13.5px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.15s}
.tab:hover{color:var(--primary)}
.tab.active{color:var(--primary);border-bottom-color:var(--gold)}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fade .3s ease}

/* role pill */
.role-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px}
.r-super{background:#F0E7FA;color:#7A3FB0}
.r-admin{background:#E5ECF8;color:var(--primary)}
.r-pastor{background:var(--gold-soft);color:var(--gold-deep)}
.r-fellow{background:var(--teal-soft);color:var(--teal)}
.r-corr{background:var(--slate-soft);color:var(--slate)}
.r-clerk{background:var(--green-soft);color:var(--green)}

/* logs */
.log-line{display:grid;grid-template-columns:48px 1fr auto;gap:14px;padding:13px 22px;border-bottom:1px solid var(--line);align-items:center}
.log-line:last-child{border-bottom:none}
.log-line:hover{background:var(--surface-2)}
.log-ico{width:34px;height:34px;border-radius:9px;display:grid;place-items:center}
.log-ico svg{width:16px;height:16px}
.li-approve{background:var(--green-soft);color:var(--green)}
.li-create{background:#E5ECF8;color:var(--royal)}
.li-delete{background:var(--red-soft);color:var(--red)}
.li-login{background:var(--slate-soft);color:var(--slate)}
.li-edit{background:var(--amber-soft);color:var(--amber)}
.log-txt b{font-weight:600}
.log-meta{font-size:11.5px;color:var(--muted-2);margin-top:2px}
.log-time{font-family:var(--mono);font-size:11.5px;color:var(--muted-2);text-align:right;white-space:nowrap}

.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.chip{padding:7px 14px;border-radius:9px;border:1px solid var(--line-strong);background:var(--surface);font-size:12.5px;font-weight:600;color:var(--muted)}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}

.mini-stat{display:flex;flex-direction:column;gap:3px}
.mini-stat .ms-v{font-family:var(--sans);font-size:22px;font-weight:700;letter-spacing:-.3px}
.mini-stat .ms-l{font-size:11.5px;color:var(--muted)}

.verse-strip{
  background:linear-gradient(100deg,#16315c,#1B3A6B);color:#fff;border-radius:var(--radius);
  padding:15px 24px;display:flex;align-items:center;gap:16px;margin-bottom:20px;box-shadow:var(--shadow);overflow:hidden;position:relative;
}
.verse-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% -20%, rgba(191,155,48,.25), transparent 50%)}
.verse-strip .vs-ico{width:36px;height:36px;border-radius:9px;background:rgba(191,155,48,.2);display:grid;place-items:center;color:var(--gold);flex:none;position:relative}
.verse-strip .vs-ico svg{width:18px;height:18px}
.verse-strip .vs-text{font-family:var(--serif);font-style:italic;font-size:15px;position:relative;transition:opacity .6s ease}
.verse-strip .vs-ref{margin-left:auto;font-size:12px;color:#A9B8D6;font-weight:600;position:relative;white-space:nowrap;transition:opacity .6s ease}

.empty-soft{padding:8px 0;color:var(--muted);font-size:13px}
.donut-center{font-family:var(--mono)}

/* ===== Modal overlay ===== */
.modal-overlay{display:none;position:fixed;inset:0;z-index:500;align-items:center;justify-content:center;background:rgba(14,31,61,.55)}
.modal-overlay:not(.hidden){display:flex}
.modal-box{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:88vh;overflow-y:auto;margin:16px}
#callModalContent{padding:20px 22px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-head h3{font-family:var(--serif);font-size:17px;font-weight:600}

/* ===== Toast ===== */
.toast{position:fixed;bottom:28px;right:28px;z-index:1000;background:var(--ink);color:#fff;padding:12px 20px;border-radius:10px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow-lg);animation:fade .25s ease;max-width:320px;line-height:1.4}
.toast-error{background:var(--red)}
.toast-success{background:var(--green)}

/* ── Responsive ── */
@media(max-width:1200px){
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .content{padding:22px 22px 40px}
}
@media(max-width:1024px){
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .counter-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;top:0;left:0;height:100vh;z-index:200;
    transform:translateX(-100%);transition:transform .25s ease;
    width:264px;flex:none;
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.visible{display:block}
  .topbar{padding:0 16px;height:60px}
  .tb-search{display:none}
  .tb-menu{display:grid;place-items:center;width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:var(--surface-2);color:var(--muted);flex:none;cursor:pointer}
  .tb-menu svg{width:20px;height:20px}
  .content{padding:16px 14px 40px}
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:12px}
  .section-head{flex-direction:column;align-items:flex-start;gap:12px}
  .head-actions{width:100%}
  .tb-title{font-size:18px}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:540px){
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi{padding:14px}
  .kpi-val{font-size:24px}
  .counter-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .funnel-row{grid-template-columns:100px 1fr 46px;gap:10px}
  .barlist-row{grid-template-columns:120px 1fr 36px;gap:10px}
  .content{padding:12px 10px 32px}
  table{font-size:12px}
  th,td{padding:9px 10px}
  .btn{padding:9px 13px;font-size:12.5px}
  .card-head{padding:13px 14px}
  .card-pad{padding:14px}
  .tb-user .u-name{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .u-role{display:none}
}
@media(max-width:380px){
  .kpi-row{grid-template-columns:1fr}
  .tb-user .u-name{display:none}
}
@media print{
  .sidebar,.topbar,.head-actions,.no-print{display:none!important}
  .app{display:block}
  body{background:#fff}
  .content{padding:0;max-width:100%;margin:0}
  .card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}
}
/* ===== Login screen ===== */
.login-wrap{
  min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.login-video{
  position:absolute;inset:0;width:100%;height:100%;overflow:hidden;z-index:0;
  pointer-events:none;
}
.login-video iframe{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:177.78vh;min-width:100%;height:56.25vw;min-height:100%;border:none;
}
.login-overlay{position:absolute;inset:0;background:rgba(14,31,61,.72);z-index:1}
.login-card{
  position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.2fr;
  max-width:900px;width:92%;border-radius:18px;overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,.45);
}
.login-brand{
  background:linear-gradient(160deg,#1B3A6B 0%,#0E1F3D 100%);
  padding:44px 36px;display:flex;flex-direction:column;color:#fff;
}
.lb-logo{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.lb-logo img{width:52px;height:52px;border-radius:12px;object-fit:contain;background:#fff;padding:4px;flex:none}
.lb-name{font-size:22px;font-weight:700;line-height:1.1}
.lb-sub{font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:#BF9B30;margin-top:3px}
.lb-branch{font-size:12.5px;color:#A9B8D6;margin-top:4px}
.lb-divider{width:36px;height:3px;background:var(--gold);border-radius:2px;margin:28px 0}
.lb-tagline{font-size:28px;font-weight:700;line-height:1.1;margin-bottom:10px}
.lb-body{font-size:13.5px;color:#C2CFE6;line-height:1.55}
.lb-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:32px}
.lb-pill{border:1px solid rgba(255,255,255,.22);border-radius:20px;padding:5px 13px;font-size:12px;font-weight:600;color:rgba(255,255,255,.85)}
.login-form-panel{background:#fff;padding:44px 40px;display:flex;flex-direction:column;justify-content:center}
.login-form-panel h2{font-size:28px;font-weight:700;margin-bottom:4px}
.lf-sub{font-size:13.5px;color:var(--muted);margin-bottom:28px}
.login-form-panel .field{margin-bottom:18px}
.login-form-panel .field label{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.login-form-panel .field input{
  width:100%;padding:12px 14px;border:1.5px solid var(--line-strong);border-radius:10px;
  font-family:var(--sans);font-size:14px;outline:none;transition:.15s;
}
.login-form-panel .field input:focus{border-color:var(--royal);box-shadow:0 0 0 3px rgba(46,90,172,.12)}
.login-form-panel .pw-wrap{position:relative}
.login-form-panel .pw-wrap input{padding-right:44px}
.login-form-panel .pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);padding:4px}
.login-forgot{font-size:13px;font-weight:600;color:var(--royal);text-align:right;display:block;margin-top:-6px;margin-bottom:20px}
.login-forgot:hover{color:var(--primary)}
.login-submit{width:100%;padding:13px;background:var(--royal);color:#fff;border:none;border-radius:10px;font-family:var(--sans);font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s;margin-bottom:14px}
.login-submit:hover{background:var(--primary)}
.login-footer{font-size:12px;font-style:italic;color:var(--muted-2);text-align:center}
.login-error{background:var(--red-soft);color:var(--red);border-radius:9px;padding:10px 14px;font-size:13px;font-weight:500;margin-bottom:16px;display:none}
.login-error.visible{display:block}
@media(max-width:700px){
  .login-card{grid-template-columns:1fr}
  .login-brand{display:none}
}

/* ===== Info banner ===== */
.info-banner{background:var(--gold-soft,#F3E9CC);border:1px solid var(--gold,#BF9B30);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--ink)}

/* ===== Tab bar ===== */
.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:20px}
.tab-btn{padding:10px 20px;font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:.15s}
.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab-btn:hover:not(.active){color:var(--ink)}

/* ===== Fellowship register cards ===== */
.fellowship-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}
.fellowship-card-head{padding:14px 18px;background:var(--surface-2);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.fellowship-card-head h4{font-weight:700;font-size:14px;color:var(--ink)}

/* ===== Fellowship filter pills ===== */
.fellowship-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.fellowship-pill{padding:5px 14px;border-radius:20px;border:1px solid var(--line-strong);background:var(--surface);font-size:12.5px;font-weight:600;cursor:pointer;color:var(--muted);transition:.15s}
.fellowship-pill.active,.fellowship-pill:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ===== Soul entry card ===== */
.soul-entry{border:1px solid var(--line);border-radius:12px;padding:20px;margin-bottom:16px;background:var(--surface)}
.soul-entry-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-weight:600;font-size:14px;color:var(--ink)}
.soul-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.soul-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}
.soul-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}
.soul-field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}
.soul-field input,.soul-field select{width:100%}
@media(max-width:768px){.soul-grid-4{grid-template-columns:1fr 1fr}.soul-grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.soul-grid-2,.soul-grid-3,.soul-grid-4{grid-template-columns:1fr}}

/* Dashboard highlights & verse scroller */
.highlights{position:relative;overflow:hidden;margin-bottom:16px;border-radius:8px;min-height:320px;background:linear-gradient(135deg,rgba(17,27,70,.94),rgba(35,71,197,.9)),var(--navy);box-shadow:var(--shadow)}
.highlights.empty{display:grid;place-items:center}
.highlight-track{height:100%;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
.highlight-track::-webkit-scrollbar{display:none}
.highlight-slide{min-width:100%;min-height:320px;display:flex;align-items:flex-end;padding:clamp(24px,5vw,44px);color:white;background-position:center;background-size:cover;scroll-snap-align:start}
.highlight-slide h2,.highlight-overlay h2{max-width:780px;margin:8px 0 10px;font-size:clamp(1.8rem,4vw,3.1rem);line-height:1.02}
.highlight-slide p,.highlight-overlay p{max-width:680px;margin:6px 0 0;color:#e3e9ff;font-size:1rem}
.highlight-overlay{width:100%;padding:clamp(24px,5vw,44px);color:white}
.highlight-dots{position:absolute;right:18px;bottom:18px;display:flex;gap:6px}
.highlight-dots span{width:24px;height:4px;overflow:hidden;border-radius:999px;background:rgba(255,255,255,.52);color:transparent}
.verse-ticker{overflow:hidden;margin-bottom:16px;border:1px solid #d8e2ff;border-radius:8px;background:#eef3ff;color:var(--navy)}
.verse-ticker div{display:flex;width:max-content;animation:verse-scroll 38s linear infinite}
.verse-ticker span{display:inline-flex;align-items:center;min-height:46px;padding:0 28px;font-weight:800;white-space:nowrap}
@keyframes verse-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Attendance toggle buttons */
.mini-button{display:inline-flex;align-items:center;justify-content:center;min-width:100px;padding:7px 16px;border-radius:20px;font-size:12.5px;font-weight:700;border:2px solid transparent;cursor:pointer;transition:all .15s;letter-spacing:.3px}
.present-btn{background:#d1fae5;color:#065f46;border-color:#6ee7b7}
.present-btn:hover{background:#a7f3d0;border-color:#34d399}
.absent-btn{background:#f1f5f9;color:#64748b;border-color:#cbd5e1}
.absent-btn:hover{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
.attendance-absent td{color:var(--muted)}

/* Activity pagination */
.pagination{padding:12px 0}
.pagination button:disabled{opacity:.4;cursor:not-allowed}

/* ===== Counter number input ===== */
.c-val-input{width:80px;text-align:center;font-family:var(--mono);font-size:22px;font-weight:700;color:var(--primary);border:1px solid var(--line-strong);border-radius:8px;padding:4px 0;background:var(--surface);-moz-appearance:textfield}
.c-val-input::-webkit-outer-spin-button,.c-val-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
