/* ============ Базовое ============ */
* { box-sizing: border-box; }

:root {
  --bg: #e0dbd4;
  --ink: #000;
  --muted: rgba(0, 0, 0, 0.5);
}

html, body {
  margin: 0;
  padding: 0;
}

body {
  background: var(--bg);
  color: var(--ink);
  font-family: "IBM Plex Mono", ui-monospace, monospace;
  padding: 24px 0 44px;
  overflow-x: hidden;
}

img { display: block; }

/* Скрытый элемент: рендерится (значит, шрифт грузится), но не виден.
   visibility:hidden оставляет элемент в раскладке → браузер скачивает вес 600 сразу. */
.font-preload-500 {
  position: absolute;
  left: -9999px;
  top: 0;
  font-weight: 500;
  visibility: hidden;
  pointer-events: none;
  white-space: nowrap;
}

/* Контентная область строго в пределах 960px */
.page {
  width: min(960px, 100% - 48px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  /* до 1440px — 184px, к 1920px растёт на 20% (до 220.8px), линейно между ними */
  gap: clamp(184px, 73.6px + 7.667vw, 220.8px);
}

.frame {
  width: 100%;
  display: flex;
  flex-direction: column;
  /* до 1440px — 144px, к 1920px растёт на 20% (до 172.8px), линейно между ними */
  gap: clamp(144px, 57.6px + 6vw, 172.8px);
}

/* ============ Хедер ============ */
.brand {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: 20px;
  line-height: normal;
}

/* ============ Блок «спросили 500+ компаний» ============ */
.intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 56px;
  width: 100%;
}

/* Диаграмма-ссылка — ширина 600px по центру; на ховере поднимается и увеличивается */
.chart-link {
  display: block;
  width: 600px;
  max-width: 100%;
  flex-shrink: 0;
  transition: transform 0.2s ease;
  transform-origin: center;
}
.chart-link:hover {
  transform: translateY(-8px) scale(1.04) rotate(-1.5deg);
}
.chart {
  width: 100%;
  height: auto;
  display: block;
}

.lead {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: 36px;
  line-height: 46px;
  letter-spacing: -0.72px;
}

/* «спросили 500+ компаний» — выделенный фрагмент текста (без подчёркивания и ссылки) */
.link {
  color: inherit;
}

/* ============ Большая надпись S&OP ============ */
.sop {
  /* размер буквы; от него считаются позиции сносок, поэтому они масштабируются вместе с буквами */
  --sop-fs: min(400px, calc((100vw - 48px) / 2.4));
  position: relative;
  width: 100%;
  height: calc(var(--sop-fs) * 1.4);   /* 560px при буквах 400px, пропорционально на планшете */
  overflow: hidden;
}
.sop__row {
  display: flex;
  justify-content: center;
  width: 100%;
}
.letter {
  flex: 0 0 auto;
  text-align: center;
  /* 4 моноширинных символа (advance 0.6em) заполняют ширину контента без зазоров,
     максимум 400px → на десктопе ровно 960px, на мобиле — во всю ширину */
  font-size: var(--sop-fs);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2.5px var(--ink);
  user-select: none;
}
.letter--int { cursor: pointer; }
/* Заливка активной буквы (последней, на которую навели; изначально — S).
   Обводку НЕ убираем, иначе буква становится тоньше. */
.letter--int.is-active {
  color: var(--ink);
}

/* Сноски: коннектор + текст. Координаты — доли от размера буквы (--sop-fs),
   при 400px дают исходные пиксели, на планшете пропорционально уменьшаются. */
.conn {
  position: absolute;
  top: calc(var(--sop-fs) * 0.9675);    /* 387px */
  width: calc(var(--sop-fs) * 0.1775);  /* 71px  */
  height: calc(var(--sop-fs) * 0.2);    /* 80px  */
  opacity: 0;
  transition: opacity 0.15s ease;
  pointer-events: none;
}
.note {
  position: absolute;
  top: calc(var(--sop-fs) * 1.035);     /* 414px */
  width: calc(var(--sop-fs) * 1.135);   /* 454px */
  margin: 0;
  font-size: calc(var(--sop-fs) * 0.05);/* 20px  */
  line-height: normal;
  opacity: 0;
  transition: opacity 0.15s ease;
  pointer-events: none;
}

