.hero {
  position: relative;
}

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

@media (min-width: 900px) {
  .hero-layout {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
}

.hero-kicker {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}

.hero-subtitle {
  font-size: var(--font-size-md);
  max-width: 34rem;
}

.hero-cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

.hero-footnote {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-8);
  margin-top: var(--space-12);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.hero-footnote-text {
  opacity: 0.9;
}

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

.section-header {
  max-width: 44rem;
  margin-left: auto;
  margin-right: auto;
}

.section-intro {
  font-size: var(--font-size-md);
}

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

.experience-card .experience-list {
  list-style: disc;
  padding-left: 1.2rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.experience-card .experience-list li + li {
  margin-top: var(--space-3);
}

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

@media (min-width: 992px) {
  .atmospherics-layout {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.4fr);
  }
}

.atmospherics-media {
  max-width: 520px;
}

.atmospherics-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-12);
  margin-top: var(--space-12);
}

@media (min-width: 768px) {
  .atmospherics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.atmospheric-item h3 {
  font-family: var(--font-sans);
  font-size: var(--font-size-md);
  text-transform: none;
  letter-spacing: normal;
  margin-bottom: var(--space-3);
}

.atmospherics-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin-top: var(--space-16);
}

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

@media (min-width: 992px) {
  .hosts-layout {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.2fr);
  }
}

.hosts-media {
  max-width: 520px;
  margin-left: auto;
}

.hosts-list {
  list-style: disc;
  padding-left: 1.3rem;
  color: var(--color-text-muted);
}

.hosts-list li + li {
  margin-top: var(--space-4);
}

.hosts-cta {
  margin-top: var(--space-12);
}

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

@media (min-width: 992px) {
  .gallery-layout {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.1fr);
  }
}

.gallery-media {
  max-width: 520px;
  margin-left: auto;
}

.gallery-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

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

.testimonial-card p {
  font-size: var(--font-size-sm);
}

.testimonial-meta {
  margin-top: var(--space-6);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-muted);
}

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

.booking-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-24);
  align-items: start;
}

@media (min-width: 992px) {
  .booking-layout {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.1fr);
  }
}

.booking-benefits {
  list-style: disc;
  padding-left: 1.3rem;
  color: var(--color-text-muted);
  margin: var(--space-8) 0 var(--space-12);
}

.booking-benefits li + li {
  margin-top: var(--space-3);
}

.booking-support {
  font-size: var(--font-size-sm);
  margin-top: var(--space-6);
}

.booking-card-wrapper {
  max-width: 460px;
  margin-left: auto;
}

.booking-summary-list {
  list-style: disc;
  padding-left: 1.2rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.booking-summary-list li + li {
  margin-top: var(--space-3);
}

.booking-privacy {
  font-size: var(--font-size-xs);
}

@media (max-width: 599px) {
  .section-pad {
    padding-top: var(--space-24);
    padding-bottom: var(--space-24);
  }
}
