:root{--bg-app: #f8fafc;--bg-card: #ffffff;--bg-sidebar: #0f172a;--bg-sidebar-hover: rgba(255, 255, 255, .06);--bg-sidebar-active: rgba(99, 102, 241, .18);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-sidebar: #cbd5e1;--text-sidebar-muted: #94a3b8;--border: #e2e8f0;--border-strong: #cbd5e1;--border-focus: #6366f1;--accent: #4f46e5;--accent-hover: #4338ca;--accent-soft: #eef2ff;--accent-soft-text: #4338ca;--danger: #dc2626;--danger-hover: #b91c1c;--danger-soft: #fef2f2;--danger-soft-text: #991b1b;--success: #10b981;--success-soft: #d1fae5;--success-soft-text: #065f46;--warning-soft: #fef3c7;--warning-soft-text: #92400e;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 1px 3px rgba(15, 23, 42, .07), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .07), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .12), 0 4px 8px rgba(15, 23, 42, .05);--radius-sm: 6px;--radius: 8px;--radius-md: 12px;--radius-lg: 16px;--t: .15s ease}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--bg-app);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0;line-height:1.25}h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.25rem;font-weight:700;letter-spacing:-.015em}h3{font-size:1.0625rem;font-weight:600}p{margin:0}code{background:#f1f5f9;padding:.125rem .375rem;border-radius:4px;font-size:.8125rem;font-family:JetBrains Mono,Consolas,Monaco,monospace}.landing-shell{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at 20% 0%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(circle at 100% 100%,rgba(16,185,129,.06) 0%,transparent 50%),var(--bg-app)}.landing-hero{padding:4rem 2rem 2rem;text-align:center;max-width:720px;margin:0 auto}.landing-hero .brand-mark{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--accent) 0%,#818cf8 100%);color:#fff;margin-bottom:1.5rem;box-shadow:var(--shadow-md)}.landing-hero h1{font-size:2.25rem;letter-spacing:-.03em;margin-bottom:.5rem}.landing-hero .subtitle{color:var(--text-muted);font-size:1.0625rem;max-width:540px;margin:0 auto}.landing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:1.5rem;max-width:1280px;width:100%;margin:2rem auto;padding:0 2rem 4rem}.dashboard-shell{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.sidebar{background:var(--bg-sidebar);color:var(--text-sidebar);display:flex;flex-direction:column;padding:1.25rem .75rem;position:sticky;top:0;height:100vh;border-right:1px solid rgba(255,255,255,.06)}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:.25rem .5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-brand-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--accent) 0%,#818cf8 100%);color:#fff;flex-shrink:0}.sidebar-brand-title{color:#fff;font-weight:700;font-size:.9375rem;letter-spacing:-.01em}.sidebar-brand-sub{color:var(--text-sidebar-muted);font-size:.75rem}.sidebar-section{padding:1rem .5rem .5rem}.sidebar-section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-sidebar-muted);margin-bottom:.5rem}.sidebar-client{display:flex;align-items:center;gap:.5rem;background:#ffffff0d;padding:.5rem .75rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.04)}.sidebar-client-name{color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dot{display:inline-block;width:7px;height:7px;border-radius:999px;flex-shrink:0}.dot-success{background:var(--success);box-shadow:0 0 0 3px #10b98140}.sidebar-nav{margin-top:1rem;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;background:none;border:none;color:var(--text-sidebar);border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-size:.9375rem;font-weight:500;font-family:inherit;transition:var(--t)}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:#fff}.sidebar-link.active{background:var(--bg-sidebar-active);color:#fff;box-shadow:inset 3px 0 0 var(--accent)}.sidebar-link-danger{color:#fca5a5}.sidebar-link-danger:hover{background:#ef44441f;color:#fca5a5}.sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.25rem}.sidebar-danger-zone{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed rgba(239,68,68,.22)}.sidebar-danger-label{color:#fca5a5!important;letter-spacing:.08em}.dashboard-main{padding:2rem 2.5rem 4rem;min-width:0}.panel-title{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.panel-title-text h1{display:flex;align-items:center;gap:.625rem}.panel-title-text .panel-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent);flex-shrink:0}.panel-title-text p{color:var(--text-muted);margin-top:.25rem;font-size:.9375rem}.card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:var(--t)}.card-padded{padding:1.5rem}.card-elevated{box-shadow:var(--shadow)}.card h2+.subtitle{margin-top:.25rem}.subtitle{color:var(--text-muted);font-size:.9375rem}.form-row{display:flex;flex-direction:column;gap:.375rem;margin-bottom:.875rem}.form-row label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.text-link{background:none;border:0;padding:0;font-size:.8125rem;color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.text-link:hover{color:var(--accent-hover)}.form-row input,.form-row select,.form-row textarea{padding:.5625rem .75rem;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:.9375rem;font-family:inherit;background:#fff;color:var(--text-primary);transition:var(--t)}.form-row input::placeholder{color:#94a3b8}.form-row input:hover,.form-row select:hover,.form-row textarea:hover{border-color:#94a3b8}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f126}.form-actions{display:flex;gap:.5rem;margin-top:.875rem}.input-with-icon{position:relative}.input-with-icon input{width:100%;padding-left:2.25rem}.input-with-icon .input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4375rem;padding:.5rem .875rem;border-radius:var(--radius);border:1px solid transparent;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--t);white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:#fff;color:var(--text-primary);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:#f1f5f9;color:var(--text-primary)}.btn-icon-only{padding:.5rem}.btn-sm{padding:.375rem .625rem;font-size:.8125rem}table.data{width:100%;background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);border-collapse:separate;border-spacing:0;box-shadow:var(--shadow-sm)}table.data th,table.data td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}table.data th{background:#f8fafc;font-weight:600;color:var(--text-secondary);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em}table.data tbody tr{transition:var(--t)}table.data tbody tr:hover{background:#f8fafc}table.data tbody tr:last-child td{border-bottom:none}table.data .actions{display:flex;gap:.375rem;justify-content:flex-end}.cell-strong{font-weight:600;color:var(--text-primary)}.cell-mono{font-family:JetBrains Mono,Consolas,monospace;font-size:.8125rem}.pill{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:999px;font-size:.75rem;font-weight:500;margin-right:.25rem;margin-bottom:.125rem;background:var(--accent-soft);color:var(--accent-soft-text);white-space:nowrap}.pill-success{background:var(--success-soft);color:var(--success-soft-text)}.pill-danger{background:var(--danger-soft);color:var(--danger-soft-text)}.pill-muted{background:#f1f5f9;color:var(--text-muted)}.toolbar{display:flex;gap:.75rem;margin-bottom:1rem;align-items:center}.toolbar .input-with-icon{flex:1;max-width:320px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fade-in .15s ease}.modal{background:#fff;border-radius:var(--radius-md);padding:0;width:560px;max-width:92vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:pop-in .18s ease-out}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0}.modal-header-danger{background:var(--danger-soft);border-bottom-color:#fecaca;color:var(--danger-soft-text)}.modal-header-danger h3{color:var(--danger-soft-text);display:flex;align-items:center;gap:.5rem}.modal-header-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:#fff;color:var(--danger)}.warning-banner{display:flex;gap:.75rem;padding:.875rem 1rem;background:var(--danger-soft);color:var(--danger-soft-text);border:1px solid #fecaca;border-radius:var(--radius);font-size:.875rem;line-height:1.5}.warning-banner-icon{flex-shrink:0;color:var(--danger);margin-top:1px}.warning-banner ul li{margin-bottom:.125rem}.modal-body{padding:1.25rem 1.5rem;overflow-y:auto}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem;background:#f8fafc}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.role-checkboxes{list-style:none;padding:.375rem;margin:.25rem 0 .875rem;display:flex;flex-direction:column;gap:.125rem;max-height:240px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);background:#f8fafc}.role-checkboxes li{padding:0;border-radius:var(--radius-sm)}.role-checkboxes label{display:flex;align-items:center;gap:.625rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem .625rem;border-radius:var(--radius-sm);font-size:.9375rem;transition:var(--t)}.role-checkboxes label:hover{background:#fff}.role-checkboxes input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.role-checkboxes label .pending{margin-left:auto;font-size:.75rem;color:var(--text-muted)}.empty-state{background:var(--bg-card);border-radius:var(--radius-md);border:1px dashed var(--border-strong);padding:3.5rem 2rem;text-align:center;color:var(--text-muted)}.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:var(--accent-soft);color:var(--accent);margin-bottom:.75rem}.empty-state h3{color:var(--text-primary);margin-bottom:.25rem}.empty-state p{color:var(--text-muted);max-width:400px;margin:0 auto}.skeleton{background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-row{height:48px;margin-bottom:.5rem}.skeleton-stack{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}.alert{padding:.625rem .875rem;border-radius:var(--radius);margin:.5rem 0;font-size:.875rem;display:flex;align-items:flex-start;gap:.5rem}.alert-error{background:var(--danger-soft);color:var(--danger-soft-text);border:1px solid #fecaca}.alert-success{background:var(--success-soft);color:var(--success-soft-text);border:1px solid #a7f3d0}.alert-warning{background:var(--warning-soft);color:var(--warning-soft-text);border:1px solid #fde68a}.muted{color:var(--text-muted);font-size:.875rem}.toaster{position:fixed;top:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:200;pointer-events:none}.toast{display:flex;align-items:center;gap:.625rem;background:#fff;border-radius:var(--radius);padding:.625rem .75rem .625rem .625rem;min-width:280px;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border);pointer-events:auto;animation:toast-slide-in .2s ease-out}@keyframes toast-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0;width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center}.toast-success .toast-icon{background:var(--success-soft);color:var(--success-soft-text)}.toast-error .toast-icon{background:var(--danger-soft);color:var(--danger-soft-text)}.toast-info .toast-icon{background:var(--accent-soft);color:var(--accent-soft-text)}.toast-msg{flex:1;font-size:.875rem;color:var(--text-primary)}.toast-close{background:none;border:none;padding:.25rem;color:var(--text-muted);border-radius:var(--radius-sm);display:inline-flex;cursor:pointer}.toast-close:hover{background:#f1f5f9;color:var(--text-primary)}.user-detail{display:flex;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);align-items:center}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--accent) 0%,#818cf8 100%);color:#fff;font-weight:700;font-size:1.125rem;text-transform:uppercase;flex-shrink:0}.user-info-text h3{margin:0}.user-info-text p{color:var(--text-muted);font-size:.875rem;margin-top:.25rem}.user-roles-section{padding:1.25rem 1.5rem}.user-roles-section h4{margin:0 0 .5rem;font-size:.9375rem}.user-roles-hint{color:var(--text-muted);font-size:.8125rem;margin-bottom:.75rem}
