:root {
  --lp-bg: #0a0a0a;
  --lp-bg-soft: #101113;
  --lp-text: #f5f0e8;
  --lp-text-muted: rgba(245, 240, 232, 0.74);
  --lp-text-faint: rgba(245, 240, 232, 0.58);
  --lp-accent: #e8b35d;
  --lp-accent-strong: #f2cb8d;
  --lp-border: rgba(245, 240, 232, 0.26);
  --lp-focus: #ffd992;
  --lp-status-ok: #68c48e;
  --lp-status-error: #f39b8f;
  --lp-shadow: 0 22px 70px rgba(0, 0, 0, 0.45);
  --lp-font-body: "Avenir Next", "Söhne", "Helvetica Neue", "Nimbus Sans", sans-serif;
  --lp-font-mark: "Iowan Old Style", "Libre Baskerville", serif;
  --lp-space-2: 0.5rem;
  --lp-space-3: 0.75rem;
  --lp-space-4: 1rem;
  --lp-space-5: 1.25rem;
  --lp-space-6: 1.5rem;
  --lp-space-8: 2rem;
  --lp-space-10: 2.5rem;
  --lp-space-12: 3rem;
  --lp-space-16: 4rem;
  --lp-radius-pill: 999px;
  --lp-radius-field: 14px;
  --lp-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --lp-dur-fast: 160ms;
  --lp-dur-base: 280ms;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  color: var(--lp-text);
  font-family: var(--lp-font-body);
  line-height: 1.5;
  background:
    radial-gradient(circle at 15% 15%, rgba(232, 179, 93, 0.13), transparent 38%),
    radial-gradient(circle at 85% 88%, rgba(232, 179, 93, 0.09), transparent 42%),
    linear-gradient(180deg, var(--lp-bg) 0%, var(--lp-bg-soft) 100%);
}

.landing {
  width: min(100%, 68rem);
  margin: 0 auto;
  min-height: 100dvh;
  padding: clamp(var(--lp-space-6), 4vw, var(--lp-space-16));
  display: grid;
  place-items: center;
}

.hero {
  width: min(100%, 42rem);
  display: grid;
  gap: var(--lp-space-5);
  text-align: center;
  animation: hero-enter 700ms var(--lp-ease);
}

.wordmark {
  margin: 0;
  font-family: var(--lp-font-mark);
  font-size: clamp(1rem, 0.86rem + 0.6vw, 1.3rem);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--lp-accent-strong);
}

h1 {
  margin: 0;
  font-size: clamp(2rem, 1.05rem + 3.9vw, 4.3rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
  text-wrap: balance;
}

.subline {
  margin: 0;
  font-size: clamp(1.04rem, 0.95rem + 0.45vw, 1.32rem);
  color: var(--lp-text-muted);
  text-wrap: pretty;
}

.waitlist-form {
  margin-top: var(--lp-space-3);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--lp-space-3);
  align-items: center;
}

.waitlist-form input[type="email"] {
  width: 100%;
  border: 1px solid var(--lp-border);
  background: rgba(245, 240, 232, 0.04);
  color: var(--lp-text);
  border-radius: var(--lp-radius-field);
  padding: 0.92rem 1rem;
  font-size: 1rem;
  box-shadow: var(--lp-shadow);
}

.waitlist-form input::placeholder {
  color: var(--lp-text-faint);
}

.waitlist-form button {
  border: 1px solid #f2cb8d;
  background: linear-gradient(180deg, #edbf79 0%, #d89e49 100%);
  color: #1a1208;
  border-radius: var(--lp-radius-pill);
  padding: 0.9rem 1.3rem;
  font-size: 1rem;
  font-weight: 720;
  letter-spacing: 0.01em;
  transition:
    transform var(--lp-dur-fast) var(--lp-ease),
    filter var(--lp-dur-fast) var(--lp-ease),
    box-shadow var(--lp-dur-fast) var(--lp-ease);
}

.waitlist-form button:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.waitlist-form button:disabled {
  transform: none;
  filter: saturate(0.6);
  cursor: not-allowed;
}

.waitlist-form input:focus-visible,
.waitlist-form button:focus-visible {
  outline: 2px solid var(--lp-focus);
  outline-offset: 2px;
}

.microline {
  margin: 0;
  color: var(--lp-text-faint);
  font-size: 0.92rem;
  letter-spacing: 0.01em;
}

.status {
  margin: 0;
  min-height: 1.2rem;
  font-size: 0.92rem;
}

.status[data-state="success"] {
  color: var(--lp-status-ok);
}

.status[data-state="error"] {
  color: var(--lp-status-error);
}

.status[data-state="info"] {
  color: var(--lp-text-muted);
}

.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

@media (max-width: 45rem) {
  .landing {
    padding: clamp(var(--lp-space-4), 6vw, var(--lp-space-10));
  }

  .hero {
    gap: var(--lp-space-4);
  }

  .waitlist-form {
    grid-template-columns: 1fr;
  }

  .waitlist-form button {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
  }
}

@keyframes hero-enter {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
