:root {
  --bg: #07040f;
  --bg-deep: #020108;
  --card: #151026;
  --card-hi: #23183d;
  --card-soft: #1b1431;
  --accent: #f4c35d;
  --accent-2: #8ce9ff;
  --accent-3: #ff7da0;
  --accent-4: #b796ff;
  --text-hi: #fff5e4;
  --text-mid: #e4d7f7;
  --text-lo: #a695c6;
  --stroke: rgba(255, 255, 255, 0.18);

  --gradient-nebula: linear-gradient(
    135deg,
    #241641 0%,
    #07040f 50%,
    #1d1137 100%
  );
  --gradient-aurora: linear-gradient(
    135deg,
    #f4c35d 0%,
    #8ce9ff 50%,
    #ff7da0 100%
  );

  --font-display: "Cinzel", serif;
  --font-secondary: "Cormorant Garamond", serif;
  --font-ui: "Sora", sans-serif;
  --font-body: "Manrope", sans-serif;

  --max-column: 560px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: var(--bg-deep);
  color: var(--text-mid);
  font-family: var(--font-body);
  font-size: 16.5px;
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  position: relative;
  overflow-x: hidden;
  background:
    radial-gradient(
      ellipse at top,
      rgba(183, 150, 255, 0.18) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse at bottom right,
      rgba(255, 125, 160, 0.12) 0%,
      transparent 60%
    ),
    var(--gradient-nebula);
  background-attachment: fixed;
}

.starfield {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(1px 1px at 12% 18%, rgba(255, 245, 228, 0.8), transparent 60%),
    radial-gradient(1px 1px at 82% 12%, rgba(140, 233, 255, 0.7), transparent 60%),
    radial-gradient(1.5px 1.5px at 24% 78%, rgba(244, 195, 93, 0.65), transparent 60%),
    radial-gradient(1px 1px at 68% 64%, rgba(255, 245, 228, 0.55), transparent 60%),
    radial-gradient(1px 1px at 92% 88%, rgba(183, 150, 255, 0.6), transparent 60%),
    radial-gradient(1px 1px at 36% 36%, rgba(255, 245, 228, 0.45), transparent 60%),
    radial-gradient(1.5px 1.5px at 54% 22%, rgba(244, 195, 93, 0.5), transparent 60%),
    radial-gradient(1px 1px at 8% 62%, rgba(140, 233, 255, 0.45), transparent 60%);
  opacity: 0.9;
}

.stage {
  position: relative;
  max-width: var(--max-column);
  margin: 0 auto;
  padding: clamp(64px, 14vh, 140px) 24px 64px;
  display: flex;
  flex-direction: column;
  gap: 56px;
  align-items: center;
  text-align: center;
}

.mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.wordmark {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.6px;
  font-size: clamp(40px, 7vw, 58px);
  background: var(--gradient-aurora);
  background-size: 200% 200%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: aurora-drift 18s ease-in-out infinite;
}

@keyframes aurora-drift {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

.tagline {
  margin: 0;
  font-family: var(--font-secondary);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(18px, 2.6vw, 22px);
  color: var(--text-hi);
  letter-spacing: 0.2px;
}

.intro p {
  margin: 0;
  color: var(--text-mid);
  font-size: clamp(15.5px, 1.8vw, 17px);
  line-height: 1.72;
}

.waitlist {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

.eyebrow {
  margin: 0;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--accent);
}

.subcopy {
  margin: 0;
  color: var(--text-mid);
  font-size: 15.5px;
  line-height: 1.62;
  max-width: 44ch;
}

.waitlist-form {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
}

.waitlist-form input[type="email"] {
  width: 100%;
  padding: 16px 20px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(27, 20, 49, 0.74);
  color: var(--text-hi);
  font-family: var(--font-body);
  font-size: 15.5px;
  transition: border-color 160ms ease, background 160ms ease;
}

.waitlist-form input[type="email"]::placeholder {
  color: var(--text-lo);
}

.waitlist-form input[type="email"]:focus {
  outline: none;
  border-color: var(--accent-2);
  background: rgba(27, 20, 49, 0.92);
}

.cta {
  padding: 16px 28px;
  border-radius: 999px;
  border: none;
  background: var(--accent);
  color: #0d0718;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 15.5px;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: transform 160ms ease, filter 160ms ease, opacity 160ms ease;
}

.cta:hover:not(:disabled) {
  filter: brightness(1.08);
  transform: translateY(-1px);
}

.cta:focus-visible {
  outline: 2px solid var(--accent-2);
  outline-offset: 3px;
}

.cta:disabled {
  opacity: 0.6;
  cursor: default;
}

.status {
  margin: 6px 0 0;
  min-height: 1.2em;
  font-size: 14px;
  color: var(--text-lo);
}

.status[data-tone="ok"] {
  color: var(--accent-2);
}

.status[data-tone="error"] {
  color: var(--accent-3);
}

.footer {
  margin-top: 32px;
  color: var(--text-lo);
  font-size: 13.5px;
  font-style: italic;
  font-family: var(--font-secondary);
}

.footer p {
  margin: 0;
}

.footer .version {
  margin-top: 10px;
  font-family: var(--font-ui);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--text-lo);
  opacity: 0.6;
}

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

