/* ========== ПЕРЕМЕННЫЕ ========== */
:root {
  /* Цветовая схема */
  --color-primary: #f07331;
  --color-primary-light: #eb6343;
  --color-secondary: #fec842;
  --color-accent: #2f43ca;
  --color-bg: #ffffff;
  --color-text: #000000;

  /* Типографика - размеры */
  --font-size-hero-title: 80px;
  --font-size-hero-subtitle: 30px;
  --font-size-section-title: 80px;
  --font-size-section-subtitle: 30px;
  --font-size-feature: 30px;
  --font-size-card: 20px;
  --font-size-footer: 25px;
  --font-size-footer-mobile: 18px;
  --font-size-copyright: 20px;
  --font-size-copyright-mobile: 16px;

  /* Типографика - жирность */
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;

  /* Хедер */
  --header-top-offset: 30px;
  --header-top-offset-mobile: 10px;
  --header-width: calc(100% - 80px);
  --header-width-mobile: calc(100% - 40px);
  --header-max-width: 1320px;
  --header-padding: 12px 24px;
  --header-padding-mobile: 10px 15px;
  --header-border-radius: 50px;
  --header-border-radius-mobile: 25px;

  /* Логотип */
  --logo-font-size: 50px;
  --logo-font-size-mobile: 22px;
  --logo-font-weight: var(--font-weight-medium);

  /* Навигация */
  --nav-gap: 8px;
  --nav-gap-mobile: 5px;
  --nav-margin-right: 15px;

  /* Кнопки в хедере */
  --header-btn-font-size: 25px;
  --header-btn-padding: 10px 25px;
  --header-btn-border: 2px solid var(--color-text);
  --header-btn-border-radius: 30px;
  --header-btn-font-size-mobile: 14px;
  --header-btn-padding-mobile: 6px 12px;
  --header-btn-border-width-mobile: 1.5px;

  /* Летающие слова */
  --flying-words-padding-top: 220px;
  --flying-words-padding-top-mobile: 120px;
  --word-tag-padding: 14px 32px;
  --word-tag-padding-mobile: 6px 12px;
  --word-tag-font-size: 24px;
  --word-tag-font-size-mobile: 12px;
  --word-tag-border-radius: 35px;
  --word-tag-border-radius-mobile: 20px;
  --word-gap: 20px;
  --word-gap-mobile: 8px;

  /* Hero секция */
  --hero-padding: 40px 20px 60px;
  --hero-padding-mobile: 20px 20px 30px;
  --hero-title-margin-bottom: 20px;
  --hero-title-font-size-mobile: 42px;
  --hero-subtitle-font-size-mobile: 18px;

  /* Карточки фич */
  --feature-card-padding: 25px;
  --feature-card-padding-mobile: 20px;
  --feature-card-border-radius: 50px;
  --feature-card-min-height: 80px;

  /* Контакты */
  --contacts-gap: 50px;
  --contacts-gap-mobile: 20px;
  --contact-card-padding: 40px 60px;
  --contact-card-border-radius: 30px;

  /* Футер */
  --footer-padding: 40px 0;
  --footer-padding-mobile: 30px 0;
  --footer-margin-top: 60px;
  --footer-gap: 30px;
  --footer-gap-mobile: 15px;
  --footer-border-top: 2px solid var(--color-text);
  --footer-border-top-mobile: 3px;
  --footer-max-width: 1800px;

  /* Отступы */
  --section-padding: 60px 0;
  --section-padding-mobile: 40px 0;
  --container-padding: 0 20px;
}

/* ========== ОБНУЛЕНИЕ И БАЗОВЫЕ СТИЛИ ========== */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  background-color: var(--color-bg);
  color: var(--color-text);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
  width: 100%;
}

/* ========== ЛЕТАЮЩИЕ СЛОВА ========== */
/* Десктопная версия */
.flying-words-wrapper {
  overflow: hidden;
  background: transparent;
  padding: var(--flying-words-padding-top) 0 0;
  width: 100%;
  position: relative;
  z-index: 1;
}

.flying-words {
  display: flex;
  flex-direction: column;
  width: 100%;
}

/* Ряды слов с разной скоростью анимации */
.words-row {
  display: flex;
  gap: var(--word-gap);
  margin-bottom: 15px;
  flex-wrap: nowrap;
  width: fit-content;
  will-change: transform;
  background: transparent;
  padding: 10px 0;
}

