@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--bg-main:#0b0f19;--bg-surface:#161c2db3;--bg-card:#1e293b66;--border-color:#ffffff14;--primary:#3875fa;--primary-hover:#1f64f9;--secondary:#925cf0;--success:#12ca6e;--warning:#f59f0a;--danger:#f43e5c;--text-main:#f8fafc;--text-muted:#94a3b8;--text-muted-dark:#64748b;--font-display:"Outfit", "Plus Jakarta Sans", system-ui, sans-serif;--font-sans:"Plus Jakarta Sans", system-ui, sans-serif;--shadow-sm:0 2px 8px -2px #00000080;--shadow-md:0 8px 30px -10px #0009;--shadow-lg:0 20px 50px -15px #000c;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-full:9999px;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-main);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 0 0,#2563eb1a 0,#0000 50%),radial-gradient(at 100% 100%,#8b5cf61a 0,#0000 50%);min-height:100vh;overflow-x:hidden}button,input,select,textarea{color:inherit;font-family:inherit}.glass-panel{background:var(--bg-surface);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-normal);padding:1.5rem}.glass-card:hover{border-color:#ffffff26;transform:translateY(-2px);box-shadow:0 12px 30px -10px #2563eb26}.app-container{min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;width:260px;height:100vh;padding:2rem 1.5rem;display:flex;position:sticky;top:0}.main-content{flex-grow:1;padding:2rem;overflow-y:auto}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;font-weight:600}h1{background:linear-gradient(135deg, #fff 30%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2.25rem}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-hover));box-shadow:0 4px 14px #2563eb66}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb80}.btn-secondary{border:1px solid var(--border-color);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-danger{background:linear-gradient(135deg, var(--danger), #f22648);box-shadow:0 4px 14px #ef444466}.btn-danger:hover{filter:brightness(1.1);box-shadow:0 6px 20px #ef444480}.form-group{flex-direction:column;gap:.375rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.form-control{border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:#0f172a99;padding:.625rem .875rem;font-size:.875rem}.form-control:focus{border-color:var(--primary);background:#0f172ae6;outline:none;box-shadow:0 0 0 3px #2563eb26}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.table-container{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#0f172a33;margin-top:1rem;overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}th{color:var(--text-muted);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;background:#161c2de6;padding:1rem;font-size:.75rem;font-weight:600}td{border-bottom:1px solid var(--border-color);color:var(--text-main);background:#161c2d33;padding:1rem}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.badge{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{color:#6a98fb;background:#2563eb26}.badge-success{color:#43ef99;background:#10b98126}.badge-warning{color:#f8bc54;background:#f59e0b26}.badge-danger{color:#f76e85;background:#ef444426}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;margin-top:1rem;display:grid}.calendar-day-header{text-align:center;color:var(--text-muted);padding:.5rem;font-size:.75rem;font-weight:600}.calendar-day{aspect-ratio:1.2;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:#1e293b33;flex-direction:column;justify-content:space-between;padding:.5rem;display:flex}.calendar-day:hover{background:#2563eb1a;border-color:#2563eb4d}.calendar-day.empty{opacity:.15;cursor:not-allowed;background:0 0;border-color:#0000}.calendar-day.public-holiday{background:#ef44441a;border-color:#ef44444d}.calendar-day.public-holiday .ph-tag{color:var(--danger);white-space:nowrap;text-overflow:ellipsis;font-size:.65rem;font-weight:600;overflow:hidden}.calendar-day.has-hours{background:#10b9810d;border-color:#10b98166}.calendar-day-number{font-size:.8125rem;font-weight:600}.calendar-day-hours{color:var(--success);text-align:right;margin-top:.25rem;font-size:.75rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);background:#111827;padding:2rem;position:relative}@media print{@page{size:A4 portrait;margin:0!important}html,body{background:#fff!important;height:297mm!important;max-height:297mm!important;margin:0!important;padding:0!important;overflow:hidden!important}body *{visibility:hidden}.no-print,.no-print *{visibility:hidden!important;display:none!important}.print-payslip,.print-payslip *{visibility:visible;color:#000!important;box-shadow:none!important;text-shadow:none!important;background:0 0!important}.print-payslip{box-sizing:border-box!important;background:#fff!important;border:none!important;width:210mm!important;height:297mm!important;padding:1.5cm!important;font-size:11px!important;line-height:1.3!important;position:absolute!important;top:0!important;left:0!important}.print-payslip h2{color:#000!important;margin-bottom:4px!important;font-size:1.45rem!important;font-weight:700!important}.print-payslip h3{color:#000!important;margin-bottom:4px!important;font-size:1.15rem!important;font-weight:700!important}.print-payslip h4{color:#000!important;border-bottom:1px solid #000!important;margin-bottom:.375rem!important;padding-bottom:2px!important;font-size:.75rem!important;font-weight:700!important}.print-payslip p{color:#000!important;margin:0!important;font-size:11px!important}.print-payslip table{border-collapse:collapse!important;border:1px solid #000!important;width:100%!important;margin-bottom:.75rem!important}.print-payslip th,.print-payslip td{color:#000!important;border:1px solid #000!important;padding:.35rem .5rem!important;font-size:11px!important}.print-payslip th{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#f1f5f9!important;font-weight:700!important}.print-payslip tr{page-break-inside:avoid}.print-payslip div[style*="margin-bottom: 2rem"],.print-payslip div[style*="margin-bottom: 1.5rem"]{margin-bottom:.75rem!important}.print-payslip div[style*="gap: 2rem"]{gap:1.5rem!important}.print-payslip div[style*="margin-top: 2.5rem"]{margin-top:1rem!important}.print-payslip div[style*="margin-top: 1.5rem"]{margin-top:.75rem!important}.print-payslip div[style*="padding: 0.75rem 1rem"]{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#f8fafc!important;border:1px solid #000!important;padding:.4rem .6rem!important}.print-payslip div[style*="border-bottom: 2px solid"]{border-bottom:2px solid #000!important}.print-payslip tr[style*="background: rgba(16, 185, 129, 0.08)"] td,.print-payslip tr[style*="background:rgba(16,185,129,0.08)"] td{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#e2e8f0!important;border-top:2px solid #000!important;border-bottom:2px solid #000!important}.print-payslip tr[style*="border-top: 2px solid"] td,.print-payslip tr[style*=borderTop] td{border-top:2px solid #000!important}.print-payslip tr[style*="background: rgba(255,255,255,0.03)"] td,.print-payslip tr[style*="background: rgba(255, 255, 255, 0.03)"] td{border-top:2px solid #000!important;border-bottom:2px solid #000!important}.print-payslip td[style*="color: var(--success)"],.print-payslip td[style*="color: var(--danger)"],.print-payslip span[style*="color: var(--primary)"]{color:#000!important}}.toast-container{z-index:2000;pointer-events:none;flex-direction:column;gap:.625rem;max-width:360px;display:flex;position:fixed;top:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);color:var(--text-main);pointer-events:auto;background:#111827f5;align-items:center;gap:.75rem;padding:.875rem 1rem;font-size:.875rem;font-weight:500;animation:.25s cubic-bezier(.4,0,.2,1) toast-slide-in;display:flex}.toast-icon{border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.toast-icon-success{color:#43ef99;background:#10b98126}.toast-icon-error{color:#f76e85;background:#ef444426}.toast-icon-info{color:#6a98fb;background:#2563eb26}.toast-message{flex:1;line-height:1.4}.toast-success{border-left:3px solid #14eb80}.toast-error{border-left:3px solid #f43e5c}.toast-info{border-left:3px solid var(--primary)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.mobile-menu-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;background:#0009;display:none;position:fixed;inset:0}.hamburger-btn{z-index:1001;-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-main);box-shadow:var(--shadow-md);background:#111827eb;justify-content:center;align-items:center;padding:.5rem;display:none;position:fixed;top:.75rem;left:.75rem}@media (width<=900px){:root{--mobile-pad:1rem}html,body{overflow-x:hidden}.app-container{flex-direction:column}.sidebar{z-index:999;border-right:1px solid var(--border-color);width:260px;height:100vh;margin:0;transition:transform .25s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:translate(0)}.sidebar-brand{margin-bottom:1.5rem!important}.mobile-menu-backdrop{pointer-events:none;opacity:0;transition:opacity .2s;display:block}.mobile-menu-backdrop.is-open{pointer-events:auto;opacity:1}.hamburger-btn{display:inline-flex}.main-content{width:100%;padding:1rem!important}.main-content>header,header.glass-panel{flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem!important;padding:.875rem 1rem!important}header.glass-panel>div{flex:100%;min-width:0}table{font-size:.8125rem}th,td{padding:.625rem .5rem!important}.dashboard-grid{grid-template-columns:1fr!important}.login-card{padding:1.5rem!important}.modal-content{max-width:95vw!important;padding:1.25rem!important}.toast-container{max-width:none;top:.75rem;left:.75rem;right:.75rem}.toast{font-size:.8125rem}h1{font-size:1.5rem!important}.empty-state-image{max-width:200px!important}}@media (width<=480px){.main-content{padding:.75rem!important}h1{font-size:1.375rem!important}}@keyframes spin-reverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}@keyframes pulse{0%{opacity:.8;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}to{opacity:.8;transform:scale(.95)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin;display:inline-block}
