/* Homepage hero — Slice 4 */

.hero {
  padding-block: var(--space-12) var(--space-16);
  min-height: calc(100svh - var(--space-8));
  display: flex;
  align-items: center;
}

@media (min-width: 48rem) {
  .hero {
    padding-block: var(--space-16) var(--space-20);
    min-height: calc(100svh - var(--space-4));
  }
}

.hero__grid {
  width: 100%;
}

@media (min-width: 48rem) {
  .hero__grid.two-column {
    grid-template-columns: 7fr 5fr;
    gap: var(--space-10);
  }
}

@media (min-width: 64rem) {
  .hero__grid.two-column {
    gap: var(--space-12);
  }
}

.hero__blob {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 32rem;
  margin-inline: auto;
}

.hero__blob img {
  width: 100%;
  max-height: min(42vh, 22rem);
  object-fit: contain;
  opacity: 0.88;
  transform: scale(0.94);
  transform-origin: center center;
}

@media (min-width: 48rem) {
  .hero__blob {
    max-width: none;
    margin-inline: 0;
    justify-content: flex-start;
  }

  .hero__blob img {
    max-height: none;
  }
}

.hero__content {
  max-width: 36rem;
}

@media (min-width: 48rem) {
  .hero__content {
    max-width: none;
  }
}

.hero__headline {
  font-family: var(--font-title);
  font-weight: 300;
  font-size: clamp(2rem, 4vw + 1rem, var(--font-size-3xl));
  line-height: var(--line-height-tight);
  color: var(--color-text-on-light);
  margin: 0;
  overflow: visible;
}

.hero__body {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: clamp(var(--font-size-base), 1vw + 0.875rem, var(--font-size-md));
  line-height: var(--line-height-relaxed);
  color: var(--color-text-on-light);
  margin: 0;
}

.hero__cta-row {
  margin-top: var(--space-2);
}

.hero__supporting {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-on-light-muted);
  margin: 0;
  max-width: 28rem;
}

@media (max-width: 47.99rem) {
  .page-home .hero {
    padding-top: var(--space-6);
    min-height: auto;
  }

  .hero__cta-row .button {
    flex: 1 1 100%;
    min-height: 2.75rem;
  }

  .hero__blob img {
    max-height: min(36vh, 18rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero__blob img {
    /* Blob remains visible; SMIL is asset-level — no layout shift */
    max-height: min(38vh, 20rem);
  }
}
