/* ═══════════════════════════════════════════════════════════════════
   Dashboard — estilos isolados (prefixo .dash-)
   Todos os seletores usam o prefixo .dash- para não vazar para
   outros módulos do sistema.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Filtros ──────────────────────────────────────────────────────── */
.dash-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  padding: .75rem 1rem;
  background: #fff;
  border-radius: var(--radius, 10px);
  box-shadow: var(--shadow, 0 2px 12px rgba(0,0,0,.08));
  margin-bottom: .75rem;
}

.dash-chips { display: flex; gap: .375rem; flex-wrap: wrap; }

.dash-chip {
  padding: .3rem .85rem;
  border: 1.5px solid #dde1e7;
  border-radius: 20px;
  background: #fff;
  font-size: .8rem;
  font-weight: 500;
  color: #555;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  line-height: 1.4;
}
.dash-chip:hover  { border-color: var(--teal-mid, #1A4E62); color: var(--teal-mid, #1A4E62); }
.dash-chip.active { background: var(--teal, #0D2E3A); border-color: var(--teal, #0D2E3A); color: #fff; }

.dash-custom-range { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.dash-date-input   { padding: .3rem .6rem !important; font-size: .8rem !important; width: 130px; }
.dash-date-sep     { font-size: .8rem; color: #888; }
.dash-apply-btn    { padding: .3rem .75rem !important; font-size: .8rem !important; }

.dash-refresh-btn {
  margin-left: auto;
  background: none;
  border: 1.5px solid #dde1e7;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #666;
  cursor: pointer;
  transition: border-color .15s, color .15s;
  flex-shrink: 0;
}
.dash-refresh-btn:hover { border-color: var(--teal-mid, #1A4E62); color: var(--teal-mid, #1A4E62); }
.dash-refresh-btn.spinning i { animation: dash-spin .6s linear infinite; }

@keyframes dash-spin { to { transform: rotate(360deg); } }

/* ── Realtime status bar ──────────────────────────────────────────── */
.dash-rt-bar {
  display: flex;
  align-items: center;
  gap: .45rem;
  font-size: .75rem;
  color: #888;
  padding: .1rem .25rem;
  margin-bottom: .75rem;
}

.dash-rt-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #aaa;
  flex-shrink: 0;
  transition: background .3s, box-shadow .3s;
}
.dash-rt-dot--online   { background: #2e7d32; box-shadow: 0 0 0 2px rgba(46,125,50,.2); }
.dash-rt-dot--offline  { background: #c62828; }
.dash-rt-dot--degraded { background: #f57f17; }

/* ── Grid 2×2 ─────────────────────────────────────────────────────── */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

/* ── Section card ─────────────────────────────────────────────────── */
.dash-section {
  background: #fff;
  border-radius: var(--radius, 10px);
  box-shadow: var(--shadow, 0 2px 12px rgba(0,0,0,.08));
  padding: 1.1rem 1.25rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .85rem;
  min-width: 0;
}

.dash-sec-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1.5px solid #f0f0f0;
  padding-bottom: .6rem;
}
.dash-sec-title {
  font-size: .95rem;
  font-weight: 700;
  color: var(--teal, #0D2E3A);
  margin: 0;
  display: flex;
  align-items: center;
  gap: .45rem;
}
.dash-sec-title i { font-size: .9rem; opacity: .7; }

/* Empurra o título à esquerda → filtros/botões agrupam à direita */
.dash-sec-header > .dash-sec-title { margin-right: auto; }

/* Botão "Analisar com IA" em cada card */
.dash-ia-btn {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .72rem; font-weight: 700; line-height: 1;
  padding: .3rem .6rem;
  border: 1.5px solid #e3d6ff; border-radius: 8px;
  background: #f5eeff; color: #7b3ff2;
  cursor: pointer; white-space: nowrap;
  transition: background .15s;
}
.dash-ia-btn:hover { background: #e9dbff; }
.dash-ia-btn:disabled { opacity: .55; cursor: default; }

/* O atributo [hidden] DEVE esconder estes blocos. Sem isto, as regras de
   `display` abaixo (.dash-skeleton/.dash-kpis/.dash-charts/.dash-error)
   sobrescrevem o estilo padrão do navegador e tudo aparece ao mesmo tempo
   (skeleton + dados + erro). */
.dash-skeleton[hidden],
.dash-kpis[hidden],
.dash-charts[hidden],
.dash-error[hidden] { display: none !important; }

/* ── Filtro de atendente (seção Leads) ────────────────────────────── */
.dash-leads-filtro {
  font-size: .76rem;
  padding: .25rem .5rem;
  border: 1.5px solid #dde1e7;
  border-radius: 8px;
  background: #fff;
  color: #555;
  cursor: pointer;
  max-width: 170px;
}
.dash-leads-filtro:hover { border-color: var(--teal-mid, #1A4E62); }

/* ── Despesas por categoria (chips) ───────────────────────────────── */
.dash-despesas-cat { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0 2px; }
.dash-desp-chip {
  font-size: .72rem; padding: 3px 10px; border-radius: 14px;
  background: #f5f6f8; border: 1px solid #eee; color: #555;
}
.dash-desp-chip b { color: #c62828; margin-left: 5px; }

/* ── Lista de inadimplência ───────────────────────────────────────── */
.dash-inadim-item {
  display: flex; align-items: center; gap: .55rem;
  font-size: .76rem; padding: .34rem .55rem; border-radius: 7px;
  background: #fff5f5; border: 1px solid #ffe0e0; margin-bottom: .32rem;
}
.dash-inadim-item .di-nome { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #333; font-weight: 600; }
.dash-inadim-item .di-atraso { color: #c62828; font-size: .68rem; white-space: nowrap; }
.dash-inadim-item .di-val { font-weight: 700; color: #c62828; white-space: nowrap; }
.dash-inadim-empty { font-size: .78rem; color: #2e7d32; padding: .4rem 0; display: flex; align-items: center; gap: .4rem; }

/* ── Sub-seção (ex.: Conversão por Atendente dentro de Leads) ─────── */
.dash-subsec-header {
  margin-top: .5rem;
  padding-top: .75rem;
  border-top: 1.5px dashed #ececec;
  font-size: .83rem;
  font-weight: 700;
  color: var(--teal, #0D2E3A);
  display: flex;
  align-items: center;
  gap: .4rem;
}
.dash-subsec-header i { opacity: .7; font-size: .8rem; }

/* ── Gestão Anual — filtro de anos ────────────────────────────────── */
.dash-gestao-filtro {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  align-items: center;
  margin-bottom: .65rem;
}
.dash-gestao-filtro .dash-gestao-flabel {
  font-size: .74rem; color: #888; font-weight: 600; margin-right: .15rem;
}
.dash-gestao-ano {
  padding: .25rem .7rem;
  border: 1.5px solid #dde1e7;
  border-radius: 20px;
  background: #fff;
  font-size: .78rem;
  font-weight: 600;
  color: #555;
  cursor: pointer;
  user-select: none;
  transition: background .15s, border-color .15s, color .15s;
}
.dash-gestao-ano:hover  { border-color: var(--teal-mid, #1A4E62); }
.dash-gestao-ano.active { background: var(--teal, #0D2E3A); border-color: var(--teal, #0D2E3A); color: #fff; }
.dash-gestao-ano.sistema::after {
  content: 'sistema'; font-size: .58rem; margin-left: .35rem;
  background: #e3f2fd; color: #1565c0; border-radius: 4px; padding: 0 4px;
}
.dash-gestao-ano.active.sistema::after { background: rgba(255,255,255,.25); color: #fff; }

/* ── Gestão Anual — gráficos comparativos ─────────────────────────── */
.dash-gestao-charts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1.1rem;
}
@media (max-width: 768px) { .dash-gestao-charts { grid-template-columns: 1fr; } }

/* ── Skeleton shimmer ─────────────────────────────────────────────── */
.dash-skeleton { display: flex; flex-direction: column; gap: .5rem; }

@keyframes dash-shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
.dash-sk-kpi,
.dash-sk-chart {
  background: linear-gradient(90deg, #ececec 25%, #f5f5f5 50%, #ececec 75%);
  background-size: 1200px 100%;
  animation: dash-shimmer 1.5s ease-in-out infinite;
  border-radius: 6px;
}
.dash-sk-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: .5rem; }
.dash-sk-kpi  { height: 56px; }
.dash-sk-chart { height: 160px; }

/* ── KPI cards ────────────────────────────────────────────────────── */
.dash-kpis {
  display: grid;
  /* Responsivo: encaixa quantos cards couberem sem cortar. Em meia largura
     (grid 2 colunas) cai para ~2 por linha em vez de estourar com 4 fixas. */
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .6rem;
}
.dash-kpis--3,
.dash-kpis--6 { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); }

.dash-kpi-card {
  background: #f8f9fb;
  border-radius: 8px;
  padding: .6rem .75rem;
  border-left: 3px solid #dde1e7;
}
.dash-kpi-card.dash-kpi-success { border-left-color: #2e7d32; }
.dash-kpi-card.dash-kpi-danger  { border-left-color: #c62828; }
.dash-kpi-card.dash-kpi-var     { border-left-color: var(--gold, #C9A96E); }

.dash-kpi-label {
  font-size: .67rem;
  color: #888;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: .25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash-kpi-value {
  font-size: 1.18rem;
  font-weight: 700;
  color: var(--teal, #0D2E3A);
  line-height: 1.15;
}
.dash-kpi-value.positive { color: #2e7d32; }
.dash-kpi-value.negative { color: #c62828; }
.dash-kpi-sub { font-size: .69rem; color: #aaa; margin-top: .15rem; }

/* ── Chart area ───────────────────────────────────────────────────── */
.dash-charts {
  display: flex;
  gap: .75rem;
  align-items: stretch;
}

.dash-chart-wrap {
  flex: 1;
  min-width: 0;
  position: relative;
  height: 160px;
}
.dash-chart-wrap--sm {
  flex: 0 0 140px;
  height: 140px;
  align-self: center;
}
.dash-chart-wrap canvas {
  width: 100% !important;
  height: 100% !important;
}

/* ── Financeiro — lista próximos 7 dias ───────────────────────────── */
.dash-fin-upcoming {
  flex: 0 0 185px;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  min-width: 0;
}
.dash-upcoming-title {
  font-size: .74rem;
  font-weight: 700;
  color: #555;
  display: flex;
  align-items: center;
  gap: .35rem;
}
.dash-upcoming-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .3rem;
  overflow-y: auto;
  max-height: 145px;
}
.dash-upcoming-item {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .74rem;
  color: #444;
  padding: .28rem .45rem;
  border-radius: 6px;
  background: #f8f9fb;
}
.dash-upcoming-item .dash-upc-badge {
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold, #C9A96E);
}
.dash-upcoming-item.overdue .dash-upc-badge { background: #c62828; }
.dash-upcoming-item .dash-upc-val {
  font-weight: 600;
  white-space: nowrap;
}
.dash-upcoming-empty {
  font-size: .74rem;
  color: #bbb;
  text-align: center;
  padding: .5rem 0;
}

/* ── Error state ──────────────────────────────────────────────────── */
.dash-profile-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.dash-profile-row > .dash-section { min-width: 0; }
.perfil-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .65rem;
  margin-bottom: 1rem;
}
.perfil-kpi {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .25rem .6rem;
  padding: .75rem .85rem;
  border: 1px solid #e7edf4;
  border-left: 3px solid #1565c0;
  border-radius: 9px;
  background: #f8fafc;
}
.perfil-kpi-rec { border-left-color: #2e7d32; }
.perfil-kpi span { width: 100%; color: #777; font-size: .72rem; }
.perfil-kpi b { color: #0D2E3A; font-size: 1.35rem; }
.perfil-kpi small { color: #2e7d32; font-size: .68rem; }
.perfil-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.perfil-bloco { min-width: 0; }
.perfil-titulo {
  color: #0D2E3A;
  font-size: .82rem;
  font-weight: 700;
  margin-bottom: .55rem;
}
.perfil-titulo i { color: #78909c; margin-right: .25rem; }
.perfil-rank { margin-bottom: .48rem; }
.perfil-rank > div {
  display: flex;
  justify-content: space-between;
  gap: .5rem;
  color: #444;
  font-size: .76rem;
  margin-bottom: .15rem;
}
.perfil-rank span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.perfil-rank b { color: #0D2E3A; }
.perfil-rank em {
  display: block;
  height: 5px;
  overflow: hidden;
  border-radius: 4px;
  background: #edf1f5;
}
.perfil-rank em i { display: block; height: 100%; border-radius: inherit; }
.perfil-tags { display: flex; flex-wrap: wrap; gap: .4rem; align-content: start; }
.perfil-tag {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .28rem .5rem;
  border: 1px solid #e7ebf0;
  border-radius: 999px;
  background: #fff;
  color: #455a64;
  font-size: .72rem;
}
.perfil-tag i { width: 7px; height: 7px; border-radius: 50%; background: var(--tag-cor); }
.perfil-tag b { color: #0D2E3A; }
.perfil-vazio { color: #aaa; font-size: .76rem; padding: .35rem 0; }
.perfil-erro { color: #c62828; }

.dash-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  padding: 1.5rem 1rem;
  color: #c62828;
  font-size: .84rem;
  text-align: center;
}
.dash-error i { font-size: 1.35rem; opacity: .7; }

/* ── Empty state overlay nos gráficos ────────────────────────────── */
/* Exibido sobre o canvas quando o dataset está vazio no período     */
.dash-chart-empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  color: #bbb;
  font-style: italic;
  pointer-events: none;
}

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .dash-grid { grid-template-columns: 1fr; }
  .dash-profile-row,
  .perfil-grid { grid-template-columns: 1fr; }

  .dash-kpis    { grid-template-columns: repeat(2, 1fr); }
  .dash-kpis--3 { grid-template-columns: repeat(2, 1fr); }
  .dash-kpis--6 { grid-template-columns: repeat(2, 1fr); }
  .dash-sk-kpis { grid-template-columns: repeat(2, 1fr); }

  .dash-charts { flex-direction: column; height: auto; }
  .dash-chart-wrap,
  .dash-chart-wrap--sm { flex: none; width: 100%; height: 180px; align-self: unset; }

  .dash-fin-upcoming { flex: none; width: 100%; }

  .dash-refresh-btn { margin-left: 0; }
  .dash-filters { gap: .4rem; }
}

@media (max-width: 480px) {
  .dash-kpi-value { font-size: 1rem; }
  .dash-section   { padding: .85rem .9rem 1rem; }
  .dash-chart-wrap,
  .dash-chart-wrap--sm { height: 155px; }
}
