/* card.css — Double-Bezel card standard */

/* ─── CARD SHELL ─────────────────────────────────────────── */
/* Flex column so .card__inner stretches to the full grid-row height —
   keeps every card (and its bezel frame) uniform regardless of copy length. */
.card {
  position: relative;
  display: flex;
  border-radius: var(--radius-card);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

/* ─── DOUBLE-BEZEL INNER INSET ───────────────────────────── */
/* Outer border on .card + 8px inner padding creates optical frame */
.card__inner {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: calc(var(--space-md) + 8px);
  position: relative;
  z-index: 1;
}

/* Subtle inset rule — optical inner frame */
.card__inner::before {
  content: '';
  position: absolute;
  inset: 8px;
  border-radius: calc(var(--radius-card) - 6px);
  border: 1px solid var(--color-border);
  pointer-events: none;
  z-index: 0;
}

/* ─── DARK VARIANT ───────────────────────────────────────── */
.card--dark {
  background: var(--color-surface-dark);
  border-color: var(--color-border-dark);
  box-shadow: none;
}

.card--dark .card__inner::before {
  border-color: var(--color-border-dark);
}

/* ─── CARD EYEBROW ───────────────────────────────────────── */
.card__eyebrow {
  font-family: var(--font-body);
  font-size: var(--size-eyebrow);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: 500;
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
}

/* ─── CARD HEADING ───────────────────────────────────────── */
.card__heading {
  font-family: var(--font-display);
  font-size: var(--size-h3);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: var(--space-xs);
}

.card--dark .card__heading {
  color: var(--color-text-inverse);
}

/* ─── CARD BODY ──────────────────────────────────────────── */
.card__body {
  font-family: var(--font-body);
  font-size: var(--size-small);
  line-height: var(--leading-body);
  color: var(--color-text-secondary);
}

.card--dark .card__body {
  color: var(--color-text-muted);
}

/* ─── CARD PRICE ─────────────────────────────────────────── */
.card__price {
  font-family: var(--font-display);
  font-size: var(--size-h2);
  font-weight: 700;
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  margin-block: var(--space-sm);
}

.card--dark .card__price {
  color: var(--color-text-inverse);
}

/* ─── CARD LIST ──────────────────────────────────────────── */
.card__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
}

.card__list-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-xs);
  font-family: var(--font-body);
  font-size: var(--size-small);
  line-height: var(--leading-body);
  color: var(--color-text-secondary);
}

.card--dark .card__list-item {
  color: var(--color-text-muted);
}

.card__list-item::before {
  content: '—';
  flex-shrink: 0;
  color: var(--color-text-muted);
  font-size: var(--size-small);
  margin-top: 2px;
}

/* ─── CARD ICON SLOT ─────────────────────────────────────── */
.card__icon {
  width: 40px;
  height: 40px;
  margin-bottom: var(--space-sm);
  color: var(--color-text-primary);
  flex-shrink: 0;
}

.card--dark .card__icon {
  color: var(--color-text-inverse);
}

/* ─── CARD FOOTER ────────────────────────────────────────── */
.card__footer {
  margin-top: auto; /* pin to bottom — aligns CTAs across uniform-height cards */
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.card--dark .card__footer {
  border-top-color: var(--color-border-dark);
}
