:root{
  --bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2e3250;
  --accent:#4f7cff;--accent2:#7c5cff;--text:#e8eaf6;--text2:#8b90b8;
  --user-bg:#1e2d5a;--danger:#ff5c7c;--success:#4caf8a;--radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
input,select,textarea{font-family:inherit}
button{font-family:inherit;cursor:pointer}

.btn{padding:9px 18px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#3d6aff}
.btn-primary:disabled{background:var(--border);color:var(--text2);cursor:not-allowed}
.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text)}
.btn-danger{background:rgba(255,92,124,.15);color:var(--danger);border:1px solid rgba(255,92,124,.3)}
.btn-danger:hover{background:rgba(255,92,124,.25)}
.btn-sm{padding:5px 12px;font-size:12px}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.form-group{margin-bottom:14px}
.form-label{font-size:12px;color:var(--text2);margin-bottom:5px;display:block}
.form-input{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 12px;font-size:14px;outline:none;transition:border-color .2s}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--text2)}
.form-select{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 12px;font-size:14px;outline:none}
.form-select:focus{border-color:var(--accent)}

.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-admin{background:rgba(124,92,255,.2);color:#b39dfc}
.badge-employee{background:rgba(79,124,255,.15);color:var(--accent)}
.badge-consumer{background:rgba(76,175,138,.12);color:var(--success)}
.badge-inactive{background:rgba(255,92,124,.12);color:var(--danger)}

.tag-active{color:var(--success)}.tag-inactive{color:var(--danger)}

#toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-70px);background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:10px;font-size:13px;z-index:9999;transition:transform .3s;pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.5);white-space:nowrap}
#toast.show{transform:translateX(-50%) translateY(0)}
#toast.ok{border-color:var(--success);color:var(--success)}
#toast.err{border-color:var(--danger);color:var(--danger)}

.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:420px;max-width:90vw}
.modal-title{font-size:16px;font-weight:600;margin-bottom:18px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
