/* ============================================================
   Fiflouu Design System · Tarjetas y contenedores
   Depende de: colors_and_type.css
   ============================================================ */

.card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition:
    box-shadow var(--dur-base) var(--ease-standard),
    border-color var(--dur-fast) var(--ease-standard),
    transform var(--dur-fast) var(--ease-standard);
}

/* paddings alternativos */
.card--compact { padding: var(--space-4); }
.card--loose { padding: var(--space-8); }
.card--flush { padding: 0; overflow: hidden; }

/* sin sombra, solo borde */
.card--plain { box-shadow: none; }

/* card interactiva — hover + active */
.card--interactive { cursor: pointer; }
.card--interactive:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--border-default);
}
.card--interactive:active { transform: translateY(1px); }
.card--interactive:focus-visible { outline: none; box-shadow: var(--ring-focus); border-color: var(--purple-500); }

/* card seleccionada */
.card.is-selected {
  border-color: var(--purple-600);
  box-shadow: 0 0 0 3px var(--purple-100);
}

/* card elevada (para hero, CTA) */
.card--elevated { box-shadow: var(--shadow-md); }

/* card de marca */
.card--brand {
  background: linear-gradient(135deg, var(--purple-700), var(--purple-600));
  color: var(--fg-inverse);
  border-color: transparent;
  box-shadow: var(--shadow-brand);
}
.card--brand .card__title,
.card--brand .card__meta { color: var(--fg-inverse); }
.card--brand .card__body { color: rgba(255, 255, 255, 0.82); }
.card--brand .card__foot { border-top-color: rgba(255, 255, 255, 0.18); }

/* ---------- ESTRUCTURA INTERNA ---------- */

.card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
}
.card__head-main { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; flex: 1; }
.card__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--fg-1);
  margin: 0;
  line-height: var(--lh-snug);
}
.card__meta {
  font-size: var(--fs-sm);
  color: var(--fg-3);
  line-height: var(--lh-normal);
}
.card__body {
  color: var(--fg-2);
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
}
.card__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-subtle);
  margin-top: auto;
}

/* card--flush: secciones internas con su propio padding */
.card--flush .card__head,
.card--flush .card__body { padding: var(--space-5) var(--space-6); }
.card--flush .card__body { padding-top: 0; }
.card--flush .card__foot { padding: var(--space-4) var(--space-6); background: var(--bg-canvas); }

/* ---------- TARJETA DE ESTADÍSTICA ---------- */

.card--stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
}
.card--stat .stat-label {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: var(--fw-semibold);
}
.card--stat .stat-value {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-tight);
  color: var(--fg-1);
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.card--stat .stat-trend {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--success-600);
}
.card--stat .stat-trend.is-down { color: var(--error-600); }
.card--stat .stat-trend.is-neutral { color: var(--fg-3); }
.card--stat .stat-trend svg { width: 14px; height: 14px; }

/* ---------- PANEL (variante menos visual) ---------- */

.panel {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.panel__head {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}
.panel__head h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  margin: 0;
  color: var(--fg-1);
}
.panel__body { padding: var(--space-5); }
.panel__foot {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  background: var(--bg-canvas);
}

/* ---------- CALLOUT / INFO BOX ---------- */

.callout {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  border: 1px solid transparent;
}
.callout svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; stroke-width: 2; }
.callout__body { flex: 1; color: var(--fg-1); }
.callout__body strong { font-weight: var(--fw-semibold); }
.callout__body p { margin: 0; }
.callout__body p + p { margin-top: var(--space-2); }

.callout--info { background: var(--info-50); border-color: rgba(46, 124, 230, 0.18); color: var(--info-700); }
.callout--info svg { color: var(--info-600); }

.callout--success { background: var(--success-50); border-color: rgba(3, 170, 111, 0.18); color: var(--success-700); }
.callout--success svg { color: var(--success-600); }

.callout--warning { background: var(--warning-50); border-color: rgba(242, 169, 59, 0.22); color: var(--warning-700); }
.callout--warning svg { color: var(--warning-600); }

.callout--error { background: var(--error-50); border-color: rgba(220, 53, 69, 0.18); color: var(--error-700); }
.callout--error svg { color: var(--error-600); }

.callout--brand { background: var(--purple-50); border-color: rgba(95, 61, 148, 0.18); color: var(--purple-800); }
.callout--brand svg { color: var(--purple-600); }

/* ---------- LISTA DE TARJETAS ---------- */

.card-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 640px) {
  .card-list--2 { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .card-list--3 { grid-template-columns: repeat(3, 1fr); }
  .card-list--4 { grid-template-columns: repeat(4, 1fr); }
}
