
.hero {
  position: relative;       /* для абсолютного позиционирования видео и градиента */
  width: calc(100% - 10px); /* ширина с учётом 5px отступов с каждой стороны */
  height: calc(90vh - 10px); /* высота экрана минус отступы */
  margin: 5px;             /* визуальные отступы сверху/снизу/слева/справа */
  display: flex;           /* flex для выравнивания контента */
  align-items: flex-end;   /* контент прижат к низу */
  justify-content: flex-start; /* контент прижат к левому краю */
  padding: 10px 10px 40px 40px; /* внутренние отступы под текст */
  box-sizing: border-box;  /* учитываем padding в размере блока */
  border-radius: 20px;     /* скругление углов */
  overflow: hidden;        /* видео и градиент не выходят за блок */
}

/* Видео на заднем фоне */
.hero__video {
  position: absolute;      /* поверх блока, ниже контента */
  top: 0;
  left: 0;
  width: 100%;             /* растягиваем на весь блок */
  height: 100%;
  object-fit: cover;       /* масштабируем видео без искажений */
  object-position: center; /* центрируем видео */
  z-index: 0;              /* видео под контентом */
  filter: brightness(0.95); /* чуть затемнённое видео */
  border-radius: 20px;     /* совпадает с hero */
}

/* Градиент для затемнения видео */
.hero::after {
  content: "";
  position: absolute;
  inset: 0; /* растягиваем на весь блок */
  background: linear-gradient(135deg, rgba(0,0,0,0.25), rgba(0,0,0,0.6));
  z-index: 1;               /* поверх видео, под текстом */
  border-radius: 20px;      /* совпадает с hero */
  pointer-events: none;     /* клики проходят сквозь градиент */
}

/* Контент внутри hero */
.hero__content {
  position: relative;       /* поверх видео и градиента */
  z-index: 2;               /* самый верхний слой */
  max-width: 1000px;         /* ограничиваем ширину текста */
  animation: fadeUp 0.9s ease both; /* плавное появление текста */
  margin-left: 40px;        /* отступ слева на десктопе */
  margin-bottom: 24px;      /* отступ от низа блока */
  text-align: left;         /* текст по левому краю */
}

/* Заголовок */
.hero__title {
  margin: 0 0 0.6rem 0;     /* нижний отступ для описания */
  font-weight: 900;
  line-height: 1.05;
  font-size: clamp(26px, 4vw, 56px); /* адаптивный размер */
  text-shadow: 0 6px 30px rgba(0, 0, 0, 0.45); /* тень для читаемости */
  color: #fff;              /* белый текст */
  width: 100%;          /* заголовок займёт всю ширину контейнера */
  max-width: 1000px; 
}
.hero__title span { 
  color: #FFD84C;           /* выделение части текста */
}

/* Описание */
.hero__desc {
  font-weight: 300;
  color: rgba(255, 255, 255, 0.9); /* чуть прозрачный текст */
  font-size: clamp(15px, 2vw, 20px);
  line-height: 1.5;
}

/* Логотип */
.header-logo {
  position: absolute;
  top: 40px;                /* отступ сверху */
  margin-left: 0px;         /* левый отступ */
  width: 160px;
  height: auto;
  z-index: 2;               /* над видео и градиентом */
}

.hero__btn-wrapper {
  margin-top: 30px;
  margin-bottom: 20px;
  text-align: left;        /* выравниваем контент по левому краю */
  margin-left: 0px;       /* такой же отступ, как у hero__content */
}

.hero__btn {
  display: inline-block;
  background: #FFD700;
  color: #000;
  font-weight: 700;
  font-size: 18px;
  padding: 16px 32px;
  border-radius: 8px;
  text-decoration: none;
  transition: 0.3s ease;
}

.hero__btn:hover {
  background: #ffcc00;
  transform: translateY(-2px);
}


/* Анимация появления текста */
@keyframes fadeUp {
  from { transform: translateY(10px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

/* ==============================
   МОБИЛЬНАЯ ВЕРСИЯ
============================== */
@media (max-width: 768px) {
  .hero__content {
    margin-left: 0px; /* возвращаем текст к левому краю */
	padding-right: 10px;     /* отступ справа */
  }
  
  .hero__btn-wrapper {
  margin-top: 30px;
  margin-bottom: 10px;
  text-align: left;        /* выравниваем контент по левому краю */
  margin-left: 0px;       /* такой же отступ, как у hero__content */
}
}