/* ═══════════════════════════════════════════════════════════════════════════
   VOTAVIS — Waitlist styles
   Matches existing app design: black bg, #635bff accent, Bricolage display +
   Be Vietnam Pro body. No external assets except Google Fonts.
   ═══════════════════════════════════════════════════════════════════════════ */

:root{
  --bg:#000;
  --surface:#0a0a0a;
  --surface-2:#111;
  --accent:#635bff;
  --accent-soft:rgba(99,91,255,.1);
  --accent-line:rgba(99,91,255,.2);
  --green:#22c55e;
  --danger:#f43f5e;
  --t1:#fff;
  --t2:rgba(255,255,255,.65);
  --t3:rgba(255,255,255,.35);
  --t4:rgba(255,255,255,.2);
  --border:rgba(255,255,255,.07);
  --serif:'Bricolage Grotesque',sans-serif;
  --sans:'Be Vietnam Pro',sans-serif;
  --easing:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  color-scheme:dark;
}

body{
  background:var(--bg);
  color:var(--t1);
  font-family:var(--sans);
  font-size:14px;
  line-height:1.5;
  font-weight:400;
  min-height:100vh;
  display:flex;flex-direction:column;
  padding:env(safe-area-inset-top) 24px env(safe-area-inset-bottom);
  position:relative;
  overflow-x:hidden;
}

/* Soft accent glow in the top-left */
body::before{
  content:"";
  position:fixed;
  top:-30vh;left:-20vw;
  width:80vw;height:80vh;
  background:radial-gradient(circle, rgba(99,91,255,.08) 0%, transparent 60%);
  pointer-events:none;
  z-index:0;
}

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}

.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;
}

.wrap{
  width:100%;max-width:520px;
  margin:0 auto;
  flex:1;
  display:flex;flex-direction:column;justify-content:center;
  padding:48px 0 32px;
  position:relative;z-index:1;
}

/* ─────────── Header / wordmark ─────────── */
.top{
  text-align:center;
  margin-bottom:8px;
  animation:rise .8s var(--easing) both;
}
.wordmark{
  font-family:var(--serif);
  font-size:42px;
  font-weight:600;
  letter-spacing:-.025em;
  line-height:1;
  color:var(--t1);
  margin:0 0 6px;
}
.wordmark em{font-style:normal;color:var(--t1)}
.tagline{
  font-size:11px;
  color:var(--t3);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  margin:0;
}

/* ─────────── Hero ─────────── */
.hero{
  text-align:center;
  margin:56px 0 36px;
}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(34px,6.5vw,46px);
  font-weight:500;
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0 0 20px;
  animation:rise .8s var(--easing) both;
  animation-delay:.1s;
}
.hero h1 em{font-style:normal;color:var(--accent)}
.lede{
  font-size:16px;
  color:var(--t2);
  line-height:1.55;
  max-width:420px;
  margin:0 auto;
  animation:rise .8s var(--easing) both;
  animation-delay:.2s;
}

/* ─────────── Form ─────────── */
.form{
  animation:rise .8s var(--easing) both;
  animation-delay:.3s;
}
.field{margin-bottom:14px}
.input{
  width:100%;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  color:var(--t1);
  font:inherit;
  font-size:15px;
  padding:16px 18px;
  transition:border-color .2s,background .2s;
}
.input:focus{
  outline:2px solid var(--accent);
  outline-offset:0;
  border-color:var(--accent);
  background:var(--surface-2);
}
.input:focus:not(:focus-visible){outline:none}
.input::placeholder{color:var(--t3)}
textarea.input{
  resize:none;
  min-height:84px;
  line-height:1.5;
  font-family:inherit;
}

.submit{
  width:100%;
  background:var(--accent);
  color:var(--t1);
  font-size:15px;
  font-weight:600;
  padding:16px;
  border-radius:12px;
  margin-top:6px;
  transition:transform .15s var(--easing),filter .2s,opacity .2s;
}
.submit:hover{filter:brightness(1.08)}
.submit:active{transform:scale(.98)}
.submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.submit:focus-visible{outline:2px solid var(--t1);outline-offset:2px}

.err{
  font-size:13px;
  color:var(--danger);
  margin:10px 0 0;
  text-align:center;
  min-height:18px;
  opacity:0;
  transition:opacity .2s;
}
.err.on{opacity:1}

/* Honeypot — hidden from real users, visible to dumb bots */
.hp{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
  opacity:0;
}

/* ─────────── Bottom ─────────── */
.bottom{
  margin-top:24px;
  text-align:center;
  animation:rise .8s var(--easing) both;
  animation-delay:.4s;
}
.trust{
  font-size:12px;
  color:var(--t3);
  margin:0;
  letter-spacing:.01em;
}

/* ─────────── Success ─────────── */
.success{
  text-align:center;
  padding:8px 0;
  animation:rise .7s var(--easing) both;
}
.success-mark{
  width:72px;height:72px;
  margin:0 auto 28px;
  border-radius:50%;
  background:var(--accent-soft);
  border:1px solid var(--accent-line);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
}
.success h1{
  font-family:var(--serif);
  font-size:36px;
  font-weight:500;
  letter-spacing:-.02em;
  line-height:1.1;
  margin:0 0 16px;
}
.success h1 em{font-style:normal;color:var(--accent)}
.success p{
  font-size:15px;
  color:var(--t2);
  line-height:1.55;
  max-width:380px;
  margin:0 auto 20px;
}
.success .signoff{
  font-size:13px;
  color:var(--t3);
  margin-top:24px;
}

/* ─────────── Page footer ─────────── */
.page-foot{
  text-align:center;
  padding:32px 24px 24px;
  position:relative;z-index:1;
}
.page-foot p{
  margin:0;
  color:var(--t3);
  font-size:12px;
  letter-spacing:.02em;
}
.page-foot a{
  color:var(--t2);
  transition:color .2s;
}
.page-foot a:hover{color:var(--accent)}

/* ─────────── Helpers ─────────── */
.hide{display:none}

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

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

@media (max-width:480px){
  body{padding:env(safe-area-inset-top) 20px env(safe-area-inset-bottom)}
  .wrap{padding:32px 0 24px}
  .wordmark{font-size:36px}
  .hero{margin:40px 0 28px}
  .success h1{font-size:30px}
}
