*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #818cf8;--sidebar-bg: #1e1b4b;--sidebar-hover: rgba(255,255,255,.08);--sidebar-active: rgba(99,102,241,.3);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6}*{box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#f1f5f9}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:250px;min-width:250px;background:var(--sidebar-bg);display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:24px}.sidebar-logo{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.sidebar-logo-icon{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}.sidebar-logo-text{color:#fff;font-weight:700;font-size:15px}.sidebar-logo-sub{color:#fff6;font-size:10px}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 0}.nav-section-label{padding:6px 16px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;border-radius:6px;margin:1px 8px;font-size:13.5px;font-weight:500;color:#fff9;transition:all .15s;position:relative}.nav-item:hover{background:var(--sidebar-hover);color:#fff}.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-item .nav-icon{font-size:15px;width:20px;text-align:center}.nav-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding:12px 16px;position:relative}.sidebar-user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .15s}.sidebar-user:hover{background:#ffffff14}.sidebar-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#e2e8f0;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;font-weight:700}.switcher-user-item.active{background:#6366f14d}.logout-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px;margin-top:4px;color:#fff6;font-size:13px;cursor:pointer;border-radius:6px;transition:all .15s;background:none;border:none}.logout-btn:hover{background:#ef444426;color:#ef4444}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 24px;height:64px;display:flex;align-items:center;gap:16px}.topbar-title-area{flex:1}.topbar-title{font-size:20px;font-weight:700;color:#1e293b}.topbar-sub{font-size:13px;color:#64748b}.search-box{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:8px 12px;width:240px}.search-box input{border:none;background:none;outline:none;font-size:13px;color:#1e293b;width:100%}.search-box input::-moz-placeholder{color:#94a3b8}.search-box input::placeholder{color:#94a3b8}.topbar-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border:1px solid #e2e8f0;cursor:pointer;color:#64748b;transition:all .15s;position:relative}.topbar-btn:hover{background:#f1f5f9;color:#1e293b}.notif-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid white}.topbar-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;cursor:pointer}.card{background:#fff;border-radius:12px;padding:20px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:700;color:#1e293b}.stat-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000d;display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.stat-icon.blue{background:#eff6ff}.stat-icon.green{background:#f0fdf4}.stat-icon.yellow{background:#fffbeb}.stat-icon.purple{background:#faf5ff}.stat-icon.red{background:#fef2f2}.stat-icon.cyan{background:#f0fdfa}.stat-icon.indigo{background:#eef2ff}.stat-icon.pink{background:#fdf2f8}.stat-value{font-size:26px;font-weight:800;color:#1e293b;line-height:1}.stat-label{font-size:13px;color:#64748b;margin-top:4px}.stat-change{font-size:12px;margin-top:4px;font-weight:500}.stat-change.up{color:#10b981}.stat-change.down{color:#ef4444}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:5px 10px;font-size:12px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-success{background:#dcfce7;color:#166534}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}.badge-purple{background:#ede9fe;color:#5b21b6}.badge-gray{background:#f1f5f9;color:#475569}.badge-cyan{background:#cffafe;color:#155e75}.badge-indigo{background:#e0e7ff;color:#3730a3}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-bottom:1px solid #f1f5f9;white-space:nowrap}tbody td{padding:12px 14px;border-bottom:1px solid #f8fafc;color:#1e293b;vertical-align:middle}tbody tr:hover td{background:#f8fafc}tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:16px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{padding:20px 24px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:17px;font-weight:700;color:#1e293b}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:10px}.modal-close{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;background:none;border:none;font-size:18px}.modal-close:hover{background:#f1f5f9;color:#1e293b}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12.5px;font-weight:600;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:13.5px;color:#1e293b;outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--primary)}.form-input::-moz-placeholder{color:#94a3b8}.form-input::placeholder{color:#94a3b8}.form-select{-webkit-appearance:none;-moz-appearance:none;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='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.tab-bar{display:flex;gap:0;border-bottom:2px solid #f1f5f9;margin-bottom:20px}.tab-item{padding:10px 18px;font-size:13.5px;font-weight:600;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}.tab-item:hover{color:var(--primary)}.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.avatar.sm{width:28px;height:28px;font-size:11px}.avatar.lg{width:48px;height:48px;font-size:16px}.avatar.xl{width:64px;height:64px;font-size:22px}.avatar.a1{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.avatar.a2{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.avatar.a3{background:linear-gradient(135deg,#10b981,#059669)}.avatar.a4{background:linear-gradient(135deg,#f59e0b,#d97706)}.avatar.a5{background:linear-gradient(135deg,#ef4444,#dc2626)}.avatar.a6{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.avatar.a7{background:linear-gradient(135deg,#ec4899,#db2777)}.avatar.a8{background:linear-gradient(135deg,#14b8a6,#0d9488)}.timeline{display:flex;flex-direction:column;gap:12px}.timeline-item{display:flex;align-items:flex-start;gap:10px}.timeline-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:#f1f5f9}.timeline-content{flex:1}.timeline-text{font-size:13.5px;color:#1e293b}.timeline-time{font-size:11.5px;color:#94a3b8;margin-top:2px}.filter-search{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:7px 12px;flex:1;min-width:200px;max-width:300px}.filter-search input{border:none;outline:none;font-size:13px;background:none;width:100%}.filter-select{padding:7px 28px 7px 10px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:13px;color:#475569;background:#fff;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;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='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.kanban-board{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px}.kanban-col{min-width:220px;width:220px;background:#f8fafc;border-radius:12px;padding:12px}.kanban-col-header{font-size:12.5px;font-weight:700;color:#475569;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}.kanban-card{background:#fff;border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:0 1px 3px #0000000f;cursor:grab;border:1px solid #f1f5f9}.kanban-card:hover{box-shadow:0 4px 10px #0000001a}.progress-bar{height:6px;background:#f1f5f9;border-radius:10px;overflow:hidden}.progress-fill{height:100%;border-radius:10px;transition:width .3s}.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.emp-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;cursor:pointer;transition:all .15s;text-align:center}.emp-card:hover{box-shadow:0 4px 15px #00000014;transform:translateY(-2px)}.emp-dept-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;display:inline-block;margin-top:6px}.cal-day.present{background:#dcfce7;color:#166534}.cal-day.absent{background:#fee2e2;color:#991b1b}.cal-day.late{background:#fef3c7;color:#92400e}.cal-day.leave{background:#dbeafe;color:#1e40af}.cal-day.holiday{background:#ede9fe;color:#5b21b6}.cal-day.today{ring:2px solid var(--primary)}.leave-balance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.leave-balance-card{background:#fff;border-radius:10px;padding:14px;border:1px solid #f1f5f9}.payslip{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.payslip-header{background:var(--primary);color:#fff;padding:20px 24px}.payslip-body{padding:20px 24px}.payslip-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f8fafc;font-size:13.5px}.payslip-total{display:flex;justify-content:space-between;padding:12px 0;font-weight:700;font-size:15px;border-top:2px solid #e2e8f0;margin-top:8px}.empty-state{text-align:center;padding:48px 24px;color:#94a3b8}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state-text{font-size:14px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .2s ease-out}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.border{border-width:1px}.uppercase{text-transform:uppercase}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.sidebar-toggle{display:none;width:36px;height:36px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0;align-items:center;justify-content:center;cursor:pointer;font-size:18px;flex-shrink:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:150}@media (max-width: 1024px){.leave-balance-grid{grid-template-columns:repeat(2,1fr)}.form-grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.app-layout{position:relative}.sidebar{position:fixed;left:-260px;top:0;z-index:200;transition:left .3s ease;width:260px;height:100vh;box-shadow:4px 0 20px #0000004d}.sidebar.open{left:0}.sidebar-overlay.visible{display:block}.sidebar-toggle{display:flex}.main-content{padding:16px}.topbar{padding:0 16px;gap:10px}.topbar-title{font-size:16px}.search-box{display:none}.form-grid,.form-grid-3{grid-template-columns:1fr}.emp-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.leave-balance-grid{grid-template-columns:1fr 1fr}.kanban-board{flex-direction:column}.kanban-col{width:100%;min-width:unset}.card{padding:14px}.modal-lg,.modal-xl{max-width:100%;margin:0;border-radius:0}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:16px 16px 0 0;max-height:90vh}.table-wrap{-webkit-overflow-scrolling:touch}table{min-width:500px}.stat-card{padding:14px;gap:12px}.stat-value{font-size:22px}.stat-icon{width:40px;height:40px;font-size:17px}.filter-bar{gap:8px}.filter-search{min-width:160px}.settings-layout{flex-direction:column!important}.settings-sidebar{width:100%!important}.settings-tab-bar{display:flex!important;overflow-x:auto;flex-direction:row!important}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.tab-item{white-space:nowrap;flex-shrink:0}.dashboard-charts-grid,.dashboard-3col{grid-template-columns:1fr!important}}@media (max-width: 480px){.main-content{padding:12px}.emp-grid{grid-template-columns:1fr 1fr}.leave-balance-grid{grid-template-columns:1fr}.topbar{height:56px}.sidebar-logo-text{font-size:14px}.stat-card{flex-direction:column;text-align:center}.stat-icon{width:44px;height:44px;margin:0 auto}}
