/* ═══ VARIÁVEIS ═══ */
.rootant {
  --bg: #f0f2f5;
  --white: #ffffff;
  --surface2: #f8f9fb;
  --border: #e2e6ed;
  --border-light: #eef0f4;
  --primary: #1a3a6b;
  --primary-light: #2451a3;
  --green: #1a8a4a; --green-bg: #eaf6ee; --green-border: #b7dfc6;
  --blue: #1560bd;  --blue-bg: #e8f0fc;  --blue-border: #aec8f0;
  --orange: #c96a00;--orange-bg: #fff3e0;--orange-border: #f5c980;
  --red: #c0392b;   --red-bg: #fdecea;   --red-border: #f0b8b3;
  --yellow: #9a6f00;--yellow-bg: #fffce0;--yellow-border: #f0de85;
  --text: #1f2937; --text-mid: #4b5563; --text-dim: #9ca3af;
  --sans: 'Inter', sans-serif;
  --mono: 'Roboto Mono', monospace;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 2px 8px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.05);
}
:root {
  --bg: #f0f2f5;
  --white: #ffffff;
  --surface2: #f8f9fb;
  --border: #e2e6ed;
  --border-light: #eef0f4;
  --primary: #f26419;
  --primary-light: #2451a3;
  --green: #1a8a4a; --green-bg: #eaf6ee; --green-border: #b7dfc6;
  --blue: #1560bd;  --blue-bg: #e8f0fc;  --blue-border: #aec8f0;
  --orange: #c96a00;--orange-bg: #fff3e0;--orange-border: #f5c980;
  --red: #c0392b;   --red-bg: #fdecea;   --red-border: #f0b8b3;
  --yellow: #9a6f00;--yellow-bg: #fffce0;--yellow-border: #f0de85;
  --text: #1f2937; --text-mid: #4b5563; --text-dim: #9ca3af;
  --sans: 'Inter', sans-serif;
  --mono: 'Roboto Mono', monospace;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 2px 8px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.05);
}

/* ═══ RESET ═══ */
* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--bg); color:var(--text); font-family:var(--sans); min-height:100vh; font-size:14px; }

/* ═══ HEADER ═══ */
header {
  background: var(--primary);
  height: 58px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 24px;
  position: sticky; top: 0; z-index: 200;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  gap: 16px;
}

