.demo-home {
  gap: clamp(28px, 5vw, 48px);
  padding: 0 0 34px;
}

.demo-home-copy {
  min-height: min(640px, calc(100vh - 96px));
  align-items: center;
  gap: clamp(36px, 6vw, 72px);
  padding: clamp(78px, 12vh, 138px) 0 clamp(54px, 8vh, 94px);
}

.demo-home-copy > div:first-child {
  display: grid;
  align-content: center;
  justify-items: start;
}

.demo-home-copy h1 {
  max-width: 920px;
  font-size: clamp(52px, 7.2vw, 94px);
  line-height: 0.96;
}

.demo-home-copy p {
  max-width: 670px;
  margin-top: 28px;
  font-size: 20px;
  line-height: 1.55;
}

.demo-home-copy .hero-actions {
  margin-top: 36px;
}

.demo-home-object {
  align-self: center;
  justify-self: end;
  width: min(100%, 440px);
  box-shadow: var(--shadow-soft);
}

.app-title-row.spacious-page-hero,
.experience-hero,
.event-hero {
  min-height: min(560px, calc(100vh - 148px));
  align-items: center;
  margin-bottom: 0;
  padding: clamp(78px, 12vh, 136px) 0 clamp(52px, 8vh, 92px);
}

.app-title-row.spacious-page-hero {
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
}

.app-title-row.spacious-page-hero h1,
.experience-hero h1 {
  max-width: 930px;
  font-size: clamp(52px, 7vw, 92px);
  line-height: 0.96;
}

.app-title-row.spacious-page-hero p,
.experience-hero-copy > p {
  max-width: 720px;
  margin-top: 28px;
  font-size: 20px;
  line-height: 1.56;
}

.app-title-row.spacious-page-hero > .primary-button,
.app-title-row.spacious-page-hero > .secondary-button {
  justify-self: start;
  margin-top: 36px;
}

.guide-filter-row {
  margin-top: 0;
  margin-bottom: 30px;
}

.experience-landing {
  padding-top: 0;
}

.experience-hero {
  gap: clamp(24px, 5vw, 56px);
}

.experience-landing .experience-hero {
  min-height: 0;
  align-items: start;
  padding: clamp(42px, 6vh, 68px) 0 clamp(28px, 4vh, 44px);
}

.experience-hero-copy {
  min-height: 0;
  border-bottom: 0;
  padding: 0;
}

.experience-landing .experience-hero-copy > p,
.experience-landing .experience-hero-copy .hero-actions {
  margin-top: 0;
}

.event-hero {
  gap: clamp(28px, 5vw, 58px);
}

.event-hero h1 {
  max-width: 900px;
  font-size: clamp(48px, 6vw, 82px);
  line-height: 0.98;
}

.research-page {
  gap: clamp(28px, 5vw, 48px);
  padding-top: 0;
}

.research-hero {
  min-height: min(600px, calc(100vh - 128px));
  align-items: center;
  gap: clamp(34px, 6vw, 72px);
  padding: clamp(78px, 12vh, 140px) 0 clamp(56px, 8vh, 96px);
}

.research-hero-copy {
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.research-hero-copy h1 {
  max-width: 940px;
  font-size: clamp(52px, 7vw, 92px);
  line-height: 0.96;
}

.research-hero-copy p {
  max-width: 720px;
  margin-top: 28px;
  font-size: 20px;
  line-height: 1.56;
}

.research-hero-panel {
  align-self: center;
  box-shadow: var(--shadow-soft);
}

@media (max-width: 1000px) {
  .demo-home-copy,
  .research-hero,
  .app-title-row.spacious-page-hero,
  .experience-hero,
  .event-hero {
    min-height: auto;
    padding-top: clamp(48px, 9vh, 88px);
    padding-bottom: clamp(34px, 7vh, 64px);
  }

  .demo-home-object {
    justify-self: stretch;
    width: 100%;
  }
}

@media (max-width: 660px) {
  .demo-home {
    gap: 18px;
  }

  .demo-home-copy,
  .research-hero,
  .app-title-row.spacious-page-hero,
  .experience-hero,
  .event-hero {
    gap: 22px;
    padding-top: 46px;
    padding-bottom: 30px;
  }

  .demo-home-copy h1,
  .research-hero-copy h1,
  .app-title-row.spacious-page-hero h1,
  .experience-hero h1,
  .event-hero h1 {
    max-width: 100%;
    font-size: 43px;
    line-height: 1.01;
  }

  .demo-home-copy p,
  .research-hero-copy p,
  .app-title-row.spacious-page-hero p,
  .experience-hero-copy > p,
  .event-hero p {
    margin-top: 18px;
    font-size: 16px;
    line-height: 1.45;
  }

  .demo-home-copy .hero-actions,
  .app-title-row.spacious-page-hero > .primary-button,
  .app-title-row.spacious-page-hero > .secondary-button {
    margin-top: 24px;
  }
}
