:root{--bg:#f5f5f0;--surface:#fff;--border:#e2e2da;--text:#1a1a18;--text-muted:#6b6b63;--primary:#1c6ef2;--primary-dk:#1456cc;--danger:#dc2626;--danger-dk:#b91c1c;--success:#16a34a;--warning:#d97706;--radius:10px;--shadow:0 1px 3px #00000014, 0 4px 12px #0000000a;--shadow-lg:0 8px 32px #0000001f, 0 2px 8px #0000000f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,system-ui,sans-serif;line-height:1.5}.app{min-height:100vh}.container{max-width:1140px;margin:0 auto;padding:32px 20px 60px}.app-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.app-header h1{letter-spacing:-.02em;color:var(--text);font-size:1.75rem;font-weight:600}.subtitle{color:var(--text-muted);margin-top:2px;font-size:.9rem}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 4px #1c6ef24d}.btn-primary:hover{background:var(--primary-dk);box-shadow:0 2px 8px #1c6ef266}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-sort{background:var(--surface);color:var(--text-muted);border:1px solid var(--border);padding:6px 12px;font-size:.8125rem}.btn-sort:hover,.btn-sort.active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-edit{color:var(--primary);background:#eff6ff;border:1px solid #bfdbfe;padding:5px 12px;font-size:.8125rem}.btn-edit:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-delete{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;padding:5px 12px;font-size:.8125rem}.btn-delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.alert{border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:.875rem;display:flex}.alert-success{color:var(--success);background:#f0fdf4;border:1px solid #bbf7d0}.alert-error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.toolbar-left,.toolbar-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-wrap{align-items:center;display:flex;position:relative}.search-icon{pointer-events:none;font-size:.85rem;position:absolute;left:11px}.search-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);width:240px;padding:8px 32px 8px 34px;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1c6ef21f}.clear-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.8rem;line-height:1;position:absolute;right:8px}.clear-btn:hover{color:var(--text);background:var(--bg)}.select-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;padding:8px 12px;font-family:inherit;font-size:.875rem}.select-input:focus{border-color:var(--primary);outline:none}.stats-bar{color:var(--text-muted);gap:24px;margin-bottom:12px;padding:0 2px;font-size:.8125rem;display:flex}.stats-bar strong{color:var(--text)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto hidden}.emp-table{border-collapse:collapse;width:100%;font-size:.875rem}.emp-table thead{border-bottom:1px solid var(--border);background:#fafafa}.emp-table thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:12px 16px;font-size:.8125rem;font-weight:600}.emp-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.emp-table thead th.sortable:hover{color:var(--primary)}.emp-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.emp-table tbody tr:last-child{border-bottom:none}.emp-table tbody tr:hover{background:#fafaf8}.emp-table td{vertical-align:middle;padding:13px 16px}.row-num{color:var(--text-muted);width:40px;font-family:DM Mono,monospace;font-size:.8rem}.emp-name{font-weight:500}.salary-cell{color:#15803d;font-family:DM Mono,monospace;font-size:.875rem;font-weight:500}.actions-cell{align-items:center;gap:8px;display:flex}.dept-badge{white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:.8rem;font-weight:500;display:inline-block}.sort-neutral{color:#d1d5db;margin-left:4px;font-size:.75rem}.sort-active{color:var(--primary);margin-left:4px;font-size:.8rem;font-weight:700}.empty-state{text-align:center;color:var(--text-muted);padding:64px 20px}.empty-icon{margin-bottom:12px;font-size:3rem}.empty-state h3{color:var(--text);margin-bottom:6px;font-size:1.1rem}.empty-state p{font-size:.875rem}.loading-spinner-wrap{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:64px 20px;font-size:.875rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);box-shadow:var(--shadow-lg);border-radius:14px;width:100%;max-width:540px;padding:28px;animation:.2s cubic-bezier(.22,.61,.36,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{align-items:center;gap:8px;font-size:1.2rem;font-weight:600;display:flex}.id-badge{color:var(--text-muted);font-family:DM Mono,monospace;font-size:.8rem;font-weight:400}.close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:6px;font-size:1rem;line-height:1;transition:background .1s,color .1s}.close-btn:hover{background:var(--bg);color:var(--text)}.emp-form{flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.form-group input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);padding:9px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1c6ef21a}.form-group input::placeholder{color:#c0bfb8}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:4px;padding-top:16px;display:flex}@media (width<=600px){.form-row{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right,.search-input{width:100%}.app-header{flex-direction:column}.emp-table{min-width:600px}}.analytics-section{background:#fff;border:1px solid #e2e2da;border-radius:10px;margin-bottom:20px;padding:20px 24px}.section-title{color:#1a1a18;margin-bottom:14px;font-size:1rem;font-weight:600}.analytics-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.analytic-card{background:#f5f5f0;border-radius:8px;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.analytic-label{color:#6b6b63;text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:500}.analytic-value{color:#1a1a18;font-size:1.2rem;font-weight:700}.analytic-green{color:#15803d}.analytic-blue{color:#1d4ed8}.analytic-orange{color:#c2410c}.dept-count-title{color:#6b6b63;margin-bottom:10px;font-size:.875rem;font-weight:600}.dept-count-list{flex-direction:column;gap:8px;display:flex}.dept-count-item{align-items:center;gap:12px;display:flex}.dept-count-badge{white-space:nowrap;border-radius:999px;padding:2px 10px;font-size:.78rem;font-weight:500}.dept-count-bar-wrap{background:#f0f0ea;border-radius:4px;flex:1;height:8px;overflow:hidden}.dept-count-bar{background:#1c6ef2;border-radius:4px;height:100%;transition:width .4s}.dept-count-num{color:#6b6b63;white-space:nowrap;text-align:right;min-width:90px;font-size:.8rem}.grade-badge,.category-badge{white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:2px 10px;font-size:.78rem;font-weight:600;display:inline-block}.bonus-cell{color:#6d28d9;font-family:DM Mono,monospace;font-size:.85rem}.total-salary-cell{color:#1d4ed8;font-family:DM Mono,monospace;font-size:.85rem;font-weight:600}body{margin:0;font-family:Arial,sans-serif}
