*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f4f5f7;color:#111827;font-family:DM Sans,system-ui,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}.app-shell,.sidebar{display:flex;min-height:100vh}.sidebar{background:#1a1744;bottom:0;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:224px;z-index:200}.sidebar-brand{align-items:center;border-bottom:1px solid #ffffff12;display:flex;flex-shrink:0;gap:.65rem;padding:1.35rem 1.25rem 1.1rem;text-decoration:none}.sidebar-brand svg{color:#818cf8;flex-shrink:0}.sidebar-brand-name{color:#fff;font-size:1rem;font-weight:700;letter-spacing:.06em}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:.1rem;padding:.85rem .75rem}.sidebar-nav .nav-item{align-items:center;border-radius:8px;color:#a5b4fc;display:flex;font-size:.875rem;font-weight:500;gap:.65rem;padding:.62rem .9rem;text-decoration:none;transition:background .15s,color .15s}.sidebar-nav .nav-item:hover{background:#4f46e52e;color:#e0e7ff}.sidebar-nav .nav-item.active{background:#4f46e5;color:#fff}.sidebar-nav .nav-item svg{flex-shrink:0;opacity:.75}.sidebar-nav .nav-item.active svg,.sidebar-nav .nav-item:hover svg{opacity:1}.nav-divider{background:#ffffff12;height:1px;margin:.6rem .15rem}.nav-section-label{color:#6366f1;font-size:.67rem;font-weight:700;letter-spacing:.1em;padding:.2rem .9rem .4rem;text-transform:uppercase}.sidebar-footer{border-top:1px solid #ffffff12;gap:.6rem;padding:.85rem .75rem}.sidebar-avatar,.sidebar-footer{align-items:center;display:flex;flex-shrink:0}.sidebar-avatar{background:#4338ca;border-radius:50%;color:#e0e7ff;font-size:.8rem;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-name{color:#e0e7ff;font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#818cf8;font-size:.68rem;margin-top:.05rem}.sidebar-logout-btn{align-items:center;background:none;border:none;border-radius:6px;color:#818cf8;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.35rem;transition:background .15s,color .15s}.sidebar-logout-btn:hover{background:#ffffff1a;color:#fff}.main-area{background:#f4f5f7;flex:1 1;margin-left:224px;min-height:100vh}.content{margin:0 auto;max-width:1100px;padding:2.5rem 1.5rem}.loading{align-items:center;color:#6b7280;display:flex;font-size:.95rem;height:100vh;justify-content:center}.loading-inline{color:#6b7280;padding:2rem 0}.login-logo svg{filter:drop-shadow(0 2px 8px rgba(79,70,229,.25))}.brand-name{color:#111827;font-size:1.05rem;font-weight:700;letter-spacing:.03em}.brand-tagline{color:#9ca3af;font-size:.7rem;font-weight:400;letter-spacing:.01em}.btn-primary{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-size:.9rem;font-weight:500;padding:.6rem 1.25rem}.btn-primary:hover{background:#4338ca}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-primary.full-width{font-size:.95rem;padding:.75rem;text-align:center;width:100%}.btn-secondary{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:.9rem;font-weight:500;padding:.6rem 1.25rem}.btn-secondary:hover{background:#f9fafb}.btn-edit{background:#eff6ff;border:none;border-radius:6px;color:#2563eb;cursor:pointer;font-size:.8rem;margin-right:.4rem;padding:.3rem .7rem}.btn-edit:hover{background:#dbeafe}.btn-delete{background:#fff1f2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;font-size:.8rem;padding:.3rem .7rem}.btn-delete:hover{background:#fee2e2}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:18px;box-shadow:0 24px 64px #0000002e;max-width:420px;padding:2.5rem;width:100%}.login-logo{align-items:center;display:flex;flex-direction:column;gap:.25rem;margin-bottom:2rem;text-align:center}.login-logo h1{font-size:1.7rem;font-weight:800;letter-spacing:.04em;margin:.3rem 0 0}.login-logo .brand-tagline{color:#9ca3af;font-size:.75rem;margin-bottom:.5rem}.login-logo p:not(.brand-tagline){color:#6b7280;font-size:.9rem}.login-form{gap:1.25rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.35rem}.form-group label{color:#374151;font-size:.82rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;font-size:.9rem;outline:none;padding:.65rem .9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.form-group-checks{gap:.75rem;justify-content:center}.check-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.88rem;font-weight:400;gap:.5rem;letter-spacing:0;text-transform:none}.check-label input[type=checkbox]{accent-color:#4f46e5;height:16px;width:16px}.error-msg{background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;color:#dc2626;font-size:.85rem;padding:.75rem 1rem}.field-error{color:#dc2626;font-size:.78rem;margin-top:.2rem}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.75rem}.page-header h2{font-size:1.4rem;font-weight:700}.page-subtitle{color:#6b7280;font-size:.85rem;margin-top:.2rem}.breadcrumb{color:#4f46e5}.breadcrumb:hover{text-decoration:underline}.launcher-header{margin-bottom:2rem}.launcher-header h2{font-size:1.6rem;font-weight:700}.launcher-header p{color:#6b7280;margin-top:.3rem}.app-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}.app-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 8px #0000000d;cursor:pointer;display:flex;flex-direction:column;gap:1rem;padding:1.75rem 1.25rem;transition:transform .15s,box-shadow .15s}.app-card:hover{box-shadow:0 10px 28px #0000001a;transform:translateY(-4px)}.app-card-icon{align-items:center;border-radius:16px;color:#fff;display:flex;font-size:1.6rem;font-weight:700;height:62px;justify-content:center;width:62px}.app-card-info{text-align:center}.app-card-info h3{font-size:.95rem;font-weight:600}.role-badge{border-radius:20px;display:inline-block;font-size:.72rem;font-weight:600;margin-top:.4rem;padding:.2rem .65rem;text-transform:capitalize}.role-badge.role-allow{background:#d1fae5;color:#065f46}.role-badge.role-viewer{background:#eff6ff;color:#1d4ed8}.role-badge.role-superadmin{background:#ede9fe;color:#6d28d9}.status-badge{border-radius:20px;display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .65rem}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#f3f4f6;color:#9ca3af}.table-wrapper{overflow-x:auto}.data-table{background:#fff;border-collapse:collapse;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;width:100%}.data-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.8rem 1.25rem;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #f3f4f6;font-size:.9rem;padding:1rem 1.25rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafafa}.td-name{font-weight:500}.td-muted{color:#6b7280}.user-form{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000d;padding:2rem}.form-section{margin-bottom:2.25rem}.form-section h3{border-bottom:1px solid #e5e7eb;color:#374151;font-size:.95rem;font-weight:700;margin-bottom:1.25rem;padding-bottom:.6rem}.section-hint{color:#6b7280;font-size:.85rem;margin-bottom:1rem;margin-top:-.75rem}.form-row{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr 1fr;margin-bottom:1.25rem}.app-access-grid{display:flex;flex-direction:column;gap:.65rem}.app-access-row{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1.25rem}.app-access-name{align-items:center;display:flex;flex:1 1;font-size:.9rem;font-weight:500;gap:.6rem}.app-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.app-url{color:#9ca3af;font-size:.78rem;font-weight:400;margin-left:.25rem}.role-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;font-size:.85rem;min-width:148px;outline:none;padding:.45rem .75rem}.role-select:focus{border-color:#4f46e5;outline:none}.role-select.role-allow-select{background:#f0fdf4;border-color:#10b981;color:#065f46;font-weight:600}.role-select.role-deny-select{border-color:#e5e7eb;color:#9ca3af}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1.25rem}.empty-state{color:#6b7280;padding:4rem 2rem;text-align:center}.empty-state p{font-size:.95rem;margin-bottom:.4rem}@media (max-width:768px){.sidebar{width:200px}.main-area{margin-left:200px}}@media (max-width:640px){.sidebar{display:none}.main-area{margin-left:0}.form-row{grid-template-columns:1fr}.app-access-row{align-items:flex-start;flex-direction:column}.role-select{width:100%}.page-header{flex-direction:column;gap:1rem}.content{padding:1.5rem 1rem}}
/*# sourceMappingURL=main.d203595f.css.map*/