@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:var(--z-sidebar);transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:visible}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-logo{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border-color);height:var(--topbar-height);flex-shrink:0;display:flex}.sidebar-logo-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));width:36px;height:36px;font-weight:var(--font-bold);font-size:var(--text-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-img{object-fit:contain;flex-shrink:0;width:40px;height:32px}.collapsed .sidebar-logo-img{width:32px;height:26px}.sidebar-logo-text{white-space:nowrap;flex-direction:column;display:flex;overflow:hidden}.sidebar-logo-text .brand{font-size:var(--text-md);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.2}.sidebar-logo-text .subtitle{font-size:var(--text-xs);color:var(--text-tertiary)}.sidebar.collapsed .sidebar-logo-text{display:none}.sidebar-nav{padding:var(--space-3) var(--space-3);flex:1;overflow:hidden auto}.sidebar-section{margin-bottom:var(--space-4)}.sidebar-section-title{padding:var(--space-2) var(--space-3);font-size:10px;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-section-title{text-align:center;font-size:0}.sidebar.collapsed .sidebar-section-title:after{content:"···";font-size:10px}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-align:left;width:100%;font-family:var(--font-sans);background:0 0;border:none;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--color-primary-50);color:var(--text-primary)}.nav-item.active{background:var(--color-primary-100);color:var(--color-primary-light)}.nav-item.active:before{content:"";background:var(--color-primary);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-item-label{text-overflow:ellipsis;overflow:hidden}.sidebar.collapsed .nav-item-label{display:none}.sidebar.collapsed .nav-item{padding:var(--space-2);justify-content:center}.nav-item-badge{background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--font-bold);border-radius:var(--radius-full);text-align:center;min-width:18px;margin-left:auto;padding:1px 6px}.sidebar.collapsed .nav-item-badge{display:none}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--border-color);flex-shrink:0}.sidebar-logout-btn{margin-top:var(--space-2);justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);font-weight:var(--font-medium);background:0 0;display:flex}.sidebar-logout-btn:hover{color:var(--color-danger);border-color:color-mix(in oklab, var(--color-danger) 35%, var(--border-color));background:color-mix(in oklab, var(--color-danger) 8%, transparent)}.sidebar-logout-label{white-space:nowrap}.sidebar.collapsed .sidebar-logout-label{display:none}.role-switcher{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);width:100%;display:flex}.role-switcher:hover{border-color:var(--border-color-hover)}.role-switcher-info{flex-direction:column;display:flex;overflow:hidden}.role-switcher-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.role-switcher-role{font-size:var(--text-xs);color:var(--text-tertiary)}.sidebar.collapsed .role-switcher-info{display:none}.sidebar-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;width:24px;height:24px;color:var(--text-secondary);opacity:0;transition:all var(--transition-fast);z-index:10;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:-12px;transform:translateY(-50%)}.sidebar:hover .sidebar-toggle{opacity:1}.sidebar-toggle:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.topbar{top:0;right:0;left:var(--sidebar-width);height:var(--topbar-height);background:var(--bg-topbar);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);padding:0 var(--space-6);z-index:var(--z-topbar);transition:left var(--transition-slow);justify-content:space-between;align-items:center;display:flex;position:fixed}.sidebar-collapsed .topbar,.topbar.sidebar-collapsed{left:var(--sidebar-collapsed-width)}.topbar-left{align-items:center;gap:var(--space-4);display:flex}.topbar-title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.topbar-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);display:flex}.topbar-breadcrumb span.current{color:var(--text-primary);font-weight:var(--font-medium)}.topbar-right{align-items:center;gap:var(--space-3);display:flex}.topbar-search{position:relative}.topbar-search input{width:240px;padding:var(--space-2) var(--space-3) var(--space-2) 36px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-sans);transition:all var(--transition-fast);outline:none}.topbar-search input:focus{border-color:var(--color-primary);width:320px;box-shadow:0 0 0 3px var(--color-primary-50)}.topbar-search input::placeholder{color:var(--text-tertiary)}.topbar-search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.topbar-icon-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--color-primary-50);color:var(--color-primary-light)}.topbar-icon-btn .notification-dot{background:var(--color-danger);border:2px solid var(--bg-sidebar);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.topbar-user{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.topbar-user:hover{background:var(--color-primary-50)}.topbar-user-name{font-size:var(--text-sm);font-weight:var(--font-medium)}.topbar-user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.app-layout{min-height:100vh}.main-content{margin-left:var(--sidebar-width);margin-top:var(--topbar-height);min-height:calc(100vh - var(--topbar-height));transition:margin-left var(--transition-slow)}.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-width)}.content-wrapper{padding:var(--space-6);max-width:var(--content-max-width);margin:0 auto;animation:.3s ease-out fadeIn}.loading-screen{background:var(--bg-primary);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-logo{align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.loading-logo-icon{border-radius:var(--radius-xl);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));width:72px;height:72px;font-weight:var(--font-bold);font-size:var(--text-3xl);color:#fff;justify-content:center;align-items:center;animation:1.5s infinite pulse;display:flex}.loading-logo-text{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.loading-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);width:200px;height:3px;overflow:hidden}.loading-bar-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:var(--radius-full);width:40%;height:100%;animation:1.2s ease-in-out infinite loadingSlide}@keyframes loadingSlide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.loading-hint{font-size:var(--text-sm);color:var(--text-tertiary)}.dashboard{gap:var(--space-5);flex-direction:column;display:flex}.dashboard-stats{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.dashboard-charts,.dashboard-bottom{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.recent-hires-list{flex-direction:column;display:flex}.recent-hire-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);transition:background var(--transition-fast);color:inherit;text-decoration:none;display:flex}.recent-hire-item:hover{background:var(--color-primary-50)}.recent-hire-info{flex:1;min-width:0}.recent-hire-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.recent-hire-meta{font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dq-summary{gap:var(--space-3);flex-direction:column;display:flex}.dq-bar-row{align-items:center;gap:var(--space-3);display:flex}.dq-label{font-size:var(--text-sm);min-width:80px}.dq-value{font-size:var(--text-sm);font-weight:var(--font-semibold);text-align:right;min-width:30px}@media (width<=1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.dashboard-stats,.dashboard-charts,.dashboard-bottom{grid-template-columns:1fr}}.employee-page{gap:var(--space-4);flex-direction:column;display:flex}.employee-toolbar{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.employee-toolbar .search-wrapper{flex:1;min-width:200px;max-width:320px}.employee-filters{gap:var(--space-2);flex-wrap:wrap;display:flex}.employee-count{font-size:var(--text-sm)}.employee-name-cell{align-items:center;gap:var(--space-3);color:inherit;text-decoration:none;display:flex}.employee-name-cell:hover .emp-name{color:var(--color-primary-light)}.emp-name{font-weight:var(--font-medium);font-size:var(--text-sm);transition:color var(--transition-fast)}.emp-id{font-size:var(--text-xs)}@media (width<=1024px){.employee-toolbar{flex-direction:column;align-items:stretch}.employee-toolbar .search-wrapper{max-width:none}.employee-filters{overflow-x:auto}}.hr-calendar{gap:var(--space-5);flex-direction:column;display:flex}.cal-header{justify-content:space-between;align-items:flex-start;display:flex}.cal-nav{align-items:center;gap:var(--space-2);display:flex}.cal-body{gap:var(--space-4);grid-template-columns:1fr 320px;align-items:stretch;display:grid}.cal-main{flex-direction:column;min-height:0;display:flex}.cal-filters{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.cal-filter-btn{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);font-family:var(--font-sans);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-items:center;gap:6px;display:inline-flex}.cal-filter-btn:hover{border-color:var(--border-color-hover);background:var(--color-primary-50)}.cal-filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.cal-filter-dot{border-radius:50%;width:6px;height:6px}.cal-grid{background:var(--border-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-day-name{padding:var(--space-2);text-align:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-tertiary);background:var(--bg-tertiary);text-transform:uppercase;letter-spacing:.05em}.cal-day{aspect-ratio:1;min-height:72px;padding:var(--space-1);background:var(--bg-secondary);cursor:pointer;font-family:var(--font-sans);transition:background var(--transition-fast);border:none;flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.cal-day:hover{background:var(--color-primary-50)}.cal-day.outside{opacity:.3}.cal-day.today .cal-day-num{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.cal-day.selected{background:var(--color-primary-50);box-shadow:inset 0 0 0 2px var(--color-primary)}.cal-day-num{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-top:2px}.cal-day-dots{align-items:center;gap:3px;margin-top:auto;padding-bottom:4px;display:flex}.cal-dot{border-radius:50%;width:5px;height:5px}.cal-dot-more{color:var(--text-tertiary);font-size:9px}.cal-sidebar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);height:100%;overflow-y:auto}.cal-event-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-1);border-bottom:1px solid var(--border-color);display:flex}.cal-event-item:last-child{border-bottom:none}.cal-event-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.cal-event-content{flex:1;min-width:0}.cal-event-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.cal-event-date{font-size:var(--text-xs)}@media (width<=1024px){.cal-body{grid-template-columns:1fr}.cal-sidebar{max-height:300px}}@media (width<=768px){.cal-header{gap:var(--space-3);flex-direction:column}.cal-day{min-height:48px}}.reports-page{gap:var(--space-4);flex-direction:column;display:flex}.reports-header{justify-content:space-between;align-items:flex-start;display:flex}.reports-period{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.period-pills{gap:var(--space-2);flex-wrap:wrap;display:flex}.period-custom{align-items:center;gap:var(--space-2);display:flex}.period-custom .form-input{padding:var(--space-1) var(--space-2);width:150px}.report-content{min-height:400px}@media (width<=1024px){.report-content>div[style*=grid-template-columns]{grid-template-columns:1fr!important}}@media (width<=768px){.reports-header{gap:var(--space-3);flex-direction:column}.reports-period{flex-direction:column;align-items:flex-start}}.payroll-page{gap:var(--space-4);flex-direction:column;display:flex}.payroll-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.payroll-month-banner{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);display:flex}.payroll-table th{white-space:nowrap;font-size:var(--text-xs)}.payroll-table td{font-size:var(--text-sm);white-space:nowrap}.payroll-table tfoot td{background:var(--bg-tertiary);border-top:2px solid var(--border-color);font-size:var(--text-sm)}.editing-row{background:var(--color-primary-50)!important}.editing-row td{background:0 0!important}.payroll-actions{padding:var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:var(--space-3);display:flex}@media (width<=1200px){.payroll-page>div[style*="grid-template-columns: repeat(5"]{grid-template-columns:repeat(3,1fr)!important}}@media (width<=768px){.payroll-header{flex-direction:column}.payroll-page>div[style*="grid-template-columns: repeat(5"]{grid-template-columns:repeat(2,1fr)!important}}:root{--color-primary:#326ede;--color-primary-light:#5a8fe8;--color-primary-dark:#0e1b63;--color-primary-50:#326ede14;--color-primary-100:#326ede26;--color-brand-gray:#bcbdc0;--color-secondary:#7c3aed;--color-secondary-light:#8b5cf6;--color-secondary-50:#7c3aed14;--color-success:#059669;--color-success-light:#10b981;--color-success-50:#0596691a;--color-warning:#d97706;--color-warning-light:#f59e0b;--color-warning-50:#d977061a;--color-danger:#dc2626;--color-danger-light:#ef4444;--color-danger-50:#dc26261a;--color-info:#0ea5e9;--color-info-50:#0ea5e91a;--bg-primary:#0b1120;--bg-secondary:#111827;--bg-tertiary:#1e293b;--bg-card:#1e293bb3;--bg-card-hover:#1e293be6;--bg-glass:#0f172a99;--bg-input:#0f172acc;--bg-sidebar:#0f172a;--bg-topbar:#0f172ad9;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-inverse:#0f172a;--border-color:#94a3b81f;--border-color-hover:#94a3b840;--border-color-focus:var(--color-primary);--color-div-bod:#7c3aed;--color-div-bd:#2563eb;--color-div-ops:#059669;--color-div-support:#d97706;--color-div-dev:#dc2626;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000080, 0 8px 10px -6px #0000004d;--shadow-glow:0 0 20px #326ede26;--shadow-card:0 4px 24px #0003;--glass-bg:#1e293b80;--glass-border:#94a3b814;--glass-blur:16px;--font-sans:"Plus Jakarta Sans", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:.9375rem;--text-lg:1.0625rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed-width:72px;--topbar-height:64px;--content-max-width:1400px;--z-sidebar:100;--z-topbar:110;--z-dropdown:200;--z-modal:300;--z-toast:400}[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-card:#ffffffd9;--bg-card-hover:#fff;--bg-glass:#ffffffb3;--bg-input:#f1f5f9cc;--bg-sidebar:#fff;--bg-topbar:#ffffffe0;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#f1f5f9;--border-color:#94a3b833;--border-color-hover:#94a3b866;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000d;--shadow-glow:0 0 20px #326ede1a;--shadow-card:0 1px 3px #0000000f, 0 1px 2px #0000000a;--glass-bg:#fff9;--glass-border:#94a3b826}*,:before,:after{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:var(--font-sans);color:inherit}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 0,#326ede14 0%,#0000 50%),radial-gradient(at 80% 100%,#7c3aed0f 0%,#0000 50%),radial-gradient(#05966908 0%,#0000 50%);position:fixed;inset:0}#root{z-index:1;position:relative}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#94a3b833}::-webkit-scrollbar-thumb:hover{background:#94a3b859}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-success{color:var(--color-success-light)}.text-warning{color:var(--color-warning-light)}.text-danger{color:var(--color-danger-light)}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.animate-slide-up{animation:.4s ease-out forwards slideInUp}.stagger-item{opacity:0;animation:.4s ease-out forwards fadeIn}.stagger-item:first-child{animation-delay:50ms}.stagger-item:nth-child(2){animation-delay:.1s}.stagger-item:nth-child(3){animation-delay:.15s}.stagger-item:nth-child(4){animation-delay:.2s}.stagger-item:nth-child(5){animation-delay:.25s}.stagger-item:nth-child(6){animation-delay:.3s}.stagger-item:nth-child(7){animation-delay:.35s}.stagger-item:nth-child(8){animation-delay:.4s}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}::selection{color:var(--text-primary);background:#326ede4d}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;line-height:1.5;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 3px #326ede4d}.btn-primary:hover:not(:disabled){background:var(--color-primary-light);transform:translateY(-1px);box-shadow:0 4px 12px #326ede66}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-color-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-primary-50);color:var(--color-primary-light)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-light)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-icon{padding:var(--space-2);width:36px;height:36px}.badge{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);padding:2px 10px;line-height:1.6;display:inline-flex}.badge-primary{background:var(--color-primary-50);color:var(--color-primary-light)}.badge-success{background:var(--color-success-50);color:var(--color-success-light)}.badge-warning{background:var(--color-warning-50);color:var(--color-warning-light)}.badge-danger{background:var(--color-danger-50);color:var(--color-danger-light)}.badge-info{background:var(--color-info-50);color:var(--color-info)}.badge-secondary{color:var(--text-secondary);background:#64748b26}.badge-violet{background:var(--color-secondary-50);color:var(--color-secondary-light)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.card:hover{border-color:var(--border-color-hover)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);font-weight:var(--font-semibold)}.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-xl);padding:var(--space-5) var(--space-6);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-color-hover);transform:translateY(-2px)}.stat-card:before{content:"";background:var(--accent-color,var(--color-primary));opacity:.8;height:3px;position:absolute;top:0;left:0;right:0}.stat-card-icon{border-radius:var(--radius-lg);width:44px;height:44px;margin-bottom:var(--space-3);justify-content:center;align-items:center;display:flex}.stat-card-value{font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-1);line-height:1.1}.stat-card-label{font-size:var(--text-sm);color:var(--text-secondary)}.stat-card-change{font-size:var(--text-xs);font-weight:var(--font-medium);margin-top:var(--space-2);border-radius:var(--radius-full);align-items:center;gap:2px;padding:2px 8px;display:inline-flex}.stat-card-change.up{color:var(--color-success-light);background:var(--color-success-50)}.stat-card-change.down{color:var(--color-danger-light);background:var(--color-danger-50)}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.form-input{padding:var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--border-color-focus);box-shadow:0 0 0 3px var(--color-primary-50)}.form-input::placeholder{color:var(--text-tertiary)}.search-wrapper{align-items:center;display:flex;position:relative}.search-wrapper .search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;left:12px}.search-wrapper .form-input{width:100%;padding-left:40px}.data-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);box-shadow:inset 0 -1px 0 var(--border-color), 0 2px 8px #0000001f;white-space:nowrap;z-index:2;background:#0f172aeb;position:sticky;top:0}.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-primary-50)}.data-table tbody tr:last-child td{border-bottom:none}.avatar{border-radius:var(--radius-full);width:36px;height:36px;font-weight:var(--font-semibold);font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.avatar-sm{width:28px;height:28px;font-size:var(--text-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--text-lg)}.avatar-xl{width:72px;height:72px;font-size:var(--text-2xl)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:640px;max-height:85vh;box-shadow:var(--shadow-xl);animation:.3s ease-out fadeInScale;overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);display:flex}.tabs{gap:var(--space-1);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-5);display:flex}.tab-item{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000}.tab-item:hover{color:var(--text-secondary)}.tab-item.active{color:var(--color-primary-light);border-bottom-color:var(--color-primary)}.tooltip-wrapper{position:relative}.tooltip{padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);color:var(--text-primary);font-size:var(--text-xs);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast);box-shadow:var(--shadow-md);z-index:var(--z-dropdown);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-wrapper:hover .tooltip{opacity:1}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--space-4);opacity:.4}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-2)}.pagination{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.pagination-controls{align-items:center;gap:var(--space-1);display:flex}.pagination-btn{border:1px solid var(--border-color);border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.pagination-btn:hover:not(:disabled){background:var(--color-primary-50);border-color:var(--color-primary);color:var(--color-primary-light)}.pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.progress-bar{border-radius:var(--radius-full);background:#94a3b826;width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--color-primary);height:100%;transition:width var(--transition-slow)}.lifecycle-pipeline{align-items:center;gap:var(--space-1);width:100%;display:flex}.lifecycle-stage{padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color);transition:all var(--transition-fast);text-align:center;flex-direction:column;flex:1;align-items:center;display:flex}.lifecycle-stage:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.lifecycle-stage-count{font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-1)}.lifecycle-stage-label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.lifecycle-arrow{color:var(--text-tertiary);flex-shrink:0}.form-select{appearance:none;padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);background:var(--bg-input) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 5.646a.5.5 0 0 1 .708 0L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);outline:none}.form-select:focus{border-color:var(--border-color-focus);box-shadow:0 0 0 3px var(--color-primary-50)}.division-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.division-dot.khoi-bd{background:var(--color-div-bd)}.division-dot.khoi-ops{background:var(--color-div-ops)}.division-dot.khoi-support{background:var(--color-div-support)}.division-dot.khoi-dev{background:var(--color-div-dev)}.division-dot.bod{background:var(--color-div-bod)}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, #94a3b814 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}
