/* === Inter, кириллица + латиница === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

/* Всегда резервировать место под полосу прокрутки — убирает прыжок шапки
   при переключении страниц с разной длиной контента */
html {
  scrollbar-gutter: stable;
}

/* ==========================================================================
   === ДИЗАЙН-СИСТЕМА: типографическая шкала и пробелы ===

   Один источник истины для размеров и отступов.
   База Material — 18px (a не стандартные 16px), поэтому 1rem = 18px.

   ШКАЛА (6 ступеней). Промежуточные значения запрещены.

   S1  Display          1.5rem (27px)   H1 на витрине, шапка карточки кейса
   S2  Heading          1.15rem (~21px) H2 секции, заголовок карточки в сетке
   S3  Body-prose       0.95rem (~17px) Основная проза кейсов, лиды
   S4  Body-ref         0.85rem (~15px) Тело справочного слоя, описания
   S5  Meta             0.72rem (~13px) Метаданные, даты, тип события
   S6  Label-caps       0.65rem (~12px) КАПС-лейблы

   LINE-HEIGHT
   --bt-lh-prose 1.65    только для длинной прозы кейсов
   --bt-lh-body  1.5     основной текст справочного слоя
   --bt-lh-tight 1.4     меты, таблицы, списки
   --bt-lh-head  1.25    заголовки

   ПРОБЕЛЫ
   Справочный слой: воздух от padding'ов и gap'ов, line-height умеренный.
   Кейсовый слой: line-height большой, max-width колонки ограничен.
   ========================================================================== */

:root {
  /* Шкала размеров (после v2-сжатия на ~12%) */
  --bt-fs-s1: 1.35rem;   /* H1 страницы */
  --bt-fs-s2: 1.05rem;   /* H2, заголовок карточки */
  --bt-fs-s3: 0.88rem;   /* Проза кейсов, лиды */
  --bt-fs-s4: 0.78rem;   /* Тело справочного слоя, мета-значения */
  --bt-fs-s5: 0.68rem;   /* Меты, даты, второстепенный текст */
  --bt-fs-s6: 0.62rem;   /* КАПС-лейблы */

  /* Line-height */
  --bt-lh-prose: 1.65;
  --bt-lh-body: 1.5;
  --bt-lh-tight: 1.4;
  --bt-lh-head: 1.25;

  /* Letter-spacing для каплс-лейблов */
  --bt-ls-caps: 0.1em;

  /* Системные отступы (справочный слой) */
  --bt-space-card-pad: 1.25rem 1.5rem;
  --bt-space-grid-gap: 1rem;
  --bt-space-section: 2.5rem;
  --bt-space-block: 1.5rem;

  /* Колонка прозы кейсов */
  --bt-prose-width: 42rem;
}

/* === Палитра, светлая тема === */
[data-md-color-scheme="default"] {
  --md-primary-fg-color:        #0A0A0A;
  --md-primary-fg-color--light: #1F1F1F;
  --md-primary-fg-color--dark:  #000000;
  --md-primary-bg-color:        #FFFFFF;

  --md-accent-fg-color:         #B8341E;
  --md-accent-fg-color--transparent: rgba(184, 52, 30, 0.1);
  --md-accent-bg-color:         #FFFFFF;

  --md-default-bg-color:        #F7F5F0;
  --md-default-fg-color:        #1F1F1F;
  --md-default-fg-color--light: #6B6B6B;
  --md-default-fg-color--lighter: #9A9893;
  --md-default-fg-color--lightest: #E5E5E0;

  --md-typeset-a-color:         #B8341E;
}

/* === Палитра, тёмная тема === */
[data-md-color-scheme="slate"] {
  --md-primary-fg-color:        #FFFFFF;
  --md-primary-fg-color--light: #E8E6E0;
  --md-primary-fg-color--dark:  #FFFFFF;
  --md-primary-bg-color:        #141413;

  --md-accent-fg-color:         #D85A30;
  --md-accent-fg-color--transparent: rgba(216, 90, 48, 0.15);

  --md-default-bg-color:        #141413;
  --md-default-fg-color:        #E8E6E0;
  --md-default-fg-color--light: #9A9893;
  --md-default-fg-color--lighter: #6B6B6B;
  --md-default-fg-color--lightest: #2A2A28;

  --md-code-bg-color:           #1C1C1B;
  --md-typeset-a-color:         #D85A30;
}

/* === Шрифты === */
:root {
  --md-text-font: "Inter", system-ui, -apple-system, sans-serif;
  --md-code-font: "JetBrains Mono", ui-monospace, monospace;
}

body, .md-typeset {
  font-family: var(--md-text-font);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* === Типографика базовая ===
   Material даёт .md-typeset { font-size: 16px }, в нашем стиле — 16px, line-height умеренный.
   Длинная проза получает увеличенный line-height только через .bt-prose / .bt-doc-prose / .bt-legal-prose. */
.md-typeset {
  font-size: 16px;
  line-height: var(--bt-lh-body);
}

.md-typeset h1 {
  font-weight: 600;
  font-size: var(--bt-fs-s1);
  line-height: var(--bt-lh-head);
  letter-spacing: -0.02em;
  margin: 0 0 1.2rem;
  color: var(--md-primary-fg-color);
}

.md-typeset h2 {
  font-weight: 600;
  font-size: var(--bt-fs-s2);
  line-height: var(--bt-lh-head);
  letter-spacing: -0.015em;
  margin: 2.5rem 0 1rem;
  color: var(--md-primary-fg-color);
}

.md-typeset h3 {
  font-weight: 500;
  font-size: var(--bt-fs-s2);
  letter-spacing: -0.01em;
  margin: 2rem 0 0.75rem;
  color: var(--md-primary-fg-color);
}

.md-typeset p {
  margin: 0 0 1rem;
}

/* Ссылки в тексте — подчёркивание поверх */
.md-typeset a {
  text-decoration: none;
  border-bottom: 1px solid var(--md-accent-fg-color);
  transition: background-color 0.15s;
}

.md-typeset a:hover {
  background-color: var(--md-accent-fg-color--transparent);
}

/* === Шапка === */
.md-header {
  background-color: var(--md-default-bg-color);
  color: var(--md-primary-fg-color);
  box-shadow: none;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.md-header__title {
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* === Вкладки навигации === */
.md-tabs {
  background-color: var(--md-default-bg-color);
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  color: var(--md-primary-fg-color);
}

.md-tabs__link {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  opacity: 0.7;
}

.md-tabs__link--active,
.md-tabs__link:hover {
  opacity: 1;
  color: var(--md-accent-fg-color);
}

/* === Таблицы === */
.md-typeset table:not([class]) {
  border: none;
  font-size: var(--bt-fs-s4);
}

.md-typeset table:not([class]) th {
  background-color: transparent;
  color: var(--md-default-fg-color--light);
  font-weight: 500;
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.md-typeset table:not([class]) td {
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

/* === Цитаты === */
.md-typeset blockquote {
  border-left: 2px solid var(--md-accent-fg-color);
  color: var(--md-default-fg-color);
  font-style: normal;
  padding-left: 1.25rem;
}

/* === Код === */
.md-typeset code {
  font-size: 0.85em;
  background-color: var(--md-default-fg-color--lightest);
  border-radius: 3px;
  padding: 0.1em 0.35em;
}

/* === Лендинг главной === */

.bt-landing {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}

.bt-landing h1,
.bt-landing h2,
.bt-landing h3 {
  font-family: var(--md-text-font);
}

/* убираем permalink-якорь только на лендинге */
.bt-landing h1 .headerlink,
.bt-landing h2 .headerlink,
.bt-landing h3 .headerlink {
  display: none;
}

/* hero */
.bt-hero {
  padding: 2.5rem 0 2rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.bt-kicker {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-accent-fg-color);
  font-weight: 500;
  margin-bottom: 1.1rem;
}

/* Прячем kicker (надтекст «РАЗДЕЛ САЙТА» и подобные) на внутренних
   страницах. На главной (.bt-hero) kicker нужен — он подписывает
   проект целиком. На внутренних он дублирует то, что и так очевидно
   из навигации, поэтому скрывается. */
.bt-person-head .bt-kicker,
.bt-index-head .bt-kicker,
.bt-inv-head .bt-kicker,
.bt-org-head .bt-kicker {
  display: none;
}

.bt-hero h1 {
  font-size: var(--bt-fs-s1);
  line-height: var(--bt-lh-head);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--md-primary-fg-color);
  margin: 0 0 1rem;
  max-width: 14em;
}

.bt-lede {
  font-size: var(--bt-fs-s3);
  line-height: var(--bt-lh-body);
  color: var(--md-default-fg-color);
  margin: 0;
}

/* строки с левой подписью */
.bt-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 2rem;
  padding: 2rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.bt-row:last-child {
  border-bottom: none;
}

/* Первый дочерний элемент любой колонки .bt-row не должен добавлять
   margin-top — иначе правая колонка с заголовком h2/h3/.bt-h2/.bt-h3
   уезжает вниз относительно левого лейбла. Без этого правила «БАЗА» и
   «КОНТАКТЫ» визуально съезжают, а «О ПРОЕКТЕ» (где справа просто <p>)
   стоит на месте. */
.bt-row > * > :first-child {
  margin-top: 0;
}

.bt-label {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  font-weight: 500;
  padding-top: 0.3rem;
}

/* === Контактный email на лендинге === */

.bt-contact-email {
  margin-top: 1rem;
  font-size: var(--bt-fs-s4);
  color: var(--md-default-fg-color--light);
}

.bt-contact-email a {
  color: var(--md-default-fg-color);
  text-decoration: none;
  border-bottom: 1px solid #B8341E;
  padding-bottom: 1px;
  transition: color 0.12s, border-bottom-color 0.12s;
}

.bt-contact-email a:hover {
  color: #B8341E;
}

/* === КЕЙСОВЫЙ СЛОЙ ===
   Длинная проза. Только здесь line-height: 1.65. */
.bt-body p {
  font-size: var(--bt-fs-s3);
  line-height: var(--bt-lh-prose);
  margin: 0 0 1em;
  color: var(--md-default-fg-color);
}

.bt-body p:last-child {
  margin-bottom: 0;
}

.bt-h2 {
  font-size: var(--bt-fs-s1);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--md-primary-fg-color);
  margin: 0 0 2rem;
}

.bt-h3 {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--md-primary-fg-color);
  margin: 0 0 0.75rem;
}

/* сетка карточек главной — 4 раздела */
.bt-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  background: transparent;
  border: none;
}

.bt-grid .bt-card,
.bt-landing .bt-card,
.md-typeset .bt-card {
  background: transparent !important;
  padding: 1rem 1.25rem;
  text-decoration: none !important;
  color: inherit !important;
  border: 1px solid var(--md-default-fg-color--lightest) !important;
  display: block;
  transition: border-color 0.15s;
}

.bt-grid .bt-card:hover,
.bt-landing .bt-card:hover,
.md-typeset .bt-card:hover {
  background: transparent !important;
  border-color: var(--md-default-fg-color--light) !important;
}

[data-md-color-scheme="slate"] .bt-grid .bt-card,
[data-md-color-scheme="slate"] .md-typeset .bt-card {
  background: transparent !important;
  border-color: rgba(255,255,255,0.1) !important;
}

[data-md-color-scheme="slate"] .bt-card:hover {
  background: transparent !important;
  border-color: rgba(255,255,255,0.18) !important;
}

.bt-card-count {
  display: none;
  font-size: var(--bt-fs-s1);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--md-primary-fg-color);
  line-height: 1;
  margin-bottom: 0.75rem;
}

.bt-card-title {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  color: var(--md-primary-fg-color);
  margin: 0 0 0.4rem;
}

.bt-card-desc {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
  color: var(--md-default-fg-color--light);
  margin: 0;
}

.bt-card-arrow {
  font-size: var(--bt-fs-s4);
  color: var(--md-accent-fg-color);
  margin-top: 0.9rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
}

.bt-card-arrow::after {
  content: "→";
  font-size: var(--bt-fs-s2);
  line-height: 1;
  font-weight: 400;
}

/* адаптив */
@media (max-width: 700px) {
  .bt-row {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 2rem 0;
  }
  .bt-hero {
    padding: 2.5rem 0;
  }
  .bt-hero h1 {
    font-size: var(--bt-fs-s2);
  }
  .bt-grid {
    grid-template-columns: 1fr;
  }
}

/* === Карточка персоналии === */

.bt-person {
  max-width: 760px;
  margin: 0 auto;
}

/* Фото-обложка */
.bt-cover {
  margin: 0 0 2rem;
  width: 100%;
  text-align: left;
}

.bt-cover-img {
  display: block;
  width: 100%;
  aspect-ratio: 21 / 9;
  background-size: cover;
  background-position: center;
  background-color: #2A2520;
  border-radius: 2px;
}

.bt-cover figcaption {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  margin-top: 0.6rem;
  text-align: left;
}

/* Шапка */
.bt-person-head {
  margin-bottom: 2rem;
}
.bt-person-head .bt-kicker {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-accent-fg-color);
  font-weight: 500;
  margin-bottom: 0.9rem;
}
.bt-person-head h1 {
  font-size: var(--bt-fs-s1);
  line-height: var(--bt-lh-head);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--md-primary-fg-color);
  margin: 0 0 0.6rem;
}
.bt-person-head h1 .headerlink { display: none; }
.bt-person-head .bt-lede {
  font-size: var(--bt-fs-s3);
  line-height: var(--bt-lh-body);
  color: var(--md-default-fg-color);
  margin: 0;
}

/* Цитата-врезка (кейсовый слой — но крупный размер сам по себе) */
.bt-pull {
  margin: 2.5rem 0;
  padding: 0 0 0 1.5rem;
  border-left: 2px solid var(--md-accent-fg-color);
  font-size: var(--bt-fs-s2);
  line-height: var(--bt-lh-tight);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--md-primary-fg-color);
}
.bt-pull cite {
  display: block;
  margin-top: 0.9rem;
  font-size: var(--bt-fs-s5);
  font-weight: 400;
  font-style: normal;
  color: var(--md-default-fg-color--light);
}

/* === КЕЙСОВЫЙ СЛОЙ === Длинная проза карточки персоналии */
.bt-prose { margin: 2rem 0; max-width: var(--bt-prose-width); }
.bt-prose p {
  font-size: var(--bt-fs-s3);
  line-height: var(--bt-lh-prose);
  color: var(--md-default-fg-color);
  margin: 0 0 1.25em;
}
.bt-prose p:last-child { margin-bottom: 0; }

/* Метка-разделитель блоков (используется и в структурах, и в связях) */
.bt-block-label {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  font-weight: 500;
  margin-bottom: 1.2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--md-default-fg-color--lightest);
}

/* Контролируемые структуры */
.bt-structures { margin: 2.5rem 0; }
.bt-struct-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--md-default-fg-color--lightest);
  border: 1px solid var(--md-default-fg-color--lightest);
}
.bt-struct {
  background: #EDEAE0;
  padding: 1.25rem 1.4rem;
}
[data-md-color-scheme="slate"] .bt-struct { background: #1A1A19; }
.bt-struct-name {
  font-size: var(--bt-fs-s3);
  font-weight: 500;
  color: var(--md-primary-fg-color);
  margin-bottom: 0.25rem;
}
.bt-struct-role {
  font-size: var(--bt-fs-s4);
  color: var(--md-default-fg-color--light);
  margin-bottom: 1rem;
}
.bt-struct-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  padding-top: 0.85rem;
  border-top: 0.5px solid var(--md-default-fg-color--lightest);
}
.bt-struct-mlabel {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  margin-bottom: 0.2rem;
}
.bt-struct-mvalue {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  color: var(--md-primary-fg-color);
  letter-spacing: -0.01em;
}

/* Связи (Mermaid контейнер) */
.bt-ties { margin: 2.5rem 0 1rem; }
.bt-ties .mermaid { background: transparent; }

/* Адаптив */
@media (max-width: 700px) {
  .bt-person-head h1 { font-size: var(--bt-fs-s2); }
  .bt-pull { font-size: var(--bt-fs-s2); }
  .bt-struct-grid { grid-template-columns: 1fr; }

  /* Скрываем mermaid-схемы на мобильном — некорректно рендерится в узком viewport,
     показывает сырой код вместо схемы. Текстовая часть карточки при этом не страдает. */
  .bt-ties,
  .bt-org-structure,
  pre.mermaid,
  .mermaid { display: none; }
}

