/* ─── Design Tokens ────────────────────────────────────────────────────────── */
:root {
  --sw: 252px;
  --sbg: #0f172a; --st: #94a3b8; --sh: #f1f5f9;
  --sa-bg: rgba(59,130,246,.12); --sa-t: #60a5fa;
  --sborder: rgba(255,255,255,.07);
  --bg: #f1f5f9; --card: #fff; --border: #e2e8f0; --border-i: #d1d5db;
  --t1: #0f172a; --t2: #475569; --t3: #94a3b8;
  --blue: #3b82f6; --blue50: #eff6ff;
  --green: #22c55e; --green50: #f0fdf4;
  --amber: #f59e0b; --amber50: #fffbeb;
  --red: #ef4444; --red50: #fef2f2;
  --slate50: #f8fafc;
  --rsm: 6px; --r: 10px; --rlg: 14px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow: 0 4px 6px -1px rgba(0,0,0,.06),0 2px 4px -1px rgba(0,0,0,.04);
}

/* ─── Base ───────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
body,.app-body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--t1);margin:0}

/* ─── Layout ─────────────────────────────────────────────────────────────── */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--sbg);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:100;transition:transform .25s;border-right:1px solid rgba(255,255,255,.04)}
.content-wrapper{margin-left:var(--sw);flex:1;min-width:0;min-height:100vh}
.page-inner{padding:32px 36px}

/* ─── Sidebar logo ────────────────────────────────────────────────────────── */
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;text-decoration:none;color:#f8fafc;font-weight:700;font-size:.95rem;letter-spacing:-.3px;border-bottom:1px solid var(--sborder)}
.sidebar-logo:hover{color:#f8fafc}
.logo-icon{width:30px;height:30px;border-radius:7px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}

/* ─── Sidebar nav ─────────────────────────────────────────────────────────── */
.sidebar-nav{flex:1;padding:8px;overflow-y:auto}
.nav-section{font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--st);opacity:.5;padding:12px 10px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--rsm);color:var(--st);text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s;margin-bottom:1px}
.nav-item:hover{background:rgba(255,255,255,.06);color:var(--sh)}
.nav-item.active{background:var(--sa-bg);color:var(--sa-t)}
.nav-item i{width:16px;text-align:center;font-size:.95rem;flex-shrink:0}

