/* supervision.css v2 */

.sv-layout { display:flex; flex:1; min-height:0; overflow:hidden; height:calc(100vh - var(--header-h)); }

/* ── Sidebar ── */
.sv-sidebar { width:260px; min-width:260px; border-right:1px solid var(--border); background:var(--surface); display:flex; flex-direction:column; overflow:hidden; }
.sv-sidebar-inner { flex:1; overflow-y:auto; display:flex; flex-direction:column; }

.sv-q-actions { display:flex; gap:5px; margin-bottom:6px; }
.sv-q-actions button { background:none; border:1px solid var(--border); border-radius:var(--radius); padding:2px 10px; font-size:10px; font-weight:600; color:var(--text3); cursor:pointer; font-family:var(--font); transition:all .15s; }
.sv-q-actions button:hover { border-color:var(--gc-orange); color:var(--gc-orange); }

.sv-q-list { display:flex; flex-direction:column; gap:2px; max-height:200px; overflow-y:auto; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--surface2); padding:4px; }
.sv-q-item { display:flex; align-items:center; gap:7px; padding:4px 7px; border-radius:4px; cursor:pointer; user-select:none; transition:background .1s; }
.sv-q-item:hover { background:var(--surface); }
.sv-q-item.sel { background:var(--gc-orange-dim); }
.sv-q-chk { width:12px; height:12px; border-radius:3px; border:2px solid var(--border2); flex-shrink:0; display:flex; align-items:center; justify-content:center; transition:all .12s; }
.sv-q-chk.chk { background:var(--gc-orange); border-color:var(--gc-orange); }
.sv-q-chk.chk::after { content:''; width:3px; height:5px; border-right:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(40deg) translate(-1px,-1px); }
.sv-q-name { font-size:11px; font-weight:600; color:var(--text2); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sv-q-item.sel .sv-q-name { color:var(--gc-orange); }

.sv-int-btn { padding:3px 9px; border-radius:var(--radius); border:1.5px solid var(--border); background:var(--surface); font-size:11px; font-weight:600; color:var(--text2); cursor:pointer; font-family:var(--font); transition:all .15s; }
.sv-int-btn:hover { border-color:var(--gc-orange); color:var(--gc-orange); }
.sv-int-btn.active { background:var(--gc-orange); border-color:var(--gc-orange); color:#fff; }

.sv-toggle { display:flex; align-items:center; gap:6px; font-size:11px; cursor:pointer; padding:2px 0; color:var(--text2); }
.sv-toggle input { accent-color:var(--gc-orange); }
.sv-tdot { width:7px; height:7px; border-radius:2px; flex-shrink:0; }

.sv-thresh { display:flex; align-items:center; justify-content:space-between; padding:5px 8px; border-radius:var(--radius); background:var(--surface2); border:1.5px solid var(--border); cursor:pointer; margin-bottom:4px; transition:all .12s; }
.sv-thresh:hover { border-color:var(--gc-orange); }
.sv-tv { font-size:10px; font-family:var(--mono); font-weight:700; padding:2px 5px; border-radius:3px; }
.sv-tw { background:rgba(255,171,0,.15); color:#b07800; }
.sv-tc { background:rgba(222,53,11,.12); color:#de350b; }

/* ── Header refresh ── */
.sv-refresh-info { display:flex; align-items:center; gap:8px; margin-right:8px; }
.sv-pulse { width:8px; height:8px; border-radius:50%; background:var(--border2); transition:background .3s; }
.sv-pulse.active { background:var(--green); animation:sv-blink .6s ease-in-out infinite; }
@keyframes sv-blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.sv-ring-wrap { position:relative; width:24px; height:24px; display:flex; align-items:center; justify-content:center; }
.sv-ring-svg { width:24px; height:24px; position:absolute; }

/* ── Main ── */
.sv-main { flex:1; overflow-y:auto; display:flex; flex-direction:column; gap:14px; padding:16px 20px; }

/* KPI bar */
.sv-kpi-bar { display:flex; flex-wrap:wrap; gap:10px; }
.sv-placeholder { font-size:13px; color:var(--text3); padding:16px; text-align:center; width:100%; }
.sv-kpi-card {
  flex:1; min-width:120px; max-width:180px;
  background:var(--surface); border-radius:var(--radius2);
  border:1.5px solid var(--border); padding:12px 14px;
  position:relative; display:flex; flex-direction:column; gap:2px;
  transition:border-color .2s;
}
.sv-kpi-icon { font-size:14px; }
.sv-kpi-val  { font-size:28px; font-weight:800; font-family:var(--font-display); line-height:1; }
.sv-kpi-lbl  { font-size:10px; color:var(--text3); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }
.sv-kpi-queue { font-size:9px; color:var(--text3); font-family:var(--mono); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sv-alert-warning  { border-color:rgba(255,171,0,.5)!important; background:rgba(255,171,0,.05)!important; }
.sv-alert-critical { border-color:rgba(222,53,11,.5)!important; background:rgba(222,53,11,.05)!important; animation:sv-pulse-c 1.5s ease-in-out infinite; }
@keyframes sv-pulse-c { 0%,100%{box-shadow:none} 50%{box-shadow:0 0 0 3px rgba(222,53,11,.2)} }
.sv-alert-badge { position:absolute; top:6px; right:6px; font-size:8px; font-weight:700; padding:2px 5px; border-radius:3px; }
.sv-alert-badge--warning  { background:rgba(255,171,0,.2); color:#b07800; }
.sv-alert-badge--critical { background:rgba(222,53,11,.15); color:#de350b; }

/* ── Panels interactions ── */
.sv-panels { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.sv-panel { background:var(--surface); border-radius:var(--radius2); border:1.5px solid var(--border); display:flex; flex-direction:column; overflow:hidden; }
.sv-panel-header { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; border-bottom:1px solid var(--border); background:var(--surface2); flex-shrink:0; }
.sv-panel-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--text2); }
.sv-panel-badge { font-size:11px; font-weight:700; font-family:var(--mono); padding:2px 8px; border-radius:10px; }
.sv-panel-badge--wait   { background:rgba(255,79,31,.12);  color:var(--gc-orange); }
.sv-panel-badge--active { background:rgba(0,102,255,.12);  color:var(--blue); }

/* ── Tables ── */
.sv-section-hdr { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text3); border-bottom:1px solid var(--border); padding-bottom:6px; }
.sv-table-wrap { overflow-x:auto; max-height:220px; overflow-y:auto; }
.sv-agents-wrap { max-height:none; }
.sv-table { width:100%; border-collapse:collapse; font-size:12px; }
.sv-table thead th { padding:7px 10px; text-align:left; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--text3); border-bottom:2px solid var(--border); background:var(--surface); position:sticky; top:0; z-index:1; white-space:nowrap; }
.sv-table tbody tr td { padding:7px 10px; border-bottom:1px solid var(--border); vertical-align:middle; }
.sv-table tbody tr:hover td { background:var(--surface2); }
.sv-empty-cell { text-align:center; padding:24px; color:var(--text3); font-size:12px; }

.sv-dur { font-family:var(--mono); font-size:11px; }
.sv-dur-warn { color:#b07800; font-weight:700; }
.sv-dur-crit { color:#de350b; font-weight:700; }
.sv-q-pill { display:inline-block; background:var(--surface2); border:1px solid var(--border); border-radius:3px; padding:1px 6px; font-size:10px; font-weight:600; color:var(--text2); white-space:nowrap; max-width:160px; overflow:hidden; text-overflow:ellipsis; }

/* ── Agent rows ── */
.sv-agent-row.sv-r-INTERACTING td    { background:rgba(0,102,255,.04); }
.sv-agent-row.sv-r-NOT_RESPONDING td { background:rgba(222,53,11,.04); }
.sv-agent-flash td { animation:sv-flash 1s ease-in-out infinite; }
@keyframes sv-flash { 0%,100%{background:rgba(255,79,31,.0)} 50%{background:rgba(255,79,31,.12)} }

.sv-avatar { width:28px; height:28px; border-radius:50%; color:#fff; font-size:10px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.sv-pill { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:20px; border:1px solid transparent; font-size:11px; font-weight:600; white-space:nowrap; }
.sv-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }

.sv-agent-alert { display:inline-flex; align-items:center; gap:4px; font-size:10px; font-weight:700; padding:2px 7px; border-radius:3px; }
.sv-agent-alert--warning  { background:rgba(255,171,0,.15); color:#b07800; }
.sv-agent-alert--critical { background:rgba(255,79,31,.15);  color:#FF4F1F; }

/* ── Modal ── */
.sv-modal-bg  { position:fixed; inset:0; background:rgba(0,0,0,.4); display:flex; align-items:center; justify-content:center; z-index:1000; }
.sv-modal     { background:var(--surface); border-radius:var(--radius2); border:1px solid var(--border); width:320px; box-shadow:var(--shadow-lg); }
.sv-modal-hdr { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--border); font-size:14px; font-weight:700; }
.sv-modal-body { padding:16px; }
.sv-mf label  { font-size:12px; font-weight:600; color:var(--text2); }

/* Sub-state pills agents */
.sv-pill-sub   { font-weight: 700; }
.sv-pill-pulse { animation: sv-pill-blink 1.2s ease-in-out infinite; }
@keyframes sv-pill-blink { 0%,100%{opacity:1} 50%{opacity:.6} }
.sv-dot-pulse  { animation: sv-dot-ping 1.2s ease-in-out infinite; }
@keyframes sv-dot-ping { 0%,100%{transform:scale(1)} 50%{transform:scale(1.4)} }

/* Skills tags */
.sv-skill-tag {
  display: inline-block;
  background: rgba(0,184,217,.1);
  color: #007a94;
  border: 1px solid rgba(0,184,217,.25);
  border-radius: 3px;
  padding: 1px 5px;
  font-size: 9px;
  font-weight: 600;
  margin: 1px;
  white-space: nowrap;
}

/* Threshold group labels */
.sv-thresh-group-lbl {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text3);
  padding: 4px 2px 2px;
}

/* ── Filtres tableau agents ── */
.sv-filter-row th {
  padding: 4px 6px;
  background: var(--surface2);
  border-bottom: 2px solid var(--border);
}
.sv-filter-input {
  width: 100%;
  padding: 4px 7px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font-size: 11px;
  font-family: var(--font);
  outline: none;
  box-sizing: border-box;
  transition: border-color .15s;
}
.sv-filter-input:focus  { border-color: var(--gc-orange); }
.sv-filter-select {
  width: 100%;
  padding: 4px 5px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font-size: 11px;
  font-family: var(--font);
  outline: none;
  cursor: pointer;
  transition: border-color .15s;
}
.sv-filter-select:focus { border-color: var(--gc-orange); }
.sv-filter-reset {
  width: 100%;
  padding: 4px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: none;
  color: var(--text3);
  font-size: 11px;
  cursor: pointer;
  transition: all .15s;
}
.sv-filter-reset:hover { border-color: var(--gc-orange); color: var(--gc-orange); }

/* ── Dropdown multi-select filtres ── */
.sv-mf-wrap { position: relative; }
.sv-mf-btn {
  width: 100%; padding: 4px 7px;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  background: var(--surface); color: var(--text2);
  font-size: 11px; font-family: var(--font); cursor: pointer;
  text-align: left; white-space: nowrap;
  transition: border-color .15s, color .15s;
}
.sv-mf-btn:hover { border-color: var(--gc-orange); color: var(--gc-orange); }
.sv-mf-dropdown {
  position: absolute; top: calc(100% + 2px); left: 0; z-index: 200;
  min-width: 160px; background: var(--surface);
  border: 1.5px solid var(--border); border-radius: var(--radius);
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  padding: 4px 0; max-height: 240px; overflow-y: auto;
}
.sv-mf-item {
  display: flex; align-items: center; gap: 7px;
  padding: 5px 10px; font-size: 11px; cursor: pointer;
  color: var(--text2); user-select: none;
  transition: background .1s;
}
.sv-mf-item:hover { background: var(--surface2); }
.sv-mf-item input { accent-color: var(--gc-orange); flex-shrink: 0; }
