/* === Блог: аккуратная ширина и читаемая "мерка" текста === */

/* Базовые переменные ширины: узкий контент на десктопе, мягкая адаптация */
:root {
  --content-w: min(960px, 92vw);   /* ширина центральной колонки (раньше было 1040px) */
  --text-w:    min(70ch,  92vw);   /* читаемая мерка текста (около 70 символов) */
}

/* Список статей и страницы статей */
body.blog-index .container-wide,
body.blog-article .container-wide {
  width: 100%;
  max-width: var(--content-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
}

/* Если по какой-то причине .container-wide отсутствует — центрируем main */
body.blog-index main,
body.blog-article main {
  display: flex;
  justify-content: center;
}
body.blog-index main > *,
body.blog-article main > * {
  width: 100%;
  max-width: var(--content-w);
  padding-left: 16px;
  padding-right: 16px;
}

/* Ограничиваем реальную ширину текста (чтобы строки не были «на всю») */
body.blog-article h1,
body.blog-article h2,
body.blog-article .post-content,
body.blog-article .post-content > * {
  max-width: var(--text-w);
}

/* Картинки и медиа — по контейнеру, без «вылезаний» */
body.blog-article img,
body.blog-article video,
body.blog-article iframe {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Перенос очень длинных слов/строк */
body.blog-article :where(h1,h2,h3,h4,h5,h6,p,li,blockquote) {
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

/* На мобильных ничего не ломаем — просто даём краевые отступы */
@media (max-width: 575.98px) {
  :root { --content-w: 100vw; --text-w: 92vw; }
}

/* ====== СТРАНИЦА СТАТЬИ ====== */
@media (max-width: 640px) {
  body.blog-article .post-content h2 {
    font-size: clamp(20px, 5.6vw, 26px);
    line-height: 1.28;
    margin-top: 1.2em;
    margin-bottom: .6em;
    letter-spacing: -0.01em;
  }
  body.blog-article .post-content h3 {
    font-size: clamp(18px, 4.8vw, 22px);
    line-height: 1.32;
    margin-top: 1.1em;
    margin-bottom: .5em;
  }
}