*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}[data-theme=light]{--bg:#fff;--bg-s:#f5f5f5;--bg-t:#eee;--bg-el:#fff;--bg-in:#fff;--tx:#111;--tx-s:#333;--tx-m:#999;--bd:#e0e0e0;--bd-l:#eee;--ac:#111;--ac-h:#333;--ac-s:rgba(0,0,0,.04);--ac-tx:#fff;--sb:#fff;--sb-a:#111;--sb-at:#fff;--sb-h:#f5f5f5;--sh:0 1px 2px rgba(0,0,0,.05);--sh-m:0 4px 12px rgba(0,0,0,.08);--ov:rgba(0,0,0,.3);--m-sh:0 16px 48px rgba(0,0,0,.12);--th-bg:#fafafa;--tr-h:#fafafa;--bs-bg:#f0f0f0;--bs-tx:#222;--bw-bg:#f0f0f0;--bw-tx:#222;--bx-bg:#f0f0f0;--bx-tx:#222;--bf-bg:#f0f0f0;--bf-tx:#666;--cg:#eee;--ct:#ccc;--tt-bg:#fff;--tt-bd:#e0e0e0;--tt-tx:#111;--tt-m:#999}[data-theme=dark]{--bg:#1a1a1a;--bg-s:#111;--bg-t:#262626;--bg-el:#1a1a1a;--bg-in:#161616;--tx:#eee;--tx-s:#ccc;--tx-m:#666;--bd:#2a2a2a;--bd-l:#222;--ac:#eee;--ac-h:#ccc;--ac-s:rgba(255,255,255,.04);--ac-tx:#111;--sb:#141414;--sb-a:#eee;--sb-at:#111;--sb-h:#222;--sh:0 1px 3px rgba(0,0,0,.3);--sh-m:0 4px 16px rgba(0,0,0,.4);--ov:rgba(0,0,0,.6);--m-sh:0 16px 48px rgba(0,0,0,.5);--th-bg:#161616;--tr-h:#1e1e1e;--bs-bg:#222;--bs-tx:#ccc;--bw-bg:#222;--bw-tx:#ccc;--bx-bg:#222;--bx-tx:#ccc;--bf-bg:#222;--bf-tx:#888;--cg:#2a2a2a;--ct:#444;--tt-bg:#1a1a1a;--tt-bd:#2a2a2a;--tt-tx:#eee;--tt-m:#666}:root{--dn:#888;--dn-h:#666;--r:8px;--rs:5px;--rl:12px;--t:.12s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-s);color:var(--tx);line-height:1.45;-webkit-font-smoothing:antialiased;font-size:13px}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}.layout{display:flex;min-height:100vh}.sidebar{width:200px;background:var(--sb);border-right:1px solid var(--bd);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-header{padding:16px 14px;border-bottom:1px solid var(--bd)}.sidebar-logo{font-size:18px;font-weight:800;color:var(--tx);letter-spacing:.5px}.sidebar-nav{flex:1;padding:8px 6px;overflow-y:auto}.sidebar-group{font-size:9px;font-weight:700;color:var(--ct);text-transform:uppercase;letter-spacing:.8px;padding:12px 10px 3px;margin-top:2px}.sidebar-group:first-child{padding-top:4px;margin-top:0}.sidebar-link{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--rs);font-size:12.5px;font-weight:500;color:var(--tx-m);transition:all var(--t);margin-bottom:1px}.sidebar-link:hover{background:var(--sb-h);color:var(--tx)}.sidebar-link.active{background:var(--sb-a);color:var(--sb-at)}.sidebar-footer{padding:8px 6px;border-top:1px solid var(--bd)}.main{flex:1;margin-left:200px;padding:20px 24px;min-height:100vh}.card{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);padding:16px;box-shadow:var(--sh)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:6px 12px;border-radius:var(--rs);font-size:12px;font-weight:500;border:none;cursor:pointer;transition:all var(--t);line-height:1.3}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--tx);color:var(--bg)}.btn-primary:hover:not(:disabled){opacity:.8}.btn-secondary{background:var(--bg-t);color:var(--tx-s);border:1px solid var(--bd)}.btn-secondary:hover:not(:disabled){background:var(--bd);color:var(--tx)}.btn-danger{background:var(--tx-m);color:var(--bg)}.btn-danger:hover:not(:disabled){opacity:.8}.btn-icon{background:transparent;color:var(--tx-m);padding:5px;border-radius:var(--rs);border:none;cursor:pointer;transition:all var(--t);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--bg-t);color:var(--tx)}.btn-icon.danger:hover{color:var(--tx)}.btn-sm{padding:4px 8px;font-size:11px}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;border-radius:var(--rs);font-size:11px;color:var(--tx-m);background:transparent;border:1px solid var(--bd);cursor:pointer;transition:all var(--t);width:100%}.theme-toggle:hover{color:var(--tx);border-color:var(--tx)}.input{width:100%;padding:7px 10px;border:1px solid var(--bd);border-radius:var(--rs);font-size:12.5px;background:var(--bg-in);color:var(--tx);transition:border-color var(--t);outline:none}.input:focus{border-color:var(--tx)}.input::placeholder{color:var(--ct)}.select{width:100%;padding:7px 10px;border:1px solid var(--bd);border-radius:var(--rs);font-size:12.5px;background:var(--bg-in);color:var(--tx);outline:none;cursor:pointer}.select:focus{border-color:var(--tx)}.select option{background:var(--bg);color:var(--tx)}.textarea{width:100%;padding:7px 10px;border:1px solid var(--bd);border-radius:var(--rs);font-size:12.5px;background:var(--bg-in);color:var(--tx);outline:none;resize:vertical;min-height:60px;font-family:inherit}.textarea:focus{border-color:var(--tx)}.label{display:block;font-size:11px;font-weight:600;color:var(--tx-m);margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px}.form-group{margin-bottom:10px}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:12.5px}.table th{text-align:left;padding:8px 12px;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--tx-m);border-bottom:1px solid var(--bd);background:var(--th-bg)}.table td{padding:8px 12px;border-bottom:1px solid var(--bd-l);color:var(--tx-s)}.table tr:hover td{background:var(--tr-h)}.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:10.5px;font-weight:500}.badge-success{background:var(--bs-bg);color:var(--bs-tx)}.badge-warning{background:var(--bw-bg);color:var(--bw-tx)}.badge-danger{background:var(--bx-bg);color:var(--bx-tx)}.badge-default{background:var(--bf-bg);color:var(--bf-tx)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh)}.stat-label{font-size:10px;font-weight:600;color:var(--tx-m);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.stat-value{font-size:22px;font-weight:700;color:var(--tx);letter-spacing:-.5px}.stat-sub{font-size:11px;color:var(--tx-m);margin-top:1px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.page-title{font-size:18px;font-weight:700;letter-spacing:-.2px}.filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.filters .input,.filters .select{width:auto;min-width:140px}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--ov);display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:var(--bg-el);border:1px solid var(--bd);border-radius:var(--rl);padding:20px;width:90%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:var(--m-sh)}.modal-title{font-size:15px;font-weight:600;margin-bottom:14px;color:var(--tx)}.modal-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:16px}.empty{text-align:center;padding:32px 16px;color:var(--ct);font-size:12.5px}.error-text{color:var(--tx-m);font-size:12px;margin-bottom:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-s)}.login-card{width:360px;padding:32px 28px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--sh-m)}.login-title{font-size:22px;font-weight:800;text-align:center;margin-bottom:2px;color:var(--tx)}.login-subtitle{text-align:center;color:var(--tx-m);font-size:12px;margin-bottom:24px}.toggle{position:relative;width:32px;height:18px;border-radius:9px;background:var(--bd);cursor:pointer;transition:background var(--t)}.toggle.active{background:var(--tx)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--bg);transition:transform var(--t)}.toggle.active:after{transform:translate(14px)}.flex{display:flex}.items-center{align-items:center}.gap-1{gap:4px}.gap-2{gap:6px}.gap-3{gap:10px}.mt-2{margin-top:6px}.mt-3{margin-top:12px}.text-sm{font-size:12px}.text-muted{color:var(--tx-m)}.font-medium{font-weight:500}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
