/* ==============================
   Article page - BEM
   ============================== */

.article-page {
  border: none;
  box-shadow: none;
  padding-block: var(--space-4xl);
}

.article-page__header {
  margin-bottom: var(--space-2xl);
}

.article-page__meta {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
  flex-wrap: wrap;
}

/* Tiny date for time/context only (Substack-style) */
.article-page__date {
  font-size: var(--font-size-xs);
}

.article-page__title {
  font-size: var(--font-size-4xl);
  font-weight: 700;
  letter-spacing: var(--letter-spacing-normal);
  line-height: var(--line-height-tight);
  margin: 0;
  color: var(--text-primary);
}

.article-page__summary {
  font-size: var(--font-size-base);
  color: var(--text-secondary);
  margin-top: var(--space-md);
  margin-bottom: 0;
  line-height: 1.4;
  max-width: 60ch;
}

.article-page__body {
  /* .flow handles vertical rhythm */
}

.article-page__body p {
  margin-bottom: 0;
}

.article-page__body p + p,
.article-page__body p + ul,
.article-page__body p + h2,
.article-page__body h2 + p,
.article-page__body ul + p {
  margin-top: var(--space-lg);
}

.article-page__body h2 {
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-sm);
  color: var(--text-primary);
}

.article-page__body strong {
  font-weight: 600;
}

.article-page__body a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.article-page__body a:hover {
  color: var(--color-primary-hover);
}

.article-page__footer {
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--border-subtle);
}

.article-page__footer-title {
  margin-bottom: var(--space-sm);
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--text-primary);
}

/* Inline platform icon next to Steam/Web in headings or body */
.article-platform-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.2em;
  margin-right: var(--space-2xs);
}
