.section--hero-info {
  padding-top: var(--space-12);
  padding-bottom: var(--space-10);
}

.hero-info-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
}

.hero-info-text h1 {
  margin-bottom: var(--space-4);
}

.hero-info-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.hero-info-figure,
.concept-figure {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
}

.hero-info-figure img,
.concept-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.concept-grid {
  align-items: center;
  gap: var(--space-8);
}

.concept-links,
.zone-links,
.private-links,
.practical-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.concept-link,
.zone-text-link,
.private-text-link,
.gallery-link,
.practical-text-link {
  font-size: var(--font-size-sm);
}

.concept-image-col {
  max-width: 520px;
  margin-left: auto;
}

.events-cta {
  margin-top: var(--space-6);
  display: flex;
  justify-content: center;
}

.private-grid {
  gap: var(--space-8);
}

.gallery-info {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: stretch;
}

.gallery-info-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-3);
}

.practical-grid {
  gap: var(--space-8);
}

.practical-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.practical-list {
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.practical-list span {
  color: var(--color-primary-strong);
  font-weight: 600;
}

.info-final-cta {
  padding-top: var(--space-8);
  padding-bottom: var(--space-10);
}

@media (max-width: 960px) {
  .hero-info-layout {
    grid-template-columns: 1fr;
  }

  .gallery-info {
    grid-template-columns: 1fr;
  }

  .concept-image-col {
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .section--hero-info {
    padding-top: var(--space-10);
  }

  .hero-info-cta {
    justify-content: flex-start;
  }
}
