@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-50:#f0fdf9;--primary-100:#ccfbef;--primary-200:#99f6e0;--primary-300:#5eead4;--primary-400:#2dd4bf;--primary-500:#14b8a6;--primary-600:#0d9488;--primary-700:#0f766e;--primary-800:#115e59;--primary-900:#134e4a;--color-primary:var(--primary-600);--color-primary-hover:var(--primary-700);--color-primary-light:var(--primary-50);--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#3b82f6;--sidebar-width:260px;--header-height:64px;--border-radius:12px;--border-radius-sm:8px;--border-radius-lg:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--transition:.2s ease;--transition-slow:.3s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--gray-800);background-color:var(--gray-50);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}.app-layout{height:100vh;display:flex;overflow:hidden}.main-content{margin-left:var(--sidebar-width);transition:margin-left var(--transition-slow);flex-direction:column;flex:1;display:flex;overflow:hidden}.page-content{flex:1;padding:24px;overflow-y:auto}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--gray-200);z-index:100;transition:transform var(--transition-slow);box-shadow:var(--shadow-md);background:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--gray-100);align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 12px #0d94884d}.sidebar-logo-text{line-height:1.2}.sidebar-logo-title{color:var(--gray-900);font-size:16px;font-weight:700}.sidebar-logo-subtitle{color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.sidebar-nav{scrollbar-width:thin;scrollbar-color:var(--gray-200) transparent;flex:1;padding:12px;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.8px;color:var(--gray-400);margin-top:8px;padding:8px 8px 4px;font-size:10px;font-weight:600}.sidebar-item{border-radius:var(--border-radius-sm);color:var(--gray-600);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-item:hover{background:var(--primary-50);color:var(--primary-700)}.sidebar-item.active{background:linear-gradient(135deg, var(--primary-600), var(--primary-500));color:#fff;box-shadow:0 2px 8px #0d94884d}.sidebar-item.active .sidebar-item-icon{color:#fff}.sidebar-item-icon{flex-shrink:0;width:20px;font-size:16px}.sidebar-badge{background:var(--color-danger);color:#fff;text-align:center;border-radius:20px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.sidebar-item.active .sidebar-badge{background:#ffffff4d}.sidebar-user{border-top:1px solid var(--gray-100);align-items:center;gap:10px;padding:12px;display:flex}.sidebar-user-avatar{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.sidebar-user-info{flex:1;overflow:hidden}.sidebar-user-name{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--gray-400);font-size:11px}.header{height:var(--header-height);border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);background:#fff;flex-shrink:0;align-items:center;gap:16px;padding:0 24px;display:flex}.header-title{color:var(--gray-900);flex:1;font-size:18px;font-weight:700}.header-actions{align-items:center;gap:8px;display:flex}.header-icon-btn{border:1px solid var(--gray-200);cursor:pointer;width:36px;height:36px;color:var(--gray-500);transition:all var(--transition);background:#fff;border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.header-icon-btn:hover{background:var(--primary-50);color:var(--primary-600);border-color:var(--primary-200)}.card{border-radius:var(--border-radius);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);background:#fff;padding:20px}.card:hover{box-shadow:var(--shadow)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--gray-800);font-size:15px;font-weight:600}.stat-card{border-radius:var(--border-radius);border:1px solid var(--gray-200);transition:all var(--transition);cursor:default;background:#fff;align-items:center;gap:16px;padding:20px;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--primary-500), var(--primary-400));height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;display:flex}.stat-card-icon.teal{background:var(--primary-50);color:var(--primary-600)}.stat-card-icon.green{color:#16a34a;background:#f0fdf4}.stat-card-icon.orange{color:#ea580c;background:#fff7ed}.stat-card-icon.red{color:#dc2626;background:#fef2f2}.stat-card-icon.blue{color:#2563eb;background:#eff6ff}.stat-card-icon.purple{color:#7c3aed;background:#faf5ff}.stat-card-value{color:var(--gray-900);font-size:28px;font-weight:800;line-height:1}.stat-card-label{color:var(--gray-500);margin-top:4px;font-size:12px}.btn{border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.btn-outline{color:var(--gray-700);border:1px solid var(--gray-300);background:#fff}.btn-outline:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.btn-danger{background:var(--color-danger);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-active{color:#16a34a;background:#dcfce7}.badge-archived{background:var(--gray-100);color:var(--gray-500)}.badge-on-leave{color:#2563eb;background:#dbeafe}.badge-on-trip{color:#d97706;background:#fef3c7}.badge-late{color:#dc2626;background:#fee2e2}.badge-absent{color:#9d174d;background:#fce7f3}.badge-pending{color:#a16207;background:#fef9c3}.badge-approved{color:#166534;background:#dcfce7}.badge-rejected{color:#991b1b;background:#fee2e2}.table-container{border-radius:var(--border-radius);border:1px solid var(--gray-200);background:#fff;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--gray-100);flex-wrap:wrap;align-items:center;gap:12px;padding:16px 20px;display:flex}.form-group{margin-bottom:16px}.form-label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input{border:1px solid var(--gray-300);border-radius:var(--border-radius-sm);width:100%;transition:border-color var(--transition);color:var(--gray-800);outline:none;padding:9px 12px;font-size:14px}.form-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #14b8a61a}.login-page{background:linear-gradient(135deg,#0f766e 0%,#134e4a 50%,#0d9488 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#ffffff0d 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-100px;right:-100px}.login-page:after{content:"";background:radial-gradient(circle,#ffffff0d 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-50px;left:-50px}.login-card{z-index:1;background:#fff;border-radius:20px;width:100%;max-width:420px;padding:40px;position:relative;box-shadow:0 25px 50px #00000040}.login-logo{flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;font-weight:800;display:flex;box-shadow:0 8px 24px #0d94884d}.login-title{color:var(--gray-900);text-align:center;font-size:22px;font-weight:800}.login-subtitle{color:var(--gray-400);text-align:center;margin-top:2px;font-size:12px}.login-btn{background:linear-gradient(135deg, var(--primary-600), var(--primary-500));color:#fff;cursor:pointer;width:100%;transition:all var(--transition);border:none;border-radius:10px;margin-top:8px;padding:12px;font-size:15px;font-weight:600}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #0d948859}.login-btn:disabled{opacity:.7;cursor:not-allowed}.employee-card{border-radius:var(--border-radius);border:1px solid var(--gray-200);transition:all var(--transition);cursor:pointer;background:#fff;align-items:center;gap:14px;padding:16px;display:flex}.employee-card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md);transform:translateY(-1px)}.employee-avatar{object-fit:cover;background:var(--primary-50);width:48px;height:48px;color:var(--primary-600);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.map-container{border-radius:var(--border-radius);border:1px solid var(--gray-200);width:100%;overflow:hidden}.chart-container{border-radius:var(--border-radius);border:1px solid var(--gray-200);background:#fff;padding:20px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}}.ant-btn-primary{background-color:var(--primary-600)!important;border-color:var(--primary-600)!important}.ant-btn-primary:hover{background-color:var(--primary-700)!important;border-color:var(--primary-700)!important}.zoom-avatar{cursor:pointer;border:1px solid #0000;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .25s}.zoom-avatar:hover{transform:scale(2);z-index:1000!important;border-color:#0f766e!important;box-shadow:0 10px 15px -3px #0003,0 4px 6px -2px #0000001a!important}.align-middle-td td{vertical-align:middle!important}.align-middle-td .ant-space{align-items:center!important}
