@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0f0f1a;--bg-secondary:#161625;--bg-card:#ffffff0a;--bg-card-hover:#ffffff12;--bg-glass:#ffffff0f;--border-subtle:#ffffff14;--border-focus:#6366f180;--text-primary:#f1f1f4;--text-secondary:#a1a1b5;--text-muted:#6b6b80;--accent:#6366f1;--accent-light:#818cf8;--accent-glow:#6366f14d;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--sidebar-width:260px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}a{color:var(--accent-light);text-decoration:none}a:hover{color:var(--accent)}.loading-screen{min-height:300px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.loading-spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.loading-spinner.small{border-width:2px;width:20px;height:20px}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:radial-gradient(ellipse at 20% 50%, #6366f114 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #8b5cf60f 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);text-align:center;z-index:1;width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px 40px;animation:.6s ease-out fadeInUp;position:relative}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:32px}.login-logo{justify-content:center;margin-bottom:20px;display:flex}.login-header h1{letter-spacing:-.02em;margin-bottom:4px;font-size:1.75rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.9rem}.login-error{border-radius:var(--radius-md);color:#fca5a5;text-align:left;background:#ef44441a;border:1px solid #ef444433;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:.85rem;display:flex}.login-button{background:linear-gradient(135deg, var(--accent), #8b5cf6);color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition);box-shadow:0 4px 16px var(--accent-glow);border:none;justify-content:center;align-items:center;gap:12px;padding:14px 24px;font-size:.95rem;font-weight:600;display:inline-flex}.login-button:hover:not(:disabled){box-shadow:0 6px 24px var(--accent-glow);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{color:var(--text-muted);margin-top:24px;font-size:.8rem}.login-bg-decoration{pointer-events:none;position:fixed;inset:0}.login-bg-circle{opacity:.5;border-radius:50%;position:absolute}.circle-1{background:radial-gradient(circle,#6366f11f,#0000 70%);width:400px;height:400px;animation:8s ease-in-out infinite float;top:-100px;right:-100px}.circle-2{background:radial-gradient(circle,#8b5cf61a,#0000 70%);width:300px;height:300px;animation:10s ease-in-out infinite reverse float;bottom:-50px;left:-50px}.circle-3{background:radial-gradient(circle,#ec489914,#0000 70%);width:200px;height:200px;animation:12s ease-in-out infinite float;top:40%;left:60%}@keyframes float{0%,to{transform:translate(0)}33%{transform:translate(15px,-20px)}66%{transform:translate(-10px,15px)}}.dashboard-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:10;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border-subtle);padding:20px}.sidebar-logo{color:var(--text-primary);align-items:center;gap:12px;font-size:1rem;font-weight:700;display:flex}.sidebar-logo svg{flex-shrink:0}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;padding:0 12px;font-size:.7rem;font-weight:600;display:block}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:10px;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex}.nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent-light)}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:16px}.user-info-compact{align-items:center;gap:10px;margin-bottom:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), #8b5cf6);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.user-avatar.small{width:28px;height:28px;font-size:.7rem}.user-details{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.logout-button{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;align-items:center;gap:8px;padding:8px 12px;font-size:.8rem;display:flex}.logout-button:hover{color:#fca5a5;background:#ef44441a;border-color:#ef44444d}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:32px}.main-content.centered{justify-content:center;align-items:center;display:flex}.content-header{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.content-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.header-subtitle{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition);overflow:hidden}.card:hover{background:var(--bg-card-hover);border-color:#ffffff1f}.card-header{padding:20px 24px 0}.card-header h2{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:.85rem;font-weight:600}.card-body{padding:20px 24px 24px}.profile-avatar-large{background:linear-gradient(135deg, var(--accent), #8b5cf6);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;font-size:1.5rem;font-weight:700;display:flex}.profile-name{margin-bottom:4px;font-size:1.1rem;font-weight:600}.profile-email{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem}.profile-dept,.profile-position{color:var(--text-muted);font-size:.8rem}.role-tags{flex-wrap:wrap;gap:8px;display:flex}.role-tags.compact{gap:4px}.role-tag{background:color-mix(in srgb, var(--role-color,#6b7280) 15%, transparent);color:color-mix(in srgb, var(--role-color,#6b7280) 80%, white);border:1px solid color-mix(in srgb, var(--role-color,#6b7280) 25%, transparent);border-radius:20px;align-items:center;padding:6px 12px;font-size:.78rem;font-weight:500;display:inline-flex}.role-tag.small{padding:3px 8px;font-size:.7rem}.stat-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.stat-row:last-child{border-bottom:none}.stat-label{color:var(--text-secondary);font-size:.85rem}.stat-value{font-size:.85rem;font-weight:500}.status-badge{border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:600}.status-badge.active{color:#34d399;background:#10b98126}.status-badge.inactive{color:#fca5a5;background:#ef444426}.admin-page{margin-left:var(--sidebar-width);min-height:100vh;padding:32px}.alert{border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px 16px;font-size:.85rem;display:flex}.alert-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444433}.alert button{color:inherit;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.2rem}.table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);white-space:nowrap;padding:14px 16px;font-size:.75rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:14px 16px;font-size:.85rem}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr:last-child td{border-bottom:none}.row-inactive{opacity:.5}.user-cell{align-items:center;gap:10px;display:flex}.text-muted{color:var(--text-muted)}.role-editor{flex-direction:column;gap:6px;min-width:160px;display:flex}.role-checkbox{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:.8rem;display:flex}.role-checkbox input[type=checkbox]{accent-color:var(--accent)}.role-editor-actions{gap:6px;margin-top:6px;display:flex}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.role-card{position:relative;overflow:hidden}.role-card:before{content:"";background:var(--role-color,var(--accent));height:3px;position:absolute;top:0;left:0;right:0}.role-card-header{align-items:center;gap:12px;padding:20px 20px 0;display:flex}.role-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.role-card-header h3{font-size:.95rem;font-weight:600}.role-name-slug{color:var(--text-muted);font-family:monospace;font-size:.75rem}.role-description{color:var(--text-secondary);padding:12px 20px;font-size:.83rem;line-height:1.5}.role-card-footer{border-top:1px solid var(--border-subtle);padding:12px 20px 16px}.users-count{color:var(--text-muted);font-size:.78rem}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:500;display:inline-flex}.btn-sm{padding:5px 10px;font-size:.78rem}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-light)}.btn-ghost{color:var(--text-secondary);border-color:var(--border-subtle);background:0 0}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-danger{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.btn-danger:hover{background:#ef444440}.btn-success{color:#34d399;background:#10b98126;border-color:#10b9814d}.btn-success:hover{background:#10b98140}.action-buttons{gap:6px;display:flex}@media (width<=768px){.sidebar{display:none}.main-content,.admin-page{margin-left:0;padding:20px}.dashboard-grid{grid-template-columns:1fr}.content-header{flex-direction:column;gap:12px}}
