/* ==========================================================================
   Cards — CoachOS Design System
   Variants: default, interactive, stat, content
   ========================================================================== */

/* Base Card
   ========================================================================== */

.card {
  background-color: var(--surface-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  min-width: 0;
}

/* Interactive Card
   ========================================================================== */

.card--interactive {
  cursor: pointer;
  transition: all var(--duration-fast);
}

.card--interactive:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
  border-color: var(--border-default);
}

/* Stat Card
   ========================================================================== */

.card--stat {
  padding: var(--space-4);
}

.card--stat .card__value {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
}

.card--stat .card__label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-top: var(--space-1);
}

/* Content Card (header / body / footer)
   ========================================================================== */

.card--content .card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  min-width: 0;
}

.card--content .card__body {
  padding-top: var(--space-4);
}

.card--content .card__footer {
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
}

/* Standalone Card Sub-elements (used without variant wrappers)
   ========================================================================== */

.card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  min-width: 0;
}

.card__header > * {
  min-width: 0;
}

.card__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
}

.card__body {
  padding-top: var(--space-4);
}

.card__value {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
}

.card__label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-top: var(--space-1);
}

.card__image {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.card__image img {
  width: 100%;
  height: auto;
  display: block;
}

.card__stat-value {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text-primary);
}

.card__stat-label {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

/* Key-Value List — dense horizontal label:value pairs inside cards
   ========================================================================== */

.kv-list {
  display: flex;
  flex-direction: column;
}

.kv-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--text-sm);
}

.kv-row:last-child {
  border-bottom: none;
}

.kv-row__label {
  color: var(--text-secondary);
}

.kv-row__value {
  color: var(--text-primary);
  font-weight: 500;
}

/* Card Grid
   ========================================================================== */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}