@media (prefers-reduced-motion: reduce) {
  .wordmark {
    animation: none;
  }
}

/* ---- Legal + contact pages ---- */

.reading {
  position: relative;
  max-width: 680px;
  margin: 0 auto;
  padding: clamp(64px, 10vh, 120px) 24px 64px;
}

.legal {
  color: var(--text-mid);
  text-align: left;
}

.legal h1 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.4px;
  font-size: clamp(32px, 5vw, 44px);
  margin: 0 0 8px;
  background: var(--gradient-aurora);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.legal h2 {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--accent);
  margin: 40px 0 14px;
}

.legal .updated {
  margin: 0 0 28px;
  font-family: var(--font-secondary);
  font-style: italic;
  color: var(--text-lo);
  font-size: 15px;
}

.legal p,
.legal li {
  font-size: 15.5px;
  line-height: 1.72;
}

.legal ul {
  padding-left: 1.25em;
}

.legal li {
  margin-bottom: 10px;
}

.legal a {
  color: var(--accent-2);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 160ms ease;
}

.legal a:hover {
  color: var(--accent);
}

.legal code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.92em;
  background: rgba(27, 20, 49, 0.7);
  border: 1px solid var(--stroke);
  border-radius: 6px;
  padding: 1px 6px;
}

.legal strong {
  color: var(--text-hi);
}

.page-footer {
  margin: 56px 0 0;
  text-align: center;
  color: var(--text-lo);
  font-family: var(--font-ui);
  font-size: 13px;
  letter-spacing: 0.3px;
}

.page-footer a,
.page-footer a:link,
.page-footer a:visited {
  color: var(--text-lo);
  text-decoration: none;
  transition: color 160ms ease;
}

.page-footer a:hover,
.page-footer a:focus-visible {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.page-footer .dot {
  margin: 0 10px;
  opacity: 0.5;
}

/* ---- Contact form ---- */

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 24px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
}

.field-label {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--text-lo);
}

.contact-form input[type="email"],
.contact-form textarea {
  width: 100%;
  padding: 14px 18px;
  border-radius: 18px;
  border: 1px solid var(--stroke);
  background: rgba(27, 20, 49, 0.74);
  color: var(--text-hi);
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.55;
  transition: border-color 160ms ease, background 160ms ease;
  resize: vertical;
}

.contact-form input[type="email"]::placeholder,
.contact-form textarea::placeholder {
  color: var(--text-lo);
}

.contact-form input[type="email"]:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--accent-2);
  background: rgba(27, 20, 49, 0.92);
}

.contact-form .cta {
  align-self: flex-start;
}

/* Footer links on home */

.footer .home-links {
  margin-top: 18px;
  font-family: var(--font-ui);
  font-style: normal;
  font-size: 12.5px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-lo);
}

.footer .home-links a,
.footer .home-links a:link,
.footer .home-links a:visited {
  color: var(--text-lo);
  text-decoration: none;
  transition: color 160ms ease;
}

.footer .home-links a:hover,
.footer .home-links a:focus-visible {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.footer .home-links .dot {
  margin: 0 8px;
  opacity: 0.5;
}
