/* ============================================================
   MOLÉCULA — Card
   Depende de: tokens.css
   ============================================================ */

.card {
  background: rgba(255, 255, 255, 0.60);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--card-radius);
  box-shadow: var(--glass-shadow), 0 1px 0 rgba(255, 255, 255, 0.15) inset;
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
  transform: translateY(-1px);
  box-shadow: var(--glass-shadow-hover), 0 1px 0 rgba(255, 255, 255, 0.85) inset;
}

[data-theme="dark"] .card {
  background: rgba(38, 44, 52, 0.60);
}

.card-header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid rgba(62, 95, 230, 0.08);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

[data-theme="dark"] .card-header {
  border-bottom-color: rgba(95, 129, 240, 0.12);
}

.card-title    { font-size: var(--text-xl); font-weight: var(--font-semibold); letter-spacing: -0.015em; color: var(--color-text); line-height: var(--leading-tight); display: flex; align-items: center; gap: var(--space-2); }
.card-subtitle { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

.card-body             { padding: var(--space-5); }
.card-body--no-padding { padding: 0; }

.card-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.50);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  background-color: rgba(255, 255, 255, 0.25);
}

@media (min-width: 768px) {
  .card-header, .card-body, .card-footer {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }
}

/* En mobile, las cards con tablas internas necesitan scroll horizontal */
@media (max-width: 767px) {
  .card {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}




.stat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  background-color: var(--color-primary-soft);
  color: var(--color-primary);
  font-size: 1.25rem;
  flex-shrink: 0;
}

.stat-content { flex: 1; min-width: 0; }

.stat-value { display: block; font-size: var(--text-2xl); font-weight: var(--font-bold); font-family: var(--font-display); letter-spacing: -0.03em; color: var(--color-text); line-height: var(--leading-tight); font-variant-numeric: tabular-nums; }
.stat-label { display: block; font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

.stat-delta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  margin-top: var(--space-1);
}
.stat-delta.up   { color: var(--color-success); }
.stat-delta.down { color: var(--color-error); }


