:root{
  --bg:#030303;
  --bg-soft:#0a0a0a;
  --text:#f4f1ea;
  --muted:rgba(244,241,234,.62);
  --line:rgba(255,255,255,.06);
  --glass:rgba(20,20,20,.72);
  --beam-white:rgba(255,255,255,.9);
  --beam-blue:rgba(111,169,255,.78);
  --beam-gold:rgba(255,213,152,.72);
  --cursor-x:50vw;
  --cursor-y:50vh;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  min-height:100vh;
  overflow-x:hidden;
  font-family:"Sora",system-ui,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top,rgba(255,255,255,.06),transparent 22%),
    linear-gradient(180deg,#020202 0%,#050505 38%,#090909 100%);
}

a{
  color:inherit;
  text-decoration:none;
}

.page-shell{
  position:relative;
  overflow:hidden;
  min-height:100vh;
}

.site-grid{
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg,transparent 0,transparent calc(50% - 1px),rgba(255,255,255,.035) calc(50% - 1px),rgba(255,255,255,.035) calc(50% + 1px),transparent calc(50% + 1px)),
    repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0 1px,transparent 1px 78px);
  opacity:.45;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.95),rgba(0,0,0,.96) 70%,transparent);
}

.topbar{
  position:fixed;
  top:18px;
  left:0;
  right:0;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
}

.brand{
  position:absolute;
  left:48px;
  color:rgba(255,255,255,.88);
  font-size:13px;
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
}

.nav-pill{
  display:flex;
  align-items:center;
  gap:4px;
  padding:8px 8px 8px 14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  background:rgba(0,0,0,.78);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 18px 45px rgba(0,0,0,.48);
  backdrop-filter:blur(18px);
}

.nav-pill a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 12px;
  border-radius:999px;
  color:rgba(255,255,255,.82);
  font-size:11px;
  font-weight:700;
  letter-spacing:.02em;
  transition:background .25s ease,color .25s ease,transform .25s ease;
}

.nav-pill a:hover{
  color:#fff;
  background:rgba(255,255,255,.04);
  transform:translateY(-1px);
}

.login-link{
  margin-left:3px;
  padding:0 15px !important;
  border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.04);
}

.hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(160px,280px) minmax(380px,1fr);
  align-items:center;
  gap:24px;
  min-height:100vh;
  padding:108px 56px 48px;
}

.hero-copy{
  position:relative;
  z-index:5;
  align-self:start;
  padding-top:128px;
}

.hero-kicker{
  margin:0;
  max-width:260px;
  color:#fbf8f2;
  font-size:24px;
  font-weight:700;
  line-height:1.22;
  letter-spacing:-.04em;
}

.hero-copy h1,
.hero-body{
  position:absolute;
  inline-size:1px;
  block-size:1px;
  overflow:hidden;
  clip-path:inset(50%);
  white-space:nowrap;
}

.hero-stage{
  position:relative;
  display:grid;
  place-items:center;
  min-height:calc(100vh - 156px);
}

.beam-backdrop,
.beam-columns{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.beam-backdrop{
  background:
    radial-gradient(circle at 50% 18%,rgba(255,255,255,.13),transparent 18%),
    linear-gradient(180deg,rgba(255,255,255,.05),transparent 24%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.028) 0 1px,transparent 1px 22px);
  opacity:.58;
  filter:blur(.2px);
}

.beam-columns{
  inset:5% 23% 10%;
  background:
    radial-gradient(circle at 50% 0,rgba(255,255,255,.5),transparent 24%),
    repeating-linear-gradient(90deg,var(--beam-white) 0 2px,var(--beam-blue) 2px 5px,var(--beam-gold) 5px 7px,transparent 7px 28px);
  opacity:.92;
  filter:saturate(130%);
  mask-image:linear-gradient(180deg,rgba(0,0,0,.92),rgba(0,0,0,.92) 76%,transparent);
}

.robot-frame{
  position:relative;
  width:min(780px,100%);
  height:min(76vh,760px);
  overflow:hidden;
  isolation:isolate;
}

.robot-glow{
  position:absolute;
  inset:8% 16% 12%;
  z-index:0;
  background:
    radial-gradient(circle at 50% 30%,rgba(255,255,255,.18),transparent 28%),
    radial-gradient(circle at 50% 72%,rgba(255,212,150,.11),transparent 40%);
  filter:blur(58px);
  opacity:.9;
}

.robot-video-track{
  position:absolute;
  inset:0;
  z-index:1;
  transform:translate3d(var(--track-x,0px),var(--track-y,0px),0);
  will-change:transform;
}

.robot-still{
  position:absolute;
  inset:-6% -24% -12%;
  width:148%;
  height:126%;
  object-fit:cover;
  object-position:50% 46%;
  transform:scale(1.02);
  filter:brightness(1.08) contrast(1.12) saturate(1.02);
}

.robot-mask{
  position:absolute;
  inset:-4% -7%;
  z-index:2;
  background:
    linear-gradient(90deg,rgba(4,4,4,.99) 0%,rgba(4,4,4,.96) 12%,transparent 21%,transparent 79%,rgba(4,4,4,.96) 88%,rgba(4,4,4,.99) 100%),
    linear-gradient(180deg,rgba(4,4,4,.995) 0%,rgba(4,4,4,.96) 24%,transparent 36%,transparent 78%,rgba(4,4,4,.94) 100%),
    radial-gradient(circle at 50% 89%,rgba(4,4,4,0),rgba(4,4,4,.8) 70%);
  pointer-events:none;
}

