@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-black: #0a0a0f;--color-charcoal: #111827;--color-dark: #1f2937;--color-mid: #4b5563;--color-gray: #6b7280;--color-light-gray: #9ca3af;--color-silver: #d1d5db;--color-off-white: #f3f4f6;--color-white: #ffffff;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--color-accent-deep: #3730a3;--color-accent-light: #e0e7ff;--color-accent-subtle: #eef2ff;--color-accent-muted: #a5b4fc;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-text: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-text: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-text: #991b1b;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-info-text: #1e40af;--color-primary: var(--color-accent);--color-primary-hover: var(--color-accent-hover);--color-surface: var(--color-white);--color-surface-alt: #f8f9fc;--color-surface-raised: var(--color-white);--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-text: #111827;--color-text-secondary: #4b5563;--color-text-muted: #9ca3af;--color-sidebar-bg: #1e1b4b;--color-sidebar-text: rgba(255,255,255,.85);--color-sidebar-hover: rgba(255,255,255,.08);--color-sidebar-active: rgba(99, 102, 241, .25);--color-sidebar-accent: #818cf8;--gradient-sidebar: linear-gradient(160deg, #1e1b4b 0%, #312e81 100%);--gradient-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-accent-hover: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--gradient-card-top: linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-login-bg: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #4c1d95 100%);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold:800;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 2px 8px rgba(0,0,0,.06);--shadow-card: 0 2px 8px rgba(99,102,241,.08), 0 1px 3px rgba(0,0,0,.06);--shadow-modal: 0 24px 64px rgba(0,0,0,.18), 0 8px 24px rgba(0,0,0,.1);--shadow-accent: 0 4px 16px rgba(99,102,241,.35);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 240px;--sidebar-width-collapsed: 64px;--header-height: 60px}:root[data-theme=light]{--color-surface: #ffffff;--color-surface-alt: #f8f9fc;--color-text: #111827;--color-text-secondary: #4b5563;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-sidebar-bg: #ffffff;--color-sidebar-text: #334155;--color-sidebar-hover: #f1f5f9;--color-sidebar-active: #e2e8f0;--color-sidebar-accent: #2563eb;--gradient-sidebar: linear-gradient(180deg, #ffffff 0%, #ffffff 100%);--gradient-login-bg: linear-gradient(135deg, #f8fafc 0%, #eef2ff 50%, #ffffff 100%)}:root[data-theme=dark]{--color-black: #000000;--color-charcoal: #0a0a0a;--color-dark: #141414;--color-mid: #525252;--color-gray: #737373;--color-light-gray: #a3a3a3;--color-silver: #d4d4d4;--color-off-white: #1a1a1a;--color-white: #ffffff;--color-accent: #a3a3a3;--color-accent-hover: #d4d4d4;--color-accent-deep: #f5f5f5;--color-accent-light: #222222;--color-accent-subtle: #1a1a1a;--color-accent-muted: #bfbfbf;--color-surface: #101010;--color-surface-alt: #050505;--color-surface-raised: #171717;--color-border: #262626;--color-border-strong: #404040;--color-text: #fafafa;--color-text-secondary: #d4d4d4;--color-text-muted: #a3a3a3;--color-sidebar-bg: #000000;--color-sidebar-text: rgba(255, 255, 255, .9);--color-sidebar-hover: rgba(255, 255, 255, .08);--color-sidebar-active: rgba(255, 255, 255, .14);--color-sidebar-accent: #ffffff;--gradient-sidebar: linear-gradient(180deg, #000000 0%, #111111 100%);--gradient-accent: linear-gradient(135deg, #525252 0%, #737373 100%);--gradient-accent-hover: linear-gradient(135deg, #737373 0%, #a3a3a3 100%);--gradient-card-top: linear-gradient(135deg, #404040, #737373);--gradient-login-bg: linear-gradient(135deg, #000000 0%, #0a0a0a 45%, #171717 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .55), 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .65), 0 1px 3px rgba(0, 0, 0, .45);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .72), 0 2px 8px rgba(0, 0, 0, .5);--shadow-card: 0 2px 10px rgba(0, 0, 0, .58), 0 1px 3px rgba(0, 0, 0, .4);--shadow-modal: 0 24px 64px rgba(0, 0, 0, .45), 0 8px 24px rgba(0, 0, 0, .3);--shadow-accent: 0 4px 16px rgba(255, 255, 255, .18)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}html[data-theme=dark]{color-scheme:dark}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background-color:var(--color-surface-alt)}#root{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-silver);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-light-gray)}.toast-region{position:fixed;top:calc(var(--header-height) + var(--space-md));right:var(--space-lg);z-index:2000;display:flex;width:min(420px,calc(100vw - 32px));flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--color-border);border-left:4px solid var(--toast-accent);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);color:var(--color-text);pointer-events:auto;animation:toast-enter .2s ease-out}.toast-success{--toast-accent: var(--color-success)}.toast-error{--toast-accent: var(--color-danger)}.toast-info{--toast-accent: var(--color-info)}.toast-icon{display:inline-flex;color:var(--toast-accent);padding-top:1px}.toast-copy{display:flex;min-width:0;flex-direction:column;gap:2px}.toast-copy strong{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.toast-copy span{color:var(--color-text-secondary);font-size:var(--font-size-xs);line-height:1.45}.toast button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);cursor:pointer}.toast button:hover{background:var(--color-surface-alt);color:var(--color-text)}@keyframes toast-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.toast-region{top:var(--space-md);right:var(--space-md);left:var(--space-md);width:auto}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-semibold);font-family:inherit;letter-spacing:.01em;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:#fff0;transition:background var(--transition-fast)}.btn:hover:not(:disabled):after{background:#ffffff14}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.48;cursor:not-allowed}.btn-primary{background:var(--gradient-accent);color:var(--color-white);box-shadow:0 2px 8px #6366f147}.btn-primary:hover:not(:disabled){background:var(--gradient-accent-hover);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-strong)}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle);box-shadow:none}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--color-white);box-shadow:0 2px 8px #ef444447}.btn-danger:hover:not(:disabled){box-shadow:0 4px 14px #ef444466;transform:translateY(-1px)}.btn-icon-danger{color:#ef4444}.btn-icon-danger:hover:not(:disabled){background:#ef44441a!important;color:#dc2626!important}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:none;box-shadow:none}.btn-ghost:hover:not(:disabled){background:var(--color-accent-subtle);color:var(--color-accent)}.btn-fab{position:fixed;bottom:2.1rem;right:2.5rem;width:56px;height:56px;border-radius:50%;padding:0;background:var(--gradient-accent);color:var(--color-white);box-shadow:0 4px 20px #00000040;z-index:100}.btn-fab:hover:not(:disabled){transform:translateY(-4px) scale(1.05);box-shadow:0 4px 20px #00000040}.btn-fab .btn-icon svg{width:28px;height:28px}.btn-icon-only{padding:8px!important;border-radius:50%;aspect-ratio:1}.btn-icon{display:inline-flex;align-items:center;justify-content:center}.btn-icon-only.btn-sm{padding:6px!important}.btn-icon-only.btn-lg{padding:12px!important}.btn-sm{padding:6px var(--space-md);font-size:var(--font-size-sm)}.btn-md{padding:10px var(--space-lg);font-size:var(--font-size-base)}.btn-lg{padding:13px var(--space-xl);font-size:var(--font-size-lg)}@media(max-width:768px){.btn-fab{bottom:1.75rem;right:1rem}}.layout{display:flex;min-height:100vh;width:100%;position:relative}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--gradient-sidebar);background-color:var(--color-sidebar-bg);color:var(--color-sidebar-text);padding:0;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:width var(--transition-base),min-width var(--transition-base);z-index:20}.sidebar-brand{display:flex;justify-content:space-between;align-items:center;height:var(--header-height);padding:0 var(--space-md);border-bottom:1px solid var(--color-border);gap:var(--space-sm)}.sidebar-brand-main{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);flex-shrink:0;overflow:hidden}.logo-img-icon{width:100%;height:100%;object-fit:contain}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-extrabold);color:var(--color-text);letter-spacing:.04em;line-height:1}.sidebar-brand-tagline{font-size:10px;color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase;margin-top:2px}.sidebar-toggle-btn{width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.sidebar-toggle-btn:hover{background:var(--color-accent-subtle);color:var(--color-accent);border-color:var(--color-accent-muted)}.mobile-sidebar-close,.mobile-menu-btn{display:none}.sidebar-brand-link{text-decoration:none;color:inherit;display:block;flex:1;transition:opacity .2s ease}.sidebar-brand-link:hover{background:none!important}.sidebar-brand-link .sidebar-brand-main{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.sidebar ul{list-style:none;padding:var(--space-md) var(--space-sm);margin:0;flex:1}.sidebar li{margin:2px 0}.sidebar a{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--color-sidebar-text);text-decoration:none;transition:all var(--transition-fast);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.sidebar a:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.sidebar a.active{background:var(--color-sidebar-active);color:var(--color-text);font-weight:var(--font-weight-semibold)}.sidebar a.active .nav-icon{color:var(--color-sidebar-accent)}.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.75}.sidebar a:hover .nav-icon,.sidebar a.active .nav-icon{opacity:1}.layout.sidebar-collapsed .sidebar{width:var(--sidebar-width-collapsed);min-width:var(--sidebar-width-collapsed)}.layout.sidebar-collapsed .sidebar-brand-text,.layout.sidebar-collapsed .nav-label{display:none}.layout.sidebar-collapsed .sidebar ul{padding:var(--space-md) var(--space-xs)}.layout.sidebar-collapsed .sidebar a{justify-content:center;padding:10px}.main{flex:1;display:flex;flex-direction:column;background:var(--color-surface-alt);min-width:0}.header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:0 var(--space-xl);height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center}.header-user{display:flex;align-items:center;gap:var(--space-sm)}.user-avatar{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-full);background:var(--gradient-accent);color:var(--color-white);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0;box-shadow:0 2px 8px #6366f14d}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.user-role{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:capitalize}.content{flex:1;padding:var(--space-xl);display:flex;flex-direction:column;min-width:0;width:100%}.sidebar-backdrop{position:fixed;inset:0;border:none;padding:0;background:#02081773;z-index:90}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(82vw,300px);min-width:min(82vw,300px);transform:translate(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-lg);z-index:100}.layout.mobile-menu-open .sidebar{transform:translate(0)}.sidebar ul{display:block;overflow:auto;padding:var(--space-md)}.layout.sidebar-collapsed .sidebar{width:min(82vw,300px);min-width:min(82vw,300px)}.layout.sidebar-collapsed .sidebar-brand-text,.layout.sidebar-collapsed .nav-label{display:block}.layout.sidebar-collapsed .sidebar a{justify-content:flex-start;padding:10px var(--space-md)}.desktop-sidebar-toggle{display:none}.mobile-sidebar-close,.mobile-menu-btn{display:inline-flex}.content{padding:var(--space-md)}.header{padding:0 var(--space-md)}.user-info{display:none}}.footer{padding:var(--space-md) var(--space-xl);background:var(--color-surface);border-top:1px solid var(--color-border);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-xs);flex-shrink:0}.footer p{margin:0;opacity:.8}.input-group{margin-bottom:var(--space-md);min-width:0}.input-label{display:block;margin-bottom:6px;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-secondary);letter-spacing:.01em}.input{width:100%;min-width:0;padding:9px var(--space-md);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--color-text-muted)}.input:hover:not(:disabled):not(:focus){border-color:var(--color-accent-muted)}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126}.input:disabled{background:var(--color-off-white);color:var(--color-text-muted);cursor:not-allowed}.input-error{border-color:var(--color-danger)}.input-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef444426}.input-error-text{display:block;margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-danger);font-weight:var(--font-weight-medium)}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%236366f1' d='M7 9.5L2.5 5h9z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:2.25rem;cursor:pointer}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--gradient-login-bg);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:var(--radius-full);filter:blur(80px);opacity:.35;pointer-events:none}.login-page:before{width:400px;height:400px;background:radial-gradient(circle,#818cf8,transparent 70%);top:-80px;right:-80px}.login-page:after{width:300px;height:300px;background:radial-gradient(circle,#a78bfa,transparent 70%);bottom:-60px;left:-60px}.login-card{background:var(--color-surface);padding:var(--space-2xl) var(--space-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);width:100%;max-width:420px;position:relative;z-index:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);animation:card-rise .5s cubic-bezier(.34,1.22,.64,1) both}@keyframes card-rise{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{display:flex;align-items:center;justify-content:center;margin:0 0 var(--space-lg)}.logo-img-full{max-width:280px;height:auto;display:block}.login-card h1{margin:0 0 var(--space-xs);font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--color-text);letter-spacing:-.03em}.login-card>p{margin:0 0 var(--space-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.login-error{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-md)}.login-btn{width:100%;margin-top:var(--space-sm);padding:12px;font-size:var(--font-size-base)}.login-card a{color:var(--color-accent);font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.login-card a:hover{color:var(--color-accent-hover);text-decoration:underline}.dashboard{display:flex;flex-direction:column;gap:var(--space-xl);width:100%;min-width:0}.dashboard-hero{display:flex;align-items:stretch;justify-content:space-between;gap:var(--space-lg);padding:var(--space-xl);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(135deg,#4f46e51f,#0ea5e914 42%,#10b98114),var(--color-surface);box-shadow:var(--shadow-card)}.dashboard-kicker{display:inline-flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-sm);color:var(--color-accent);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em}.dashboard-hero h1{margin:0;color:var(--color-text);font-size:var(--font-size-3xl);letter-spacing:0}.dashboard-hero p{max-width:760px;margin:var(--space-sm) 0 0;color:var(--color-text-secondary);line-height:1.6}.hero-score{display:flex;min-width:190px;flex-direction:column;justify-content:center;gap:2px;padding:var(--space-lg);border:1px solid rgba(79,70,229,.2);border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-surface) 88%,var(--color-accent-subtle))}.hero-score span,.hero-score small{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.hero-score strong{color:var(--color-text);font-size:2.25rem;line-height:1;font-variant-numeric:tabular-nums}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-md)}.metric-card{position:relative;display:flex;min-height:148px;min-width:0;flex-direction:column;justify-content:space-between;overflow:hidden;padding:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card);color:var(--color-text);text-align:left;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.metric-card:not(:disabled){cursor:pointer}.metric-card:not(:disabled):hover{transform:translateY(-3px);border-color:var(--metric-color);box-shadow:var(--shadow-lg)}.metric-card:disabled{cursor:default}.metric-glow{position:absolute;inset:auto -48px -68px auto;width:140px;height:140px;border-radius:var(--radius-full);background:var(--metric-soft)}.metric-topline{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.06em;text-transform:uppercase}.metric-icon{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--metric-soft);color:var(--metric-color);flex-shrink:0}.metric-card strong{position:relative;z-index:1;margin-top:var(--space-md);color:var(--color-text);font-size:clamp(1.35rem,2vw,1.75rem);line-height:1.1;overflow-wrap:anywhere;font-variant-numeric:tabular-nums}.metric-card small{position:relative;z-index:1;color:var(--color-text-secondary);font-size:var(--font-size-xs);line-height:1.45}.metric-indigo{--metric-color: #4f46e5;--metric-soft: rgba(79, 70, 229, .12)}.metric-emerald{--metric-color: #059669;--metric-soft: rgba(16, 185, 129, .13)}.metric-amber{--metric-color: #d97706;--metric-soft: rgba(245, 158, 11, .15)}.metric-rose{--metric-color: #dc2626;--metric-soft: rgba(239, 68, 68, .13)}.metric-sky{--metric-color: #0284c7;--metric-soft: rgba(14, 165, 233, .13)}.metric-slate{--metric-color: #475569;--metric-soft: rgba(100, 116, 139, .13)}.dashboard-main-grid,.dashboard-lists{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-lg)}.panel-wide{grid-column:span 2}.dashboard-panel{min-width:0;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card)}.panel-title{display:flex;min-height:62px;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface-alt) 84%,var(--color-surface))}.panel-title div{display:flex;min-width:0;align-items:center;gap:var(--space-sm);color:var(--color-accent)}.panel-title h2{margin:0;color:var(--color-text);font-size:var(--font-size-base);font-weight:var(--font-weight-bold)}.panel-title span{color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.panel-title button{display:inline-flex;align-items:center;gap:var(--space-xs);border:none;background:transparent;color:var(--color-accent);cursor:pointer;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.bar-list{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg)}.bar-row-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-xs);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.bar-row-meta strong{color:var(--color-text);font-size:var(--font-size-sm);white-space:nowrap}.bar-track{height:9px;overflow:hidden;border-radius:var(--radius-full);background:var(--color-surface-alt)}.bar-track span{display:block;min-width:8px;height:100%;border-radius:inherit;background:linear-gradient(90deg,#4f46e5,#0ea5e9)}.donut-wrap{display:grid;grid-template-columns:150px 1fr;align-items:center;gap:var(--space-lg);padding:var(--space-lg)}.donut{position:relative;display:grid;width:150px;aspect-ratio:1;place-items:center;border-radius:var(--radius-full)}.donut:after{content:"";position:absolute;inset:22px;border-radius:inherit;background:var(--color-surface);box-shadow:inset 0 0 0 1px var(--color-border)}.donut span{position:relative;z-index:1;color:var(--color-text);font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold)}.donut-legend{display:flex;min-width:0;flex-direction:column;gap:var(--space-sm)}.donut-legend span,.chart-legend span{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.donut-legend i,.chart-legend i{width:9px;height:9px;border-radius:var(--radius-full);flex-shrink:0}.revenue-chart{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;min-height:260px;padding:var(--space-lg) var(--space-lg) var(--space-md);gap:var(--space-md)}.revenue-month{display:flex;min-width:0;height:220px;flex-direction:column;justify-content:flex-end;gap:var(--space-sm)}.revenue-bars{display:flex;height:180px;align-items:flex-end;justify-content:center;gap:6px;padding:0 var(--space-xs);border-bottom:1px solid var(--color-border)}.revenue-bars span{width:min(28px,40%);min-height:8px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.revenue-bars .received{background:linear-gradient(180deg,#10b981,#059669)}.revenue-bars .estimated{background:linear-gradient(180deg,#4f46e5,#0ea5e9)}.revenue-month small{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-align:center}.chart-legend{display:flex;justify-content:center;gap:var(--space-lg);padding:0 var(--space-lg) var(--space-lg)}.received-dot{background:#10b981}.estimated-dot{background:#4f46e5}.work-list,.timeline-list,.risk-stack{display:flex;flex-direction:column}.work-item,.timeline-item{display:grid;grid-template-columns:auto 1fr;column-gap:var(--space-sm);row-gap:3px;padding:var(--space-md) var(--space-lg);border:none;border-bottom:1px solid var(--color-border);background:transparent;color:var(--color-text);text-align:left;cursor:pointer}.work-item:hover,.timeline-item:hover{background:var(--color-surface-alt)}.work-item strong,.timeline-item strong,.risk-item strong{min-width:0;overflow:hidden;color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-overflow:ellipsis;white-space:nowrap}.work-item small,.timeline-item small,.risk-item small{color:var(--color-text-secondary);font-size:var(--font-size-xs);line-height:1.45}.work-type{grid-row:span 2;align-self:start;min-width:52px;padding:4px 7px;border-radius:var(--radius-sm);background:var(--color-accent-light);color:var(--color-accent);font-size:10px;font-weight:var(--font-weight-extrabold);text-align:center;text-transform:uppercase}.priority-2{background:var(--color-warning-light);color:var(--color-warning-text)}.priority-3{background:var(--color-danger-light);color:var(--color-danger-text)}.timeline-item{grid-template-columns:12px 1fr}.timeline-item span{grid-row:span 2;width:9px;height:9px;margin-top:5px;border-radius:var(--radius-full);background:var(--color-info);box-shadow:0 0 0 4px var(--color-info-light)}.risk-item{display:flex;flex-direction:column;gap:3px;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);border-left:3px solid var(--color-warning)}.risk-danger{border-left-color:var(--color-danger)}.dashboard-empty{padding:var(--space-xl);color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic;text-align:center}.dashboard-loading{display:flex;min-height:320px;align-items:center;justify-content:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:var(--font-size-sm)}.spin{animation:dashboard-spin .9s linear infinite}@keyframes dashboard-spin{to{transform:rotate(360deg)}}@media(max-width:1280px){.metric-grid,.dashboard-main-grid,.dashboard-lists{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.dashboard-hero{flex-direction:column}.hero-score{min-width:0}.dashboard-main-grid,.dashboard-lists,.panel-wide{grid-template-columns:1fr;grid-column:auto}.donut-wrap{grid-template-columns:1fr;justify-items:center}}@media(max-width:640px){.dashboard{gap:var(--space-lg)}.dashboard-hero{padding:var(--space-lg)}.dashboard-hero h1{font-size:var(--font-size-2xl)}.metric-grid{grid-template-columns:1fr}.metric-card{min-height:132px}.panel-title{align-items:flex-start;flex-direction:column}.revenue-chart{gap:var(--space-sm);overflow-x:auto}.revenue-month{min-width:58px}}.data-table-wrapper{overflow-x:auto;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);width:100%;min-width:0}.data-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0}.data-table thead{position:sticky;top:0;z-index:1}.data-table th{padding:12px var(--space-lg);text-align:left;background:var(--color-surface);font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);color:var(--color-accent-deep);letter-spacing:.06em;text-transform:uppercase;border-bottom:2px solid var(--color-accent-light);white-space:nowrap}.data-table th:first-child{border-top-left-radius:var(--radius-lg)}.data-table th:last-child{border-top-right-radius:var(--radius-lg)}.data-table td{padding:13px var(--space-lg);text-align:left;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:nth-child(2n) td{background:var(--color-surface-alt)}.data-table tbody tr:hover td{background:var(--color-accent-subtle)!important;transition:background var(--transition-fast)}.data-table tbody tr.clickable{cursor:pointer}.data-table .empty{text-align:center;color:var(--color-text-muted);padding:var(--space-2xl) var(--space-xl);font-size:var(--font-size-sm)}.data-table .skeleton-row td{padding:16px var(--space-lg)}.skeleton-cell{height:14px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-off-white) 25%,var(--color-silver) 50%,var(--color-off-white) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite}@keyframes shimmer{0%{background-position:200% center}to{background-position:-200% center}}.pagination-root{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-top:auto;padding-top:var(--space-2xl);flex-wrap:wrap}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.pagination-controls{display:flex;align-items:center;gap:var(--space-xs);order:1}.pagination-info{order:2;margin-left:auto}.pg-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:inherit;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.pg-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-btn.pg-active{background:var(--gradient-accent);color:var(--color-white);border-color:transparent;box-shadow:var(--shadow-accent);font-weight:var(--font-weight-semibold)}.pg-arrow{color:var(--color-text-secondary)}.pg-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:36px;color:var(--color-text-muted);font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none}@media(max-width:640px){.pagination-root{flex-direction:row;align-items:center;gap:var(--space-sm)}.pagination-info{width:100%;margin-left:0;text-align:right}}.modal-overlay{position:fixed;inset:0;background:#0f0c298c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);overflow-y:auto;animation:overlay-in var(--transition-base) ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:min(1100px,96vw);max-height:min(90vh,720px);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-modal);margin:auto;animation:modal-in var(--transition-base) cubic-bezier(.34,1.36,.64,1);border:1px solid var(--color-border)}@keyframes modal-in{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);flex-shrink:0;background:linear-gradient(135deg,var(--color-accent-subtle),var(--color-surface))}.modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-off-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1.25rem;cursor:pointer;color:var(--color-text-muted);line-height:1;padding:0;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.modal-body{padding:var(--space-xl);overflow-y:auto;overflow-x:hidden;min-height:0}.modal-body form{min-width:0}@media(max-width:900px){.modal{max-width:min(96vw,760px)}}.page{width:100%;max-width:100%;min-width:0;flex:1;min-height:0;padding-bottom:0;display:flex;flex-direction:column}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.page-title{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);letter-spacing:-.02em}.page-subtitle{margin:2px 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.header-actions{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.search-input{padding:9px var(--space-md);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);min-width:200px;max-width:260px;font-size:var(--font-size-sm);font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input::placeholder{color:var(--color-text-muted)}.search-input:hover:not(:focus){border-color:var(--color-accent-muted)}.search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126}.row-actions{display:flex;gap:var(--space-xs)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.entity-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:var(--space-lg);row-gap:var(--space-sm)}.entity-form .input-group{margin-bottom:0}.entity-form .form-actions,.entity-form .form-span-2{grid-column:1 / -1}.form-error{grid-column:1 / -1;display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin:0}.form-textarea{min-height:110px;resize:vertical}.loading{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-2xl);color:var(--color-text-muted);font-size:var(--font-size-sm)}@media(max-width:640px){.page-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:column}.search-input{max-width:none;width:100%}.entity-form{grid-template-columns:1fr}}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.02em;white-space:nowrap;line-height:1.5}.badge-success{background:var(--color-success-light);color:var(--color-success-text)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-text)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-text)}.badge-info{background:var(--color-info-light);color:var(--color-info-text)}.badge-neutral{background:var(--color-off-white);color:var(--color-mid);border:1px solid var(--color-border)}.badge-accent{background:var(--color-accent-light);color:var(--color-accent-deep)}.detail-overlay{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;animation:fadeIn .2s ease}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:min(480px,100vw);background:var(--color-surface);box-shadow:-4px 0 24px #00000026;z-index:201;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .25s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-surface-alt)}.detail-header-info{display:flex;align-items:center;gap:var(--space-md)}.detail-avatar{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--gradient-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);flex-shrink:0}.detail-title{margin:0 0 var(--space-xs);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--color-border);border-bottom:1px solid var(--color-border);flex-shrink:0}.detail-info-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-md) var(--space-lg);background:var(--color-surface)}.detail-info-item.full{grid-column:1 / -1}.detail-notes{white-space:pre-wrap;word-break:break-word;font-weight:var(--font-weight-normal);color:var(--color-text-secondary)}.detail-info-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-info-value{font-size:var(--font-size-sm);color:var(--color-text);font-weight:var(--font-weight-medium)}.detail-link{color:var(--color-accent);text-decoration:none}.detail-link:hover{text-decoration:underline}.detail-followup-banner{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);flex-shrink:0}.detail-followup-banner.today{background:var(--color-warning-light);color:var(--color-warning-dark, #92400e);border-bottom-color:var(--color-warning)}.detail-followup-banner.overdue{background:var(--color-danger-light);color:var(--color-danger);border-bottom-color:var(--color-danger)}.detail-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);flex-shrink:0}.detail-section-header h3{margin:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.detail-followup-form{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);display:flex;flex-direction:column;gap:var(--space-sm);flex-shrink:0}.detail-textarea{width:100%;resize:vertical;min-height:72px;font-family:inherit}.input-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:2px}.timeline{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:0}.timeline-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--space-2xl) 0;font-style:italic}.timeline-item{display:flex;gap:var(--space-md);position:relative;padding-bottom:var(--space-lg)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:0 0 0 2px var(--color-accent);flex-shrink:0;margin-top:4px;z-index:1}.timeline-line{position:absolute;left:4px;top:14px;bottom:0;width:2px;background:var(--color-border)}.timeline-content{flex:1;min-width:0}.timeline-notes{margin:0 0 var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text);line-height:1.5;word-break:break-word}.timeline-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.timeline-meta-item{display:flex;align-items:center;gap:3px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.task-progress-cell{display:flex;align-items:center;gap:var(--space-sm);min-width:120px}.progress-track{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s ease,background-color .3s ease}.progress-fill.low{background:var(--color-danger)}.progress-fill.med{background:var(--color-warning)}.progress-fill.high{background:var(--color-accent)}.progress-fill.done{background:var(--color-success)}.progress-text{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);width:3ch;text-align:right;line-height:1;display:inline-flex;align-items:center;justify-content:flex-end}.task-notes-row{background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.task-notes-content{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;white-space:pre-wrap}.badge-priority-critical{background-color:var(--color-danger-light);color:var(--color-danger);border-color:var(--color-danger)}.badge-priority-high{background-color:var(--color-warning-light);color:#c2410c;border-color:var(--color-warning)}.progress-slider-container{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-xs)}.progress-slider{width:100%;display:block;accent-color:var(--color-accent)}.progress-slider-value{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-text);width:3ch;text-align:right;line-height:1;display:inline-flex;align-items:center;justify-content:flex-end}.page-subtitle{margin:6px 0 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.permission-role-tabs{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.permission-role-tabs button{border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:8px 12px}.permission-role-tabs button.active{background:var(--color-accent-light);color:var(--color-accent)}.permission-card{overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-card)}.permission-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-surface-alt)}.permission-table-wrap{overflow-x:auto}.permission-api-warning{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-warning-light);color:var(--color-warning-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.permission-table{width:100%;min-width:720px;border-collapse:collapse}.permission-table th,.permission-table td{padding:14px var(--space-lg);border-bottom:1px solid var(--color-border);text-align:center}.permission-table th:first-child,.permission-table td:first-child{text-align:left}.permission-table th{color:var(--color-text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em}.permission-table td strong,.permission-table td small{display:block}.permission-table td small{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:3px}.permission-toggle{display:inline-flex;cursor:pointer}.permission-toggle input{position:absolute;opacity:0;pointer-events:none}.permission-toggle span{position:relative;width:42px;height:24px;border-radius:var(--radius-full);background:var(--color-border-strong);transition:background var(--transition-fast)}.permission-toggle span:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:var(--radius-full);background:var(--color-surface);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.permission-toggle input:checked+span{background:var(--color-accent)}.permission-toggle input:checked+span:after{transform:translate(18px)}.permission-toggle input:disabled+span{cursor:not-allowed;opacity:.55}@media(max-width:768px){.permission-role-tabs{width:100%;overflow-x:auto}}
