/* ============================================================
   SkyRoute - Reset и базовые элементы
   Опирается на токены из colors / typography / layout.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Декоративные элементы могут выходить за край — обрезаем на уровне body */
html { overflow-x: clip; }

body {
  display: flex;
  flex-direction: column;
  min-height: 100svh;
  overflow-x: clip;
  background: var(--bg-page);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  font-weight: var(--fw-regular);
  -webkit-font-smoothing: antialiased;
}

::selection { background: var(--sky); color: var(--navy); }

a { color: inherit; text-decoration: none; }

button { cursor: pointer; font-family: inherit; border: none; background: none; padding: 0; }

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

h1, h2, h3, h4 {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  color: var(--text-primary);
  letter-spacing: var(--ls-heading);
}

/* Утилита-контейнер: используется в шапке, подвале и разовых местах */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* Обратная совместимость с page.php / 404.php */
.section        { padding-block: var(--section-y); }
.section__inner { max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }

/* ---- Автоматические ограничения секций ---------------------------------- */
/* Каждая секция держит контент внутри content-max через именованный __inner.
   Перечисляем здесь, чтобы не дублировать max-width в каждом section-css.  */
.final-cta__inner,
.footer__top,
.footer__cols,
.footer__bottom {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* body flex → main растягивает вертикаль */
.site-main { flex: 1; }

/* Адаптивное уменьшение gutter */
@media (max-width: 767px) {
  :root { --gutter: 16px; }
}
@media (max-width: 374px) {
  :root { --gutter: 12px; }
}

/* Адаптивное уменьшение вертикального ритма секций */
@media (max-width: 767px) {
  :root { --section-y: 64px; }
}
@media (max-width: 374px) {
  :root { --section-y: 48px; }
}
