:root {
  color-scheme: light;
  --page-bg: #fff;
  --text: #111;
  --muted: #5a5a5a;
  --page-pad: clamp(1rem, 2dvh, 1.5rem);
  --page-gap: clamp(0.75rem, 1.6dvh, 1.25rem);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-block-size: 100dvh;
  overflow: hidden;
  background: var(--page-bg);
  color: var(--text);
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

a {
  color: inherit;
}

.page {
  block-size: 100dvh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--page-gap);
  overflow: hidden;
  padding: var(--page-pad);
}

.site-header {
  display: grid;
  place-items: center;
}

.logo {
  inline-size: min(16rem, 64vw);
  max-block-size: 4.75rem;
  block-size: auto;
  display: block;
  object-fit: contain;
}

.hero {
  display: grid;
  grid-template-columns: minmax(18rem, 0.8fr) minmax(0, 1.2fr);
  align-items: stretch;
  gap: clamp(1.5rem, 4vw, 4rem);
  block-size: 100%;
  min-block-size: 0;
}

.copy {
  display: grid;
  align-content: center;
  padding-inline: clamp(0rem, 1vw, 1rem);
}

.copy h1 {
  margin: 0 0 0.75rem;
  font-size: 4rem;
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0;
  max-inline-size: 8ch;
}

.copy p {
  margin: 0;
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  color: var(--muted);
}

.copy a {
  text-underline-offset: 0.18em;
}

.slideshow {
  position: relative;
  min-block-size: 0;
  block-size: 100%;
  inline-size: 100%;
  overflow: clip;
}

.slide {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  display: block;
  border-radius: 1.25rem;
  object-fit: cover;
  opacity: 0;
  transition: opacity 900ms ease;
}

.slide.is-active {
  opacity: 1;
}

@media (max-width: 1100px) {
  .copy h1 {
    font-size: 3.25rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .slide {
    transition: none;
  }
}

@media (max-width: 800px) {
  .page {
    gap: 0.75rem;
    padding: 0.875rem;
  }

  .logo {
    inline-size: min(13rem, 72vw);
    max-block-size: 3.75rem;
  }

  .hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 0.75rem;
  }

  .copy {
    align-content: start;
    padding-inline: 0;
  }

  .copy h1 {
    font-size: 2.2rem;
    max-inline-size: none;
  }

  .copy p {
    font-size: 1rem;
  }

  .slideshow {
    min-block-size: 0;
  }
}

@media (max-height: 650px) {
  .logo {
    max-block-size: 3.5rem;
  }

  .copy h1 {
    font-size: 3rem;
  }
}