/* Индивидуальные скорости для каждого ряда */
.words-row:nth-child(1) {
  animation: scroll-left 10s linear infinite alternate;
}

.words-row:nth-child(2) {
  animation: scroll-right 6s linear infinite alternate;
}

.words-row:nth-child(3) {
  animation: scroll-left 14s linear infinite alternate;
}

.words-row:nth-child(4) {
  animation: scroll-right 8s linear infinite alternate;
}

/* Анимации движения */
@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-30%);
  }
}

@keyframes scroll-right {
  0% {
    transform: translateX(-30%);
  }

  100% {
    transform: translateX(0);
  }
}

/* Стили для тегов слов */
.word-tag {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--word-tag-padding);
  border-radius: var(--word-tag-border-radius);
  font-size: var(--word-tag-font-size);
  color: #ffffff;
  background-color: var(--color-primary);
  white-space: nowrap;
}

/* Цветовые варианты слов */
.word-tag.word-yellow {
  background-color: var(--color-secondary);
  color: var(--color-text);
}

.word-tag.word-blue {
  background-color: var(--color-accent);
}

/* Чередование цветов для нечетных слов */
.word-tag:nth-child(odd):not(.word-yellow):not(.word-blue) {
  background-color: var(--color-primary-light);
}

/* Мобильная версия летающих слов - по умолчанию скрыта */
.flying-words-mobile-top {
  display: none;
}

/* ========== КОНТЕЙНЕР ЛЕНДИНГА ========== */
.landing {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  position: relative;
}

/* ========== ХЕДЕР ========== */
.header {
  position: fixed;
  top: var(--header-top-offset);
  left: 50%;
  transform: translateX(-50%);
  width: var(--header-width);
  max-width: var(--header-max-width);
  z-index: 100;
}

.header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--color-bg);
  border: 2px solid var(--color-text);
  border-radius: var(--header-border-radius);
  padding: var(--header-padding);
  box-shadow: 0 15px 34px rgba(99, 99, 99, 0.1);
}

/* Логотип */
.logo {
  font-family: 'Coolvetica', 'Helvetica Neue', Helvetica, sans-serif;
  font-size: var(--logo-font-size);
  font-weight: var(--logo-font-weight);
  color: var(--color-text);
  margin-right: auto;
}

/* Навигация - ОТВЕЧАЕТ ЗА РАСПОЛОЖЕНИЕ КНОПОК СПРАВА */
.nav {
  display: flex;
  gap: var(--nav-gap);
  margin-left: auto;
  /* Прижимает навигацию к правому краю */
  margin-right: var(--nav-margin-right);
  /* Отступ перед кнопкой Играть */
}

/* КНОПКИ В ХЕДЕРЕ - размеры и стили */
.nav-link {
  font-size: var(--header-btn-font-size);
  color: var(--color-text);
  text-decoration: none;
  padding: var(--header-btn-padding);
  border: var(--header-btn-border);
  border-radius: var(--header-btn-border-radius);
  transition: background-color 0.2s ease, color 0.2s ease;
  white-space: nowrap;
}

.nav-link:hover {
  background-color: var(--color-text);
  color: var(--color-bg);
}

/* Базовые стили для всех кнопок */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 25px;
  border-radius: 30px;
  text-decoration: none;
  font-size: 20px;
  font-weight: var(--font-weight-normal);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

/* Кнопка Играть в хедере */
.btn-primary {
  background-color: var(--color-secondary);
  color: var(--color-text);
  border: var(--header-btn-border);
  flex-shrink: 0;
  /* Запрещает кнопке сжиматься */
  font-size: var(--header-btn-font-size);
  padding: var(--header-btn-padding);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(254, 200, 66, 0.4);
}

/* Кнопка Играть в футере - синяя */
.footer .btn-primary {
  background-color: var(--color-accent);
  color: #ffffff;
}

.footer .btn-primary:hover {
  box-shadow: 0 4px 12px rgba(47, 67, 202, 0.4);
}

/* Большая кнопка в hero секции */
.btn-large {
  background-color: var(--color-primary);
  color: var(--color-bg);
  font-size: 20px;
  padding: 16px 32px;
  border-radius: 30px;
}

.btn-large:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(240, 115, 49, 0.4);
}

