:root{--bg:#fafaf8;--surface:#fff;--surface-2:#f5f4f0;--border:#e4e2dc;--border-2:#d1cec6;--text-primary:#1a1a18;--text-secondary:#4a4a44;--text-muted:#9a9890;--accent-blue:#2563eb;--accent-green:#16a34a;--accent-red:#dc2626;--accent-amber:#d97706;--accent-purple:#7c3aed;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014;--radius:12px;--radius-sm:6px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:12px;padding:14px 16px}.card-title{color:var(--text-primary);align-items:center;gap:6px;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.grid-2>.card{margin-bottom:0}@media (width<=900px){.grid-2{grid-template-columns:1fr}}.kpi-grid{gap:12px;margin-bottom:16px;display:grid}.kpi-grid-4{grid-template-columns:repeat(4,1fr)}.kpi-grid-3{grid-template-columns:repeat(3,1fr)}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);min-height:90px;padding:14px 16px}.kpi-label{color:var(--text-muted);margin-bottom:4px;font-size:11px}.kpi-value{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.1}.kpi-sub{color:var(--text-secondary);margin-top:3px;font-size:11px}.kpi-badge{border-radius:20px;align-items:center;gap:3px;margin-top:5px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.kpi-badge.red{color:#dc2626;background:#fee2e2}.kpi-badge.amber{color:#b45309;background:#d977061a}.kpi-badge.green{color:#15803d;background:#16a34a1a}.kpi-badge.gray{background:var(--surface-2);color:var(--text-muted)}.filter-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.filter-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-secondary);border-radius:20px;padding:4px 11px;font-size:12px;transition:all .15s}.filter-btn:hover{border-color:var(--accent-green);color:var(--accent-green)}.filter-btn.active{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.filter-label{color:var(--text-muted);font-size:11px}.ai-card{border:1px solid var(--border);border-radius:var(--radius);background:#16a34a0a;border-left:3px solid #16a34a66;margin-top:4px;padding:12px 14px}.ai-card-title{color:#15803d;align-items:center;gap:6px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;padding:12px 14px}.plan-card.recommended{background:#16a34a0d;border-color:#16a34a4d}.plan-card-header{margin-bottom:8px;font-size:12px;font-weight:700}.plan-card-header.rec{color:#15803d}.plan-card-header.stable{color:#0369a1}.plan-card-header.conservative{color:#475569}.shift-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 0;display:flex}.shift-row:last-child{border-bottom:none}.shift-name{width:80px;color:var(--text-secondary);font-size:11px}.shift-bar-wrap{background:var(--surface-2);border-radius:3px;flex:1;height:6px;overflow:hidden}.shift-bar{border-radius:3px;height:100%}.shift-num{text-align:right;width:36px;color:var(--text-primary);font-size:12px;font-weight:600}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:12px}thead th{background:var(--surface-2);color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 10px;font-weight:600}tbody td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:8px 10px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.tag{border-radius:20px;align-items:center;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.tag.red{color:#dc2626;background:#fee2e2}.tag.amber{color:#d97706;background:#fef3c7}.tag.green{color:#059669;background:#d1fae5}.tag.blue{color:#1d4ed8;background:#dbeafe}.tag.gray{background:var(--surface-2);color:var(--text-secondary)}.tag.mock{color:#7c3aed;background:#f3e8ff;font-size:10px}.note{color:var(--text-muted);align-items:flex-start;gap:5px;margin-top:8px;font-size:10px;line-height:1.6;display:flex}.note ul{flex-direction:column;gap:1px;margin:0;padding:0;list-style:none;display:flex}.note ul li:before{content:"· "}.section-divider{border:none;border-top:1px solid var(--border);margin:14px 0}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-secondary);padding:6px 14px;font-size:12px;font-weight:500;transition:all .15s}.btn:hover{border-color:var(--accent-green);color:var(--accent-green);background:#16a34a0f}.btn.primary{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.btn.primary:hover{background:#15803d}.progress-bar-wrap{background:var(--surface-2);border-radius:3px;flex:1;min-width:50px;height:5px;overflow:hidden}.progress-bar{border-radius:3px;height:100%;transition:width .4s}.week-nav-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.week-nav-btn:hover:not(:disabled){border-color:var(--accent-green);color:var(--accent-green)}.week-nav-btn:disabled{opacity:.3;cursor:not-allowed}.week-reset-btn{border:1px solid var(--accent-green);cursor:pointer;color:var(--accent-green);white-space:nowrap;background:0 0;border-radius:14px;padding:3px 10px;font-size:11px;transition:all .15s}.week-reset-btn:hover{background:#16a34a14}.drp-trigger{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;white-space:nowrap;border-radius:20px;align-items:center;gap:7px;padding:6px 12px;font-size:12px;transition:all .15s;display:inline-flex}.drp-trigger:hover{border-color:var(--accent-green);color:var(--text-primary)}.drp-trigger.active{border-color:var(--accent-green);color:var(--accent-green);background:#16a34a0f}.drp-trigger-label{font-weight:500}.drp-trigger-clear{background:var(--text-muted);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;transition:background .12s;display:flex}.drp-trigger-clear:hover{background:var(--accent-red)}.drp-wrap{display:inline-block;position:relative}.drp-panel{z-index:999;background:var(--surface);border:1px solid var(--border);border-radius:12px;min-width:520px;display:flex;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden;box-shadow:0 8px 32px #0000001f}.drp-shortcuts{border-right:1px solid var(--border);background:var(--surface-2);flex-direction:column;flex-shrink:0;gap:3px;width:110px;padding:14px 10px;display:flex}.drp-shortcut-label{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px;padding:0 8px;font-size:10px;font-weight:600}.drp-shortcut-btn{cursor:pointer;color:var(--text-secondary);text-align:left;background:0 0;border:none;border-radius:7px;padding:7px 8px;font-size:12px;transition:all .12s}.drp-shortcut-btn:hover{background:var(--surface);color:var(--accent-green)}.drp-shortcut-btn.active{color:var(--accent-green);background:#16a34a1a;font-weight:600}.drp-shortcut-divider{background:var(--border);height:1px;margin:6px 0}.drp-cal-body{flex:1;padding:16px 18px}.drp-cal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.drp-cal-nav{border:1px solid var(--border);background:var(--surface-2);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);border-radius:6px;justify-content:center;align-items:center;transition:all .12s;display:flex}.drp-cal-nav:hover:not(:disabled){border-color:var(--accent-green);color:var(--accent-green);background:#16a34a0f}.drp-cal-nav:disabled{opacity:.3;cursor:not-allowed}.drp-cal-grid{grid-template-columns:repeat(7,34px);gap:2px;display:grid}.drp-cal-weekday{text-align:center;color:var(--text-muted);padding:4px 0 6px;font-size:11px;font-weight:500}.dc{cursor:pointer;width:34px;height:32px;color:var(--text-secondary);-webkit-user-select:none;user-select:none;border-radius:7px;justify-content:center;align-items:center;font-size:12px;transition:background .1s,color .1s;display:flex;position:relative}.dc:hover:not(.dc-off){background:var(--surface-2);color:var(--text-primary)}.dc.dc-has{color:var(--text-primary)}.dc.dc-start,.dc.dc-end{font-weight:700;background:var(--accent-green)!important;color:#fff!important}.dc.dc-range{color:var(--text-primary);background:#16a34a1a;border-radius:0}.dc.dc-start{border-radius:7px 0 0 7px}.dc.dc-end{border-radius:0 7px 7px 0}.dc.dc-start.dc-end{border-radius:7px!important}.dc.dc-off{color:var(--text-muted);opacity:.3;cursor:not-allowed;pointer-events:none}.dc.dc-today:after{content:"";background:var(--accent-amber);border-radius:50%;width:4px;height:4px;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.drp-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 18px 14px;display:flex}.drp-footer-info{color:var(--text-secondary);font-size:12px}.drp-confirm-btn{background:var(--accent-green);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:6px 16px;font-size:12px;font-weight:600;transition:background .12s}.drp-confirm-btn:hover{background:#15803d}.staff-summary-bar{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.staff-stat{background:var(--surface);border-radius:var(--radius);min-width:120px;box-shadow:var(--shadow-sm);border:1px solid var(--border);flex:1;align-items:center;gap:12px;padding:14px 16px;display:flex}.staff-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.staff-stat-num{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.1;display:block}.staff-stat-lbl{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.staff-filter-row{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px 20px;margin-bottom:18px;padding:11px 14px;display:flex}.staff-filter-group{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.staff-card-grid{grid-template-columns:repeat(auto-fill,minmax(188px,1fr));gap:12px;margin-bottom:14px;display:grid}.staff-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border-top:3px solid var(--card-accent,var(--border));border:1px solid var(--border);border-top:3px solid var(--card-accent,var(--border));padding:14px 15px 12px;transition:box-shadow .2s,transform .15s}.staff-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.staff-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.staff-avatar{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.staff-name{color:var(--text-primary);font-size:13.5px;font-weight:700}.staff-post{align-items:center;gap:4px;margin-top:2px;font-size:11px;font-weight:500;display:flex}.staff-pt-tag{color:#7c3aed;background:#7c3aed1f;border-radius:8px;padding:0 5px;font-size:10px;font-weight:600}.staff-hours-row{align-items:center;margin-bottom:10px;display:flex}.staff-hour-item{text-align:center;flex:1}.staff-hour-center{flex:1.2}.staff-hour-divider{background:var(--border);flex-shrink:0;width:1px;height:28px}.staff-hour-num{color:var(--text-primary);font-size:14px;font-weight:700;line-height:1.2}.staff-hour-center .staff-hour-num{font-size:16px}.staff-hour-unit{color:var(--text-muted);font-size:10px;font-weight:400}.staff-hour-lbl{color:var(--text-muted);margin-top:1px;font-size:10px}.staff-progress{align-items:center;gap:7px;display:flex}.progress-track{background:var(--border);border-radius:3px;flex:1;height:5px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-pct{text-align:right;flex-shrink:0;width:32px;font-size:11px;font-weight:600}.staff-note{color:var(--text-muted);background:var(--surface);border-radius:var(--radius-sm);border-left:2px solid var(--border);align-items:flex-start;gap:7px;padding:9px 13px;font-size:12px;display:flex}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:18px 18px 12px}.chart-card h3{color:var(--text-primary);margin:0 0 3px;font-size:14px;font-weight:600}.chart-subtitle{color:var(--text-muted);margin-bottom:12px;font-size:11px;line-height:1.4}.mock-tag{color:#b45309;letter-spacing:.5px;vertical-align:middle;background:#d977061f;border:1px dashed #d9770680;border-radius:8px;margin-left:8px;padding:1px 7px;font-size:10px;font-weight:600;display:inline-block}
