*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f1f5f9;--surface:#ffffff;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--accent:#3b82f6;--accent-hover:#2563eb;--danger:#ef4444;--success:#22c55e;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-active-bg:#3b82f6;--sidebar-active-text:#ffffff;--sidebar-hover-bg:#334155;--radius:8px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05)}body,html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.6;color:var(--text);background:var(--bg)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 36px;width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{font-size:20px;font-weight:700;color:var(--text)}.login-logo span{font-size:12px;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase}.login-step-title{font-size:16px;font-weight:600;margin-bottom:20px;color:var(--text)}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:16px}.field label{font-size:13px;font-weight:500;color:var(--text)}.field input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--text-muted)}.field-hint{font-size:12px;color:var(--text-muted);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg)}.error-msg{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:var(--radius)}.error-msg,.success-msg{padding:10px 12px;font-size:13px;margin-bottom:16px}.success-msg{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;border-radius:var(--radius)}.admin-layout{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid #334155}.sidebar-brand h2{font-size:15px;font-weight:700;color:#f1f5f9}.sidebar-brand span{font-size:11px;color:#64748b;letter-spacing:.06em;text-transform:uppercase}.sidebar-nav{flex:1 1;padding:12px 0}.sidebar-section{padding:10px 14px 4px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#475569}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 20px;color:var(--sidebar-text);font-size:13.5px;font-weight:400;cursor:pointer;transition:background .12s,color .12s;text-decoration:none}.sidebar-link:hover{background:var(--sidebar-hover-bg);color:#f1f5f9;text-decoration:none}.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:500}.sidebar-link svg{flex-shrink:0;opacity:.8}.sidebar-link.active svg{opacity:1}.sidebar-footer{padding:16px 20px;border-top:1px solid #334155;font-size:12px;color:#475569}.sidebar-footer .user-info{margin-bottom:10px}.sidebar-footer .user-name{font-weight:600;color:#94a3b8}.admin-main{margin-left:240px;flex:1 1;display:flex;flex-direction:column;min-height:100vh}.admin-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:50}.admin-header h1{font-size:16px;font-weight:600}.admin-content{padding:28px;flex:1 1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px}.card-title{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.card-value{font-size:28px;font-weight:700;color:var(--text)}.card-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:28px}.section-title{font-size:15px;font-weight:600;margin-bottom:16px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{text-align:left;padding:10px 14px;font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}tbody td,thead th{border-bottom:1px solid var(--border)}tbody td{padding:11px 14px;color:var(--text)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f8fafc}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11.5px;font-weight:500}.badge-green{background:#dcfce7;color:#15803d}.badge-red{background:#fee2e2;color:#b91c1c}.badge-yellow{background:#fef9c3;color:#a16207}.badge-gray{background:#f1f5f9;color:#475569}.badge-blue{background:#dbeafe;color:#1d4ed8}.setup-2fa{max-width:480px}.qr-wrap{text-align:center;margin:20px 0}.qr-wrap img{padding:12px}.qr-wrap img,.secret-code{border:1px solid var(--border);border-radius:var(--radius)}.secret-code{font-family:monospace;font-size:13px;background:var(--bg);padding:10px 14px;word-break:break-all;margin:8px 0 16px}.totp-input{text-align:center;font-size:24px;font-weight:600;letter-spacing:.2em;padding:12px}