:root{
  --bg:#f5f1ea;
  --ink:#11100e;
  --muted:rgba(17,16,14,.56);
  --soft:rgba(17,16,14,.12);
}

*{box-sizing:border-box;margin:0;padding:0}

html,body{min-height:100%}

body{
  min-height:100svh;
  background:
    radial-gradient(circle at 50% 34%, rgba(255,255,255,.58), transparent 34%),
    linear-gradient(135deg,#f9f7f3 0%, var(--bg) 58%, #ede6da 100%);
  color:var(--ink);
  font-family:"Inter", system-ui, sans-serif;
  overflow:hidden;
}

.page{
  min-height:100svh;
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:34px;
}

.noise{
  pointer-events:none;
  position:absolute;
  inset:0;
  opacity:.04;
  background-image:
    repeating-radial-gradient(circle at 0 0, #000 0, #000 1px, transparent 1px, transparent 7px);
  mix-blend-mode:multiply;
}

.topbar, footer{
  position:absolute;
  left:34px;
  right:34px;
  display:flex;
  justify-content:space-between;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  z-index:10;
}

.topbar{top:28px}
footer{bottom:28px}

.logo-wrap{
  position:fixed;
  top:76px;
  left:50%;
  transform:translateX(-50%);
  z-index:20;
  pointer-events:none;
}

.logo-mark{
  width:46px;
  height:auto;
  display:block;
  opacity:0;
  filter:drop-shadow(0 10px 18px rgba(17,16,14,.08));
  animation:logoReveal 1.45s cubic-bezier(.2,.8,.2,1) .18s forwards,
            logoFloat 5.8s ease-in-out 1.8s infinite;
}

.hero{
  width:min(620px, 92vw);
  margin:0 auto;
  text-align:center;
  animation:fadeUp 1.3s ease both;
}

.eyebrow{
  margin-bottom:18px;
  font-size:11px;
  letter-spacing:.48em;
  color:var(--muted);
}

h1{
  font-family:"Cormorant Garamond", serif;
  font-weight:500;
  font-size:clamp(52px, 9vw, 96px);
  letter-spacing:.18em;
  line-height:.88;
  margin-left:.18em;
}

.subtitle{
  margin-top:22px;
  font-family:"Cormorant Garamond", serif;
  font-size:clamp(20px, 2.6vw, 28px);
  color:rgba(17,16,14,.72);
  letter-spacing:.03em;
}

.waitlist{
  margin:44px auto 0;
  width:min(410px, 100%);
  display:flex;
  align-items:center;
  border-bottom:1px solid var(--soft);
  padding-bottom:10px;
}

.waitlist input{
  flex:1;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--ink);
  font:300 13px "Inter", sans-serif;
  letter-spacing:.06em;
}

.waitlist input::placeholder{color:rgba(17,16,14,.38)}

.waitlist button{
  border:0;
  background:transparent;
  color:var(--ink);
  font:400 10px "Inter", sans-serif;
  letter-spacing:.26em;
  text-transform:uppercase;
  cursor:pointer;
  padding-left:18px;
  white-space:nowrap;
}

.caption{
  margin-top:20px;
  color:rgba(17,16,14,.45);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}

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

@keyframes logoReveal{
  from{opacity:0; transform:translateY(-10px) scale(.94)}
  to{opacity:1; transform:translateY(0) scale(1)}
}

@keyframes logoFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-3px)}
}

@media (max-width:640px){
  body{overflow:hidden}

  .page{
    min-height:100svh;
    justify-content:center;
    padding:24px 26px;
  }

  .topbar, footer{
    left:26px;
    right:26px;
    font-size:9px;
    letter-spacing:.16em;
  }

  .topbar{top:28px}
  footer{bottom:24px}

  .topbar span:nth-child(2),
  footer span:nth-child(2){display:none}

  .logo-wrap{
    top:88px;
  }

  .logo-mark{
    width:34px;
  }

  .hero{
    width:100%;
    max-width:420px;
    margin-top:4.5vh;
  }

  .eyebrow{
    margin-bottom:20px;
    font-size:10px;
    letter-spacing:.44em;
  }

  h1{
    font-size:clamp(48px, 13vw, 66px);
    letter-spacing:.13em;
    margin-left:.13em;
    line-height:.9;
  }

  .subtitle{
    margin-top:20px;
    font-size:clamp(21px, 6vw, 28px);
    line-height:1.15;
  }

  .waitlist{
    width:100%;
    margin-top:42px;
    padding-bottom:12px;
  }

  .waitlist input{
    font-size:16px;
    letter-spacing:.03em;
  }

  .waitlist button{
    font-size:10px;
    letter-spacing:.22em;
    padding-left:14px;
  }

  .caption{
    margin-top:22px;
    font-size:10px;
    letter-spacing:.22em;
    line-height:1.8;
  }
}

@media (max-width:390px){
  .page{padding-left:22px; padding-right:22px}
  .topbar, footer{left:22px; right:22px}
  .logo-wrap{top:82px}
  .logo-mark{width:32px}
  h1{font-size:clamp(44px, 12.5vw, 58px); letter-spacing:.115em; margin-left:.115em}
  .subtitle{font-size:21px}
  .waitlist button{letter-spacing:.18em}
}


.hidden-frame{
  display:none;
  width:0;
  height:0;
  border:0;
}

.waitlist.is-submitting{
  opacity:.62;
  pointer-events:none;
}

.success-message{
  width:100%;
  max-height:0;
  margin:0 auto;
  overflow:hidden;
  text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-size:17px;
  line-height:1.25;
  letter-spacing:.045em;
  color:rgba(17,16,14,.68);
  opacity:0;
  transform:translateY(6px);
  pointer-events:none;
  transition:
    max-height .7s cubic-bezier(.2,.8,.2,1),
    margin .7s cubic-bezier(.2,.8,.2,1),
    opacity .7s ease,
    transform .7s cubic-bezier(.2,.8,.2,1);
}

.success-message.is-visible{
  max-height:42px;
  margin:18px auto 0;
  opacity:1;
  transform:translateY(0);
}

@media (max-width:640px){
  .success-message{
    max-width:280px;
    font-size:16px;
    letter-spacing:.035em;
  }

  .success-message.is-visible{
    margin-top:16px;
  }
}