/* === Теги (подвал карточки) === */

.bt-tags {
  margin-top: 3rem;
}

.bt-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.bt-tag {
  font-size: var(--bt-fs-s5);
  letter-spacing: 0.04em;
  padding: 4px 10px;
  background: var(--md-default-fg-color--lightest);
  color: var(--md-default-fg-color--light);
  border-radius: 2px;
  font-weight: 500;
}

[data-md-color-scheme="slate"] .bt-tag {
  background: #2A2A28;
  color: #9A9893;
}

/* === Витрина раздела === */

.bt-index {
  max-width: 1000px;
  margin: 0 auto;
  padding-bottom: 4rem;
}

.bt-index-head {
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.bt-index-head .bt-kicker {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-accent-fg-color);
  font-weight: 500;
  margin-bottom: 0.9rem;
}

.bt-index-head h1 {
  font-size: var(--bt-fs-s1);
  line-height: var(--bt-lh-head);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--md-primary-fg-color);
  margin: 0 0 0.7rem;
}

.bt-index-head h1 .headerlink { display: none; }

.bt-index-head .bt-lede {
  font-size: var(--bt-fs-s3);
  line-height: var(--bt-lh-body);
  color: var(--md-default-fg-color--light);
  margin: 0;
}

/* Сетка карточек */
.bt-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1px;
  background: var(--md-default-fg-color--lightest);
  border: 1px solid var(--md-default-fg-color--lightest);
}

/* Карточка-превью персоналии */
.bt-card-person {
  background: var(--md-default-bg-color);
  display: flex;
  flex-direction: column;
  text-decoration: none !important;
  color: inherit !important;
  border: none !important;
  transition: background 0.15s;
}

.bt-card-person:hover {
  background: #EDEAE0 !important;
}

[data-md-color-scheme="slate"] .bt-card-person:hover {
  background: #1A1A19 !important;
}

.bt-card-photo {
  width: 100%;
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  background-color: #2A2520;
}

.bt-card-info {
  padding: 1rem 1.2rem 1.2rem;
}

.bt-card-name {
  font-size: var(--bt-fs-s3);
  font-weight: 500;
  color: var(--md-primary-fg-color);
  margin-bottom: 0.25rem;
  letter-spacing: -0.005em;
}

.bt-card-role {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-tight);
  color: var(--md-default-fg-color--light);
}

/* Адаптив */
@media (max-width: 700px) {
  .bt-index-head h1 { font-size: var(--bt-fs-s2); }
}

/* === Полная ширина контента когда обе боковые панели скрыты === */

/* На страницах с hide: navigation + hide: toc вытягиваем контент */
.md-main__inner {
  margin-top: 0;
}

/* Контент-обёртка занимает всю ширину контейнера */
body[data-md-color-scheme] .md-content {
  max-width: none;
}

/* Внутри .md-content ограничиваем только статью разумной шириной */
.md-content__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1rem 1.5rem 2rem;
}

/* ==========================================================================
   === Шапка сайта: горизонтальный логотип + переключение тем ===

   v2.1 — усиленные селекторы. Material может рендерить partials/logo.html
   в разных контекстах (шапка, боковая панель), и DOM-структура может
   отличаться. Поэтому правила переключения работают по классу .bt-logo*
   глобально, без привязки к родителю.
   ========================================================================== */

/* Скрываем дублирующее название из site_name */
.md-header__title .md-header__topic {
  display: none !important;
}

/* Высота логотипа в шапке */
.md-header__button.md-logo {
  margin: 0.4rem 0.6rem 0.4rem 0.65rem;
  padding: 0;
}

.md-header__button.md-logo img.bt-logo,
.md-header__button.md-logo .bt-logo {
  height: 40px;
  width: auto;
}

@media screen and (max-width: 76.234375em) {
  .md-header__button.md-logo img.bt-logo,
  .md-header__button.md-logo .bt-logo {
    height: 32px;
  }
}

/* ==========================================================================
   Переключение версий по теме — глобальные правила (не зависят от родителя)
   ========================================================================== */

/* По умолчанию (светлая тема): прячем тёмные варианты везде */
img.bt-logo--dark,
.bt-lang--dark {
  display: none !important;
}

/* В тёмной теме: показываем тёмные, прячем светлые */
[data-md-color-scheme="slate"] img.bt-logo--light,
[data-md-color-scheme="slate"] .bt-lang--light {
  display: none !important;
}

[data-md-color-scheme="slate"] img.bt-logo--dark {
  display: inline-block !important;
}

[data-md-color-scheme="slate"] .bt-lang--dark {
  display: inline-flex !important;
}

/* span'ы внутри кнопки языка */
.md-header__option .bt-lang {
  display: inline-flex;
  align-items: center;
}

/* ==========================================================================
   === Поиск ===
   Полное сворачивание поиска в иконку (как мы пробовали) требует знания
   точной DOM-структуры, которую Material генерирует для нашей конфигурации;
   без неё правила ломают шапку. К этой задаче вернёмся, когда будет под
   рукой HTML собранной страницы из DevTools.

   А пока — минимальная косметика: убираем агрессивный серый фон поля
   поиска, чтобы оно сливалось с бежевой шапкой и не доминировало
   визуально.
   ========================================================================== */

/* Поле поиска в шапке — фон под цвет шапки, без своих рамок и теней */
.md-search__form {
  background: var(--md-default-bg-color);
  box-shadow: none;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 2px;
}

.md-search__form:hover,
.md-search__form:focus-within {
  background: var(--md-default-bg-color);
  border-color: var(--md-default-fg-color--lighter);
}

.md-search__input {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color);
  background: transparent;
}

.md-search__input::placeholder {
  color: var(--md-default-fg-color--light);
  opacity: 1;
}

/* Иконка-лупа слева в поле — приглушённая, не лезет в глаза */
.md-search__icon[for="__search"] {
  color: var(--md-default-fg-color--light);
}

/* Кнопка сброса (×) справа в поле */
.md-search__icon[type="reset"] {
  color: var(--md-default-fg-color--light);
}

/* === Витрина расследований ===
   Переведена с px на единую rem-шкалу.
   Inter везде (раньше .bt-inv-title была Georgia — убрана). */

.bt-inv-index {
  max-width: 1000px;
  margin: 0 auto;
}

.bt-inv-head {
  border-bottom: 1px solid #E5E5E0;
  padding-bottom: 18px;
  margin-bottom: 22px;
}
.bt-inv-head h1 {
  font-size: var(--bt-fs-s1);
  font-weight: 500;
  color: #0A0A0A;
  margin: 0 0 6px;
  line-height: var(--bt-lh-head);
}
.bt-inv-head .bt-kicker {
  font-size: var(--bt-fs-s6);
  font-weight: 500;
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: #B8341E;
  margin-bottom: 8px;
}
.bt-inv-head .bt-lede {
  font-size: var(--bt-fs-s4);
  color: #6B6B6B;
  margin: 0;
  line-height: var(--bt-lh-body);
}

/* Фильтры */
.bt-inv-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  margin-bottom: 22px;
}
.bt-inv-flabel {
  font-size: var(--bt-fs-s6);
  font-weight: 500;
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: #6B6B6B;
  margin-right: 4px;
}
.bt-inv-filter {
  font-size: var(--bt-fs-s5);
  padding: 5px 11px;
  border: 1px solid #D3D1C7;
  background: transparent;
  color: #444441;
  border-radius: 0;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s;
}
.bt-inv-filter:hover {
  background: #EDEAE0;
}
.bt-inv-filter.active {
  background: #1F1F1F;
  color: #FFFFFF;
  border-color: #1F1F1F;
}

/* Список карточек */
.bt-inv-list {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.bt-inv-card {
  display: block;
  border: 1px solid #E5E5E0;
  text-decoration: none !important;
  color: inherit;
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  transition: border-color 0.15s;
}
.bt-inv-card:hover {
  border-color: #1F1F1F;
}

/* Затемнение фото градиентом */
.bt-inv-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.4) 55%, rgba(0,0,0,0.7) 100%);
  z-index: 1;
}

/* Верхняя половина: код, дата, заголовок, лид */
.bt-inv-cover {
  position: relative;
  aspect-ratio: 1800 / 1010;     /* пропорция исходников — не обрезать */
  z-index: 2;
  padding: 26px 22px 22px;       /* +8px сверху — отвести надписи от кромки */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.bt-inv-cover-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.bt-inv-cover-bottom {
  display: flex;
  flex-direction: column;
  gap: 16px;                     /* было 8px — +полстрочки воздуха */
  max-width: 92%;
}
.bt-inv-code {
  font-size: var(--bt-fs-s6);
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.85);
  text-transform: uppercase;
  padding-left: 14px;
  position: relative;
}
.bt-inv-code::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1px;
  bottom: 1px;
  width: 3px;
  background: #B8341E;
}
.bt-inv-date {
  font-size: var(--bt-fs-s6);
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.04em;
}
/* Заголовок кейса на обложке — Inter, без serif */
.bt-inv-title {
  font-family: var(--md-text-font);
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  color: #FFFFFF;
  letter-spacing: -0.01em;
}
/* Лид с кирпичной полоской слева */
.bt-inv-lede {
  font-size: var(--bt-fs-s5);
  color: rgba(255,255,255,0.85);
  line-height: var(--bt-lh-body);
  margin: 0;
  padding-left: 12px;
  border-left: 2px solid #B8341E;
}

/* Нижняя плашка: теги | бар+сумма | статус */
.bt-inv-foot {
  position: relative;
  z-index: 2;
  padding: 12px 22px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
  background: rgba(247, 245, 240, 0.88);
  color: #1F1F1F;
  border-top: 1px solid rgba(255,255,255,0.5);
}
.bt-inv-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}
.bt-inv-tag {
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  padding: 2px 7px;
  background: #F1EFE8;
  border: 1px solid #E5E5E0;
}
.bt-inv-grants {
  display: flex;
  align-items: center;
  gap: 0;
}
.bt-inv-prefix {
  font-size: var(--bt-fs-s6);
  font-weight: 400;
  color: #6B6B6B;
  margin-right: 4px;
  white-space: nowrap;
}
.bt-inv-sum {
  font-size: var(--bt-fs-s5);
  font-weight: 500;
  color: #0A0A0A;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.bt-inv-sum-val {
  white-space: nowrap;
}
/* Кирпичный разделитель между суммой и статусом */
.bt-inv-sep {
  width: 1.5px;
  height: 14px;
  background: #B8341E;
  flex-shrink: 0;
  margin: 0 12px;
}
.bt-inv-status {
  font-size: var(--bt-fs-s6);
  letter-spacing: 0.04em;
  white-space: nowrap;
  font-weight: 500;
}
.bt-inv-status.published { color: #0F6E56; }
.bt-inv-status.active    { color: #C0280E; }
.bt-inv-status.draft     { color: #888780; }

/* Мобильная адаптация */
@media (max-width: 600px) {
  /* Усиленное затемнение фото — текст должен оставаться читаемым на узком экране */
  .bt-inv-card::before {
    background: linear-gradient(180deg, rgba(0,0,0,0.42) 0%, rgba(0,0,0,0.62) 55%, rgba(0,0,0,0.88) 100%);
  }

  /* На мобильном текста больше — нужен явный воздух между верхом (код/дата) и низом (заголовок/лид) */
  .bt-inv-cover {
    gap: 20px;
  }

  /* Нижняя плашка: только сумма + статус, без тегов */
  .bt-inv-foot {
    grid-template-columns: 1fr auto;
    gap: 10px 12px;
    padding: 12px 16px;          /* было 22px по бокам — на 380px экране это слишком */
  }
  .bt-inv-tags { display: none; }
  .bt-inv-grants {
    justify-content: flex-start;
    min-width: 0;
  }

  /* Заголовок чуть меньше, чем на десктопе */
  .bt-inv-title { font-size: var(--bt-fs-s3); }
}

/* === Витрина раздела событий === */

.bt-event-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin: 1.5rem 0 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  font-size: var(--bt-fs-s5);
}

.bt-filter {
  color: var(--md-default-fg-color--light);
  cursor: pointer;
  user-select: none;
  padding-bottom: 2px;
  border-bottom: 1px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.bt-filter:hover {
  color: var(--md-default-fg-color);
}

.bt-filter.active {
  color: var(--md-default-fg-color);
  border-bottom-color: #B8341E;
}

.bt-events-list {
  display: block;
}

/* Превью-строка события */
.bt-event-row {
  display: grid;
  grid-template-columns: 60px 120px 1fr 100px;
  gap: 1.5rem;
  align-items: baseline;
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  color: inherit !important;
  text-decoration: none !important;
  transition: background 0.15s ease;
}

.bt-event-row > * {
  color: inherit;
}

.bt-event-row:hover {
  background: var(--md-default-fg-color--lightest);
}

/* Дата — день / месяц / год — три строки, одного размера, моноширинно */
.bt-event-date {
  line-height: 1.25;
  font-variant-numeric: tabular-nums;
  font-family: var(--md-code-font, "JetBrains Mono", ui-monospace, monospace);
}

.bt-event-day {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: var(--md-default-fg-color);
}

.bt-event-month {
  font-size: var(--bt-fs-s4);
  font-weight: 400;
  color: var(--md-default-fg-color--light);
}

.bt-event-year {
  font-size: var(--bt-fs-s4);
  font-weight: 400;
  color: var(--md-default-fg-color--lighter);
}


/* Тип события — без капса, обычный серый текст */
.bt-event-type {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
}

/* Заголовок + summary */
.bt-event-info {
  min-width: 0;
}

.bt-event-title {
  font-size: var(--bt-fs-s3);
  font-weight: 500;
  color: var(--md-default-fg-color);
  line-height: var(--bt-lh-tight);
  margin-bottom: 2px;
}

.bt-event-summary {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  line-height: var(--bt-lh-body);
}

.bt-event-place {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  text-align: right;
}

/* Мобильная версия: убираем колонки типа и места */
@media (max-width: 768px) {
  .bt-event-row {
    grid-template-columns: 55px 1fr;
    gap: 1rem;
  }
  .bt-event-type,
  .bt-event-place {
    display: none;
  }
}

/* === Витрина дашбордов: 2 колонки (дата + контент) ========================
 * Скрываем колонки «тип» и «место» — они избыточны для дашбордов
 * (тип очевиден из раздела, место всегда «онлайн»).
 */
.bt-events-list--dashboards .bt-event-row {
  grid-template-columns: 60px 1fr;
}

@media (max-width: 768px) {
  .bt-events-list--dashboards .bt-event-row {
    grid-template-columns: 55px 1fr;
  }
}

/* === Карточка события === */

/*
 * Этот блок РАСШИРЯЕТ существующую секцию `/* === Карточка события === *\/`
 * в extra.css. Куда вставить: сразу ПОСЛЕ заголовка-комментария секции
 * (строка 1250) и ПЕРЕД определением `.bt-event-head` (строка 1252).
 *
 * Существующие стили `.bt-event-head`, `.bt-event-meta`, `.bt-meta-*`,
 * `.bt-participants`, `.bt-money`, `.bt-sources` НЕ ТРОГАТЬ — они уже
 * стилизованы и работают.
 *
 * Что добавляется:
 *   .bt-event               — корневая обёртка (группа «Объекты», 760px)
 *   .bt-block               — универсальная секция-блок с лейблом + контентом
 *   .bt-event-table         — таблицы внутри .bt-block
 *   .bt-event-row-highlight — подсветка строки выделенного получателя
 *   .bt-event-cases         — секция «Упоминается в кейсах»
 */

.bt-event {
  max-width: 760px;
  margin: 0 auto;
}

/* Универсальный блок-секция: лейбл сверху, контент под ним.
   Используется для таблиц получателей, любых других контентных блоков. */
.bt-block {
  margin: 2rem 0;
}

.bt-block > .bt-block-label {
  margin-bottom: 0.75rem;
}

/* Таблицы внутри карточки события — читаемые, с переносами,
   без схлопывания на узких колонках */
.bt-event-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--bt-fs-s5);
  table-layout: auto;
}

.bt-event-table th {
  text-align: left;
  padding: 0.5rem 0.75rem 0.5rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  font-weight: 500;
  vertical-align: bottom;
}

.bt-event-table td {
  padding: 0.6rem 0.75rem 0.6rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  vertical-align: top;
  line-height: var(--bt-lh-tight);
}

.bt-event-table tbody tr:last-child td {
  border-bottom: none;
}

/* Числовые колонки (Балл, Сумма) — без переносов, выровнены по правому краю.
   Так суммы вида «980 000» не разрываются на две строки и выстраиваются
   по разрядам. */
.bt-event-table--numeric th:nth-last-child(-n+2),
.bt-event-table--numeric td:nth-last-child(-n+2) {
  white-space: nowrap;
  text-align: right;
}

.bt-event-table th:last-child,
.bt-event-table td:last-child {
  padding-right: 0;
}

/* Подсветка строки выделенного получателя */
.bt-event-table tr.bt-event-row-highlight td {
  background: rgba(184, 52, 30, 0.05);
}

[data-md-color-scheme="slate"] .bt-event-table tr.bt-event-row-highlight td {
  background: rgba(216, 90, 48, 0.08);
}

/* Алиас .bt-event-cases — те же стили, что у .bt-sources */
.bt-event-cases {
  margin: 2rem 0;
}

.bt-event-head {
  margin: 2rem 0 1.5rem;
}

.bt-event-meta {
  background: var(--md-default-fg-color--lightest);
  padding: 1.5rem;
  margin: 2rem 0;
  border-left: 3px solid #B8341E;
}

.bt-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem 2rem;
}

