/* ============================================================
   Производ 21 — Блог v2. Статические страницы (без React).
   On-brand, под чтение/вовлечение/SEO. Совместимо с CSP сайта.
   ============================================================ */
:root{
  --paper:#F2EFE8; --paper-2:#EAE6DC; --card:#FFFFFF;
  --ink:#16170F; --ink-2:#2A2B23; --mute:#6B6C62; --mute-2:#6F6F66;
  --line:#DDD8CD; --line-2:#C9C3B5; --accent:#1F2E22; --wood:#C9A66B; --blue:#3B4A6B;
  --r-md:12px; --r-lg:18px; --container:760px;
  --font:'Onest',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font);
  font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--blue);text-underline-offset:3px}
img{max-width:100%;height:auto;display:block;border-radius:var(--r-md)}
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

/* Reading progress bar */
.b-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--wood),#E4C58B);transition:width .08s linear}

/* Header */
.b-header{border-bottom:1px solid var(--line);background:rgba(242,239,232,.9);
  backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}
.b-header .wrap{max-width:1100px;display:flex;align-items:center;justify-content:space-between;gap:16px;height:64px}
.b-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.b-brand .mark{width:38px;height:38px;border-radius:9px;background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-weight:700;font-family:var(--mono);font-size:13px}
.b-brand b{font-weight:600;font-size:16px;letter-spacing:-.01em}
.b-brand span{display:block;font-family:var(--mono);font-size:10px;color:var(--mute);letter-spacing:.04em}
.b-nav{display:flex;gap:20px;font-size:14px}
.b-nav a{color:var(--ink-2);text-decoration:none}
.b-nav a:hover{color:var(--blue)}
.b-cta{background:var(--ink);color:var(--paper);text-decoration:none;padding:9px 16px;border-radius:999px;font-size:14px;font-weight:500;white-space:nowrap}
@media(max-width:760px){.b-nav{display:none}}

/* HERO band (dark blueprint, без фото; цвет акцента — var(--c) от кластера) */
.b-hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden;--c:var(--wood)}
.b-hero::before{content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--c) 1px,transparent 1px),linear-gradient(90deg,var(--c) 1px,transparent 1px);
  background-size:34px 34px;opacity:.10}
