/* ==========================================================================
   ABM components - KPI cards
   ========================================================================== */

.abm-kpi-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.abm-kpi-card,
.abm-kpi,
.abm-stat-card {
  position: relative;
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--abm-border-subtle);
  border-radius: var(--abm-radius-lg);
  background: var(--abm-color-surface);
  box-shadow: var(--abm-shadow-sm);
}

.abm-stat-card {
  display: grid;
  gap: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.88));
}

.abm-kpi-label,
.abm-stat-card span {
  margin: 0;
  color: var(--abm-color-muted);
  font-size: 0.76rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  line-height: 1.25;
  text-transform: uppercase;
}

.abm-kpi-value,
.abm-stat-card strong {
  margin: 8px 0 0;
  color: var(--abm-color-text);
  font-size: 1.75rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
}

.abm-stat-card strong {
  margin: 0;
  font-size: clamp(1.6rem, 2.2vw, 2.25rem);
  line-height: 1.14;
}

.abm-kpi-value--compact {
  font-size: 1rem;
}

.abm-kpi-help,
.abm-kpi-sub,
.abm-stat-card small {
  margin: 8px 0 0;
  color: var(--abm-color-muted);
  font-size: 0.84rem;
  line-height: 1.4;
}

.abm-stat-card small {
  margin: 0;
  color: var(--abm-color-muted-strong);
  font-size: 0.86rem;
  line-height: 1.45;
}

.abm-kpi-card--success {
  border-color: rgba(16, 185, 129, 0.24);
}

.abm-kpi-card--warning {
  border-color: rgba(245, 179, 1, 0.32);
}

.abm-kpi-card--danger {
  border-color: rgba(239, 68, 68, 0.24);
}
