/* ============================================================
   БАЗА — reset, типографика, утилиты, секции
   ============================================================ */

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  position: relative;
  min-height: 100vh;
  /* Фон всей страницы перекрашивается в палитру стороны (v2).
     Градиент + радиальное свечение из page-* токенов. */
  background:
    radial-gradient(140% 100% at 50% -10%, var(--page-glow) 0%, transparent 55%),
    linear-gradient(180deg, var(--page-bg-1) 0%, var(--page-bg-2) 60%);
  background-attachment: fixed;
  /* Плавная смена фона при перекраске стороны */
  transition: background-color 600ms cubic-bezier(0.4, 0, 0.2, 1);
}

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

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

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

input, textarea, select { font-family: inherit; font-size: inherit; }

/* --- Типографика --- */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--ink);
}

h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: 700; }

.display-names {
  font-family: var(--font-display);
  font-weight: 900;
  line-height: 1.0;
}

.lead {
  font-size: var(--fs-lead);
  color: var(--ink-secondary);
  line-height: 1.55;
}

.eyebrow {
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-deep);
  transition: color var(--transition-side);
}

.caption {
  font-size: var(--fs-caption);
  color: var(--ink-caption);
}

.small { font-size: var(--fs-small); }

.text-secondary { color: var(--ink-secondary); }

/* --- Раскладка --- */
.section {
  padding: clamp(56px, 12vw, 96px) var(--pad-screen);
}

.container {
  width: 100%;
  max-width: 1080px;
  margin-inline: auto;
}

.container-narrow { max-width: 640px; }

.section-head {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin-bottom: var(--s-8);
}

/* Секция в цвете стороны (tint-фон) */
.section--tint {
  background: var(--c-tint);
  color: var(--c-tint-ink);
  transition: background-color var(--transition-side), color var(--transition-side);
}
.section--tint h2,
.section--tint h3 { color: var(--c-tint-ink); }

/* Утилиты */
.stack { display: flex; flex-direction: column; }
.gap-2 { gap: var(--s-2); }
.gap-3 { gap: var(--s-3); }
.gap-4 { gap: var(--s-4); }
.gap-6 { gap: var(--s-6); }
.center { text-align: center; align-items: center; }

.is-hidden { display: none !important; }

/* Доступность: скрыто визуально, доступно скринридеру */
.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;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition-duration: 0.01ms !important; }
}
