html,
body {
  margin: 0;
  padding: 0;
}

body {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 100vh;
  background: #f5efdc;
}

.intro-text {
  width: 100%;
}

.site-title {
  margin: 0;
  padding: 48px 24px 24px;
  font-family: "Noto Sans", system-ui, sans-serif;
  font-weight: 400;
  font-size: clamp(1.4rem, 3vw, 2.4rem);
  letter-spacing: 0.4em;
  text-align: center;
  text-transform: lowercase;
  color: #464545;
}

.site-tagline {
  display: block;
  margin: 0 auto;
  padding: 0 0 32px;
  border: 0;
  background: transparent;
  font-family: "Noto Sans", system-ui, sans-serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(0.9rem, 1.4vw, 1.05rem);
  text-align: center;
  color: #3f3f3f;
  cursor: pointer;
  text-decoration: none;
}

.site-tagline:hover,
.site-tagline:focus-visible {
  color: #1f1f1f;
  outline: none;
}

.waitlist-form {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: flex-start;
  gap: 8px;
  margin: 0 auto 28px;
  padding: 0 24px;
  min-height: 76px;
  font-family: "Noto Sans", system-ui, sans-serif;
}

.waitlist-form:not(.is-open) {
  visibility: hidden;
  pointer-events: none;
}

.waitlist-input {
  flex: 0 1 280px;
  padding: 10px 14px;
  border: 1px solid #c9c4b1;
  border-radius: 4px;
  background: #fdfaf0;
  font: inherit;
  color: #2f2f2f;
}

.waitlist-input:focus {
  outline: 2px solid #6f7a56;
  outline-offset: 1px;
}

.waitlist-submit {
  padding: 10px 18px;
  border: 1px solid #3f3f3f;
  border-radius: 4px;
  background: #3f3f3f;
  color: #f5efdc;
  font: inherit;
  cursor: pointer;
}

.waitlist-submit:hover,
.waitlist-submit:focus-visible {
  background: #1f1f1f;
}

.waitlist-submit:disabled {
  cursor: default;
  opacity: 0.7;
}

.waitlist-status {
  flex-basis: 100%;
  margin: 4px 0 0;
  font-size: 0.9rem;
  color: #5b625d;
  text-align: center;
}

.homepage {
  position: relative;
  width: 100%;
}

.homepage-image {
  display: block;
  width: 100%;
  height: auto;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 12%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 12%);
}

.mower-video-overlay {
  position: absolute;
  left: 0;
  bottom: 3%;
  width: min(22.4vw, 288px);
  pointer-events: none;
  transform: translateX(-88%);
  animation: mower-drive 88s linear infinite;
}

.mower-video-wobble {
  width: 100%;
  transform-origin: 50% 78%;
  animation: mower-wobble 5.7s ease-in-out infinite;
}

.mower-video {
  display: block;
  width: 100%;
  height: auto;
}

@keyframes mower-drive {
  0%   { transform: translateX(-88%); }
  95%  { transform: translateX(calc(100vw + 30%)); }
  100% { transform: translateX(calc(100vw + 30%)); }
}

@keyframes mower-wobble {
  0%, 12%, 100% { transform: translateY(0) rotate(0deg); }
  16%           { transform: translateY(-1px) rotate(-0.45deg); }
  19%           { transform: translateY(0.5px) rotate(0.35deg); }
  22%           { transform: translateY(0) rotate(0deg); }
  43%           { transform: translateY(0) rotate(0deg); }
  47%           { transform: translateY(-1.6px) rotate(0.55deg); }
  50%           { transform: translateY(0.6px) rotate(-0.35deg); }
  53%           { transform: translateY(0) rotate(0deg); }
  76%           { transform: translateY(0) rotate(0deg); }
  79%           { transform: translateY(-0.8px) rotate(-0.3deg); }
  82%           { transform: translateY(0) rotate(0.2deg); }
  85%           { transform: translateY(0) rotate(0deg); }
}

@media (max-width: 640px) {
  body {
    position: relative;
    min-height: 100svh;
  }

  .intro-text {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 2;
    transform: translateY(-50%);
  }

  .site-title {
    padding: 0 20px 24px;
  }

  .waitlist-form {
    margin-bottom: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mower-video-overlay {
    animation: none;
    transform: translateX(6vw);
  }

  .mower-video-wobble {
    animation: none;
  }
}