/* ========== HERO СЕКЦИЯ ========== */
.hero {
  text-align: center;
  padding: var(--hero-padding);
  position: relative;
  z-index: 2;
  background: transparent;
}

.hero-title {
  font-family: 'Coolvetica', 'Helvetica Neue', Helvetica, sans-serif;
  font-size: var(--font-size-hero-title);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  margin-bottom: var(--hero-title-margin-bottom);
}

.hero-subtitle {
  font-size: var(--font-size-hero-subtitle);
  color: var(--color-text);
  margin-bottom: 40px;
}

/* ========== FEATURES СЕКЦИЯ (Карточки с преимуществами) ========== */
.features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: var(--section-padding);
  scroll-margin-top: 100px;
}

/* Карточка фичи */
.feature-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--feature-card-padding);
  border-radius: var(--feature-card-border-radius);
  min-height: var(--feature-card-min-height);
  background-color: var(--color-primary);
}

/* Варианты цветов для карточек */
.feature-card-orange {
  background-color: var(--color-primary-light);
}

.feature-card-yellow {
  background-color: var(--color-secondary);
}

.feature-title {
  font-size: var(--font-size-feature);
  font-weight: var(--font-weight-normal);
  color: var(--color-bg);
  margin-bottom: 8px;
}

/* Стили для текста в цветных карточках */
.feature-card-orange .feature-title,
.feature-card-yellow .feature-title,
.feature-card-orange .feature-text,
.feature-card-yellow .feature-text {
  color: var(--color-text);
}

.feature-text {
  font-size: var(--font-size-feature);
  font-weight: var(--font-weight-normal);
  color: var(--color-bg);
  text-align: center;
}

/* ========== CONTACTS СЕКЦИЯ ========== */
.contacts {
  text-align: center;
  padding: var(--section-padding);
  scroll-margin-top: 100px;
}

.contacts-title {
  font-family: 'Coolvetica', 'Helvetica Neue', Helvetica, sans-serif;
  font-size: var(--font-size-section-title);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  margin-bottom: 20px;
}

.contacts-subtitle {
  font-size: var(--font-size-section-subtitle);
  color: var(--color-text);
  margin-bottom: 40px;
}

.contacts-cards {
  display: flex;
  justify-content: center;
  gap: var(--contacts-gap);
  flex-wrap: wrap;
}

/* Карточка контакта */
.contact-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: var(--contact-card-padding);
  border-radius: var(--contact-card-border-radius);
  transform: rotate(-5deg);
  border: 2px solid var(--color-text);
  position: relative;
}

.contact-card::before,
.contact-card::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: var(--contact-card-border-radius);
  border: 2px solid var(--color-text);
  z-index: -1;
}

.contact-card::before {
  top: 8px;
  left: 12px;
  background-color: var(--color-primary);
}

.contact-card::after {
  top: 16px;
  left: 24px;
  background-color: var(--color-secondary);
}

/* Разный поворот для карточек */
.contact-card:first-child {
  background-color: var(--color-secondary);
  transform: rotate(5deg);
}

.contact-card:first-child::before {
  background-color: var(--color-primary);
}

.contact-card:first-child::after {
  background-color: var(--color-primary-light);
}

.contact-card:last-child {
  background-color: var(--color-primary-light);
}

.contact-card:last-child::before {
  background-color: var(--color-secondary);
}

.contact-card:last-child::after {
  background-color: var(--color-primary);
}

.contact-label {
  font-size: var(--font-size-card);
  color: var(--color-text);
}

.contact-value {
  font-size: var(--font-size-card);
  color: var(--color-text);
}

/* ========== ФУТЕР ========== */
.footer {
  border-top: var(--footer-border-top);
  padding: var(--footer-padding);
  margin-top: var(--footer-margin-top);
  width: 100%;
}

/* Контейнер футера - центрирование контента */
.footer-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: var(--footer-max-width);
  margin: 0 auto;
  padding: var(--container-padding);
  width: 100%;
  position: static;
  left: auto;
}

/* Ссылки в футере - расположены слева */
.footer-links {
  display: flex;
  gap: var(--footer-gap);
  align-items: center;
}

.footer-link {
  font-size: var(--font-size-footer);
  color: var(--color-text);
  text-decoration: none;
}