.bt-meta-label {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  color: var(--md-default-fg-color--light);
  margin-bottom: 0.25rem;
}

.bt-meta-value {
  font-size: var(--bt-fs-s4);
  color: var(--md-default-fg-color);
  font-weight: 500;
}

.bt-participants {
  margin: 2rem 0;
}

.bt-participants-list {
  list-style: none;
  padding-left: 0;
  margin: 0.75rem 0 0;
}

.bt-participants-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  font-size: var(--bt-fs-s3);
}

.bt-participants-list li:last-child {
  border-bottom: none;
}

.bt-money {
  margin: 2rem 0;
  padding: 1.5rem;
  border: 1px dashed #888780;
  background: rgba(247, 245, 240, 0.5);
}

[data-md-color-scheme="slate"] .bt-money {
  background: rgba(20, 20, 19, 0.5);
}

.bt-money-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 1rem 1.5rem;
  margin-top: 0.75rem;
}

.bt-money-label {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  color: var(--md-default-fg-color--light);
  margin-bottom: 0.25rem;
}

.bt-money-value {
  font-size: var(--bt-fs-s3);
  font-weight: 600;
  color: var(--md-default-fg-color);
}

.bt-sources {
  margin: 2rem 0;
}

.bt-sources-list {
  list-style: none;
  padding-left: 0;
  margin: 0.75rem 0 0;
}

.bt-sources-list li {
  padding: 0.4rem 0;
  font-size: var(--bt-fs-s4);
  font-family: var(--md-code-font);
  color: var(--md-default-fg-color--light);
}

/* === Витрина архива === */

.bt-archive-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin: 1.5rem 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  font-size: var(--bt-fs-s5);
}

.bt-archive-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--bt-fs-s5);
}

.bt-archive-table th {
  text-align: left;
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  font-weight: 500;
  padding: 0.6rem 0.75rem 0.6rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

.bt-archive-table td {
  padding: 0.75rem 0.75rem 0.75rem 0;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  vertical-align: top;
  line-height: var(--bt-lh-tight);
}

.bt-archive-table tr:hover {
  background: var(--md-default-fg-color--lightest);
}

.bt-archive-table .bt-col-id { width: 90px; }
.bt-archive-table .bt-col-type { width: 90px; }
.bt-archive-table .bt-col-date { width: 100px; }
.bt-archive-table .bt-col-status { width: 95px; }

.bt-arc-id {
  white-space: nowrap;
  font-family: var(--md-code-font);
}

.bt-arc-id a {
  color: #B8341E;
  text-decoration: none;
  font-weight: 500;
}

.bt-arc-id a:hover {
  text-decoration: underline;
}

.bt-arc-title a {
  color: var(--md-default-fg-color);
  text-decoration: none;
}

.bt-arc-title a:hover {
  color: #B8341E;
}

.bt-arc-type,
.bt-arc-date {
  color: var(--md-default-fg-color--light);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.bt-arc-status {
  white-space: nowrap;
}

.bt-src-dead {
  color: #B8341E;
  font-size: var(--bt-fs-s5);
}

.bt-src-alive {
  color: #2A8F3C;
  font-size: var(--bt-fs-s5);
}


/* === Карточка документа === */

.bt-doc {
  max-width: 760px;
  margin: 0 auto;
}

.bt-doc-kicker {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  margin: 1rem 0 0.5rem;
}

.bt-doc-id {
  color: #B8341E;
  font-family: var(--md-code-font);
  font-weight: 500;
}

.bt-doc-title {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  margin: 0 0 0.5rem;
  color: var(--md-default-fg-color);
}

.bt-doc-lede {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
  color: var(--md-default-fg-color--light);
  margin: 0 0 1.5rem;
}

.bt-doc-meta {
  border-left: 2px solid var(--md-default-fg-color--lighter);
  padding: 0.5rem 0 0.5rem 1.25rem;
  margin: 1.5rem 0;
}

.bt-doc-meta-row {
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 0.5rem 1rem;
  padding: 0.35rem 0;
  font-size: var(--bt-fs-s5);
  align-items: baseline;
}

.bt-doc-meta-label {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  color: var(--md-default-fg-color--light);
}

.bt-doc-meta-value {
  color: var(--md-default-fg-color);
  word-break: break-word;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25rem 0.5rem;
}

.bt-doc-meta-value a {
  color: #B8341E;
  text-decoration: none;
}

.bt-doc-meta-value a:hover {
  text-decoration: underline;
}

.bt-doc-status {
  display: inline-block;
  margin-left: 0.5rem;
  font-size: var(--bt-fs-s6);
  padding: 1px 6px;
  border: 1px solid currentColor;
  letter-spacing: 0.04em;
  vertical-align: 1px;
  text-transform: lowercase;
  white-space: nowrap;
}

.bt-doc-status-dead {
  color: #B8341E;
}

.bt-doc-status-alive {
  color: #2A8F3C;
}

.bt-doc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1.5rem 0;
}

.bt-doc-btn {
  display: inline-block;
  padding: 0.35rem 0.85rem;
  font-size: var(--bt-fs-s5);
  font-weight: 500;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  border: 1px solid var(--md-default-fg-color);
  color: var(--md-default-fg-color) !important;
  transition: all 0.15s ease;
}

.bt-doc-btn:hover {
  background: var(--md-default-fg-color);
  color: var(--md-default-bg-color) !important;
  border-color: var(--md-default-fg-color);
}

.bt-doc-btn-primary {
  background: #B8341E;
  border-color: #B8341E;
  color: #FFFFFF !important;
}

.bt-doc-btn-primary:hover {
  background: #0A0A0A;
  border-color: #0A0A0A;
  color: #FFFFFF !important;
}

/* === КЕЙСОВЫЙ СЛОЙ === Длинная проза карточки документа */
.bt-doc-prose {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-prose);
  margin: 1.5rem 0;
  max-width: var(--bt-prose-width);
}

.bt-doc-prose p {
  margin: 0 0 0.75rem;
}

.bt-doc-block-label {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  margin: 1.75rem 0 0.5rem;
}

.bt-doc-rel-group {
  margin: 0.5rem 0 1rem;
  font-size: var(--bt-fs-s5);
}

.bt-doc-rel-label {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  color: var(--md-default-fg-color--light);
  margin-bottom: 0.25rem;
}

.bt-doc-rel-list {
  list-style: none;
  padding-left: 0;
  margin: 0.25rem 0 0;
}

.bt-doc-rel-list li {
  padding: 0.2rem 0;
}

.bt-doc-rel-list li a {
  color: #B8341E;
  text-decoration: none;
}

.bt-doc-rel-list li a:hover {
  text-decoration: underline;
}

.bt-doc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.5rem;
}

.bt-doc-tag {
  font-size: var(--bt-fs-s6);
  color: var(--md-default-fg-color--light);
  padding: 2px 8px;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 999px;
}


/* Мобильная адаптация */
@media (max-width: 768px) {
  .bt-doc-meta-row {
    grid-template-columns: 1fr;
    gap: 0.15rem;
  }
  .bt-doc-title {
    font-size: var(--bt-fs-s2);
  }
}

/* Мобильная адаптация архива */
@media (max-width: 768px) {
  .bt-archive-table .bt-col-type,
  .bt-archive-table .bt-arc-type,
  .bt-archive-table .bt-col-status,
  .bt-archive-table .bt-arc-status {
    display: none;
  }
}

/* === Подвал сайта === */

/* --- Material-контейнер: переводим в строку, прижимаем нашу
       .md-copyright на всю ширину. Material не вставляет
       больше ничего рядом — extra.social не используется. --- */
.md-footer-meta__inner.md-grid {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  padding: 0;
}

.md-footer-meta__inner > .md-copyright {
  flex: 1 1 100%;
  width: 100%;
  min-width: 0;
  max-width: none;
  margin: 0;
  padding: 0;
}

/* --- Наш футер --- */

.bt-footer {
  font-size: var(--bt-fs-s6);
  line-height: var(--bt-lh-body);
  color: var(--md-footer-fg-color--light);
  padding: 1.5rem 1.25rem 0;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
}

.bt-footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  width: 100%;
  padding-bottom: 1.25rem;
}

/* Зоны */
.bt-footer-copy {
  color: #B8341E !important;
  font-weight: 500;
  letter-spacing: 0.01em;
  flex-shrink: 0;
}

.bt-footer-mid {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.bt-footer-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

/* Ссылки в меню */
.bt-footer-mid a {
  color: var(--md-footer-fg-color--light) !important;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s ease, color 0.15s ease;
  padding-bottom: 1px;
  white-space: nowrap;
}

.bt-footer-mid a:hover {
  color: var(--md-footer-fg-color) !important;
  border-bottom-color: #B8341E;
}

/* Иконки соцсетей */
.bt-footer-icon {
  color: var(--md-footer-fg-color--light) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  text-decoration: none;
  border-bottom: none !important;
  transition: color 0.15s ease;
}

.bt-footer-icon:hover {
  color: #B8341E !important;
}

.bt-footer-icon svg {
  display: block;
}

/* Кирпичная линия снизу + пустое пространство под ней */
.bt-footer-line {
  height: 1px;
  background: #B8341E;
  width: 100%;
}

.bt-footer-after {
  height: 1rem;
}

/* --- Мобильная адаптация --- */
@media (max-width: 768px) {
  .bt-footer-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
  .bt-footer-mid {
    justify-content: flex-start;
    gap: 0.5rem 1rem;
  }
}


/* === Юридические страницы (privacy, terms, imprint) === */

.bt-legal {
  max-width: 760px;
  margin: 0 auto;
}

.bt-legal-kicker {
  font-size: var(--bt-fs-s6);
  letter-spacing: var(--bt-ls-caps);
  text-transform: uppercase;
  color: var(--md-default-fg-color--light);
  margin: 1rem 0 0.5rem;
}

.bt-legal-title {
  font-size: var(--bt-fs-s1);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  margin: 0 0 0.5rem;
  color: var(--md-default-fg-color);
}

.bt-legal-meta {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  margin: 0 0 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
}

/* === КЕЙСОВЫЙ СЛОЙ === Юридическая проза — длинные тексты для чтения */
.bt-legal-prose {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-prose);
  color: var(--md-default-fg-color);
}

.bt-legal-prose h2 {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  margin: 2rem 0 0.75rem;
  color: var(--md-default-fg-color);
  letter-spacing: -0.005em;
}

.bt-legal-prose h3 {
  font-size: var(--bt-fs-s3);
  font-weight: 500;
  margin: 1.25rem 0 0.5rem;
  color: var(--md-default-fg-color);
}

.bt-legal-prose p {
  margin: 0 0 0.75rem;
}

.bt-legal-prose ul {
  margin: 0.5rem 0 1rem;
  padding-left: 1.25rem;
}

.bt-legal-prose li {
  margin: 0.25rem 0;
}

.bt-legal-prose a {
  color: #B8341E;
  text-decoration: none;
}

.bt-legal-prose a:hover {
  text-decoration: underline;
}

.bt-legal-prose strong {
  font-weight: 500;
  color: var(--md-default-fg-color);
}

/* ============================================================
   === Витрина раздела организаций ===
   Лента карточек с фильтрами по типу.
   Каждая карточка показывает 4 индикатора прозрачности.

   ВАЖНО: карточка — это <div role="link">, а НЕ <a>.
   Причина — внутри карточки бывает вложенная ссылка на персону,
   и <a> внутри <a> запрещён. Поведение ссылки эмулируется
   через JS (см. шаблон index.md) + стили cursor/hover/focus здесь.
   ============================================================ */

.bt-orgs-index {
  max-width: 1000px;
  margin: 0 auto;
}

.bt-org-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 20px;
  margin: 1.5rem 0 2rem;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest, #E5E5E0);
}

.bt-org-filters .bt-filter {
  font-size: var(--bt-fs-s5);
  color: #6B6B6B;
  text-decoration: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: color 0.15s ease;
}

.bt-org-filters .bt-filter:hover {
  color: #B8341E;
}

.bt-org-filters .bt-filter-active {
  color: #0A0A0A;
  font-weight: 500;
}

[data-md-color-scheme="slate"] .bt-org-filters {
  border-bottom-color: #2A2A28;
}

[data-md-color-scheme="slate"] .bt-org-filters .bt-filter {
  color: #9A9893;
}

[data-md-color-scheme="slate"] .bt-org-filters .bt-filter-active {
  color: #FFFFFF;
}

[data-md-color-scheme="slate"] .bt-org-filters .bt-filter:hover {
  color: #D85A30;
}

/* Лента карточек */
.bt-orgs-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Превью-карточка организации.
   Свободные поля: 32px сверху, 36px по бокам, 30px снизу.

   ВАЖНО про hover/focus без дрожания:
   - Рамка border-left: 3px solid transparent существует ВСЕГДА.
   - Padding-left уменьшен на 3px ВСЕГДА — текст стоит на месте.
   - На hover меняется только ЦВЕТ рамки (transparent → красный).
   - Цвет не двигает layout, поэтому дрожания нет.

   Сбрасываем outline + border-top/right/bottom во всех состояниях,
   чтобы тема Material не накладывала свою рамку при фокусе/наведении. */
.bt-org-row {
  display: block;
  padding: 2rem 2.25rem 1.875rem calc(2.25rem - 3px);
  background: #EDEAE0;
  border: 0 solid transparent;
  border-left: 3px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  color: #1F1F1F;
  outline: none;
  transition: background-color 0.18s ease, border-left-color 0.18s ease, border-radius 0.18s ease;
}

.bt-org-row:hover,
.bt-org-row:focus,
.bt-org-row:focus-visible {
  background: #E1DDD0;
  border: 0 solid transparent;
  border-left: 3px solid #B8341E;
  border-radius: 0;
  outline: none;
  box-shadow: none;
}

[data-md-color-scheme="slate"] .bt-org-row {
  background: #1A1A19;
  color: #E8E6E0;
}

[data-md-color-scheme="slate"] .bt-org-row:hover,
[data-md-color-scheme="slate"] .bt-org-row:focus,
[data-md-color-scheme="slate"] .bt-org-row:focus-visible {
  background: #232321;
  border-left-color: #D85A30;
}

/* Шапка карточки — тип слева, статус-линия справа */
.bt-org-row-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 1.25rem;
}

.bt-org-row-type {
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
}

[data-md-color-scheme="slate"] .bt-org-row-type {
  color: #9A9893;
}

.bt-org-row-status-line {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-shrink: 0;
}

/* Бейджи статуса (общие — используются и в карточке, и в полной странице) */
.bt-status {
  font-size: var(--bt-fs-s6);
  padding: 2px 7px;
  border-radius: 3px;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  white-space: nowrap;
}

