@import "https://fonts.googleapis.com/css2?family=Outfit:wght@500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg-base:#f3f4f6;--bg-surface:#fff;--bg-card:#fff;--bg-elevated:#fff;--bg-hover:#f9fafb;--bg-input:#fff;--bg-tertiary:#f3f4f6;--glass-bg:#fff;--glass-border:#0000000d;--glass-hover-bg:#f9fafb;--border-color:#e5e7eb;--border-subtle:#f3f4f6;--border-focus:#6366f180;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#6b7280;--text-dim:#9ca3af;--primary:#6366f1;--primary-hover:#4f46e5;--primary-light:#818cf8;--primary-glow:#6366f126;--primary-glow-sm:#6366f114;--accent:#3b82f6;--accent-glow:#3b82f626;--success:#10b981;--success-light:#34d399;--success-glow:#10b9811f;--success-border:#10b98133;--danger:#ef4444;--danger-light:#f87171;--danger-glow:#ef44441f;--danger-border:#ef444433;--warning:#f59e0b;--warning-light:#fbbf24;--warning-glow:#f59e0b1f;--warning-border:#f59e0b33;--info:#3b82f6;--info-glow:#3b82f61f;--info-border:#3b82f633;--grad-primary:linear-gradient(135deg, #6366f1, #3b82f6);--grad-card:#fff;--grad-sidebar:#fff;--grad-success:linear-gradient(135deg, #10b981, #059669);--grad-danger:linear-gradient(135deg, #ef4444, #e11d48);--grad-warning:linear-gradient(135deg, #f59e0b, #d97706);--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-display:"Outfit", "Plus Jakarta Sans", sans-serif;--shadow-sm:0 1px 3px #0000000d, 0 1px 2px #00000008;--shadow-md:0 4px 12px #0000000d, 0 2px 4px #00000008;--shadow-lg:0 12px 32px #00000014, 0 4px 12px #0000000a;--shadow-glow:0 0 24px #6366f126;--shadow-glow-lg:0 0 48px #6366f133;--shadow-success:0 4px 16px #10b98133;--shadow-danger:0 4px 16px #ef444433;--radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--t-fast:.15s ease;--t-normal:.25s cubic-bezier(.2, .8, .2, 1);--t-slow:.45s cubic-bezier(.2, .8, .2, 1);--transition-fast:var(--t-fast);--transition-normal:var(--t-normal);--transition-slow:var(--t-slow)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(80% 60% at 10% 10%,#8b5cf614,#0000),radial-gradient(60% 50% at 90% 80%,#06b6d40f,#0000),radial-gradient(40% 40%,#6366f10a,#0000);position:fixed;inset:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#8b5cf64d}::-webkit-scrollbar-thumb:hover{background:#8b5cf699}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text-primary);font-weight:700;line-height:1.2}a{color:var(--primary-light);transition:color var(--t-fast);text-decoration:none}a:hover{color:var(--primary)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:box-shadow var(--t-normal), transform var(--t-normal), border-color var(--t-normal)}.glass-panel:hover{box-shadow:var(--shadow-lg), 0 0 0 1px #8b5cf61a;border-color:#8b5cf626}.hover-lift:hover{transform:translateY(-3px)}input,select,textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);padding:11px 16px;font-size:.93rem}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow-sm), inset 0 0 0 1px #8b5cf61a;background:#8b5cf60a;outline:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}select option{background:var(--bg-elevated);color:var(--text-primary)}label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px;font-size:.78rem;font-weight:600;display:block}.btn{border-radius:var(--radius-full);font-family:var(--font-sans);cursor:pointer;transition:all var(--t-normal);white-space:nowrap;letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-size:.88rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";opacity:0;transition:opacity var(--t-fast);background:linear-gradient(#ffffff14 0%,#0000 100%);position:absolute;inset:0}.btn:hover:before{opacity:1}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 4px 16px var(--primary-glow), inset 0 1px 0 #ffffff26}.btn-primary:hover{box-shadow:0 8px 28px var(--primary-glow), 0 0 0 1px #8b5cf666;transform:translateY(-2px)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-secondary);background:#ffffff0f}.btn-secondary:hover{color:var(--text-primary);background:#ffffff1a;border-color:#ffffff26;transform:translateY(-1px)}.btn-danger{background:var(--grad-danger);color:#fff;box-shadow:0 4px 16px var(--danger-glow)}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f43f5e66}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;align-items:center;gap:5px;padding:4px 11px;font-size:.71rem;font-weight:700;display:inline-flex}.badge-pending{background:var(--warning-glow);color:var(--warning-light);border:1px solid var(--warning-border)}.badge-approved,.badge-compliant,.badge-paid,.badge-active{background:var(--success-glow);color:var(--success-light);border:1px solid var(--success-border)}.badge-rejected,.badge-non_compliant,.badge-inactive{background:var(--danger-glow);color:var(--danger-light);border:1px solid var(--danger-border)}.badge-under_review{background:var(--info-glow);color:var(--info);border:1px solid var(--info-border)}.badge-present{background:var(--success-glow);color:var(--success-light);border:1px solid var(--success-border)}.badge-absent{background:var(--danger-glow);color:var(--danger-light);border:1px solid var(--danger-border)}.badge-late{background:var(--warning-glow);color:var(--warning-light);border:1px solid var(--warning-border)}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #8b5cf600}50%{box-shadow:0 0 16px 4px #8b5cf64d}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fadeIn var(--t-normal) forwards}.animate-slide-in{animation:slideInLeft var(--t-normal) forwards}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr));gap:20px;display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;display:grid}.login-container.split-layout{background-color:var(--bg-base);min-height:100vh;margin:0;padding:0;display:flex}.login-image-side{background-image:url(https://images.unsplash.com/photo-1542744173-8e7e53415bb0?q=80&w=1600&auto=format&fit=crop);background-position:50%;background-size:cover;flex:1;display:none;position:relative}@media (width>=900px){.login-image-side{align-items:flex-end;padding:60px;display:flex}}.login-image-side:after{content:"";z-index:1;background:linear-gradient(#0f172a1a,#0f172a33 40%,#0f172ae6);position:absolute;inset:0}.login-image-overlay{z-index:2;color:#fff;max-width:520px;position:relative}.login-image-overlay h2{font-size:2.8rem;font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:16px;font-weight:800;line-height:1.1}.login-image-overlay p{opacity:.9;font-size:1.15rem;line-height:1.6}.login-form-side{background-color:var(--bg-base);flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-card{width:100%;max-width:400px;box-shadow:none;z-index:10;background:0 0;border:none;padding:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUpFade;position:relative}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:left;margin-bottom:40px}.login-logo{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.04em;margin-bottom:8px;font-size:2.2rem;font-weight:800}.login-subtitle{color:var(--text-secondary);font-size:.95rem;font-weight:400}.form-group{margin-bottom:24px}.form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.form-group input{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-surface);width:100%;color:var(--text-primary);transition:all var(--t-fast);padding:12px 16px;font-size:.95rem}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow);background:var(--bg-surface);outline:none}.form-error{background:var(--danger-glow);color:var(--danger);border:1px solid var(--danger-border);border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:.88rem;animation:.2s ease-out fadeIn;display:flex}.dashboard-shell{background:var(--bg-base);min-height:100vh;display:flex}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border-color);z-index:20;flex-direction:column;flex-shrink:0;width:260px;padding:28px 16px;display:flex;position:relative;overflow:hidden}.sidebar:before{display:none}.sidebar-logo{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.03em;align-items:center;gap:10px;margin-bottom:32px;padding:0 8px;font-size:1.25rem;font-weight:800;display:flex}.sidebar-logo-icon{color:var(--primary)}.sidebar-user{border-radius:var(--radius-md);background:var(--bg-hover);border:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:28px;padding:14px;display:flex;position:relative}.sidebar-avatar{background:var(--grad-primary);color:#fff;width:40px;height:40px;box-shadow:0 4px 12px var(--primary-glow);letter-spacing:-.02em;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:flex}.sidebar-user-info{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar-username{white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);font-size:.88rem;font-weight:700;overflow:hidden}.sidebar-role{background:var(--grad-primary);-webkit-text-fill-color:transparent;text-transform:uppercase;letter-spacing:.1em;-webkit-background-clip:text;background-clip:text;font-size:.7rem;font-weight:700}.sidebar-nav{flex-direction:column;flex-grow:1;gap:4px;display:flex}.sidebar-nav-label{text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);padding:14px 12px 6px;font-size:.65rem;font-weight:700}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--t-normal);-webkit-user-select:none;user-select:none;border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-size:.92rem;font-weight:500;display:flex;position:relative;overflow:hidden}.nav-item svg{transition:color var(--t-fast);opacity:.7;flex-shrink:0}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover);transform:translate(4px)}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--primary-glow-sm);color:var(--primary);border-color:var(--primary-glow);font-weight:600;box-shadow:inset 0 1px 2px #fffc}.nav-item.active:before{content:"";background:var(--grad-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;width:4px;position:absolute;top:0;bottom:0;left:0}.nav-item.active svg{color:var(--primary);opacity:1}.sidebar-footer{border-top:1px solid var(--border-color);margin-top:auto;padding-top:16px}.main-wrapper{flex-direction:column;flex-grow:1;height:100vh;display:flex;overflow-x:hidden}.header{border-bottom:1px solid var(--border-color);background:var(--bg-surface);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;height:68px;padding:0 36px;display:flex;position:relative}.header:before{content:"";background:linear-gradient(90deg,#0000,#8b5cf680 30%,#06b6d466 70%,#0000);height:1px;position:absolute;top:0;left:0;right:0}.header-search{width:380px;position:relative}.header-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.header-search input{border-radius:var(--radius-full);background:#00000008;border-color:#00000014;height:40px;padding-left:44px;font-size:.88rem}.header-search input:focus{background:#8b5cf60f}.header-actions{align-items:center;gap:14px;display:flex}.badge-online{color:var(--success-light);border:1px solid var(--success-border);border-radius:var(--radius-full);letter-spacing:.08em;text-transform:uppercase;background:#10b9811f;align-items:center;gap:6px;padding:5px 12px;font-size:.72rem;font-weight:700;display:flex}.badge-online:before{content:"";background:var(--success-light);width:7px;height:7px;box-shadow:0 0 8px var(--success);border-radius:50%;animation:2s ease-in-out infinite pulse-glow}.content-viewport{flex-grow:1;padding:36px 40px;position:relative;overflow-y:auto}.view-header{justify-content:space-between;align-items:flex-end;margin-bottom:32px;display:flex}.view-title-wrap h2{color:var(--text-primary);letter-spacing:-.04em;margin-bottom:5px;font-size:1.9rem;font-weight:800}.view-subtitle{color:var(--text-secondary);font-size:.88rem;font-weight:400}.metrics-grid{margin-bottom:32px}.metric-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--t-normal);cursor:default;flex-direction:column;align-items:flex-start;gap:12px;padding:24px;display:flex;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-focus);transform:translateY(-2px)}.metric-card-icon{border-radius:var(--radius-sm);background:var(--accent-bg,#6366f11a);width:42px;height:42px;color:var(--accent-color,var(--primary));flex-shrink:0;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.metric-card-value{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.02em;font-size:2.2rem;font-weight:800;line-height:1}.metric-card-info h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.65rem;font-weight:700;font-family:var(--font-sans);margin:0}.table-container{background:0 0;margin-bottom:32px;overflow-x:auto}.table-header-bar{justify-content:space-between;align-items:center;padding:20px 0;display:flex}.table-header-title{color:var(--text-primary);font-size:1rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;text-transform:uppercase}.table-filters{gap:12px;display:flex}.table-filters select,.table-filters input{width:auto;min-width:150px;height:36px;padding:6px 12px;font-size:.83rem}table{border-collapse:separate;border-spacing:0 8px;text-align:left;width:100%}th{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap;background:0 0;border:none;padding:0 24px 12px;font-size:.7rem;font-weight:800}tr{background:var(--bg-card);transition:all var(--t-normal);border-radius:var(--radius-md);box-shadow:0 2px 6px #00000008}tr:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000000f}td{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);color:var(--text-secondary);transition:color var(--t-fast);padding:16px 24px;font-size:.88rem;font-weight:500}td:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md);border-left:1px solid var(--border-color)}td:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);border-right:1px solid var(--border-color)}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge:before{content:"";border-radius:50%;width:6px;height:6px}.badge-pending,.badge-warning{background:var(--warning-glow);color:var(--warning)}.badge-pending:before,.badge-warning:before{background:var(--warning)}.badge-approved,.badge-active,.badge-success{background:var(--success-glow);color:var(--success)}.badge-approved:before,.badge-active:before,.badge-success:before{background:var(--success)}.badge-rejected,.badge-inactive,.badge-danger{background:var(--danger-glow);color:var(--danger)}.badge-rejected:before,.badge-inactive:before,.badge-danger:before{background:var(--danger)}.table-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--t-fast);background:var(--bg-tertiary);color:var(--text-secondary);border:none;padding:4px 10px;font-size:.75rem;font-weight:600}.table-btn:hover{filter:brightness(.95)}.table-btn.btn-primary{background:var(--info-glow);color:var(--info)}.table-btn.btn-danger{background:var(--danger-glow);color:var(--danger)}.bank-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:28px;display:grid}.bank-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--t-normal);padding:28px;position:relative;overflow:hidden}.bank-card:before{content:"";background:var(--grad-primary);opacity:.6;height:2px;position:absolute;top:0;left:0;right:0}.bank-card:hover{box-shadow:var(--shadow-md), 0 0 0 1px #8b5cf626;border-color:#8b5cf633;transform:translateY(-5px)}.bank-card-bg-glow{pointer-events:none;background:radial-gradient(circle,#8b5cf614,#0000 70%);border-radius:50%;width:200px;height:200px;position:absolute;bottom:-60px;right:-60px}.bank-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.bank-logo{border-radius:var(--radius-sm);color:var(--primary-light);background:#8b5cf61a;border:1px solid #8b5cf633;padding:10px}.bank-details{text-align:right}.bank-name{color:var(--text-secondary);font-size:.82rem;font-weight:600}.bank-number{font-family:var(--font-display);letter-spacing:.05em;color:var(--text-muted);font-size:.88rem}.bank-card-body h4{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-sans);margin-bottom:8px}.bank-balance{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.04em;font-size:2.2rem;font-weight:800}.action-buttons{gap:8px;display:flex}.action-btn-circle{border:1px solid var(--glass-border);cursor:pointer;width:34px;height:34px;color:var(--text-muted);transition:all var(--t-normal);background:#ffffff0a;border-radius:50%;justify-content:center;align-items:center;display:flex}.action-btn-circle:hover{color:var(--text-primary);background:#ffffff14;transform:scale(1.12)}.action-btn-circle.approve:hover{color:var(--success-light);border-color:var(--success-border);background:var(--success-glow);box-shadow:0 0 12px #10b98140}.action-btn-circle.reject:hover{color:var(--danger-light);border-color:var(--danger-border);background:var(--danger-glow);box-shadow:0 0 12px #f43f5e40}.modal-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-xl);background:var(--bg-elevated);border:1px solid var(--border-color);width:100%;max-width:600px;animation:.25s ease-out fadeIn;position:relative;overflow:hidden;box-shadow:0 20px 40px #0000001a}.modal-content:before{content:"";background:var(--grad-primary);height:2px;position:absolute;top:0;left:0;right:0}.modal-header{border-bottom:1px solid var(--border-color);background:#00000005;justify-content:space-between;align-items:center;padding:22px 28px;display:flex}.modal-header h3{letter-spacing:-.02em;color:var(--text-primary);font-size:1.05rem;font-weight:700}.modal-body{max-height:65vh;padding:28px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background:#00000004;justify-content:flex-end;gap:12px;padding:20px 28px;display:flex}.close-btn{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:all var(--t-normal);background:#0000000f;border-radius:50%;justify-content:center;align-items:center;padding:7px;display:flex}.close-btn:hover{background:var(--danger-glow);color:var(--danger-light);border-color:var(--danger-border);transform:rotate(90deg)}.file-upload-zone{text-align:center;border-radius:var(--radius-md);cursor:pointer;transition:all var(--t-normal);color:var(--text-secondary);background:#8b5cf60a;border:2px dashed #8b5cf640;flex-direction:column;align-items:center;gap:12px;padding:32px;display:flex}.file-upload-zone:hover{border-color:var(--primary);background:var(--primary-glow-sm);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot-pending{background:var(--warning);box-shadow:0 0 6px var(--warning)}.status-dot-approved{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot-rejected{background:var(--danger);box-shadow:0 0 6px var(--danger)}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.empty-state svg{opacity:.15;color:var(--primary-light)}.admin-tab-bar,.hrm-tab-bar{background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-wrap:wrap;gap:4px;width:fit-content;margin-bottom:28px;padding:6px;display:flex}.hrm-tab-bar{background:var(--bg-hover)}.admin-tab,.hrm-tab{border-radius:var(--radius-xs);cursor:pointer;transition:all var(--t-normal);color:var(--text-muted);white-space:nowrap;-webkit-user-select:none;user-select:none;background:0 0;border:none;align-items:center;gap:8px;padding:9px 20px;font-size:.88rem;font-weight:600;display:flex}.admin-tab:hover,.hrm-tab:hover{color:var(--text-secondary);background:#0000000a}.admin-tab.active,.hrm-tab.active{background:var(--bg-surface);color:var(--primary);box-shadow:var(--shadow-sm);border:1px solid #0000000d}.logs-viewer{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden}.logs-viewer table th{background:#00000008}.reports-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:32px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--t-normal);padding:0;overflow:hidden;box-shadow:0 4px 12px #00000008}.chart-card:hover{border-color:#8b5cf626;box-shadow:0 8px 24px #0000000f}.chart-header{border-bottom:1px solid var(--border-subtle);background:0 0;padding:20px 24px 16px}.chart-title{color:var(--text-primary);font-size:.92rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;display:block}.chart-subtitle{color:var(--text-muted);margin-top:3px;font-size:.76rem}.chart-content{justify-content:center;align-items:center;min-height:200px;padding:20px;display:flex}.chart-bar{transition:opacity var(--t-fast), filter var(--t-fast);cursor:default;rx:3}.chart-bar:hover{opacity:.85;filter:brightness(1.15)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--t-normal)}.card:hover{box-shadow:var(--shadow-md);border-color:#8b5cf626}.salary-deadline-banner{border-radius:var(--radius-md);border:1px solid;align-items:center;gap:16px;margin-bottom:24px;padding:18px 24px;display:flex}.salary-deadline-banner.overdue{border-color:var(--danger-border);color:var(--danger-light);background:#f43f5e14}.salary-deadline-banner.due-soon{border-color:var(--warning-border);color:var(--warning-light);background:#f59e0b14}.salary-deadline-banner.ok{background:var(--success-glow);border-color:var(--success-border);color:var(--success-light)}#printable-payslip{font-family:var(--font-sans)!important;color:#1a1a2e!important}.pagination{justify-content:center;align-items:center;gap:8px;margin-top:20px;display:flex}.pagination button{border-radius:var(--radius-xs);min-width:36px;height:36px;padding:0 10px;font-size:.85rem;font-weight:600}.search-results-section{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color)}.leave-day-cell{border-radius:var(--radius-xs);padding:3px 6px;font-size:.75rem}.alert-banner{border-radius:var(--radius-md);border:1px solid;align-items:flex-start;gap:14px;margin-bottom:20px;padding:14px 20px;font-size:.88rem;display:flex}.alert-danger{border-color:var(--danger-border);color:var(--danger-light);background:#f43f5e14}.alert-warning{border-color:var(--warning-border);color:var(--warning-light);background:#f59e0b14}.alert-success{border-color:var(--success-border);color:var(--success-light);background:#10b98114}.alert-info{border-color:var(--info-border);color:var(--info);background:#38bdf814}[title]{cursor:help}button[title]{cursor:pointer}.totp-secret-box{border-radius:var(--radius-sm);text-align:center;letter-spacing:.15em;color:var(--primary-light);word-break:break-all;background:#8b5cf614;border:1px solid #8b5cf633;padding:16px 20px;font-family:monospace;font-size:1.25rem;font-weight:700}.divider{background:var(--border-color);height:1px;margin:24px 0}.text-gradient{background:var(--grad-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.glow-primary{box-shadow:var(--shadow-glow)}.chart-bar-container:hover .chart-bar{filter:brightness(1.15)}@media (width<=1200px){.reports-grid{grid-template-columns:1fr}.grid-cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){.sidebar{width:220px}.content-viewport{padding:24px 20px}.header{padding:0 20px}.header-search{width:260px}}@media (width<=700px){.dashboard-shell{flex-direction:column}.sidebar{flex-flow:wrap;width:100%;height:auto;padding:16px}.main-wrapper{height:auto}.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}}.notifications-dropdown-container{position:relative}.notifications-bell-btn{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--t-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex}.notifications-bell-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.notifications-bell-btn.active{background:var(--bg-hover);color:var(--primary)}.notifications-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);min-width:16px;height:16px;box-shadow:0 0 0 2px var(--bg-surface), 0 0 8px #f43f5e66;justify-content:center;align-items:center;padding:2px 6px;font-size:.68rem;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notifications-popover{z-index:90;border-radius:var(--radius-md);width:360px;max-height:480px;box-shadow:var(--shadow-lg), 0 10px 30px #00000026;background:var(--bg-elevated);flex-direction:column;animation:.2s ease-out fadeIn;display:flex;position:absolute;top:48px;right:0;overflow:hidden}.notifications-header{border-bottom:1px solid var(--border-color);background:#00000005;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.notifications-header h4{color:var(--text-primary);margin:0;font-size:.95rem;font-weight:700}.mark-all-read-btn{color:var(--primary-light);cursor:pointer;border-radius:var(--radius-xs);transition:all var(--t-fast);background:0 0;border:none;align-items:center;padding:4px 8px;font-size:.78rem;font-weight:600;display:flex}.mark-all-read-btn:hover{background:var(--primary-glow-sm);color:var(--primary)}.notifications-list{flex-direction:column;flex:1;display:flex;overflow-y:auto}.notifications-empty-state{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:.85rem}.notification-item{cursor:pointer;border-bottom:1px solid var(--border-subtle);transition:all var(--t-fast);gap:12px;padding:14px 20px;display:flex}.notification-item:hover{background:var(--bg-hover)}.notification-item.unread{background:#8b5cf608}.notification-icon-wrapper{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.notification-content{flex:1;min-width:0}.notification-title-wrap{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.notification-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.83rem;font-weight:700;overflow:hidden}.unread-indicator-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:6px;height:6px}.notification-message{color:var(--text-secondary);margin:0 0 6px;font-size:.8rem;line-height:1.4}.notification-time{color:var(--text-muted);font-size:.7rem;display:block}.noti-icon-tx{color:var(--info)}.noti-icon-refund{color:var(--danger)}.noti-icon-leave{color:var(--warning)}.noti-icon-payroll{color:var(--success)}@media print{body{color:#000!important;background:#fff!important;font-size:11pt!important}.sidebar,.header,.btn,button,.admin-tab-bar,.hrm-tab-bar,input,select,.table-filters,.glass-panel:not(.print-panel){display:none!important}.main-wrapper{height:auto!important;margin:0!important;padding:0!important;overflow:visible!important}.content-viewport{margin:0!important;padding:0!important;overflow:visible!important}.glass-panel.print-panel,.chart-card{box-shadow:none!important;page-break-inside:avoid!important;background:0 0!important;border:none!important;overflow:visible!important}.reports-grid{display:block!important}.chart-card{page-break-inside:avoid!important;margin-bottom:30px!important}table{border-spacing:0!important;border-collapse:collapse!important;width:100%!important}tr{box-shadow:none!important;page-break-inside:avoid!important;background:0 0!important}td,th{border:1px solid #ddd!important;padding:8px 12px!important}th{color:#000!important;background-color:#f2f2f2!important;font-weight:700!important}h2,h3,h4{color:#000!important}.text-gradient{color:#000!important;-webkit-text-fill-color:initial!important;background:0 0!important}}
