/* =====================================================================
   ФУДОНАВТ · БЛОГ — публичные страницы (хаб, статья, блок на лендинге)
   Построено строго на tokens.css. Без сырых hex для chrome, без эмодзи,
   единственный шрифт — Pragmatica, единственный градиент — brand.
   ===================================================================== */

body { background: var(--bg-secondary); color: var(--text-primary); overflow-x: clip; }
.bl { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
a { color: inherit; text-decoration: none; }

/* mark colors (logo geometry from landing) */
#fdnt-mark .fdnt-stroke  { stroke: var(--mark-color, #fff); fill: none; }
#fdnt-mark .fdnt-fill    { fill: var(--mark-color, #fff); }
#fdnt-mark .fdnt-sparkle { fill: var(--mark-sparkle, #4F80E8); }
#fdnt-mark .fdnt-helmet  { fill: var(--mark-color, #fff); }

/* ---------------- Header (sticky glass) ---------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--bg-secondary) 92%, transparent);
  backdrop-filter: saturate(140%) blur(16px);
  -webkit-backdrop-filter: saturate(140%) blur(16px);
  border-bottom: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}
.site-header__bar {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  height: 64px; display: flex; align-items: center; gap: 28px;
}
.site-header__logo { display: inline-flex; align-items: center; gap: 10px; flex: none; }
.site-header__logo-mark { width: 32px; height: 32px; flex: none; --mark-color: var(--text-primary); }
.site-header__logo-text { font-weight: 800; font-size: 22px; letter-spacing: -0.02em; color: var(--text-primary); line-height: 32px; }
.site-header__nav { display: flex; align-items: center; gap: 4px; flex: 1; }
.site-header__nav a {
  display: inline-flex; align-items: center; height: 40px; padding: 0 14px;
  border-radius: var(--radius-md); font-size: var(--font-size-base); font-weight: 500;
  color: var(--text-secondary); transition: background .15s, color .15s;
}
.site-header__nav a:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.site-header__nav a.is-active { color: var(--brand-primary); background: var(--brand-primary-light); font-weight: 600; }
.site-header__cta {
  display: inline-flex; align-items: center; height: 44px; padding: 0 20px; flex: none;
  border-radius: var(--radius-md); background: var(--brand-gradient); color: var(--text-inverse);
  font-size: var(--font-size-base); font-weight: 700; white-space: nowrap;
  border: var(--border-primary-glass);
  box-shadow: var(--shadow-primary); transition: filter .15s, box-shadow .25s, transform .1s;
}
.site-header__cta:hover { filter: brightness(1.06); box-shadow: var(--shadow-primary-hover); }
.site-header__cta:active { transform: translateY(1px); box-shadow: var(--shadow-primary-active); }
.site-header__burger { display: none; width: 40px; height: 40px; border: 1px solid var(--border-color); border-radius: var(--radius-md); background: var(--bg-secondary); flex-direction: column; gap: 4px; align-items: center; justify-content: center; cursor: pointer; }
.site-header__burger span { width: 18px; height: 2px; background: var(--text-primary); border-radius: 2px; transition: transform .25s, opacity .2s; }

/* ---------------- Footer ---------------- */
.footer { margin-top: 120px; padding: 56px 0 40px; border-top: 1px solid var(--border-color); color: var(--text-secondary); font-size: var(--font-size-sm); background: var(--bg-secondary); }
.footer__grid { max-width: 1200px; margin: 0 auto 48px; padding: 0 24px; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer__brand .lp-brand { display: inline-flex; align-items: center; gap: 10px; color: var(--text-primary); }
.footer__brand .lp-brand__mark { width: 32px; height: 32px; --mark-color: var(--text-primary); }
.footer__brand .lp-brand__text { font-weight: 800; font-size: 20px; letter-spacing: -0.02em; }
.footer__brand p { margin-top: 12px; max-width: 280px; line-height: 1.55; }
.footer__col h4 { font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-tertiary); margin-bottom: 14px; }
.footer__col a { display: block; color: var(--text-secondary); padding: 4px 0; }
.footer__col a:hover { color: var(--brand-primary); }
.footer__legal { max-width: 1200px; margin: 0 auto; padding: 24px 24px 0; border-top: 1px solid var(--border-color); display: flex; justify-content: space-between; gap: 16px; color: var(--text-tertiary); font-size: var(--font-size-xs); }

/* ---------------- Eyebrow ---------------- */
.bl-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--brand-primary); margin-bottom: 18px;
}
.bl-eyebrow::before {
  content: ""; width: 12px; height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 14 L56 44 L86 50 L56 56 L50 86 L44 56 L14 50 L44 44 Z' fill='%233B5BFF'/></svg>") center/contain no-repeat;
}
.bl-eyebrow--inverse { color: rgba(255,255,255,0.82); }
.bl-eyebrow--inverse::before { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 14 L56 44 L86 50 L56 56 L50 86 L44 56 L14 50 L44 44 Z' fill='%23ffffff'/></svg>"); }

/* ---------------- Category chip ---------------- */
.bl-cat {
  display: inline-flex; align-items: center; height: 24px; padding: 0 10px;
  border-radius: var(--radius-full); font-size: var(--font-size-xs); font-weight: 700;
  letter-spacing: 0.04em; color: var(--brand-primary); background: var(--brand-primary-light);
}
.bl-cat--onimg { background: rgba(255,255,255,0.92); color: var(--brand-primary); backdrop-filter: blur(4px); }

/* image placeholder (no real imagery yet) */
.bl-imgph { position: relative; width: 100%; height: 100%; overflow: hidden; background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-end) 100%); display: flex; align-items: center; justify-content: center; }
.bl-imgph svg { width: 30%; max-width: 88px; height: auto; opacity: 0.9; --mark-color: rgba(255,255,255,0.92); --mark-sparkle: rgba(255,255,255,0.6); }
.bl-imgph::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 120% at 80% 10%, rgba(255,255,255,0.18), transparent 45%); }
.bl-imgph--alt { background: linear-gradient(135deg, #16307a 0%, var(--brand-primary) 100%); }
.bl-imgph--soft { background: linear-gradient(135deg, var(--brand-primary-end) 0%, #6FA6FF 100%); }
/* реальная картинка статьи */
.bl-imgph img, .bl-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .4s ease; }
/* шиммер до загрузки фото: бегущий блик поверх градиента, фото проявляется по onload */
.bl-imgph.is-loading img { opacity: 0; }
.bl-imgph.is-loading::before {
  content: ""; position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(100deg, transparent 20%, rgba(255,255,255,0.22) 50%, transparent 80%);
  background-size: 200% 100%; animation: bl-shimmer 1.2s linear infinite;
}
@keyframes bl-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .bl-imgph.is-loading::before { animation: none; } }

/* =====================================================================
   BLOG HUB — hero + featured + grid
   ===================================================================== */
.bl-hero { padding: 56px 0 8px; }
.bl-hero h1 { font-size: clamp(34px, 4.4vw, 52px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.06; max-width: 16ch; }
.bl-hero p { margin-top: 16px; font-size: var(--font-size-xl); color: var(--text-secondary); line-height: 1.5; max-width: 52ch; }

/* category filter bar */
.bl-filters { display: flex; flex-wrap: wrap; gap: 8px; margin: 36px 0 40px; }
.bl-filter {
  display: inline-flex; align-items: center; height: 40px; padding: 0 16px; white-space: nowrap;
  border-radius: var(--radius-full); border: 1px solid var(--border-color);
  background: var(--bg-secondary); color: var(--text-secondary);
  font-size: var(--font-size-base); font-weight: 600; cursor: pointer; transition: all .15s;
}
.bl-filter:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.bl-filter.is-active { background: var(--brand-gradient); border-color: transparent; color: var(--text-inverse); box-shadow: var(--shadow-primary); }

/* featured */
.bl-featured {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; margin-bottom: 64px;
  background: var(--bg-primary); border: 1px solid var(--border-color);
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md);
  transition: box-shadow .2s, transform .2s;
}
.bl-featured:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.bl-featured__media { position: relative; min-height: 360px; }
.bl-featured__badge { position: absolute; top: 16px; left: 16px; display: inline-flex; align-items: center; height: 26px; padding: 0 12px; border-radius: var(--radius-full); background: rgba(15,23,42,0.55); color: #fff; font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; backdrop-filter: blur(6px); }
.bl-featured__body { padding: 40px; display: flex; flex-direction: column; }
.bl-featured__cat { margin-bottom: 16px; }
.bl-featured__title { font-size: var(--font-size-3xl); font-weight: 800; line-height: 1.12; letter-spacing: -0.02em; text-wrap: balance; }
.bl-featured__excerpt { margin-top: 16px; font-size: var(--font-size-lg); color: var(--text-secondary); line-height: 1.6; }
.bl-featured__foot { margin-top: auto; padding-top: 28px; display: flex; align-items: center; gap: 12px; }

/* grid */
.bl-sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 24px; }
.bl-sec-head h2 { font-size: var(--font-size-2xl); font-weight: 700; letter-spacing: -0.01em; }
.bl-sec-head a { font-size: var(--font-size-base); font-weight: 600; color: var(--brand-primary); }
.bl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* article card */
.bl-card {
  display: flex; flex-direction: column; background: var(--bg-primary);
  border: 1px solid var(--border-color); border-radius: var(--radius-lg); overflow: hidden;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}
.bl-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: color-mix(in srgb, var(--brand-primary) 30%, var(--border-color)); }
.bl-card__media { position: relative; aspect-ratio: 16/10; }
.bl-card__cat { position: absolute; top: 12px; left: 12px; }
.bl-card__body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.bl-card__title { font-size: var(--font-size-lg); font-weight: 700; line-height: 1.3; letter-spacing: -0.01em; text-wrap: balance; }
.bl-card:hover .bl-card__title { color: var(--brand-primary); }
.bl-card__excerpt { margin-top: 10px; font-size: var(--font-size-base); color: var(--text-secondary); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bl-card__foot { margin-top: auto; padding-top: 16px; }

/* meta line */
.bl-meta { display: inline-flex; align-items: center; gap: 8px; font-size: var(--font-size-sm); color: var(--text-tertiary); }
.bl-meta__dot { width: 3px; height: 3px; border-radius: var(--radius-full); background: var(--text-tertiary); }
.bl-byline { display: inline-flex; align-items: center; gap: 10px; }
.bl-avatar { width: 34px; height: 34px; border-radius: var(--radius-full); background: var(--brand-gradient); color: #fff; font-weight: 700; font-size: var(--font-size-sm); display: inline-flex; align-items: center; justify-content: center; flex: none; }
.bl-byline__name { font-size: var(--font-size-sm); font-weight: 600; color: var(--text-primary); line-height: 1.2; }
.bl-byline__sub { font-size: var(--font-size-xs); color: var(--text-tertiary); }

/* load more / pagination */
.bl-more { display: flex; justify-content: center; margin-top: 48px; }
.bl-more button {
  display: inline-flex; align-items: center; gap: 8px; height: 48px; padding: 0 28px;
  border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--bg-secondary);
  color: var(--text-primary); font-size: var(--font-size-base); font-weight: 600; cursor: pointer; transition: all .15s;
}
.bl-more button:hover { border-color: var(--brand-primary); color: var(--brand-primary); }

/* newsletter strip */
.bl-news {
  margin-top: 80px; position: relative; overflow: hidden;
  background: var(--brand-gradient); border-radius: var(--radius-lg);
  padding: 48px 48px; color: #fff; display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; align-items: center;
  box-shadow: var(--shadow-primary);
}
.bl-news::after { content: ""; position: absolute; right: -120px; top: -140px; width: 420px; height: 420px; background: radial-gradient(circle at 35% 35%, rgba(255,255,255,0.22), transparent 62%); pointer-events: none; }
.bl-news h2 { position: relative; font-size: var(--font-size-2xl); font-weight: 800; color: #fff; letter-spacing: -0.01em; }
.bl-news p { position: relative; margin-top: 10px; font-size: var(--font-size-lg); color: rgba(255,255,255,0.88); line-height: 1.5; }
.bl-news__form { position: relative; display: flex; gap: 10px; }
.bl-news__form input { flex: 1; height: 48px; padding: 0 16px; border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,0.4); background: rgba(255,255,255,0.14); color: #fff; font-size: var(--font-size-base); }
.bl-news__form input::placeholder { color: rgba(255,255,255,0.7); }
.bl-news__form button { height: 48px; padding: 0 22px; border-radius: var(--radius-md); border: 0; background: #fff; color: var(--brand-primary); font-weight: 700; font-size: var(--font-size-base); cursor: pointer; white-space: nowrap; }

/* =====================================================================
   ARTICLE PAGE
   ===================================================================== */
.bl-article-wrap { max-width: 760px; margin: 0 auto; padding: 0 24px; }
.bl-breadcrumb { display: flex; align-items: center; gap: 8px; margin: 32px 0 0; font-size: var(--font-size-sm); color: var(--text-tertiary); }
.bl-breadcrumb a:hover { color: var(--brand-primary); }
.bl-breadcrumb svg { width: 14px; height: 14px; }

.bl-article__head { padding: 28px 0 0; }
.bl-article__title { font-size: clamp(32px, 3.6vw, 46px); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; margin: 14px 0 0; text-wrap: balance; }
.bl-article__lede { margin-top: 18px; font-size: var(--font-size-xl); color: var(--text-secondary); line-height: 1.5; }
.bl-article__byrow { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin: 28px 0 24px; padding-bottom: 24px; border-bottom: 1px solid var(--border-color); }
.bl-article__share { display: flex; gap: 8px; }
.bl-share-btn { width: 40px; height: 40px; border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--bg-secondary); color: var(--text-secondary); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s; }
.bl-share-btn:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.bl-share-btn svg { width: 18px; height: 18px; }

.bl-article__hero { width: 100%; aspect-ratio: 16/8; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 8px; }
.bl-article__hero-cap { font-size: var(--font-size-xs); color: var(--text-tertiary); text-align: center; margin: 8px 0 32px; }

/* article typography — выровнено под админку: serif-тело (Georgia) + sans-serif
   заголовки, крупнее размеры. Шрифт текста статьи читается как в админке. */
.bl-prose {
    --font-body: Georgia, "PT Serif", "Times New Roman", serif;
    font-family: var(--font-body);
    font-size: 19px;
    line-height: 1.7;
}
/* Глобальное `* { font-family: Pragmatica }` (tokens.css) перебивает наследование
   на дочерних p/li/td — поэтому задаём serif-тело и обычный вес ЯВНО для текстовых
   потомков. Иначе абзацы рендерятся плотным Pragmatica-Medium («жирноватый»). */
.bl-prose p, .bl-prose li, .bl-prose blockquote, .bl-prose td, .bl-prose th {
    font-family: var(--font-body);
    font-weight: 400;
}
.bl-prose > p { line-height: 1.7; color: var(--text-primary); margin: 0 0 1.1em; }
.bl-prose > p:first-of-type::first-letter { font-size: 3.4em; font-weight: 800; line-height: 0.86; float: left; margin: 6px 12px 0 0; color: var(--brand-primary); font-family: var(--font-family); }
.bl-prose h2, .bl-prose h3, .bl-prose h4 { font-family: var(--font-family); }
.bl-prose h2 { font-size: 27px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.25; margin: 2.4em 0 .6em; scroll-margin-top: 84px; }
.bl-prose h3 { font-size: 22px; font-weight: 700; line-height: 1.25; margin: 1.8em 0 .4em; }
.bl-prose h4 { font-size: 19px; font-weight: 700; line-height: 1.3; margin: 1.6em 0 .4em; }
.bl-prose ul, .bl-prose ol { margin: 0 0 1.1em; padding-left: 1.5em; }
.bl-prose li { line-height: 1.7; margin-bottom: .4em; }
.bl-prose li::marker { color: var(--brand-primary); }
.bl-prose strong { font-weight: 700; }
.bl-prose a { color: var(--brand-primary); font-weight: 600; text-decoration: none; }
.bl-prose figure { margin: 28px 0; }
.bl-prose figure img { width: 100%; height: auto; border-radius: var(--radius-md); max-height: 520px; object-fit: contain; display: block; }
.bl-prose figure .bl-imgph { aspect-ratio: 16/9; border-radius: var(--radius-md); }
.bl-prose figcaption { font-size: var(--font-size-xs); color: var(--text-tertiary); text-align: center; margin-top: 8px; }
/* таблицы из пайплайна (.table-wrap) */
.bl-prose .table-wrap { overflow-x: auto; margin: 24px 0; border: 1px solid var(--border-color); border-radius: var(--radius-md); }
.bl-prose table { border-collapse: collapse; width: 100%; font-size: var(--font-size-base); }
.bl-prose th, .bl-prose td { padding: 10px 14px; border-bottom: 1px solid var(--border-color); text-align: left; }
.bl-prose thead th { background: var(--bg-tertiary); font-weight: 600; }

/* pull-quote */
.bl-pullquote, .bl-prose .pullquote { margin: 32px 0; padding: 4px 0 4px 24px; border-left: 4px solid var(--brand-primary); }
.bl-pullquote p, .bl-prose .pullquote p { font-size: var(--font-size-2xl); font-weight: 700; line-height: 1.3; letter-spacing: -0.01em; color: var(--text-primary); text-wrap: balance; }

/* callout */
.bl-callout, .bl-prose .callout { margin: 28px 0; padding: 20px 22px; border-radius: var(--radius-md); background: var(--info-bg); border: 1px solid color-mix(in srgb, var(--info) 22%, transparent); display: flex; gap: 14px; }
.bl-callout svg { width: 22px; height: 22px; color: var(--info); flex: none; margin-top: 2px; }
.bl-callout p, .bl-prose .callout p { margin: 0; font-size: var(--font-size-base); line-height: 1.6; color: var(--text-primary); }
.bl-callout b { font-weight: 700; }

/* ---- CTA block (один шаблон .cta, контент из seo_cta_blocks) ---- */
.cta { position: relative; overflow: hidden; margin: 44px 0; padding: 34px 38px; background: var(--brand-gradient); border-radius: 16px; border: var(--border-primary-glass); box-shadow: var(--shadow-primary), 0 18px 40px -18px rgba(24,81,172,0.55); color: var(--text-inverse); }
.cta::before { content: ""; position: absolute; right: -120px; top: -150px; width: 380px; height: 380px; background: radial-gradient(circle at 35% 35%, rgba(255,255,255,0.20), transparent 62%); pointer-events: none; }
.cta__eyebrow { position: relative; display: inline-flex; align-items: center; gap: 8px; font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.85); margin-bottom: 14px; }
.cta__dot { width: 8px; height: 8px; border-radius: var(--radius-full); background: var(--brand-accent-green); box-shadow: 0 0 0 3px rgba(48,205,108,0.25); }
.cta .cta__title, .cta h2 { position: relative; font-size: var(--font-size-2xl); line-height: 1.22; font-weight: 700; letter-spacing: -0.01em; color: #fff; margin: 0 0 10px; max-width: 30ch; text-wrap: balance; }
.cta .cta__body, .cta p { position: relative; font-size: var(--font-size-lg); line-height: 1.55; color: rgba(255,255,255,0.9); margin: 0 0 24px; max-width: 60ch; }
.cta .cta__body strong, .cta p strong { color: #fff; font-weight: 700; }
.cta__btn, .cta a { position: relative; display: inline-flex; align-items: center; gap: 9px; height: 48px; padding: 0 22px; border-radius: var(--radius-md); background: #fff; color: var(--brand-primary); font-size: var(--font-size-base); font-weight: 600; box-shadow: 0 1px 2px rgba(15,23,42,0.12); transition: transform .15s, box-shadow .15s; text-decoration: none; }
.cta__btn svg { width: 18px; height: 18px; }
.cta__btn:hover, .cta a:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -6px rgba(15,23,42,0.40); text-decoration: none; }
.cta__btn:active { transform: translateY(0); box-shadow: 0 1px 2px rgba(15,23,42,0.20); }

/* author bio */
.bl-authorbox { margin-top: 48px; padding: 24px; border: 1px solid var(--border-color); border-radius: var(--radius-lg); background: var(--bg-primary); display: flex; gap: 16px; align-items: flex-start; }
.bl-authorbox .bl-avatar { width: 52px; height: 52px; font-size: var(--font-size-lg); }
.bl-authorbox__name { font-size: var(--font-size-lg); font-weight: 700; }
.bl-authorbox__role { font-size: var(--font-size-sm); color: var(--brand-primary); font-weight: 600; margin-top: 2px; }
.bl-authorbox__bio { margin-top: 10px; font-size: var(--font-size-base); color: var(--text-secondary); line-height: 1.6; }

/* tags */
.bl-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px; }
.bl-tag { display: inline-flex; align-items: center; height: 32px; padding: 0 14px; border-radius: var(--radius-full); background: var(--bg-tertiary); color: var(--text-secondary); font-size: var(--font-size-sm); font-weight: 500; }
.bl-tag:hover { background: var(--brand-primary-light); color: var(--brand-primary); }

/* =====================================================================
   RELATED ARTICLES (SEO interlinking)
   ===================================================================== */
.bl-related { margin-top: 88px; padding-top: 56px; border-top: 1px solid var(--border-color); }
.bl-related__head { text-align: center; margin-bottom: 36px; }
.bl-related__head .bl-eyebrow { justify-content: center; }
.bl-related__head h2 { font-size: var(--font-size-2xl); font-weight: 800; letter-spacing: -0.01em; }
.bl-related__head p { margin-top: 8px; font-size: var(--font-size-base); color: var(--text-secondary); }
.bl-related .bl-grid { max-width: 1100px; margin: 0 auto; }

/* =====================================================================
   404
   ===================================================================== */
.bl-404 { max-width: 600px; margin: 0 auto; padding: 120px 24px; text-align: center; }
.bl-404__code { font-size: 96px; font-weight: 800; line-height: 1; background: var(--brand-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.bl-404 h1 { font-size: var(--font-size-2xl); margin: 16px 0 8px; }
.bl-404 p { color: var(--text-secondary); margin-bottom: 24px; }
.bl-404 a { display: inline-flex; align-items: center; height: 48px; padding: 0 24px; border-radius: var(--radius-md); background: var(--brand-gradient); color: #fff; font-weight: 700; box-shadow: var(--shadow-primary); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1023px) {
  .bl-grid { grid-template-columns: repeat(2, 1fr); }
  .bl-featured { grid-template-columns: 1fr; }
  .bl-featured__media { min-height: 240px; }
}
@media (max-width: 767px) {
  .site-header__nav, .site-header__cta { display: none; }
  .site-header__burger { display: flex; }
  body { font-size: 16px; }
  .bl-grid { grid-template-columns: 1fr; }
  .bl-news { grid-template-columns: 1fr; padding: 32px 24px; }
  .bl-news__form { flex-direction: column; }
  .bl-news__form button { width: 100%; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .bl-featured__body { padding: 28px 24px; }
  .bl-article__byrow { gap: 12px; }
  .cta { padding: 26px 22px; border-radius: 14px; }
  .cta__btn { width: 100%; justify-content: center; }
  .bl-prose > p:first-of-type::first-letter { font-size: 2.8em; }
}
@media (max-width: 480px) {
  .footer__grid { grid-template-columns: 1fr; }
  .footer__legal { flex-direction: column; gap: 6px; }
}
