/* Раздел «Законодательство России в сфере ГИС ЖКХ»
   Дизайн-токены совпадают с redesign-2026 темы сайта (oklch, Manrope/Fraunces/JetBrains Mono),
   но scoped в .zk-* — чтобы не конфликтовать с bootstrap/старым main.css темы. */
.zk-wrap {
  --bg: oklch(0.97 0.012 95);
  --bg-2: oklch(0.94 0.018 95);
  --ink: oklch(0.22 0.04 155);
  --ink-2: oklch(0.45 0.03 155);
  --line: oklch(0.88 0.02 105);
  --line-2: oklch(0.92 0.015 100);
  --accent: oklch(0.62 0.13 152);
  --accent-2: oklch(0.78 0.12 152);
  --accent-soft: oklch(0.92 0.04 152);
  --accent-ink: oklch(0.98 0.01 152);
  --serif: 'Fraunces', Georgia, serif;
  --sans: 'Manrope', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  padding: 32px 0 80px;
  -webkit-font-smoothing: antialiased;
}
.zk-container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* Хлебные крошки */
.zk-bc { font-family: var(--mono); font-size: 12px; color: var(--ink-2); margin-bottom: 22px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.zk-bc a { color: var(--ink-2); text-decoration: none; }
.zk-bc a:hover { color: var(--accent); }
.zk-bc span:last-child { color: var(--ink); }
.zk-bc-sep { color: var(--line); }

/* Сетка: оглавление + документ */
.zk-layout { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 40px; align-items: start; }

/* Оглавление (липкое) */
.zk-toc { position: sticky; top: 24px; }
.zk-toc-box { background: var(--bg-2); border: 1px solid var(--line); border-radius: 16px; padding: 14px 14px 14px 16px; }
.zk-toc-title { font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: .9px; text-transform: uppercase; color: var(--ink-2); cursor: pointer; list-style: none; padding-bottom: 6px; }
.zk-toc-title::-webkit-details-marker { display: none; }
/* Прокрутка только по высоте; по ширине — нет (текст переносится). Тонкий скроллбар в тон сайту. */
.zk-toc-list {
  list-style: none; margin: 8px 0 0; padding: 0;
  max-height: calc(100vh - 130px); overflow-y: auto; overflow-x: hidden;
  scrollbar-width: thin; scrollbar-color: var(--accent-2) transparent;
}
.zk-toc-list::-webkit-scrollbar { width: 6px; }
.zk-toc-list::-webkit-scrollbar-track { background: transparent; }
.zk-toc-list::-webkit-scrollbar-thumb { background: var(--line); border-radius: 999px; }
.zk-toc-list::-webkit-scrollbar-thumb:hover { background: var(--accent-2); }
.zk-toc-list li { margin: 0; }
.zk-toc-list a {
  display: block; padding: 5px 8px; border-radius: 8px; color: var(--ink-2); text-decoration: none;
  font-size: 12px; line-height: 1.32; border-left: 2px solid transparent;
  white-space: normal; overflow-wrap: anywhere; word-break: break-word;
  transition: background .15s, color .15s, border-color .15s;
}
.zk-toc-list a:hover { background: var(--accent-soft); color: var(--ink); }
.zk-toc-l3 a { padding-left: 18px; font-size: 11.5px; }
.zk-toc-list a.zk-active { color: var(--accent); border-left-color: var(--accent); background: var(--accent-soft); font-weight: 600; }

/* Документ */
.zk-doc { background: oklch(0.99 0.008 95); border: 1px solid var(--line); border-radius: 20px; padding: 40px 44px; box-shadow: 0 1px 2px rgba(0,0,0,.03); }
.zk-head { border-bottom: 1px solid var(--line); padding-bottom: 22px; margin-bottom: 26px; }
.zk-meta-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.zk-badge { font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: .4px; color: var(--accent-ink); background: var(--accent); padding: 4px 10px; border-radius: 999px; }
.zk-tag { font-family: var(--mono); font-size: 12px; color: var(--ink); background: var(--bg-2); border: 1px solid var(--line); padding: 4px 10px; border-radius: 999px; }
.zk-tag-dim { color: var(--ink-2); }
.zk-title { font-family: var(--serif); font-weight: 600; font-size: 30px; line-height: 1.18; letter-spacing: -.2px; margin: 6px 0 0; color: var(--ink); }
.zk-official { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.4; color: var(--ink-2); margin: 12px 0 0; }

.zk-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.zk-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: 14px; font-weight: 600; padding: 10px 18px; border-radius: 999px; text-decoration: none; transition: transform .15s, background .15s, box-shadow .15s; }
.zk-btn-primary { background: var(--accent-2); color: oklch(0.25 0.05 152); box-shadow: 0 4px 14px oklch(0.62 0.13 152 / .18); }
.zk-btn-primary:hover { transform: translateY(-1px); background: oklch(0.82 0.11 152); }
.zk-btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.zk-btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
.zk-btn-ic { font-size: 20px; line-height: 1; }

/* Тело документа */
.zk-body { font-size: 16px; color: var(--ink); overflow-wrap: anywhere; word-break: break-word; }
.zk-body h2.zk-h, .zk-body h3.zk-h { font-family: var(--sans); color: var(--ink); scroll-margin-top: 90px; }
.zk-body h2.zk-h { font-size: 20px; font-weight: 700; margin: 34px 0 12px; padding-top: 8px; border-top: 1px solid var(--line-2); }
.zk-body h2.zk-h:first-child { border-top: none; margin-top: 0; }
.zk-body h3.zk-h { font-size: 17px; font-weight: 700; margin: 24px 0 8px; color: oklch(0.32 0.05 152); }
.zk-body p { margin: 0 0 14px; }
.zk-body p:first-of-type { color: var(--ink-2); }