/* S — коннектор уходит вправо, текст справа (точно как в Фигме) */
.conn--s { left: calc(var(--sop-fs) * 0.3); }      /* 120px */
.note--s { left: calc(var(--sop-fs) * 0.5425); text-align: left; }  /* 217px */

/* O — коннектор зеркалится влево, текст слева (чтобы влезть в ширину) */
.conn--o { left: calc(var(--sop-fs) * 1.325); transform: scaleX(-1); }  /* 530px */
.note--o { left: calc(var(--sop-fs) * 0.1225); text-align: right; }     /* 49px  */

/* P — то же, что и O */
.conn--p { left: calc(var(--sop-fs) * 1.925); transform: scaleX(-1); }  /* 770px */
.note--p { left: calc(var(--sop-fs) * 0.7225); text-align: right; }     /* 289px */

/* Показ сноски активной буквы */
.sop:has([data-letter="s"].is-active) .conn--s,
.sop:has([data-letter="s"].is-active) .note--s,
.sop:has([data-letter="o"].is-active) .conn--o,
.sop:has([data-letter="o"].is-active) .note--o,
.sop:has([data-letter="p"].is-active) .conn--p,
.sop:has([data-letter="p"].is-active) .note--p {
  opacity: 1;
}

/* ============ Призыв и кнопка ============ */
.cta-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 56px;   /* как отступ перед «Мы спросили…» (.intro) */
  width: 100%;
}
.headline {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: 36px;
  line-height: 46px;
  letter-spacing: -0.72px;
}
.cta-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
/* Белая кнопка-ссылка: текст становится semibold на ховере */
.cta {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 600px;
  padding: 19px 56px 23px;
  text-decoration: none;
}
/* Белый фон вынесен в псевдоэлемент, чтобы расширять его на ховере без сдвига вёрстки */
.cta::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  transition: left 0.18s ease, right 0.18s ease;
}
.cta:hover::before {
  left: -16px;
  right: -16px;
}
.cta span {
  position: relative;   /* над фоном */
  z-index: 1;
  color: var(--ink);
  font-size: 36px;
  line-height: 46px;
  letter-spacing: -0.72px;
  text-align: center;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
  white-space: nowrap;
}
.cta:hover span {
  font-weight: 500;
}
.cta-note {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: 20px;
  line-height: normal;
  color: rgba(0, 0, 0, 0.4);
}

/* ============ Футер «Уже сыграли» (по Figma) ============ */
.footer {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 32px;
  font-size: 20px;
  line-height: normal;
  color: rgba(0, 0, 0, 0.4);
}
.footer__line {
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.2);
}
.footer__row {
  display: flex;
  align-items: center;
  gap: 32px;
  width: 100%;
}
.footer__label {
  margin: 0;
  white-space: nowrap;
  flex-shrink: 0;
}
.footer__logos {
  flex: 1;
  min-width: 0;
  overflow: hidden;   /* обрезает бегущую строку по краям контейнера */
}
.footer__track {
  display: flex;
  width: 100%;
}
.footer__group {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;   /* статичный режим: названия равномерно по ширине */
  gap: 24px;                        /* минимальный зазор между названиями */
}
.footer__name {
  white-space: nowrap;
  flex-shrink: 0;
  color: inherit;            /* наследуем rgba(0,0,0,0.4) от .footer */
  text-decoration: none;
}
a.footer__name:hover { color: var(--ink); }   /* на ховере — чёрный */
.footer__group--dup { display: none; }

/* Режим бегущей строки — включает JS, когда названия не помещаются в контейнер */
.footer--marquee .footer__row { gap: 22px; }   /* «Уже сыграли:» → строка (мобайл), на ~30% меньше */
/* на планшете чуть больше */
@media (min-width: 768px) and (max-width: 1008px) {
  .footer--marquee .footer__row { gap: 26px; }
}
.footer--marquee .footer__track {
  width: max-content;
  animation: footer-marquee 30s linear infinite;
}
.footer--marquee .footer__group {
  flex: 0 0 auto;
  justify-content: flex-start;
  gap: 22px;             /* зазор в бегущей строке (на ~30% меньше десктопного) */
  padding-right: 22px;   /* = зазор: group+padding повторяется дважды → сдвиг -50% бесшовный */
}
.footer--marquee .footer__group--dup { display: flex; }

