/* ==========================================================
   IMPERSOL — KPI / Relatórios (design system)
   Seletores: .kpi-*, .kpi-hero-*, .kpi-obra-*
   ========================================================== */

/* ── Hero card row ── */
.kpi-hero {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--imp-space-3);
  padding: var(--imp-space-4) var(--imp-space-3) var(--imp-space-2);
}
.kpi-hero-card {
  background: var(--imp-surface);
  border: 1px solid var(--imp-border);
  border-radius: var(--imp-radius-md);
  padding: var(--imp-space-4);
  display: flex;
  flex-direction: column;
  gap: var(--imp-space-1);
}
.kpi-hero-val {
  font-size: var(--imp-text-2xl);
  font-weight: var(--imp-weight-bold);
  color: var(--imp-text);
  line-height: 1;
}
.kpi-hero-val.brand { color: var(--imp-brand-400); }
.kpi-hero-val.success { color: var(--imp-success); }
.kpi-hero-val.warn    { color: var(--imp-warn); }
.kpi-hero-val.danger  { color: var(--imp-danger); }
.kpi-hero-lbl {
  font-size: var(--imp-text-xs);
  color: var(--imp-text-muted);
}
.kpi-hero-delta {
  font-size: var(--imp-text-xs);
  font-weight: var(--imp-weight-medium);
  color: var(--imp-success);
}
.kpi-hero-delta.negativo { color: var(--imp-danger); }

/* ── Section heading ── */
.kpi-section {
  font-size: var(--imp-text-xs);
  font-weight: var(--imp-weight-semibold);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--imp-text-dim);
  padding: var(--imp-space-4) var(--imp-space-4) var(--imp-space-2);
}

/* ── Obra ranking row ── */
.kpi-obra-row {
  display: flex;
  align-items: center;
  gap: var(--imp-space-3);
  padding: var(--imp-space-3) var(--imp-space-4);
  border-bottom: 1px solid var(--imp-border-soft);
}
.kpi-obra-rank {
  font-size: var(--imp-text-lg);
  font-weight: var(--imp-weight-bold);
  color: var(--imp-text-faint);
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}
.kpi-obra-info { flex: 1; min-width: 0; }
.kpi-obra-nome {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-medium);
  color: var(--imp-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.kpi-obra-sub { font-size: var(--imp-text-xs); color: var(--imp-text-muted); margin-top: 1px; }
.kpi-obra-val {
  font-size: var(--imp-text-lg);
  font-weight: var(--imp-weight-bold);
  color: var(--imp-brand-400);
  flex-shrink: 0;
}

/* ── Bar chart row ── */
.kpi-bar-row {
  display: flex;
  align-items: center;
  gap: var(--imp-space-2);
  padding: var(--imp-space-2) var(--imp-space-4);
}
.kpi-bar-lbl {
  font-size: var(--imp-text-xs);
  color: var(--imp-text-muted);
  width: 80px;
  flex-shrink: 0;
}
.kpi-bar-track {
  flex: 1;
  height: 6px;
  background: var(--imp-border);
  border-radius: var(--imp-radius-full);
  overflow: hidden;
}
.kpi-bar-fill {
  height: 100%;
  background: var(--imp-brand-400);
  border-radius: var(--imp-radius-full);
  transition: width var(--imp-duration-slow) var(--imp-ease-out);
}
.kpi-bar-val {
  font-size: var(--imp-text-xs);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-text-muted);
  width: 40px;
  text-align: right;
}

/* ── Empty state ── */
.kpi-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--imp-space-10) var(--imp-space-6);
  gap: var(--imp-space-3);
}
.kpi-empty svg { opacity: .3; }
.kpi-empty-title {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-text-muted);
}
