:root{--bg: #f3f5f8;--surface: #ffffff;--line: #ebeef3;--line-strong: #d6dbe3;--text: #20242a;--muted: #8a94a3;--blue: #1677ff;--blue-dark: #0958d9;--danger: #d4380d;--tag: #f4f5f7}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Microsoft YaHei,Segoe UI,Arial,sans-serif;font-size:14px;overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:flex;height:100%;min-height:0;overflow:hidden;background:var(--bg)}.main-shell{flex:1;min-width:0;height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden}.history-tabs{flex:0 0 auto;display:flex;align-items:flex-end;min-height:38px;padding:6px 10px 0;gap:2px;overflow-x:auto;overflow-y:hidden;border-bottom:1px solid #cfd6e0;background:#eef2f7}.history-tab{position:relative;display:inline-flex;align-items:center;gap:8px;max-width:190px;min-width:104px;height:32px;padding:0 9px 0 12px;border:1px solid #c8d0dc;border-bottom:0;border-radius:6px 6px 0 0;background:#e5e9ef;color:#3f4652;text-align:left}.history-tab span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-tab em{flex:0 0 auto;width:18px;height:18px;border-radius:50%;color:#7a8494;font-style:normal;line-height:18px;text-align:center}.history-tab em:hover{background:#edf1f6;color:#d4380d}.history-tab:hover{background:#f7faff;color:var(--blue)}.history-tab.active{z-index:1;height:34px;margin-bottom:-1px;border-color:#b8c6d8;background:#fff;color:var(--blue);font-weight:600}.page-stack{flex:1;min-height:0;display:flex;overflow:hidden}.page-view{flex:1;min-width:0;min-height:0;display:none}.page-view.active{display:flex}.side-menu{width:204px;flex:0 0 204px;height:100%;overflow-y:auto;border-right:0;background:linear-gradient(180deg,#123946,#163b52 48%,#24313b);box-shadow:5px 0 18px #172a3a21;color:#eff8fb}.side-title{height:64px;display:flex;align-items:center;padding:0 22px;border-bottom:1px solid rgba(255,255,255,.12);color:#fff;font-size:16px;font-weight:600}.side-title:before{content:"";width:9px;height:28px;margin-right:12px;border-radius:5px;background:linear-gradient(180deg,#2fd0a2,#ffc857);box-shadow:0 0 0 4px #2fd0a21f}.nav-list{display:grid;gap:8px;padding:16px 12px}.nav-item{position:relative;display:flex;align-items:center;height:42px;padding:0 16px;border:1px solid transparent;border-radius:8px;color:#d9e8ee;text-decoration:none;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.nav-item:before{content:"";width:4px;height:18px;margin-right:11px;border-radius:3px;background:#ffffff3d}.nav-item:hover{background:#ffffff14;border-color:#ffffff24;color:#fff;transform:translate(2px)}.nav-item.active{background:#fff;border-color:#ffffffb8;color:#0d5c89;font-weight:700;box-shadow:0 8px 20px #0b1f2d38}.nav-item.active:before{background:#20b486}.mapping-page,.config-page,.attendance-page,.department-page{flex:1;min-width:0;height:100%;min-height:0;overflow-x:hidden;overflow-y:auto;padding:22px 28px 28px}.attendance-page{display:flex;flex-direction:column;gap:8px;overflow:hidden;padding:14px 18px 16px}.attendance-page .page-header{flex:0 0 auto;margin-bottom:0}.attendance-page .page-header p{display:none}.attendance-page .filter-panel,.attendance-page .notice,.attendance-page .sync-progress-card,.attendance-page .attendance-metrics{flex:0 0 auto;margin-bottom:0}.mapping-page,.attendance-page,.department-page{background:transparent}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.page-header h1{margin:0;color:#1f2329;font-size:22px;font-weight:650;line-height:1.25}.page-header p{margin:6px 0 0;color:var(--muted);line-height:1.5}.panel{overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff}.filter-panel{margin-bottom:12px}.archive-status-card{flex:0 0 auto;display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;min-height:34px;padding:8px 12px;border:1px solid #ffd591;border-radius:8px;background:#fff7e6;color:#873800}.archive-status-card strong{font-weight:700}.archive-status-card span{color:#5c3a00}.archive-status-card em{color:#ad4e00;font-style:normal}.archive-status-card.archive-view{border-color:#b7eb8f;background:#f6ffed;color:#135200}.archive-status-card.archive-view span{color:#237804}.archive-status-card.empty-archive{border-color:#d9d9d9;background:#fafafa;color:#5f6673}.archive-status-card.empty-archive span{color:#7a8494}.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}.mapping-toolbar{align-items:stretch;gap:10px}.toolbar-group{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center;min-width:0;padding:7px;border:1px solid #eef1f5;border-radius:8px;background:#fbfcfe}.toolbar-group.grow{flex:1 1 460px}.toolbar-group.wide{flex:1 1 520px}.toolbar-label{color:#606a78;font-size:12px;font-weight:600;white-space:nowrap}.danger-check{color:#a8071a}.toolbar-check,.check-line{display:inline-flex;gap:6px;align-items:center;color:#3f4652;white-space:nowrap}.premium-filter{height:32px;padding:0 10px;border:1px solid #d8e2f1;border-radius:6px;background:#f8fbff}.toolbar-check input,.check-line input{margin:0}.search-box{position:relative;width:220px}.search-box input{width:100%;height:32px;padding:4px 10px 4px 32px;border:1px solid var(--line-strong);border-radius:6px;background:#fff}.search-icon{position:absolute;top:5px;left:10px;color:#3f4652;font-size:18px}.btn{height:32px;padding:0 14px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--text);white-space:nowrap}.btn:hover{border-color:var(--blue);color:var(--blue)}.btn.mini{height:28px;padding:0 10px;font-size:12px}.btn:disabled{cursor:not-allowed;color:#b8bec8;background:#f7f8fa;border-color:var(--line)}.btn:disabled:hover{color:#b8bec8;border-color:var(--line)}.btn.primary,.seg.active{border-color:var(--blue);background:var(--blue);color:#fff}.btn.primary:hover,.seg.active:hover{background:var(--blue-dark);color:#fff}.segmented{display:inline-flex;border-radius:6px;overflow:hidden}.seg{height:32px;min-width:66px;padding:0 14px;border:1px solid var(--line-strong);border-right:0;background:#fff}.seg:last-child{border-right:1px solid var(--line-strong)}.action-segmented .seg{min-width:78px;padding:0 10px}.notice{margin:0 0 12px;padding:8px 12px;border:1px solid #91caff;border-radius:6px;background:#e6f4ff;color:#0958d9}.notice.error{border-color:#ffccc7;background:#fff2f0;color:#a8071a}.wecom-result{margin:10px 12px;padding:12px;border:1px solid #d6e4ff;border-radius:8px;background:#f8fbff}.wecom-result-head,.wecom-result-metrics{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center}.wecom-result-head strong{color:#1f2329}.wecom-result-head span,.wecom-result-metrics span,.wecom-action em,.wecom-action small{color:#606a78}.wecom-result-metrics{margin-top:8px}.wecom-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px;margin-top:10px}.wecom-action{display:grid;grid-template-columns:auto 1fr;gap:3px 8px;min-width:0;padding:8px;border:1px solid var(--line);border-radius:6px;background:#fff}.wecom-action strong,.wecom-action em,.wecom-action small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wecom-action small{grid-column:2}.wecom-action-type{grid-row:span 3;align-self:center;padding:2px 6px;border-radius:4px;background:#edf5ff;color:#0958d9;font-size:12px}.wecom-action-type.user_create{background:#f6ffed;color:#237804}.wecom-action-type.user_update{background:#fff7e6;color:#ad4e00}.wecom-action-type.user_leave{background:#fff1f0;color:#a8071a}.wecom-action-type.skip{background:#f5f7fa;color:#606a78}.wecom-warnings{margin-top:8px;color:#ad4e00}.wecom-leave-panel{margin:10px 12px;padding:12px;border:1px solid #ffccc7;border-radius:8px;background:#fff7f6}.leave-candidate-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:8px;margin-top:10px}.leave-candidate{display:grid;grid-template-columns:34px 1fr;gap:3px 8px;padding:9px;border:1px solid #ffd8d2;border-radius:6px;background:#fff}.leave-candidate strong,.leave-candidate em,.leave-candidate small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leave-candidate em,.leave-candidate small{color:#606a78;font-style:normal}.leave-candidate small{grid-column:2}.compact-empty{padding:12px}.sync-progress-card{margin:0 0 14px;padding:13px 16px;border:1px solid #b7d8ff;border-radius:8px;background:#f7fbff}.sync-progress-card.done{border-color:#b7eb8f;background:#f6ffed}.sync-progress-card.failed{border-color:#ffccc7;background:#fff2f0}.sync-progress-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.sync-progress-head strong{display:block;color:#1f2329;line-height:1.4}.sync-progress-head span{display:inline-block;margin-top:3px;color:#606a78;font-size:13px}.sync-progress-head em{color:var(--blue);font-style:normal;font-weight:700}.sync-progress-track{height:8px;margin-top:12px;overflow:hidden;border-radius:999px;background:#e6eef8}.sync-progress-track span{display:block;height:100%;border-radius:inherit;background:var(--blue);transition:width .25s ease}.sync-progress-card.running .sync-progress-track span{background:linear-gradient(90deg,var(--blue),#69b1ff,var(--blue));background-size:36px 100%;animation:sync-progress-stripes .9s linear infinite}.sync-progress-card.done .sync-progress-track span{background:#52c41a}.sync-progress-card.failed .sync-progress-track span{background:#ff4d4f}.sync-progress-meta{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:10px;color:#3f4652;font-size:13px}.sync-progress-meta span:nth-child(5),.sync-progress-meta span:nth-child(6){display:none}.sync-progress-warning,.sync-progress-error{margin-top:8px;color:#a8071a;font-size:13px;line-height:1.5}@keyframes sync-progress-stripes{0%{background-position:0 0}to{background-position:36px 0}}.table-wrap{overflow:auto}.mapping-table{width:100%;min-width:1260px;border-collapse:collapse}.mapping-table th,.mapping-table td{height:49px;padding:8px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}.mapping-table th{height:40px;background:#f8fafc;font-weight:600}.mapping-table tbody tr:hover td{background:#fbfdff}.mapping-table th+th{border-left:1px solid #f0f0f0}.mapping-table td:nth-child(1),.mapping-table th:nth-child(1){width:170px}.mapping-table td:nth-child(2),.mapping-table th:nth-child(2){width:200px}.mapping-table td:nth-child(3),.mapping-table th:nth-child(3){width:160px}.mapping-table td:nth-child(4),.mapping-table th:nth-child(4){width:140px}.mapping-table td:nth-child(5),.mapping-table th:nth-child(5){width:460px}.personnel-table td:nth-child(1),.personnel-table th:nth-child(1){width:64px}.personnel-table td:nth-child(2),.personnel-table th:nth-child(2){width:72px}.personnel-table{min-width:1900px}.personnel-table td:nth-child(3),.personnel-table th:nth-child(3){width:170px}.personnel-table td:nth-child(4),.personnel-table th:nth-child(4){width:190px}.personnel-table td:nth-child(5),.personnel-table th:nth-child(5){width:130px}.personnel-table td:nth-child(6),.personnel-table th:nth-child(6){width:110px}.personnel-table td:nth-child(7),.personnel-table th:nth-child(7){width:180px}.personnel-table td:nth-child(8),.personnel-table th:nth-child(8){width:360px}.personnel-table td:nth-child(9),.personnel-table th:nth-child(9){width:190px}.personnel-table td:nth-child(10),.personnel-table th:nth-child(10){width:440px}.select-cell{text-align:center}.row-index{color:#606a78;font-variant-numeric:tabular-nums}.status-tag{display:inline-block;padding:2px 7px;border-radius:4px;background:var(--tag);color:#1f2329;font-size:13px}.status-tag.ok{background:#f0f7ff;color:#0958d9}.link-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.link-cell.compact{gap:5px}.wecom-action-chip{display:inline-block;padding:2px 7px;border-radius:4px;background:#f4f5f7;color:#606a78;font-size:12px;white-space:nowrap}.wecom-action-chip.onboard{background:#f6ffed;color:#237804}.wecom-action-chip.update{background:#fff7e6;color:#ad4e00}.wecom-action-chip.leave,.wecom-action-chip.blocked{background:#fff1f0;color:#a8071a}.wecom-action-chip.synced{background:#f0f7ff;color:#0958d9}.mapping-row-mismatch td{background:#fff2f0}.mapping-row-mismatch:hover td{background:#fff1ed}.mismatch-reason{flex-basis:100%;color:#cf1322;font-size:12px}.sync-tag{display:inline-block;padding:2px 7px;border-radius:4px;background:#f4f5f7;color:#606a78;font-size:12px}.sync-tag.ok{background:#f6ffed;color:#237804}.sync-tag.warning{background:#fff7e6;color:#ad4e00}.sync-tag.danger{background:#fff1f0;color:#a8071a}.erp-select{width:min(260px,100%);height:34px;padding:4px 10px;border:1px solid var(--line-strong);border-radius:6px;color:#606a78;background:#fff}.search-select{width:min(300px,100%)}.search-select-input{width:100%;min-width:230px}.search-select-input:focus{border-color:#1677ff;box-shadow:0 0 0 2px #1677ff1f;color:#1f2329;outline:none}.search-select-input::placeholder{color:#aab2bf}.department-map-form{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr)) auto;gap:12px;align-items:end;padding:12px}.department-map-form label{display:flex;flex-direction:column;gap:6px;color:#475569;font-size:13px}.department-map-form .search-select{width:100%}.department-map-form .search-select-input{min-width:0}.department-map-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.department-map-table{min-width:1180px}.department-map-table td:nth-child(1),.department-map-table th:nth-child(1){width:72px}.department-map-table td:nth-child(2),.department-map-table th:nth-child(2){width:330px}.department-map-table td:nth-child(3),.department-map-table th:nth-child(3),.department-map-table td:nth-child(4),.department-map-table th:nth-child(4){width:390px}.department-link-cell{min-width:0}.department-linked{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.muted-text{color:#7a8494;font-size:12px}.attendance-toolbar{gap:10px}.attendance-page .toolbar{padding:9px 12px}.employee-select{height:32px;padding:4px 9px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--text)}.month-query{display:inline-flex;align-items:center;min-height:34px;gap:6px;padding:4px;border:1px solid #d8e2f1;border-radius:8px;background:#f8fbff;box-shadow:inset 0 0 0 1px #1677ff0a}.month-selects{display:inline-flex;gap:4px}.month-select{height:26px;min-width:72px;padding:0 22px 0 8px;border:1px solid transparent;border-radius:6px;background:#fff;color:#1f2329;font-weight:600}.year-select{min-width:92px}.month-step{height:26px;min-width:44px;padding:0 9px;border:0;border-radius:6px;background:transparent;color:#506078}.month-step:hover{background:#edf5ff;color:var(--blue)}.month-range{padding:0 8px 0 4px;color:#657184;font-size:12px;white-space:nowrap}.employee-select{width:190px}.department-select{width:260px}.department-search{width:220px}.department-daily-row.premium-row .department-store-col{background:#fff7e6}.department-store-col span{display:block}.premium-badge{display:inline-flex;margin-top:4px;padding:1px 6px;border-radius:999px;background:#ffe7ba;color:#ad4e00;font-size:11px;font-style:normal;line-height:18px}.metric-grid{display:grid;gap:12px;margin:0 0 14px}.mapping-metrics{grid-template-columns:repeat(3,minmax(140px,1fr))}.attendance-metrics{grid-template-columns:repeat(5,minmax(130px,1fr))}.attendance-page .attendance-metrics{grid-template-columns:repeat(auto-fit,minmax(98px,1fr));gap:8px}.department-metrics{grid-template-columns:repeat(6,minmax(120px,1fr))}.metric-card{min-height:78px;padding:13px 16px;border:1px solid var(--line);border-radius:8px;background:#fff}.attendance-page .metric-card{min-height:52px;padding:8px 11px}.metric-card span{display:block;color:var(--muted);font-size:13px}.metric-card strong{display:inline-block;margin-top:8px;color:#1f2329;font-size:24px;line-height:1}.attendance-page .metric-card strong{margin-top:5px;font-size:19px}.metric-card em{margin-left:5px;color:#606a78;font-style:normal}.metric-card.success{border-color:#b7eb8f}.metric-card.warning{border-color:#ffd591}.metric-card.danger{border-color:#ffccc7}.tabs{display:flex;gap:4px;margin:0;padding:0 16px;border-bottom:1px solid var(--line)}.tab{height:36px;padding:0 14px;border:0;border-bottom:2px solid transparent;background:transparent;color:#606a78}.tab.active{border-bottom-color:var(--blue);color:var(--blue);font-weight:600}.attendance-table{min-width:1720px}.attendance-detail-table{min-width:1180px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:22px;background:#0d18227a}.detail-dialog{width:min(1180px,calc(100vw - 44px));max-height:calc(100vh - 44px);display:flex;flex-direction:column;overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 20px 60px #0c1b2b47}.detail-dialog-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border-bottom:1px solid var(--line);background:#f8fbff}.detail-dialog-header h2{margin:0;color:#18212c;font-size:17px}.detail-dialog-header p{margin:5px 0 0;color:#687385;font-size:12px}.dialog-close{width:32px;height:32px;border:1px solid var(--line-strong);border-radius:50%;background:#fff;color:#687385;font-size:20px;line-height:28px}.dialog-close:hover{border-color:#ff7875;color:#cf1322}.detail-dialog-table-wrap{flex:1 1 auto;min-height:0;max-height:none;border:0;border-radius:0;overflow:auto}.detail-dialog-table{min-width:1040px}.detail-dialog-table thead th{position:sticky;top:0;z-index:3}.detail-dialog-pager{flex:0 0 auto;margin:0;padding:10px 14px;border-top:1px solid var(--line);background:#fff}.attendance-workspace{display:flex;flex:1 1 auto;flex-direction:column;min-height:0}.attendance-workspace>.tabs{flex:0 0 auto}.attendance-workspace>.table-wrap{flex:1 1 auto;min-height:0;max-height:none;overflow:auto;border-bottom:1px solid var(--line)}.attendance-workspace>.pager{flex:0 0 auto;margin:0;padding:8px 12px;background:#fff}.attendance-workspace .mapping-table thead th{position:sticky;top:0;z-index:5;box-shadow:inset 0 -1px 0 var(--line-strong)}.attendance-workspace .mapping-table thead .sticky-col{z-index:8}.attendance-workspace .monthly-table thead tr:first-child th,.attendance-workspace .monthly-report-table thead tr:first-child th{top:0}.attendance-workspace .monthly-table thead tr:nth-child(2) th{top:42px}.attendance-workspace .monthly-report-table thead tr:nth-child(2) th{top:44px}.department-panel+.department-panel{margin-top:14px}.section-title{height:42px;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--line);color:#1f2329;font-weight:650}.department-daily-wrap{max-height:430px}.department-day-table{min-width:760px}.department-day-table th,.department-day-table td{text-align:center}.department-daily-matrix{table-layout:fixed;border-collapse:separate;border-spacing:0}.department-daily-matrix th,.department-daily-matrix td{height:58px;padding:6px 8px;border-right:1px solid #d8dde6;border-bottom:1px solid #d8dde6;text-align:center;vertical-align:middle}.department-daily-matrix thead th{position:sticky;top:0;z-index:3;background:#fffecf;color:#1f2329}.department-daily-matrix .department-store-column,.department-daily-matrix .department-store-col{width:220px;min-width:220px}.department-daily-matrix .department-day-column,.department-daily-matrix .department-day-head,.department-daily-matrix .department-daily-cell{width:126px;min-width:126px}.department-daily-matrix .department-store-col{left:0;z-index:4;overflow:hidden;background:#fff;text-align:left;text-overflow:ellipsis;white-space:nowrap}.department-daily-matrix thead .department-store-col{background:#fffecf}.department-daily-row{cursor:pointer}.department-daily-row:hover td{background:#f5f8ff}.department-daily-row.active td,.department-daily-row.active .department-store-col{background:#edf5ff}.department-day-head span,.department-day-head small,.department-daily-cell strong,.department-daily-cell span,.department-daily-cell em{display:block}.department-day-head span{font-size:16px;font-weight:700}.department-day-head small{margin-top:3px;color:#606a78;font-size:12px}.department-day-head.weekend span,.department-day-head.weekend small,.department-daily-cell.weekend strong{color:#d4380d}.department-daily-cell strong,.department-daily-cell span{font-size:13px;line-height:1.25}.department-daily-cell strong:before{content:"上 ";color:#606a78;font-weight:400}.department-daily-cell span:before{content:"下 ";color:#606a78}.department-daily-cell em{margin-top:3px;color:#8a94a3;font-size:11px;font-style:normal}.monthly-wrap{max-height:calc(100vh - 290px)}.attendance-workspace>.monthly-wrap{max-height:none}.monthly-table{min-width:max-content;border-collapse:separate;border-spacing:0;table-layout:fixed}.monthly-table th,.monthly-table td{border-right:1px solid #1f1f1f;border-bottom:1px solid #1f1f1f}.monthly-table thead th{background:#fffecf;color:#111}.monthly-title{height:44px;text-align:center;font-size:15px;font-weight:700}.monthly-day-head{width:112px;min-width:112px;height:58px;text-align:center;vertical-align:middle}.monthly-day-head span,.monthly-day-head small{display:block}.monthly-day-head span{font-size:16px;font-weight:700}.monthly-day-head small{margin-top:4px;font-size:13px;color:#303846}.monthly-day-head.weekend span,.monthly-day-head.weekend small{color:#d4380d}.monthly-cell{width:112px;min-width:112px;height:62px;padding:3px 5px;text-align:center;vertical-align:middle;white-space:normal}.monthly-cell strong,.monthly-cell span,.monthly-cell em{display:block;line-height:1.25}.monthly-cell strong{font-size:14px;white-space:normal}.monthly-cell span{color:#15191f;font-size:12px}.monthly-cell em{color:#5b6370;font-size:12px;font-style:normal}.monthly-normal{background:#fff}.monthly-late,.monthly-early{background:#c9ffc9}.monthly-absent{background:#f77}.monthly-leave{background:#efc2ff}.monthly-unscheduled{background:#fff}.monthly-unknown{background:#f5f7fa}.ding-monthly-table tbody tr:hover td.monthly-normal{background:#fff}.ding-monthly-table tbody tr:hover td.monthly-late,.ding-monthly-table tbody tr:hover td.monthly-early{background:#c9ffc9}.ding-monthly-table tbody tr:hover td.monthly-absent{background:#f77}.ding-monthly-table tbody tr:hover td.monthly-leave{background:#efc2ff}.ding-monthly-table tbody tr:hover td.monthly-unscheduled{background:#fff}.ding-monthly-table tbody tr:hover td.monthly-unknown{background:#f5f7fa}.ding-monthly-table th,.ding-monthly-table td{border-color:#1f1f1f}.ding-monthly-table .monthly-title{height:42px;background:#fffecf;text-align:center;font-size:15px}.ding-monthly-table{table-layout:fixed;border-left:1px solid #1f1f1f;border-top:1px solid #1f1f1f}.ding-monthly-table .monthly-col-index{width:54px}.ding-monthly-table .monthly-col-name{width:128px}.ding-monthly-table .monthly-col-dept{width:200px}.ding-monthly-table .monthly-col-day{width:104px}.ding-monthly-table th.monthly-index,.ding-monthly-table td.monthly-index{left:0;width:54px;min-width:54px;max-width:54px;text-align:center}.ding-monthly-table th.monthly-name,.ding-monthly-table td.monthly-name{left:54px;width:128px;min-width:128px;max-width:128px}.ding-monthly-table th.monthly-dept,.ding-monthly-table td.monthly-dept{left:182px;width:200px;min-width:200px;max-width:200px}.ding-monthly-table .monthly-index,.ding-monthly-table .monthly-name,.ding-monthly-table .monthly-dept{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ding-monthly-table th.monthly-day-head,.ding-monthly-table td.monthly-cell{width:104px;min-width:104px;max-width:104px}.ding-monthly-table .monthly-day-head{height:52px;padding:4px 5px}.ding-monthly-table .monthly-cell{height:66px;padding:4px 5px;overflow:hidden;word-break:break-word;overflow-wrap:anywhere}.ding-monthly-table .monthly-cell strong{font-size:13px;line-height:1.2;overflow-wrap:anywhere}.ding-monthly-table .monthly-cell span{margin-top:2px;font-size:11px;line-height:1.25;overflow-wrap:anywhere}.monthly-report-table{min-width:1540px;border-collapse:separate;border-spacing:0;table-layout:fixed}.monthly-report-table th,.monthly-report-table td{height:42px;padding:7px 10px;border-right:1px solid #d8dde6;border-bottom:1px solid #d8dde6;text-align:center;vertical-align:middle;white-space:nowrap}.monthly-report-table thead th{background:#f8fafc;color:#1f2329}.monthly-report-title{height:44px;background:#fffecf!important;border-top:1px solid #d8dde6;font-size:15px;font-weight:700;text-align:left!important;padding-left:18px!important}.monthly-report-table tbody td{background:#fff}.monthly-report-table tbody tr:hover td{background:#f7fbff}.monthly-report-table .sticky-col{background:#fff;text-align:left}.monthly-report-table thead .sticky-col{background:#f8fafc}.monthly-report-table tbody tr:hover .sticky-col{background:#f7fbff}.monthly-report-table .monthly-index,.monthly-report-table .row-index{text-align:center}.monthly-erp{left:304px;width:104px;min-width:104px}.number-cell,.money-cell{font-variant-numeric:tabular-nums}.metric-alert,.metric-danger{font-weight:700;font-variant-numeric:tabular-nums}.metric-alert{background:#fff7e6!important;color:#ad4e00}.metric-danger{background:#fff1f0!important;color:#a8071a}.money-cell{color:#0958d9;font-weight:600}.stats-report-table{--stats-index-w: 56px;--stats-name-w: 112px;--stats-dept-w: 220px;--stats-erp-w: 98px;--stats-count-w: 82px;--stats-hours-w: 112px;--stats-period-w: 150px;--stats-money-w: 104px;--stats-action-w: 112px;width:2296px;min-width:2296px}.stats-report-table th,.stats-report-table td{overflow:hidden;text-overflow:ellipsis}.stats-report-table .stats-col-index{width:var(--stats-index-w)}.stats-report-table .stats-col-name{width:var(--stats-name-w)}.stats-report-table .stats-col-dept{width:var(--stats-dept-w)}.stats-report-table .stats-col-erp{width:var(--stats-erp-w)}.stats-report-table .stats-col-count{width:var(--stats-count-w)}.stats-report-table .stats-col-hours{width:var(--stats-hours-w)}.stats-report-table .stats-col-period{width:var(--stats-period-w)}.stats-report-table .stats-col-money{width:var(--stats-money-w)}.stats-report-table .stats-col-action{width:var(--stats-action-w)}.stats-report-table .monthly-index{width:var(--stats-index-w);min-width:var(--stats-index-w)}.stats-report-table .monthly-name{left:var(--stats-index-w);width:var(--stats-name-w);min-width:var(--stats-name-w)}.stats-report-table .monthly-dept{left:calc(var(--stats-index-w) + var(--stats-name-w));width:var(--stats-dept-w);min-width:var(--stats-dept-w)}.stats-report-table .monthly-erp{left:calc(var(--stats-index-w) + var(--stats-name-w) + var(--stats-dept-w));width:var(--stats-erp-w);min-width:var(--stats-erp-w)}.stats-report-table .action-cell{text-align:center}.sticky-col{position:sticky;z-index:2;background:#fff}thead .sticky-col{z-index:4;background:#fffecf}.monthly-index{left:0;width:58px;min-width:58px}.monthly-name{left:58px;width:96px;min-width:96px}.monthly-dept{left:154px;width:150px;min-width:150px}.attendance-detail-row.result-late,.attendance-detail-row.result-early,.attendance-detail-row.result-absent,.attendance-detail-row.result-leave{background:#fffdf5}.attendance-detail-row.result-absent{background:#fff2f0}.attendance-detail-row.result-leave{background:#f0f7ff}.work-date.weekend{color:#d4380d;font-weight:700}.result-pill{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:26px;padding:0 10px;border:1px solid transparent;border-radius:4px;font-weight:600;line-height:1;white-space:nowrap}.result-pill.result-normal{color:#237804;background:#f6ffed;border-color:#b7eb8f}.result-pill.result-late{color:#135200;background:#d9f7be;border-color:#95de64}.result-pill.result-early{color:#ad4e00;background:#fff7e6;border-color:#ffd591}.result-pill.result-absent{color:#a8071a;background:#fff1f0;border-color:#ffa39e}.result-pill.result-leave{color:#0958d9;background:#e6f4ff;border-color:#91caff}.result-pill.result-unknown{color:#606a78;background:#f5f7fa;border-color:var(--line)}.pager{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-top:12px;color:#606a78}.link-btn{height:30px;padding:0 11px;border:1px solid var(--line-strong);border-radius:5px;background:#f7f8fa;color:#606a78}.link-btn:not(:disabled){background:#fff;color:var(--blue);border-color:#91caff}.link-btn.danger:not(:disabled){color:var(--danger);border-color:#ffbb96}.link-btn:disabled{cursor:not-allowed;color:#b8bec8;background:#f7f8fa}.empty{color:var(--muted);text-align:center}.config-head,.config-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.config-actions{justify-content:flex-end;gap:10px}.config-head h1,.config-panel h2{margin:0}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.config-panel{padding:18px;border:1px solid var(--line);border-radius:8px;background:#fff}.form{display:grid;gap:12px;margin-top:14px}.form label{display:grid;gap:6px;color:#606a78;font-size:13px}.form input,.form select,.form textarea{width:100%;min-height:34px;padding:6px 9px;border:1px solid var(--line-strong);border-radius:6px;color:var(--text)}.form textarea{resize:vertical;line-height:1.5}.diagnostic-actions{margin-top:14px;display:flex;justify-content:flex-start}.diagnostic-box{margin-top:12px;padding:12px;border-radius:8px;border:1px solid #ffd591;background:#fffaf0}.diagnostic-box.ok{border-color:#b7eb8f;background:#f6ffed}.diagnostic-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.diagnostic-title span{color:#ad4e00;font-size:12px}.diagnostic-box.ok .diagnostic-title span{color:#237804}.diagnostic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.diagnostic-item{min-height:32px;padding:6px 8px;border:1px solid var(--line);border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px}.diagnostic-item.ok b{color:#237804}.diagnostic-item.bad b{color:var(--danger)}.diagnostic-meta{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:10px;color:#606a78;font-size:12px}.diagnostic-api{margin-top:10px;display:grid;gap:6px}.diagnostic-hint{margin-top:10px;padding:8px 10px;border-radius:6px;background:#f6ffed;border:1px solid #b7eb8f;color:#237804;font-size:12px;line-height:1.55}.diagnostic-api-row{display:grid;grid-template-columns:120px minmax(0,1fr);gap:10px;align-items:start;padding:7px 8px;border:1px solid var(--line);border-radius:6px;background:#fff;font-size:12px}.diagnostic-api-row b{color:#111827}.diagnostic-api-row span{min-width:0;overflow-wrap:anywhere;line-height:1.45}.diagnostic-api-row.ok span{color:#237804}.diagnostic-api-row.bad span{color:var(--danger)}.diagnostic-warnings{margin:10px 0 0;padding-left:18px;color:#ad4e00;font-size:12px;line-height:1.6}@media(max-width:780px){body{overflow:hidden}.app-shell{display:flex;height:100%;min-height:0;overflow:hidden}.side-menu{width:168px;flex:0 0 168px;height:100%;overflow-y:auto;border-right:0;border-bottom:0}.side-title{height:48px;padding:0 14px;font-size:14px}.nav-list{grid-template-columns:1fr;gap:6px;padding:10px 8px}.nav-item{height:38px;padding:0 10px}.mapping-page,.config-page,.attendance-page{height:100%;min-height:0;overflow-x:hidden;overflow-y:auto;padding:12px}.toolbar{align-items:stretch;flex-direction:column}.search-box,.month-query,.employee-select,.toolbar .btn,.segmented{width:100%}.month-query{justify-content:stretch;flex-wrap:wrap}.month-selects{flex:1 1 160px}.month-select{flex:1}.month-range{width:100%;padding:2px 4px 0}.seg{flex:1}.config-grid{grid-template-columns:1fr}.metric-grid,.mapping-metrics,.attendance-metrics{grid-template-columns:1fr 1fr}}
