.section {
  padding-block: var(--space-64);
}

.section__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
  margin-bottom: var(--space-32);
}

.section__header--center {
  text-align: center;
  align-items: center;
}

.section__header--split {
  flex-direction: column;
}

.section__header-aside {
  margin-top: var(--space-16);
}

.section__cta {
  margin-top: var(--space-32);
}

.section__cta--center {
  text-align: center;
}

.hero {
  padding-block: var(--space-80);
}

.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: center;
}

.hero__eyebrow {
  font-size: var(--text-sm);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin-bottom: var(--space-16);
}

.hero__lead {
  margin-bottom: var(--space-16);
}

.hero__sub {
  margin-bottom: var(--space-24);
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-bottom: var(--space-16);
}

.hero__meta {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

.hero__image-wrapper {
  max-width: 520px;
  margin-inline: auto;
}

.hero__media {
  min-height: 260px;
}

.section--portfolio {
  background-color: var(--color-surface);
}

.portfolio__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: stretch;
}

.portfolio__media {
  min-height: 260px;
}

.portfolio__overlay {
  display: flex;
  align-items: flex-end;
}

.portfolio__overlay-content {
  padding: var(--space-24);
}

.portfolio__tag {
  font-size: var(--text-sm);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-neutral-200);
  margin-bottom: var(--space-16);
}

.portfolio__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-24);
}

.section--artists {
  background-color: var(--color-surface-alt);
}

.artists__grid {
  margin-top: var(--space-24);
}

.artists__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.artists__media {
  aspect-ratio: 4 / 5;
}

.artists__name {
  font-size: var(--text-lg);
  margin-bottom: var(--space-4);
}

.artists__role {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin-bottom: var(--space-12);
}

.section--hygiene {
  background-color: var(--color-background);
}

.hygiene__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: flex-start;
}

.hygiene__list,
.services__list,
.atmosphere__list,
.resources__list {
  list-style: none;
  margin-top: var(--space-16);
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.hygiene__list li::before,
.services__list li::before,
.atmosphere__list li::before,
.resources__list li::before {
  content: " b7";
  margin-right: var(--space-8);
  color: var(--color-text-soft);
}

.hygiene__link {
  margin-top: var(--space-24);
}

.section--services {
  background-color: var(--color-surface);
}

.services__grid {
  margin-top: var(--space-16);
}

.services__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.section--atmosphere {
  background-color: var(--color-background);
}

.atmosphere__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: flex-start;
}

.atmosphere__highlights {
  height: 100%;
}

.section--booking {
  background-color: var(--color-surface-alt);
}

.booking__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: flex-start;
}

.booking__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-24);
}

.booking__steps {
  margin-top: var(--space-16);
  padding-left: 1.25rem;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.section--news {
  background-color: var(--color-background);
}

.news__grid {
  margin-top: var(--space-16);
}

.news__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.news__meta {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-soft);
}

.section--resources {
  background-color: var(--color-surface);
}

.resources__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: var(--space-32);
  align-items: flex-start;
}

.resources__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-24);
}

.section--newsletter {
  background-color: var(--color-background);
  padding-block: var(--space-64);
}

.newsletter__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.2fr);
  gap: var(--space-32);
  align-items: center;
}

.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.newsletter__form-row {
  display: flex;
  gap: var(--space-12);
}

.newsletter__hint {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
}

.newsletter__social {
  margin-top: var(--space-24);
}

.newsletter__social-label {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin-bottom: var(--space-12);
}

.newsletter__social-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
}

@media (max-width: 1024px) {
  .hero__grid,
  .portfolio__grid,
  .hygiene__grid,
  .atmosphere__grid,
  .booking__grid,
  .resources__grid,
  .newsletter__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero__image-wrapper,
  .hero__content {
    max-width: 640px;
    margin-inline: auto;
  }

  .section__header--split {
    flex-direction: column;
  }

  .section__header-aside {
    align-self: flex-start;
  }
}

@media (max-width: 640px) {
  .section {
    padding-block: var(--space-48);
  }

  .hero {
    padding-block: var(--space-64);
  }

  .hero__actions,
  .portfolio__links,
  .booking__actions,
  .newsletter__form-row,
  .newsletter__social-links {
    flex-direction: column;
    align-items: stretch;
  }

  .newsletter__form-row .btn {
    width: 100%;
  }
}
