@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&family=Inter:wght@300;400;500&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#f8faff;--bg-secondary:#f1f5ff;--bg-card:#fff;--bg-card-hover:#f8faff;--border:#4f46e51a;--border-light:#4f46e50f;--accent:#4f46e5;--accent-2:#6366f1;--accent-3:#818cf8;--accent-4:#a5b4fc;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--sidebar-w:260px;--header-h:64px;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #4f46e514;--shadow-lg:0 8px 48px #4f46e51f;--font-display:"Poppins",sans-serif;--font-body:"Inter",sans-serif;--transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}html{font-size:16px}body,html{height:100%}body{background-color:#fff;background-image:none;color:#0f172a;color:var(--text-primary);font-family:Inter,sans-serif;font-family:var(--font-body);line-height:1.6;overflow-x:hidden}#root,body{min-height:100vh}#root{display:flex;flex-direction:column;width:100%}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f5ff}::-webkit-scrollbar-thumb{background:#a5b4fc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#818cf8}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif;font-family:var(--font-display);font-weight:700;line-height:1.2}.app-loading{align-items:center;background:#f8faff;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh}.spinner{animation:spin .8s linear infinite;border:3px solid #4f46e51a;border-top-color:#4f46e5;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.layout,.main-content{display:flex;min-height:100vh}.main-content{flex:1 1;flex-direction:column;margin-left:260px;margin-left:var(--sidebar-w)}.page-content{animation:fadeInUp .3s ease;flex:1 1;margin-top:64px;margin-top:var(--header-h);padding:24px 32px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sidebar{background:#fff;border-right:1px solid #4f46e51a;border-right:1px solid var(--border);box-shadow:2px 0 16px #4f46e512;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:260px;width:var(--sidebar-w);z-index:100}.sidebar-logo{border-bottom:1px solid #4f46e51a;border-bottom:1px solid var(--border);gap:12px;padding:24px 20px}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{border-radius:10px;box-shadow:0 4px 12px #6c63ff4d;font-size:18px;height:36px;justify-content:center;width:36px}.logo-icon,.logo-text{background:linear-gradient(135deg,#4f46e5,#6366f1);background:linear-gradient(135deg,var(--accent),var(--accent-2))}.logo-text{-webkit-text-fill-color:#0000;-webkit-background-clip:text;font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:20px;font-weight:800}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 12px}.nav-section-label{color:#94a3b8;color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:1.5px;padding:12px 8px 6px;text-transform:uppercase}.nav-link{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.nav-link:hover{background:#6c63ff1a;color:#0f172a;color:var(--text-primary)}.nav-link.active{background:#6c63ff26;font-weight:600}.nav-link.active,.nav-link.active .nav-icon{color:#4f46e5;color:var(--accent)}.nav-icon{flex-shrink:0;height:18px;width:18px}.sidebar-user{border-top:1px solid #4f46e51a;border-top:1px solid var(--border);gap:12px;padding:16px}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#4f46e5,#6366f1);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:50%;color:#fff;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.user-info{flex:1 1;min-width:0}.user-name{truncate:clip;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:11px;gap:4px;text-transform:capitalize}.role-dot{border-radius:50%;display:inline-block;height:6px;width:6px}.role-dot.admin{background:#6366f1;background:var(--accent-2)}.role-dot.manager{background:#4f46e5;background:var(--accent)}.role-dot.employee{background:#818cf8;background:var(--accent-3)}.header{align-items:center;background:#fff;border-bottom:1px solid #4f46e51a;border-bottom:1px solid var(--border);box-shadow:0 2px 12px #4f46e512;display:flex;height:64px;height:var(--header-h);justify-content:space-between;left:260px;left:var(--sidebar-w);padding:0 32px;position:fixed;right:0;top:0;z-index:50}.header-title{font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:18px;font-weight:700}.header-actions{align-items:center;display:flex;gap:12px}.card{background:#fff;border:1px solid #4f46e51a;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 12px #4f46e50f;padding:20px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.card:hover{border-color:#4f46e50f;border-color:var(--border-light)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-title{font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:16px;font-weight:700}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:#fff;border:1px solid #4f46e51a;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 12px #4f46e50f;overflow:hidden;padding:20px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.stat-card:before{background:#4f46e5;background:var(--stat-color,var(--accent));content:"";height:3px;left:0;position:absolute;right:0;top:0}.stat-card:hover{border-color:#4f46e50f;border-color:var(--border-light);box-shadow:0 4px 24px #4f46e514;box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{align-items:center;background:color-mix(in srgb,#4f46e5 15%,#0000);background:color-mix(in srgb,var(--stat-color,var(--accent)) 15%,#0000);border-radius:10px;color:#4f46e5;color:var(--stat-color,var(--accent));display:flex;height:40px;justify-content:center;margin-bottom:12px;width:40px}.stat-value{font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}.stat-label{color:#475569;color:var(--text-secondary);font-size:13px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:14px;font-weight:600;gap:8px;padding:9px 18px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#4f46e5;background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#5b52f0;box-shadow:0 4px 12px #6c63ff66;transform:translateY(-1px)}.btn-secondary{background:#f8faff;background:var(--bg-card-hover);border:1px solid #4f46e50f;border:1px solid var(--border-light);color:#0f172a;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#4f46e51a;background:var(--border)}.btn-danger{background:#ff6b6b26;border:1px solid #ff6b6b4d;color:#ef4444;color:var(--danger)}.btn-danger:hover:not(:disabled){background:#ff6b6b40}.btn-success{background:#38d9a926;border:1px solid #38d9a94d;color:#10b981;color:var(--success)}.btn-success:hover:not(:disabled){background:#38d9a940}.btn-sm{font-size:12px;padding:6px 12px}.btn-icon{border-radius:8px;border-radius:var(--radius-sm);padding:8px}.form-group{margin-bottom:16px}.form-label{color:#475569;color:var(--text-secondary);display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-input,.form-select,.form-textarea{background:#f8faff;background:var(--bg-primary);border:1px solid #4f46e50f;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-sm);color:#0f172a;color:var(--text-primary);font-family:Inter,sans-serif;font-family:var(--font-body);font-size:14px;padding:10px 14px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4f46e5;border-color:var(--accent);box-shadow:0 0 0 3px #6c63ff26;outline:none}.form-textarea{min-height:100px;resize:vertical}.form-select option{background:#fff;background:var(--bg-card)}.form-error{color:#ef4444;color:var(--danger);font-size:12px;margin-top:4px}.table-container{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{color:#94a3b8;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.8px;padding:10px 16px;text-align:left;text-transform:uppercase}.table td,.table th{border-bottom:1px solid #4f46e51a;border-bottom:1px solid var(--border)}.table td{font-size:14px;padding:14px 16px;vertical-align:middle}.table tr:hover td{background:#ffffff05}.table tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.3px;padding:3px 10px;text-transform:capitalize}.badge-pending{background:#f7971e26;color:#a5b4fc;color:var(--accent-4)}.badge-in-progress{background:#6c63ff26;color:#4f46e5;color:var(--accent)}.badge-completed{background:#38d9a926;color:#10b981;color:var(--success)}.badge-submitted{background:#74c0fc26;color:#3b82f6;color:var(--info)}.badge-reviewed{background:#6c63ff26;color:#4f46e5;color:var(--accent)}.badge-approved{background:#38d9a926;color:#10b981;color:var(--success)}.badge-admin{background:#ff658426;color:#6366f1;color:var(--accent-2)}.badge-manager{background:#6c63ff26;color:#4f46e5;color:var(--accent)}.badge-employee{background:#43e97b26;color:#818cf8;color:var(--accent-3)}.badge-low{background:#74c0fc26;color:#3b82f6;color:var(--info)}.badge-medium{background:#f7971e26;color:#a5b4fc;color:var(--accent-4)}.badge-high{background:#ff6b6b26;color:#ef4444;color:var(--danger)}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideIn .2s ease;background:#fff;background:var(--bg-card);border:1px solid #4f46e50f;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 48px #4f46e51f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:520px;overflow-y:auto;width:100%}@keyframes slideIn{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 24px 0}.modal-title{font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:18px;font-weight:700}.modal-body{padding:0 24px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.stars{display:flex;gap:4px}.star{color:#4f46e50f;color:var(--border-light);cursor:pointer;font-size:22px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.star.active{color:#f59e0b;color:var(--warning)}.star:hover{transform:scale(1.2)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-title{font-size:24px;font-weight:800}.page-subtitle{color:#475569;color:var(--text-secondary);font-size:14px;margin-top:2px}.empty-state{color:#94a3b8;color:var(--text-muted);padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-title{color:#475569;color:var(--text-secondary);font-size:16px;font-weight:600;margin-bottom:6px}.empty-desc{font-size:14px}.filters{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.filter-select{background:#fff;background:var(--bg-card);border:1px solid #4f46e50f;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-sm);color:#0f172a;color:var(--text-primary);cursor:pointer;font-size:13px;padding:8px 12px}.search-input{flex:1 1;min-width:200px;position:relative}.search-input input{padding-left:36px;width:100%}.search-icon{color:#94a3b8;color:var(--text-muted);height:16px;left:10px;position:absolute;top:50%;transform:translateY(-50%);width:16px}.auth-page{display:flex;flex-direction:row;overflow:hidden}.auth-bg,.auth-page{min-height:100vh;position:relative}.auth-bg{background-attachment:fixed;background-image:url(/static/media/background.2b47263ac885da3e0e71.jpg);background-position:0;background-size:cover;flex:1 1}.auth-bg:after{background:linear-gradient(135deg,#4f46e573,#10b98140);content:"";inset:0;position:absolute}.auth-bg-brand{align-items:flex-start;color:#fff;display:flex;flex-direction:column;inset:0;justify-content:flex-end;padding:48px 52px;position:absolute;z-index:2}.auth-bg-brand h2{font-family:Poppins,sans-serif;font-family:var(--font-display);font-size:36px;font-weight:800;line-height:1.2;margin-bottom:12px;text-shadow:0 2px 12px #0000004d}.auth-bg-brand p{font-size:15px;line-height:1.6;max-width:360px;opacity:.88;text-shadow:0 1px 6px #00000040}.auth-panel{align-items:center;background:#fffffff7;box-shadow:-8px 0 48px #4f46e51f;display:flex;flex-direction:column;justify-content:center;min-height:100vh;min-width:380px;padding:48px 40px;position:relative;width:480px;z-index:10}.auth-card{background:#0000;border:none;border-radius:0;box-shadow:none;max-width:400px;padding:0;position:relative;width:100%;z-index:1}.auth-logo{align-items:center;display:flex;gap:12px;margin-bottom:36px}.auth-title{color:#0f172a;color:var(--text-primary);font-size:30px;font-weight:800;margin-bottom:6px}.auth-subtitle{color:#475569;color:var(--text-secondary);font-size:14px;margin-bottom:28px}@media (max-width:820px){.auth-page{flex-direction:column}.auth-bg{background-attachment:scroll;flex:none;min-height:220px}.auth-panel{box-shadow:none;min-height:auto;min-width:0;padding:36px 24px;width:100%}}.grid-2{grid-gap:16px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-gap:16px;grid-template-columns:repeat(3,1fr)}.scroll-list{display:flex;flex-direction:column;gap:8px}.list-item{align-items:center;background:#f8faff;border:1px solid #4f46e51a;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);display:flex;gap:12px;padding:12px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.list-item:hover{border-color:#4f46e50f;border-color:var(--border-light)}.progress-bar{background:#4f46e51a;background:var(--border);border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#4f46e5,#6366f1);background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px;height:100%;transition:width .5s ease}.chip{align-items:center;background:#4f46e51a;background:var(--border);border-radius:100px;color:#475569;color:var(--text-secondary);display:inline-flex;font-size:11px;padding:2px 8px}.alert{align-items:flex-start;border-radius:8px;border-radius:var(--radius-sm);display:flex;font-size:13px;gap:10px;margin-bottom:16px;padding:12px 16px}.alert-error{background:#ff6b6b1f;border:1px solid #ff6b6b40;color:#ff8f8f}.alert-success{background:#38d9a91f;border:1px solid #38d9a940;color:#10b981;color:var(--success)}.alert-info{background:#74c0fc1f;border:1px solid #74c0fc40;color:#3b82f6;color:var(--info)}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.main-content{margin-left:0}.page-content{padding:16px}.grid-2,.grid-3{grid-template-columns:1fr}}
/*# sourceMappingURL=main.baa9a03e.css.map*/