.b-hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--c);opacity:.9}
.b-hero .wrap{max-width:880px;position:relative;padding:30px 20px 38px}
.b-hero .b-watermark{position:absolute;right:8px;bottom:-44px;font-family:var(--mono);font-weight:700;
  font-size:200px;line-height:1;color:#fff;opacity:.04;pointer-events:none;user-select:none}
.b-hero .b-crumbs{color:#9a9b90;margin:0 0 16px}
.b-hero .b-crumbs a{color:#9a9b90;text-decoration:none}
.b-hero .b-crumbs a:hover{color:var(--paper)}
.b-hero .b-meta{color:#b9b9ad;margin:0 0 8px}
.b-hero .b-tag{background:color-mix(in srgb,var(--c) 18%,transparent);border:1px solid color-mix(in srgb,var(--c) 45%,transparent);color:var(--c)}
.b-hero h1{color:var(--paper);font-size:clamp(28px,5vw,44px);line-height:1.1;letter-spacing:-.02em;margin:.1em 0 .35em;font-weight:700}
.b-hero .lead{color:#d7d6cc;font-size:clamp(18px,2.4vw,22px);line-height:1.55;max-width:730px;margin:0}

/* Layout: article + TOC sidebar */
.b-layout{display:grid;grid-template-columns:minmax(0,760px) 244px;gap:52px;max-width:1100px;margin:0 auto;padding:0 20px;align-items:start}
@media(max-width:980px){.b-layout{grid-template-columns:1fr;gap:0}}

/* TOC — sticky sidebar (desktop) */
.b-toc{position:sticky;top:84px;align-self:start;font-size:13.5px;padding:6px 0}
.b-toc .ttl{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--mute);margin-bottom:12px}
.b-toc nav{display:flex;flex-direction:column;border-left:2px solid var(--line)}
.b-toc a{color:var(--mute);text-decoration:none;padding:5px 0 5px 16px;line-height:1.35;border-left:2px solid transparent;margin-left:-2px;transition:color .15s,border-color .15s}
.b-toc a:hover{color:var(--ink-2)}
.b-toc a.active{color:var(--ink);border-left-color:var(--wood);font-weight:500}
@media(max-width:980px){.b-toc{display:none}}

/* TOC — collapsible (mobile) */
.b-toc-m{display:none}
@media(max-width:980px){
  .b-toc-m{display:block;margin:20px 0 4px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card)}
  .b-toc-m summary{cursor:pointer;list-style:none;padding:14px 18px;font-weight:600;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
  .b-toc-m summary::-webkit-details-marker{display:none}
  .b-toc-m summary::after{content:'▾';float:right;color:var(--wood)}
  .b-toc-m[open] summary::after{content:'▴'}
  .b-toc-m ol{margin:0;padding:2px 22px 16px 40px;color:var(--ink-2)}
  .b-toc-m li{margin:7px 0}
  .b-toc-m a{color:var(--ink-2);text-decoration:none}
}

/* Article */
article{padding:30px 0 24px}
.b-body{font-size:18px;overflow-wrap:break-word;word-break:break-word}
.b-body>p:first-of-type::first-letter{float:left;font-size:3.1em;line-height:.82;font-weight:700;padding:6px 10px 0 0;color:var(--accent)}
h1{font-size:clamp(28px,5vw,42px);line-height:1.12;letter-spacing:-.02em;margin:.2em 0 .4em;font-weight:700}
h2{font-size:clamp(22px,3.4vw,28px);line-height:1.2;letter-spacing:-.015em;margin:1.8em 0 .5em;font-weight:600;
  padding-top:.5em;border-top:1px solid var(--line);scroll-margin-top:84px}
h3{font-size:20px;line-height:1.3;margin:1.4em 0 .4em;font-weight:600;scroll-margin-top:84px}
article p{margin:0 0 1.1em}
article ul,article ol{margin:0 0 1.2em;padding-left:1.3em}
article li{margin:.4em 0}
article .lead{font-size:21px;line-height:1.6;color:var(--ink-2)}
.b-hero .lead{color:#D9D8CE!important}
blockquote{margin:1.5em 0;padding:14px 22px;border-left:3px solid var(--wood);background:var(--paper-2);
  border-radius:0 var(--r-md) var(--r-md) 0;color:var(--ink-2)}
.b-tablewrap{margin:1.5em 0;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--r-md)}
.b-tablewrap::-webkit-scrollbar{height:8px}.b-tablewrap::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
article table{width:100%;border-collapse:collapse;font-size:15px;margin:0;background:var(--card)}
article th,article td{padding:11px 14px;text-align:left;border-top:1px solid var(--line)}
article th{background:var(--paper-2);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}
article figure{margin:1.5em 0}
article figcaption{font-size:13px;color:var(--mute);margin-top:8px;text-align:center}

/* Meta row (used in hero) */
.b-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-family:var(--mono);font-size:12px;color:var(--mute);align-items:center}
.b-tag{display:inline-block;background:var(--paper-2);border:1px solid var(--line);color:var(--ink-2);
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;border-radius:999px;text-decoration:none}
.b-crumbs{font-family:var(--mono);font-size:12px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}

/* Key takeaways / callout */
.b-callout{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 24px;margin:1.6em 0}
.b-callout h4{margin:.1em 0 .5em;font-size:15px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--mute)}

/* In-article mid CTA */
.b-midcta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:var(--paper-2);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:18px 22px;margin:2em 0}
.b-midcta .t{font-weight:600;font-size:16px}
.b-midcta p{margin:3px 0 0;font-size:13.5px;color:var(--mute)}
.b-midcta a{background:var(--ink);color:var(--paper);text-decoration:none;padding:11px 20px;border-radius:999px;font-weight:500;white-space:nowrap}

/* Share */
.b-share{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:26px 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.b-share .lbl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--mute);margin-right:2px}
.b-share a,.b-share button{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:13px;cursor:pointer;
  background:var(--card);border:1px solid var(--line);color:var(--ink-2);padding:7px 13px;border-radius:999px;text-decoration:none}
.b-share a:hover,.b-share button:hover{border-color:var(--mute);color:var(--ink)}

/* FAQ (CSS-only via <details>) */
.b-faq{margin:2.4em 0 .6em}
.b-faq details{border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);margin-bottom:10px;overflow:hidden}
.b-faq summary{cursor:pointer;list-style:none;padding:16px 20px;font-weight:500;font-size:17px;display:flex;justify-content:space-between;gap:16px}
.b-faq summary::-webkit-details-marker{display:none}
.b-faq summary::after{content:'+';color:var(--wood);font-size:22px;line-height:1}
.b-faq details[open] summary::after{content:'–'}
.b-faq details>div{padding:0 20px 18px;color:var(--ink-2)}

