.page-hero {
  border-bottom: 1px solid var(--color-border-subtle);
}

.hero-layout {
  display: grid;
  gap: var(--space-8);
}

.hero-content {
  max-width: 640px;
}

.hero-subtitle {
  font-size: var(--font-size-lg);
  color: var(--color-text-soft);
}

.hero-actions {
  margin-top: var(--space-4);
  flex-wrap: wrap;
}

.hero-meta {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.hero-meta-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.hero-media {
  max-width: 520px;
  margin-inline: auto;
}

.section-header {
  margin-bottom: var(--space-4);
}

.section-header-centered {
  text-align: center;
  max-width: 720px;
  margin-inline: auto;
}

.releases-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4);
}

.visual-layout {
  display: grid;
  gap: var(--space-4);
}

.visual-block {
  min-height: 220px;
}

.accessories-grid,
.selection-grid,
.upcoming-grid,
.offers-grid,
.news-grid {
  gap: var(--space-4);
}

.genres-section {
  background: radial-gradient(circle at top, #10152b 0, #05060a 55%, #020308 100%);
}

.genres-grid {
  display: grid;
  gap: var(--space-4);
}

.selection-france-layout {
  display: grid;
}

.trailers-layout {
  display: grid;
  gap: var(--space-6);
  align-items: center;
}

.trailers-list {
  display: grid;
  gap: var(--space-4);
}

.trailers-media {
  max-width: 520px;
  margin-inline: auto;
}

.launch-offers-section {
  border-block: 1px solid var(--color-border-subtle);
}

.news-layout {
  display: grid;
}

@media (min-width: 768px) {
  .hero-layout {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2.5fr);
    align-items: center;
  }

  .visual-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .genres-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .selection-france-layout {
    grid-template-columns: minmax(0, 3fr);
  }

  .trailers-layout {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2.5fr);
  }

  .news-layout {
    grid-template-columns: minmax(0, 3fr);
  }
}

@media (max-width: 480px) {
  .hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-actions .button {
    width: 100%;
    justify-content: center;
  }
}