/* ===== Старый футер «Уже сыграли» (заменён новым по Figma) — оставлен закомментированным:
.played {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}
.played__title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  width: 100%;
}
.played__title span {
  font-size: 20px;
  line-height: normal;
  color: var(--muted);
  white-space: nowrap;
}
.played__line {
  width: 390px;
  height: 4px;
  flex-shrink: 0;
}
.played__logos {
  width: 100%;
}
.played__track {
  display: flex;
  width: 100%;
}
.played__group {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.played__group--dup {
  display: none;
}
===== */

/* ============ Адаптив ============ */
/* Порог = момент, когда контент перестаёт помещаться в 960px (960 + 2×24 = 1008) */
@media (max-width: 1008px) {
  body { padding-bottom: 28px; }   /* нижний отступ страницы на мобиле/планшете (десктоп — 44px) */
  .page { gap: clamp(104px, 12vw, 160px); }
  .frame { gap: clamp(80px, 11vw, 144px); }
  .intro { gap: 24px; }       /* между диаграммой и текстом */
  .cta-block { gap: 32px; }   /* перед кнопкой «Спросить за участие» */
  .cta-group { gap: 16px; }   /* перед «Игры проводим раз…» (−4px) */
  .footer { gap: 24px; }      /* между линией и рядом логотипов */

  /* Шрифты 36px: пропорционально уменьшаем, но держим крупными (иерархия) */
  .lead, .headline, .cta span {
    font-size: clamp(26px, 5.6vw, 36px);
    line-height: 1.25;
  }
  /* Шрифты 20px: пропорционально уменьшаем (на мобиле 20px смотрелись крупно) */
  .brand, .cta-note, .footer {
    font-size: clamp(14px, 3vw, 20px);
  }

  /* Ширина кнопки = ширина диаграммы: min(600px, 100%) */
  .cta-group { width: 100%; }
  .cta { width: 100%; max-width: 600px; padding: 14px 24px 18px; }
  .cta span { white-space: normal; }   /* допускаем перенос текста кнопки */
  .cta:hover::before { left: 0; right: 0; }   /* на мобиле фон не расширяем (нет ховера) */

  /* На планшете (768–1008px) сноски остаются десктопными (коннектор + абсолют,
     масштаб через --sop-fs). Статичный вариант сносок — только для телефонов: см. @media ≤767px ниже. */

  /* Футер выглядит «как на десктопе» на всех экранах; бегущая строка включается
     не по брейкпоинту, а по факту переполнения (класс .footer--marquee от JS). */
}

/* ===== Телефоны: сноски статичным потоком под надписью (десктопный коннектор тесен) ===== */
@media (max-width: 767px) {
  .sop {
    height: auto;
    min-height: 256px;     /* фикс. минимум, чтобы высота не скакала при смене сноски */
  }
  .conn { display: none; }   /* «уголок»-коннектор — только десктоп/планшет */

  /* вместо коннектора — небольшая точка под активной буквой */
  .letter { position: relative; }
  .letter--int.is-active::after {
    content: "";
    position: absolute;
    left: 50%;
    top: calc(0.86em + 20px);   /* чуть ниже базовой линии глифа, опущена на 20px */
    width: 6px;
    height: 6px;
    margin-left: -3px;
    border-radius: 50%;
    background: var(--ink);
  }

  .note {
    position: static;
    left: auto;
    top: auto;
    width: 100%;
    max-width: none;
    margin: calc(clamp(8px, 3vw, 32px) + 4px) 0 0;
    font-size: clamp(14px, 3vw, 20px);
    opacity: 1;
    display: none;
  }
  /* на мобиле все сноски — по левому краю */
  .note--s,
  .note--o,
  .note--p { text-align: left; }
  .sop:has([data-letter="s"].is-active) .note--s,
  .sop:has([data-letter="o"].is-active) .note--o,
  .sop:has([data-letter="p"].is-active) .note--p {
    display: block;
  }
}

/* Бегущая строка логотипов: сдвиг на одну копию (-50% дорожки из двух копий) */
@keyframes footer-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
/* Уважаем системную настройку «уменьшить движение» */
@media (prefers-reduced-motion: reduce) {
  .footer__track { animation: none; }
}
