/* Дизайн по канону современных баз знаний (Wikipedia Vector 2022, MDN, Mintlify):
   типографика — основа макета, ширина строки ~70ch, липкая шапка с поиском,
   оглавление статьи сбоку, светлая и тёмная темы с переключателем. */

:root, :root[data-theme="dark"] {
  --bg: #10141a;
  --panel: #171d26;
  --text: #d7dee8;
  --muted: #8494a8;
  --accent: #4fc3f7;
  --accent-strong: #81d4fa;
  --border: #26303d;
}
:root[data-theme="light"] {
  --bg: #fafbfc;
  --panel: #ffffff;
  --text: #1c2530;
  --muted: #5c6b7c;
  --accent: #0277bd;
  --accent-strong: #01579b;
  --border: #dde4ec;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 17px/1.7 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
.wrap { max-width: 1080px; margin: 0 auto; padding: 0 20px; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; color: var(--accent-strong); }

/* Липкая шапка: поиск всегда под рукой — у Wikipedia это дало +30% к поиску. */
header {
  position: sticky; top: 0; z-index: 10;
  background: var(--panel); border-bottom: 1px solid var(--border);
}
header nav { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; padding: 10px 20px; }
.logo { font-size: 21px; font-weight: 700; color: var(--text); letter-spacing: -0.02em; }
.logo span { color: var(--accent); }
.sections { display: flex; gap: 14px; flex-wrap: wrap; font-size: 14.5px; }
.sections a { color: var(--muted); }
.sections a:hover { color: var(--accent); text-decoration: none; }
header form { margin-left: auto; }
header input[type="search"] {
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 7px 12px; width: 190px; font-size: 14.5px;
}
header input[type="search"]:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
#theme {
  background: none; border: 1px solid var(--border); border-radius: 8px;
  color: var(--muted); font-size: 16px; padding: 5px 10px; cursor: pointer;
}
#theme:hover { color: var(--accent); border-color: var(--accent); }

main { padding: 32px 20px 56px; }

/* Двухколоночный макет статьи: текст + оглавление (паттерн MDN/Mintlify). */
main.with-toc { display: grid; grid-template-columns: minmax(0, 1fr) 220px; gap: 40px; }
.content-col { min-width: 0; }
.toc { font-size: 14px; }
.toc-inner { position: sticky; top: 70px; }
.toc strong { color: var(--muted); font-size: 12.5px; text-transform: uppercase; letter-spacing: 0.06em; }
.toc ul { list-style: none; padding-left: 0; margin: 8px 0; border-left: 2px solid var(--border); }
.toc ul ul { border-left: none; padding-left: 14px; }
.toc li { margin: 2px 0; }
.toc a { display: block; color: var(--muted); padding: 3px 0 3px 12px; }
.toc a:hover { color: var(--accent); text-decoration: none; }

/* Типографика — основа: крупные заголовки, ограниченная ширина строки. */
h1 { font-size: 32px; line-height: 1.25; letter-spacing: -0.02em; }
h2 { font-size: 22px; margin-top: 36px; letter-spacing: -0.01em; }
article, .article-list p, .hero p { max-width: 70ch; }

.hero h1 { font-size: 38px; }
.hero { padding: 24px 0 12px; }
.hero p { color: var(--muted); font-size: 19px; }
.hero-search { display: flex; gap: 10px; max-width: 560px; margin: 22px 0 10px; }
.hero-search input {
  flex: 1; background: var(--panel); color: var(--text);
  border: 1px solid var(--border); border-radius: 10px;
  padding: 12px 16px; font-size: 16px;
}
.hero-search input:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
.hero-search button {
  background: var(--accent); color: var(--bg); border: none; border-radius: 10px;
  padding: 12px 22px; font-size: 16px; font-weight: 600; cursor: pointer;
}
.hero-search button:hover { background: var(--accent-strong); }

/* Bento-карточки разделов. */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; }
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
  padding: 18px 20px; display: flex; justify-content: space-between; align-items: baseline;
  color: var(--text); transition: border-color .15s;
}
.card:hover { border-color: var(--accent); text-decoration: none; }
.card p { margin: 4px 0 0; color: var(--muted); font-size: 13.5px; line-height: 1.45; }
.card span {
  color: var(--accent); font-size: 14px; font-weight: 600;
  background: var(--bg); border-radius: 12px; padding: 2px 10px; flex-shrink: 0; margin-left: 10px;
}

.article-list { list-style: none; padding: 0; }
.article-list li { padding: 12px 0; border-bottom: 1px solid var(--border); }
.article-list p { margin: 4px 0 0; color: var(--muted); font-size: 15px; }

.badge { font-size: 12px; border: 1px solid var(--border); border-radius: 10px; padding: 1px 8px; color: var(--muted); margin-left: 6px; }
.badge.beginner { color: #66a06a; border-color: color-mix(in srgb, #66a06a 40%, var(--border)); }
.badge.advanced { color: #cf8f3d; border-color: color-mix(in srgb, #cf8f3d 40%, var(--border)); }

.crumbs { font-size: 14px; color: var(--muted); margin-bottom: 10px; }

article {
  background: var(--panel); border: 1px solid var(--border); border-radius: 14px;
  padding: 10px 32px 24px;
}
article h1 { margin-top: 18px; }
article h2 { scroll-margin-top: 70px; } /* якоря из оглавления не прячутся под шапку */
article h3 { scroll-margin-top: 70px; }
article code { background: var(--bg); padding: 2px 6px; border-radius: 4px; font-size: 88%; }
article pre { background: var(--bg); padding: 14px; border-radius: 10px; overflow-x: auto; }
article pre code { padding: 0; }
article table { border-collapse: collapse; width: 100%; display: block; overflow-x: auto; }
article th, article td { border: 1px solid var(--border); padding: 6px 10px; text-align: left; }
article img { max-width: 100%; border-radius: 8px; }

/* Вики-ссылка на ещё не написанную статью: видно, чего не хватает. */
.missing { color: var(--muted); border-bottom: 1px dashed var(--muted); cursor: help; }

.related { margin-top: 28px; }
.related ul { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.related li a {
  display: inline-block; background: var(--panel); border: 1px solid var(--border);
  border-radius: 18px; padding: 5px 15px; font-size: 14px;
}
.related li a:hover { border-color: var(--accent); text-decoration: none; }

.muted { color: var(--muted); }
footer { border-top: 1px solid var(--border); padding: 18px 20px; color: var(--muted); font-size: 13px; }

@media (max-width: 900px) {
  main.with-toc { grid-template-columns: 1fr; }
  .toc { display: none; } /* на мобильных оглавление скрыто — экономим первый экран */
}
@media (max-width: 600px) {
  header form { order: 5; margin-left: 0; flex: 1 1 100%; }
  header input[type="search"] { width: 100%; }
  article { padding: 6px 18px 18px; }
  h1 { font-size: 26px; }
  .hero h1 { font-size: 30px; }
}