.bt-status-active {
  background: #EAF3DE;
  color: #3B6D11;
}

.bt-status-closed {
  background: #F1EFE8;
  color: #6B6B6B;
}

.bt-status-paused {
  background: #FAEEDA;
  color: #854F0B;
}

[data-md-color-scheme="slate"] .bt-status-active {
  background: rgba(99, 153, 34, 0.18);
  color: #97C459;
}

[data-md-color-scheme="slate"] .bt-status-closed {
  background: #2A2A28;
  color: #9A9893;
}

[data-md-color-scheme="slate"] .bt-status-paused {
  background: rgba(186, 117, 23, 0.18);
  color: #EF9F27;
}

/* Бейдж "≡ Имя" — отсылка к персоне для one-person организаций.
   Это НАСТОЯЩАЯ ссылка <a>, она работает независимо от клика по карточке.
   Символ "≡" взят из Inter (раньше был Georgia — убран). */
.bt-org-eq {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--bt-fs-s6);
  color: #6B6B6B !important;
  background: #F1EFE8;
  padding: 2px 8px 2px 6px;
  border-radius: 3px;
  font-weight: 500;
  text-decoration: none !important;
  white-space: nowrap;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.bt-org-eq:hover {
  background: #E5E2D6;
  color: #0A0A0A !important;
}

.bt-org-eq-sym {
  font-family: var(--md-text-font);
  font-size: var(--bt-fs-s5);
  color: #B8341E;
  font-weight: 400;
  line-height: 1;
}

[data-md-color-scheme="slate"] .bt-org-eq {
  background: #2A2A28;
  color: #9A9893 !important;
}

[data-md-color-scheme="slate"] .bt-org-eq:hover {
  background: #3A3A37;
  color: #FFFFFF !important;
}

[data-md-color-scheme="slate"] .bt-org-eq-sym {
  color: #D85A30;
}

/* Название и роль */
.bt-org-row-name {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  color: #0A0A0A;
  line-height: var(--bt-lh-head);
  margin-bottom: 0.35rem;
}

[data-md-color-scheme="slate"] .bt-org-row-name {
  color: #FFFFFF;
}

.bt-org-row-role {
  font-size: var(--bt-fs-s4);
  color: #6B6B6B;
  line-height: var(--bt-lh-tight);
  margin-bottom: 1.65rem;
}

[data-md-color-scheme="slate"] .bt-org-row-role {
  color: #9A9893;
}
/* ============================================================
   ПАТЧ ДЛЯ extra.css — стили витрины персоналий с горизонтальными плашками.
   Добавить в конец extra.css (или рядом со стилями bt-orgs).
   ============================================================ */

/* === Витрина персон — горизонтальные плашки === */

.bt-persons-index {
  max-width: 1000px;
  margin: 0 auto;
}

/* Группа фильтров — повторяет стиль .bt-org-filters */
.bt-persons-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 20px;
  margin: 1.5rem 0 2rem;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest, #E5E5E0);
}

.bt-persons-filters .bt-filter {
  font-size: var(--bt-fs-s5);
  color: #6B6B6B;
  text-decoration: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: color 0.15s ease;
}

.bt-persons-filters .bt-filter:hover {
  color: #B8341E;
}

.bt-persons-filters .bt-filter-active {
  color: #0A0A0A;
  font-weight: 500;
}

[data-md-color-scheme="slate"] .bt-persons-filters {
  border-bottom-color: #2A2A28;
}

[data-md-color-scheme="slate"] .bt-persons-filters .bt-filter {
  color: #9A9893;
}

[data-md-color-scheme="slate"] .bt-persons-filters .bt-filter-active {
  color: #FFFFFF;
}

[data-md-color-scheme="slate"] .bt-persons-filters .bt-filter:hover {
  color: #D85A30;
}

/* Лента плашек */
.bt-persons-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Плашка персоны — горизонтальная, как у org-row, но более компактная.
   Структура: фото слева (квадрат 56×56), имя+роль в центре, бейджи справа. */
.bt-person-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px 14px calc(18px - 3px);
  background: #EDEAE0;
  border: 0 solid transparent;
  border-left: 3px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  color: #1F1F1F;
  outline: none;
  transition: background-color 0.18s ease, border-left-color 0.18s ease, border-radius 0.18s ease;
}

.bt-person-row:hover,
.bt-person-row:focus,
.bt-person-row:focus-visible {
  background: #E1DDD0;
  border-left-color: #B8341E;
  border-radius: 0;
  outline: none;
  box-shadow: none;
}

[data-md-color-scheme="slate"] .bt-person-row {
  background: #1A1A19;
  color: #E8E6E0;
}

[data-md-color-scheme="slate"] .bt-person-row:hover,
[data-md-color-scheme="slate"] .bt-person-row:focus,
[data-md-color-scheme="slate"] .bt-person-row:focus-visible {
  background: #232321;
  border-left-color: #D85A30;
}

/* Фото-квадрат слева */
.bt-person-row-photo {
  width: 56px;
  height: 56px;
  border-radius: 3px;
  background-size: cover;
  background-position: center;
  background-color: #2A2520;
  flex-shrink: 0;
}

/* Центральный блок с именем и описанием — расширяется */
.bt-person-row-info {
  flex: 1;
  min-width: 0;
}

.bt-person-row-name {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: #1F1F1F;
  margin-bottom: 2px;
  letter-spacing: -0.005em;
}

[data-md-color-scheme="slate"] .bt-person-row-name {
  color: #E8E6E0;
}

.bt-person-row-role {
  font-size: var(--bt-fs-s5);
  line-height: var(--bt-lh-tight);
  color: #6B6B6B;
}

[data-md-color-scheme="slate"] .bt-person-row-role {
  color: #9A9893;
}

/* Бейджи справа — компактные пилюли */
.bt-person-row-badges {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: wrap;
  justify-content: flex-end;
  max-width: 220px;
}

.bt-badge {
  font-size: 11px;
  padding: 3px 9px;
  border-radius: 10px;
  white-space: nowrap;
  line-height: 1.4;
  letter-spacing: 0.01em;
}

/* Бейджи функциональной роли — синяя гамма */
.bt-badge-role-politician {
  background: #D6E4F4;
  color: #1F3F66;
}
.bt-badge-role-media {
  background: #E6E0F0;
  color: #3F2E66;
}
.bt-badge-role-expert {
  background: #DDE9DD;
  color: #2E5C2E;
}
.bt-badge-role-civic {
  background: #F4E3D6;
  color: #66401F;
}
.bt-badge-role-business {
  background: #F0E8D6;
  color: #66552E;
}
.bt-badge-role-private {
  background: #F4DDE3;
  color: #66304D;
}

