/* ============================================================
   Component · Card
   Selectors: .card  +  modifiers
   Modifiers: card--interactive | card--elevated | card--inverse
   Sub-elements: .card__header .card__body .card__footer .card__media
   ============================================================ */

.card {
  display: flex;
  flex-direction: column;
  background: var(--gio-color-surface);
  color: var(--gio-color-text);
  border: 1px solid var(--gio-color-border);
  border-radius: var(--gio-radius-xl);
  overflow: hidden;
  transition:
    border-color var(--gio-dur-med) var(--gio-ease-out),
    box-shadow var(--gio-dur-med) var(--gio-ease-out),
    transform var(--gio-dur-med) var(--gio-ease-out);
}

.card--elevated { box-shadow: var(--gio-shadow-md); }

.card--interactive {
  cursor: pointer;
}
.card--interactive:hover {
  border-color: var(--gio-color-border-strong);
  box-shadow: var(--gio-shadow-lg);
  transform: translateY(-2px);
}
.card--interactive:focus-visible {
  outline: none;
  border-color: var(--gio-color-action);
  box-shadow: var(--gio-focus-ring);
}

.card--inverse {
  background: var(--gio-color-surface-inverse);
  color: var(--gio-color-text-inverse);
  border-color: transparent;
}
.card--inverse .card__title  { color: var(--gio-color-text-inverse); }
.card--inverse .card__sub    { color: rgba(255,255,255,0.72); }

/* Sub-elements */
.card__media {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--gio-color-bg-subtle);
  border-bottom: 1px solid var(--gio-color-border);
}

.card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gio-space-3);
  padding: var(--gio-space-5) var(--gio-space-6) var(--gio-space-3);
}

.card__body {
  padding: var(--gio-space-3) var(--gio-space-6) var(--gio-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--gio-space-3);
  flex: 1;
}

.card__footer {
  padding: var(--gio-space-4) var(--gio-space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gio-space-3);
  border-top: 1px solid var(--gio-color-divider);
  background: var(--gio-color-surface-alt);
}

.card__title {
  font-size: var(--gio-text-lg);
  line-height: var(--gio-text-lg-lh);
  font-weight: var(--gio-w-semibold);
  color: var(--gio-color-text-strong);
  letter-spacing: var(--gio-tracking-default);
  margin: 0;
}

.card__sub {
  font-size: var(--gio-text-sm);
  line-height: var(--gio-text-sm-lh);
  color: var(--gio-color-text-muted);
  margin: 0;
}

.card__meta {
  display: flex;
  gap: var(--gio-space-4);
  align-items: center;
  font-size: var(--gio-text-xs);
  color: var(--gio-color-text-muted);
}
