@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap);:root{--surface-0:#fff;--surface-05:#fafbfc;--surface-1:#f5f7fa;--surface-2:#edf0f7;--surface-3:#e2e6ef;--surface-4:#d5dae5;--bg-gradient:linear-gradient(160deg,#f5f7fa,#edf0f7 40%,#f0f2f8 70%,#f5f7fa);--border-subtle:#edf0f7;--border-default:#d8dce6;--border-strong:#c1c7d4;--border-focus:#4f46e566;--primary:#4f46e5;--primary-dark:#4338ca;--primary-muted:#4f46e51a;--primary-glow:#4f46e533;--primary-light:#4f46e50f;--primary-border:#4f46e54d;--holo-gradient:linear-gradient(135deg,#4f46e5,#7c3aed);--holo-gradient-h:linear-gradient(135deg,#4f46e5,#6d28d9 50%,#7c3aed);--success:#059669;--success-muted:#05966914;--success-border:#05966940;--warning:#d97706;--warning-muted:#d9770614;--warning-border:#d9770640;--danger:#dc2626;--danger-muted:#dc26260f;--danger-border:#dc262640;--info:#2563eb;--info-muted:#2563eb0f;--info-border:#2563eb40;--purple:#7c3aed;--purple-muted:#7c3aed0f;--purple-border:#7c3aed40;--neutral-950:#020617;--neutral-900:#0f172a;--neutral-800:#1e293b;--neutral-700:#334155;--neutral-600:#475569;--neutral-500:#64748b;--neutral-400:#94a3b8;--neutral-300:#cbd5e1;--neutral-200:#e2e8f0;--neutral-100:#f1f5f9;--neutral-50:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-disabled:#cbd5e1;--text-accent:var(--primary);--sidebar-bg:#1e293b;--sidebar-border:#ffffff14;--sidebar-hover:#ffffff0f;--sidebar-active:#4f46e533;--font-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code","Consolas",monospace;--text-2xs:10px;--text-xs:11px;--text-sm:12px;--text-base:13px;--text-md:14px;--text-lg:16px;--text-xl:20px;--text-2xl:28px;--text-3xl:36px;--tracking-tight:-0.02em;--tracking-normal:0;--tracking-wide:0.04em;--tracking-wider:0.08em;--tabular-nums:"tnum";--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--space-0:0;--space-px:1px;--space-0-5:2px;--space-1:4px;--space-1-5:6px;--space-2:8px;--space-2-5:10px;--space-3:12px;--space-3-5:14px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--space-9:36px;--space-10:40px;--space-12:48px;--space-14:56px;--space-16:64px;--space-20:80px;--radius-xs:4px;--radius-sm:6px;--radius:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-pill:999px;--radius-full:50%;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-md:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000d;--shadow-lg:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a;--shadow-xl:0 25px 50px -12px #00000026;--shadow-card:0 1px 3px #0000000d,0 10px 30px -10px #00000014;--shadow-card-hover:0 1px 3px #0000000d,0 20px 40px -15px #0000001f;--shadow-glow-primary:0 4px 14px #4f46e540;--shadow-glow-success:0 4px 14px #05966933;--shadow-glow-danger:0 4px 14px #dc262633;--shadow-glow-warning:0 4px 14px #d9770633;--focus-ring:0 0 0 3px var(--primary-glow);--z-base:1;--z-sticky:50;--z-overlay:100;--z-sidebar:150;--z-modal:200;--z-dropdown:300;--z-popover:400;--z-toast:1000;--duration-fast:120ms;--duration-normal:200ms;--duration-slow:300ms;--duration-spring:500ms;--ease-default:cubic-bezier(0.4,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ease-bounce:cubic-bezier(0.34,1.56,0.64,1);--ease-smooth:cubic-bezier(0.22,1,0.36,1);--transition-fast:all var(--duration-fast) var(--ease-default);--transition-normal:all var(--duration-normal) var(--ease-default);--transition-spring:all var(--duration-spring) var(--ease-spring);--sidebar-w:260px;--header-h:60px;--content-max:1440px;--blur-sm:8px;--blur-md:16px;--blur-lg:24px;--gray-50:var(--neutral-50);--gray-100:var(--neutral-100);--gray-200:var(--neutral-200);--gray-300:var(--neutral-300);--gray-400:var(--neutral-400);--gray-500:var(--neutral-500);--gray-600:var(--neutral-600);--gray-700:var(--neutral-700);--gray-800:var(--neutral-800);--gray-900:var(--neutral-900);--success-light:var(--success-muted);--warning-light:var(--warning-muted);--danger-light:var(--danger-muted);--info-light:var(--info-muted);--purple-light:var(--purple-muted);--accent:var(--primary)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 #4f46e566}50%{box-shadow:0 0 0 8px #4f46e500}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes staggerFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes ripple{to{opacity:0;transform:scale(4)}}@keyframes notifBellPulse{0%,to{transform:scale(1) rotate(0deg)}25%{transform:scale(1.1) rotate(8deg)}50%{transform:scale(1.05) rotate(-5deg)}75%{transform:scale(1.08) rotate(3deg)}}@keyframes commentBtnFlash{0%,to{background:#7c3aed0f;background:var(--purple-muted);box-shadow:0 0 0 0 #0000;color:#7c3aed;color:var(--purple);transform:scale(1)}50%{background:#4f46e5;background:var(--primary);box-shadow:0 4px 14px #4f46e540;box-shadow:var(--shadow-glow-primary);color:#fff;transform:scale(1.15)}}@keyframes progressGrow{0%{width:0}}@keyframes borderGlow{0%,to{border-color:#d8dce6;border-color:var(--border-default)}50%{border-color:#4f46e54d;border-color:var(--primary-border)}}@keyframes cardEntrance{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-gradient);background-attachment:fixed;color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-md);line-height:var(--leading-normal);min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:var(--tracking-tight)}button{cursor:pointer}button,input,select,textarea{font-family:var(--font-body)}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:var(--surface-1)}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.fade-in{animation:fadeUp .4s var(--ease-smooth) forwards}.skip-to-content{background:var(--primary);border-radius:var(--radius);color:#fff;font-weight:600;left:-9999px;padding:var(--space-2) var(--space-4);position:absolute;text-decoration:none;top:var(--space-2);z-index:var(--z-toast)}.skip-to-content:focus{left:var(--space-2)}.layout{display:flex;min-height:100vh;overflow-x:hidden;position:relative;width:100%}.sidebar-overlay{animation:fadeIn var(--duration-normal) ease;-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:#0f172a66;display:none;inset:0;position:fixed;z-index:var(--z-overlay)}.sidebar{background:var(--sidebar-bg);border-right:none;bottom:0;box-shadow:4px 0 24px #00000014;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;transition:transform var(--duration-slow) var(--ease-default);width:var(--sidebar-w);z-index:var(--z-sidebar)}.main-content{background:#0000;display:flex;flex:1 1;flex-direction:column;margin-left:var(--sidebar-w);min-height:100vh;min-width:0}.topbar{align-items:center;backdrop-filter:blur(var(--blur-lg));-webkit-backdrop-filter:blur(var(--blur-lg));background:#ffffffd9;border-bottom:1px solid var(--border-default);box-shadow:0 1px 3px #0000000a;display:flex;gap:var(--space-3);height:var(--header-h);justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:var(--z-sticky)}.hamburger{background:none;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:none;font-size:18px;padding:var(--space-1-5) var(--space-2);transition:var(--transition-fast)}.hamburger:hover{background:var(--surface-2);color:var(--text-primary)}.page-content{flex:1 1;min-width:0;padding:var(--space-6);scroll-behavior:smooth}.sidebar-logo{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;padding:var(--space-5) var(--space-4) var(--space-4)}.sidebar-logo-inner{gap:var(--space-2-5)}.logo-icon,.sidebar-logo-inner{align-items:center;display:flex}.logo-icon{background:var(--holo-gradient);border-radius:var(--radius-md);box-shadow:var(--shadow-glow-primary);flex-shrink:0;font-size:var(--text-lg);height:36px;justify-content:center;width:36px}.sidebar-logo h2{color:#fff;font-family:var(--font-display);font-size:15px;font-weight:800;letter-spacing:var(--tracking-tight)}.sidebar-logo p{color:#ffffff80;font-size:var(--text-xs);margin-top:var(--space-px)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--space-2-5) 0;scroll-behavior:smooth}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:var(--radius-pill)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff40}.nav-section-title{color:#ffffff4d;font-family:var(--font-display);font-size:var(--text-2xs);font-weight:700;letter-spacing:var(--tracking-wider);padding:var(--space-4) var(--space-4) var(--space-1);text-transform:uppercase}.nav-item{align-items:center;border-left:2px solid #0000;border-radius:var(--radius);color:#fff9;cursor:pointer;display:flex;font-size:var(--text-base);font-weight:500;gap:var(--space-2);margin:var(--space-px) var(--space-2);padding:var(--space-2) var(--space-3);transition:var(--transition-fast)}.nav-item:hover{background:var(--sidebar-hover);color:#ffffffe6}.nav-item.active{background:var(--sidebar-active);border-left-color:var(--primary);color:#fff;font-weight:600}.nav-icon{flex-shrink:0;font-size:15px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:var(--space-3) var(--space-4)}.user-chip{align-items:center;background:#ffffff0f;border:1px solid var(--sidebar-border);border-radius:var(--radius);cursor:pointer;display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-2-5);transition:var(--transition-fast)}.user-chip:hover{background:#ffffff1a}.avatar{align-items:center;border-radius:var(--radius-full);display:flex;flex-shrink:0;font-family:var(--font-display);font-weight:700;justify-content:center}.avatar-sm{font-size:var(--text-xs);height:30px;width:30px}.avatar-md{font-size:var(--text-md);height:38px;width:38px}.avatar-lg{font-size:17px;height:50px;width:50px}.avatar-admin{background:var(--holo-gradient);color:#fff}.avatar-employee{background:linear-gradient(135deg,var(--success),#34d399);color:#fff}.page-header{margin-bottom:var(--space-5)}.page-header h1{align-items:center;color:var(--text-primary);display:flex;font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;gap:var(--space-2);letter-spacing:var(--tracking-tight)}.page-header p{color:var(--text-tertiary);font-size:var(--text-base);margin-top:var(--space-1)}.stats-grid{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-5)}.stat-card{animation:cardEntrance .5s var(--ease-smooth) both;background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);cursor:pointer;overflow:hidden;padding:var(--space-5);position:relative;transition:transform var(--duration-spring) var(--ease-spring),box-shadow var(--duration-normal) var(--ease-default),border-color var(--duration-normal)}.stat-card:first-child{animation-delay:0ms}.stat-card:nth-child(2){animation-delay:60ms}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.18s}.stat-card:nth-child(5){animation-delay:.24s}.stat-card:nth-child(6){animation-delay:.3s}.stat-card:after{background:currentColor;border-radius:var(--radius-full);content:"";height:80px;opacity:.04;position:absolute;right:-20px;top:-20px;transition:transform var(--duration-spring) var(--ease-spring);width:80px}.stat-card:hover{border-color:var(--primary-border);box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.stat-card:hover:after{transform:scale(1.5)}.stat-card-icon{align-items:center;background:var(--surface-1);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);display:inline-flex;font-size:var(--text-xl);height:42px;justify-content:center;margin-bottom:var(--space-3-5);width:42px}.stat-card-value{font-feature-settings:var(--tabular-nums);animation:countUp .6s var(--ease-smooth) both;color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;letter-spacing:-1px;line-height:var(--leading-none);margin-bottom:var(--space-1)}.stat-card-label{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600}.stat-card-sub{color:var(--text-tertiary);font-size:var(--text-xs);margin-top:var(--space-0-5)}.card{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--duration-normal),border-color var(--duration-normal)}.card:hover{box-shadow:var(--shadow-md)}.card+.card{margin-top:var(--space-4)}.card-header{align-items:center;background:var(--surface-05);border-bottom:1px solid var(--border-subtle);display:flex;gap:var(--space-3);justify-content:space-between;padding:var(--space-4) var(--space-5)}.card-title{color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-md);font-weight:700}.card-body{padding:var(--space-5)}.badge{align-items:center;border:1px solid #0000;border-radius:var(--radius-pill);display:inline-flex;font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;gap:var(--space-1);padding:var(--space-0-5) var(--space-2-5);white-space:nowrap}.badge-success{background:var(--success-muted);border-color:var(--success-border);color:var(--success)}.badge-warning{background:var(--warning-muted);border-color:var(--warning-border);color:var(--warning)}.badge-danger{background:var(--danger-muted);border-color:var(--danger-border);color:var(--danger)}.badge-info{background:var(--info-muted);border-color:var(--info-border);color:var(--info)}.badge-gray{background:var(--surface-2);border-color:var(--border-default);color:var(--text-secondary)}.badge-purple{background:var(--purple-muted);border-color:var(--purple-border);color:var(--purple)}.btn{align-items:center;border:none;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:var(--text-base);font-weight:600;gap:var(--space-1-5);letter-spacing:.01em;overflow:hidden;padding:var(--space-2) var(--space-4);position:relative;transition:var(--transition-normal);white-space:nowrap}.btn:after{background:radial-gradient(circle,#ffffff4d 10%,#0000 0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transform:scale(0);transition:transform .4s,opacity .4s;width:100%}.btn:active:after{opacity:0;transform:scale(4);transition:0s}.btn-primary{background:var(--holo-gradient);box-shadow:var(--shadow-glow-primary);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-glow-primary),var(--shadow-md);filter:brightness(1.05);transform:translateY(-1px)}.btn-secondary{background:var(--surface-1);border:1.5px solid var(--border-default);box-shadow:var(--shadow-xs);color:var(--text-primary)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--primary-border);box-shadow:var(--shadow-sm)}.btn-danger{background:#dc26261f;border:1.5px solid var(--danger-border);color:var(--danger)}.btn-danger:hover{background:var(--danger);box-shadow:var(--shadow-glow-danger);color:#fff;transform:translateY(-1px)}.btn-success{background:var(--success-muted);border:1px solid var(--success-border);color:var(--success)}.btn-ghost{background:#0000;border:1px solid #0000;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-1);border-color:var(--border-subtle)}.btn-sm{border-radius:var(--radius-sm);font-size:var(--text-sm);padding:var(--space-1) var(--space-3)}.btn-lg{border-radius:var(--radius-lg);font-size:15px;padding:var(--space-3) var(--space-6)}.btn:disabled{box-shadow:none!important;cursor:not-allowed;filter:none!important;opacity:.45;transform:none!important}.btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.table-wrapper{-webkit-overflow-scrolling:touch;background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;font-size:var(--text-base);width:100%}thead tr{background:var(--surface-1)}th{border-bottom:1px solid var(--border-default);color:var(--text-tertiary);cursor:pointer;font-family:var(--font-display);font-size:var(--text-2xs);font-weight:700;letter-spacing:var(--tracking-wide);padding:var(--space-2-5) var(--space-3-5);text-align:left;text-transform:uppercase;transition:color var(--duration-fast);-webkit-user-select:none;user-select:none;white-space:nowrap}th:hover{color:var(--text-primary)}td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);max-width:200px;overflow:hidden;padding:var(--space-3) var(--space-3-5);text-overflow:ellipsis;white-space:nowrap}tr:last-child td{border-bottom:none}tr{transition:background var(--duration-fast)}tr:hover td{background:var(--surface-05)}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2-5);margin-bottom:var(--space-3-5)}.search-wrapper{position:relative}.search-icon{color:var(--text-disabled);font-size:var(--text-base);left:var(--space-3);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);min-width:220px;outline:none;padding:var(--space-2) var(--space-3) var(--space-2) 34px;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.search-input:focus{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.search-input::placeholder{color:var(--text-disabled)}.filter-select{appearance:none;background:var(--surface-0);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%2394A3B8' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-primary);cursor:pointer;font-family:var(--font-body);font-size:var(--text-base);outline:none;padding:var(--space-2) var(--space-7) var(--space-2) var(--space-3);transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.filter-select:focus{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.form-group{margin-bottom:var(--space-4)}.form-label{color:var(--text-secondary);display:block;font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-1-5);text-transform:uppercase}.form-label span{color:var(--danger);margin-left:var(--space-0-5)}.form-input,.form-select,.form-textarea{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-md);outline:none;padding:var(--space-2-5) var(--space-3);transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.form-input::placeholder{color:var(--text-disabled)}.form-textarea{line-height:var(--leading-relaxed);min-height:88px;resize:vertical}.form-grid{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:1fr 1fr}.form-hint{color:var(--text-disabled);font-size:var(--text-xs);margin-top:var(--space-1)}.alert{align-items:center;animation:slideInUp .3s var(--ease-smooth);border-left:3px solid;border-radius:var(--radius);display:flex;font-size:var(--text-base);font-weight:500;gap:var(--space-2);margin-bottom:var(--space-3-5);padding:var(--space-3) var(--space-3-5)}.alert-error{background:var(--danger-muted);border-color:var(--danger);color:var(--danger)}.alert-success{background:var(--success-muted);border-color:var(--success);color:var(--success)}.alert-warning{background:var(--warning-muted);border-color:var(--warning);color:var(--warning)}.modal-overlay{align-items:center;animation:fadeIn var(--duration-normal) ease;backdrop-filter:blur(var(--blur-sm));-webkit-backdrop-filter:blur(var(--blur-sm));background:#0f172a59;display:flex;inset:0;justify-content:center;padding:var(--space-5);position:fixed;z-index:var(--z-modal)}.modal{animation:scaleIn var(--duration-spring) var(--ease-smooth);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:620px;overflow-y:auto;width:100%}.modal,.modal-header{background:var(--surface-0)}.modal-header{align-items:center;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-4);position:sticky;top:0;z-index:var(--z-base)}.modal-header h3{color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-lg);font-weight:800}.modal-close{align-items:center;background:var(--surface-2);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;display:flex;font-size:15px;height:28px;justify-content:center;transition:var(--transition-fast);width:28px}.modal-close:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--text-primary)}.modal-body{padding:var(--space-5) var(--space-6)}.modal-footer{background:var(--surface-05);border-top:1px solid var(--border-subtle);display:flex;gap:var(--space-2-5);justify-content:flex-end;padding:var(--space-3-5) var(--space-6)}.loading-box{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:var(--space-3-5);justify-content:center;padding:var(--space-20) var(--space-5)}.spinner{animation:spin .7s linear infinite;border:3px solid var(--border-default);border-radius:var(--radius-full);border-top-color:var(--primary);height:32px;width:32px}.skeleton{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--surface-1) 0,var(--surface-2) 40%,var(--surface-1) 80%);background-size:200% 100%;border-radius:var(--radius)}.skeleton-text{border-radius:var(--radius-xs);height:14px;margin-bottom:var(--space-2)}.skeleton-card{border-radius:var(--radius-lg);height:120px}.empty-box{color:var(--text-tertiary);padding:var(--space-14) var(--space-5);text-align:center}.empty-box .empty-icon{font-size:40px;margin-bottom:var(--space-3-5);opacity:.5}.empty-box p{font-size:var(--text-base);font-weight:500}.login-page{align-items:center;background:var(--bg-gradient);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:var(--space-5);position:relative}.login-page:before{background:radial-gradient(ellipse 60% 50% at 20% 40%,#4f46e50f 0,#0000 60%),radial-gradient(ellipse 50% 40% at 80% 60%,#7c3aed0a 0,#0000 55%);content:"";inset:0;position:absolute}.login-page:after{background-image:radial-gradient(var(--neutral-300) .5px,#0000 .5px);background-size:24px 24px;content:"";inset:0;opacity:.4;position:absolute}.login-card{animation:scaleIn .5s var(--ease-smooth);background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-width:400px;padding:40px 36px;position:relative;width:100%;z-index:1}.login-logo-wrap{align-items:center;background:var(--holo-gradient);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow-primary);display:flex;font-size:22px;height:52px;justify-content:center;margin-bottom:var(--space-6);width:52px}.login-card h1{color:var(--text-primary);font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-1-5)}.login-card>p{color:var(--text-tertiary);font-size:var(--text-base);line-height:var(--leading-normal);margin-bottom:var(--space-7)}.topbar-right{gap:var(--space-2-5)}.topbar-avatar,.topbar-right{align-items:center;display:flex}.topbar-avatar{background:var(--holo-gradient);border-radius:var(--radius-full);box-shadow:var(--shadow-glow-primary);color:#fff;cursor:pointer;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;height:34px;justify-content:center;overflow:hidden;width:34px}.employee-grid{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.employee-card{animation:cardEntrance .5s var(--ease-smooth) both;background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-5);transition:transform var(--duration-spring) var(--ease-spring),box-shadow var(--duration-normal),border-color var(--duration-normal)}.employee-card:hover{border-color:var(--primary-border);box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.employee-mini-stats{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:1fr 1fr;margin-top:var(--space-3-5)}.employee-mini-stat{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--space-2) var(--space-2-5)}.employee-mini-stat-label{color:var(--text-tertiary);font-family:var(--font-display);font-size:var(--text-2xs);font-weight:700;letter-spacing:var(--tracking-wide);text-transform:uppercase}.employee-mini-stat-value{font-feature-settings:var(--tabular-nums);font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;margin-top:var(--space-px)}.overdue-banner{animation:slideInUp .3s var(--ease-smooth);background:var(--danger-muted);border:1px solid var(--danger-border);border-left:3px solid var(--danger);border-radius:var(--radius-lg);color:var(--danger);font-size:var(--text-base);font-weight:600;gap:var(--space-2-5);padding:var(--space-3) var(--space-4)}.overdue-banner,.welcome-banner{align-items:center;display:flex;margin-bottom:var(--space-5)}.welcome-banner{animation:fadeUp .5s var(--ease-smooth);background:var(--holo-gradient);border-radius:var(--radius-xl);box-shadow:var(--shadow-glow-primary);color:#fff;justify-content:space-between;overflow:hidden;padding:var(--space-7) var(--space-7);position:relative}.welcome-banner:before{background:#ffffff14;height:160px;right:-30px;top:-30px;width:160px}.welcome-banner:after,.welcome-banner:before{border-radius:var(--radius-full);content:"";position:absolute}.welcome-banner:after{background:#ffffff0d;bottom:-50px;height:120px;right:60px;width:120px}.welcome-text h2{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-1)}.welcome-text p{font-size:var(--text-base);opacity:.8}.welcome-emoji{animation:float 3s ease-in-out infinite;font-size:44px;position:relative;z-index:1}.incard-table{border:none;border-radius:0;box-shadow:none}.nav-badge{font-feature-settings:var(--tabular-nums);border-radius:var(--radius-pill);font-size:var(--text-2xs);font-weight:700;margin-left:auto;min-width:18px;padding:var(--space-px) var(--space-1-5);text-align:center}.nav-badge-pending{background:var(--warning);color:#fff}.nav-badge-overdue{background:var(--danger);color:#fff}.performance-section{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin:var(--space-6) 0;padding:var(--space-6)}.performance-header{margin-bottom:2rem}.performance-title{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.chart-legend{display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:center;margin-bottom:1.5rem}.legend-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.5rem;transition:var(--transition-normal)}.legend-dot{border-radius:var(--radius-full);height:8px;width:8px}.chart-container{align-items:flex-end;display:flex;gap:1.5rem;height:480px;min-width:100%;overflow-x:auto;overflow-y:hidden;padding:2.5rem 1rem 11rem 3.5rem;position:relative}.chart-container::-webkit-scrollbar{height:6px}.chart-container::-webkit-scrollbar-track{background:var(--surface-1);border-radius:var(--radius-pill)}.chart-container::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-pill)}.chart-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.chart-y-axis{color:var(--text-tertiary);font-size:.75rem;left:0;text-align:right;width:2.5rem}.chart-grid-wrapper,.chart-y-axis{bottom:11rem;display:flex;flex-direction:column;justify-content:space-between;position:absolute;top:2.5rem}.chart-grid-wrapper{left:3rem;pointer-events:none;right:1rem}.chart-grid-line{border-top:1px solid var(--border-subtle);height:0;width:100%}.performance-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%;justify-content:flex-end;min-width:80px;position:relative;z-index:1}.performance-bar{animation:progressGrow .8s var(--ease-smooth) both;background:var(--primary);border-radius:var(--radius-xs) var(--radius-xs) 0 0;cursor:pointer;opacity:.85;position:relative;transition:all var(--duration-slow) var(--ease-default);width:32px}.performance-bar:hover{filter:brightness(1.1);opacity:1;transform:scaleX(1.1)}.performance-bar-value{font-feature-settings:var(--tabular-nums);color:var(--text-primary);font-size:.8rem;font-weight:600;top:-24px}.performance-bar-label,.performance-bar-value{left:50%;position:absolute;transform:translateX(-50%)}.performance-bar-label{color:var(--text-tertiary);font-size:.7rem;font-weight:500;line-height:1.3;text-align:center;top:calc(100% + 12px);transition:color var(--duration-normal);white-space:normal;width:100px}.performance-bar-wrapper:hover .performance-bar-label{color:var(--primary);font-weight:600}.donut-card{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex:1 1;flex-direction:column;min-width:320px;padding:2rem;position:relative}.donut-title{color:var(--text-primary);font-size:1.15rem;font-weight:700;margin-bottom:2rem}.donut-wrapper{align-items:center;display:flex;height:240px;justify-content:center;margin:0 auto;position:relative;width:240px}.donut-center-text{display:flex;flex-direction:column;pointer-events:none;position:absolute;text-align:center}.donut-number{font-feature-settings:var(--tabular-nums);color:var(--text-primary);font-size:2.5rem;font-weight:800;line-height:var(--leading-none)}.donut-label{color:var(--text-tertiary);font-size:.9rem;margin-top:var(--space-1)}.donut-segment{transition:transform var(--duration-normal) var(--ease-spring)}.donut-segment:hover{transform:scale(1.03)}.grouped-chart-card{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin:var(--space-6) 0;padding:var(--space-6)}.grouped-bar-container{align-items:flex-end;display:flex;gap:4rem;height:600px;overflow-x:auto;overflow-y:hidden;padding:2.5rem 1rem 14rem 4rem;position:relative}.chart-y-axis-grouped{color:var(--text-tertiary);font-size:.75rem;left:0;padding-right:.5rem;text-align:right;width:3.5rem}.chart-y-axis-grouped,.grid-wrapper-grouped{bottom:14rem;display:flex;flex-direction:column;justify-content:space-between;position:absolute;top:2.5rem}.grid-wrapper-grouped{left:4rem;pointer-events:none;right:1rem}.bar-group{align-items:flex-end;display:flex;flex:0 0 150px;gap:2px;height:100%;justify-content:center;min-width:150px;position:relative}.group-bar{animation:progressGrow .8s var(--ease-smooth) both;border-radius:2px 2px 0 0;cursor:pointer;position:relative;transition:all var(--duration-slow) var(--ease-default);width:20px}.group-bar:hover{filter:brightness(1.15);transform:scaleY(1.03);z-index:5}.group-bar-label-value{color:var(--text-secondary);font-size:.65rem;font-weight:600;left:50%;opacity:0;position:absolute;top:-20px;transform:translateX(-50%);transition:opacity var(--duration-normal)}.group-bar:hover .group-bar-label-value{opacity:1}.group-title-label{color:var(--text-secondary);font-size:.75rem;font-weight:600;left:50%;line-height:1.3;position:absolute;text-align:center;top:calc(100% + 12px);transform:translateX(-50%);white-space:normal;width:140px}.chart-legend-horizontal{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem;padding:0 .5rem}.legend-item-horizontal{align-items:center;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.5rem}.dropdown-filter{appearance:none;-webkit-appearance:none;background-color:var(--surface-0);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:14px;border:1px solid var(--border-default);border-radius:var(--radius);box-shadow:var(--shadow-xs);color:var(--text-primary);cursor:pointer;font-size:.85rem;font-weight:600;min-width:200px;outline:none;padding:var(--space-2-5) 38px var(--space-2-5) var(--space-3-5);transition:var(--transition-normal)}.dropdown-filter:hover{background-color:var(--surface-05);border-color:var(--primary-border)}.dropdown-filter:focus{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.custom-select-trigger{align-items:center;background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius);box-shadow:var(--shadow-xs);cursor:pointer;display:flex;gap:var(--space-2);justify-content:space-between;min-height:46px;padding:var(--space-2-5) var(--space-3-5);transition:var(--transition-normal)}.custom-select-trigger:hover{background-color:var(--surface-05);border-color:var(--primary-border)}.custom-select-trigger.open{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.custom-select-value{color:var(--text-primary);flex:1 1;font-size:var(--text-md);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-value.placeholder{color:var(--text-disabled);font-weight:400}.custom-select-arrow{color:var(--text-tertiary);font-size:var(--text-2xs);transition:transform var(--duration-normal)}.custom-select-trigger.open .custom-select-arrow{transform:rotate(180deg)}.custom-select-dropdown{animation:slideInDown var(--duration-normal) var(--ease-out);background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--space-2);left:0;margin-top:var(--space-1-5);padding:var(--space-2);position:absolute;right:0;top:100%;z-index:var(--z-dropdown)}.custom-select-search-wrapper{align-items:center;display:flex;position:relative}.custom-select-search-wrapper .search-icon{font-size:var(--text-md);left:10px;position:absolute}.custom-select-search-input{background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:var(--text-base);outline:none;padding:var(--space-2) var(--space-3) var(--space-2) 34px;transition:var(--transition-normal);width:100%}.custom-select-search-input:focus{background:var(--surface-0);border-color:var(--primary-border);box-shadow:var(--focus-ring)}.custom-select-options{display:flex;flex-direction:column;gap:var(--space-0-5);max-height:400px;overflow-x:hidden;overflow-y:auto;padding-bottom:var(--space-3);padding-right:var(--space-1)}.custom-select-options::-webkit-scrollbar{width:6px}.custom-select-options::-webkit-scrollbar-track{background:#0000}.custom-select-options::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-pill)}.custom-select-option{align-items:center;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:var(--text-base);justify-content:space-between;line-height:var(--leading-snug);min-height:44px;padding:var(--space-2-5) var(--space-3);transition:var(--transition-fast)}.custom-select-option:hover{background-color:var(--surface-1);color:var(--primary)}.custom-select-option.selected{background-color:var(--primary-muted);color:var(--primary);font-weight:600}.custom-select-option.clear-option{border-bottom:1px solid var(--border-subtle);color:var(--text-disabled);font-style:italic;margin-bottom:var(--space-1)}.custom-select-no-results{color:var(--text-disabled);font-size:var(--text-base);padding:var(--space-4);text-align:center}.check-mark{color:var(--primary);font-weight:700}input[type=date]{cursor:pointer;position:relative}input[type=date]::-webkit-calendar-picker-indicator{background:#0000;bottom:0;color:#0000;cursor:pointer;height:100%;left:0;position:absolute;right:0;top:0;width:100%;z-index:2}input[type=date]:before{color:var(--text-disabled);content:attr(placeholder);font-family:var(--font-body);font-size:inherit;left:var(--space-3);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:1}input[type=date].has-value:before,input[type=date]:focus:before{content:""!important;display:none!important}input[type=date]:not(.has-value):not(:focus)::-webkit-datetime-edit{color:#0000!important}.chart-date-filter{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.chart-date-filter input[type=date]{background:var(--surface-0);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-sm);min-width:130px;outline:none;padding:var(--space-1-5) var(--space-2-5);transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.chart-date-filter input[type=date]:focus{border-color:var(--primary-border);box-shadow:var(--focus-ring)}.chart-date-filter .date-sep{color:var(--text-disabled);font-size:var(--text-xs)}.chart-date-filter .btn-reset-date{align-items:center;background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);transition:var(--transition-fast);white-space:nowrap}.chart-date-filter .btn-reset-date:hover{background:var(--danger-muted);border-color:var(--danger-border);color:var(--danger)}.date-input{background:var(--surface-0)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius)!important;box-sizing:border-box!important;color:var(--text-primary)!important;font-family:var(--font-body)!important;font-size:var(--text-base)!important;min-width:0!important;outline:none!important;padding:var(--space-2) var(--space-3)!important;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)!important;width:100%!important}.date-input:focus{border-color:var(--primary-border)!important;box-shadow:var(--focus-ring)!important}.date-range-group{align-items:center;display:flex;gap:var(--space-2);max-width:400px;width:100%}@media (max-width:1024px){:root{--sidebar-w:240px}.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){:root{--header-h:54px}.hamburger{display:block}.sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity var(--duration-slow) ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.sidebar{box-shadow:none;transform:translateX(-100%);width:260px}.sidebar.open{box-shadow:10px 0 30px #00000026;transform:translateX(0)}.main-content{margin-left:0;min-width:100%;transition:transform var(--duration-slow) var(--ease-default);width:100%}.page-content{padding:var(--space-3-5)}.topbar{padding:0 var(--space-3-5)}.stats-grid{gap:var(--space-2-5);grid-template-columns:repeat(2,1fr)}.stat-card{padding:var(--space-3-5)}.stat-card-value{font-size:24px}.stat-card-icon{font-size:18px;height:36px;margin-bottom:var(--space-2-5);width:36px}.form-grid{grid-template-columns:1fr}.welcome-banner{padding:var(--space-5) var(--space-5)}.welcome-emoji{display:none}.welcome-text h2{font-size:var(--text-lg)}.toolbar{align-items:stretch;flex-direction:column;gap:var(--space-2)}.search-input{min-width:0;min-width:auto;width:100%}.filter-select{width:100%}.toolbar .btn{justify-content:center;width:100%}.employee-grid{grid-template-columns:1fr}.modal{border-radius:var(--radius-lg)}.modal-body{padding:var(--space-4)}.modal-header{padding:var(--space-3-5) var(--space-4)}.page-header h1{font-size:17px}td,th{padding:var(--space-2) var(--space-3)}.chart-container{gap:1rem;height:400px;padding:1rem 1rem 11rem}.chart-y-axis{display:none}.chart-grid-wrapper{left:1rem}.performance-bar-wrapper{min-width:60px}.grouped-bar-container{gap:2rem;height:500px;padding:1rem 1rem 14rem}.chart-y-axis-grouped{display:none}.grid-wrapper-grouped{left:1rem}.bar-group{flex-basis:120px;min-width:120px}.date-range-group{max-width:100%;width:100%}}@media (max-width:480px){.stats-grid{gap:var(--space-2);grid-template-columns:1fr 1fr}.stat-card{padding:var(--space-3)}.stat-card-value{font-size:22px}.login-card{border-radius:var(--radius-xl);padding:var(--space-7) var(--space-5)}.login-card h1{font-size:var(--text-xl)}.welcome-banner{padding:var(--space-4)}.btn{padding:var(--space-2) var(--space-3)}.page-header h1{font-size:var(--text-lg)}.welcome-text p{font-size:var(--text-xs)}.topbar span{display:none}.topbar span:last-child{display:inline}}:focus{outline:none}:focus-visible{box-shadow:var(--focus-ring);outline:none}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:var(--focus-ring);outline:none}.kanban-action-btn-complete{transition:transform .2s var(--ease-spring),box-shadow .2s ease}.kanban-action-btn-complete:hover:not(:disabled){box-shadow:var(--shadow-md);filter:brightness(1.05);transform:translateY(-2px)}.kanban-action-btn-complete:active:not(:disabled){transform:translateY(0) scale(.98)}.kanban-card{animation:cardEntrance .4s var(--ease-smooth) both}.kanban-card:first-child{animation-delay:0ms}.kanban-card:nth-child(2){animation-delay:50ms}.kanban-card:nth-child(3){animation-delay:.1s}.kanban-card:nth-child(4){animation-delay:.15s}.kanban-card:nth-child(5){animation-delay:.2s}a,button,input,select,textarea{transition:all var(--duration-fast) var(--ease-default)}.modal,.table-wrapper{scroll-behavior:smooth}
/*# sourceMappingURL=main.e61ddbaa.css.map*/