[data-md-color-scheme="slate"] .bt-badge-role-politician { background: #2A3548; color: #B5CFEC; }
[data-md-color-scheme="slate"] .bt-badge-role-media      { background: #34293F; color: #C9BBE6; }
[data-md-color-scheme="slate"] .bt-badge-role-expert     { background: #2A3A2A; color: #B5D4B5; }
[data-md-color-scheme="slate"] .bt-badge-role-civic      { background: #3F2F22; color: #E6C9B5; }
[data-md-color-scheme="slate"] .bt-badge-role-business   { background: #3A3320; color: #E0CFB5; }
[data-md-color-scheme="slate"] .bt-badge-role-private    { background: #3F2932; color: #E6BFCC; }

/* Бейджи структурной позиции — нейтральные серые/коричневые */
.bt-badge-position-principal {
  background: #1F1F1F;
  color: #FFFFFF;
}
.bt-badge-position-nominal {
  background: #E0DCD0;
  color: #4A4A45;
  border: 1px solid #C5C0B0;
}
.bt-badge-position-witness {
  background: #EDEAE0;
  color: #6B6B6B;
  border: 1px dashed #C5C0B0;
}
.bt-badge-position-kin {
  background: #E8D4D0;
  color: #66302A;
}

[data-md-color-scheme="slate"] .bt-badge-position-principal { background: #FFFFFF; color: #1F1F1F; }
[data-md-color-scheme="slate"] .bt-badge-position-nominal   { background: #2A2A28; color: #B0AEA5; border-color: #3A3A38; }
[data-md-color-scheme="slate"] .bt-badge-position-witness   { background: #1A1A19; color: #888780; border-color: #3A3A38; }
[data-md-color-scheme="slate"] .bt-badge-position-kin       { background: #3F2925; color: #E6C2BC; }

/* Адаптив — на узких экранах бейджи переходят под имя */
@media (max-width: 700px) {
  .bt-person-row {
    flex-wrap: wrap;
  }
  .bt-person-row-info {
    flex: 1 1 calc(100% - 56px - 16px);
  }
  .bt-person-row-badges {
    flex: 1 1 100%;
    justify-content: flex-start;
    margin-top: 4px;
    margin-left: calc(56px + 16px);
    max-width: none;
  }
  .bt-person-row-photo {
    width: 48px;
    height: 48px;
  }
}

/* ============================================================
   === Полоска индикаторов прозрачности ===
   Используется и в витрине, и внутри карточки организации.
   4 сегмента: устав / отчёты / аудит / контроль.
   Цвета: зелёный=да, красный=нет, серый=неизвестно, жёлтый=частично.
   ============================================================ */

.bt-tp-bar {
  display: flex;
  gap: 2px;
  margin-top: 0.5rem;
}

.bt-tp-seg {
  flex: 1;
  height: 8px;
  border-radius: 2px;
}

.bt-tp-yes {
  background: #639922;
}

.bt-tp-no {
  background: #E24B4A;
}

.bt-tp-unk {
  background: #C8C5BC;
}

.bt-tp-part {
  background: #EF9F27;
}

[data-md-color-scheme="slate"] .bt-tp-unk {
  background: #3A3A37;
}

.bt-tp-legend {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  letter-spacing: 0.02em;
}

.bt-tp-legend span {
  flex: 1;
  text-align: center;
}

[data-md-color-scheme="slate"] .bt-tp-legend {
  color: #9A9893;
}

/* ============================================================
   === Карточка организации ===
   ============================================================ */

.bt-org {
  max-width: 760px;
  margin: 0 auto;
}

.bt-org .bt-cover {
  margin-bottom: 1.5rem;
}

.bt-org-head {
  margin-bottom: 1.6rem;
}

.bt-org-head h1 {
  margin: 0.3rem 0 0.5rem;
  font-size: var(--bt-fs-s1);
  line-height: var(--bt-lh-head);
  color: #0A0A0A;
  font-weight: 500;
}

[data-md-color-scheme="slate"] .bt-org-head h1 {
  color: #FFFFFF;
}

.bt-org-head .bt-kicker {
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
}

[data-md-color-scheme="slate"] .bt-org-head .bt-kicker {
  color: #9A9893;
}

.bt-org-head .bt-lede {
  font-size: var(--bt-fs-s3);
  color: #6B6B6B;
  line-height: var(--bt-lh-body);
  margin: 0 0 0.8rem;
}

[data-md-color-scheme="slate"] .bt-org-head .bt-lede {
  color: #9A9893;
}

.bt-org-status {
  display: flex;
  gap: 6px;
  align-items: center;
}
.bt-org-status-note {
  font-size: 0.78rem;
  color: #6B6B6B;
  line-height: 1.45;
  margin-top: 0.4rem;
  font-style: italic;
}

[data-md-color-scheme="slate"] .bt-org-status-note {
  color: #9A9893;
}

/* === Блок прозрачности внутри карточки === */

.bt-org-transparency {
  background: #EDEAE0;
  padding: 1.5rem 1.75rem 1.6rem;
  border-radius: 4px;
  margin: 1.5rem 0 2rem;
}

[data-md-color-scheme="slate"] .bt-org-transparency {
  background: #1A1A19;
}

.bt-org-transparency .bt-block-label {
  margin-bottom: 0.6rem;
}

.bt-tp-details {
  margin-top: 1rem;
  border-top: 1px solid rgba(0,0,0,0.06);
  padding-top: 0.8rem;
  display: grid;
  gap: 0.4rem;
}

[data-md-color-scheme="slate"] .bt-tp-details {
  border-top-color: rgba(255,255,255,0.06);
}

.bt-tp-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
}

.bt-tp-label {
  color: #6B6B6B;
}

[data-md-color-scheme="slate"] .bt-tp-label {
  color: #9A9893;
}

/* Значение — обычный тёмный текст, цвет только через точку-маркер слева.
   Маркер рисуется через ::before; цвет берётся из --bt-marker, заданного
   на классах-модификаторах ниже. */
.bt-tp-value-yes,
.bt-tp-value-no,
.bt-tp-value-unk,
.bt-tp-value-part {
  color: var(--md-default-fg-color);
  position: relative;
  padding-left: 1rem;
}

.bt-tp-value-yes::before,
.bt-tp-value-no::before,
.bt-tp-value-unk::before,
.bt-tp-value-part::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--bt-marker);
}

.bt-tp-value-yes  { --bt-marker: #639922; }
.bt-tp-value-no   { --bt-marker: #E24B4A; }
.bt-tp-value-unk  { --bt-marker: #C8C5BC; }
.bt-tp-value-part { --bt-marker: #EF9F27; }

/* В тёмной теме маркеры чуть осветляем, чтобы не тонули в фоне.
   "unk" в тёмной теме делаем темнее, чтобы держал ритм с другими. */
[data-md-color-scheme="slate"] .bt-tp-value-yes  { --bt-marker: #97C459; }
[data-md-color-scheme="slate"] .bt-tp-value-no   { --bt-marker: #F09595; }
[data-md-color-scheme="slate"] .bt-tp-value-unk  { --bt-marker: #6B6A65; }
[data-md-color-scheme="slate"] .bt-tp-value-part { --bt-marker: #EF9F27; }

@media (max-width: 600px) {
  .bt-tp-row {
    grid-template-columns: 1fr;
    gap: 2px;
  }
}

/* === Блок-метаданные организации === */

.bt-org-meta {
  margin: 1.5rem 0;
}

.bt-org-meta .bt-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.8rem 1.5rem;
}

.bt-org-meta .bt-meta-item {
  border-left: 2px solid #B8341E;
  padding-left: 10px;
  min-width: 0;
}

.bt-org-meta .bt-meta-label {
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin-bottom: 2px;
  /* Длинные каплс-лейблы вроде "РЕЕСТР ПРЕДПРИНИМАТЕЛЕЙ" не должны
     ломаться посреди слова */
  overflow-wrap: normal;
  word-break: keep-all;
}

.bt-org-meta .bt-meta-value {
  font-size: var(--bt-fs-s5);
  line-height: var(--bt-lh-tight);
  /* Переносим только по пробелам, без разрывов внутри слов */
  overflow-wrap: normal;
  word-break: normal;
}

[data-md-color-scheme="slate"] .bt-org-meta .bt-meta-label {
  color: #9A9893;
}

/* === Блок "Персональная организация" === */

.bt-org-single {
  margin: 1.8rem 0;
  padding: 1rem 1.2rem;
  background: #F7F5F0;
  border-left: 3px solid #B8341E;
  border-radius: 0;
}

.bt-org-single .bt-block-label {
  margin-bottom: 0.4rem;
}

.bt-org-single-body p {
  margin: 0;
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
}

[data-md-color-scheme="slate"] .bt-org-single {
  background: #141413;
  border-left-color: #D85A30;
}

/* === Блок "Структура" === */

.bt-org-structure {
  margin: 2rem 0;
}

.bt-org-structure .bt-block-label {
  margin-bottom: 0.7rem;
}

/* === Финансовый блок — общие стили === */

.bt-org-money {
  margin: 2rem 0;
}

.bt-org-money .bt-block-label {
  margin-bottom: 0.6rem;
}

.bt-org-money-note {
  font-size: var(--bt-fs-s5);
  color: #6B6B6B;
  margin: 0 0 1rem;
  font-style: italic;
  line-height: var(--bt-lh-body);
}

[data-md-color-scheme="slate"] .bt-org-money-note {
  color: #9A9893;
}

/* Режим А — таблица годовой отчётности */
.bt-money-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--bt-fs-s4);
}

.bt-money-table thead th {
  text-align: left;
  font-weight: 500;
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  padding: 0.5rem 0.8rem 0.5rem 0;
  border-bottom: 1px solid #E5E5E0;
}

.bt-money-table tbody td {
  padding: 0.55rem 0.8rem 0.55rem 0;
  border-bottom: 1px solid #F1EFE8;
  line-height: var(--bt-lh-tight);
  vertical-align: top;
}

.bt-money-table tfoot td {
  padding: 0.7rem 0.8rem 0.5rem 0;
  font-weight: 500;
  border-top: 1px solid #E5E5E0;
  font-size: var(--bt-fs-s4);
}

[data-md-color-scheme="slate"] .bt-money-table thead th {
  color: #9A9893;
  border-bottom-color: #2A2A28;
}

[data-md-color-scheme="slate"] .bt-money-table tbody td {
  border-bottom-color: #1A1A19;
}

[data-md-color-scheme="slate"] .bt-money-table tfoot td {
  border-top-color: #2A2A28;
}

/* Режим Б — список фрагментов */
.bt-money-fragments-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.bt-money-fragments-list li {
  display: grid;
  grid-template-columns: 48px 140px 1fr auto;
  gap: 10px;
  align-items: baseline;
  padding: 0.4rem 0;
  border-bottom: 1px solid #F1EFE8;
  font-size: var(--bt-fs-s5);
  line-height: var(--bt-lh-tight);
}

.bt-money-fragments-list li:last-child {
  border-bottom: none;
}

.bt-mf-year {
  font-weight: 500;
  color: #B8341E;
}

.bt-mf-amount {
  color: #0A0A0A;
}

.bt-mf-source {
  color: #1F1F1F;
}

.bt-mf-doc {
  font-size: var(--bt-fs-s5);
}

.bt-mf-context {
  grid-column: 1 / -1;
  font-size: var(--bt-fs-s6);
  color: #6B6B6B;
  font-style: italic;
  margin-top: -3px;
  margin-left: 58px;
}

[data-md-color-scheme="slate"] .bt-money-fragments-list li {
  border-bottom-color: #1A1A19;
}

[data-md-color-scheme="slate"] .bt-mf-year {
  color: #D85A30;
}

[data-md-color-scheme="slate"] .bt-mf-amount {
  color: #FFFFFF;
}

[data-md-color-scheme="slate"] .bt-mf-source {
  color: #E8E6E0;
}

[data-md-color-scheme="slate"] .bt-mf-context {
  color: #9A9893;
}

@media (max-width: 600px) {
  .bt-money-fragments-list li {
    grid-template-columns: 56px 1fr;
  }
  .bt-mf-source, .bt-mf-doc {
    grid-column: 2;
  }
  .bt-mf-context {
    margin-left: 0;
  }
}

/* Режим В — блок непрозрачности */
.bt-org-money-opaque-body {
  padding: 0.9rem 1.1rem;
  background: #F7F5F0;
  border-left: 3px solid #C8C5BC;
}

.bt-org-money-opaque-body p {
  margin: 0;
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
}

.bt-org-money-opaque-body p + p {
  margin-top: 0.6rem;
}

.bt-org-money-checked {
  font-size: var(--bt-fs-s5) !important;
  color: #6B6B6B;
  font-style: italic;
}

[data-md-color-scheme="slate"] .bt-org-money-opaque-body {
  background: #141413;
  border-left-color: #3A3A37;
}

[data-md-color-scheme="slate"] .bt-org-money-checked {
  color: #9A9893;
}

/* === Блок "Ключевые люди" и "Связанные события" === */

.bt-org-people, .bt-org-events, .bt-org-sources, .bt-org-timeline, .bt-org-cases {
  margin: 1.8rem 0;
}

.bt-org-people-list,
.bt-org-events-list,
.bt-org-cases-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.bt-org-people-list li,
.bt-org-events-list li,
.bt-org-cases-list li {
  padding: 0.35rem 0;
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
  border-bottom: 1px solid #F1EFE8;
}

.bt-org-people-list li:last-child,
.bt-org-events-list li:last-child,
.bt-org-cases-list li:last-child {
  border-bottom: none;
}

[data-md-color-scheme="slate"] .bt-org-people-list li,
[data-md-color-scheme="slate"] .bt-org-events-list li,
[data-md-color-scheme="slate"] .bt-org-cases-list li {
  border-bottom-color: #1A1A19;
}

/* === Блок хронологии реестровых событий === */

.bt-org-timeline-list {
  list-style: none;
  padding: 0 0 0 1.5rem;
  margin: 0;
  border-left: 2px solid #B8341E;
}

.bt-org-timeline-list li {
  padding: 0.4rem 0;
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-body);
  position: relative;
  list-style: none;
}

.bt-org-timeline-list li::before {
  content: none;
}

.bt-org-timeline-list li + li {
  border-top: 1px solid #F1EFE8;
}

.bt-tl-date {
  display: inline-block;
  font-weight: 500;
  color: #B8341E;
  margin-right: 0.5rem;
  font-variant-numeric: tabular-nums;
}

[data-md-color-scheme="slate"] .bt-org-timeline-list {
  border-left-color: #D85A30;
}

[data-md-color-scheme="slate"] .bt-org-timeline-list li + li {
  border-top-color: #1A1A19;
}

[data-md-color-scheme="slate"] .bt-tl-date {
  color: #D85A30;
}

/* === Блок упоминаний в кейсах === */

.bt-org-cases-list em {
  color: #888780;
  font-style: italic;
  font-size: var(--bt-fs-s4);
}

[data-md-color-scheme="slate"] .bt-org-cases-list em {
  color: #6B6A65;
}

/* === Маркер идентификатора документа в контексте ===
   Используется когда документ упоминается в тексте/блоке карточки,
   но кликабельная ссылка на него — только в финальном блоке
   "Первичные документы" внизу страницы. Это правило одного источника
   истины для документа на странице: каждый doc-XXXX даёт ровно одну
   ссылку в карточке, в блоке "Первичные документы". */

.bt-doc-ref {
  font-family: var(--md-code-font, ui-monospace, monospace);
  font-size: 0.78em;
  color: #6B6B6B;
  background: rgba(0, 0, 0, 0.04);
  padding: 1px 6px;
  border-radius: 3px;
  white-space: nowrap;
  font-weight: 400;
}

[data-md-color-scheme="slate"] .bt-doc-ref {
  color: #9A9893;
  background: rgba(255, 255, 255, 0.05);
}

/* === Дашборд КС-2026 (v2: двухрежимный) ==================================
 * Двухрежимный дашборд для страницы /dashboards/kc-2026/.
 * Использует переменные --bt-fs-s1..s6 из дизайн-системы.
 * Поддержка светлой и тёмной темы через --md-* переменные Material.
 */

#bt-kc-dashboard {
  --bt-kc-affil: #993C1D;
  --bt-kc-affil-soft: rgba(153, 60, 29, 0.10);
  --bt-kc-split: #BA7517;
  --bt-kc-indep: #888780;
  --bt-kc-text: var(--md-default-fg-color);
  --bt-kc-text-muted: var(--md-default-fg-color--light);
  --bt-kc-text-faint: var(--md-default-fg-color--lighter);
  --bt-kc-surface: var(--md-default-bg-color);
  --bt-kc-surface-2: var(--md-code-bg-color);
  --bt-kc-border: var(--md-default-fg-color--lightest);

  font-family: var(--md-text-font-family, system-ui, sans-serif);
  color: var(--bt-kc-text);
  max-width: 100%;
}

[data-md-color-scheme="slate"] #bt-kc-dashboard {
  --bt-kc-affil: #C44A24;
  --bt-kc-affil-soft: rgba(196, 74, 36, 0.18);
  --bt-kc-split: #D88A2A;
  --bt-kc-indep: #9C9A92;
}

#bt-kc-dashboard a { color: inherit; }

/* PDF-кнопка только на мобильных */
.bt-kc-pdf-mobile {
  display: none;
  margin: 0 0 1rem;
}
@media (max-width: 700px) {
  .bt-kc-pdf-mobile { display: block; }
}
.bt-kc-pdf-btn {
  display: inline-block;
  padding: 0.6rem 1rem;
  background: var(--bt-kc-affil);
  color: #fff !important;
  text-decoration: none !important;
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  border-radius: 4px;
  letter-spacing: 0.3px;
}
.bt-kc-pdf-btn:hover { opacity: 0.92; }

/* Переключатель режимов */
.bt-kc-mode-toggle {
  display: inline-flex;
  gap: 0;
  margin: 0 0 1.25rem;
  padding: 4px;
  background: var(--bt-kc-surface-2);
  border: 1px solid var(--bt-kc-border);
  border-radius: 6px;
}
.bt-kc-mode-btn {
  background: transparent;
  border: 0;
  color: var(--bt-kc-text-muted);
  font-family: inherit;
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  padding: 0.45rem 0.9rem;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.15s ease;
  letter-spacing: 0.2px;
}
.bt-kc-mode-btn:hover { color: var(--bt-kc-text); }
.bt-kc-mode-btn.is-active {
  background: var(--bt-kc-affil);
  color: #FFFFFF;
}

/* Шапка */
.bt-kc-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.5rem;
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bt-kc-border);
}
.bt-kc-header-main { flex: 1; min-width: 0; }
.bt-kc-h1 {
  font-size: var(--bt-fs-s1);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  margin: 0 0 0.5rem;
  color: var(--bt-kc-text);
}
.bt-kc-h1 .bt-kc-accent {
  color: var(--bt-kc-affil);
}
.bt-kc-sub {
  font-size: var(--bt-fs-s3);
  color: var(--bt-kc-text-muted);
  line-height: var(--bt-lh-body);
  margin: 0;
}
.bt-kc-date-badge {
  background: var(--bt-kc-affil-soft);
  border-left: 3px solid var(--bt-kc-affil);
  padding: 0.5rem 0.75rem;
  font-size: var(--bt-fs-s5);
  white-space: nowrap;
  flex-shrink: 0;
}
.bt-kc-date-label {
  color: var(--bt-kc-affil);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin-bottom: 0.15rem;
}
.bt-kc-date-value {
  font-weight: 500;
  font-size: var(--bt-fs-s4);
  color: var(--bt-kc-text);
}
@media (max-width: 700px) {
  .bt-kc-header { flex-direction: column; gap: 0.75rem; }
}

/* Метрики */
.bt-kc-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.6rem;
  margin: 0 0 1.5rem;
}
.bt-kc-stat {
  background: var(--bt-kc-surface-2);
  padding: 0.85rem 1rem;
  border-radius: 4px;
  border: 1px solid var(--bt-kc-border);
}
.bt-kc-stat-warn {
  background: var(--bt-kc-affil-soft);
  border-color: var(--bt-kc-affil);
}
.bt-kc-stat-label {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin-bottom: 0.4rem;
}
.bt-kc-stat-warn .bt-kc-stat-label { color: var(--bt-kc-affil); }
.bt-kc-stat-val {
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -1px;
  color: var(--bt-kc-text);
}
.bt-kc-stat-warn .bt-kc-stat-val { color: var(--bt-kc-affil); }
.bt-kc-stat-sub {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-text-faint);
  margin-top: 0.3rem;
}
@media (max-width: 700px) {
  .bt-kc-stats { grid-template-columns: repeat(2, 1fr); }
  .bt-kc-stat-val { font-size: 1.5rem; }
}

/* Highlight-блок (главный итог в режиме After) */
.bt-kc-highlight {
  background: var(--bt-kc-affil-soft);
  border: 1px solid var(--bt-kc-affil);
  border-radius: 6px;
  padding: 1rem 1.25rem;
  margin: 0 0 1.5rem;
}
.bt-kc-highlight-label {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-affil);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin-bottom: 0.4rem;
  font-weight: 500;
}
.bt-kc-highlight-title {
  font-size: var(--bt-fs-s3);
  color: var(--bt-kc-text);
  font-weight: 500;
  margin-bottom: 0.25rem;
  line-height: var(--bt-lh-tight);
}
.bt-kc-highlight-big {
  font-size: 2rem;
  font-weight: 500;
  color: var(--bt-kc-affil);
  letter-spacing: -1px;
  line-height: 1;
  margin: 0.4rem 0 0.55rem;
}
.bt-kc-highlight-sub {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-muted);
  line-height: var(--bt-lh-body);
}

/* Секция-обёртка */
.bt-kc-donut-section,
.bt-kc-routes-section,
.bt-kc-factions-section {
  margin: 0 0 1.5rem;
  padding: 1rem 1.1rem;
  background: var(--bt-kc-surface-2);
  border-radius: 4px;
  border: 1px solid var(--bt-kc-border);
}
.bt-kc-section-title {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin: 0 0 0.85rem;
}
.bt-kc-section-title strong {
  color: var(--bt-kc-affil);
  font-weight: 500;
}

/* Донат */
.bt-kc-donut-flex {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.bt-kc-donut-wrap { flex-shrink: 0; }
.bt-kc-donut-legend {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  font-size: var(--bt-fs-s4);
}
.bt-kc-leg-row {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  line-height: var(--bt-lh-tight);
}
.bt-kc-leg-dot {
  width: 12px;
  height: 12px;
  border-radius: 2px;
  flex-shrink: 0;
  margin-top: 4px;
}
.bt-kc-color-affil { background: var(--bt-kc-affil); }
.bt-kc-color-split { background: var(--bt-kc-split); }
.bt-kc-color-indep { background: var(--bt-kc-indep); }
.bt-kc-color-empty { background: #3A3938; }
[data-md-color-scheme="default"] .bt-kc-color-empty { background: #C8C5BD; }
.bt-kc-leg-strong { font-weight: 500; }
.bt-kc-leg-note {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-faint);
  margin: 0.5rem 0 0;
  line-height: var(--bt-lh-body);
}
@media (max-width: 700px) {
  .bt-kc-donut-flex { flex-direction: column; align-items: flex-start; gap: 1rem; }
}

/* Маршруты */
.bt-kc-routes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}
.bt-kc-route {
  background: var(--bt-kc-surface);
  border-left: 3px solid var(--bt-kc-affil);
  padding: 0.7rem 0.85rem;
  border-radius: 0 3px 3px 0;
}
.bt-kc-route-dept {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-affil);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  font-weight: 500;
  line-height: var(--bt-lh-tight);
  margin-bottom: 0.4rem;
}
.bt-kc-route-names {
  font-size: var(--bt-fs-s3);
  font-weight: 500;
  color: var(--bt-kc-text);
  margin-bottom: 0.4rem;
}
.bt-kc-route-arrow {
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-text-faint);
  margin-bottom: 0.3rem;
}
.bt-kc-route-frac {
  font-size: var(--bt-fs-s4);
  color: var(--bt-kc-text);
}
.bt-kc-route-seats {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-affil);
  font-weight: 500;
  margin-top: 0.35rem;
  letter-spacing: 0.2px;
}
@media (max-width: 700px) {
  .bt-kc-routes-grid { grid-template-columns: 1fr; }
}

/* Фракции — список + drill-down */
.bt-kc-factions-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.bt-kc-faction {
  border: 1px solid var(--bt-kc-border);
  border-radius: 4px;
  background: var(--bt-kc-surface);
  overflow: hidden;
}
.bt-kc-faction.is-open {
  border-color: var(--bt-kc-affil);
}

/* Шапка таблицы фракций (только в After) */
.bt-kc-bars-header {
  display: grid;
  grid-template-columns: 1.3fr 2fr 0.55fr 0.5fr 22px;
  align-items: center;
  gap: 0.6rem;
  font-size: var(--bt-fs-s6);
  color: var(--bt-kc-text-faint);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  padding: 0 0.85rem 0.45rem;
  border-bottom: 1px solid var(--bt-kc-border);
  margin-bottom: 0.5rem;
}
.bt-kc-bars-header > span:nth-child(3),
.bt-kc-bars-header > span:nth-child(4) {
  text-align: right;
}

.bt-kc-faction-head {
  display: grid;
  grid-template-columns: 1.4fr 2fr 0.6fr 22px;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.55rem 0.85rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  color: inherit;
  font: inherit;
}
.bt-kc-factions-list-after .bt-kc-faction-head {
  grid-template-columns: 1.3fr 2fr 0.55fr 0.5fr 22px;
}
.bt-kc-faction-head:hover {
  background: var(--bt-kc-surface-2);
}
.bt-kc-faction-label {
  font-size: var(--bt-fs-s4);
  line-height: var(--bt-lh-tight);
}
.bt-kc-faction-num {
  color: var(--bt-kc-text-faint);
  margin-right: 0.2rem;
}
.bt-kc-faction-name {
  font-weight: 500;
  color: var(--bt-kc-text);
}
.bt-kc-faction-track {
  background: var(--bt-kc-surface-2);
  height: 18px;
  border-radius: 2px;
  overflow: hidden;
}
.bt-kc-faction-fill {
  height: 100%;
  border-radius: 2px;
  transition: opacity 0.15s ease;
  display: flex;
  align-items: center;
  padding: 0 0.5rem;
  font-size: var(--bt-fs-s5);
  color: #FFFFFF;
  font-weight: 500;
}
.bt-kc-faction-fill.bt-kc-zero {
  background: rgba(186, 117, 23, 0.15);
  border: 1px dashed var(--bt-kc-split);
  color: var(--bt-kc-split);
  font-weight: 500;
  width: 100%;
  justify-content: center;
}
.bt-kc-faction-count {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-muted);
  text-align: right;
  white-space: nowrap;
}
.bt-kc-faction-percand {
  font-size: var(--bt-fs-s4);
  color: var(--bt-kc-text);
  font-variant-numeric: tabular-nums;
  text-align: right;
  font-weight: 500;
  white-space: nowrap;
}
.bt-kc-faction-chevron {
  font-size: 0.8rem;
  color: var(--bt-kc-text-faint);
  transition: transform 0.2s ease;
  justify-self: center;
}
.bt-kc-faction.is-open .bt-kc-faction-chevron {
  transform: rotate(180deg);
}