.header-left { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.header-logo { font-size:17px; font-weight:700; color:#fff; letter-spacing:-0.3px; }
.header-logo span { color:#7fb3ff; }
.header-divider { width:1px; height:22px; background:rgba(255,255,255,0.2); }
.header-subtitle { font-size:17px; font-weight:700; color:#ffffff; white-space:nowrap; letter-spacing:-.2px; }

.header-search { position:relative; display:flex; align-items:center; }
.search-icon { position:absolute; left:10px; color:rgba(255,255,255,0.45); pointer-events:none; font-size:14px; }
.header-search input {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 6px;
  padding: 7px 32px 7px 34px;
  font-family: var(--sans); font-size:13px; color:#fff;
  width: 240px; outline:none;
  transition: background .2s, border-color .2s, width .25s;
}
.header-search input::placeholder { color:rgba(255,255,255,0.4); }
.header-search input:focus { background:rgba(255,255,255,0.18); border-color:rgba(255,255,255,0.4); width:300px; }
.search-clear {
  position:absolute; right:8px;
  background:none; border:none; color:rgba(255,255,255,0.5);
  cursor:pointer; font-size:15px; display:none; padding:2px 4px; line-height:1; border-radius:3px;
}
.search-clear:hover { color:#fff; }

.header-stats { display:flex; gap:6px; align-items:center; flex-shrink:0; }
.hstat {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.15);
  border-radius:6px; padding:5px 11px;
  font-size:12px; color:rgba(255,255,255,0.85); font-weight:500; white-space:nowrap;
}
.hstat strong { font-size:15px; font-weight:700; color:#fff; }
.hstat-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.hstat-dot.green  { background:#4ade80; }
.hstat-dot.blue   { background:#60a5fa; }
.hstat-dot.orange { background:#fb923c; }
.hstat-dot.red    { background:#f87171; }

.header-right { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.live-badge { display:flex; align-items:center; gap:5px; font-size:11px; font-weight:600; color:#4ade80; text-transform:uppercase; letter-spacing:.06em; }
.live-dot { width:7px; height:7px; border-radius:50%; background:#4ade80; animation:livepulse 1.8s ease-in-out infinite; }
@keyframes livepulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }
.header-time {
  font-family:var(--mono); font-size:15px; font-weight:500;
  color:rgba(255,255,255,0.9); letter-spacing:.04em;
  background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.15);
  border-radius:6px; padding:5px 12px; white-space:nowrap;
}

/* ═══ PAGE ═══ */
.page {
  display: grid;
  grid-template-columns: 1fr 295px;
  gap: 20px;
  padding: 20px;
  max-width: 1800px;
  margin: 0 auto;
  align-items: start;
}

/* ═══ SIDEBAR SETORES ═══ */
.setores-sidebar {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.sidebar-head {
  background: var(--primary);
  padding: 11px 14px;
  display: flex; align-items: center; justify-content: space-between;
}
.sidebar-head-title { font-size:12px; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:.07em; }
.btn-toggle-all {
  font-size:11px; color:rgba(255,255,255,0.7);
  background:none; border:none; cursor:pointer; font-family:var(--sans);
  text-decoration:underline; text-underline-offset:2px; padding:0;
}
.btn-toggle-all:hover { color:#fff; }

.setor-filter-list { padding:6px 0; max-height:300px; overflow-y:auto; }
.setor-filter-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 14px; cursor:pointer;
  transition:background .12s; user-select:none;
  border-bottom:1px solid var(--border-light);
}
.setor-filter-item:last-child { border-bottom:none; }
.setor-filter-item:hover { background:var(--surface2); }
.setor-check {
  width:16px; height:16px;
  border:2px solid var(--border); border-radius:4px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:background .12s, border-color .12s;
  font-size:10px; color:#fff; font-weight:700;
}
.setor-filter-item.active .setor-check { background:#e07010; border-color:#b85810; }
.setor-filter-info { flex:1; min-width:0; }
.setor-filter-name { font-size:12px; font-weight:600; color:var(--text); line-height:1.3; }
.setor-filter-sub  { font-size:10px; color:var(--text-dim); margin-top:2px; }
.setor-filter-badge {
  font-family:var(--mono); font-size:10px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:10px; padding:1px 7px; color:var(--text-mid); flex-shrink:0;
}

/* ═══ MAIN ═══ */
.main-col { display:flex; flex-direction:column; gap:20px; min-width:0; }

.search-notice {
  display:none; align-items:center; gap:8px;
  font-size:13px; color:var(--text-mid);
  background:var(--white); border:1px solid var(--border);
  border-radius:7px; padding:9px 14px;
  box-shadow:var(--shadow-sm);
}
.search-notice.visible { display:flex; }
.search-notice strong { color:var(--primary); }

.no-results {
  display:none; text-align:center; padding:48px 20px;
  color:var(--text-dim); font-size:13px;
  background:var(--white); border:1px solid var(--border); border-radius:8px;
}
.no-results.visible { display:block; }
.no-results-icon { font-size:36px; margin-bottom:10px; }

/* ═══ SETOR BLOCK ═══ */
.setor-block { display:block; }
.setor-block.hidden { display:none; }

.setor-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.setor-title {
  margin-top: 20px;
  font-size:13px; font-weight:700; color:var(--primary);
  text-transform:uppercase; letter-spacing:.06em;
  display:flex; align-items:center; gap:8px;
}
.setor-title::before {
  content:''; display:block; width:3px; height:14px;
  background:var(--primary-light); border-radius:2px;
}
.setor-meta { display:flex; gap:10px; font-size:11px; color:var(--text-dim); align-items:center; flex-wrap:wrap; }
.setor-meta-item { display:flex; align-items:center; gap:4px; }
.sdot { width:6px; height:6px; border-radius:50%; }
.sdot-green  { background:var(--green); }
.sdot-blue   { background:var(--blue); }
.sdot-orange { background:var(--orange); }
.sdot-red    { background:var(--red); }

/* ═══ RAMAL CARDS ═══ */
.ramais-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap:10px;
}

.ramal-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:8px; padding:14px 14px 12px;
  display:flex; flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .18s, border-color .18s;
  position:relative; overflow:hidden;
  min-height: 106px;
}
.ramal-card:hover { box-shadow:var(--shadow); }
.ramal-card.search-hidden { display:none; }

.ramal-card::after {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; border-radius:8px 8px 0 0;
}
.ramal-card.s-ocupado::after      { background:var(--orange); }
.ramal-card.s-espera::after       { background:var(--orange); }
.ramal-card.s-desconectado::after { background:#d1d5db; }
.ramal-card.s-desconectado        { opacity:.65; }

/* ── Em chamada ── */
.ramal-card.s-em-chamada {
  background: #e74c3c;
  border-color: #c0392b;
  box-shadow: 0 0 0 2px rgba(231,76,60,0.25), 0 4px 14px rgba(231,76,60,0.2);
}
.ramal-card.s-em-chamada::after         { background: #c0392b; height: 4px; }
.ramal-card.s-em-chamada .ramal-num     { color: #ffffff; }
.ramal-card.s-em-chamada .ramal-name    { color: rgba(255,255,255,0.8); }
.ramal-card.s-em-chamada .ramal-divider { background: rgba(255,255,255,0.2); }
.ramal-card.s-em-chamada .info-row      { color: rgba(255,255,255,0.85); }
.ramal-card.s-em-chamada .info-row .lbl { color: rgba(255,255,255,0.55); }
.ramal-card.s-em-chamada .info-row .val { color: #ffffff; }
.ramal-card.s-em-chamada .arr-in        { color: rgba(255,255,255,0.9); }
.ramal-card.s-em-chamada .t-green       { color: #a7f3d0; }

/* ── Chamando — estado vermelho aplicado via JS (painel.js) ── */
.ramal-card.s-chamando::after { background:var(--red); height: 4px; }

.ramal-card.s-chamando.blink-red {
  background: #e74c3c;
  border-color: #c0392b;
  box-shadow: 0 0 0 4px rgba(231,76,60,0.3), 0 6px 20px rgba(231,76,60,0.45);
}
.ramal-card.s-chamando.blink-red::after         { background: #ffffff; }
.ramal-card.s-chamando.blink-red .ramal-num     { color: #ffffff; }
.ramal-card.s-chamando.blink-red .ramal-name    { color: rgba(255,255,255,0.85); }
.ramal-card.s-chamando.blink-red .ramal-divider { background: rgba(255,255,255,0.25); }
.ramal-card.s-chamando.blink-red .info-row      { color: rgba(255,255,255,0.9); }
.ramal-card.s-chamando.blink-red .info-row .lbl { color: rgba(255,255,255,0.6); }
.ramal-card.s-chamando.blink-red .info-row .val { color: #ffffff; }
.ramal-card.s-chamando.blink-red .arr-in        { color: rgba(255,255,255,0.9); }
.ramal-card.s-chamando.blink-red .badge         { background:rgba(255,255,255,0.2); color:#ffffff; border-color:rgba(255,255,255,0.5); }

.ramal-top  { display:flex; justify-content:space-between; align-items:flex-start; margin-top:4px; }
.ramal-num  { font-family:var(--mono); font-size:22px; font-weight:500; color:var(--primary); line-height:1; }
.ramal-name { font-size:12px; color:var(--text-mid); margin-top:3px; }

/* ═══ BADGES ═══ */
.badge {
  font-size:10px; font-weight:600; padding:3px 8px;
  border-radius:20px; text-transform:uppercase; letter-spacing:.04em;
  white-space:nowrap; border:1px solid transparent; flex-shrink:0;
  min-width: 90px; text-align: center;
}
/* ── Livre ── */
.ramal-card.s-livre {
  background: #fde8c8;
  border-color: #f5bc78;
}
.ramal-card.s-livre::after        { background: #c06010; height:4px; }
.ramal-card.s-livre .ramal-num    { color: #c44e0e; }
.ramal-card.s-livre .ramal-name   { color: #7a4520; }

.badge-livre { background:#e07010; color:#ffffff; border-color:#b85810; font-weight:700; }
.badge-ocupado      { background:var(--orange-bg); color:var(--orange); border-color:var(--orange-border); }
.badge-espera       { background:var(--orange-bg); color:var(--orange); border-color:var(--orange-border); }
.badge-desconectado { background:#f3f4f6; color:#6b7280; border-color:#d1d5db; }
.badge-chamando     { background:var(--red-bg); color:var(--red); border-color:var(--red-border); font-weight:700; }
.badge-em-chamada   { font-weight:700; letter-spacing:.06em; animation:cycle-badge 2.4s ease-in-out infinite; }

@keyframes cycle-badge {
  0%,100% { background:rgba(255,255,255,0.22); color:#ffffff; border-color:rgba(255,255,255,0.4); }
  50%     { background:#c0392b; color:rgba(255,255,255,0.6); border-color:rgba(192,57,43,0.8); }
}

/* ═══ INFO ROWS ═══ */
.ramal-divider { height:1px; background:var(--border-light); margin:10px 0 8px; }
.ramal-info { display:flex; flex-direction:column; gap:4px; }
.info-row { display:flex; align-items:center; gap:5px; font-size:11.5px; color:var(--text-mid); }
.info-row .lbl { color:var(--text-dim); font-size:10.5px; width:32px; flex-shrink:0; }
.info-row .val { color:var(--text); font-weight:500; font-family:var(--mono); font-size:11px; }
.info-row .timer { margin-left:auto; font-family:var(--mono); font-size:11px; font-weight:600; }
.t-green  { color:var(--green); }
.t-orange { color:var(--orange); }
.t-red    { color:var(--red); }
.arr-in   { color:var(--blue);  font-weight:700; }
.arr-out  { color:var(--green); font-weight:700; }

/* ═══ LEGENDA ═══ */
.legend { display:flex; gap:14px; flex-wrap:wrap; padding-top:10px; border-top:1px solid var(--border); }
.legend-item { display:flex; align-items:center; gap:5px; font-size:11px; color:var(--text-dim); }
.legend-stripe { width:12px; height:4px; border-radius:2px; }

/* ═══ SIDEBAR DIREITA ═══ */
.right-sidebar { display:flex; flex-direction:column; gap:16px; position:sticky; top:78px; }
.side-card, .panel-card { background:var(--white); border:1px solid var(--border); border-radius:8px; box-shadow:var(--shadow-sm); overflow:hidden; }
.side-card-header, .panel-card-header {
  background:var(--primary); padding:11px 16px;
  display:flex; align-items:center; justify-content:space-between;
}
.side-card-title, .panel-card-title { font-size:12px; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:.07em; }
.side-card-badge { font-size:11px; font-weight:600; background:rgba(255,255,255,0.15); color:#fff; border-radius:12px; padding:1px 9px; }

/* ═══ FILAS ═══ */
.fila-block { border-bottom:1px solid var(--border-light); }
.fila-block:last-child { border-bottom:none; }
.fila-block-header, .panel-block-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 16px 7px; background:var(--surface2); border-bottom:1px solid var(--border-light);
}
.fila-block-name  { font-size:12px; font-weight:600; color:var(--primary); }
.fila-block-count { font-size:11px; font-weight:600; padding:2px 8px; border-radius:12px; border:1px solid transparent; }
.fila-block-count.has  { background:var(--orange-bg); color:var(--orange); border-color:var(--orange-border); }
.fila-block-count.free { background:var(--green-bg);  color:var(--green);  border-color:var(--green-border); }
.fila-block-items { padding:6px 16px 8px; }
.fila-row { display:flex; align-items:center; gap:8px; padding:5px 0; border-bottom:1px solid var(--border-light); font-size:12px; }
.fila-row:last-child { border-bottom:none; }
.fila-pos  { width:18px; height:18px; border-radius:50%; background:var(--primary); color:#fff; font-size:10px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.fila-num  { font-family:var(--mono); font-size:11px; color:var(--text); font-weight:500; flex:1; }
.fila-wait { font-family:var(--mono); font-size:11px; font-weight:600; flex-shrink:0; }
.fila-empty { font-size:11px; color:var(--text-dim); padding:8px 0; text-align:center; }

/* ═══ SELECT PAINEL ═══ */
#selectPainel {
  font-family: var(--sans); font-size: 13px;
  width: 100%;
  border: none;
  padding: 10px;
  background: #f0f2f5;
  border-radius: 8px;
  cursor: pointer;
  outline: none;
  box-shadow: var(--shadow);
  color: var(--text);
  font-weight: 600;
}

/* ═══ SCROLLBAR ═══ */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }