/* =========================================================================
   blog.css — стили блога «Спасение+ Тула» (Этап 4).
   Дизайн-система: accent #c1d9e5 / green #79d1c3, text #111, muted #667085.
   Подключается только в контексте блога (см. functions.php).
   ========================================================================= */

.blog-page {
	--bl-accent: #c1d9e5;
	--bl-green: #79d1c3;
	--bl-text: #111;
	--bl-muted: #667085;
	--bl-panel: #f6f8f9;
	--bl-border: #e6eef0;
	--bl-ring: rgba(193, 217, 229, .45);
	--bl-radius: 16px;
	--bl-shadow: 0 8px 24px rgba(11, 18, 32, .06);
	--bl-shadow-hover: 0 14px 30px rgba(11, 18, 32, .12);
	background: #fff;
}

/* ---------- Хлебные крошки ---------- */
.blog-crumbs {
	padding-top: calc(var(--header-height) + 22px);
}
.blog-crumbs .container { padding-block: 0; }
.blog-crumbs ol {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
	font-size: 13px; color: var(--bl-muted);
}
.blog-crumbs li { display: flex; align-items: center; gap: 6px; }
.blog-crumbs li:not(:last-child)::after { content: "/"; color: #c3ccd6; }
.blog-crumbs a { color: var(--bl-muted); text-decoration: none; }
.blog-crumbs a:hover { color: var(--bl-green); }
.blog-crumbs [aria-current="page"] { color: var(--bl-text); }

/* ---------- Лента ---------- */
.blog-feed { padding: 22px 0 56px; }
.blog-feed__head { max-width: 760px; margin: 0 0 28px; }
.blog-feed__eyebrow {
	display: inline-block; font-size: 13px; font-weight: 600; letter-spacing: .02em;
	color: #2a8a7a; background: rgba(121, 209, 195, .14);
	padding: 5px 12px; border-radius: 999px; margin-bottom: 14px;
}
.blog-feed__title {
	margin: 0 0 12px; font-size: clamp(1.8rem, 4.5vw, 2.7rem); line-height: 1.15; color: var(--bl-text);
}
.blog-feed__lead { margin: 0; font-size: clamp(1rem, 2vw, 1.15rem); color: var(--bl-muted); line-height: 1.6; }

/* ---------- Фильтр-чипы рубрик ---------- */
.blog-filter { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.blog-filter__chip {
	display: inline-flex; align-items: center; gap: 7px;
	padding: 8px 16px; border-radius: 999px; text-decoration: none;
	font-size: 14px; font-weight: 500; color: #334155;
	background: var(--bl-panel); border: 1px solid var(--bl-border);
	transition: background .18s, border-color .18s, color .18s;
}
.blog-filter__chip:hover { border-color: var(--bl-green); color: #0f172a; }
.blog-filter__chip.is-active { background: var(--bl-green); border-color: var(--bl-green); color: #04201c; }
.blog-filter__count { font-size: 12px; opacity: .7; }
.blog-filter__chip.is-active .blog-filter__count { opacity: .85; }

/* ---------- Сетка карточек ---------- */
.blog-grid {
	display: grid; gap: 22px;
	grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
}
.blog-featured-wrap { margin-bottom: 24px; }

.blog-card {
	display: flex; flex-direction: column; text-decoration: none; color: inherit;
	background: #fff; border: 1px solid var(--bl-border); border-radius: var(--bl-radius);
	overflow: hidden; box-shadow: var(--bl-shadow);
	transition: transform .18s, box-shadow .18s, border-color .18s;
}
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--bl-shadow-hover); border-color: var(--bl-accent); }
.blog-card__media {
	position: relative; aspect-ratio: 16 / 9; background: var(--bl-panel);
	display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; }
.blog-card__ph { color: #b6c4cf; }
.blog-card__body { display: flex; flex-direction: column; gap: 10px; padding: 18px 18px 20px; flex: 1; }
.blog-card__chip {
	align-self: flex-start; font-size: 12px; font-weight: 600; color: #2a8a7a;
	background: rgba(121, 209, 195, .14); padding: 4px 10px; border-radius: 999px;
}
.blog-card__title { margin: 0; font-size: 1.12rem; line-height: 1.3; color: var(--bl-text); }
.blog-card__excerpt { margin: 0; font-size: .94rem; line-height: 1.55; color: var(--bl-muted); }
.blog-card__meta {
	margin-top: auto; display: flex; flex-wrap: wrap; gap: 6px;
	font-size: 13px; color: #8a96a3; padding-top: 4px;
}

/* Featured — крупная карточка в две колонки на десктопе */
@media (min-width: 720px) {
	.blog-card--featured { flex-direction: row; }
	.blog-card--featured .blog-card__media { width: 52%; aspect-ratio: auto; min-height: 280px; }
	.blog-card--featured .blog-card__body { width: 48%; justify-content: center; padding: 28px; }
	.blog-card--featured .blog-card__title { font-size: 1.6rem; }
	.blog-card--featured .blog-card__excerpt { font-size: 1rem; }
}

/* ---------- Пагинация ---------- */
.blog-pager { margin-top: 36px; }
.blog-pager .nav-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.blog-pager .page-numbers {
	display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px;
	padding: 0 12px; border-radius: 10px; text-decoration: none; font-weight: 500; color: #334155;
	background: var(--bl-panel); border: 1px solid var(--bl-border);
}
.blog-pager .page-numbers:hover { border-color: var(--bl-green); }
.blog-pager .page-numbers.current { background: var(--bl-green); border-color: var(--bl-green); color: #04201c; }
.blog-pager .page-numbers.dots { background: none; border: none; }
.blog-empty { padding: 48px 0; text-align: center; color: var(--bl-muted); }
.blog-empty a { color: var(--bl-green); }

/* =========================================================================
   single — статья
   ========================================================================= */
.post-single { padding: 22px 0 8px; }
.post-single__container { max-width: 820px; }

.post-head { margin-bottom: 22px; }
.post-head__chip {
	display: inline-block; font-size: 13px; font-weight: 600; color: #2a8a7a;
	background: rgba(121, 209, 195, .14); padding: 5px 12px; border-radius: 999px; text-decoration: none;
	margin-bottom: 14px;
}
.post-head__title { margin: 0 0 20px; font-size: clamp(1.7rem, 4.5vw, 2.5rem); line-height: 1.2; color: var(--bl-text); }

/* Карточка автора */
.author-card { display: flex; gap: 14px; align-items: center; }
.author-card__avatar {
	width: 56px; height: 56px; border-radius: 50%; object-fit: cover; flex: none; display: block;
	background: var(--bl-panel);
}
.author-card__avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.author-card__avatar--ph {
	display: flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 22px; color: #2a8a7a; background: rgba(121, 209, 195, .18);
}
.author-card__name { font-weight: 600; font-size: 1rem; color: var(--bl-text); }
.author-card__name a { text-decoration: none; color: inherit; }
.author-card__name a:hover { color: var(--bl-green); }
.author-card__role { font-size: 13px; color: var(--bl-muted); line-height: 1.4; margin-top: 2px; }
.author-card__meta { font-size: 12.5px; color: #8a96a3; margin-top: 4px; display: flex; flex-wrap: wrap; gap: 5px; }

.post-reviewed {
	display: flex; align-items: flex-start; gap: 8px; margin-top: 16px;
	font-size: 13.5px; color: #3f5a55; background: rgba(121, 209, 195, .10);
	border: 1px solid rgba(121, 209, 195, .35); border-radius: 12px; padding: 10px 14px;
}
.post-reviewed svg { flex: none; color: var(--bl-green); margin-top: 1px; }
.post-reviewed a { color: #2a8a7a; }

/* Обложка */
.post-cover:not(:empty) { margin: 0 0 26px; }
.post-cover__img { width: 100%; border-radius: var(--bl-radius); object-fit: cover; box-shadow: var(--bl-shadow); }

/* Оглавление */
.post-toc {
	background: var(--bl-panel); border: 1px solid var(--bl-border); border-radius: 14px;
	padding: 16px 20px; margin: 0 0 28px;
}
.post-toc__title { font-weight: 700; font-size: 14px; color: var(--bl-text); margin-bottom: 8px; }
.post-toc ol { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 6px; }
.post-toc a { color: #355; text-decoration: none; font-size: 14.5px; line-height: 1.45; }
.post-toc a:hover { color: var(--bl-green); text-decoration: underline; }

/* Типографика статьи */
.post-prose { font-size: 1.06rem; line-height: 1.72; color: #1d2733; }
.post-prose > * { scroll-margin-top: calc(var(--header-height) + 16px); }
.post-prose p { margin: 0 0 18px; }
.post-prose h2 { font-size: clamp(1.35rem, 3vw, 1.7rem); line-height: 1.25; margin: 38px 0 14px; color: var(--bl-text); }
.post-prose h3 { font-size: 1.2rem; margin: 28px 0 10px; color: var(--bl-text); }
.post-prose ul, .post-prose ol { margin: 0 0 18px; padding-left: 24px; }
.post-prose li { margin-bottom: 8px; }
.post-prose a { color: #2a8a7a; text-decoration: underline; text-underline-offset: 2px; }
.post-prose img { border-radius: 12px; margin: 18px 0; }
.post-prose blockquote {
	margin: 22px 0; padding: 14px 20px; border-left: 4px solid var(--bl-green);
	background: var(--bl-panel); border-radius: 0 12px 12px 0; color: #2c3a44;
}
.post-prose table { width: 100%; border-collapse: collapse; margin: 18px 0; font-size: .96rem; }
.post-prose th, .post-prose td { border: 1px solid var(--bl-border); padding: 10px 12px; text-align: left; }
.post-prose th { background: var(--bl-panel); }

/* Источники */
.post-sources {
	margin: 34px 0 0; padding: 18px 22px; background: var(--bl-panel);
	border: 1px solid var(--bl-border); border-radius: 14px;
}
.post-sources__title { margin: 0 0 10px; font-size: 1rem; color: var(--bl-text); }
.post-sources ol { margin: 0; padding-left: 20px; }
.post-sources li { margin-bottom: 7px; font-size: 14px; color: #475569; line-height: 1.5; }
.post-sources a { color: #2a8a7a; }

/* Дисклеймер */
.post-disclaimer {
	margin: 22px 0 0; padding: 14px 18px; font-size: 13.5px; line-height: 1.55; color: #6b5a2a;
	background: #fbf6e9; border: 1px solid #efe2bf; border-radius: 12px;
}

/* Расширенная карточка автора */
.author-card--full {
	margin: 34px 0 0; padding: 22px; align-items: flex-start;
	background: #fff; border: 1px solid var(--bl-border); border-radius: var(--bl-radius); box-shadow: var(--bl-shadow);
}
.author-card--full .author-card__avatar { width: 88px; height: 88px; }
.author-card__label { font-size: 12px; font-weight: 600; letter-spacing: .03em; text-transform: uppercase; color: #9aa7b3; }
.author-card--full .author-card__name { font-size: 1.15rem; margin-top: 4px; }
.author-card__bio { margin: 10px 0 12px; font-size: 14px; line-height: 1.6; color: var(--bl-muted); }
.author-card__link { font-weight: 600; font-size: 14px; color: #2a8a7a; text-decoration: none; }
.author-card__link:hover { text-decoration: underline; }

/* Похожие + услуги */
.blog-related { padding: 44px 0 8px; }
.blog-related__title, .blog-services__title { margin: 0 0 22px; font-size: clamp(1.4rem, 3vw, 1.9rem); color: var(--bl-text); }
.blog-services { padding: 36px 0; }
.blog-services__grid { display: flex; flex-wrap: wrap; gap: 12px; }
.blog-services__item {
	display: inline-flex; align-items: center; padding: 12px 20px; border-radius: 12px; text-decoration: none;
	font-weight: 500; color: #0f172a; background: var(--bl-panel); border: 1px solid var(--bl-border);
	transition: border-color .18s, background .18s;
}
.blog-services__item:hover { border-color: var(--bl-green); background: #fff; }

/* Итоговый CTA */
.blog-cta { padding: 0 0 60px; }
.blog-cta__inner {
	background: linear-gradient(135deg, #eaf4f4, #f6f8f9); border: 1px solid var(--bl-border);
	border-radius: 22px; padding: clamp(28px, 5vw, 48px); text-align: center;
}
.blog-cta__title { margin: 0 0 10px; font-size: clamp(1.4rem, 3.5vw, 2rem); color: var(--bl-text); }
.blog-cta__text { margin: 0 auto 22px; max-width: 560px; color: var(--bl-muted); line-height: 1.6; }
.blog-cta__actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.blog-cta__actions .cta-button { min-width: 200px; }

@media (max-width: 600px) {
	.author-card--full { flex-direction: column; }
	.blog-cta__actions .cta-button { width: 100%; }
}
