:root{--bg: #0e0a1c;--bg2: #150d2b;--panel: #1a1233;--panel2: #211743;--border: rgba(167, 139, 250, .18);--border2: rgba(255, 255, 255, .08);--text: #f3effc;--muted: #9385bd;--magenta: #ff3d81;--violet: #a78bfa;--cyan: #22d3ee;--teal: #2ee6b8;--amber: #fbbf24;--danger: #ff5670;--radius: 14px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:radial-gradient(1200px 600px at 80% -10%,rgba(124,58,237,.18),transparent 60%),var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px}a{color:var(--violet)}button{font-family:inherit;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}.app{display:flex;min-height:100vh}.sidebar{width:230px;flex-shrink:0;background:linear-gradient(180deg,var(--bg2),var(--bg));border-right:1px solid var(--border);padding:18px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 16px;font-size:17px;font-weight:700;letter-spacing:1px}.brand .dot{width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,var(--magenta),var(--violet));box-shadow:0 0 12px var(--magenta)}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted);background:transparent;border:none;width:100%;text-align:left;font-size:14px;transition:background .12s,color .12s}.nav-link:hover{background:#ffffff0a;color:var(--text)}.nav-link.active{background:linear-gradient(90deg,#ff3d8129,#a78bfa1f);color:#fff;border:1px solid var(--border)}.nav-spacer{flex:1}.logout{color:var(--danger)}.main{flex:1;min-width:0;padding:22px 26px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;margin:0}.page-sub{color:var(--muted);font-size:13px;margin-top:4px}.card{background:linear-gradient(160deg,var(--panel),var(--bg2));border:1px solid var(--border);border-radius:var(--radius);padding:16px}.grid{display:grid;gap:14px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.stat{padding:16px}.stat .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.6px}.stat .value{font-size:26px;font-weight:700;margin-top:8px}.stat .value.teal{color:var(--teal)}.stat .value.amber{color:var(--amber)}.stat .value.magenta{color:var(--magenta)}.stat .value.cyan{color:var(--cyan)}.btn{border:1px solid var(--border2);background:#ffffff0d;color:var(--text);padding:8px 14px;border-radius:10px;font-size:13px;display:inline-flex;align-items:center;gap:6px}.btn:hover{background:#ffffff17}.btn.primary{background:linear-gradient(90deg,var(--magenta),var(--violet));border:none;color:#fff}.btn.green{background:linear-gradient(90deg,var(--teal),var(--cyan));border:none;color:#06231b}.btn.danger{background:#ff567029;border-color:#ff567066;color:#ff95a5}.btn.amber{background:#fbbf2429;border-color:#fbbf2466;color:var(--amber)}.btn.sm{padding:5px 10px;font-size:12px;border-radius:8px}.input,.select,textarea.input{width:100%;background:#ffffff0a;border:1px solid var(--border2);border-radius:10px;padding:10px 12px;color:var(--text);font-size:13px;outline:none}.input:focus,.select:focus{border-color:var(--violet)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;color:var(--muted)}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.tabs{display:flex;gap:6px;flex-wrap:wrap}.tab{padding:7px 14px;border-radius:999px;border:1px solid var(--border2);background:transparent;color:var(--muted);font-size:13px}.tab.active{background:#a78bfa29;border-color:var(--border);color:#fff}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}table{width:100%;border-collapse:collapse;font-size:13px;min-width:640px}thead th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:12px 14px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0}tbody td{padding:11px 14px;border-bottom:1px solid var(--border2);vertical-align:middle}tbody tr:hover{background:#ffffff06}tbody tr.selected{background:#a78bfa1a}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600}.badge.pending{background:#fbbf2429;color:var(--amber)}.badge.approved{background:#22d3ee29;color:var(--cyan)}.badge.paid{background:#2ee6b829;color:var(--teal)}.badge.rejected{background:#ff567029;color:#ff95a5}.badge.gw{background:#a78bfa24;color:var(--violet)}.chk{width:17px;height:17px;accent-color:var(--magenta);cursor:pointer}.bulkbar{position:sticky;bottom:16px;z-index:5;display:flex;align-items:center;gap:12px;margin-top:14px;padding:12px 16px;border-radius:12px;background:linear-gradient(90deg,#ff3d812e,#a78bfa29);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06040eb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;background:linear-gradient(160deg,var(--panel2),var(--bg2));border:1px solid var(--border);border-radius:18px;padding:22px}.modal h3{margin:0 0 16px}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{width:100%;max-width:360px}.muted{color:var(--muted)}.empty{padding:40px;text-align:center;color:var(--muted)}.toast{position:fixed;bottom:20px;right:20px;background:var(--panel2);border:1px solid var(--border);padding:12px 18px;border-radius:12px;z-index:60}.toast.err{border-color:#ff567080;color:#ff95a5}.toast.ok{border-color:#2ee6b880;color:var(--teal)}.menu-btn{display:none}@media (max-width: 820px){.app{flex-direction:column}.sidebar{position:static;width:100%;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:4px;padding:10px}.sidebar .brand{padding:4px 8px}.nav-spacer{display:none}.nav-link{width:auto;padding:8px 10px}.main{padding:16px}}
