/* ===========================================================================
   Hero - главная страница
   Фото-фон с градиентом, закруглённые нижние углы, шапка внутри секции.
   =========================================================================== */

.hero {
  position: relative;
  overflow: hidden;
  border-radius: 0 0 var(--radius-2xl) var(--radius-2xl);
  display: flex;
  flex-direction: column;
  padding-inline: 40px;
}

/* Фоновое фото */
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--media-image);
  background-size: cover;
  background-position: center;
}

/* Градиент: плотный navy слева, прозрачнее справа - фото проступает */
.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to right,
    rgba(47,65,86,.82) 0%,
    rgba(47,65,86,.55) 55%,
    rgba(47,65,86,.30) 100%
  );
}

/* Декоративная пунктирная волна-маршрут */
.hero__wave {
  position: absolute;
  left: -20px;
  top: 270px;
  width: clamp(900px, 100%, 1420px);
  transform: rotate(10deg);
  transform-origin: 0 50%;
  z-index: 2;
  color: var(--route-line);
  pointer-events: none;
  user-select: none;
}

.hero__wave svg {
  display: block;
  width: 100%;
}

/* Шапка поверх фона — hero-padding убирает лишний отступ из .container */
.hero .site-header {
  position: relative;
  z-index: 10;
}

.hero .site-header__inner {
  padding-inline: 0;
  padding-block: 30px;
}

/* Контент: левая + правая колонки */
.hero__content {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: var(--container);
  align-self: center;
  display: grid;
  grid-template-columns: 1fr 1.26fr;
  gap: 48px;
  align-items: stretch;
  padding-block: 48px;
}

/* ---- Левая колонка ------------------------------------------------------- */

.hero__left {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 24px;
}

.hero__left-top {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 10px;
}

.hero__eyebrow { color: var(--text-inverse-dim); }
.hero__eyebrow::before { background: var(--brand-blue); }

.hero__title {
  font-size: clamp(36px, 3.6vw, 52px);
  font-weight: var(--fw-bold);
  line-height: 1.16;
  letter-spacing: 0;
  color: var(--white);
}

.hero__title .highlight {
  background: var(--sky);
  color: var(--navy);
  display: inline;
}

.hero__bottom {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 10px;
}

.hero__lead {
  font-size: var(--fs-lead);
  line-height: 26px;
  color: var(--text-inverse-dim);
}

.hero__btn {
  align-self: flex-start;
  font-size: var(--fs-body);
  padding: 14px 14px 14px 28px;
  gap: var(--space-3);
}

/* Круглый контейнер со стрелкой внутри кнопки */
.hero__btn-arrow {
  width: 30px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--navy);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ---- Правая колонка: ступенчатые карточки ------------------------------- */

.hero__right {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.hero__card-row             { display: flex; align-items: center; }
.hero__card-row--top        { justify-content: flex-end; padding: 10px; }
.hero__card-row--mid        { justify-content: center; padding: 10px; }
.hero__card-row--bot        { justify-content: flex-start; padding: 10px; }

.hero__card {
  position: relative;
  width: 285px;
  background: rgba(30,44,60,.70);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 44px;
  overflow: hidden;
}

/* Декоративный эллипс в углу карточки */
.hero__card-bubble {
  position: absolute;
  width: 65px;
  aspect-ratio: 1;
  right: -32px;
  top: -30px;
  pointer-events: none;
}

.hero__card-bubble svg { display: block; width: 100%; }

.hero__card-title {
  font-size: var(--fs-lead-sm);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  color: var(--text-inverse);
}

.hero__card-body {
  font-size: var(--fs-sm);
  line-height: 1.47;
  color: var(--text-inverse-dim);
}

/* ---- Адаптив ------------------------------------------------------------- */

@media (max-width: 1024px) {
  .hero { padding-inline: 24px; }

  .hero__content {
    grid-template-columns: 1fr;
    padding-block: 24px;
    padding-bottom: 48px;
    gap: 32px;
  }

  .hero__right {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--space-4);
  }

  .hero__card-row {
    justify-content: center;
    flex: 1 1 200px;
  }

  .hero__card { width: 100%; }

  .hero__wave {
    top: 350px;
    opacity: .35;
  }
}

@media (max-width: 767px) {
  .hero { padding-inline: 16px; }

  .hero__title { font-size: clamp(32px, 8vw, 48px); }

  .hero__content { gap: 24px; }
}

@media (max-width: 480px) {
  .hero__right { flex-direction: column; }

  .hero__card-row {
    flex: unset;
    padding: 0;
  }

  .hero__card { gap: 42px; }
}
