@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");:root{--color-primary:#1a56db;--color-primary-dark:#1240a8;--color-primary-light:#3b82f6;--color-accent:#0ea5e9;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#dc2626;--color-info:#3b82f6;--color-orange:#f97316;--color-purple:#8b5cf6;--color-emergency:#b91c1c;--color-bg:#0f1117;--color-bg-card:#1a1d2e;--color-bg-elevated:#232740;--color-bg-input:#1e2235;--color-border:#2d3250;--color-border-focus:#3b82f6;--color-text:#e8eaed;--color-text-secondary:#9ca3af;--color-text-muted:#94a3b8;--glass-bg:rgba(26,29,46,0.75);--glass-border:rgba(59,130,246,0.15);--glass-blur:16px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(0,0,0,0.3);--shadow-md:0 4px 12px rgba(0,0,0,0.4);--shadow-lg:0 8px 30px rgba(0,0,0,0.5);--shadow-glow:0 0 20px rgba(59,130,246,0.2);--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:400ms cubic-bezier(0.4,0,0.2,1)}[data-theme=light]{--color-bg:#f8fafc;--color-bg-card:#ffffff;--color-bg-elevated:#f1f5f9;--color-bg-input:#ffffff;--color-border:#e2e8f0;--color-border-focus:#2563eb;--color-text:#0f172a;--color-text-secondary:#334155;--color-text-muted:#64748b;--glass-bg:rgba(255,255,255,0.85);--glass-border:rgba(37,99,235,0.12);--glass-blur:16px;--shadow-sm:0 1px 3px rgba(0,0,0,0.08);--shadow-md:0 4px 12px rgba(0,0,0,0.1);--shadow-lg:0 8px 30px rgba(0,0,0,0.12);--shadow-glow:0 0 20px rgba(37,99,235,0.1)}[data-theme=light] body:before{background:linear-gradient(135deg,rgba(37,99,235,.03),rgba(14,165,233,.03))}[data-theme=light] .sidebar{background:#1e293b;border-right-color:rgba(59,130,246,.15)}[data-theme=light] .sidebar,[data-theme=light] .sidebar *{--color-text:#e8eaed;--color-text-secondary:#9ca3af;--color-text-muted:#94a3b8}[data-theme=light] .card:hover{border-color:rgba(37,99,235,.2)}[data-theme=light] .page-header h1{-webkit-text-fill-color:unset;background:none;color:#0f172a}.theme-toggle-group{display:flex;gap:4px;padding:4px;background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.theme-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.theme-toggle-btn:hover{color:var(--color-text);background:var(--color-bg-card)}.theme-toggle-active{background:var(--color-primary);color:white}.theme-toggle-active:hover{background:var(--color-primary-dark);color:white}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 0,rgba(26,86,219,.12) 0,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(14,165,233,.08) 0,transparent 50%);pointer-events:none;z-index:0}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent)}.app-container{display:flex;min-height:100vh;position:relative;z-index:1}.sidebar{width:260px;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border-right:1px solid var(--glass-border);padding:var(--space-lg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10;overflow-y:auto;transition:width var(--transition-base),padding var(--transition-base)}.sidebar-logo{font-size:1.1rem;color:var(--color-text);margin-bottom:var(--space-xs);gap:var(--space-sm)}.sidebar-logo,.sidebar-logo .logo-icon{font-weight:700;display:flex;align-items:center}.sidebar-logo .logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-sm);justify-content:center;font-size:.8rem;color:white}.sidebar-subtitle{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-xl)}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-nav a{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:1rem;font-weight:500;transition:all var(--transition-fast)}.sidebar-nav a.active,.sidebar-nav a:hover{background:var(--color-bg-elevated);color:var(--color-text)}.sidebar-nav a.active{background:rgba(59,130,246,.12);color:var(--color-primary-light)}.sidebar-footer{margin-top:auto;padding-top:var(--space-lg);border-top:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-muted)}.main-content{flex:1 1;margin-left:260px;padding:var(--space-xl) var(--space-2xl);max-width:1100px}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.card:hover{border-color:rgba(59,130,246,.3);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.card-title{font-size:1.15rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:white;box-shadow:0 2px 8px rgba(26,86,219,.3)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px rgba(26,86,219,.5);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-danger{background:linear-gradient(135deg,var(--color-danger),#ef4444);color:white}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{color:var(--color-text);background:var(--color-bg-elevated)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.text-danger{color:var(--color-danger)}.program-cards-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-md);gap:var(--space-md)}@media (max-width:640px){.program-cards-grid{grid-template-columns:1fr}}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.03em}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px rgba(59,130,246,.15)}.form-textarea{min-height:100px;resize:vertical}.form-hint{color:var(--color-text-muted)}.form-error,.form-hint{font-size:.875rem;margin-top:var(--space-xs)}.form-error{color:var(--color-danger)}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-lg);gap:var(--space-lg)}.checkbox-group{flex-direction:column}.checkbox-group,.checkbox-label{display:flex;gap:var(--space-sm)}.checkbox-label{align-items:center;cursor:pointer;font-size:1rem;color:var(--color-text)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary-light);cursor:pointer}.wizard-progress{gap:var(--space-xs);margin-bottom:var(--space-xl);padding:var(--space-md) var(--space-lg);background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow-x:auto}.wizard-progress,.wizard-step{display:flex;align-items:center}.wizard-step{gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;white-space:nowrap;color:var(--color-text-muted);transition:all var(--transition-base)}.wizard-step.active{background:rgba(59,130,246,.15);color:var(--color-primary-light)}.wizard-step.completed{color:var(--color-success)}.wizard-step-number{width:24px;height:24px;border-radius:50%;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.wizard-step.active .wizard-step-number{background:var(--color-primary);color:white}.wizard-step.completed .wizard-step-number{background:var(--color-success);color:white}.wizard-connector{width:20px;height:2px;background:var(--color-border);flex-shrink:0}.wizard-connector.completed{background:var(--color-success)}.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:1rem;margin-bottom:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-sm)}.alert-warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:var(--color-warning)}.alert-danger{background:rgba(220,38,38,.1);border:1px solid rgba(220,38,38,.3);color:var(--color-danger)}.alert-emergency{background:rgba(185,28,28,.15);border:1px solid rgba(185,28,28,.5);color:#fca5a5;animation:pulse-emergency 2s ease-in-out infinite}@keyframes pulse-emergency{0%,to{border-color:rgba(185,28,28,.5)}50%{border-color:rgba(185,28,28,.9)}}.alert-success{background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.3);color:var(--color-success)}.alert-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:var(--color-primary-light)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:var(--space-md);gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.stat-value{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--color-text),var(--color-primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-xs)}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse}td,th{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--color-border)}th{background:var(--color-bg-elevated);font-size:.875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}tr:hover td{background:rgba(59,130,246,.04)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-success{background:rgba(22,163,74,.15);color:var(--color-success)}.badge-warning{background:rgba(245,158,11,.15);color:var(--color-warning)}.badge-danger{background:rgba(220,38,38,.15);color:var(--color-danger)}.badge-info{background:rgba(59,130,246,.15);color:var(--color-primary-light)}.badge-neutral{background:rgba(148,163,184,.15);color:var(--color-text-muted)}.badge-purple{background:rgba(139,92,246,.15);color:#a78bfa}[data-theme=light] .badge-purple{color:#7c3aed}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.login-card{width:100%;max-width:420px;text-align:center}.login-card .card-title{font-size:1.5rem;margin-bottom:var(--space-xs)}.login-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--color-text-muted);font-size:.875rem}.login-divider:after,.login-divider:before{content:"";flex:1 1;height:1px;background:var(--color-border)}.login-sso-info{display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-xs)}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;text-decoration:underline}.btn-link:hover{color:var(--color-primary-hover)}.wizard-nav{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.loading-skeleton{background:linear-gradient(90deg,var(--color-bg-elevated) 25%,var(--color-border) 50%,var(--color-bg-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:var(--space-xs)}.skeleton-stat{height:2rem;width:60px}.table-skeleton{display:flex;flex-direction:column;gap:1px}.table-skeleton-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));grid-gap:var(--space-sm);gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border)}.table-skeleton-cell{height:1.2em;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-bg-elevated) 25%,var(--color-border) 50%,var(--color-bg-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:50;flex-direction:column}.toast,.toast-container{display:flex;gap:var(--space-sm)}.toast{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:1rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn var(--transition-base) ease-out;align-items:center;max-width:400px}.toast-success{background:rgba(22,163,74,.95);color:white}.toast-error{background:rgba(220,38,38,.95);color:white}@keyframes toastIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.mobile-nav-toggle{display:none;position:fixed;top:var(--space-md);left:var(--space-md);z-index:20;width:44px;height:44px;border-radius:var(--radius-sm);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);color:var(--color-text);font-size:1.25rem;cursor:pointer;align-items:center;justify-content:center}@media (max-width:768px){.sidebar{display:none;width:100%;max-width:280px}.mobile-nav-toggle,.sidebar.sidebar-open{display:flex}.main-content{margin-left:0;padding:var(--space-md);padding-top:calc(var(--space-md) + 56px)}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}[role=button],a,button{min-height:44px}}@media (min-width:769px) and (max-width:1280px){.sidebar{width:64px;padding:var(--space-md) var(--space-sm);overflow-x:hidden}.sidebar-external-icon,.sidebar-help-link span:not([aria-hidden=true]),.sidebar-kbd,.sidebar-logo span,.sidebar-nav-label,.sidebar-role-badge,.sidebar-section-label,.sidebar-subtitle{display:none}.sidebar-logo{justify-content:center;margin-bottom:var(--space-md)}.sidebar-nav a{justify-content:center;padding:var(--space-sm)}.sidebar-nav a span[aria-hidden=true]{font-size:1.25rem}.sidebar-help-link{justify-content:center;padding:var(--space-sm)}.sidebar-footer{padding-top:var(--space-sm)}.sidebar-footer>div:first-child{justify-content:center}.sidebar-footer>div:first-child>div:last-child{display:none}.sidebar-footer .btn{font-size:0;padding:var(--space-sm);min-width:44px}.sidebar-footer .btn:before{content:"→";font-size:1.125rem}.main-content{margin-left:64px}}@media (min-width:1281px){.main-content{max-width:1200px}}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--color-text),var(--color-primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{color:var(--color-text-secondary);margin-top:var(--space-xs)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-slow) ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.slide-in{animation:slideIn var(--transition-slow) ease-out}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.btn:focus-visible,.form-input:focus-visible,.form-select:focus-visible,.form-textarea:focus-visible{box-shadow:0 0 0 3px rgba(59,130,246,.25)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-link{position:absolute;top:-100%;left:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-primary);color:white;border-radius:var(--radius-sm);z-index:100;font-weight:600;font-size:1rem}.skip-link:focus{top:var(--space-md)}.breadcrumb{margin-bottom:var(--space-md)}.breadcrumb-list{list-style:none;font-size:.875rem}.breadcrumb-item,.breadcrumb-list{display:flex;align-items:center;gap:var(--space-xs)}.breadcrumb-link{color:var(--color-text-muted);transition:color var(--transition-fast)}.breadcrumb-link:hover{color:var(--color-primary-light)}.breadcrumb-current{color:var(--color-text-secondary);font-weight:500}.breadcrumb-separator{color:var(--color-text-muted);font-size:.75rem}.confirm-dialog-backdrop{border:none;background:transparent;padding:0;max-width:100vw;max-height:100vh}.confirm-dialog-backdrop::-webkit-backdrop{background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog-backdrop::backdrop{background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);min-width:380px;max-width:480px;text-align:center;box-shadow:var(--shadow-lg);animation:fadeIn var(--transition-base) ease-out}.confirm-dialog-icon{font-size:2rem;margin-bottom:var(--space-md)}.confirm-dialog-title{font-size:1.15rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.confirm-dialog-message{font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-xl);line-height:1.5}.confirm-dialog-actions{display:flex;gap:var(--space-sm);justify-content:center}.toast-warning{background:rgba(245,158,11,.95);color:white}.toast-info{background:rgba(59,130,246,.95);color:white}.toast-icon{font-weight:700;font-size:1rem;flex-shrink:0}.toast-message{flex:1 1}.toast-dismiss{background:none;border:none;color:inherit;opacity:.7;cursor:pointer;font-size:.875rem;padding:0;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.toast-dismiss:hover{opacity:1}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.6}.empty-state-title{font-size:1.15rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.empty-state-description{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--space-lg);max-width:400px;margin-left:auto;margin-right:auto}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input-icon{position:absolute;left:var(--space-sm);font-size:.875rem;pointer-events:none;z-index:1}.search-input{width:100%;padding:var(--space-sm) var(--space-md);padding-left:calc(var(--space-sm) + 1.5em);padding-right:calc(var(--space-sm) + 1.5em);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:1rem;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px rgba(59,130,246,.15)}.search-input::placeholder{color:var(--color-text-muted)}.search-input-clear{position:absolute;right:var(--space-sm);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:.875rem;padding:0;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.search-input-clear:hover{color:var(--color-text)}.pagination{justify-content:space-between;padding:var(--space-md) 0;font-size:.875rem;color:var(--color-text-secondary);flex-wrap:wrap}.pagination,.pagination-info{display:flex;align-items:center;gap:var(--space-md)}.pagination-size-select{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);padding:var(--space-xs) var(--space-sm);font-size:.875rem;font-family:inherit;min-height:44px}.pagination-controls{display:flex;align-items:center;gap:var(--space-xs)}.pagination-btn{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);padding:var(--space-xs) var(--space-sm);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast);min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-current{padding:0 var(--space-sm);font-weight:500;white-space:nowrap}.th-sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color var(--transition-fast)}.th-sortable:hover{color:var(--color-text)}.th-sort-indicator{display:inline-block;margin-left:var(--space-xs);font-size:.75rem;opacity:.5}.th-sort-indicator.active{opacity:1;color:var(--color-primary-light)}.top-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);gap:var(--space-md)}.top-header-left{flex:1 1;max-width:400px}.top-header-right{display:flex;align-items:center;gap:var(--space-md)}.header-user-menu{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast);background:none;border:1px solid transparent}.header-user-menu:hover{background:var(--color-bg-elevated);border-color:var(--color-border)}.header-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:white;flex-shrink:0}.notification-dropdown-wrapper{position:relative}.notification-bell{position:relative;background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;padding:var(--space-xs);min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.notification-bell:hover{background:var(--color-bg-elevated);color:var(--color-text)}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;line-height:18px;text-align:center;pointer-events:none}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;display:flex;flex-direction:column;overflow:hidden}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);font-size:.875rem}.notification-empty{padding:var(--space-xl) var(--space-md);text-align:center;color:var(--color-text-muted);font-size:.875rem}.notification-list{overflow-y:auto;max-height:340px}.notification-item{display:block;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--color-border);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background var(--transition-fast);color:var(--color-text-secondary);font-family:inherit}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-bg-elevated)}.notification-unread{background:rgba(59,130,246,.06);border-left:3px solid var(--color-primary)}.notification-unread:hover{background:rgba(59,130,246,.1)}.notification-item-title{font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:2px}.notification-item-message{font-size:.75rem;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-time{font-size:.6875rem;color:var(--color-text-muted);margin-top:4px}.notification-view-all{display:block;width:100%;text-align:center;background:none;border:none;border-top:1px solid var(--color-border);padding:var(--space-sm) var(--space-md);color:var(--color-primary-light);font-size:.8125rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background var(--transition-fast)}.notification-view-all:hover{background:var(--color-bg-elevated)}.notification-page-filters{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.notification-page-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.notification-page-item:hover{background:var(--color-bg-elevated)}.notification-page-item.unread{background:rgba(59,130,246,.06);border-left:3px solid var(--color-primary)}.notification-page-item-content{flex:1 1;min-width:0}.notification-page-item-actions{flex-shrink:0}.form-input.input-error,.form-select.input-error,.form-textarea.input-error{border-color:var(--color-danger);box-shadow:0 0 0 3px rgba(220,38,38,.15)}.field-error{color:var(--color-danger);margin-top:var(--space-xs);display:flex}.draft-indicator,.field-error{font-size:.875rem;align-items:center;gap:var(--space-xs)}.draft-indicator{display:inline-flex;color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);background:var(--color-bg-elevated);border-radius:var(--radius-sm)}.draft-indicator-dot{width:6px;height:6px;border-radius:50%;background:var(--color-warning)}.draft-indicator-saved .draft-indicator-dot{background:var(--color-success)}.tr-clickable{cursor:pointer}.tr-clickable:hover td{background:rgba(59,130,246,.08)}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.table-toolbar-actions{display:flex;align-items:center;gap:var(--space-sm)}@media (max-width:768px){.top-header{flex-direction:column;align-items:stretch}.top-header-left{max-width:100%}.pagination{flex-direction:column;align-items:center}.table-toolbar{flex-direction:column;align-items:stretch}.confirm-dialog{min-width:auto;margin:var(--space-md)}.filter-panel-row{flex-direction:column}.keyboard-help-grid{grid-template-columns:1fr}}.global-progress-bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;background:transparent;pointer-events:none}.global-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));transition:width .2s ease-out;border-radius:0 2px 2px 0;box-shadow:0 0 8px rgba(59,130,246,.5)}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:var(--space-2xl)}.error-boundary-icon{font-size:3rem;margin-bottom:var(--space-md)}.error-boundary-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-sm);color:var(--color-text)}.error-boundary-message{color:var(--color-text-secondary);max-width:480px;margin-bottom:var(--space-lg);line-height:1.6}.error-boundary-details{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg);max-width:600px;width:100%;text-align:left}.error-boundary-details summary{cursor:pointer;color:var(--color-text-muted);font-size:.875rem;margin-bottom:var(--space-sm)}.error-boundary-details pre{font-size:.875rem;color:var(--color-danger);white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;gap:var(--space-md)}.session-timeout-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn var(--transition-fast) ease-out}.session-timeout-dialog{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;max-width:420px;width:90%;box-shadow:var(--shadow-lg)}.session-timeout-icon{font-size:2.5rem;margin-bottom:var(--space-md)}.session-timeout-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-sm)}.session-timeout-message{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-lg)}.session-timeout-actions{display:flex;gap:var(--space-md);justify-content:center}.offline-banner{position:fixed;top:3px;left:0;right:0;z-index:9998;background:linear-gradient(135deg,var(--color-warning),#d97706);color:#1a1a1a;padding:var(--space-sm) var(--space-lg);text-align:center;font-size:.875rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);animation:slideDown var(--transition-base) ease-out}.offline-banner-icon{font-size:1rem}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.keyboard-help-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn var(--transition-fast) ease-out}.keyboard-help-dialog{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);max-width:560px;width:90%;box-shadow:var(--shadow-lg)}.keyboard-help-dialog h2{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-lg);color:var(--color-text)}.keyboard-help-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-lg);gap:var(--space-lg)}.keyboard-help-section h3{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.keyboard-shortcut{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) 0;font-size:.875rem}.keyboard-shortcut span{color:var(--color-text-secondary)}.keyboard-shortcut kbd,.sidebar-kbd{display:inline-block;padding:2px 6px;font-size:.75rem;font-family:Inter,monospace;color:var(--color-text);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:4px;box-shadow:0 1px 0 rgba(0,0,0,.3);min-width:20px;text-align:center}.filter-panel{background:rgba(30,41,59,.5);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);animation:slideDown var(--transition-fast) ease-out}.filter-panel-row{display:flex;gap:var(--space-md);align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:var(--space-xs);min-width:140px}.filter-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.filter-input,.filter-select{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-input);color:var(--color-text);font-size:.875rem;outline:none;transition:border-color var(--transition-fast)}.filter-input:focus,.filter-select:focus{border-color:var(--color-border-focus)}.filter-toggle-btn{position:relative}.filter-toggle-btn.active{color:var(--color-primary-light)}.filter-active-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--color-primary-light);margin-left:4px;vertical-align:middle}.filter-clear-btn{align-self:flex-end;white-space:nowrap;color:var(--color-text-muted)!important;font-size:.875rem!important}.last-updated-label,.results-count{font-size:.875rem;color:var(--color-text-muted);white-space:nowrap}.stat-card-interactive{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.stat-alert-badge{display:inline-block;margin-top:var(--space-xs);padding:2px 8px;font-size:.75rem;font-weight:600;color:var(--color-warning);background:rgba(245,158,11,.15);border-radius:var(--radius-full);animation:pulse 2s ease-in-out infinite}.sidebar-section-label{margin:0 16px 8px;font-size:.75rem;font-weight:700;letter-spacing:.1em;color:var(--color-text-muted)}.sidebar-help-section{padding:var(--space-sm) var(--space-md);border-top:1px solid rgba(99,102,241,.1);margin-top:auto}.sidebar-help-link{display:flex;align-items:center;gap:var(--space-sm);padding:6px 8px;font-size:.875rem;color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);cursor:pointer;background:none;border:none;width:100%;text-align:left;min-height:44px}.sidebar-help-link:hover{color:var(--color-text);background:rgba(99,102,241,.08)}.sidebar-external-icon{margin-left:auto;font-size:.75rem;opacity:.5}.sidebar-role-badge{display:inline-block;padding:1px 6px;font-size:.75rem;font-weight:600;border:1px solid;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.sidebar-kbd{margin-left:auto;font-size:.75rem;opacity:.7}.help-tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;padding:2px;margin-left:4px;cursor:help;color:var(--color-text-muted);border-radius:50%;transition:color var(--transition-fast);vertical-align:middle}.help-tooltip-trigger:focus-visible,.help-tooltip-trigger:hover{color:var(--color-primary-light)}.help-tooltip-popover{bottom:calc(100% + 8px);background:var(--color-bg-elevated);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);width:280px;z-index:200;box-shadow:var(--shadow-lg);font-size:.875rem;line-height:1.5}.help-tooltip-popover,.help-tooltip-popover:after{position:absolute;left:50%;transform:translateX(-50%)}.help-tooltip-popover:after{content:"";top:100%;border:6px solid transparent;border-top:6px solid var(--color-border)}.help-tooltip-title{font-weight:600;margin-bottom:var(--space-xs);color:var(--color-primary-light)}.help-tooltip-body{color:var(--color-text-secondary)}.help-tooltip-source{margin-top:var(--space-sm);font-size:.75rem;color:var(--color-text-muted);font-style:italic}.data-table-cards-container{display:none}.data-table-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);background:var(--color-bg-card)}.data-table-card-clickable{cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.data-table-card-clickable:focus-visible,.data-table-card-clickable:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-sm)}.data-table-card-field{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-xs) 0;gap:var(--space-sm)}.data-table-card-field:not(:last-child){border-bottom:1px solid rgba(45,50,80,.3)}.data-table-card-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;min-width:80px}.data-table-card-value{font-size:.875rem;color:var(--color-text);text-align:right;flex:1 1}@media (max-width:768px){.data-table-cards-container{display:block}.data-table-desktop{display:none}}.data-table-bulk-bar{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);margin-bottom:var(--space-sm);font-size:.875rem;font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.25)}.data-table-bulk-bar-count{white-space:nowrap}.data-table-bulk-bar-actions{display:flex;gap:var(--space-xs);flex:1 1}.data-table-bulk-bar .btn{color:#fff;border-color:rgba(255,255,255,.3)}.data-table-bulk-bar .btn:hover{background:rgba(255,255,255,.15)}.tr-selected{background:rgba(59,130,246,.08)}.tr-selected:hover{background:rgba(59,130,246,.12)}.field-tooltip{position:relative;margin-left:4px;cursor:help}.field-tooltip,.field-tooltip-icon{display:inline-flex;align-items:center}.field-tooltip-icon{justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(99,102,241,.2);color:var(--color-primary-light);font-size:.75rem;font-weight:700}.field-tooltip:hover .field-tooltip-text{visibility:visible;opacity:1}.field-tooltip-text{visibility:hidden;opacity:0;position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;line-height:1.4;white-space:normal;width:250px;z-index:100;box-shadow:var(--shadow-md);transition:opacity var(--transition-fast),visibility var(--transition-fast);margin-bottom:4px}.tab-list{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:0}.tab-button{padding:var(--space-sm) var(--space-lg);border:none;border-bottom:2px solid transparent;background:none;font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;color:var(--color-text-secondary);margin-bottom:-2px;transition:color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.tab-button:hover{color:var(--color-text)}.tab-button[aria-selected=true]{color:var(--color-primary-light);border-bottom-color:var(--color-primary-light);font-weight:700}.tab-panel{animation:fadeIn var(--transition-base) ease-out}.tab-panel-card{border-top-left-radius:0;border-top-right-radius:0}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out}.modal-dialog{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);max-width:600px;width:90%;box-shadow:var(--shadow-lg);animation:fadeIn var(--transition-base) ease-out;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-title{font-size:1.25rem;font-weight:700;color:var(--color-text)}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1}.modal-close:hover{color:var(--color-text);background:var(--color-bg-elevated)}.modal-body{display:flex;flex-direction:column;gap:var(--space-md)}.modal-footer{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.form-section{margin-bottom:var(--space-lg)}.form-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.form-section-hint{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-md);line-height:1.5}.action-group{display:flex;gap:var(--space-xs);flex-wrap:nowrap;align-items:center}.action-group .btn{font-size:.8rem;padding:var(--space-xs) var(--space-sm);white-space:nowrap}.badge-secondary{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.impersonation-banner{background:linear-gradient(135deg,var(--color-warning),#d97706);color:#1a1a1a;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-md);display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:.9rem;animation:slideDown var(--transition-base) ease-out}.impersonation-banner .btn{background:#1a1a1a;color:white;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-weight:600;border:none}.chip-filter-group{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.chip-filter{background:var(--color-bg-elevated);border:2px solid transparent;border-radius:var(--radius-full);padding:var(--space-xs) var(--space-md);display:inline-flex;align-items:center;gap:var(--space-xs);cursor:pointer;font-size:.85rem;color:var(--color-text-secondary);transition:all var(--transition-fast)}.chip-filter:hover{background:var(--color-border);color:var(--color-text)}.chip-filter.active{border-color:var(--color-primary-light);background:rgba(59,130,246,.12);color:var(--color-primary-light)}.chip-filter-count{font-weight:700}.metadata-kv{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.metadata-kv-item{display:inline-flex;gap:2px;font-size:.8rem;background:var(--color-bg-elevated);padding:1px 6px;border-radius:var(--radius-sm)}.metadata-kv-key{color:var(--color-text-muted)}.metadata-kv-value{color:var(--color-text-secondary);font-weight:500}.inline-spinner{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:.9rem;padding:var(--space-xl);justify-content:center;width:100%}@media (max-width:768px){.modal-dialog{width:95%;padding:var(--space-md)}.tab-list{overflow-x:auto}.chip-filter-group{overflow-x:auto;flex-wrap:nowrap}}