/* ============================================================
   BASE — сброс + базовая типографика.
   Это «правила по умолчанию»: любой <h2>, <p>, <a> уже выглядит
   правильно БЕЗ доп. классов. Компоненты лишь уточняют.
   ============================================================ */

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }

* { margin: 0; }

html {
  font-size: 100%;            /* 1rem = 16px; уважает настройки браузера */
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  font-family: var(--font-base);
  font-weight: var(--fw-regular);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-text-primary);
  background: var(--color-bg-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, picture, svg, video { display: block; max-width: 100%; height: auto; }

button, input, select, textarea { font: inherit; color: inherit; }

ul, ol { list-style: none; padding: 0; }

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

:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--radius-sm); }

/* ---------- Заголовки ---------- */
h1, h2, h3, h4 {
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--color-text-primary);
  text-wrap: balance;
}
h1 { font-size: var(--fs-h1); letter-spacing: var(--ls-tight); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); }

/* ---------- Текст ---------- */
p { line-height: var(--lh-normal); }
p + p { margin-top: var(--space-4); }

strong, b { font-weight: var(--fw-bold); }

small, .text-sm  { font-size: var(--fs-sm); }
.text-xs         { font-size: var(--fs-xs); }
.text-muted      { color: var(--color-text-muted); }
.text-dim        { color: var(--color-text-dim); }
.text-accent     { color: var(--color-accent); }
.lead            { font-size: var(--fs-lead); color: var(--color-text-muted); }

/* ---------- Раскладка-утилиты ---------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* Вертикальный ритм: дочерние блоки получают одинаковый отступ.
   Меняется через --gap, по умолчанию 16px. Убивает «плавающие» margin'ы. */
.stack > * + * { margin-top: var(--gap, var(--space-4)); }

/* Сетка с автоколонками — для карточек. Управляется через --min/--gap. */
.grid-auto {
  display: grid;
  gap: var(--gap, var(--space-6));
  grid-template-columns: repeat(auto-fill, minmax(var(--min, 240px), 1fr));
}
/* Как grid-auto, но auto-fit: карточки растягиваются и ЗАПОЛНЯЮТ всю ширину сетки. */
.grid-fit {
  display: grid;
  gap: var(--gap, var(--space-6));
  grid-template-columns: repeat(auto-fit, minmax(var(--min, 260px), 1fr));
}

.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* Контейнер для container-queries: компоненты внутри реагируют на ШИРИНУ
   этого блока, а не окна. На реальной странице оборачивай контентную колонку
   в .cq — тогда компонент сам перестроится под свою ширину. */
.cq { container-type: inline-size; }

/* ---------- PROSE — длинный текстовый контент ---------- */
.prose { font-size: var(--fs-body); line-height: var(--lh-normal); color: var(--color-text-primary); }
.prose > * + * { margin-top: var(--space-4); }
.prose h2 { font-size: var(--fs-h2); }
.prose h3 { font-size: var(--fs-h3); margin-top: var(--space-6); }
.prose ul { display: flex; flex-direction: column; gap: var(--space-3); }
.prose ul li { position: relative; padding-left: var(--space-5); }
.prose ul li::before { content: "•"; position: absolute; left: var(--space-2); color: var(--color-accent); }
.prose .text-muted, .prose p { color: var(--color-text-muted); }
.prose strong { color: var(--color-text-primary); }
