:root{
  --bg:#040305; --panel:#0E0B0D; --panel2:#181214;
  --text:#EFE9DD; --muted:#928A80; --accent:#B60912;
  --green:#29B35E; --yellow:#E2CE3A; --orange:#F35A18; --red:#EA0915; --gray:#55545A;
  --sans:'Plus Jakarta Sans',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1100px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.55;
  overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
em{font-style:normal;color:var(--accent)}

/* film grain + ambient drift */
.grain{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay}
body::before{content:"";position:fixed;inset:-20%;z-index:0;pointer-events:none;
  background:radial-gradient(40% 35% at 20% 15%,rgba(182,9,18,.18),transparent 70%),
             radial-gradient(45% 40% at 85% 80%,rgba(41,179,94,.10),transparent 70%);
  animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{to{transform:translate3d(2%,-2%,0) scale(1.06)}}

/* ticker */
.ticker{position:relative;z-index:3;border-bottom:1px solid rgba(239,233,221,.07);
  overflow:hidden;font-family:var(--mono);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);background:rgba(4,3,5,.6)}
.ticker__track{display:inline-flex;gap:1.4rem;white-space:nowrap;padding:.6rem 0;
  animation:marq 32s linear infinite}
.ticker__track span:nth-child(even){color:var(--accent)}
@keyframes marq{to{transform:translateX(-50%)}}

/* nav */
.nav{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:1.5rem;
  padding:1rem clamp(1rem,4vw,2.5rem);backdrop-filter:blur(10px);
  background:linear-gradient(rgba(4,3,5,.85),rgba(4,3,5,.55));
  border-bottom:1px solid rgba(239,233,221,.06)}
.nav__logo{display:flex;align-items:center}
.nav__mark{width:auto;height:42px;filter:drop-shadow(0 0 16px rgba(255,255,255,.05))}
@media(max-width:560px){.nav__mark{height:36px}}
.hero__logo{width:clamp(150px,24vw,210px);height:auto;display:block;margin:0 auto 1.5rem;filter:drop-shadow(0 0 30px rgba(255,255,255,.06))}
.nav__links{display:flex;gap:1.4rem;margin-left:auto;font-size:14px;color:var(--muted)}
.nav__links a:hover{color:var(--text)}
.nav__cta{margin-left:0}
@media(max-width:680px){.nav__links{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:800;font-size:15px;padding:.85rem 1.4rem;border:none;cursor:pointer;
  border-radius:2px;transition:transform .15s ease,filter .15s ease}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn--ghost{background:transparent;color:var(--text);border:1px solid rgba(239,233,221,.18);
  font-weight:600;font-size:13px;padding:.5rem 1rem}
.btn--ghost:hover{border-color:var(--accent);color:#fff}

/* hero */
.hero{position:relative;min-height:clamp(560px,90svh,880px);display:grid;place-items:center;
  text-align:center;padding:6vh clamp(1rem,5vw,2rem) 8vh;overflow:hidden}
.hero__pulse{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero__inner{position:relative;z-index:1;max-width:760px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.2rem}
.hero__title{font-size:clamp(3rem,11vw,6.5rem);font-weight:800;line-height:.98;
  letter-spacing:-.02em;margin-bottom:1.3rem}
.toggle-word{display:inline-block;transition:opacity .4s ease,transform .4s ease}
.toggle-word.flip{opacity:0;transform:translateY(8px)}
.hero__sub{font-size:clamp(1.05rem,2.4vw,1.35rem);color:var(--muted);max-width:620px;
  margin:0 auto 2.2rem}
.hero__note{margin-top:1rem;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}
.hero__scroll{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);z-index:1;
  color:var(--muted);font-size:22px;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translate(-50%,8px)}}

/* waitlist */
.waitlist{display:flex;gap:.6rem;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.waitlist input{flex:1;min-width:200px;background:var(--panel2);border:1px solid rgba(239,233,221,.12);
  color:var(--text);padding:.85rem 1rem;border-radius:2px;font-size:15px;font-family:var(--sans)}
.waitlist input:focus{outline:none;border-color:var(--accent)}
.waitlist--big{margin-top:1.6rem}

/* bands */
.band{padding:clamp(4rem,9vw,7rem) clamp(1rem,5vw,2rem)}
.band--alt{background:linear-gradient(180deg,transparent,rgba(24,18,20,.5),transparent)}
.band__inner{max-width:820px;margin:0 auto;text-align:center}
.section-title{font-size:clamp(1.7rem,4.2vw,2.8rem);font-weight:800;letter-spacing:-.01em;line-height:1.1}
.lead{margin-top:1.2rem;font-size:clamp(1.05rem,2.2vw,1.25rem);color:var(--muted)}

/* features */
.features{padding:clamp(3rem,7vw,6rem) clamp(1rem,5vw,2rem);max-width:var(--maxw);margin:0 auto}
.features__head{text-align:center;margin-bottom:2.8rem}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.card{background:var(--panel);border:1px solid rgba(239,233,221,.07);padding:1.6rem;border-radius:3px;
  transition:transform .2s ease,border-color .2s ease,background .2s ease}
.card:hover{transform:translateY(-4px);border-color:rgba(239,233,221,.16);background:var(--panel2)}
.card__dot{width:14px;height:14px;border-radius:50%;display:block;margin-bottom:1rem;
  box-shadow:0 0 18px 2px currentColor}
.card__dot[data-c=green]{background:var(--green);color:var(--green)}
.card__dot[data-c=yellow]{background:var(--yellow);color:var(--yellow)}
.card__dot[data-c=orange]{background:var(--orange);color:var(--orange)}
.card__dot[data-c=red]{background:var(--red);color:var(--red)}
.card__dot[data-c=gray]{background:var(--gray);color:var(--gray)}
.card h3{font-size:1.25rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.98rem}

/* demo phones */
.demo{padding:clamp(3rem,7vw,6rem) clamp(1rem,5vw,2rem);max-width:var(--maxw);margin:0 auto}
.demo__head{text-align:center;margin-bottom:3rem}
.phones{display:flex;gap:clamp(1rem,3vw,2.2rem);justify-content:center;align-items:flex-end;
  flex-wrap:wrap}
.phone{width:clamp(150px,21vw,210px)}
.phone img{border-radius:26px;border:1px solid rgba(239,233,221,.12);
  box-shadow:0 30px 60px rgba(0,0,0,.6),0 0 0 6px #0a0a0c;background:#000}
.phone--hero{width:clamp(180px,25vw,250px)}
.phone--hero img{box-shadow:0 30px 80px rgba(182,9,18,.25),0 0 0 6px #0a0a0c}
.phone figcaption{margin-top:.9rem;text-align:center;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* trust */
.trust{padding:clamp(4rem,9vw,7rem) clamp(1rem,5vw,2rem)}
.trust__inner{max-width:820px;margin:0 auto;text-align:center}
.nots{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:.7rem;margin:2.2rem 0;text-align:left}
.nots li{background:var(--panel);border:1px solid rgba(239,233,221,.07);padding:1rem 1.1rem;
  border-radius:2px;font-weight:500;position:relative;padding-left:2.4rem}
.nots li::before{content:"✕";position:absolute;left:1rem;color:var(--accent);font-weight:800}
.trust__line{color:var(--muted);max-width:600px;margin:0 auto}

/* cta */
.cta{padding:clamp(4rem,10vw,8rem) clamp(1rem,5vw,2rem);text-align:center;
  background:radial-gradient(60% 80% at 50% 0%,rgba(182,9,18,.12),transparent 70%)}
.cta__title{font-size:clamp(2.2rem,7vw,4rem);font-weight:800;letter-spacing:-.02em}
.cta__sub{color:var(--muted);margin-top:.8rem}
.cta__msg{margin-top:1rem;font-family:var(--mono);font-size:13px;color:var(--green);min-height:1.2em}

/* footer */
.foot{border-top:1px solid rgba(239,233,221,.07);padding:3rem clamp(1rem,5vw,2.5rem);
  max-width:var(--maxw);margin:0 auto}
.foot__top{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  margin-bottom:1.6rem}
.foot__brand{display:flex;align-items:center;gap:.85rem}
.foot__mark{width:auto;height:48px}
.foot__by{font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted)}
.foot__slogan{color:var(--muted);font-family:var(--mono);font-size:13px}
.foot__legal p{font-size:12.5px;color:var(--muted);line-height:1.7}

/* reveal animation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ── polish: typography, focus, mobile-first ───────────────────────── */
.hero__title,.section-title,.cta__title{text-wrap:balance}
.hero__sub,.lead,.trust__line{text-wrap:pretty}

/* keyboard focus (a11y) */
a:focus-visible,.btn:focus-visible,.waitlist input:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

/* short / landscape screens: drop the scroll hint so it can't overlap */
@media(max-height:640px){.hero__scroll{display:none}}

/* phones → thumb-friendly snap carousel on phones */
@media(max-width:680px){
  .phones{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;align-items:stretch;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    gap:1rem;padding:.5rem 1rem 1.2rem;margin:0 -1rem;scrollbar-width:none}
  .phones::-webkit-scrollbar{display:none}
  .phone{flex:0 0 auto;width:62vw;max-width:240px;scroll-snap-align:center}
  .phone--hero{width:68vw;max-width:260px}
}

/* waitlist stacks cleanly on narrow screens */
@media(max-width:480px){
  .waitlist{flex-direction:column;flex-wrap:nowrap}
  .waitlist input,.waitlist .btn{width:100%;min-width:0}
}