.hero-note{
  position:absolute;
  right:58px;
  bottom:62px;
  z-index:6;
  max-width:430px;
  padding:24px 28px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:28px;
  background:var(--glass);
  color:rgba(255,255,255,.82);
  font-size:16px;
  line-height:1.7;
  text-align:right;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 22px 54px rgba(0,0,0,.42);
  backdrop-filter:blur(16px);
}

.hero-orbs{
  position:absolute;
  left:42px;
  bottom:-8px;
  z-index:6;
  display:flex;
  gap:18px;
}

.hero-orbs span{
  width:78px;
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle at 32% 28%,#fff,#f0f0f0 48%,#b8b8b8 100%);
  box-shadow:0 18px 38px rgba(0,0,0,.34);
}

.details{
  position:relative;
  z-index:5;
  display:grid;
  gap:0;
  padding:24px 56px 0;
}

.detail-line{
  display:grid;
  grid-template-columns:180px minmax(0,1fr);
  gap:18px;
  padding:28px 0;
  border-top:1px solid var(--line);
}

.detail-line p,
.footer p{
  margin:0;
  color:rgba(255,255,255,.48);
  font-size:11px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
}

.detail-line h2,
.footer h2{
  margin:0;
  max-width:840px;
  color:rgba(255,255,255,.94);
  font-size:26px;
  font-weight:600;
  line-height:1.22;
  letter-spacing:-.04em;
}

.footer{
  position:relative;
  z-index:5;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  padding:40px 56px 72px;
  border-top:1px solid var(--line);
}

.footer-link{
  display:inline-flex;
  align-items:center;
  min-height:50px;
  padding:0 18px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  background:rgba(255,255,255,.03);
  color:#fff;
  font-size:13px;
  font-weight:600;
}

.cursor-ring,
.cursor-dot{
  position:fixed;
  top:0;
  left:0;
  z-index:50;
  pointer-events:none;
  transform:translate3d(-100px,-100px,0);
  mix-blend-mode:screen;
}

.cursor-ring{
  width:38px;
  height:38px;
  margin-left:-19px;
  margin-top:-19px;
  border:1px solid rgba(255,255,255,.5);
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.08),transparent 68%);
  box-shadow:0 0 24px rgba(255,255,255,.12);
}

.cursor-dot{
  width:8px;
  height:8px;
  margin-left:-4px;
  margin-top:-4px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 18px rgba(255,255,255,.5);
}

.is-ready .hero-copy,
.is-ready .hero-note,
.is-ready .robot-frame{
  animation:riseIn .9s cubic-bezier(.2,.75,.2,1) both;
}

.is-ready .hero-note{
  animation-delay:.12s;
}

.is-ready .robot-frame{
  animation-delay:.08s;
}

@keyframes riseIn{
  from{
    opacity:0;
    transform:translate3d(0,22px,0);
  }

  to{
    opacity:1;
    transform:translate3d(0,0,0);
  }
}

@media (max-width: 1100px){
  .brand{
    left:24px;
  }

  .hero{
    grid-template-columns:1fr;
    gap:18px;
    padding:108px 24px 36px;
  }

  .hero-copy{
    padding-top:12px;
  }

  .hero-stage{
    min-height:auto;
  }

  .robot-frame{
    width:min(100%,720px);
    height:72vh;
    margin:0 auto;
  }

  .hero-note{
    position:relative;
    right:auto;
    bottom:auto;
    max-width:none;
    margin-top:-12px;
    text-align:left;
  }

  .hero-orbs{
    left:24px;
    bottom:-12px;
  }

  .details,
  .footer{
    padding-left:24px;
    padding-right:24px;
  }

  .detail-line{
    grid-template-columns:1fr;
  }

  .footer{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width: 760px){
  .topbar{
    top:12px;
    justify-content:flex-start;
    padding:0 12px;
  }

  .brand{
    display:none;
  }

  .nav-pill{
    width:100%;
    justify-content:flex-start;
    overflow:auto hidden;
    scrollbar-width:none;
  }

  .nav-pill::-webkit-scrollbar{
    display:none;
  }

  .nav-pill a{
    flex:0 0 auto;
    font-size:10px;
  }

  .hero{
    padding:92px 12px 28px;
  }

  .hero-kicker{
    max-width:210px;
    font-size:17px;
  }

  .robot-frame{
    height:60vh;
  }

  .robot-still{
    inset:-2% -40% -10%;
    width:180%;
    height:132%;
    object-position:50% 44%;
    transform:scale(1.04);
  }

  .hero-note{
    padding:18px 18px 20px;
    font-size:14px;
    line-height:1.65;
  }

  .hero-orbs{
    gap:12px;
    left:12px;
  }

  .hero-orbs span{
    width:58px;
  }

  .detail-line h2,
  .footer h2{
    font-size:21px;
  }

  .cursor-ring,
  .cursor-dot{
    display:none;
  }
}
