@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--primary-hue:206;--secondary-hue:0;--primary:#1d8ce0;--primary-light:#1d8ce01a;--primary-hover:#1670b3;--primary-glow:#1d8ce026;--secondary:#e7a842;--secondary-light:#fdf5e7;--success:#20b66b;--success-light:#e9fbf2;--warning:#f59f0a;--warning-light:#fef5e7;--danger:#e33d48;--danger-light:#e33d481a;--bg-app:#f0f4f8;--bg-sidebar:#fff;--surface:#fff;--surface-hover:#f9fafb;--text-main:#172136;--text-muted:#626d84;--text-light:#98a1b3;--text-white:#fff;--border-color:#e2e4e9;--border-light:#edeff2;--shadow-sm:0 2px 8px #0000000a;--shadow-md:0 4px 20px -2px #0000000f, 0 2px 6px -1px #00000008;--shadow-lg:0 12px 30px -4px #4f46e514, 0 4px 12px -2px #00000008;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-full:9999px;--font-heading:"Outfit", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}@keyframes pulse{0%{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}to{opacity:.6;transform:scale(.9)}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-main);font-weight:600}.app-container{width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-sidebar);width:260px;height:100%;transition:var(--transition-normal);color:var(--text-main);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;flex-shrink:0;display:flex}.sidebar.desktop-closed{border-right:none;width:0;padding:0;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:24px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--primary-hover));border-radius:var(--radius-md);justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 4px 12px #216ab44d}.logo-text{font-family:var(--font-heading);color:var(--primary);letter-spacing:-.5px;font-size:20px;font-weight:800}.logo-sub{color:var(--primary);letter-spacing:1px;font-size:10px;font-weight:600}.sidebar-menu{flex:1;padding:20px 14px;list-style:none;overflow-y:auto}.sidebar-menu::-webkit-scrollbar{width:4px}.sidebar-menu::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.sidebar-item{margin-bottom:4px}.sidebar-link{color:var(--text-muted);border-radius:var(--radius-md);transition:var(--transition-fast);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;text-decoration:none;display:flex}.sidebar-link:hover{background-color:var(--primary-light);color:var(--primary);transform:scale(1.02)}.sidebar-link.active{background:linear-gradient(to right, var(--primary), var(--primary-hover));color:var(--text-white);box-shadow:0 4px 15px #216ab433}.sidebar-link i,.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid var(--border-color);background-color:var(--surface-hover);color:var(--text-muted);text-align:center;padding:16px;font-size:11px}.main-layout{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.navbar{background-color:var(--surface);border-bottom:1px solid var(--border-color);z-index:90;height:70px;box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 32px;display:flex}.nav-left{align-items:center;gap:16px;display:flex}.page-title-badge{font-family:var(--font-heading);color:var(--text-main);align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.nav-right{align-items:center;gap:20px;display:flex}.role-simulator{background-color:var(--primary-light);border:1px dashed var(--primary);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:6px 12px;display:flex}.role-simulator label{color:var(--primary);text-transform:uppercase;font-size:11px;font-weight:600}.role-select{font-family:var(--font-body);color:var(--text-main);cursor:pointer;background:0 0;border:none;outline:none;font-size:13px;font-weight:600}.mobile-navbar-logo{object-fit:contain;border-radius:6px;width:32px;height:32px;display:none}.mobile-app-name{display:none}.notification-bell{border-radius:var(--radius-full);border:1px solid var(--border-color);cursor:pointer;width:40px;height:40px;transition:var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.notification-bell:hover{background-color:var(--surface-hover)}.bell-badge{background-color:var(--danger);border-radius:var(--radius-full);border:2px solid var(--surface);width:10px;height:10px;position:absolute;top:6px;right:6px}.profile-dropdown{cursor:pointer;border-radius:var(--radius-md);transition:var(--transition-fast);align-items:center;gap:12px;padding:4px 8px;display:flex}.notification-dropdown-container{background-color:var(--bg-app);border-radius:var(--radius-md);border:1px solid var(--border-color);z-index:1001;width:340px;animation:.2s ease-out forwards slideUp;position:absolute;top:calc(100% + 12px);right:0;overflow:hidden;box-shadow:0 8px 32px #00000026}.profile-dropdown:hover{background-color:var(--surface-hover)}.profile-avatar{border-radius:var(--radius-full);width:38px;height:38px;font-family:var(--font-heading);color:#fff;background:linear-gradient(135deg,#a78bfa,#818cf8);border:2px solid #fff;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex;box-shadow:0 0 10px #0000000d}.profile-info{flex-direction:column;display:flex}.profile-name{color:var(--text-main);font-size:13px;font-weight:600}.profile-role{color:var(--text-muted);font-size:11px}.content-container{flex:1;padding:32px;position:relative;overflow-y:auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.stat-card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);transition:transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:space-between;align-items:flex-start;padding:24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-info{flex-direction:column;gap:8px;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.stat-value{font-family:var(--font-heading);color:var(--text-main);font-size:28px;font-weight:700}.stat-meta{color:var(--text-light);margin-top:4px;font-size:12px}.stat-icon-wrapper{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-icon-wrapper.blue{color:var(--secondary);background-color:#e2edfd}.stat-icon-wrapper.purple{background-color:var(--primary-light);color:var(--primary)}.stat-icon-wrapper.green{background-color:var(--success-light);color:var(--success)}.stat-icon-wrapper.yellow{background-color:var(--warning-light);color:var(--warning)}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:24px;margin-bottom:32px;display:grid}.pic-dashboard-grid{grid-template-columns:1.5fr 1fr;gap:24px;margin-bottom:32px;display:grid}.chart-card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);flex-direction:column;height:380px;padding:24px;display:flex}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-title{font-size:16px;font-weight:600}.chart-body{flex:1;justify-content:center;align-items:center;display:flex;position:relative}.table-card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);margin-bottom:32px;overflow:hidden}.table-header{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.table-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.table-search{position:relative}.table-search input{border-radius:var(--radius-sm);border:1px solid var(--border-color);font-family:var(--font-body);width:220px;transition:var(--transition-fast);outline:none;padding:8px 12px 8px 36px;font-size:13px}.table-search input:focus{border-color:var(--primary);box-shadow:var(--primary-glow)}.table-search svg{color:var(--text-light);width:16px;height:16px;position:absolute;top:9px;left:12px}.table-filter-select{border-radius:var(--radius-sm);border:1px solid var(--border-color);font-family:var(--font-body);background-color:var(--surface);color:var(--text-main);cursor:pointer;outline:none;padding:8px 12px;font-size:13px}.table-filter-select:focus{border-color:var(--primary)}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;transition:transform .1s, box-shadow var(--transition-fast);border:none;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;display:flex}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #216ab440}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-main);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;transition:var(--transition-fast);background-color:#fff;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.btn-secondary:hover{background-color:var(--surface-hover);border-color:var(--text-light)}.responsive-table-container{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:13px}.data-table th{background-color:var(--surface-hover);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:14px 24px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border-light);color:var(--text-main);vertical-align:middle;padding:16px 24px}.data-table tbody tr:hover{background-color:var(--border-light)}.badge{border-radius:var(--radius-full);text-transform:uppercase;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge.badge-success{background-color:var(--success-light);color:var(--success)}.badge.badge-warning{background-color:var(--warning-light);color:var(--warning)}.badge.badge-danger{background-color:var(--danger-light);color:var(--danger)}.badge.badge-blue{background-color:var(--secondary-light);color:var(--secondary)}.badge.badge-purple{background-color:var(--primary-light);color:var(--primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background-color:#0f172a66;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:580px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);animation:.25s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden}.modal-content.modal-lg{max-width:800px}.modal-content.modal-xl{max-width:1100px}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:18px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-light);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{color:var(--danger)}.modal-body{max-height:70vh;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background-color:var(--surface-hover);justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px;display:flex}.form-group{margin-bottom:18px}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-control{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);transition:var(--transition-fast);outline:none;padding:10px 14px;font-size:13px}.form-control:focus{border-color:var(--primary);box-shadow:var(--primary-glow)}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.salary-template-preview{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:12px;padding:16px}.salary-preview-title{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:600}.salary-preview-grid{grid-template-columns:repeat(2,1fr);gap:10px;font-size:12px;display:grid}.salary-preview-item{flex-direction:column;display:flex}.salary-preview-label{color:var(--text-light)}.salary-preview-value{color:var(--text-main);margin-top:2px;font-weight:600}.attendance-layout{grid-template-columns:360px 1fr;align-items:start;gap:24px;display:grid}.radar-card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);text-align:center;padding:24px}.face-scanner-container{border-radius:var(--radius-md);border:2px solid var(--primary-light);background-color:#020617;justify-content:center;align-items:center;width:100%;height:220px;margin-bottom:20px;display:flex;position:relative;overflow:hidden}.webcam-simulated{object-fit:cover;opacity:.7;width:100%;height:100%}.camera-fallback{color:var(--text-white);flex-direction:column;align-items:center;gap:8px;font-size:13px;display:flex}.scanner-overlay{pointer-events:none;box-sizing:border-box;width:100%;height:100%;position:absolute;top:0;left:0}.scan-line{background:linear-gradient(to right, transparent, var(--primary), var(--secondary), transparent);width:100%;height:3px;box-shadow:0 0 12px var(--primary);animation:3s linear infinite scan;position:absolute;top:0}.scan-corners{border-radius:var(--radius-sm);border:1.5px dashed #ffffff59;position:absolute;inset:20px}.scan-status-text{color:#fff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:1px;background-color:#0f172ad9;padding:4px 10px;font-size:10px;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.gps-radar{border-radius:var(--radius-full);border:1px solid var(--border-color);background-color:var(--surface-hover);justify-content:center;align-items:center;width:140px;height:140px;margin:0 auto 20px;display:flex;position:relative;overflow:hidden}.radar-sweep{background:conic-gradient(from 0deg, var(--primary-glow) 0deg, transparent 180deg);border-radius:var(--radius-full);pointer-events:none;width:100%;height:100%;animation:4s linear infinite rotate;position:absolute}.radar-ping{background-color:var(--secondary);border-radius:var(--radius-full);width:12px;height:12px;box-shadow:0 0 10px var(--secondary);animation:1.5s ease-in-out infinite pulse;position:absolute}.gps-status-indicator{border-radius:var(--radius-md);margin-bottom:20px;padding:12px;font-size:12px;line-height:1.5}.gps-status-indicator.success{background-color:var(--success-light);color:var(--success);border:1px solid #10b98133}.gps-status-indicator.error{background-color:var(--danger-light);color:var(--danger);border:1px solid #ef444433}.gps-demo-switch{border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:20px;display:flex;overflow:hidden}.gps-demo-btn{font-family:var(--font-body);cursor:pointer;transition:var(--transition-fast);background:#fff;border:none;flex:1;padding:8px;font-size:11px;font-weight:600}.gps-demo-btn.active{background-color:var(--text-main);color:#fff}.calendar-container{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);padding:24px}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.calendar-day-label{text-align:center;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:10px 0;font-size:11px;font-weight:600}.calendar-day-cell{border:1px solid var(--border-light);border-radius:var(--radius-sm);background-color:var(--surface);cursor:pointer;min-height:100px;transition:var(--transition-fast);flex-direction:column;justify-content:space-between;padding:8px;display:flex}.calendar-day-cell:hover{background-color:var(--surface-hover);border-color:var(--text-light)}.calendar-day-cell.other-month{opacity:.3}.day-number{color:var(--text-main);font-size:12px;font-weight:600}.calendar-shift-badge{text-align:center;text-transform:uppercase;border-radius:4px;margin-top:4px;padding:2px 6px;font-size:9px;font-weight:700}.calendar-shift-badge.pagi{color:var(--secondary);background-color:#e2edfd}.calendar-shift-badge.siang,.calendar-shift-badge.shift{background-color:var(--primary-light);color:var(--primary)}.calendar-shift-badge.malam{color:#7322c3;background-color:#ebdcf9}.calendar-shift-badge.off{color:var(--text-muted);background-color:#e3e5e8}.scheduling-layout{grid-template-columns:1.5fr 1fr;gap:24px;display:grid}@media (width<=1024px){.scheduling-layout{grid-template-columns:1fr}}@media (width<=768px){.calendar-container{padding:12px}.calendar-day-cell{min-height:70px;padding:6px}.calendar-shift-badge{margin-top:2px;padding:1px 2px;font-size:8px}}.matrix-select{text-align-last:center;appearance:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;outline:none;width:50px;padding:4px 6px;font-size:11px;font-weight:700;transition:all .15s}.matrix-select:hover{filter:brightness(.95)}.matrix-select.pagi{color:var(--secondary);background-color:#e2edfd}.matrix-select.siang,.matrix-select.shift{background-color:var(--primary-light);color:var(--primary)}.matrix-select.malam{color:#7322c3;background-color:#ebdcf9}.matrix-select.off{color:var(--text-muted);background-color:#e3e5e8}.payroll-split-layout{grid-template-columns:1.2fr 1fr;align-items:stretch;gap:24px;height:calc(100vh - 210px);min-height:500px;display:grid}.payroll-pane-left,.payroll-pane-right{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);flex-direction:column;display:flex;overflow:hidden}.payroll-pane-header{border-bottom:1px solid var(--border-color);background-color:var(--surface-hover);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.payroll-pane-title{color:var(--text-main);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.payroll-table-wrapper{flex:1;overflow:auto}.excel-style-payroll{border-collapse:collapse;width:100%;font-size:12px}.excel-style-payroll th{color:#334155;text-align:left;background-color:#f1f5f9;border:1px solid #cbd5e1;padding:8px 12px;font-weight:600;position:sticky;top:0}.excel-style-payroll td{color:#334155;border:1px solid #e2e8f0;padding:10px 12px}.excel-style-payroll tbody tr:hover{background-color:#f8fafc}.payroll-slip-preview{flex:1;padding:24px;overflow-y:auto}.slip-header-info{text-align:center;border-bottom:2px dashed var(--border-color);margin-bottom:20px;padding-bottom:16px}.slip-company{font-family:var(--font-heading);color:var(--primary);font-size:16px;font-weight:700}.slip-subtitle{color:var(--text-light);margin-top:4px;font-size:11px}.slip-emp-details{border-bottom:1px solid var(--border-light);grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;padding-bottom:16px;font-size:12px;display:grid}.slip-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:11px;font-weight:700}.slip-row{justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.slip-row.total{color:var(--text-main);border-top:1px solid var(--border-color);margin-top:12px;padding-top:8px;font-weight:700}.slip-row.net-pay{background-color:var(--primary-light);border-radius:var(--radius-sm);color:var(--primary);border:1px solid #6366f133;margin-top:16px;padding:12px;font-size:15px;font-weight:700}.approval-progress-wrapper{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);margin-bottom:24px;padding:32px 24px}.stepper-container{justify-content:space-between;align-items:center;max-width:600px;margin:0 auto;display:flex;position:relative}.stepper-line{background-color:var(--border-color);z-index:1;height:4px;position:absolute;top:24px;left:0;right:0}.stepper-line-progress{background-color:var(--primary);z-index:2;height:4px;transition:width .3s;position:absolute;top:24px;left:0}.stepper-step{z-index:3;flex-direction:column;align-items:center;display:flex;position:relative}.step-circle{border-radius:var(--radius-full);background-color:var(--surface);border:3px solid var(--border-color);width:52px;height:52px;color:var(--text-light);transition:var(--transition-normal);justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.stepper-step.active .step-circle{border-color:var(--primary);color:var(--primary);box-shadow:0 0 15px var(--primary-glow)}.stepper-step.completed .step-circle{border-color:var(--success);background-color:var(--success);color:#fff}.step-label{color:var(--text-muted);margin-top:10px;font-size:12px;font-weight:600}.stepper-step.active .step-label{color:var(--primary)}.stepper-step.completed .step-label{color:var(--success)}.permissions-matrix-table{border-collapse:collapse;width:100%}.permissions-matrix-table th{background-color:var(--surface-hover);border:1px solid var(--border-color);text-align:center;padding:14px 20px;font-size:12px;font-weight:600}.permissions-matrix-table td{border:1px solid var(--border-color);vertical-align:middle;padding:12px 20px;font-size:13px}.permission-feature-name{color:var(--text-main);font-weight:600}.permission-feature-desc{color:var(--text-light);margin-top:2px;font-size:11px}.checkbox-center{justify-content:center;align-items:center;display:flex}.custom-checkbox{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scan{0%,to{opacity:0;top:0%}10%,90%{opacity:1}50%{top:98%}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ui-alert-locked{background-color:var(--danger-light);color:var(--danger);border-radius:var(--radius-md);border:1px solid #ef444433;align-items:center;gap:12px;margin-bottom:24px;padding:16px;font-size:13px;font-weight:500;display:flex}.ui-alert-locked svg{width:20px;height:20px}.locked-badge{background-color:var(--danger-light);border:1px solid var(--danger);color:var(--danger)}select.form-control{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 14px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}@media (width<=1024px){.payroll-split-layout{grid-template-columns:1fr;gap:20px;height:auto;min-height:auto}.payroll-pane-right{min-width:0}}@media (width<=768px){body{overflow-x:hidden}.app-container{flex-direction:column;width:100vw;height:100vh}.sidebar{z-index:999;width:260px;height:100vh;box-shadow:none;transition:transform .3s cubic-bezier(.16,1,.3,1);position:fixed;top:0;left:0;transform:translate(-100%);display:flex!important}.sidebar.open{transform:translate(0);box-shadow:5px 0 25px #0f172a40}.sidebar-close-btn{display:flex!important}.mobile-hamburger-btn{display:none!important}.mobile-navbar-logo{margin-right:8px;display:block!important}.mobile-app-name{color:var(--primary);letter-spacing:-.5px;margin-right:8px;font-size:15px;font-weight:800;display:flex!important}.hide-on-mobile{display:none!important}.navbar{height:60px;box-shadow:var(--shadow-sm);padding:0 16px}.profile-dropdown{padding:4px}.profile-info{display:none}.notification-bell{width:36px;height:36px}.notification-dropdown-container{width:auto;max-height:calc(100vh - 80px);position:fixed;top:65px;left:16px;right:16px;box-shadow:0 10px 40px #0003}.page-title-badge{font-size:16px}.content-container{height:calc(100vh - 60px);padding:16px 16px 90px;overflow-y:auto}.stats-grid{gap:12px;margin-bottom:20px;grid-template-columns:1fr!important}.charts-grid,.pic-dashboard-grid{gap:20px;margin-bottom:20px;grid-template-columns:1fr!important}.chart-card{height:auto;min-height:320px}.form-grid{gap:12px;grid-template-columns:1fr!important}.attendance-layout{gap:20px;grid-template-columns:1fr!important}.responsive-table-container{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.mobile-bottom-nav{-webkit-backdrop-filter:blur(24px)saturate(180%);backdrop-filter:blur(24px)saturate(180%);z-index:990;background:#fffffff2;border-top:1px solid #fffc;border-radius:24px 24px 0 0;justify-content:space-around;align-items:stretch;width:100%;height:70px;padding:0 16px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #00000014}.mobile-nav-item{height:100%;color:var(--text-muted);cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;min-width:0;font-size:10px;font-weight:600;text-decoration:none;display:flex;position:relative}.mobile-nav-icon-container{width:36px;height:36px;color:var(--text-light);z-index:2;border-radius:12px;justify-content:center;align-items:center;margin-bottom:4px;transition:all .3s;display:flex}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item.active .mobile-nav-icon-container{background:var(--primary-light);color:var(--primary);transform:scale(1.05)}.mobile-nav-item span{opacity:.8;transition:all .3s}.mobile-nav-item.active span{opacity:1;font-weight:700}.modal-content{border-radius:20px 20px 0 0!important;width:100%!important;max-width:none!important}.payroll-split-layout{gap:16px;grid-template-columns:1fr!important;height:auto!important;min-height:auto!important}.premium-payroll-left,.premium-payroll-right{max-width:100vw;overflow:hidden;min-width:0!important}.premium-payroll-right{order:-1}.premium-payroll-header{flex-wrap:wrap;gap:8px;padding:12px 14px}.premium-payroll-title{font-size:14px!important}.premium-payroll-title span{font-size:14px}.payroll-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.excel-style-payroll{min-width:600px;font-size:10px!important}.excel-style-payroll th{padding:6px 8px;font-size:9px}.excel-style-payroll td{padding:6px 8px;font-size:10px}.payroll-slip-preview{padding:16px!important;font-size:11px!important}.slip-row{gap:8px;font-size:11px}.slip-row>span:first-child{word-break:break-word;flex-shrink:1;min-width:0}.slip-row>span:last-child{text-align:right;white-space:nowrap;flex-shrink:0}.payroll-slip-preview table{table-layout:fixed;width:100%;font-size:10px}.payroll-slip-preview table td{word-break:break-word;padding:6px 4px;font-size:10px}.payroll-slip-preview table td:last-child{white-space:nowrap;text-align:right;width:35%}.ui-alert-locked{flex-direction:row;align-items:flex-start;gap:8px;padding:12px;font-size:11px}.ui-alert-locked span{font-size:11px;line-height:1.4}}@media (width>=769px){.mobile-bottom-nav{display:none}}.weekly-day-card{transition:transform var(--transition-fast), box-shadow var(--transition-fast)!important}.weekly-day-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)!important}.premium-payroll-layout{grid-template-columns:1.3fr 1fr;align-items:stretch;gap:24px;height:calc(100vh - 120px);min-height:500px;display:grid}@media (width<=1024px){.premium-payroll-layout{grid-template-columns:1fr;height:auto}}.premium-payroll-left,.premium-payroll-right{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#ffffffb3;border:1px solid #ffffff80;flex-direction:column;transition:box-shadow .3s;display:flex;position:relative;overflow:hidden}.premium-payroll-left:hover,.premium-payroll-right:hover{box-shadow:var(--shadow-lg)}.premium-payroll-header{border-bottom:1px solid var(--border-color);z-index:2;background:linear-gradient(135deg,#ffffffe6,#f0f4f8e6);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 24px;display:flex}.premium-payroll-title{font-family:var(--font-heading);color:var(--primary);align-items:center;gap:10px;font-size:16px;font-weight:700;display:flex}.premium-btn-download{color:#fff;border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;background:linear-gradient(135deg,#4f46e5,#3b82f6);border:none;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #3b82f64d}.premium-btn-download:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.premium-btn-download:active{transform:translateY(0)}.premium-payroll-table-wrapper{background:#fff;flex:1;padding:0;overflow:auto}.premium-payroll-table{border-collapse:separate;border-spacing:0;width:100%;font-size:12px}.premium-payroll-table th{background:var(--surface-hover);color:var(--text-muted);text-align:left;z-index:10;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:11px;font-weight:600;position:sticky;top:0}.premium-payroll-table td{color:var(--text-main);border-bottom:1px solid var(--border-light);padding:12px 16px;transition:background-color .15s}.premium-payroll-table tr.even-row{background-color:#fafbfc}.premium-payroll-table tr.odd-row{background-color:#fff}.premium-payroll-table tr:hover td{background-color:var(--primary-light)}.premium-slip-preview{flex:1;padding:24px;overflow-y:auto}.slip-content-wrapper{width:100%;position:relative}.slip-watermark{font-size:64px;font-family:var(--font-heading);color:#216ab408;pointer-events:none;white-space:nowrap;z-index:0;font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-30deg)}.slip-divider{background-color:var(--border-color);height:1px;margin:16px 0}.slip-divider.dashed{border-top:1px dashed var(--border-color);background-color:#0000}.premium-badge{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);padding:4px 8px;font-size:11px;font-weight:700}.premium-badge.success{background:var(--success-light);color:var(--success)}.premium-badge.neutral{background:var(--border-light);color:var(--text-muted)}.premium-badge.small{padding:2px 6px;font-size:10px}.danger-text{color:var(--danger)}.success-text{color:var(--success);font-weight:600}.total-gaji{color:var(--text-main);border-radius:var(--radius-sm);border-left:3px solid var(--primary);background:#f8fafc;margin-top:16px;padding:12px;font-size:14px;font-weight:700}.premium-bpjs-card{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;margin-top:24px;padding:16px}.bpjs-row{color:var(--text-muted);justify-content:space-between;margin-bottom:8px;font-size:11px;display:flex}.bpjs-row:last-child{margin-bottom:0}.bpjs-row span:last-child{color:var(--danger);font-weight:600}.premium-take-home-pay{background:linear-gradient(135deg, var(--primary), var(--primary-hover));border-radius:var(--radius-md);color:#fff;text-align:center;margin-top:24px;padding:20px;animation:3s ease-in-out infinite pulse;box-shadow:0 8px 24px #216ab440}.thp-label{opacity:.9;letter-spacing:1px;font-size:12px;font-weight:600}.thp-amount{font-family:var(--font-heading);margin-top:4px;font-size:28px;font-weight:700}.premium-empty-state{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.premium-empty-state p{color:var(--text-main);margin-top:16px;font-size:16px;font-weight:600}.premium-empty-state span{margin-top:8px;font-size:13px}.slip-header-modern{border-bottom:2px dashed var(--border-color);justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:24px;display:flex}.slip-emp-name{font-size:22px;font-family:var(--font-heading);color:var(--primary);margin-bottom:6px;font-weight:800}.slip-emp-role{color:var(--text-muted);font-size:13px;font-weight:500}.slip-period-box{border:1px dashed var(--border-color);border-radius:var(--radius-sm);text-align:right;background:0 0;flex-direction:column;padding:8px 16px;display:flex}.period-label{color:var(--text-light);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:700}.period-value{color:var(--text-main);margin-top:2px;font-size:16px;font-weight:800}.slip-body-modern{flex-direction:column;gap:24px;display:flex}.slip-section{background:0 0}.slip-section.bg-light{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#ffffff4d;padding:16px}.slip-section-title{color:var(--text-main);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:8px;font-size:14px;font-weight:700;display:flex}.slip-section-title.text-danger{color:var(--danger)}.slip-items-grid{flex-direction:column;gap:12px;display:flex}.slip-items-grid.bpjs{gap:8px}.slip-item{justify-content:space-between;align-items:center;font-size:12px;display:flex}.item-label{color:var(--text-muted);align-items:center;gap:8px;display:flex}.item-value{color:var(--text-main);font-weight:500}.item-value.highlight{font-weight:700}.slip-subtotal{border-top:1px dashed var(--border-color);color:var(--text-main);justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;font-size:13px;font-weight:700;display:flex}.slip-subtotal.danger{color:var(--danger)}.subtotal-val{font-size:14px}.slip-gross-pay{background:var(--primary-light);border-radius:var(--radius-md);color:var(--primary);border-left:4px solid var(--primary);justify-content:space-between;align-items:center;padding:16px;font-size:16px;font-weight:700;display:flex}.mini-badge{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);letter-spacing:.5px;padding:2px 6px;font-size:9px;font-weight:800}.mini-badge.success{background:var(--success-light);color:var(--success)}.mini-badge.neutral{background:var(--border-color);color:var(--text-muted)}.text-danger{color:var(--danger)!important}.text-success{color:var(--success)!important}.bold{font-weight:700!important}.slip-footer-modern{border-top:2px dashed var(--border-color);margin-top:32px;padding-top:24px}.thp-modern-card{background:linear-gradient(135deg, var(--primary), var(--primary-hover));border-radius:var(--radius-lg);color:#fff;align-items:center;gap:20px;padding:20px 24px;animation:3s ease-in-out infinite pulse;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px #216ab44d}.thp-icon{border-radius:var(--radius-md);background:#fff3;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.thp-details{flex-direction:column;display:flex}.thp-details .thp-label{letter-spacing:1px;opacity:.9;margin-bottom:4px;font-size:11px;font-weight:700}.thp-details .thp-amount{font-size:26px;font-weight:800;font-family:var(--font-heading)}.profile-banner{background:linear-gradient(135deg, var(--primary) 0%, #60a5fa 100%);align-items:flex-end;height:160px;padding:0 40px;display:flex;position:relative;overflow:visible}.profile-avatar-container{border:5px solid var(--surface);background-color:var(--primary-light);width:110px;height:110px;color:var(--primary);z-index:10;background-position:50%;background-size:cover;border-radius:50%;justify-content:center;align-items:center;margin-bottom:-40px;font-size:36px;font-weight:700;transition:transform .3s;display:flex;box-shadow:0 8px 16px #0000001a}.profile-avatar-container:hover{transform:translateY(-5px)}.profile-header-info{color:#fff;margin-bottom:20px;margin-left:24px}.profile-header-name{font-size:26px;font-weight:700;font-family:var(--font-heading);text-shadow:0 2px 4px #00000026;margin-bottom:6px}.profile-badges{flex-wrap:wrap;gap:8px;display:flex}.profile-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);text-shadow:0 1px 2px #0000001a;background:#ffffff40;border:1px solid #ffffff4d;padding:6px 14px;font-size:11px;font-weight:700;box-shadow:0 2px 8px #0000000d}.profile-tabs-wrapper{background:var(--surface);border-bottom:1px solid var(--border-light);gap:32px;padding:45px 32px 0;display:flex;overflow-x:auto}.profile-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;padding:14px 0;font-size:14px;font-weight:600;transition:all .2s}.profile-tab:hover{color:var(--primary)}.profile-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-body{background:var(--surface);padding:32px 40px}.profile-password-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light);margin-top:24px;overflow:hidden}.profile-password-header{cursor:pointer;justify-content:space-between;align-items:center;padding:24px;transition:background .2s;display:flex}.profile-password-header:hover{background:var(--surface-hover)}@media (width<=768px){.form-grid{grid-template-columns:1fr!important;gap:16px!important}.profile-banner{text-align:center;flex-direction:column;align-items:center;height:auto;padding:30px 20px}.profile-avatar-container{width:90px;height:90px;margin-bottom:16px}.profile-header-info{margin-bottom:0;margin-left:0}.profile-badges{justify-content:center}.profile-tabs-wrapper{gap:20px;padding:20px 20px 0}.profile-body{padding:24px 20px}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeSlideUp}.table-card{transition:transform var(--transition-normal), box-shadow var(--transition-normal)}.table-card:hover{transform:translateY(-2px);box-shadow:0 10px 25px #2563eb14}.data-table tbody tr{transition:background-color var(--transition-fast), transform var(--transition-fast)}.data-table tbody tr:hover{z-index:1;position:relative;transform:scale(1.002);box-shadow:0 4px 12px #00000008}.modal-content{animation:.3s cubic-bezier(.16,1,.3,1) forwards fadeSlideUp}.biometric-glass{-webkit-backdrop-filter:blur(16px);background:#ffffffb3;border:1px solid #ffffff80;border-radius:20px;padding:24px;box-shadow:0 8px 32px #1f268712}.scanner-container{background-color:#050505;border:2px solid #1d8ce04d;border-radius:16px;position:relative;overflow:hidden;box-shadow:0 10px 30px #1d8ce026}.scanner-beam{z-index:10;background:#1d8ce0cc;height:4px;animation:2.5s linear infinite scan;position:absolute;top:0;left:0;right:0;box-shadow:0 0 15px 5px #1d8ce066}.face-guide-overlay{pointer-events:none;z-index:5;border:2px dashed #ffffff80;border-radius:50%;width:200px;height:260px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 9999px #0006}.biometric-gradient-text{background:linear-gradient(135deg, var(--primary), #bf9d9d);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.biometric-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));align-items:start;gap:40px;display:grid}@media (width<=768px){.biometric-grid{grid-template-columns:1fr;gap:24px}}
