@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:"Inter", system-ui, sans-serif;--heading:"Inter", system-ui, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}html,body,#root{min-height:100vh}body{margin:0}#root{text-align:center;box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100vh;margin:0;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--color-primary:#dc2626;--color-primary-dark:#b91c1c;--color-primary-light:#ef4444;--color-primary-50:#fef2f2;--color-success:#059669;--color-success-light:#10b981;--color-warning:#f59e0b;--color-error:#dc2626;--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--text-primary:#111827;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--border-color:#e5e7eb;--border-light:#f3f4f6;--shadow-xs:0 .5px 1px 0 #0000000d;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--shadow-2xl:0 25px 50px -12px #0000001a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:2.5rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:999px}.hrm-root.dark-theme{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-primary:#ef4444;--color-primary-dark:#dc2626;--color-primary-light:#f87171;--color-primary-50:#7f1d1d;--bg-primary:#1f2937;--bg-secondary:#111827;--bg-tertiary:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#374151;--border-light:#4b5563;--shadow-xs:0 .5px 1px 0 #0000004d;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d;--shadow-xl:0 20px 25px -5px #0000004d;--shadow-2xl:0 25px 50px -12px #0000004d}*{box-sizing:border-box;margin:0;padding:0}:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{color:var(--text-primary);background:var(--bg-secondary);transition:background-color var(--transition-slow), color var(--transition-slow);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.6}.hrm-root{background:var(--bg-secondary);min-height:100vh;color:var(--text-primary);transition:background-color var(--transition-slow), color var(--transition-slow)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.5px;font-weight:700;line-height:1.2}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}a{color:var(--color-primary);transition:color var(--transition-base);text-decoration:none}a:hover{color:var(--color-primary-dark);text-decoration:underline}small{color:var(--text-tertiary);font-size:.875rem}img,video{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::selection{background:var(--color-primary);color:#fff}::selection{background:var(--color-primary);color:#fff}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-tertiary{background:var(--bg-tertiary)}.hidden{display:none!important}.visible{display:block!important}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.m-auto{margin:auto}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border-color);margin-top:4px;margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:700}.transition-fast{transition:all var(--transition-fast)}.transition-base{transition:all var(--transition-base)}.transition-slow{transition:all var(--transition-slow)}.hrm-layout{min-height:calc(100vh - 64px);display:flex}.hrm-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:0 var(--spacing-xl);z-index:100;height:90px;box-shadow:var(--shadow-sm);transition:background-color var(--transition-slow), border-color var(--transition-slow);justify-content:space-between;align-items:center;padding-top:12px;padding-bottom:12px;display:flex;position:sticky;top:0}.hrm-brand{align-items:center;gap:var(--spacing-md);display:flex}.hrm-brand-info{flex-direction:column;justify-content:center;display:flex}.hrm-brand-logo{width:40px;height:40px;color:inherit;font-weight:inherit;font-size:inherit;letter-spacing:normal;box-shadow:none;cursor:default;background:0 0;border-radius:0;justify-content:center;align-items:center;transition:none;display:flex;overflow:hidden}.hrm-brand-logo img,.hrm-brand-logo .hrm-brand-logo-img{object-fit:contain;width:100%;height:100%}.hrm-brand-logo:hover{box-shadow:none;transform:none}.hrm-brand-name{color:var(--text-primary);font-size:18px;font-weight:700}.hrm-brand-sub{color:var(--text-secondary);margin-top:2px;font-size:12px}.hrm-header-right{align-items:center;gap:var(--spacing-lg);display:flex}.hrm-user-pill{align-items:center;gap:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-base);padding:7px 16px;font-size:13px;font-weight:500;display:flex}.hrm-user-pill:hover{background:var(--border-light);color:var(--text-primary)}.hrm-avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;width:38px;height:38px;transition:all var(--transition-base);color:var(--text-secondary);justify-content:center;align-items:center;font-size:18px;display:flex}.theme-toggle:hover{background:var(--border-light);color:var(--text-primary)}.theme-toggle:active{transform:scale(.95)}.hrm-sidebar{background:var(--bg-primary);border-right:1px solid var(--border-color);width:240px;min-width:240px;padding:var(--spacing-lg) 0;transition:background-color var(--transition-slow), border-color var(--transition-slow);flex-direction:column;gap:2px;display:flex;overflow-y:auto}.sidebar-section-label{letter-spacing:1px;color:var(--text-tertiary);text-transform:uppercase;margin-top:12px;padding:12px 20px 6px;font-size:11px;font-weight:700}.sidebar-item{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:12px;width:100%;padding:11px 20px;font-size:14px;font-weight:500;display:flex}.sidebar-item:hover{background:var(--bg-tertiary);color:var(--color-primary);border-left-color:var(--color-primary)}.sidebar-item.active{background:var(--bg-tertiary);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.sidebar-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.hrm-main{padding:var(--spacing-xl);background:var(--bg-secondary);transition:background-color var(--transition-slow);flex:1;overflow-y:auto}.page-header{margin-bottom:var(--spacing-2xl);animation:fadeIn var(--transition-slow)}.page-header h1{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:800}.page-header p{color:var(--text-secondary);margin:0;font-size:14px}.hamburger{border:1.5px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;width:38px;height:38px;transition:all var(--transition-base);color:var(--text-secondary);justify-content:center;align-items:center;font-size:20px;display:none}.hamburger:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.hamburger:active{transform:scale(.95)}button{cursor:pointer;transition:all var(--transition-base);border:none;font-family:Inter,sans-serif}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:var(--radius-md);white-space:nowrap;transition:all var(--transition-base);padding:10px 22px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #dc262633}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));transform:translateY(-2px);box-shadow:0 6px 16px #dc26264d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-secondary);color:var(--color-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);white-space:nowrap;transition:all var(--transition-base);padding:9px 20px;font-size:14px;font-weight:600}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 2px 8px #dc26261a}.btn-sm{border-radius:var(--radius-sm);padding:6px 14px;font-size:12px;font-weight:600}.btn-approve{background:linear-gradient(135deg, var(--color-success), var(--color-success-light));color:#fff;border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;border:none;padding:10px 22px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #10b98133}.btn-approve:hover:not(:disabled){background:linear-gradient(135deg, #047857, var(--color-success));transform:translateY(-2px);box-shadow:0 6px 16px #10b9814d}.btn-approve:active:not(:disabled){transform:translateY(0)}.btn-reject{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;border:none;padding:10px 22px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #dc262633}.btn-reject:hover:not(:disabled){background:linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));transform:translateY(-2px);box-shadow:0 6px 16px #dc26264d}.btn-reject:active:not(:disabled){transform:translateY(0)}.btn-logout{color:var(--color-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-base);background:0 0;padding:8px 18px;font-size:13px;font-weight:600}.btn-logout:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 2px 8px #dc26261a}.btn-group{gap:var(--spacing-md);flex-wrap:wrap;display:flex}.btn-group .btn-primary,.btn-group .btn-secondary{flex:1;min-width:120px}.btn-icon{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--border-light);color:var(--text-primary)}.btn-icon-sm{width:32px;height:32px}.btn-icon-lg{width:40px;height:40px}.form-grid{gap:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.field{flex-direction:column;justify-content:center;gap:8px;width:92%;display:flex}.field label{color:var(--text-primary);text-transform:capitalize;transition:color var(--transition-base);font-size:13px;font-weight:600}.field label.required:after{content:" *";color:var(--color-error)}input,select,textarea{background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-base);outline:none;width:100%;padding:10px 13px;font-family:Inter,sans-serif;font-size:14px}input::placeholder,select::placeholder,textarea::placeholder{color:var(--text-tertiary)}input:hover,select:hover,textarea:hover{border-color:var(--border-light)}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);background:var(--bg-primary);box-shadow:0 0 0 3px #dc26261a}input:disabled,select:disabled,textarea:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}textarea{resize:vertical;min-height:100px;line-height:1.5}.form-group{margin-bottom:var(--spacing-lg)}.form-group:last-child{margin-bottom:0}.form-inline{gap:var(--spacing-md);align-items:flex-end;display:flex}.form-inline .field{flex:1;min-width:200px}.form-inline button{margin-top:22px}.form-actions{gap:var(--spacing-md);margin-top:var(--spacing-xl);flex-wrap:wrap;justify-content:flex-end;display:flex}.form-feedback{align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.form-feedback.error{color:var(--color-error)}.form-feedback.success{color:var(--color-success)}.form-feedback.warning{color:var(--color-warning)}.form-feedback.info{color:var(--text-secondary)}.form-help{color:var(--text-tertiary);margin-top:4px;font-size:12px}.login-screen{min-height:100vh;transition:background var(--transition-slow);padding:var(--spacing-lg);background:linear-gradient(135deg,#fff 0%,#f9fafb 100%);justify-content:center;align-items:center;display:flex}.hrm-root.dark-theme .login-screen{background:linear-gradient(135deg,#1f2937 0%,#111827 100%)}.login-card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-2xl);border:1px solid var(--border-color);width:100%;max-width:440px;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn var(--transition-slow)}.login-logo{width:60px;height:60px;color:inherit;font-size:inherit;font-weight:inherit;margin:0 auto var(--spacing-lg);box-shadow:none;background:0 0;border-radius:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.login-logo img,.login-logo .login-logo-img{object-fit:contain;width:100%;height:100%}.login-title{text-align:center;color:var(--text-primary);margin-bottom:8px;font-size:26px;font-weight:800}.login-sub{color:var(--text-secondary);text-align:center;margin-top:8px;margin-bottom:var(--spacing-2xl);font-size:14px}.login-fields{gap:var(--spacing-lg);flex-direction:column;display:flex}.login-btn{border-radius:var(--radius-lg);width:100%;margin-top:8px;padding:12px;font-size:15px}.login-error{color:var(--color-primary);border-radius:var(--radius-md);margin-top:var(--spacing-md);text-align:center;animation:fadeIn var(--transition-base);background:#dc262626;border:1px solid #dc26264d;padding:11px 14px;font-size:13px}.login-demo{color:var(--text-tertiary);text-align:center;margin-top:var(--spacing-lg);font-size:12px}.login-demo span{color:var(--color-primary);font-weight:600}.login-card input{background:var(--bg-primary)!important;border:1.5px solid var(--border-color)!important;box-shadow:none!important;border-radius:var(--radius-md)!important;color:var(--text-primary)!important;padding:11px 13px!important;font-family:Inter,sans-serif!important;font-size:14px!important}.login-card input::placeholder{color:var(--text-tertiary)!important}.login-card input:focus{border-color:var(--color-primary)!important;background:var(--bg-primary)!important;box-shadow:0 0 0 3px #dc26261a!important}.login-card input:-webkit-autofill{-webkit-box-shadow:0 0 0 30px var(--bg-primary) inset!important;-webkit-text-fill-color:var(--text-primary)!important;border:1.5px solid var(--border-color)!important}.login-card input:-webkit-autofill:hover{-webkit-box-shadow:0 0 0 30px var(--bg-primary) inset!important;-webkit-text-fill-color:var(--text-primary)!important;border:1.5px solid var(--border-color)!important}.login-card input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 30px var(--bg-primary) inset!important;-webkit-text-fill-color:var(--text-primary)!important;border:1.5px solid var(--border-color)!important}.login-card input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--bg-primary) inset!important;-webkit-text-fill-color:var(--text-primary)!important;border:1.5px solid var(--border-color)!important}.login-card input:-webkit-autofill:first-line{font-family:Inter,sans-serif!important}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.card{background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);animation:fadeIn var(--transition-slow)}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-title{color:var(--text-primary);margin-bottom:6px;font-size:18px;font-weight:700}.card-sub{color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-size:13px}.card-footer{padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);margin-top:var(--spacing-lg)}.stats-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.stat-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-base);animation:fadeIn var(--transition-slow)}.stat-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 4px 12px #dc26261a}.stat-label{color:var(--text-secondary);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.stat-value{color:var(--color-primary);margin-bottom:8px;font-size:28px;font-weight:800;line-height:1}.stat-value.green{color:var(--color-success)}.stat-value.warning{color:var(--color-warning)}.stat-value.gray{color:var(--text-secondary)}.stat-change{border-radius:var(--radius-sm);padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.stat-change.up{color:var(--color-success);background:#10b98126}.stat-change.down{color:var(--color-error);background:#dc262626}.stat-change.neutral{color:var(--text-secondary);background:#9ca3af26}.two-col{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.three-col{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.four-col{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.divider{border:none;border-top:1px solid var(--border-color);margin:var(--spacing-lg) 0}.divider-vertical{border:none;border-left:1px solid var(--border-color);margin:0 var(--spacing-lg)}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}thead{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;-webkit-user-select:none;user-select:none;padding:13px 16px;font-size:12px;font-weight:700}td{color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle;padding:13px 16px}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg-tertiary);transition:background-color var(--transition-base)}tbody tr:active{background:var(--border-light)}.table-compact td,.table-compact th{padding:10px 12px}.table-spacious td,.table-spacious th{padding:16px 20px}.badge{border-radius:var(--radius-full);letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.badge-pending{color:#b45309;background:#fbbf2426}.badge-approved{color:var(--color-success);background:#10b98126}.badge-rejected{color:var(--color-primary);background:#dc262626}.badge-in{color:var(--color-success);background:#10b98126}.badge-out{color:var(--color-primary);background:#dc262626}.badge-active{color:var(--color-success);background:#10b98126}.badge-inactive{color:var(--text-secondary);background:#9ca3af26}.badge-warning{color:var(--color-warning);background:#f59e0b26}.badge-info{color:#3b82f6;background:#3b82f626}.cal-wrap{border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow-x:auto}.week-table{border-collapse:collapse;background:var(--bg-primary);width:100%;min-width:520px}.week-table th{background:var(--bg-tertiary);text-align:center;color:var(--color-primary);border:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.5px;padding:12px 10px;font-size:12px;font-weight:700}.week-table td{text-align:center;border:1px solid var(--border-color);vertical-align:top;min-width:90px;min-height:70px;color:var(--text-primary);padding:12px 10px;font-size:13px}.day-date{color:var(--text-secondary);margin-bottom:6px;font-size:11px;font-weight:600}.time-chip{color:var(--color-success);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.3px;background:#10b98126;margin:2px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.time-chip.out{color:var(--color-primary);background:#dc262626}.today-col{background:#dc26260d}.check-status-bar{align-items:center;gap:var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-2xl);box-shadow:var(--shadow-sm);flex-wrap:wrap;display:flex}.cstatus-dot{background:var(--text-tertiary);width:12px;height:12px;transition:all var(--transition-base);border-radius:50%;flex-shrink:0}.cstatus-dot.active{background:var(--color-success);animation:2s infinite pulse;box-shadow:0 0 0 4px #10b98133}.cstatus-text{color:var(--text-primary);font-size:14px;font-weight:600}.cstatus-sub{color:var(--text-secondary);font-size:12px}.cstatus-spacer{flex:1}.report-preview{background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;color:var(--text-secondary);justify-content:center;align-items:center;gap:var(--spacing-md);flex-direction:column;min-height:140px;font-size:14px;display:flex}.report-preview.has-data{color:var(--text-primary);text-align:left;background:var(--bg-primary);border-style:solid;align-items:flex-start}.report-name{color:var(--color-primary);margin-bottom:6px;font-size:20px;font-weight:800}.report-pos{color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:13px}.report-row{border-bottom:1px solid var(--border-color);color:var(--text-primary);justify-content:space-between;padding:10px 0;font-size:13px;display:flex}.report-row:last-child{border:none}.alert{padding:var(--spacing-lg);border-radius:var(--radius-md);border-left:4px solid var(--color-primary);margin-bottom:var(--spacing-md);gap:var(--spacing-md);align-items:flex-start;display:flex}.alert.success{border-left-color:var(--color-success);color:var(--color-success);background:#10b9811a}.alert.error{border-left-color:var(--color-error);color:var(--color-error);background:#dc26261a}.alert.warning{border-left-color:var(--color-warning);color:var(--color-warning);background:#f59e0b1a}.alert.info{color:#3b82f6;background:#3b82f61a;border-left-color:#3b82f6}.alert-close{cursor:pointer;opacity:.7;transition:opacity var(--transition-base);margin-left:auto}.alert-close:hover{opacity:1}.modal-overlay{z-index:1000;animation:fadeIn var(--transition-base);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-2xl);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-2xl);animation:slideInRight var(--transition-slow);overflow-y:auto}.toast-overlay{z-index:1100;pointer-events:none;position:fixed;top:20px;right:20px}.toast-popup{pointer-events:auto;text-align:center;background:#fffffffa;border:1px solid #0000000f;border-radius:16px;min-width:280px;max-width:90%;padding:16px 24px;font-size:14px;font-weight:600;animation:.2s forwards floatIn;box-shadow:0 18px 40px #00000029}.toast-popup.success{color:var(--color-success);border-color:#10b9813d}.toast-popup.error{color:var(--color-error);border-color:#dc26263d}@keyframes floatIn{0%{opacity:0;transform:translateY(-10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--text-primary);font-size:20px;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:24px}.modal-body{margin-bottom:var(--spacing-lg)}.modal-footer{border-top:1px solid var(--border-color);padding-top:var(--spacing-lg);gap:var(--spacing-md);justify-content:flex-end;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin;display:inline-block}.spinner-sm{border-width:2px;width:16px;height:16px}.spinner-lg{border-width:4px;width:24px;height:24px}.spinner-center{padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.dropdown{display:inline-block;position:relative}.dropdown-toggle{cursor:pointer;align-items:center;gap:6px;display:flex}.dropdown-toggle:after{content:"▼";transition:transform var(--transition-base);font-size:10px}.dropdown-toggle.active:after{transform:rotate(180deg)}.dropdown-menu{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:200px;animation:fadeIn var(--transition-base);margin-top:4px;position:absolute;top:100%;left:0}.dropdown-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);background:0 0;border:none;padding:10px 16px;font-size:14px;display:block}.dropdown-item:first-child{border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.dropdown-item:last-child{border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.dropdown-divider{background:var(--border-color);height:1px;margin:4px 0}.tabs{border-bottom:1px solid var(--border-color);gap:var(--spacing-lg);display:flex}.tab-button{padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:all var(--transition-base);color:var(--text-secondary);background:0 0;border:none;border-bottom:3px solid #0000;font-weight:600}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content{animation:fadeIn var(--transition-base)}.tab-content.hidden{display:none}.pagination{padding:var(--spacing-lg) 0;justify-content:center;align-items:center;gap:4px;display:flex}.pagination-item{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);cursor:pointer;width:36px;height:36px;transition:all var(--transition-base);color:var(--text-primary);justify-content:center;align-items:center;font-weight:600;display:flex}.pagination-item:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination-item.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-item.disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{color:var(--text-tertiary);padding:0 8px}.breadcrumb{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);font-size:14px;display:flex}.breadcrumb-item{color:var(--text-secondary)}.breadcrumb-item a{color:var(--color-primary);transition:color var(--transition-base);text-decoration:none}.breadcrumb-item a:hover{color:var(--color-primary-dark);text-decoration:underline}.breadcrumb-separator{color:var(--text-tertiary);margin:0 var(--spacing-sm)}.breadcrumb-item.active{color:var(--text-primary);font-weight:600}.upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--bg-tertiary)}.upload-area:hover,.upload-area.dragover{border-color:var(--color-primary);background:var(--color-primary-50)}.upload-area-icon{margin-bottom:var(--spacing-md);font-size:32px}.upload-area-text{color:var(--text-secondary);margin-bottom:4px}.upload-area-hint{color:var(--text-tertiary);font-size:12px}.badge-dot{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 2px 4px #dc262633}.badge-dot.success{background:var(--color-success)}.badge-dot.warning{background:var(--color-warning)}.empty-state{min-height:400px;padding:var(--spacing-2xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--spacing-lg);opacity:.5;font-size:64px}.empty-state-title{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:700}.empty-state-text{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.empty-state-action{margin-top:var(--spacing-md)}@media (width<=1024px){.hrm-sidebar{width:220px;min-width:220px}.hrm-main{padding:var(--spacing-lg)}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.hrm-header{padding:0 var(--spacing-md)}.hrm-sidebar{display:none}.hrm-sidebar.mobile-open{z-index:200;flex-direction:column;width:260px;height:calc(100vh - 64px);display:flex;position:fixed;top:64px;left:0;box-shadow:4px 0 20px #00000026}.hrm-main{padding:var(--spacing-md)}.hamburger{display:flex!important}.form-grid,.grid-2,.grid-3,.two-col,.three-col,.stats-grid{gap:var(--spacing-lg);grid-template-columns:1fr!important}div[style*="grid-template-columns: 1fr 1fr"],div[style*="grid-template-columns: 1fr auto"]{grid-template-columns:1fr!important}.page-header h1{font-size:20px}.card{padding:var(--spacing-md);width:100%!important;max-width:100%!important}h1{font-size:1.5rem}h2{font-size:1.25rem}table{font-size:11px}th,td{padding:8px 6px}.form-actions{flex-direction:column-reverse;gap:10px}.form-actions button{width:100%}input[type=date],input[type=time],input[type=text],input[type=number],input[type=password],select,textarea{box-sizing:border-box;font-size:16px;width:100%!important}.modal-content{width:95%!important;max-width:95%!important;padding:var(--spacing-lg)!important}}@media (width<=480px){.hrm-header{height:60px;padding:0 var(--spacing-sm);justify-content:center;align-items:center;display:flex;position:relative}.hamburger{left:var(--spacing-sm);margin:0;position:absolute}.hrm-header-right{right:var(--spacing-sm);gap:var(--spacing-xs);position:absolute}.hrm-brand{gap:var(--spacing-xs);text-align:center;justify-content:center;align-items:center;display:flex}.hrm-brand-info{text-align:center;align-items:center}.hrm-brand-logo{width:30px;height:30px}.hrm-brand-name{white-space:normal;text-align:center;justify-content:center;max-width:140px;font-size:12px;line-height:1.2;display:flex}.hrm-brand-sub{white-space:nowrap;text-align:center;justify-content:center;font-size:10px;display:flex}.hrm-header-right{gap:var(--spacing-xs)}.hrm-user-pill{display:none}.btn-logout{padding:6px 10px;font-size:11px}.theme-toggle{width:32px;height:32px}.check-status-bar{align-items:flex-start;gap:var(--spacing-md);flex-direction:column}}.grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.hide-mobile{display:none}.show-mobile{display:block}@media (width>=769px){.hide-mobile{display:block}.show-mobile,.hide-desktop{display:none}.show-desktop{display:block}}@media print{body{background:#fff}.hrm-header,.hrm-sidebar,.hamburger,.theme-toggle,.btn-logout{display:none}.hrm-main{margin:0;padding:0}.card{page-break-inside:avoid}.table-wrap{box-shadow:none}table{border-collapse:collapse}th,td{border:1px solid #ccc}}.dash-attendance{background:var(--bg-primary);border:1px solid #94a3b82e;border-radius:26px;gap:1.2rem;padding:1.5rem;display:grid;box-shadow:0 18px 40px #0f172a0f}.dash-attendance__header,.dash-attendance__footer{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.dash-attendance__eyebrow{color:#1d4ed8;text-transform:uppercase;letter-spacing:.08em;background:#1e40af14;border-radius:999px;padding:.35rem .7rem;font-size:.78rem;font-weight:700;display:inline-flex}.dash-attendance__header h2{color:var(--text-primary);margin:.8rem 0 .3rem;font-size:1.35rem}.dash-attendance__header p{color:var(--text-secondary);margin:0}.dash-attendance__date{color:#f8fafc;white-space:nowrap;background:#0f172a;border-radius:18px;padding:.8rem 1rem;font-weight:700}.dash-attendance__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.dash-attendance__metric{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;gap:.35rem;padding:1rem 1.1rem;display:grid}.dash-attendance__metric span{color:var(--text-secondary);font-size:.83rem;font-weight:600}.dash-attendance__metric strong{color:var(--text-primary);font-size:1.3rem;line-height:1.2}.dash-attendance__metric small{color:var(--text-secondary);font-size:.88rem;line-height:1.45}.dash-attendance__metric.accent-red{box-shadow:inset 0 4px #dc2626}.dash-attendance__metric.accent-blue{box-shadow:inset 0 4px #2563eb}.dash-attendance__metric.accent-green{box-shadow:inset 0 4px #16a34a}.dash-attendance__button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc2626,#ef4444);border:0;border-radius:14px;min-width:180px;padding:.9rem 1.2rem;font-weight:700;box-shadow:0 14px 26px #dc262638}.dash-attendance__button.is-checkout{background:linear-gradient(135deg,#ea580c,#fb923c);box-shadow:0 14px 26px #ea580c38}.dash-attendance__button:disabled{cursor:not-allowed;background:var(--bg-tertiary);color:var(--text-tertiary);box-shadow:none}.dash-attendance__helper{color:var(--text-secondary);font-size:.9rem}.dash-attendance__error{color:var(--text-error);font-size:.9rem}@media (width<=900px){.dash-attendance__grid{grid-template-columns:1fr}}@media (width<=760px){.dash-attendance__header,.dash-attendance__footer{flex-direction:column}.dash-attendance__date{white-space:normal}}.admin-dashboard{gap:1.5rem;display:grid}.admin-hero,.admin-panel,.admin-summary-card{border:1px solid #94a3b82e;box-shadow:0 18px 40px #0f172a0f}.admin-hero{background:var(--bg-primary);border-radius:28px;justify-content:space-between;align-items:stretch;gap:1.5rem;padding:2rem;display:flex}.admin-hero-copy{max-width:640px}.admin-eyebrow{color:#9a3412;letter-spacing:.08em;text-transform:uppercase;background:#c2410c14;border-radius:999px;padding:.35rem .75rem;font-size:.78rem;font-weight:700;display:inline-flex}.admin-hero h1{color:var(--text-primary);margin:.9rem 0 .45rem;font-size:clamp(2rem,4vw,3rem);line-height:1.05}.admin-hero p{max-width:56ch;color:var(--text-secondary);margin:0;font-size:1rem;line-height:1.65}.admin-hero-status{color:#f8fafc;background:#0f172af0;border-radius:22px;align-content:center;gap:.4rem;min-width:220px;padding:1.5rem;display:grid}.admin-status-label{text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0c7;font-size:.82rem}.admin-status-value{font-size:3rem;font-weight:800;line-height:1}.admin-status-caption{color:#cbd5e1}.admin-summary-grid,.admin-bottom-grid,.approval-grid,.quick-actions{gap:1rem;display:grid}.admin-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-summary-card{background:var(--bg-primary);border-radius:24px;gap:.55rem;padding:1.3rem 1.35rem;display:grid;position:relative;overflow:hidden}.admin-summary-card:after{content:"";opacity:.18;background:currentColor;border-radius:999px;width:120px;height:120px;position:absolute;inset:auto -25% -35% auto}.accent-gold{color:#b45309}.accent-coral{color:#c2410c}.accent-green{color:#15803d}.accent-blue{color:#1d4ed8}.summary-label,.summary-footnote{z-index:1;position:relative}.summary-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.summary-value{z-index:1;font-size:2rem;font-weight:800;line-height:1;position:relative}.summary-footnote{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.admin-panel{background:var(--bg-primary);border-radius:26px;padding:1.4rem}.admin-panel.compact{height:100%}.panel-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.2rem;display:flex}.panel-header h2{color:var(--text-primary);margin:0;font-size:1.2rem}.panel-header p{color:var(--text-secondary);margin:.35rem 0 0;line-height:1.5}.panel-badge{color:#b45309;background:#d977061f;border-radius:999px;padding:.45rem .8rem;font-size:.82rem;font-weight:700}.approval-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.approval-card,.quick-action{text-align:left;cursor:pointer;border:0;transition:transform .2s,box-shadow .2s}.approval-card{color:#f8fafc;background:#0f172a;border-radius:22px;align-items:center;gap:1rem;padding:1.15rem;display:flex;box-shadow:0 14px 28px #0f172a2e}.approval-card.leave{background:linear-gradient(135deg,#7c2d12,#c2410c)}.approval-card.attendance{background:linear-gradient(135deg,#0f172a,#1d4ed8)}.approval-card:hover,.quick-action:hover{transform:translateY(-3px)}.approval-icon{letter-spacing:.08em;background:#ffffff29;border-radius:16px;place-items:center;width:54px;height:54px;font-weight:800;display:grid}.approval-info{gap:.18rem;display:grid}.approval-title{color:#ffffffc7;font-size:.92rem}.approval-count{font-size:2rem;font-weight:800;line-height:1}.approval-meta{color:#ffffffe0;font-size:.9rem}.panel-empty-state{background:var(--bg-tertiary);color:var(--text-secondary);border:1px dashed var(--border-color);text-align:center;border-radius:20px;padding:1.2rem}.panel-empty-state.success{color:#166534;background:#16a34a14;border-style:solid;border-color:#16a34a2e}.admin-bottom-grid{grid-template-columns:1.25fr .9fr}.quick-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.quick-action{background:#fff;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;gap:.3rem;padding:1rem;display:grid}.quick-action span{color:var(--text-primary);font-size:.98rem;font-weight:700}.quick-action small{color:var(--text-secondary);font-size:.82rem;line-height:1.45}.admin-insights{gap:.85rem;margin:0;padding:0;list-style:none;display:grid}.admin-insights li{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:18px;justify-content:space-between;align-items:center;gap:1rem;padding:.95rem 1rem;display:flex}.insight-key{color:var(--text-secondary);font-weight:600}.insight-value{color:var(--text-primary);font-weight:700}.admin-inline-note{color:var(--text-secondary);padding:0 .25rem;font-size:.92rem}@media (width<=1100px){.admin-summary-grid,.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-bottom-grid{grid-template-columns:1fr}}@media (width<=760px){.admin-hero{padding:1.4rem;display:grid}.admin-summary-grid,.approval-grid,.quick-actions{grid-template-columns:1fr}.panel-header{flex-direction:column}.admin-hero-status{min-width:0}.approval-card{width:100%}}.emp-dashboard{gap:1.5rem;display:grid}.leave-visual-section{grid-template-columns:1.45fr .8fr;gap:1.25rem;display:grid}.leave-chart-card,.leave-quick-apply{border:1px solid #94a3b82e;border-radius:28px;box-shadow:0 18px 40px #0f172a0f}.leave-chart-card{background:var(--bg-primary);padding:1.5rem}.leave-quick-apply{background:var(--bg-primary);align-content:center;gap:.9rem;padding:1.6rem;display:grid}.leave-card-header h2,.leave-quick-apply h3{color:var(--text-primary);margin:.55rem 0 .25rem}.leave-card-header p,.leave-quick-apply p{color:var(--text-secondary);margin:0;line-height:1.6}.leave-eyebrow{color:#1d4ed8;text-transform:uppercase;letter-spacing:.08em;background:#2563eb14;border-radius:999px;padding:.35rem .7rem;font-size:.78rem;font-weight:700;display:inline-flex}.leave-chart-wrap{grid-template-columns:240px 1fr;align-items:center;gap:1.4rem;margin-top:1rem;display:grid}.leave-chart-shell{width:220px;height:220px;position:relative}.leave-chart{border-radius:50%;width:220px;height:220px;position:relative;box-shadow:inset 0 0 0 1px #94a3b81f}.leave-chart-core{background:var(--bg-primary);border-radius:50%;position:absolute;inset:20px}.leave-chart-center{text-align:center;place-content:center;display:grid;position:absolute;inset:0}.leave-chart-center strong{color:var(--text-primary);font-size:2.2rem;line-height:1}.leave-chart-center span{color:var(--text-secondary);margin-top:.35rem}.leave-chart-legend{gap:.85rem;display:grid}.leave-legend-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:18px;align-items:center;gap:.85rem;padding:.95rem 1rem;display:flex}.leave-legend-item strong{color:var(--text-primary);display:block}.leave-legend-item small{color:var(--text-secondary)}.legend-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.legend-dot.earned{background:#2563eb}.legend-dot.sick{background:#f97316}.leave-apply-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ea580c,#fb923c);border:0;border-radius:16px;padding:.95rem 1.2rem;font-size:1rem;font-weight:700;box-shadow:0 16px 28px #ea580c38}@media (width<=980px){.leave-visual-section,.leave-chart-wrap{grid-template-columns:1fr}.leave-chart-shell{margin:0 auto}}
