/* 🎨 Глобальные переменные — цвета, отступы, шрифты и размеры */
:root {
  --primary-color: #2ecc71;     /* Основной зелёный цвет */
  --primary-dark: #27ae60;      /* Более тёмный оттенок зелёного */
  --primary-light: #a8e6cf;     /* Светло-зелёный для фона или выделений */
  --secondary-color: #f1f9f5;   /* Светлый второстепенный фон */
  --text-color: #2c3e50;        /* Основной цвет текста */
  --text-light: #7f8c8d;        /* Светлый текст (для подзаголовков) */
  --border-color: #e9ecef;      /* Цвет границ и линий */

  --header-height: 72px;        /* Высота фиксированного заголовка */
}

/* 📏 Сброс отступов и упрощение расчёта размеров */
* { box-sizing: border-box; }

/* ⚙️ Основные стили для html и body */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Inter', system-ui, Arial, sans-serif;
  color: var(--text-color);
  background: #fff;
  -webkit-font-smoothing: antialiased; /* Сглаживание шрифтов */
}

/* 🚫 Запрет горизонтальной прокрутки, отступ под фиксированный header */
body {
  padding-top: var(--header-height);
  overflow-x: hidden;
}

/* 🖼️ Секции, занимающие всю высоту экрана (минус header) */
.section.full-screen {
  /* сделал секции чуть плотнее по вертикали */
  min-height: calc(100vh - var(--header-height));
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 1rem; /* уменьшил вертикальные отступы для плотности */
}

/* 🧭 HEADER — фиксированная панель вверху */
header {
  background-color: rgba(241, 249, 245, 0.9); /* Полупрозрачный светлый фон */
  backdrop-filter: blur(6px);                 /* Эффект размытия позади */
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);     /* Тень снизу */
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 50;                               /* Поверх других элементов */
  padding: 10px 18px; /* чуть меньше, чтобы шапка визуально компактнее */
  font-family: Arial, sans-serif;
  border-bottom: 1px solid #e9ecef;
}

/* 🦸 HERO-СЕКЦИЯ — главный блок */
.container.hero-inner {
  max-width: 1200px;
  width: 100%;
  display: flex;
  gap: 16px; /* уменьшил расстояние между колонками */
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 0 auto;
}

.hero-left { flex: 1 1 480px; min-width: 260px; }  /* Левая колонка с текстом */
.hero-right { flex: 0 1 380px; text-align: center; position: relative; } /* Правая — изображение */

/* 📝 Заголовок и подзаголовок */
.hero-title {
  font-size: 2.6rem; /* чуть меньше для лучшей читаемости при плотной компоновке */
  line-height: 1.08;
  margin: 0;
  font-weight: 800;
  color: var(--text-color);
}

.hero-sub {
  color: var(--text-light);
  margin-top: 12px;
  font-size: 1.05rem;
  margin-bottom: 14px;
}

/* ✨ Подсветка текста выделением */
.highlight {
  position: relative;
  display: inline-block;
  z-index: 0;
  font-weight: 800;
  color: var(--text-color);
}
.highlight::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.05em;
  height: 0.42em;
  background: var(--primary-light);  /* Цвет подсветки */
  border-radius: 6px;
  z-index: -1;
}

/* 🔘 Кнопки CTA (призыв к действию) */
.btn-cta {
  display: inline-block;
  text-decoration: none;
  border-radius: 24px;
  padding: 10px 20px; /* компактнее */
  font-weight: 700;
  transition: all 0.22s ease;
  white-space: nowrap;
  font-size: 0.95rem;
}
.btn-cta.primary {
  background: var(--primary-color);
  color: #fff;
  border: none;
}
.btn-cta.primary:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
}
.btn-cta.outline {
  background: #fff;
  color: var(--primary-dark);
  border: 2px solid var(--primary-dark);
}
.btn-cta.outline:hover {
  background: var(--primary-light);
}

/* уменьшил расстояние между CTA и остальным текстом */
.hero-ctas { display:flex; gap:12px; align-items:center; margin-top:14px; flex-wrap:wrap; }

/* 🖼️ Изображение героя */
.hero-img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(44,62,80,0.08);
}

/* 💬 Маленькие плавающие карточки поверх изображения */
.float-card {
  position: absolute;
  background: #fff;
  color: var(--text-color);
  border-radius: 12px;
  padding: 10px 12px; /* чуть меньше, чтобы выглядеть аккуратно */
  box-shadow: 0 8px 20px rgba(30,40,50,0.08);
  font-weight: 700;
  min-width: 100px;
  font-size: 0.95rem;
}
.card-1 { right: 6%; top: 8%; text-align:center; }
.card-1 .card-num { font-size: 1.1rem; color: var(--primary-dark); }
.card-2 { right: 5%; bottom: 14%; text-align:left; font-weight:600; }


/* --- 📱 Адаптивные правки --- */

/* 📘 Планшеты */
@media (max-width: 1100px) {
  .features-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .hero-title { font-size: 2.2rem; }
}

/* 🤝 Секция "При поддержке" */
#partners {
  background: var(--secondary-color);
  text-align: center;
  padding: 4rem 1rem;
  border-top: 1px solid var(--border-color);
}

#partners h2 {
  color: var(--text-color);
  font-weight: 800;
  font-size: 1.9rem;
  margin-bottom: 2rem;
  position: relative;
  display: inline-block;
}

#partners h2::after {
  content: "";
  display: block;
  width: 60%;
  height: 4px;
  background: var(--primary-color);
  margin: 0.4rem auto 0;
  border-radius: 2px;
}

.partner-logo {
  max-height: 80px;     
  max-width: 200px;     
  width: auto;            
  height: auto;
  margin-bottom: 1rem;
  transition: transform 0.3s ease, filter 0.3s ease;
}
.partner-logo:hover {
  transform: scale(1.05);
  filter: brightness(1.1);
}


/* 📱 Мобильная адаптация */
@media (max-width: 700px) {
  #partners {
    padding: 3rem 1rem;
  }

  #partners h2 {
    font-size: 1.6rem;
  }

  .partner-logo {
    max-height: 64px;
  }
}


/* 📱 Телефоны */
@media (max-width: 700px) {
  .container.hero-inner {
    flex-direction: column-reverse;
    align-items: center;
    text-align: center;
    gap: 1.2rem;
  }

  .hero-left, .hero-right {
    flex: 1 1 100%;
    max-width: 100%;
  }

  .hero-title { font-size: 1.8rem; }
  .hero-sub { font-size: 0.98rem; }

  .btn-cta {
    width: 100%;
    max-width: none;
    text-align: center;
    margin-bottom: 0.5rem;
    padding: 10px 16px;
    font-size: 0.95rem;
  }

  .hero-ctas { justify-content:center; gap:10px; }

  .features-grid { grid-template-columns: 1fr; gap: 12px; }

  .marquee-track { font-size: 0.95rem; animation-duration: 24s; }

  .float-card { display: none; }

  .intro-title { font-size: 1.6rem; }
}