@media (max-width: 700px) {
  .bt-kc-faction-head {
    grid-template-columns: 1fr auto 16px;
    gap: 0.5rem;
    row-gap: 0.4rem;
  }
  .bt-kc-faction-track {
    grid-column: 1 / 4;
    order: 3;
  }
  .bt-kc-faction-count { order: 2; }
  .bt-kc-faction-chevron { order: 1; justify-self: end; }

  /* Бары After на мобильном */
  .bt-kc-bars-header {
    grid-template-columns: 1fr auto auto 16px;
    gap: 0.4rem;
    font-size: 0.55rem;
  }
  .bt-kc-bars-header > span:nth-child(2) {
    display: none;
  }
  .bt-kc-factions-list-after .bt-kc-faction-head {
    grid-template-columns: 1fr auto auto 16px;
    gap: 0.4rem;
  }
  .bt-kc-factions-list-after .bt-kc-faction-track {
    grid-column: 1 / 5;
    order: 3;
  }
  .bt-kc-faction-percand {
    order: 2;
    font-size: var(--bt-fs-s5);
  }
}

/* Тело раскрытой фракции */
.bt-kc-faction-body {
  border-top: 1px solid var(--bt-kc-border);
  background: var(--bt-kc-surface-2);
}
.bt-kc-cand-list {
  display: flex;
  flex-direction: column;
}
.bt-kc-cand {
  display: grid;
  grid-template-columns: 28px 32px 1fr;
  align-items: start;
  gap: 0.65rem;
  padding: 0.55rem 0.85rem;
  border-bottom: 1px solid var(--bt-kc-border);
}
.bt-kc-cand:last-child { border-bottom: 0; }
.bt-kc-cand-affil { background: var(--bt-kc-affil-soft); }
.bt-kc-cand-num {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-faint);
  font-variant-numeric: tabular-nums;
  padding-top: 0.5rem;
}
.bt-kc-cand-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bt-kc-surface);
  border: 1px solid var(--bt-kc-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--bt-fs-s5);
  font-weight: 500;
  color: var(--bt-kc-text-muted);
  letter-spacing: 0.3px;
}
.bt-kc-cand-affil .bt-kc-cand-avatar {
  background: var(--bt-kc-affil);
  color: #fff;
  border-color: var(--bt-kc-affil);
}
.bt-kc-cand-body { min-width: 0; }
.bt-kc-cand-name {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: var(--bt-kc-text);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  line-height: var(--bt-lh-tight);
}
.bt-kc-cand-meta {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-faint);
  line-height: var(--bt-lh-tight);
  margin-top: 0.15rem;
}
.bt-kc-cand-be { font-style: italic; }
.bt-kc-cand-note { color: var(--bt-kc-text-muted); }

/* Иконка аффилиации */
.bt-kc-affil-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--bt-kc-affil);
  cursor: help;
  border-radius: 50%;
  outline: none;
}
.bt-kc-affil-icon:hover,
.bt-kc-affil-icon:focus {
  background: var(--bt-kc-affil-soft);
}
.bt-kc-affil-icon[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute;
  z-index: 100;
  background: var(--bt-kc-text);
  color: var(--bt-kc-surface);
  padding: 0.4rem 0.65rem;
  font-size: var(--bt-fs-s5);
  font-weight: 400;
  font-style: normal;
  line-height: var(--bt-lh-tight);
  border-radius: 3px;
  max-width: 280px;
  white-space: normal;
  margin-top: 1.6rem;
  margin-left: -8rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18);
}

/* Всплывающая подсказка для tap (мобайл) */
.bt-kc-tooltip-bubble {
  position: absolute;
  background: #1f1f1f;
  color: #fff;
  padding: 0.5rem 0.75rem;
  border-radius: 3px;
  font-size: 0.72rem;
  line-height: var(--bt-lh-tight);
  max-width: 280px;
  z-index: 1000;
  box-shadow: 0 4px 14px rgba(0,0,0,0.25);
  pointer-events: none;
}

/* Дисклеймер (расчёт носит предварительный характер) */
.bt-kc-disclaimer {
  margin: 1rem 0 0;
  padding: 0.75rem 1rem;
  background: rgba(186, 117, 23, 0.08);
  border-left: 3px solid var(--bt-kc-split);
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-muted);
  line-height: var(--bt-lh-body);
  border-radius: 0 4px 4px 0;
}

/* Подвал */
.bt-kc-footer {
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-muted);
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bt-kc-border);
}
.bt-kc-footer strong {
  color: var(--bt-kc-affil);
  font-weight: 500;
}

/* === Нижняя кнопка скачивания PDF (видна и на десктопе, и на мобильном) ===
 * Без плашки-обёртки. Кнопка слева, подсказка под ней мелким курсивом.
 * Заменить блок .bt-kc-pdf-download в extra.css на этот.
 */

.bt-kc-pdf-download {
  margin: 1.25rem 0 0;
  padding: 0;
  background: transparent;
  border: 0;
  text-align: left;
}
.bt-kc-pdf-download .bt-kc-pdf-btn {
  display: inline-block;
  padding: 0.55rem 1rem;
  font-size: var(--bt-fs-s4);
}
.bt-kc-pdf-hint {
  margin-top: 0.5rem;
  font-size: var(--bt-fs-s5);
  color: var(--bt-kc-text-faint);
  font-style: italic;
  line-height: var(--bt-lh-body);
  max-width: 50rem;
}


/* === Дашборд внутри лонгрида ============================================= */
/* Используется в карточках расследований вместо громоздких Mermaid-схем.    */
/* Все размеры тянутся из общих --bt-fs-*; цвета — из общих переменных темы. */
/* Брейкпойнт мобильной сборки — 640px.                                      */

.bt-dash{
  margin:24px 0 32px;
  border-top:2px solid var(--md-default-fg-color);
  padding-top:20px;
}

.bt-dash-head{
  display:flex;justify-content:space-between;align-items:baseline;
  flex-wrap:wrap;gap:8px;margin-bottom:18px;
}
.bt-dash-title{
  font-size:var(--bt-fs-s2);font-weight:600;
  color:var(--md-default-fg-color);
  letter-spacing:.01em;
}
.bt-dash-asof{
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
  text-transform:uppercase;letter-spacing:.06em;
}

/* --- KPI row -------------------------------------------------------------- */

