@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--font-title:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#ffffffb3;--bg-card-hover:#ffffffe6;--border-color:#6366f11f;--border-focus:#6366f180;--primary:#4f46e5;--primary-hover:#4338ca;--primary-gradient:linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--success:#059669;--success-bg:#0596691a;--warning:#d97706;--warning-bg:#d977061a;--danger:#dc2626;--danger-bg:#dc26261a;--info:#0891b2;--info-bg:#0891b21a;--text-main:#0f172a;--text-muted:#64748b;--text-dark:#0f172a;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #00000026;--shadow-glow:0 0 15px #6366f159;--transition-fast:.15s ease;--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1.25rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-main);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);letter-spacing:-.02em;font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f199}.app-container{min-height:100vh;display:flex}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);width:260px;transition:all var(--transition-normal);z-index:10;flex-direction:column;flex-shrink:0;display:flex}.sidebar.collapsed{width:75px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1.75rem .5rem}.sidebar.collapsed .sidebar-logo-text{display:none}.sidebar.collapsed .sidebar-menu{padding:1.25rem .4rem}.sidebar.collapsed .sidebar-link{justify-content:center;gap:0;padding:.85rem}.sidebar.collapsed .sidebar-footer{padding:1rem .5rem}.sidebar.collapsed .user-profile-badge{flex-direction:column;justify-content:center;gap:.5rem}.sidebar-header{border-bottom:1px solid var(--border-color);align-items:center;gap:.75rem;padding:1.75rem;display:flex}.sidebar-logo-text{font-family:var(--font-title);background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-menu{flex-direction:column;flex:1;gap:.5rem;padding:1.25rem .75rem;list-style:none;display:flex}.sidebar-link{color:var(--text-muted);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;gap:.85rem;padding:.85rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--text-main);background-color:#6366f114}.sidebar-link.active{background:var(--primary-gradient);color:#fff;font-weight:600;box-shadow:0 4px 12px #6366f140}.sidebar-footer{border-top:1px solid var(--border-color);background-color:var(--bg-primary);padding:1.25rem}.user-profile-badge{align-items:center;gap:.75rem;display:flex}.user-avatar{background:var(--primary-gradient);width:42px;height:42px;font-weight:700;font-family:var(--font-title);color:#fff;border:2px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex}.main-header{background-color:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:9;justify-content:space-between;align-items:center;height:55px;padding:0 1.5rem;display:flex;position:sticky;top:0}.main-content{flex:1;padding:2rem;overflow-y:auto}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:transform var(--transition-normal), border-color var(--transition-normal);padding:1.5rem}.glass-card:hover{border-color:#6366f14d}.btn{font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-main);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-primary);border-color:#6366f14d}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){color:#fff;background:#ef4444}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-muted);margin-bottom:.45rem;font-size:.85rem;font-weight:500;display:block}.form-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-body);transition:all var(--transition-fast);padding:.75rem 1rem;font-size:.95rem}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f133}.form-select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-body);transition:all var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1.25rem;padding:.75rem 1rem;font-size:.95rem}.form-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f133}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;animation:fadeIn var(--transition-fast) forwards;background:#0f172a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:650px;box-shadow:var(--shadow-lg), 0 0 30px #6366f114;animation:zoomIn var(--transition-normal) forwards;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-body{max-height:75vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background:var(--bg-primary);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.loader-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:4px solid #6366f11a;border-top-color:var(--primary);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}.loading-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999;background:#fffc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.table-responsive{border-radius:var(--radius-md);border:1px solid var(--border-color);width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.custom-table th{background:var(--bg-primary);color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:1rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-main);background:0 0;padding:1rem}.custom-table tbody tr:hover td{background:#6366f10d}.badge{border-radius:50px;align-items:center;gap:.35rem;padding:.25rem .65rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-pending{background-color:var(--warning-bg);color:var(--warning)}.badge-approved{background-color:var(--success-bg);color:var(--success)}.badge-cancelled{background-color:var(--danger-bg);color:var(--danger)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.text-gradient{background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.grid-cols-4{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.grid-cols-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}@media (width<=1024px){.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-cols-4,.grid-cols-3{grid-template-columns:1fr}.sidebar{width:0;position:absolute;overflow:hidden}}.compact-dashboard-grid{grid-template-columns:1fr 2.5fr;align-items:stretch;gap:1.5rem;display:grid}@media (width<=1024px){.compact-dashboard-grid{grid-template-columns:1fr}}.mini-month-grid{grid-template-columns:repeat(7,1fr);gap:6px;margin-top:1rem;display:grid}.mini-day-header{text-align:center;color:var(--text-muted);padding-bottom:4px;font-size:.75rem;font-weight:600}.mini-day-cell{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex;position:relative}.mini-day-cell:hover{filter:brightness(1.2);transform:translateY(-2px)}.mini-day-cell.status-reported{background-color:var(--success-bg);color:#34d399;border:1px solid #10b98166}.mini-day-cell.status-missing{background-color:var(--danger-bg);color:#f87171;border:1px solid #ef444466}.mini-day-cell.status-leave{background-color:var(--info-bg);color:#22d3ee;border:1px solid #06b6d466}.mini-day-cell.status-holiday{background-color:var(--warning-bg);color:#fbbf24;border:1px solid #f59e0b66}.mini-day-cell.status-weekend{color:var(--text-muted);background-color:#ffffff08;border:1px solid #ffffff14}.mini-day-cell.empty{cursor:default;background-color:#0000;border:none}.mini-day-cell.empty:hover{filter:none;transform:none}.calendar-legend{flex-wrap:wrap;gap:1rem;margin-top:1rem;font-size:.8rem;display:flex}.legend-item{align-items:center;gap:.35rem;display:flex}.legend-color{border-radius:3px;width:12px;height:12px}.filter-bar{gap:1rem!important;padding:.85rem 1.25rem!important}.filter-bar .form-label{margin-bottom:.25rem;font-size:.75rem}.filter-bar .form-input,.filter-bar .form-select{height:38px;padding:.5rem .85rem;font-size:.85rem}.filter-bar .form-select{background-position:right .85rem center;background-size:1rem}.filter-bar .btn{align-items:center;gap:.35rem;height:38px;padding:.5rem 1rem;font-size:.85rem;display:inline-flex}.filter-bar .form-input[type=month],.filter-bar .form-input[type=date]{padding:.4rem .65rem}
