/* ==========================================================================
   RUKIA F10 — kpis.css
   --------------------------------------------------------------------------
   F10.4.3-F — camada visual dos indicadores/KPIs.

   Responsabilidade:
   - Grid de KPIs
   - Cards de KPI
   - Estado ativo de filtro KPI
   - Tamanhos compact/standard/currency
   - Tons visuais de KPI

   NÃO contém:
   - Regras JS de cálculo/filtro
   - Tabela/paginação
   - Cliente Público
   - Modal/importação
   ========================================================================== */

.kpi-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  align-items: stretch;
  max-width: 100%;
  padding-bottom: 2px;
  overflow-x: auto;
  scrollbar-width: thin;
}

.kpi-card {
  position: relative;
  flex: 0 0 136px;
  overflow: hidden;
  appearance: none;
  min-width: 124px;
  max-width: 220px;
  min-height: 66px;
  padding: 10px 11px;
  color: inherit;
  text-align: left;
  cursor: pointer;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  transition:
    transform var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
}

.kpi-card:hover {
  background: var(--bg-hover);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.kpi-card:focus-visible {
  outline: 3px solid var(--brand-glow);
  outline-offset: 3px;
}

.kpi-card.is-active {
  border-color: var(--brand);
  box-shadow: 0 0 0 4px var(--brand-glow), var(--shadow-sm);
}

.kpi-card.is-active::after {
  position: absolute;
  right: 10px;
  bottom: 8px;
  color: var(--brand);
  font-size: 10px;
  font-weight: 850;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  content: "FILTRO";
}

.kpi-card--compact {
  flex-basis: 116px;
  min-width: 116px;
  max-width: 166px;
}

.kpi-card--standard {
  flex-basis: 136px;
  min-width: 130px;
  max-width: 210px;
}

.kpi-card--currency {
  flex: 0 0 auto;
  width: max-content;
  min-width: 190px;
  max-width: min(420px, 100%);
}

.kpi-card::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  content: "";
  background: linear-gradient(90deg, var(--brand), var(--system-purple));
  opacity: 0.8;
}

.kpi-label {
  margin: 0;
  overflow: hidden;
  color: var(--text-muted);
  font-size: 10px;
  font-weight: 850;
  line-height: 1.25;
  letter-spacing: 0.05em;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.kpi-value {
  margin: 7px 0 0;
  overflow: hidden;
  color: var(--text-strong);
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 850;
  line-height: 1.02;
  letter-spacing: -0.05em;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.kpi-card--currency .kpi-value {
  max-width: none;
  overflow: visible;
  font-size: clamp(17px, 1.55vw, 23px);
  letter-spacing: -0.035em;
  text-overflow: clip;
}

.kpi-hint {
  display: none;
}

.kpi-card.is-warning::before {
  background: var(--warning);
}

.kpi-card.is-danger::before {
  background: var(--danger);
}

.kpi-card.is-success::before {
  background: var(--success);
}

.kpi-card.is-info::before {
  background: var(--info);
}


/* ========================================================================== 
   F10.5 — Cliente Gestão: KPIs executivos da rede
   --------------------------------------------------------------------------
   Escopo exclusivo: .app-shell-cliente-gestao
   ========================================================================== */

.app-shell-cliente-gestao .kpi-grid {
  gap: 10px;
  padding-bottom: 4px;
}

.app-shell-cliente-gestao .kpi-card {
  flex-basis: 156px;
  min-width: 144px;
  min-height: 74px;
  padding: 11px 12px;
  border-radius: var(--radius-lg);
}

.app-shell-cliente-gestao .kpi-card::before {
  height: 4px;
}

.app-shell-cliente-gestao .kpi-label {
  font-size: 10.5px;
  letter-spacing: 0.06em;
}

.app-shell-cliente-gestao .kpi-value {
  margin-top: 8px;
  font-size: clamp(21px, 2.1vw, 30px);
}

.app-shell-cliente-gestao .kpi-card.is-active {
  box-shadow: 0 0 0 4px var(--brand-glow), var(--shadow-md);
}