/* CTA block */
.b-cta-box{background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:clamp(24px,4vw,40px);margin:2.2em 0;text-align:center;position:relative;overflow:hidden}
.b-cta-box::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--wood) 1px,transparent 1px),linear-gradient(90deg,var(--wood) 1px,transparent 1px);background-size:30px 30px;opacity:.06}
.b-cta-box>*{position:relative}
.b-cta-box h3{color:var(--paper);margin:0 0 .4em;border:0;padding:0}
.b-cta-box p{color:#C8C7BD;margin:0 auto 1.2em;max-width:520px}
.b-cta-box .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.b-btn-gold{background:var(--wood);color:var(--ink);text-decoration:none;padding:13px 26px;border-radius:999px;font-weight:600}
.b-btn-ghost{background:transparent;color:var(--paper);border:1px solid rgba(242,239,232,.35);text-decoration:none;padding:13px 26px;border-radius:999px;font-weight:500}

/* Author */
.b-author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);margin-top:2em;padding-top:1.4em;font-size:14px;color:var(--mute)}
.b-author .mark{width:40px;height:40px;border-radius:9px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-weight:700;flex-shrink:0}

/* Prev / next pager */
.b-pager{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:2.2em 0 0}
.b-pager a{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;text-decoration:none;color:var(--ink);transition:border-color .15s,transform .12s}
.b-pager a:hover{border-color:var(--mute);transform:translateY(-2px)}
.b-pager .k{font-family:var(--mono);font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.b-pager b{display:block;margin-top:6px;font-weight:500;line-height:1.3;font-size:15px}
.b-pager .next{text-align:right}
@media(max-width:560px){.b-pager{grid-template-columns:1fr}.b-pager .next{text-align:left}}

/* Related */
.b-related{margin:2.5em 0}
.b-related h2{border:0;padding:0}
.b-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.b-related a{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;text-decoration:none;color:var(--ink);transition:border-color .15s,transform .12s}
.b-related a:hover{border-color:var(--mute);transform:translateY(-2px)}
.b-related .k{font-family:var(--mono);font-size:11px;color:var(--wood);text-transform:uppercase;letter-spacing:.06em}
.b-related b{display:block;margin-top:6px;font-weight:500;line-height:1.3}

/* ============ Blog index ============ */
.b-index-hero{padding:48px 0 8px}
.b-index-hero h1{margin:0 0 .2em}
.b-index-hero p{font-size:19px;color:var(--ink-2);max-width:640px}
.b-tools{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:26px 0 10px}
.b-search{flex:1;min-width:240px;display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:11px 18px}
.b-search svg{flex-shrink:0;color:var(--mute)}
.b-search input{border:0;outline:0;background:transparent;font:inherit;font-size:15px;width:100%;color:var(--ink)}
.b-count{font-family:var(--mono);font-size:12px;color:var(--mute);white-space:nowrap}
.b-filters{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 30px}
.b-chip{font-family:var(--mono);font-size:12px;border:1px solid var(--line);background:var(--card);color:var(--ink-2);padding:8px 14px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}
.b-chip:hover{border-color:var(--mute)}
.b-chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.b-empty{display:none;color:var(--mute);padding:40px 0;text-align:center}
.b-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:18px}
.b-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:border-color .15s,transform .12s}
.b-card:hover{border-color:var(--mute);transform:translateY(-2px)}
.b-card__cover{height:8px;background:var(--cc,var(--wood))}
.b-card__body{padding:20px 22px;display:flex;flex-direction:column;gap:9px}
.b-card .k{font-family:var(--mono);font-size:11px;color:var(--wood);text-transform:uppercase;letter-spacing:.06em}
.b-card h3{margin:0;font-size:18px;font-weight:600;line-height:1.3}
.b-card p{margin:0;font-size:14px;color:var(--mute);line-height:1.5}
.b-card .b-card__meta{margin-top:auto;font-family:var(--mono);font-size:11px;color:var(--mute-2);padding-top:4px}

/* Footer */
.b-footer{border-top:1px solid var(--line);margin-top:48px;background:var(--ink);color:#C8C7BD}
.b-footer .wrap{max-width:1100px;padding:36px 20px;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;font-size:14px}
.b-footer a{color:#E4E2DA}
.b-footer .reqs{font-size:12px;color:#8A8B81;line-height:1.6;max-width:340px}

@media(max-width:560px){
  .wrap{padding:0 16px}
  .b-hero .wrap{padding:24px 16px 30px}
  .b-hero .b-watermark{font-size:120px;bottom:-22px;right:0}
  .b-hero h1{font-size:clamp(25px,7vw,34px)}
  .b-layout{padding:0 16px}
  .b-body{font-size:17px}
  .b-tablewrap table{min-width:480px}
  blockquote{padding:12px 16px}
  .b-midcta{padding:16px 18px;gap:12px}
  .b-cta-box{padding:24px 18px}
  .b-share{gap:7px}
  .b-header .wrap{height:58px}
  .b-index-hero{padding:32px 0 4px}
  .b-index-hero p{font-size:17px}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.b-progress{transition:none}}