/* Копирайт - расположен справа */
.footer-copyright {
  font-size: var(--font-size-copyright);
  color: var(--color-text);
}

/* ========== АДАПТИВНОСТЬ ========== */

/* Планшеты и небольшие десктопы */
@media (max-width: 1400px) {
  .features {
    grid-template-columns: 1fr;
    max-width: 600px;
    margin: 0 auto;
  }
}

@media (max-width: 1200px) {
  .footer {
    padding-left: 30px;
    padding-right: 30px;
  }
}

/* Мобильные устройства */
@media (max-width: 768px) {

  /* Контейнер */
  .landing {
    padding: 0;
  }

  /* Хедер */
  .header {
    width: var(--header-width-mobile);
    top: var(--header-top-offset-mobile);
  }

  .header-container {
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: var(--header-padding-mobile);
    border-radius: var(--header-border-radius-mobile);
  }

  .logo {
    font-size: var(--logo-font-size-mobile);
    margin-right: auto;
  }

  /* Навигация на мобилках - скрываем */
  .nav {
    display: none;
  }

  .btn-primary {
    margin-left: auto;
  }

  /* Размеры кнопок на мобилках */
  .btn-primary,
  .nav-link {
    font-size: var(--header-btn-font-size-mobile) !important;
    padding: var(--header-btn-padding-mobile) !important;
    border-width: var(--header-btn-border-width-mobile);
  }

  /* Летающие слова на мобилках */
  .flying-words-wrapper {
    display: none;
  }

  .flying-words-mobile-top {
    display: block;
    overflow: hidden;
    width: 100%;
    padding: var(--flying-words-padding-top-mobile) 0 20px;
    margin: 0;
    background: transparent;
    position: relative;
    z-index: 5;
  }

  .words-row-mobile {
    display: flex;
    gap: var(--word-gap-mobile);
    flex-wrap: nowrap;
    width: fit-content;
    animation: scroll-left 8s linear infinite alternate;
    padding: 5px 0;
  }

  .words-row-mobile-second {
    display: flex;
    gap: var(--word-gap-mobile);
    flex-wrap: nowrap;
    width: fit-content;
    animation: scroll-right 4s linear infinite alternate;
    padding: 5px 0;
  }

  .words-row-mobile .word-tag,
  .words-row-mobile-second .word-tag {
    padding: var(--word-tag-padding-mobile);
    font-size: var(--word-tag-font-size-mobile);
    border-radius: var(--word-tag-border-radius-mobile);
    white-space: nowrap;
  }

  /* Hero секция */
  .hero {
    padding: var(--hero-padding-mobile);
  }

  .hero-title {
    font-size: var(--hero-title-font-size-mobile);
    font-weight: var(--font-weight-medium);
  }

  .hero-subtitle {
    font-size: var(--hero-subtitle-font-size-mobile);
  }

  /* Features секция */
  .features {
    padding: var(--section-padding-mobile);
  }

  .feature-card {
    padding: var(--feature-card-padding-mobile);
    border-radius: var(--feature-card-border-radius-mobile);
  }

  .feature-title,
  .feature-text {
    font-size: 20px;
  }

  /* Contacts секция */
  .contacts-title {
    font-size: var(--hero-title-font-size-mobile);
    font-weight: var(--font-weight-medium);
  }

  .contacts-subtitle {
    font-size: var(--hero-subtitle-font-size-mobile);
  }

  .contacts-cards {
    flex-direction: column;
    align-items: center;
    gap: var(--contacts-gap-mobile);
  }

  /* Футер */
  .footer {
    padding: var(--footer-padding-mobile);
    border-top-width: var(--footer-border-top-mobile);
  }

  .footer-container {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
    text-align: center;
    padding: 0 20px;
  }

  .footer-links {
    flex-direction: row;
    gap: var(--footer-gap-mobile);
  }

  .footer-link {
    font-size: var(--font-size-footer-mobile);
  }

  .footer-copyright {
    font-size: var(--font-size-copyright-mobile);
  }
}

/* ========== ДОПОЛНИТЕЛЬНЫЕ ПРАВИЛА ========== */

/* Чуть смещаем футер для центрирования (по желанию) */
.footer-container {
  /* left: 10px;  — раскомментировать если нужно сместить */
}

@media (max-width: 768px) {
  .footer-container {
    left: 0;
    /* Отключаем смещение на мобилках */
  }
}