*{box-sizing:border-box;margin:0;padding:0}html,body,#root{-webkit-font-smoothing:antialiased;color:#0f172a;background:#f1f5f9;width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:24px;width:100%;max-width:420px;padding:48px 40px;box-shadow:0 25px 50px #0000004d}.login-brand{flex-direction:column;align-items:center;margin-bottom:36px;display:flex}.login-shield{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:20px;display:flex;box-shadow:0 8px 20px #3b82f659}.login-brand h1{color:#0f172a;letter-spacing:-.5px;margin-bottom:8px;font-size:26px;font-weight:800}.login-brand p{color:#64748b;text-align:center;font-size:14px}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;align-items:center;gap:10px;margin-bottom:24px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.login-form{flex-direction:column;gap:20px;display:flex}.field-group{flex-direction:column;gap:8px;display:flex}.field-group label{color:#475569;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.input-wrap{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.input-wrap:focus-within{background:#fff;border-color:#3b82f6}.input-icon{color:#94a3b8;flex-shrink:0;margin-left:14px}.input-wrap input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;padding:14px;font-size:15px}.login-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:12px;justify-content:center;align-items:center;margin-top:8px;padding:16px;font-size:16px;font-weight:700;transition:opacity .2s,transform .1s;display:flex;box-shadow:0 6px 18px #3b82f659}.login-btn:hover{opacity:.92}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.7;cursor:not-allowed}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;color:#94a3b8;margin-top:28px;font-size:13px}.users-page{padding:32px}.up-header{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.up-header h1{color:#0f172a;margin-bottom:6px;font-size:26px;font-weight:800}.up-header p{color:#64748b;font-size:14px}.stats-row{gap:12px;display:flex}.stat-pill{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;min-width:90px;padding:12px 20px;display:flex;box-shadow:0 2px 4px #00000008}.admin-stat{background:#eff6ff;border-color:#bfdbfe}.stat-num{color:#3b82f6;margin-bottom:4px;font-size:22px;font-weight:800;line-height:1}.stat-lbl{text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;font-size:11px;font-weight:600}.up-search{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;align-items:center;margin-bottom:28px;padding:0 16px;transition:border-color .2s;display:flex}.up-search:focus-within{border-color:#3b82f6}.up-search-icon{color:#94a3b8;margin-right:12px}.up-search input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;padding:14px 0;font-size:15px}.up-loading{color:#64748b;flex-direction:column;align-items:center;gap:16px;padding:60px;display:flex}.up-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:28px;overflow:hidden;box-shadow:0 4px 6px #00000008}.accent-section{border-color:#bfdbfe}.up-section-title{color:#0f172a;border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:20px 24px 16px;font-size:15px;font-weight:700;display:flex}.count-badge{color:#64748b;background:#f1f5f9;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600}.up-empty{color:#cbd5e1;flex-direction:column;align-items:center;gap:12px;padding:48px;display:flex}.up-empty p{color:#94a3b8;font-size:14px}.up-table-wrap{overflow-x:auto}.up-table{border-collapse:collapse;width:100%}.up-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 24px;font-size:11px;font-weight:700}.up-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:14px 24px}.up-table tr:last-child td{border-bottom:none}.up-table tbody tr:hover{background:#fafbff}.up-user-cell{align-items:center;gap:14px;display:flex}.up-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.up-name{color:#0f172a;margin-bottom:2px;font-size:14px;font-weight:600}.up-email{color:#94a3b8;font-size:13px}.up-badge{text-transform:capitalize;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.up-badge.user{color:#166534;background:#dcfce7}.up-badge.admin{color:#1d4ed8;background:#dbeafe}.up-badge.superuser{color:#6d28d9;background:#ede9fe}.up-date{color:#64748b;align-items:center;gap:6px;font-size:13px;display:flex}.up-uid{color:#cbd5e1;font-family:monospace;font-size:11px}.spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.role-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:700;transition:opacity .15s,transform .1s;display:inline-flex}.role-btn:hover{opacity:.85;transform:scale(1.03)}.role-btn:active{transform:scale(.97)}.promote-btn{color:#1d4ed8;background:#dbeafe}.demote-btn{color:#dc2626;background:#fee2e2}.create-admin-page{padding:32px}.ca-header{color:#3b82f6;align-items:center;gap:16px;margin-bottom:32px;display:flex}.ca-header h1{color:#0f172a;margin-bottom:4px;font-size:26px;font-weight:800}.ca-header p{color:#64748b;font-size:14px}.ca-grid{grid-template-columns:1fr 360px;gap:24px;display:grid}.ca-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:32px;box-shadow:0 4px 6px #00000008}.ca-card h2{color:#0f172a;margin-bottom:24px;font-size:18px;font-weight:700}.ca-success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.ca-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.ca-form{flex-direction:column;gap:20px;display:flex}.ca-field{flex-direction:column;gap:8px;display:flex}.ca-field label{color:#475569;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.required{color:#ef4444}.ca-input-wrap{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.ca-input-wrap:focus-within{background:#fff;border-color:#3b82f6}.ca-input-icon{color:#94a3b8;flex-shrink:0;margin-left:14px}.ca-input-wrap input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;padding:13px 14px;font-size:15px}.role-options{gap:12px;display:flex}.role-option{cursor:pointer;text-align:left;color:#64748b;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;flex:1;align-items:flex-start;gap:12px;padding:16px;transition:all .2s;display:flex}.role-option strong{color:#0f172a;margin-bottom:2px;font-size:15px;display:block}.role-option span{color:#94a3b8;font-size:12px}.role-option.selected{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.role-option.selected.superuser{color:#7c3aed;background:#f5f3ff;border-color:#7c3aed}.ca-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;margin-top:8px;padding:14px;font-size:16px;font-weight:700;transition:opacity .2s;display:flex;box-shadow:0 4px 12px #3b82f64d}.ca-submit:hover{opacity:.9}.ca-submit:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin;display:inline-block}.ca-info-panel{flex-direction:column;gap:16px;display:flex}.ca-info-panel h3{text-transform:uppercase;letter-spacing:.5px;color:#64748b;margin-bottom:4px;font-size:14px;font-weight:700}.role-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px}.role-info-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.admin-info .role-info-header{color:#3b82f6}.super-info .role-info-header{color:#7c3aed}.role-info-header strong{color:#0f172a;flex:1;font-size:16px}.role-badge-sm{text-transform:uppercase;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.role-badge-sm.admin{color:#166534;background:#dcfce7}.role-badge-sm.superuser{color:#5b21b6;background:#ede9fe}.role-info-card ul{flex-direction:column;gap:8px;list-style:none;display:flex}.role-info-card li{color:#475569;font-size:13px}.ca-tip{background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1px solid #bfdbfe;border-radius:14px;padding:20px}.ca-tip strong{color:#1e40af;margin-bottom:8px;font-size:14px;display:block}.ca-tip p{color:#475569;font-size:13px;line-height:1.6}.app-layout{background:#f1f5f9;width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{z-index:100;background:#0f172a;flex-direction:column;flex-shrink:0;width:260px;transition:transform .25s;display:flex}.sidebar-brand{color:#f8fafc;letter-spacing:.3px;border-bottom:1px solid #ffffff12;align-items:center;gap:12px;padding:20px 22px;font-size:17px;font-weight:800;display:flex}.brand-shield{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 4px 10px #3b82f666}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.nav-item{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 14px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:#f1f5f9;background:#ffffff0f}.nav-item.active{color:#60a5fa;background:#3b82f626}.sidebar-footer{border-top:1px solid #ffffff12;align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.sidebar-user{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar-email{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.sidebar-role{text-transform:capitalize;margin-top:2px;font-size:11px;font-weight:700}.sidebar-role.admin{color:#60a5fa}.sidebar-role.superuser{color:#a78bfa}.logout-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;align-items:center;padding:6px;transition:all .15s;display:flex}.logout-btn:hover{color:#ef4444;background:#ef44441a}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.mobile-topbar{color:#fff;background:#0f172a;align-items:center;gap:12px;padding:14px 20px;font-weight:700;display:none}.hamburger{color:#fff;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex}.mobile-title{font-size:16px}.page-content{flex:1;overflow-y:auto}.full-center{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;font-size:14px;display:flex}.app-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@media (width<=768px){.sidebar{position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.overlay{z-index:99;background:#00000080;position:fixed;inset:0}.mobile-topbar{display:flex}}
