:root{--bg: #f6f7f9;--card: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--accent: #2563eb;--surface1: #ffffff;--surface2: #f1f5f9}:root.dark{--bg: #162955;--card: #1e3564;--border: #2d4373;--text: #eef2f9;--muted: #9fb3d9;--accent: #5b9dfb;--surface1: #1e3564;--surface2: #23407a}:root.dark tbody tr:hover{background:var(--surface2)}:root.dark .sched-grid thead th{background:var(--surface2)}:root.dark .heat-summary{background:var(--surface2)}:root.dark .kpi-select{background:var(--card)}:root.dark .sidebar .tab.on{background:#5b9dfb2e}:root.dark .tab.on{color:#fff}:root.dark .chip.on{background:#5b9dfb2e}:root.dark .agent.offshift{background:#14224a}:root.dark .sched-grid th.is-today,:root.dark .sched-grid td.is-today{background:#5b9dfb1f}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{display:flex;min-height:100vh}header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}header h1{font-size:20px;margin:0 0 6px}.sidebar{width:196px;flex:none;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:16px 14px 12px;border-bottom:1px solid var(--border)}.sidebar-logo-img{display:block;width:148px;height:auto}.sidebar-logo-sub{margin-top:5px;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.theme-toggle{margin-top:10px;width:100%;border:1px solid var(--border);background:var(--bg);color:var(--text);padding:6px 10px;border-radius:6px;font-size:12px;cursor:pointer}.theme-toggle:hover{background:var(--surface2)}.sidebar .tabs{display:flex;flex-direction:column;gap:2px;padding:8px;flex:1}.sidebar-divider{border-top:1px solid var(--border);margin:6px 0}.content{flex:1;min-width:0;padding:24px;overflow-y:auto}.status{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--muted)}.status .sep{color:#d1d5db}.status .src{display:inline-flex;align-items:center;gap:4px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--muted)}.dot.ok{background:#16a34a}.dot.err{background:#dc2626}.dot.live{background:var(--accent);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.range{display:flex;gap:16px}.range label{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:4px}.range input{padding:6px 8px;border:1px solid var(--border);border-radius:6px}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}.kpi{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.kpi-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.kpi-value{font-size:26px;font-weight:700;margin-top:4px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;margin-bottom:20px}.card h2{font-size:15px;margin:0 0 14px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600}tbody tr:hover{background:#f9fafb}.ext-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 720px){.ext-grid{grid-template-columns:1fr}}.powerbi{display:flex;flex-direction:column;gap:8px}.powerbi-bar{font-size:12px}.powerbi iframe{width:100%;height:calc(100vh - 140px);border:1px solid var(--border);border-radius:10px;background:#fff}.login{min-height:90vh;display:flex;align-items:center;justify-content:center}.login-card{width:320px;max-width:90vw;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:12px}.login-card h1{font-size:18px;margin:0}.login-card p{margin:0;font-size:13px}.login-card input{padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:14px}.login-card button{padding:9px;border-radius:8px;cursor:pointer}.shell-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}.shell-head h1{font-size:20px;margin:0}.tabs{display:flex;gap:6px}.tab{border:1px solid var(--border);background:var(--card);color:var(--text);padding:7px 14px;border-radius:8px;font-size:13px;cursor:pointer}.tab.on{background:var(--accent);color:#fff;border-color:var(--accent)}.sidebar .tab{border:none;background:transparent;color:var(--text);padding:7px 10px;border-radius:6px;font-size:13px;text-align:left;width:100%}.sidebar .tab:hover{background:var(--bg)}.sidebar .tab.on{background:#eff6ff;color:var(--accent);font-weight:600}.live-controls{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:14px}.live-controls select,.live-controls input[type=date]{padding:5px 8px;border:1px solid var(--border);border-radius:6px}.scope-banner{display:inline-block;background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;padding:6px 14px;border-radius:999px;font-size:13px;margin-bottom:16px}.wall .scope-banner{background:#15233f;border-color:#2a3b5e;color:#bfdbfe}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.chip{border:1px solid var(--border);background:var(--card);color:var(--text);padding:5px 12px;border-radius:999px;font-size:12px;cursor:pointer}.chip.on{background:#eff6ff;border-color:var(--accent);color:var(--accent);font-weight:600}.team-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}.team-head h2{margin:0}.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.agent{border:1px solid var(--border);border-radius:10px;padding:12px}.agent.alert{border-color:#fca5a5;box-shadow:0 0 0 1px #fca5a5 inset}.agent-top{display:flex;align-items:center;gap:6px;margin-bottom:8px}.agent-name{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0;font-weight:600;font-size:14px}.agent-name .name-row{display:flex;align-items:center;gap:6px}.pill.lead-badge{background:#dbeafe;color:#1e40af}.wall .pill.lead-badge{background:#1e3a8a;color:#dbeafe}.pill.pip-badge{background:#fee2e2;color:#dc2626}.wall .pill.pip-badge{background:#7f1d1d;color:#fecaca}.agent-name .shift{font-weight:500;font-size:11px;color:var(--muted);white-space:nowrap}.wall .agent-name .shift{font-size:13px;color:#94a3b8}.agent-name .lead{font-weight:500;font-size:11px;color:var(--muted);white-space:nowrap}.agent-name .lead:before{content:"👤 "}.wall .agent-name .lead{font-size:13px;color:#94a3b8}.agent-name .device{font-weight:500;font-size:11px;color:var(--muted);white-space:nowrap}.wall .agent-name .device{font-size:13px;color:#94a3b8}.pill{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:2px 7px;border-radius:999px;white-space:nowrap}.pill.high{background:#dcfce7;color:#15803d}.pill.med{background:#fef3c7;color:#b45309}.pill.low{background:#fee2e2;color:#b91c1c}.pill.off{background:#e5e7eb;color:#4b5563}.pill.unusual{background:#f3e8ff;color:#6b21a8;border:1px solid #d8b4fe}.wall .pill.unusual{background:#2e1065;color:#e9d5ff;border-color:#6d28d9}.flags-panel h2{margin:0 0 12px}.flags-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.flag-col{border:1px solid var(--border);border-radius:10px;overflow:hidden}.flag-col-head{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;font-size:12px;font-weight:700}.flag-col-head.unusual{background:#f3e8ff;color:#6b21a8}.flag-col-head.low{background:#fee2e2;color:#b91c1c}.flag-col-head .count{font-size:13px}.flag-col ul{list-style:none;margin:0;padding:4px 0;max-height:168px;overflow-y:auto}.flag-col li{display:flex;justify-content:space-between;gap:8px;padding:4px 10px;font-size:12px}.flag-col li .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flag-col li .pc{font-weight:700}.wall .flag-col{border-color:#1f2a44}.wall .flag-col-head.unusual{background:#2e1065;color:#e9d5ff}.wall .flag-col-head.low{background:#3f1d1d;color:#fecaca}.metric{margin-top:8px}.metric-head{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:13px}.metric-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);width:26px}.metric-head .pill{margin-left:auto}.agent-foot{font-size:11px;margin-top:8px}.calls{font-size:12px;margin-top:8px;padding-top:6px;border-top:1px dashed var(--border);font-weight:600}.wall .calls{border-top-color:#1f2a44}.agent.offshift{background:#fafafa}.wall .agent.offshift{background:#0c1426}.search{padding:5px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;min-width:140px}.wall{background:#0b1220;color:#e5e7eb;min-height:100vh;padding:20px;overflow-y:auto}.wall .card,.wall .kpi{background:#111a2e;border-color:#1f2a44}.wall .kpi-value{font-size:34px}.wall .team-head h2{font-size:22px}.wall .agent{background:#0f1830;border-color:#1f2a44;padding:16px}.wall .agent-name{font-size:18px}.wall .agent-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.wall .muted{color:#94a3b8}.wall .bar{background:#1f2a44;height:12px}.bar{height:8px;background:#eef0f3;border-radius:999px;overflow:hidden;margin-bottom:6px}.bar-fill{height:100%;border-radius:999px;transition:width .4s}.agent-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:12px}.agent-24h{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;margin-top:5px;padding-top:5px;border-top:1px dashed var(--border)}.agent-meta .tag,.agent-24h .tag{font-size:10px;text-transform:uppercase;letter-spacing:.03em}.wall .agent-24h{border-top-color:#1f2a44}.flag-unusual{margin-top:6px;padding:3px 8px;border-radius:6px;background:#f3e8ff;color:#6b21a8;border:1px solid #e9d5ff;font-size:11px;font-weight:700;text-align:center}.wall .flag-unusual{background:#2e1065;color:#e9d5ff;border-color:#4c1d95}.muted{color:var(--muted)}.status-box,.status-box td{color:#0f172a}.status-box .muted{color:#475569}.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:12px 14px;border-radius:8px;margin-bottom:16px}.sched-grid{width:100%;border-collapse:collapse;font-size:13px}.sched-grid th,.sched-grid td{border:1px solid var(--border);padding:6px 8px;vertical-align:top;text-align:left}.sched-grid thead th{background:#f9fafb;font-size:12px}.sched-grid th .dow{font-weight:700}.sched-grid th.is-today,.sched-grid td.is-today{background:#eff6ff}.sched-grid .sched-name{min-width:180px;white-space:nowrap}.sched-grid .sched-name .name-row{display:flex;align-items:center;gap:6px}.sched-shift{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;border-radius:6px;padding:2px 6px;margin:2px 0;white-space:nowrap;font-weight:600}.sched-grid.day td{vertical-align:middle}.conn-banner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:13px}.conn-banner.offline,.conn-banner.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.conn-banner.ratelimited{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.conn-banner .conn-dot{width:9px;height:9px;border-radius:50%;background:currentColor;flex:none;animation:conn-pulse 1.2s ease-in-out infinite}.conn-banner .conn-msg{flex:1 1 320px}.conn-banner .conn-meta{margin-left:auto;opacity:.85;font-size:12px;white-space:nowrap}.conn-banner button.tab{padding:3px 10px}@keyframes conn-pulse{0%,to{opacity:1}50%{opacity:.25}}.heatmap{border-collapse:collapse;font-size:11px}.heatmap th,.heatmap td{border:1px solid var(--border);text-align:center;padding:2px}.heatmap thead th{font-weight:600;color:var(--muted);padding:3px 2px}.heatmap .hm-day{text-align:left;font-weight:600;white-space:nowrap;padding:3px 10px}.heatmap .hm-cell{width:26px;height:22px;font-variant-numeric:tabular-nums}.heatmap .hm-total{padding:3px 10px;white-space:nowrap}.heat-summary{display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;margin:4px 0 12px;padding:8px 12px;font-size:13px;background:#f9fafb;border:1px solid var(--border);border-radius:8px}.heat-summary span:not(:first-child):before{content:"·";color:var(--muted);margin-right:16px;margin-left:-10px}.kpi-select{margin-top:6px;width:100%;font-size:11px;padding:2px 4px;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text)}
