/* ============================================================
   article-page.css
   Desktop 1440px: centered article content with sidebar-like width
   Mobile  370px:  full-width stacked content
   ============================================================ */

/* ── Section ────────────────────────────────────────────────── */
.article-page {
  padding-top:    calc(40 / var(--vw-base) * 100vw);
  padding-bottom: calc(40 / var(--vw-base) * 100vw);
  background-color: var(--color-bg);
}

/* ── Container ───────────────────────────────────────────────── */
.article-page .container {
  display: flex;
  flex-direction: column;
  gap: calc(30 / var(--vw-base) * 100vw);
}

/* ── Header block (tag + title + meta) ────────────────────────── */
.article-page__header {
  display: flex;
  flex-direction: column;
  gap: calc(20 / var(--vw-base) * 100vw);
}

.article-page__tag {
  display: inline-flex;
  align-self: flex-start;
  padding: calc(8 / var(--vw-base) * 100vw) calc(15 / var(--vw-base) * 100vw);
  border-radius: calc(10 / var(--vw-base) * 100vw);
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.43;
  color: var(--color-red);
  background-color: rgba(234, 51, 35, 0.08);
}

.article-page__title {
  font-size:   calc(35 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.14;
  color: var(--color-text);
}

.article-page__meta {
  display: flex;
  align-items: center;
  gap: calc(20 / var(--vw-base) * 100vw);
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.43;
  color: var(--color-text);
  opacity: 0.6;
}

/* ── Featured image ───────────────────────────────────────────── */
.article-page__image {
  width: 100%;
  border-radius: calc(20 / var(--vw-base) * 100vw);
  object-fit: cover;
}

/* ── Article body ─────────────────────────────────────────────── */
.article-page__body {
  display: flex;
  flex-direction: column;
  gap: calc(20 / var(--vw-base) * 100vw);
}

.article-page__subtitle {
  font-size:   calc(24 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.17;
  color: var(--color-text);
}

.article-page__text {
  font-size:   calc(18 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.56;
  color: var(--color-text);
}

.article-page__list {
  display: flex;
  flex-direction: column;
  gap: calc(10 / var(--vw-base) * 100vw);
  padding-left: calc(25 / var(--vw-base) * 100vw);
  list-style: disc;
}

.article-page__list li {
  font-size:   calc(18 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.56;
  color: var(--color-text);
}

/* ── Back link ────────────────────────────────────────────────── */
.article-page__back {
  display: inline-flex;
  align-items: center;
  gap: calc(8 / var(--vw-base) * 100vw);
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.43;
  color: var(--color-red);
  transition: opacity 0.2s;
}
.article-page__back:hover { opacity: 0.7; }

.article-page__back-arrow {
  width:  calc(8 / var(--vw-base) * 100vw);
  height: calc(8 / var(--vw-base) * 100vw);
  fill: none;
  stroke: var(--color-red);
  stroke-width: 2;
  transform: rotate(180deg);
}

/* ============================================================
   MOBILE  (max-width: 767px)
   ============================================================ */
@media (max-width: 767px) {
  .article-page {
    padding-top:    calc(15 / var(--vw-base) * 100vw);
    padding-bottom: calc(15 / var(--vw-base) * 100vw);
  }

  .article-page .container {
    gap: calc(20 / var(--vw-base) * 100vw);
    max-width: none;
  }

  .article-page__header {
    gap: calc(15 / var(--vw-base) * 100vw);
  }

  .article-page__tag {
    padding: calc(6 / var(--vw-base) * 100vw) calc(12 / var(--vw-base) * 100vw);
    font-size: calc(12 / var(--vw-base) * 100vw);
  }

  .article-page__title {
    font-size:   calc(26 / var(--vw-base) * 100vw);
    line-height: 1.15;
  }

  .article-page__meta {
    gap: calc(15 / var(--vw-base) * 100vw);
    font-size: calc(12 / var(--vw-base) * 100vw);
  }

  .article-page__image {
    border-radius: calc(10 / var(--vw-base) * 100vw);
  }

  .article-page__body {
    gap: calc(15 / var(--vw-base) * 100vw);
  }

  .article-page__subtitle {
    font-size:   calc(20 / var(--vw-base) * 100vw);
    line-height: 1.2;
  }

  .article-page__text {
    font-size:   calc(14 / var(--vw-base) * 100vw);
    line-height: 1.43;
  }

  .article-page__list li {
    font-size:   calc(14 / var(--vw-base) * 100vw);
    line-height: 1.43;
  }
}