/* ─── Sidebar footer ──────────────────────────────────────────────────────── */
.sidebar-foot{padding:10px;border-top:1px solid var(--sborder)}
.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--rsm);margin-bottom:6px;text-decoration:none;transition:background .15s}
.sidebar-user:hover{background:rgba(255,255,255,.06)}
.s-avatar{width:28px;height:28px;border-radius:50%;background:var(--blue);color:#fff;font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
.s-name{font-size:.78rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.s-role{font-size:.62rem;color:var(--st);text-transform:uppercase;letter-spacing:.05em}
.btn-signout{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border-radius:var(--rsm);background:transparent;border:1px solid rgba(255,255,255,.08);color:var(--st);font-size:.78rem;cursor:pointer;transition:all .15s;font-family:inherit}
.btn-signout:hover{background:rgba(239,68,68,.12);color:#fca5a5;border-color:rgba(239,68,68,.25)}

/* ─── Mobile ──────────────────────────────────────────────────────────────── */
.mobile-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;width:36px;height:36px;background:var(--sbg);color:#fff;border:none;border-radius:6px;cursor:pointer;align-items:center;justify-content:center;font-size:1.1rem}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99}
@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-backdrop.open{display:block}.content-wrapper{margin-left:0!important}.page-inner{padding:64px 16px 20px}.mobile-toggle{display:flex!important}.mobile-toggle.hidden{display:none!important}}

/* ─── Page header ─────────────────────────────────────────────────────────── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.page-title{font-size:1.35rem;font-weight:700;color:var(--t1);margin:0;letter-spacing:-.3px}
.page-sub{font-size:.875rem;color:var(--t2);margin:3px 0 0}

/* ─── Stat cards ──────────────────────────────────────────────────────────── */
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow-sm)}
.stat-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:14px}
.ic-blue{background:var(--blue50);color:var(--blue)}.ic-green{background:var(--green50);color:#16a34a}.ic-amber{background:var(--amber50);color:#d97706}.ic-red{background:var(--red50);color:#dc2626}
.stat-val{font-size:1.75rem;font-weight:700;color:var(--t1);line-height:1}
.stat-lbl{font-size:.78rem;color:var(--t2);margin-top:3px}

/* ─── Cards ───────────────────────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.card-header{padding:13px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:.875rem;color:var(--t1);background:transparent!important;border-radius:var(--r) var(--r) 0 0;display:flex;align-items:center;justify-content:space-between}
.card-body{padding:20px}
.card-footer{padding:13px 20px;border-top:1px solid var(--border);background:transparent!important}

/* ─── Tables ──────────────────────────────────────────────────────────────── */
.table{font-size:.875rem;margin:0;border-color:var(--border)}
.table thead th{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--t2);background:var(--slate50)!important;border-bottom:1px solid var(--border)!important;padding:10px 16px;white-space:nowrap}
.table tbody td{padding:11px 16px;border-bottom:1px solid #f1f5f9!important;vertical-align:middle;color:var(--t1)}
.table tbody tr:last-child td{border-bottom:none!important}
.table-hover tbody tr:hover td{background:var(--slate50)!important}
.table-clickable tbody tr{cursor:pointer}

/* ─── Badges ──────────────────────────────────────────────────────────────── */
.badge{font-weight:500;border-radius:20px;padding:3px 9px;font-size:.72rem;letter-spacing:.01em}
.badge.bg-success{background:#dcfce7!important;color:#15803d!important}
.badge.bg-primary{background:#dbeafe!important;color:#1d4ed8!important}
.badge.bg-danger{background:#fee2e2!important;color:#b91c1c!important}
.badge.bg-warning{background:#fef3c7!important;color:#b45309!important}
.badge.bg-secondary{background:#f1f5f9!important;color:#475569!important;border:1px solid var(--border)}

/* ─── Filter pills ────────────────────────────────────────────────────────── */
.filter-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:11px 16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.filter-label{font-size:.75rem;font-weight:600;color:var(--t2);white-space:nowrap}
.filter-pill{padding:4px 13px;border-radius:20px;font-size:.78rem;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--t2);cursor:pointer;transition:all .15s;font-family:inherit}
.filter-pill:hover{border-color:#94a3b8;color:var(--t1)}
.filter-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.btn{font-family:inherit;font-weight:500;border-radius:var(--rsm);font-size:.875rem}
.btn-sm{padding:5px 12px;font-size:.8rem}
.btn-primary{background:var(--blue);border-color:var(--blue)}
.btn-primary:hover{background:#2563eb;border-color:#2563eb}

/* ─── Forms ───────────────────────────────────────────────────────────────── */
.form-label{font-size:.78rem;font-weight:600;color:var(--t2);margin-bottom:5px}
.form-control,.form-select{border-color:var(--border-i);border-radius:var(--rsm);font-size:.875rem;padding:8px 12px;font-family:inherit;color:var(--t1)}
.form-control:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.form-control::placeholder{color:var(--t3)}
.form-text{font-size:.75rem;color:var(--t3)}
.input-group .btn-outline-secondary{border-color:var(--border-i)}
.btn-toggle-pass{border-left:0}

/* ─── Auth ────────────────────────────────────────────────────────────────── */
.auth-body{font-family:'Inter',system-ui,sans-serif;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 55%,#0f172a 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;margin:0}
.auth-box{background:#fff;border-radius:var(--rlg);width:100%;max-width:420px;box-shadow:0 25px 60px rgba(0,0,0,.3);overflow:hidden}
.auth-head{background:linear-gradient(135deg,#1d4ed8,var(--blue));padding:28px 32px 22px;text-align:center}
.auth-head i{font-size:1.8rem;color:rgba(255,255,255,.9)}
.auth-head h1{font-size:1.15rem;font-weight:700;color:#fff;margin:8px 0 3px}
.auth-head p{font-size:.82rem;color:rgba(255,255,255,.7);margin:0}
.auth-form{padding:26px 32px 30px}
.auth-foot{text-align:center;margin-top:18px;font-size:.82rem;color:var(--t2)}
.auth-foot a{color:var(--blue);font-weight:600;text-decoration:none}

/* ─── Info grid ───────────────────────────────────────────────────────────── */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.info-item .lbl{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--t3);margin-bottom:2px}
.info-item .val{font-size:.875rem;font-weight:500;color:var(--t1)}
.back-btn{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:500;color:var(--t2);text-decoration:none;margin-bottom:18px;transition:color .15s}
.back-btn:hover{color:var(--t1)}
.empty-state{text-align:center;padding:52px 24px;color:var(--t3)}
.empty-state i{font-size:2.5rem;display:block;margin-bottom:10px;opacity:.4}
.empty-state p{font-size:.875rem;margin:0}
.id-tag{display:inline-block;font-size:.7rem;font-weight:600;color:var(--t3);background:var(--slate50);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-variant-numeric:tabular-nums}
.money{font-variant-numeric:tabular-nums;font-weight:600}