.zk-foot { margin-top: 30px; padding-top: 18px; border-top: 1px solid var(--line); }
.zk-disclaimer {
  font-size: 13px; line-height: 1.55; color: oklch(0.42 0.035 155); margin: 0;
  overflow-wrap: anywhere;
}

/* Адаптив */
@media (max-width: 900px) {
  .zk-wrap { padding: 20px 0 56px; }
  .zk-layout, .zk-layout-notoc { grid-template-columns: 1fr; gap: 18px; }
  .zk-layout-notoc .zk-doc { max-width: none; }
  .zk-toc { position: static; max-height: none; }
  .zk-toc-box { padding: 8px 14px; }
  /* на мобиле оглавление — компактный сворачиваемый блок, не во весь экран */
  .zk-toc-list { max-height: 260px; }
  .zk-toc-box:not([open]) .zk-toc-list { display: none; }
  .zk-doc { padding: 26px 20px; border-radius: 16px; }
  .zk-title { font-size: 24px; }
  .zk-official { font-size: 16px; }
  /* облако тем: гасим крупный инлайн font-size, чтобы длинные теги не вылезали за экран */
  .zk-cloud-tag { font-size: 15px !important; }
}
@media (max-width: 560px) {
  .zk-container { padding: 0 16px; }
  .zk-doc { padding: 22px 16px; }
  .zk-title { font-size: 21px; }
  .zk-official { font-size: 15px; }
  .zk-body { font-size: 15.5px; }
  .zk-btn { width: 100%; justify-content: center; }   /* кнопки во всю ширину, удобно тапать */
  .zk-cloud-title { font-size: 19px; }
}

/* Архив раздела */
.zk-arc-head { margin-bottom: 28px; }
.zk-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; }
.zk-card { display: flex; align-items: center; justify-content: space-between; gap: 12px; background: oklch(0.99 0.008 95); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; text-decoration: none; color: var(--ink); transition: border-color .15s, transform .15s; }
.zk-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.zk-card-name { font-weight: 600; font-size: 15px; line-height: 1.3; }
.zk-card-count { font-family: var(--mono); font-size: 13px; color: var(--accent-ink); background: var(--accent); min-width: 28px; height: 24px; padding: 0 8px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; }
.zk-doc-list { list-style: none; margin: 24px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.zk-doc-item a { display: block; background: oklch(0.99 0.008 95); border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: 12px; padding: 14px 18px; text-decoration: none; color: var(--ink); transition: background .15s, transform .15s; }
.zk-doc-item a:hover { background: var(--accent-soft); transform: translateX(2px); }
.zk-di-title { display: block; font-weight: 600; font-size: 15px; }
.zk-di-official { display: block; font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--ink-2); margin-top: 3px; }
.zk-pager { margin-top: 24px; }
.zk-pager .page-numbers { font-family: var(--mono); font-size: 13px; padding: 6px 11px; border: 1px solid var(--line); border-radius: 8px; margin-right: 6px; text-decoration: none; color: var(--ink); }
.zk-pager .page-numbers.current { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* Тема-теги документа */
.zk-temy { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 18px; }
.zk-temy-label { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase; color: var(--ink-2); }
.zk-tema { font-size: 12.5px; font-weight: 500; color: var(--ink); background: var(--accent-soft); border: 1px solid transparent; border-radius: 999px; padding: 4px 12px; text-decoration: none; transition: background .15s, border-color .15s; }
.zk-tema:hover { background: var(--bg); border-color: var(--accent); color: var(--accent); }

/* Облако тем (архив раздела) */
.zk-cloud-wrap { margin-top: 40px; padding-top: 28px; border-top: 1px solid var(--line); }
.zk-cloud-title { font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); margin: 0 0 18px; }
.zk-cloud { display: flex; flex-wrap: wrap; gap: 10px 12px; align-items: baseline; }
.zk-cloud-tag { display: inline-flex; align-items: baseline; gap: 6px; color: var(--ink); text-decoration: none;
  line-height: 1.25; font-weight: 500; padding: 5px 13px; border-radius: 999px; background: var(--bg-2);
  border: 1px solid var(--line); transition: background .15s, border-color .15s, color .15s; }
.zk-cloud-tag:hover { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }
.zk-cloud-n { font-family: var(--mono); font-size: 10px; color: var(--ink-2); font-weight: 600; }
.zk-cloud-tag:hover .zk-cloud-n { color: var(--accent); }

/* Заглушка для документов с непригодным к извлечению текстом (битые RTF) */
.zk-corrupt { background: oklch(0.96 0.04 85); border: 1px solid oklch(0.85 0.08 85); border-left: 3px solid var(--warm, #d99a2b);
  border-radius: 12px; padding: 16px 18px; font-size: 14.5px; line-height: 1.6; color: oklch(0.40 0.04 85); }

/* Документ без оглавления — одна колонка на всю ширину (а не узкий первый трек грида) */
.zk-layout-notoc { grid-template-columns: minmax(0, 1fr); }
.zk-layout-notoc .zk-doc { max-width: 880px; margin: 0 auto; width: 100%; }
