.card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  position: relative;
  transition: border-color var(--d-fast) var(--ease-std), background var(--d-fast) var(--ease-std), transform var(--d-fast) var(--ease-std);
}

.card--interactive { cursor: pointer; }
.card--interactive:hover { border-color: var(--line-strong); background: var(--bg-2); }
.card--interactive:active { transform: translateY(1px); }

.card--raised { box-shadow: var(--sh-sheet); }
.card--featured { border-color: var(--accent); box-shadow: var(--sh-glow); }
.card--flush { background: transparent; border: 0; }
.card--inset { background: var(--bg-inset); border-color: var(--line-soft); }

.card__head {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--line);
}

.card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--t-md);
  text-transform: uppercase;
  letter-spacing: var(--tr-snug);
}

.card__sub { font-size: var(--t-xs); color: var(--ink-3); }

.card__body { padding: var(--s-4) var(--s-5); }
.card__body--flush { padding: 0; }
.card__body--tight { padding: var(--s-3) var(--s-4); }

.card__foot {
  padding: var(--s-3) var(--s-5);
  border-top: 1px solid var(--line);
  background: var(--bg-inset);
  border-radius: 0 0 var(--r-md) var(--r-md);
}

.card__action { color: var(--accent); font-size: var(--t-xs); font-weight: 600; text-transform: uppercase; letter-spacing: var(--tr-wide); display: inline-flex; align-items: center; gap: 4px; }
.card__action:hover { color: var(--accent-hot); }
.card__action::after { content: "→"; transition: transform var(--d-fast) var(--ease-std); }
.card__action:hover::after { transform: translateX(2px); }

@media (max-width: 480px) {
  .card__head { padding: var(--s-3) var(--s-4); }
  .card__body { padding: var(--s-3) var(--s-4); }
  .card__foot { padding: var(--s-3) var(--s-4); }
  .card__body--tight { padding: var(--s-2) var(--s-3); }
}
