@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.woff2) format("woff2");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.woff2) format("woff2");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.woff2) format("woff2");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.woff2) format("woff2");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.woff2) format("woff2");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Material Symbols Outlined;font-style:normal;font-weight:100 700;font-display:swap;src:url(https://fonts.gstatic.com/s/materialsymbolsoutlined/v323/kJEhBvYX7BgnkSrUwT8OhrdQw4oELdPIeeII9v6oFsI.woff2) format("woff2")}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}.btn{display:flex;align-items:center;gap:8px;padding:9px 18px;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn .material-symbols-outlined{font-size:18px}.btn-primary{background:#d97706;color:#fff}.btn-primary:hover{background:#b45309}.btn-outline{background:#fff;border:1.5px solid #e2e8f0;color:#475569;position:relative}.btn-outline:hover{background:#f8fafc}.btn-ghost{background:none;border:1.5px solid #e2e8f0;color:#475569}.btn-ghost:hover{background:#f1f5f9}.btn-sm{padding:7px 14px;font-size:13px}.btn-alert{border-color:#fca5a5!important;color:#dc2626!important}.btn-alert:hover{background:#fef2f2!important}.pending-dot{position:absolute;top:-4px;right:-4px;width:9px;height:9px;border-radius:50%;background:#ef4444;border:2px solid white;animation:hr-blink 1s steps(1) infinite}@keyframes hr-blink{0%,to{opacity:1}50%{opacity:0}}.filters-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#94a3b8;pointer-events:none}.search-input{width:100%;padding:9px 12px 9px 40px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:14px;outline:none;background:#fff;box-sizing:border-box}.search-input:focus{border-color:#d97706;box-shadow:0 0 0 3px #d977061a}.filter-select{padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:13px;background:#fff;color:#374151;outline:none;cursor:pointer}.filter-select:focus{border-color:#d97706}.ml-auto{margin-left:auto}.role-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px}.role-badge .material-symbols-outlined{font-size:13px}.status-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px}.contract-badge{font-size:11px;font-weight:700}.section-badge{background:#d97706;color:#fff;font-size:11px;font-weight:800;padding:1px 7px;border-radius:10px}.section-badge-red{background:#ef4444}.tab-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:800;padding:1px 6px;border-radius:10px}.tab-badge-red{background:#ef4444}.mini-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}.mini-avatar.sm{width:26px;height:26px;font-size:10px}.action-btn{display:flex;align-items:center;padding:6px;border-radius:8px;border:none;background:none;cursor:pointer;color:#94a3b8;transition:all .15s}.action-btn .material-symbols-outlined{font-size:18px}.action-btn:hover{background:#f1f5f9;color:#475569}.action-btn.action-delete:hover{background:#fef2f2;color:#ef4444}.icon-btn{display:flex;align-items:center;padding:8px;border:1.5px solid #e2e8f0;border-radius:9px;background:#fff;cursor:pointer;color:#475569;transition:all .2s}.icon-btn:hover{background:#f1f5f9}.empty-state{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:48px;text-align:center;color:#94a3b8;display:flex;flex-direction:column;align-items:center;gap:12px}.empty-state .material-symbols-outlined{font-size:38px}.empty-state p{font-size:14px;margin:0}.empty-state-sm{display:flex;align-items:center;gap:10px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;color:#94a3b8;font-size:13px}.empty-state-sm .material-symbols-outlined{font-size:20px}.section-block{margin-top:24px;display:flex;flex-direction:column;gap:10px}.section-block-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#0f172a;margin:0 0 8px}.section-block-title .material-symbols-outlined{font-size:18px;color:#64748b}.main-content{display:grid;grid-template-columns:1fr;gap:16px}.main-content:has(.detail-panel){grid-template-columns:1fr 360px}.staff-list{display:flex;flex-direction:column;gap:8px}.staff-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;transition:all .2s}.staff-card:hover{box-shadow:0 4px 12px #00000012;border-color:#cbd5e1}.staff-card.selected{border-color:#d97706;box-shadow:0 0 0 2px #d9770626}.staff-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}.staff-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.staff-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.staff-name{font-size:14px;font-weight:700;color:#0f172a}.staff-meta{display:flex;align-items:center;gap:4px;font-size:12px;color:#64748b;flex-wrap:wrap}.staff-meta .material-symbols-outlined{font-size:13px}.staff-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.staff-actions{display:flex;gap:2px;flex-shrink:0}.leave-gauge-row{display:flex;align-items:center;gap:8px}.leave-gauge{flex:1;height:5px;background:#f1f5f9;border-radius:10px;overflow:hidden;max-width:160px}.leave-gauge-fill{height:100%;background:#22c55e;border-radius:10px;transition:width .4s}.leave-gauge-fill.gauge-warn{background:#f97316}.leave-gauge-fill.gauge-full{background:#ef4444}.full-gauge{width:100%;max-width:100%;height:8px}.leave-gauge-label{font-size:11px;color:#64748b;white-space:nowrap}.detail-panel{background:#fff;border-radius:14px;border:1px solid #e2e8f0;display:flex;flex-direction:column;position:sticky;top:16px;max-height:calc(100vh - 120px);overflow:hidden}.detail-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid #f1f5f9;flex-shrink:0}.detail-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:#fff;flex-shrink:0}.detail-identity{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.detail-name{font-size:15px;font-weight:700;color:#0f172a;margin:0}.close-btn{background:none;border:none;cursor:pointer;padding:6px;color:#94a3b8;border-radius:8px;display:flex;align-items:center}.close-btn:hover{background:#f1f5f9;color:#475569}.detail-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.detail-footer{padding:12px 14px;border-top:1px solid #f1f5f9;flex-shrink:0;display:flex;gap:8px;justify-content:flex-end}.detail-section{background:#f8fafc;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px}.detail-section-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0}.detail-section-title .material-symbols-outlined{font-size:14px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.detail-field{display:flex;flex-direction:column;gap:3px}.field-label{font-size:11px;color:#94a3b8;font-weight:600;text-transform:uppercase}.field-value{font-size:13px;color:#334155}.leave-summary{display:flex;gap:16px}.leave-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.leave-stat-val{font-size:22px;font-weight:800;color:#0f172a}.leave-stat-val.used{color:#f97316}.leave-stat-val.remaining{color:#16a34a}.leave-stat-lbl{font-size:11px;color:#94a3b8}.leave-history{display:flex;flex-direction:column;gap:6px}.leave-item{display:flex;align-items:center;gap:10px;padding:8px;background:#fff;border-radius:8px;border:1px solid #f1f5f9}.leave-type-icon{font-size:18px;color:#64748b;flex-shrink:0}.leave-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.leave-item-type{font-size:12px;font-weight:700;color:#334155}.leave-item-dates{font-size:11px;color:#94a3b8}.leave-status-chip{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;flex-shrink:0}.ls-pending{background:#fffbeb;color:#d97706}.ls-approved{background:#f0fdf4;color:#16a34a}.ls-rejected{background:#fef2f2;color:#dc2626}.leave-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:14px 16px;display:flex;align-items:center;gap:14px}.leave-card-pending{border-color:#fde68a;background:#fffdf5}.lc-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}.lc-info{min-width:140px;display:flex;flex-direction:column;gap:2px}.lc-name{font-size:13px;font-weight:700;color:#0f172a}.lc-meta{font-size:11px;color:#94a3b8}.lc-leave{flex:1;display:flex;align-items:flex-start;gap:10px}.lc-leave>.material-symbols-outlined{font-size:20px;color:#64748b;flex-shrink:0;margin-top:1px}.lc-leave-detail{display:flex;flex-direction:column;gap:2px}.lc-leave-type{font-size:13px;font-weight:700;color:#334155}.lc-leave-dates{font-size:12px;color:#64748b}.lc-leave-reason{font-size:12px;color:#94a3b8;font-style:italic}.lc-actions{display:flex;gap:6px;flex-shrink:0}.lc-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;border:1.5px solid;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}.lc-btn .material-symbols-outlined{font-size:15px}.lc-approve{border-color:#86efac;background:#f0fdf4;color:#16a34a}.lc-approve:hover{background:#dcfce7}.lc-reject{border-color:#fca5a5;background:#fef2f2;color:#dc2626}.lc-reject:hover{background:#fee2e2}.dpc-mini{display:flex;flex-direction:column;gap:6px}.dpc-mini-row{display:flex;justify-content:space-between;font-size:12px;color:#64748b}.dpc-mini-val{font-weight:700;color:#0f172a}.dpc-compliant{background:#22c55e!important}.dpc-at_risk{background:#f97316!important}.dpc-non_compliant{background:#ef4444!important}.dpc-status-chip{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;align-self:flex-start}.dpc-chip-compliant{background:#f0fdf4;color:#16a34a}.dpc-chip-at_risk{background:#fff7ed;color:#d97706}.dpc-chip-non_compliant{background:#fef2f2;color:#dc2626}.planning-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.week-label{font-size:14px;font-weight:700;color:#0f172a;min-width:180px;text-align:center}.shift-legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.legend-item{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px}.legend-item .material-symbols-outlined{font-size:13px}.planning-grid-wrap{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.planning-table{width:100%;border-collapse:collapse;min-width:900px}.planning-table thead th{background:#f8fafc;padding:10px 12px;font-size:12px;font-weight:700;color:#64748b;text-align:center;border-bottom:1px solid #e2e8f0;white-space:nowrap}.col-staff{text-align:left!important;min-width:180px}.col-day{min-width:110px}.col-total{min-width:70px}.planning-table th.today,.planning-table td.today{background:#fffbeb}.cell-staff{padding:8px 12px;border-bottom:1px solid #f1f5f9}.cell-staff-inner{display:flex;align-items:center;gap:8px}.cell-staff-name{font-size:12px;font-weight:700;color:#0f172a}.cell-staff-role{font-size:11px;color:#94a3b8}.cell-day{padding:6px 8px;border-bottom:1px solid #f1f5f9;border-left:1px solid #f1f5f9;vertical-align:top}.cell-total{padding:6px 10px;border-bottom:1px solid #f1f5f9;border-left:1px solid #e2e8f0;text-align:center;font-size:13px;font-weight:700;color:#475569}.shift-chip{display:flex;align-items:center;gap:4px;padding:3px 7px;border-radius:8px;font-size:11px;font-weight:600;margin-bottom:3px;white-space:nowrap;cursor:pointer;position:relative}.shift-chip:hover{filter:brightness(.95)}.shift-chip .material-symbols-outlined{font-size:13px}.ot-badge{background:#ef4444;color:#fff;font-size:9px;font-weight:800;padding:1px 4px;border-radius:6px}.shift-delete-btn{display:none;align-items:center;justify-content:center;background:#0000001f;border:none;border-radius:4px;cursor:pointer;padding:1px;margin-left:2px;color:inherit}.shift-delete-btn .material-symbols-outlined{font-size:12px}.shift-chip:hover .shift-delete-btn{display:flex}.cell-empty{cursor:pointer}.cell-empty:hover{background:#f0f9ff!important}.cell-add-hint{display:none;align-items:center;justify-content:center;color:#cbd5e1}.cell-add-hint .material-symbols-outlined{font-size:16px}.cell-empty:hover .cell-add-hint{display:flex}.alert-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:10px;font-size:13px;margin-top:14px}.alert-info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.alert-info .material-symbols-outlined{font-size:18px}.alerts-block{margin-bottom:20px}.alerts-list{display:flex;flex-direction:column;gap:6px}.alert-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;border:1px solid}.alert-error{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.alert-warning{background:#fffbeb;border-color:#fde68a;color:#d97706}.alert-item .material-symbols-outlined{font-size:18px;flex-shrink:0}.alert-item-info{flex:1;display:flex;flex-direction:column;gap:1px}.alert-item-name{font-size:13px;font-weight:700}.alert-item-label{font-size:12px;opacity:.8}.alert-dept{font-size:11px;font-weight:600;opacity:.7}.medical-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.medical-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:16px;display:flex;flex-direction:column;gap:12px}.mc-header{display:flex;align-items:center;gap:10px}.mc-identity{display:flex;flex-direction:column;gap:2px}.mc-name{font-size:14px;font-weight:700;color:#0f172a}.mc-dept{font-size:12px;color:#64748b}.mc-section{display:flex;flex-direction:column;gap:6px;padding-top:10px;border-top:1px solid #f1f5f9}.mc-section-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase}.mc-section-label .material-symbols-outlined{font-size:13px}.cert-list{display:flex;flex-direction:column;gap:5px}.cert-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cert-name{font-size:12px;color:#334155;flex:1}.cert-name.mandatory{font-weight:700}.cert-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px}.cert-chip .material-symbols-outlined{font-size:12px}.cert-expiry{font-size:11px;color:#94a3b8}.vaccine-chips{display:flex;flex-wrap:wrap;gap:6px}.occ-health{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.occ-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px}.occ-fit{background:#f0fdf4;color:#16a34a}.occ-fit_with_restrictions{background:#fffbeb;color:#d97706}.occ-unfit{background:#fef2f2;color:#dc2626}.occ-pending{background:#f1f5f9;color:#64748b}.occ-date{font-size:12px;color:#64748b}.occ-restriction{font-size:11px;color:#d97706;background:#fffbeb;padding:4px 8px;border-radius:8px}.payroll-header-info{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;font-size:13px;color:#1d4ed8;margin-bottom:16px}.payroll-header-info .material-symbols-outlined{font-size:18px}.payroll-list{display:flex;flex-direction:column;gap:12px}.payroll-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:16px;display:flex;flex-direction:column;gap:12px}.pc-identity{display:flex;align-items:center;gap:12px}.pc-name{font-size:14px;font-weight:700;color:#0f172a}.pc-dept{font-size:12px;color:#64748b}.pay-status-chip{margin-left:auto;font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px}.pay-paid{background:#f0fdf4;color:#16a34a}.pay-validated{background:#fffbeb;color:#d97706}.pay-draft{background:#f1f5f9;color:#64748b}.pc-figures{display:flex;gap:20px;flex-wrap:wrap;padding:10px;background:#f8fafc;border-radius:10px}.pc-fig{display:flex;flex-direction:column;gap:2px}.pc-fig-val{font-size:16px;font-weight:800;color:#0f172a}.pc-fig-val.indemnity{color:#0891b2}.pc-fig-val.gross{color:#d97706}.pc-fig-val.net{color:#16a34a}.pc-fig-val.overtime{color:#f97316}.pc-fig-lbl{font-size:11px;color:#94a3b8}.allowances-row{display:flex;gap:8px;flex-wrap:wrap}.allowance-chip{display:flex;align-items:center;gap:6px;padding:5px 10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;color:#475569}.allowance-chip .material-symbols-outlined{font-size:14px;color:#64748b}.allowance-amount{font-weight:700;color:#0f172a;margin-left:4px}.recruitment-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.recruit-section{display:flex;flex-direction:column;gap:10px}.substitutes-list{display:flex;flex-direction:column;gap:8px}.sub-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:12px 14px;display:flex;align-items:flex-start;gap:12px}.sub-info{flex:1;display:flex;flex-direction:column;gap:4px}.sub-name{font-size:13px;font-weight:700;color:#0f172a}.sub-role{font-size:12px;color:#64748b}.sub-units{display:flex;gap:5px;flex-wrap:wrap}.unit-chip{font-size:10px;background:#f1f5f9;color:#475569;padding:2px 7px;border-radius:6px}.sub-missions{font-size:11px;color:#94a3b8}.sub-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.avail-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px}.avail-available{background:#f0fdf4;color:#16a34a}.avail-partially{background:#fffbeb;color:#d97706}.avail-unavailable{background:#fef2f2;color:#dc2626}.sub-days{font-size:10px;color:#94a3b8;max-width:100px;text-align:right}.mobility-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:12px 14px;display:flex;align-items:center;gap:12px}.mob-info{flex:1;display:flex;flex-direction:column;gap:4px}.mob-name{font-size:13px;font-weight:700;color:#0f172a}.mob-route{display:flex;align-items:center;gap:6px;font-size:12px}.mob-route .material-symbols-outlined{font-size:15px;color:#94a3b8}.mob-from{color:#64748b}.mob-to{color:#0891b2;font-weight:700}.mob-reason{font-size:12px;color:#94a3b8;font-style:italic}.mob-date{font-size:11px;color:#64748b}.training-content{display:flex;flex-direction:column;gap:20px}.dpc-alerts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.dpc-alert-card{background:#fff;border-radius:12px;border:1px solid #fde68a;padding:12px 14px;display:flex;align-items:center;gap:12px}.dpc-alert-card.non-compliant{border-color:#fca5a5;background:#fef9f9}.dpc-info{flex:1;display:flex;flex-direction:column;gap:5px}.dpc-name{font-size:13px;font-weight:700;color:#0f172a}.dpc-dept{font-size:11px;color:#94a3b8}.dpc-progress-row{display:flex;align-items:center;gap:8px}.dpc-hrs{font-size:11px;font-weight:700;color:#475569;white-space:nowrap}.trainings-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.trainings-table{width:100%;border-collapse:collapse;min-width:900px}.trainings-table thead th{background:#f8fafc;padding:10px 12px;font-size:12px;font-weight:700;color:#64748b;text-align:left;border-bottom:1px solid #e2e8f0;white-space:nowrap}.trainings-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.trainings-table tbody tr:hover{background:#f8fafc}.trainings-table tbody tr.mandatory-row{background:#fffdf5}.trainings-table td{padding:10px 12px;font-size:13px;color:#334155;vertical-align:middle}.tr-agent{display:flex;align-items:center;gap:8px}.tr-title{font-weight:600}.mandatory-chip{font-size:10px;font-weight:700;background:#fef9c3;color:#a16207;padding:1px 6px;border-radius:6px;margin-left:6px}.type-badge{font-size:11px;font-weight:800}.tr-org,.tr-dates{color:#64748b;font-size:12px}.tr-num{text-align:center;font-weight:700}.tr-status{font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px}.ts-planned{background:#eff6ff;color:#2563eb}.ts-in_progress{background:#fffbeb;color:#d97706}.ts-completed{background:#f0fdf4;color:#16a34a}.ts-cancelled{background:#f1f5f9;color:#64748b}@media(max-width:1100px){.recruitment-grid{grid-template-columns:1fr}}@media(max-width:768px){.filters-bar{flex-direction:column}.staff-actions{display:none}.pc-figures{gap:12px}.medical-grid{grid-template-columns:1fr}}.settings-section{display:flex;flex-direction:column;gap:16px}.section-header{display:flex;align-items:center;gap:14px;margin-bottom:4px}.section-icon{font-size:28px}.section-title{font-size:18px;font-weight:800;color:#0f172a;margin:0 0 2px}.section-desc{font-size:13px;color:#64748b;margin:0}.section-header .btn{margin-left:auto}.settings-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:16px}.settings-card.no-padding{padding:0;overflow:hidden}.card-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:#0f172a;margin:0}.card-title .material-symbols-outlined{font-size:18px;color:#64748b}.field-group{display:flex;flex-direction:column;gap:6px;flex:1}.field-row{display:flex;gap:12px}.field-label{font-size:12px;font-weight:700;color:#374151}.form-input{padding:10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;transition:border .2s;width:100%;background:#fff;font-family:inherit;box-sizing:border-box}.form-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.form-input.field-invalid{border-color:#ef4444!important;background:#fff5f5}.form-input.field-invalid:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-select.field-invalid{border-color:#ef4444!important;background:#fff5f5}.field-error{font-size:11px;color:#ef4444;font-weight:600;margin-top:3px;display:flex;align-items:center;gap:3px}.field-error:before{content:"\26a0"}.select-wrap{position:relative}.form-select{width:100%;padding:10px 36px 10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;background:#fff;appearance:none;cursor:pointer;transition:border .2s;font-family:inherit}.form-select:focus{border-color:#8b5cf6}.select-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:18px;color:#94a3b8;pointer-events:none}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid #f1f5f9}.toggle-row:last-child{border-bottom:none;padding-bottom:0}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-size:14px;font-weight:600;color:#0f172a}.toggle-desc{font-size:12px;color:#94a3b8}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:#e2e8f0;border-radius:24px;cursor:pointer;transition:background .25s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;left:3px;top:3px;transition:transform .25s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:#8b5cf6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.save-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;font-size:14px;font-weight:600;color:#16a34a;animation:settingsFadeSlide .3s ease}.save-banner .material-symbols-outlined{font-size:18px}.save-banner--error{background:#fef2f2;border-color:#fecaca;color:#dc2626}.save-banner--lab{background:#faf5ff;border-color:#d8b4fe;color:#7c3aed}@keyframes settingsFadeSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.settings-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.settings-toolbar .search-wrap{position:relative;flex:1}.settings-toolbar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#94a3b8;pointer-events:none}.settings-toolbar .search-input{width:100%;padding:10px 14px 10px 40px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;outline:none;transition:border .2s;background:#fff}.settings-toolbar .search-input:focus{border-color:#10b981}.settings-drawer-overlay{position:fixed;inset:0;background:#0000004d;z-index:1000;animation:settingsFadeIn .2s ease}.settings-drawer{position:fixed;right:0;top:0;bottom:0;width:460px;max-width:95vw;background:#fff;z-index:1001;display:flex;flex-direction:column;box-shadow:-8px 0 32px #00000026;animation:settingsSlideIn .25s ease}.settings-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0}.settings-drawer-header h3{font-size:17px;font-weight:800;color:#0f172a;margin:0}.settings-drawer-close{width:34px;height:34px;border-radius:8px;border:none;background:#f1f5f9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.settings-drawer-close:hover{background:#e2e8f0}.settings-drawer-close .material-symbols-outlined{font-size:18px;color:#64748b}.settings-drawer-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px;isolation:auto}.settings-drawer-body .psi-dropdown,.settings-drawer-body .dsi-dropdown,.settings-drawer-body .emi-dropdown{z-index:2000}.settings-drawer-footer{padding:16px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:10px}@keyframes settingsFadeIn{0%{opacity:0}to{opacity:1}}@keyframes settingsSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-sub-tabs{display:flex;gap:4px;border-bottom:2px solid #e2e8f0;margin-bottom:20px}.settings-sub-tab{display:flex;align-items:center;gap:6px;padding:9px 18px;border:none;background:none;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.settings-sub-tab .material-symbols-outlined{font-size:17px}.settings-sub-tab:hover{color:#0f172a}.settings-sub-tab.active{color:#10b981;border-bottom-color:#10b981}@media(max-width:900px){.settings-drawer{width:100%}.field-row{flex-direction:column}}*,*:before,*:after{box-sizing:border-box}html,body{height:100%;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#1e293b}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";font-feature-settings:"liga";-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none}::-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}a{text-decoration:none}button{font-family:inherit}
