*{box-sizing:border-box}:root{--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#e0e7ff;--success:#10b981;--sidebar-bg:#1e1b4b;--sidebar-text:#e0e7ff;--sidebar-active:hsla(0,0%,100%,.12);--shadow:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 12px rgba(0,0,0,.08);--radius:10px;--radius-sm:6px}body{margin:0;font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input{font-family:inherit}.dashboard-layout{display:flex;min-height:100vh}.dashboard-sidebar{width:260px;flex-shrink:0;background:var(--sidebar-bg);padding:1.5rem 0;display:flex;flex-direction:column}.sidebar-brand{padding:0 1.25rem 1.25rem;border-bottom:1px solid hsla(0,0%,100%,.08);margin-bottom:1rem}.sidebar-brand a{font-size:1.125rem;font-weight:700;color:var(--sidebar-text);letter-spacing:-.02em}.sidebar-nav{flex:1 1}.sidebar-link{display:block;padding:.65rem 1.25rem;color:rgba(224,231,255,.85);font-weight:500;font-size:.9375rem;transition:background .15s,color .15s}.sidebar-link:hover{color:var(--sidebar-text);background:hsla(0,0%,100%,.06)}.sidebar-link.active{color:var(--sidebar-text);background:var(--sidebar-active);border-left:3px solid var(--accent);padding-left:calc(1.25rem - 3px)}.sidebar-footer{padding:1rem 1.25rem 0;border-top:1px solid hsla(0,0%,100%,.08);margin-top:auto}.sidebar-logout{width:100%;padding:.6rem 1rem;background:hsla(0,0%,100%,.1);color:var(--sidebar-text);border:1px solid hsla(0,0%,100%,.15);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:500;transition:background .15s}.sidebar-logout:hover:not(:disabled){background:hsla(0,0%,100%,.18)}.sidebar-logout:disabled{cursor:not-allowed;opacity:.7}.dashboard-main{flex:1 1;padding:2rem 2.5rem;max-width:1100px;overflow-x:auto}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.overview-page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.overview-title{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.overview-desc{color:var(--text-muted);margin:0 0 2rem;font-size:.9375rem;max-width:480px}.overview-card{display:flex;flex-direction:column;align-items:flex-start;width:100%;max-width:420px;padding:1.75rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);transition:box-shadow .2s,border-color .2s,transform .15s}.overview-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent-light);transform:translateY(-2px)}.overview-card-icon{font-size:1.75rem;margin-bottom:.75rem}.overview-card-title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text)}.overview-card-desc{margin:0 0 1rem;font-size:.875rem;color:var(--text-muted);line-height:1.5}.overview-card-arrow{font-size:1.25rem;color:var(--accent);font-weight:600}.users-list{animation:fadeIn .3s ease}.users-list-title{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.users-list-desc{color:var(--text-muted);margin:0 0 1.5rem;font-size:.9375rem}.users-list-search{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.users-list-input{padding:.6rem 1rem;width:100%;max-width:320px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;background:var(--surface);transition:border-color .15s,box-shadow .15s}.users-list-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.users-list-btn{padding:.6rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.9375rem;cursor:pointer;transition:background .15s}.users-list-btn:hover{background:var(--accent-hover)}.users-list-loading{display:flex;align-items:center;gap:1rem;padding:2rem;color:var(--text-muted)}.users-list-table-wrap{overflow-x:auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.users-list-table{width:100%;border-collapse:collapse;font-size:.9375rem}.users-list-table th{text-align:left;font-weight:600;color:var(--text-muted);font-size:.8125rem;text-transform:uppercase;letter-spacing:.04em;background:var(--bg)}.users-list-table td,.users-list-table th{padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.users-list-table tbody tr:last-child td{border-bottom:none}.users-list-table tbody tr:hover{background:var(--bg)}.users-list-user{display:inline-flex;align-items:center;gap:.75rem}.users-list-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.users-list-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.users-list-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8125rem;font-weight:500;background:var(--border);color:var(--text-muted)}.users-list-badge.success{background:rgba(16,185,129,.15);color:var(--success)}.users-list-muted,.users-list-pagination{color:var(--text-muted);font-size:.875rem}.users-list-pagination{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1.25rem}.users-list-pagination-btns{display:flex;gap:.5rem}.users-list-page-btn{padding:.4rem .75rem;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;color:var(--text);transition:background .15s,border-color .15s}.users-list-page-btn:hover:not(:disabled){background:var(--bg);border-color:var(--accent);color:var(--accent)}.users-list-page-btn:disabled{cursor:not-allowed;opacity:.5}.users-list-empty{padding:2rem;text-align:center;color:var(--text-muted);background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:380px;padding:2.25rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--border)}.login-title{margin:0 0 1.75rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.login-label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9375rem;color:var(--text)}.login-input{width:100%;padding:.65rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;margin-bottom:1.25rem;background:var(--surface);transition:border-color .15s,box-shadow .15s}.login-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.login-error{color:#dc2626;font-size:.875rem;margin-bottom:1rem}.login-btn{width:100%;padding:.75rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.9375rem;cursor:pointer;transition:background .15s}.login-btn:hover:not(:disabled){background:var(--accent-hover)}.login-btn:disabled{cursor:not-allowed;opacity:.7}