/* ─────────────────────────────────────
   EOAM (End-of-Article Moment) — Article v2
   3-slot block: Primary CTA + Related grid + Continue link
   SPEC: docs/specs/INK-DEV-EOAM-V2.md
   ───────────────────────────────────── */

.eoam {
  margin: var(--space-12, 3rem) 0;
  padding-top: var(--space-8, 2rem);
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-8, 2rem);
}

/* ─── Primary CTA ─── */
.eoam__cta { width: 100%; }

.eoam-cta {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-6, 1.5rem);
  background: var(--color-surface, #1a1a1a);
  border-radius: var(--radius-lg, 0.75rem);
  border: 1px solid var(--color-border);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.eoam-cta:hover {
  border-color: var(--color-brand-accent);
  background: var(--color-surface-elevated, #222);
}
.eoam-cta__h {
  font-family: var(--font-display, 'DM Serif Display', serif);
  font-size: var(--text-2xl, 1.5rem);
  line-height: 1.2;
  color: var(--color-text);
}
.eoam-cta__sub {
  font-size: var(--text-base, 1rem);
  color: var(--color-text-muted);
  line-height: 1.5;
}
.eoam-cta__btn {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: var(--space-3, 0.75rem) var(--space-5, 1.25rem);
  background: var(--color-brand-accent);
  color: #0A0A0A;
  font-weight: 600;
  font-size: var(--text-sm, 0.875rem);
  border-radius: var(--radius-md, 0.5rem);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin-top: var(--space-2, 0.5rem);
}

/* Subscribe Plus variant — slightly more prominent */
.eoam-cta--subscribe_plus {
  background: linear-gradient(135deg, var(--color-surface), var(--color-bg-elevated, #1a1a1a));
}

/* ─── Related grid ─── */
.eoam__related {
  display: flex;
  flex-direction: column;
  gap: var(--space-4, 1rem);
}
.eoam__related-title {
  font-family: var(--font-display, 'DM Serif Display', serif);
  font-size: var(--text-xl, 1.25rem);
  margin: 0;
  color: var(--color-text);
}
.eoam__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4, 1rem);
  min-height: 240px; /* skeleton reserve, prevents CLS */
}
.eoam-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2, 0.5rem);
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease;
}
.eoam-card:hover { transform: translateY(-2px); }
.eoam-card__img {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
}
.eoam-card__img img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.eoam-card__title {
  font-size: var(--text-base, 1rem);
  line-height: 1.3;
  margin: 0;
  font-weight: 600;
  color: var(--color-text);
}
.eoam-card__dek {
  font-size: var(--text-sm, 0.875rem);
  line-height: 1.4;
  color: var(--color-text-muted);
  margin: 0;
}
.eoam__view-all {
  align-self: flex-end;
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-brand-accent);
  text-decoration: none;
  padding-top: var(--space-2, 0.5rem);
}
.eoam__view-all:hover { text-decoration: underline; }

/* ─── Continue reading link ─── */
.eoam__next {
  display: flex;
  flex-direction: column;
  gap: var(--space-1, 0.25rem);
  padding: var(--space-4, 1rem) 0;
  text-decoration: none;
  color: inherit;
  border-top: 1px solid var(--color-border);
}
.eoam__next-kicker {
  font-size: var(--text-xs, 0.75rem);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.eoam__next-title {
  font-family: var(--font-display, 'DM Serif Display', serif);
  font-size: var(--text-lg, 1.125rem);
  color: var(--color-text);
  line-height: 1.3;
}
.eoam__next:hover .eoam__next-title { color: var(--color-brand-accent); }

/* ─── Mobile ≤375px ─── */
@media (max-width: 768px) {
  .eoam__grid {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  .eoam-cta__h { font-size: var(--text-xl, 1.25rem); }
  .eoam-cta__btn { width: 100%; justify-content: center; }
}

/* Empty image placeholder (no cover_image_url) */
.eoam-card__img--empty {
  background: linear-gradient(135deg,
    var(--color-surface, #1a1a1a),
    var(--color-bg-elevated, #222));
  border: 1px dashed var(--color-border, #2a2a2a);
}