.bt-dash-kpi{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--md-default-fg-color--lightest,#E5E5E0);
  border:1px solid var(--md-default-fg-color--lightest,#E5E5E0);
  margin-bottom:22px;
}
.bt-kpi{
  background:var(--md-default-bg-color);
  padding:14px 12px;
}
.bt-kpi-value{
  font-size:1.4rem;font-weight:600;line-height:1.15;
  color:var(--md-default-fg-color);
}
.bt-kpi-label{
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
  text-transform:uppercase;letter-spacing:.06em;margin-top:6px;
}
.bt-kpi-sub{
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);margin-top:2px;
}
.bt-kpi.bt-kpi-alert .bt-kpi-value{color:var(--md-accent-fg-color,#B8341E)}

@media (max-width:640px){
  .bt-dash-kpi{grid-template-columns:repeat(2,1fr)}
}

/* --- Юрлица --------------------------------------------------------------- */

.bt-dash-entities{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.bt-ent{
  display:block;
  background:var(--md-code-bg-color,#EDEAE0);
  border:1px solid var(--md-default-fg-color--lightest,#E5E5E0);
  padding:14px;color:inherit;text-decoration:none;
  transition:border-color .15s;
}
.bt-ent:hover{
  border-color:var(--md-accent-fg-color,#B8341E);
  text-decoration:none;
}
.bt-ent-type{
  font-size:var(--bt-fs-s6);text-transform:uppercase;letter-spacing:.1em;
  color:var(--bt-color-meta,#6B6B6B);
}
.bt-ent-name{
  font-size:var(--bt-fs-s3);font-weight:600;
  color:var(--md-default-fg-color);margin:6px 0 4px;line-height:1.25;
}
.bt-ent-krs{
  font-family:var(--md-code-font-family,'JetBrains Mono',ui-monospace,monospace);
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
}
.bt-ent-foot{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:8px;margin-top:10px;flex-wrap:wrap;
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
}
.bt-ent-since{font-variant-numeric:tabular-nums}

@media (max-width:640px){
  .bt-dash-entities{grid-template-columns:1fr;gap:8px}
}

/* --- Персоналии ----------------------------------------------------------- */

.bt-dash-people{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px;
}
.bt-pers{
  display:block;padding:10px 12px;
  border-left:2px solid var(--md-default-fg-color--lightest,#E5E5E0);
  color:inherit;text-decoration:none;
  transition:border-color .15s;
}
.bt-pers:hover{
  border-left-color:var(--md-accent-fg-color,#B8341E);
  text-decoration:none;
}
.bt-pers-name{
  font-size:var(--bt-fs-s3);font-weight:500;line-height:1.3;
  color:var(--md-default-fg-color);
}
.bt-pers-role{
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
  margin-top:3px;line-height:1.4;
}
.bt-pers.bt-pers-removed{opacity:.55}
.bt-pers.bt-pers-removed .bt-pers-name::after{
  content:" · вышел";
  color:var(--bt-color-meta,#6B6B6B);font-weight:400;
  font-size:var(--bt-fs-s5);
}

@media (max-width:640px){
  .bt-dash-people{grid-template-columns:1fr}
}

/* --- Денежные потоки ------------------------------------------------------ */

.bt-dash-money{margin-bottom:4px}
.bt-mf{
  display:grid;
  grid-template-columns:1fr auto auto auto;
  align-items:center;gap:14px;
  padding:9px 0;
  border-bottom:1px solid var(--md-default-fg-color--lightest,#E5E5E0);
  font-size:var(--bt-fs-s4);
}
.bt-mf:last-child{border-bottom:none}
.bt-mf-donor{color:var(--md-default-fg-color);font-weight:500}
.bt-mf-target{color:var(--bt-color-meta,#6B6B6B)}
.bt-mf-target::before{content:"→ ";color:var(--bt-color-meta,#6B6B6B)}
.bt-mf > .bt-mf-amount{
  font-variant-numeric:tabular-nums;white-space:nowrap;
  font-family:var(--md-code-font-family,'JetBrains Mono',ui-monospace,monospace);
  font-size:var(--bt-fs-s4);color:var(--md-default-fg-color);
}
.bt-mf > .bt-mf-year{
  font-variant-numeric:tabular-nums;white-space:nowrap;
  font-size:var(--bt-fs-s5);color:var(--bt-color-meta,#6B6B6B);
}
.bt-mf.bt-mf-cut{opacity:.55}
.bt-mf.bt-mf-cut .bt-mf-donor::after{
  content:" · разрыв";
  color:var(--md-accent-fg-color,#B8341E);font-weight:600;
  font-size:var(--bt-fs-s5);
}

@media (max-width:640px){
  .bt-mf{grid-template-columns:1fr auto;gap:4px 12px}
  .bt-mf-target{grid-column:1;grid-row:2;font-size:var(--bt-fs-s5)}
  .bt-mf-year{grid-column:2;grid-row:2;font-size:var(--bt-fs-s5);text-align:right}
  .bt-mf-amount{grid-column:2;grid-row:1;text-align:right}
}

/* --- Конфликт-блок -------------------------------------------------------- */

.bt-dash-conflict{
  border-left:3px solid var(--md-accent-fg-color,#B8341E);
  padding:4px 14px;margin:10px 0 4px;
}
.bt-conf-row{
  display:grid;grid-template-columns:90px 1fr;gap:14px;
  padding:7px 0;font-size:var(--bt-fs-s4);
}
.bt-conf-row + .bt-conf-row{
  border-top:1px solid var(--md-default-fg-color--lightest,#E5E5E0);
}
.bt-conf-date{
  color:var(--bt-color-meta,#6B6B6B);
  font-variant-numeric:tabular-nums;white-space:nowrap;
}
.bt-conf-text{color:var(--md-default-fg-color)}
.bt-conf-text a{color:var(--md-default-fg-color)}

.bt-dash-conflict-tail{
  margin-top:6px;font-size:var(--bt-fs-s5);
  color:var(--md-accent-fg-color,#B8341E);font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
}

@media (max-width:640px){
  .bt-conf-row{grid-template-columns:1fr;gap:2px}
}

/* --- Подвал-легенда ------------------------------------------------------- */

.bt-dash-legend{
  margin-top:18px;font-size:var(--bt-fs-s5);
  color:var(--bt-color-meta,#6B6B6B);line-height:1.5;
}

/* === Языковой переключатель === */

/* Внешняя обёртка — наш уникальный класс. По нему таргетим order. */
.bt-lang-wrap {
  display: inline-flex;
  align-items: center;
}

/* Сама плашка с 4 языками */
.bt-lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
}

.bt-lang-link {
  color: var(--md-default-fg-color--light);
  text-decoration: none;
  font-weight: 400;
  padding-bottom: 2px;
  border-bottom: 1.5px solid transparent;
  transition: color 0.12s;
  line-height: 1.2;
  cursor: pointer;
}

.bt-lang-link:hover,
.bt-lang-link:focus {
  color: var(--md-default-fg-color);
}

.bt-lang-link.current {
  color: var(--md-default-fg-color);
  font-weight: 500;
  border-bottom-color: #B8341E;
  pointer-events: none;
  cursor: default;
}

/* Кирпичная вертикальная чёрточка справа от языков, с отступами от соседей */
.bt-lang-sep {
  width: 1.5px;
  height: 16px;
  background: #B8341E;
  display: inline-block;
  margin: 0 8px 0 22px;   /* ещё больше слева, меньше справа */
  flex-shrink: 0;
}

/* === Порядок элементов в шапке: бургер | логотип | ... | языки | тема | поиск === */

/* Языки — слева от темы, но справа от всего основного контента шапки. */
.md-header__inner > .bt-lang-wrap {
  order: 10;
  margin-left: auto;     /* отжимает плашку и всё что справа к правому краю */
}

/* Иконка темы — после языков. Material рендерит её как <form> с кнопкой. */
.md-header__inner > form[data-md-component="palette"] {
  order: 20;
}

/* Поиск — самый правый */
.md-header__inner > .md-search {
  order: 30;
}

/* === Минималистичная иконка темы === */

/* Уменьшаем размер SVG-иконки внутри кнопки палитры, чтобы не доминировала */
.md-header__inner [data-md-component="palette"] .md-icon svg {
  width: 18px;
  height: 18px;
  stroke-width: 1.5;
}

/* === Адаптив: мобильный === */
@media screen and (max-width: 76.234375em) {
  /* На мобильном Material показывает бургер слева, логотип-заголовок,
     дальше элементы шапки. Растягиваем правую группу. */

  .bt-lang-switcher {
    gap: 12px;
    font-size: 12px;
  }

  .bt-lang-sep {
    margin: 0 10px;
    height: 14px;
  }
}

/* Очень узкие экраны — ещё компактнее */
@media screen and (max-width: 480px) {
  .bt-lang-switcher {
    gap: 10px;
    font-size: 11px;
  }
  .bt-lang-sep {
    margin: 0 8px;
  }
}

/* === Порядок элементов в шапке ===
   Material располагает элементы по DOM-порядку, мы переопределяем через order.
   Целевая последовательность (слева направо):
     [логотип] ... [языки RU EN PL LT | ] [тема] [поиск]

   Используем большие положительные order для правых элементов:
   - языки: 10
   - переключатель темы (.md-header__button[for*="scheme"]): 20
   - поиск (.md-search): 30
   Логотип и заголовок имеют order: 0 — остаются слева. */
.md-header__inner > .bt-lang-switcher,
.md-header__inner > .md-header__option:has(.bt-lang-switcher) {
  order: 10;
}

.md-header__inner > [data-md-component="palette"],
.md-header__inner > .md-header__option:not(:has(.bt-lang-switcher)) {
  order: 20;
}

.md-header__inner > .md-header__source,
.md-header__inner > form,
.md-header__inner > .md-search {
  order: 30;
}

/* Адаптив: мобильный — компактнее */
@media screen and (max-width: 600px) {
  .bt-lang-switcher {
    gap: 10px;
    font-size: 11px;
  }
  .bt-lang-sep {
    height: 14px;
  }
}
/* === Pending-сущности (карточка ещё не создана) === */

.bt-pending {
  border-bottom: 1px dotted var(--md-default-fg-color--light);
  cursor: help;
}

.bt-pending:hover {
  border-bottom-color: var(--md-default-fg-color);
}

/* === Перевод названия документа в архиве === */

/* Мелкая, серая строка под оригинальным названием.
   Показывается только когда язык витрины ≠ языку оригинала
   документа и есть перевод. Логика в шаблоне archive/index.md. */
.bt-arc-title-tr {
  display: block;
  margin-top: 2px;
  font-size: 0.82em;
  color: var(--md-default-fg-color--light);
  line-height: 1.3;
  font-style: italic;
}

/* === Дашборд "Следи за деньгами" === */

.bt-ftm-page .md-content h1,
.bt-ftm-page .md-typeset h1 {
  display: none;
}

/* === Дашборд "Следи за деньгами" === */

/* Растягиваем на весь max-width контейнера, компенсируя padding */
.md-content__inner:has(.bt-ftm) {
  max-width: none !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}
.md-content__inner:has(.bt-ftm) h1 {
  display: none;
}

.bt-ftm {
  background: #0F1419;
  color: #E8E6E0;
  font-family: var(--md-text-font);
  font-size: 14px;
  margin: 1.5rem 0 0;
  border-top: 3px solid #B8341E;
}


/* Единая трёхколоночная сетка на весь дашборд */
/* Все строки: хедер, цитата, матрица+сайдбар, футер */
/* Левая зона (2fr) = кружки/текст, правая (1fr) = статы/имена */

.bt-ftm-header {
  padding: 22px 36px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: grid;
  grid-template-columns: 2fr 1fr;
  align-items: start;
  gap: 0;
}
.bt-ftm-kicker {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #B8341E;
  margin-bottom: 7px;
}
.bt-ftm-title {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-bottom: 5px;
  color: #E8E6E0;
}
.bt-ftm-sub {
  font-size: 12px;
  color: #9A9690;
  line-height: 1.5;
}
.bt-ftm-stats {
  display: flex;
  gap: 2px;
  width: 100%;
}
.bt-ftm-stat {
  background: #1C242D;
  padding: 10px 12px;
  text-align: center;
  flex: 1;
  border: 1px solid rgba(255,255,255,0.12);
}
.bt-ftm-stat-val {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #E8E6E0;
}
.bt-ftm-stat-val.bt-ftm-red { color: #B8341E; }
.bt-ftm-stat-val.bt-ftm-amber { color: #C8791A; }
.bt-ftm-stat-label {
  font-size: 9px;
  color: #9A9690;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 3px;
}

/* Цитата — на всю ширину */
.bt-ftm-quote {
  padding: 10px 36px;
  background: #161C23;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  gap: 16px;
}
.bt-ftm-quote-bar {
  width: 2px;
  align-self: stretch;
  background: #B8341E;
  flex-shrink: 0;
}
.bt-ftm-quote-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bt-ftm-quote-text {
  font-size: 14px;
  font-style: normal;
  color: #E8E6E0;
  line-height: 1.45;
  font-family: Georgia, serif;
}
.bt-ftm-quote-cite {
  font-size: 10px;
  color: #4A4845;
  letter-spacing: 0.04em;
}

/* Тело — та же сетка 2fr 1fr */
.bt-ftm-body {
  display: grid;
  grid-template-columns: 2fr 1fr;
  align-items: start;
}

/* Матрица — левые 2/3, без border-right */
.bt-ftm-matrix {
  padding: 18px 20px 24px 36px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.bt-ftm-sector {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.bt-ftm-sector-label {
  width: 100px;
  flex-shrink: 0;
  padding-top: 2px;
}
.bt-ftm-sector-name {
  font-size: 11px;
  font-weight: 600;
  color: #9A9690;
  line-height: 1.3;
}
.bt-ftm-sector-amt {
  font-size: 9px;
  color: #4A4845;
  margin-top: 1px;
}
.bt-ftm-dots {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  flex: 1;
}
.bt-ftm-dot {
  display: inline-block;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  flex-shrink: 0;
  cursor: default;
  transition: transform 0.1s;
}
.bt-ftm-dot.uninvestigated {
  background: #252D38;
  border: 1px solid #323D4A;
}
.bt-ftm-dot.draft {
  background: #7A5010;
  border: 1px solid #C8791A;
  box-shadow: 0 0 4px rgba(200,121,26,0.4);
  cursor: pointer;
}
.bt-ftm-dot.active {
  background: #C0280E;
  border: 1px solid #E03518;
  box-shadow: 0 0 5px rgba(224,53,24,0.55);
  cursor: pointer;
}
.bt-ftm-dot.published {
  background: #8A1E0E;
  border: 1px solid #B8341E;
  box-shadow: 0 0 5px rgba(184,52,30,0.5);
  cursor: pointer;
}
.bt-ftm-dot.published:hover,
.bt-ftm-dot.active:hover,
.bt-ftm-dot.draft:hover {
  transform: scale(1.5);
  z-index: 5;
}

/* Сайдбар — правая 1/3, без left border */
.bt-ftm-sidebar {
  padding: 18px 36px 18px 0;
  margin-left: -14px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.bt-ftm-sb-block {
  padding-bottom: 14px;
  padding-left: 12px;
  margin-bottom: 14px;
  border-left: 1px solid #B8341E;
}
.bt-ftm-sb-block:last-child {
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}
.bt-ftm-sb-title {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #4A4845;
  margin-bottom: 9px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.bt-ftm-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-content: flex-start;
}

.bt-ftm-sb-block > .bt-ftm-chips {
  max-height: 130px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(184,52,30,0.5) transparent;
}
.bt-ftm-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 7px;
  background: #1D252F;
  border: 1px solid rgba(255,255,255,0.06);
  font-size: 10px;
  color: #9A9690;
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s;
  border-bottom: none;
}
.bt-ftm-chip:hover {
  border-color: #B8341E;
  color: #E8E6E0;
  background-color: transparent;
}
.bt-ftm-chip.published { border-color: rgba(184,52,30,0.4); color: #E8E6E0; }
.bt-ftm-chip.active    { border-color: rgba(224,53,24,0.4); color: #E8E6E0; }
.bt-ftm-chip.draft     { border-color: rgba(200,121,26,0.4); color: #E8E6E0; }
.bt-ftm-chip-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}
.bt-ftm-chip-dot.published  { background: #B8341E; }
.bt-ftm-chip-dot.active     { background: #E03518; }
.bt-ftm-chip-dot.draft      { background: #C8791A; }

/* Футер — та же сетка 2fr 1fr */
.bt-ftm-footer {
  padding: 10px 36px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: grid;
  grid-template-columns: 2fr 1fr;
  align-items: center;
}
.bt-ftm-legend {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
}
.bt-ftm-leg-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: #9A9690;
}
.bt-ftm-leg-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}
.bt-ftm-leg-dot.uninvestigated { background: #252D38; border: 1px solid #323D4A; }
.bt-ftm-leg-dot.draft          { background: #7A5010; border: 1px solid #C8791A; }
.bt-ftm-leg-dot.active         { background: #C0280E; border: 1px solid #E03518; }
.bt-ftm-leg-dot.published      { background: #8A1E0E; border: 1px solid #B8341E; }
.bt-ftm-leg-sep {
  display: inline-block;
  width: 1px;
  height: 10px;
  background: rgba(255,255,255,0.06);
  margin: 0 10px;
}
.bt-ftm-footer-note {
  font-size: 10px;
  color: #4A4845;
  padding-left: 0;
}

/* Tooltip */
.bt-ftm-tooltip {
  position: fixed;
  background: #1A222C;
  border: 1px solid rgba(255,255,255,0.1);
  border-left: 3px solid #B8341E;
  padding: 10px 14px;
  font-size: 12px;
  line-height: 1.6;
  max-width: 240px;
  pointer-events: none;
  z-index: 200;
  display: none;
  box-shadow: 0 8px 28px rgba(0,0,0,0.6);
  color: #E8E6E0;
}
.bt-ftm-tooltip.show { display: block; }
.bt-ftm-tt-status { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 4px; }
.bt-ftm-tt-status.confirmed    { color: #B8341E; }
.bt-ftm-tt-status.investigating { color: #C8791A; }
.bt-ftm-tt-title  { font-weight: 600; color: #E8E6E0; margin-bottom: 3px; }
.bt-ftm-tt-sub    { color: #9A9690; font-size: 11px; }
.bt-ftm-tt-link   { color: #B8341E; font-size: 10px; margin-top: 6px; }

/* === FTM: светлая тема === */
[data-md-color-scheme="default"] .bt-ftm {
  background: #F0EDE6;
  color: #1F1F1F;
  border-top: 3px solid #B8341E;
}
[data-md-color-scheme="default"] .bt-ftm-header {
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
[data-md-color-scheme="default"] .bt-ftm-title {
  color: #0A0A0A;
}
[data-md-color-scheme="default"] .bt-ftm-sub {
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-stat {
  background: #E5E2D8;
  border: 1px solid rgba(0,0,0,0.1);
}
[data-md-color-scheme="default"] .bt-ftm-stat-val {
  color: #0A0A0A;
}
[data-md-color-scheme="default"] .bt-ftm-stat-label {
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-quote {
  background: #E8E5DC;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
[data-md-color-scheme="default"] .bt-ftm-quote-text {
  color: #1F1F1F;
}
[data-md-color-scheme="default"] .bt-ftm-quote-cite {
  color: #9A9690;
}
[data-md-color-scheme="default"] .bt-ftm-sector-name {
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-sector-amt {
  color: #9A9690;
}
[data-md-color-scheme="default"] .bt-ftm-dot.uninvestigated {
  background: #C8C5BD;
  border: 1px solid #B0ADA6;
}
[data-md-color-scheme="default"] .bt-ftm-sb-block {
  border-left: 1px solid #B8341E;
}
[data-md-color-scheme="default"] .bt-ftm-sb-title {
  color: #9A9690;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
[data-md-color-scheme="default"] .bt-ftm-chip {
  background: #E5E2D8;
  border: 1px solid rgba(0,0,0,0.1);
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-chip:hover {
  border-color: #B8341E;
  color: #1F1F1F;
  background-color: transparent;
}
[data-md-color-scheme="default"] .bt-ftm-chip.published { border-color: rgba(184,52,30,0.5); color: #1F1F1F; }
[data-md-color-scheme="default"] .bt-ftm-chip.active    { border-color: rgba(224,53,24,0.5); color: #1F1F1F; }
[data-md-color-scheme="default"] .bt-ftm-chip.draft     { border-color: rgba(200,121,26,0.5); color: #1F1F1F; }
[data-md-color-scheme="default"] .bt-ftm-footer {
  border-top: 1px solid rgba(0,0,0,0.08);
}
[data-md-color-scheme="default"] .bt-ftm-leg-item {
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-dot.draft {
  background: #C8791A;
  border: 1px solid #E09020;
  box-shadow: 0 0 4px rgba(200,121,26,0.35);
}
[data-md-color-scheme="default"] .bt-ftm-leg-dot.draft {
  background: #C8791A;
  border: 1px solid #E09020;
}
[data-md-color-scheme="default"] .bt-ftm-chip-dot.draft {
  background: #C8791A;
}
[data-md-color-scheme="default"] .bt-ftm-leg-dot.uninvestigated {
  background: #C8C5BD;
  border: 1px solid #B0ADA6;
}
[data-md-color-scheme="default"] .bt-ftm-leg-sep {
  background: rgba(0,0,0,0.1);
}
[data-md-color-scheme="default"] .bt-ftm-footer-note {
  color: #9A9690;
}
[data-md-color-scheme="default"] .bt-ftm-tooltip {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.12);
  border-left: 3px solid #B8341E;
  color: #1F1F1F;
  box-shadow: 0 8px 28px rgba(0,0,0,0.15);
}
[data-md-color-scheme="default"] .bt-ftm-tt-title {
  color: #0A0A0A;
}
[data-md-color-scheme="default"] .bt-ftm-tt-sub {
  color: #6B6B6B;
}
[data-md-color-scheme="default"] .bt-ftm-sidebar {
  border-left: none;
}

/* Mobile */
@media (max-width: 768px) {
  .bt-ftm-header { grid-template-columns: 1fr; padding: 16px 18px 14px; }
  .bt-ftm-stats  { flex-wrap: wrap; }
  .bt-ftm-stat   { min-width: 70px; }
  .bt-ftm-quote  { padding: 10px 18px; }
  .bt-ftm-body   { grid-template-columns: 1fr; }
  .bt-ftm-matrix { padding: 14px 18px; }
  .bt-ftm-sidebar { padding: 14px 18px; border-left: none; border-top: 1px solid rgba(255,255,255,0.06); }
  .bt-ftm-footer  { grid-template-columns: 1fr; padding: 10px 18px; gap: 8px; }
  .bt-ftm-footer-note { padding-left: 0; border-left: none; }
  .bt-ftm-sector-label { width: 84px; }
}

/* === Баннер "Следуй за деньгами" на главной === */

.bt-ftm-lb {
  border-left: 3px solid #B8341E;
  padding: 14px 18px;
  background: var(--md-default-fg-color--lightest);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: end;
}
.bt-ftm-lb-title {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: var(--md-default-fg-color);
  line-height: var(--bt-lh-tight);
  margin-bottom: 4px;
}
.bt-ftm-lb-tagline {
  font-size: var(--bt-fs-s4);
  color: var(--md-default-fg-color--light);
}
.bt-ftm-lb-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 7px;
}
.bt-ftm-lb-dots {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  width: 90px;
  justify-content: flex-end;
}
.bt-ftm-lb-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--md-default-fg-color--lightest);
  border: 1px solid var(--md-default-fg-color--lighter);
}
.bt-ftm-lb-dot.published {
  background: #B8341E;
  border-color: #B8341E;
}
.bt-ftm-lb-dot.active {
  background: #E03518;
  border-color: #E03518;
}
.bt-ftm-lb-dot.draft {
  background: #C8791A;
  border-color: #C8791A;
}
.bt-ftm-lb-link {
  font-size: var(--bt-fs-s5);
  color: #B8341E !important;
  border-bottom: 1px solid #B8341E !important;
  text-decoration: none !important;
  white-space: nowrap;
}

/* === Баннер "Следуй за деньгами" на витрине расследований === */

.bt-ftm-inv-banner {
  background: #1A1A19;
  border-top: 2px solid #B8341E;
  padding: 22px 20px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: end;
  margin-bottom: 1.5rem;
}
.bt-ftm-ib-kicker {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  color: #B8341E;
  font-weight: 500;
  margin-bottom: 6px;
}
.bt-ftm-ib-title {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: #E8E6E0;
  line-height: var(--bt-lh-tight);
  margin-bottom: 4px;
}
.bt-ftm-ib-tagline {
  font-size: var(--bt-fs-s4);
  color: #9A9690;
}
.bt-ftm-ib-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 7px;
}
.bt-ftm-ib-dots {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  width: 100px;
  justify-content: flex-end;
}
.bt-ftm-ib-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #252D38;
  border: 0.5px solid #323D4A;
}
.bt-ftm-ib-dot.published {
  background: #8A1E0E;
  border-color: #B8341E;
}
.bt-ftm-ib-dot.active {
  background: #C0280E;
  border-color: #E03518;
}
.bt-ftm-ib-dot.draft {
  background: #7A5010;
  border-color: #C8791A;
}
.bt-ftm-ib-link {
  font-size: var(--bt-fs-s5);
  color: #B8341E !important;
  border-bottom: 0.5px solid #B8341E !important;
  text-decoration: none !important;
  white-space: nowrap;
}

/* === Таблица финансов bt-mf-table === */
.bt-mf-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--bt-fs-s5);
  margin: 1rem 0;
}
.bt-mf-table th {
  font-size: var(--bt-fs-s6);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--md-default-fg-color--light);
  padding: 6px 8px;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  text-align: left;
  font-weight: 400;
}
.bt-mf-table td {
  padding: 8px;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  vertical-align: top;
}
.bt-mf-table tr:last-child td { border-bottom: 0; }
.bt-mf-table .bt-mf-year {
  color: #B8341E;
  font-weight: 500;
  white-space: nowrap;
  font-size: var(--bt-fs-s5);
}
.bt-mf-table .bt-mf-amount {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  font-weight: 400;
  font-size: var(--bt-fs-s5);
}
.bt-mf-table .bt-mf-amount--na {
  color: var(--md-default-fg-color--light);
  font-style: italic;
}
.bt-mf-table .bt-mf-transp {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.bt-mf-bar-wrap { flex-shrink: 0; }
.bt-mf-bar-track {
  width: 52px;
  height: 4px;
  background: var(--md-default-fg-color--lightest);
  border-radius: 2px;
  overflow: hidden;
}
.bt-mf-bar-fill {
  height: 100%;
  background: #B8341E;
  border-radius: 2px;
}
.bt-mf-pct {
  font-size: var(--bt-fs-s6);
  color: var(--md-default-fg-color--light);
  min-width: 36px;
}
.bt-mf-table .bt-mf-note {
  font-size: var(--bt-fs-s5);
  color: var(--md-default-fg-color--light);
  line-height: 1.5;
}
.bt-mf-table .bt-mf-doc {
  font-size: var(--bt-fs-s6);
  white-space: nowrap;
  color: var(--md-default-fg-color--light);
}

@media (max-width: 600px) {
  .bt-mf-table thead { display: none; }
  .bt-mf-table, .bt-mf-table tbody, .bt-mf-table tr, .bt-mf-table td { display: block; width: 100%; }
  .bt-mf-table tr { padding: 10px 0; border-bottom: 1px solid var(--md-default-fg-color--lightest); }
  .bt-mf-table tr:last-child { border-bottom: 0; }
  .bt-mf-table td { padding: 2px 0; border: none; text-align: left !important; }
  .bt-mf-table .bt-mf-year { display: inline; margin-right: 8px; }
  .bt-mf-table .bt-mf-amount { display: inline; }
  .bt-mf-table .bt-mf-transp { margin: 4px 0; }
}

/* === Дашборд WP143 (CASE Working Paper №143/2025) ========================
 * Зеркало секции «Дашборд КС-2026» по архитектуре.
 * Префикс классов: bt-wp143-*
 * Все размеры — из общей дизайн-системы (--bt-fs-s1..s6, --bt-lh-*, --bt-ls-caps).
 * Цвета — через --md-* переменные Material (адаптация под светлую/тёмную тему).
 *
 * Технический долг: при появлении третьего дашборда выделить общий слой
 * bt-dash-* (header, stats, section, callout, marker, chain) и мигрировать
 * на него и KC-2026, и WP143. См. manual_addition.md.
 */

#bt-wp143-dashboard {
  --bt-wp143-accent:       #993C1D;
  --bt-wp143-accent-soft:  rgba(153, 60, 29, 0.10);
  --bt-wp143-accent-text:  #4A1B0C;
  --bt-wp143-mute:         #BA7517;
  --bt-wp143-text:         var(--md-default-fg-color);
  --bt-wp143-text-muted:   var(--md-default-fg-color--light);
  --bt-wp143-text-faint:   var(--md-default-fg-color--lighter);
  --bt-wp143-surface:      var(--md-default-bg-color);
  --bt-wp143-surface-2:    var(--md-code-bg-color);
  --bt-wp143-border:       var(--md-default-fg-color--lightest);

  font-family: var(--md-text-font-family, system-ui, sans-serif);
  color: var(--bt-wp143-text);
  max-width: 100%;
}

[data-md-color-scheme="slate"] #bt-wp143-dashboard {
  --bt-wp143-accent:       #C44A24;
  --bt-wp143-accent-soft:  rgba(196, 74, 36, 0.18);
  --bt-wp143-accent-text:  #F5C4B3;
  --bt-wp143-mute:         #D88A2A;
}

#bt-wp143-dashboard a { color: inherit; }

/* ---------------------- Hero ---------------------- */
.bt-wp143-hero {
  background: var(--bt-wp143-surface-2);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 6px;
  padding: 1.25rem 1.5rem;
  margin: 0 0 1.5rem;
}
.bt-wp143-hero-eyebrow {
  font-size: var(--bt-fs-s6);
  color: var(--bt-wp143-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin: 0 0 0.5rem;
  line-height: var(--bt-lh-tight);
}
.bt-wp143-hero-title {
  font-size: var(--bt-fs-s1);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  margin: 0 0 0.3rem;
  color: var(--bt-wp143-text);
}
.bt-wp143-hero-authors {
  font-size: var(--bt-fs-s5);
  color: var(--bt-wp143-text-muted);
  font-style: italic;
  margin: 0 0 1rem;
  line-height: var(--bt-lh-body);
}
.bt-wp143-hero-verdict {
  background: var(--bt-wp143-accent-soft);
  border-left: 3px solid var(--bt-wp143-accent);
  border-radius: 0 4px 4px 0;
  padding: 0.7rem 0.9rem;
  margin: 0 0 1rem;
}
.bt-wp143-hero-verdict-label {
  font-size: var(--bt-fs-s6);
  font-weight: 500;
  color: var(--bt-wp143-accent);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin: 0 0 0.25rem;
}
.bt-wp143-hero-verdict-text {
  font-size: var(--bt-fs-s4);
  color: var(--bt-wp143-text);
  line-height: var(--bt-lh-tight);
  margin: 0;
  font-weight: 500;
}
.bt-wp143-hero-meta {
  font-size: var(--bt-fs-s5);
  color: var(--bt-wp143-text-muted);
  margin: 0;
  line-height: var(--bt-lh-body);
}
.bt-wp143-hero-meta strong {
  color: var(--bt-wp143-text);
  font-weight: 500;
}
@media (max-width: 700px) {
  .bt-wp143-hero { padding: 1rem 1.1rem; }
}


/* ---------------------- Metrics ---------------------- */
.bt-wp143-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.6rem;
  margin: 0 0 1.5rem;
}
.bt-wp143-metric {
  background: var(--bt-wp143-surface-2);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 4px;
  padding: 0.85rem 1rem;
}
.bt-wp143-metric-label {
  font-size: var(--bt-fs-s6);
  color: var(--bt-wp143-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin: 0 0 0.4rem;
  line-height: var(--bt-lh-tight);
}
.bt-wp143-metric-value {
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -1px;
  color: var(--bt-wp143-text);
  margin: 0;
}
.bt-wp143-metric-sub {
  font-size: var(--bt-fs-s6);
  color: var(--bt-wp143-text-faint);
  margin: 0.3rem 0 0;
  line-height: var(--bt-lh-tight);
}
@media (max-width: 700px) {
  .bt-wp143-metrics { grid-template-columns: repeat(2, 1fr); }
  .bt-wp143-metric-value { font-size: 1.5rem; }
}

/* ---------------------- Section ---------------------- */
.bt-wp143-section {
  margin: 0 0 1.5rem;
  padding: 1rem 1.1rem;
  background: var(--bt-wp143-surface-2);
  border-radius: 4px;
  border: 1px solid var(--bt-wp143-border);
}
.bt-wp143-section-title {
  font-size: var(--bt-fs-s2);
  font-weight: 500;
  line-height: var(--bt-lh-head);
  color: var(--bt-wp143-text);
  margin: 0 0 0.85rem;
}
.bt-wp143-section-lede {
  font-size: var(--bt-fs-s4);
  color: var(--bt-wp143-text-muted);
  line-height: var(--bt-lh-body);
  margin: 0 0 0.75rem;
}
.bt-wp143-section-lede strong {
  color: var(--bt-wp143-text);
  font-weight: 500;
}
.bt-wp143-question {
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: var(--bt-wp143-text);
  line-height: var(--bt-lh-tight);
  margin: 0 0 0.75rem;
}
.bt-wp143-subprose {
  font-size: var(--bt-fs-s4);
  color: var(--bt-wp143-text-muted);
  line-height: var(--bt-lh-body);
  margin: 1rem 0 0.5rem;
}
.bt-wp143-subprose strong {
  color: var(--bt-wp143-text);
  font-weight: 500;
}

/* ---------------------- Icons (inline SVG) ---------------------- */
.bt-wp143-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}

/* ---------------------- SVG network — базовые цвета ---------------------- */
.bt-wp143-svg-wrap {
  background: var(--bt-wp143-surface);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 4px;
  padding: 0.75rem;
  margin: 0.5rem 0 0;
}
.bt-wp143-svg-wrap svg {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}
.bt-wp143-svg-bg {
  fill: var(--bt-wp143-surface);
  stroke: var(--bt-wp143-border);
}
.bt-wp143-svg-line {
  stroke: var(--bt-wp143-text-faint);
  fill: none;
}
.bt-wp143-svg-text-primary  { fill: var(--bt-wp143-text); }
.bt-wp143-svg-text-secondary { fill: var(--bt-wp143-text-muted); }
.bt-wp143-svg-coral-fill    { fill: var(--bt-wp143-accent-soft); }
.bt-wp143-svg-coral-stroke  { stroke: var(--bt-wp143-accent); }
.bt-wp143-svg-coral-title   { fill: var(--bt-wp143-text); }
.bt-wp143-svg-coral-sub     { fill: var(--bt-wp143-text-muted); }
.bt-wp143-svg-coral-strong  { fill: var(--bt-wp143-accent); }
.bt-wp143-svg-coral-divider { stroke: var(--bt-wp143-accent); opacity: 0.25; }

/* ---------------------- Callouts ---------------------- */
.bt-wp143-callout {
  display: flex;
  gap: 0.7rem;
  background: var(--bt-wp143-surface);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 4px;
  padding: 0.75rem 0.9rem;
  margin: 1rem 0 0;
  font-size: var(--bt-fs-s4);
  color: var(--bt-wp143-text);
  line-height: var(--bt-lh-body);
}
.bt-wp143-callout-ironic {
  border-left: 3px solid var(--bt-wp143-accent);
  background: var(--bt-wp143-accent-soft);
}
.bt-wp143-callout-ironic .bt-wp143-icon { color: var(--bt-wp143-accent); }

.bt-wp143-callout-curio {
  border-left: 3px solid var(--bt-wp143-mute);
}
.bt-wp143-callout-curio .bt-wp143-icon { color: var(--bt-wp143-text-muted); }

.bt-wp143-callout-postscript {
  border-left: 3px solid var(--bt-wp143-border);
  margin-top: 1.5rem;
}
.bt-wp143-callout-postscript .bt-wp143-icon { color: var(--bt-wp143-text-muted); }

.bt-wp143-callout-body { flex: 1; min-width: 0; }
.bt-wp143-callout p { margin: 0; }
.bt-wp143-callout p + p { margin-top: 0.5rem; }
.bt-wp143-callout strong { font-weight: 500; }
.bt-wp143-callout em { font-style: italic; }
.bt-wp143-callout code {
  font-family: var(--md-code-font-family, ui-monospace, monospace);
  font-size: 0.9em;
  background: var(--bt-wp143-surface-2);
  padding: 1px 5px;
  border-radius: 3px;
}
.bt-wp143-callout-label {
  font-size: var(--bt-fs-s6);
  font-weight: 500;
  color: var(--bt-wp143-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--bt-ls-caps);
  margin: 0 0 0.35rem;
}

/* ---------------------- Markers (список «Признаки текста под донора») ---------------------- */
.bt-wp143-markers {
  background: var(--bt-wp143-surface);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 4px;
  padding: 0 1rem;
}
.bt-wp143-marker {
  display: flex;
  gap: 0.7rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--bt-wp143-border);
}
.bt-wp143-marker:last-child { border-bottom: none; }
.bt-wp143-marker .bt-wp143-icon {
  color: var(--bt-wp143-accent);
  margin-top: 2px;
}
.bt-wp143-marker-body {
  flex: 1;
  min-width: 0;
  font-size: var(--bt-fs-s4);
  font-weight: 500;
  color: var(--bt-wp143-text);
  line-height: var(--bt-lh-tight);
}
.bt-wp143-marker-sub {
  font-size: var(--bt-fs-s5);
  font-weight: 400;
  color: var(--bt-wp143-text-muted);
  margin-top: 0.3rem;
  line-height: var(--bt-lh-body);
}
.bt-wp143-marker-sub strong { color: var(--bt-wp143-text); font-weight: 500; }
.bt-wp143-marker-sub em { font-style: italic; }

/* ---------------------- Chain (цепочка делегирования) ---------------------- */
.bt-wp143-chain {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.bt-wp143-chain-step {
  display: flex;
  gap: 0.9rem;
  background: var(--bt-wp143-surface);
  border: 1px solid var(--bt-wp143-border);
  border-radius: 4px;
  padding: 0.8rem 0.95rem;
  align-items: flex-start;
}
.bt-wp143-chain-num {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bt-wp143-accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--bt-fs-s5);
  font-weight: 500;
  line-height: 1;
}
.bt-wp143-chain-body {
  flex: 1;
  min-width: 0;
  font-size: var(--bt-fs-s4);
  color: var(--bt-wp143-text);
  line-height: var(--bt-lh-tight);
}
.bt-wp143-chain-body strong { font-weight: 500; }
.bt-wp143-chain-sub {
  font-size: var(--bt-fs-s5);
  color: var(--bt-wp143-text-muted);
  margin-top: 0.3rem;
  line-height: var(--bt-lh-body);
}
.bt-wp143-chain-sub strong { color: var(--bt-wp143-text); font-weight: 500; }

/* ---------------------- Footnote ---------------------- */
.bt-wp143-footnote {
  font-size: var(--bt-fs-s6);
  color: var(--bt-wp143-text-faint);
  line-height: var(--bt-lh-body);
  margin: 2rem 0 0;
  padding-top: 1rem;
  border-top: 1px solid var(--bt-wp143-border);
}


/* === Блок открытого вопроса (.bt-open) === */

.bt-open {
  border-left: 3px solid var(--md-accent-fg-color, #B8341E);
  background: color-mix(in srgb, var(--md-accent-fg-color, #B8341E) 6%, transparent);
  padding: 0.75rem 1rem;
  margin: 1.25rem 0;
  border-radius: 0 4px 4px 0;
  font-size: var(--bt-fs-s4);
  color: var(--md-default-fg-color--light);
  line-height: var(--bt-lh-body);
}

.bt-open::before {
  content: "⟳ В работе";
  display: block;
  font-size: var(--bt-fs-s6);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--md-accent-fg-color, #B8341E);
  margin-bottom: 0.4rem;
}

[data-md-color-scheme="slate"] .bt-open {
  background: color-mix(in srgb, var(--md-accent-fg-color, #D85A30) 8%, transparent);
}
