/* Active homepage hero: static fast body image with a lightweight 3D head layer. */
.home-hero-v3{
  position:relative !important;
  box-sizing:border-box !important;
  width:100vw !important;
  max-width:none !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
  padding-left:max(50px,calc((100vw - var(--max)) / 2)) !important;
  padding-right:max(50px,calc((100vw - var(--max)) / 2)) !important;
  overflow:visible !important;
  isolation:isolate !important;
  background:#000 !important;
}

.home-hero-v3::before,
.home-hero-v3::after{
  content:none !important;
  display:none !important;
  background:none !important;
}

.home-hero-v3 .hero-spline-background,
.home-hero-v3 .hero-background-spline{
  display:none !important;
}

.home-hero-v3 .home-robot-composite{
  position:absolute !important;
  right:max(-96px,calc((100vw - var(--max)) / 2 - 96px)) !important;
  top:170px !important;
  width:min(760px,54vw) !important;
  aspect-ratio:1280/960 !important;
  z-index:0 !important;
  overflow:visible !important;
  pointer-events:auto !important;
  contain:layout style !important;
}

.home-hero-v3 .home-robot-composite::before{
  content:"" !important;
  position:absolute !important;
  inset:-12% -8% -20% -8% !important;
  background:radial-gradient(ellipse at 58% 58%,rgba(98,56,160,.16),rgba(0,0,0,0) 58%) !important;
  z-index:-1 !important;
}

.home-hero-v3 .home-robot-body,
.home-hero-v3 .home-robot-head{
  position:absolute !important;
  inset:0 !important;
  display:block !important;
  width:100% !important;
  height:100% !important;
  pointer-events:none !important;
}

.home-hero-v3 .home-robot-body{
  object-fit:contain !important;
  z-index:1 !important;
  transform:scale(1.17) !important;
  transform-origin:50% 42% !important;
  filter:none !important;
  -webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 88%,rgba(0,0,0,.72) 94%,rgba(0,0,0,0) 100%) !important;
  mask-image:linear-gradient(to bottom,#000 0%,#000 88%,rgba(0,0,0,.72) 94%,rgba(0,0,0,0) 100%) !important;
}

.home-hero-v3 .home-robot-head{
  z-index:3 !important;
  transform:translate(-2%, -27%) scale(1.25) !important;
  transform-origin:50% 58% !important;
  filter:brightness(.62) contrast(1.1) saturate(.92) !important;
  opacity:0 !important;
  transition:opacity .18s ease !important;
}

.home-hero-v3 .home-robot-composite::after{
  content:"" !important;
  position:absolute !important;
  left:46.5% !important;
  top:32.5% !important;
  width:15% !important;
  height:9% !important;
  border-radius:50% !important;
  background:radial-gradient(ellipse at 50% 54%,rgba(0,0,0,.98) 0%,rgba(0,0,0,.8) 42%,rgba(0,0,0,.28) 70%,rgba(0,0,0,0) 84%) !important;
  filter:blur(7px) !important;
  z-index:2 !important;
  pointer-events:none !important;
}

.home-hero-v3 .home-robot-composite.is-loaded .home-robot-head{
  opacity:1 !important;
}

.home-hero-v3 .hero-copy{
  position:relative !important;
  z-index:2 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  text-shadow:0 8px 26px rgba(0,0,0,.62) !important;
}

.home-hero-v3 .robot-hero-stack,
.home-hero-v3 .hero-channel-strip{
  display:none !important;
}

@media(min-width:1021px){
  .home-hero-v3{
    grid-template-columns:minmax(410px,.42fr) minmax(540px,.58fr) !important;
    min-height:760px !important;
  }
  .home-hero-v3 .hero-copy{
    grid-column:1 !important;
    grid-row:1 !important;
    max-width:540px !important;
  }
}

@media(max-width:1020px){
  .home-hero-v3{
    padding-left:24px !important;
    padding-right:24px !important;
  }
  .home-hero-v3 .home-robot-composite{
    right:-28vw !important;
    top:360px !important;
    width:118vw !important;
  }
  .home-hero-v3 .home-robot-body{
    transform:scale(1.13) !important;
    transform-origin:50% 42% !important;
  }
  .home-hero-v3 .home-robot-head{
    transform:translate(-2%, -27%) scale(1.22) !important;
    transform-origin:50% 58% !important;
  }
}

@media(max-width:760px){
  .home-hero-v3{
    min-height:980px !important;
    padding-left:16px !important;
    padding-right:16px !important;
    align-items:flex-start !important;
    background:linear-gradient(180deg,#000 0%,#000 82%,rgba(0,0,0,.58) 91%,rgba(0,0,0,0) 100%) !important;
  }
  .home-hero-v3 .hero-copy{
    width:66vw !important;
    max-width:258px !important;
    padding-top:28px !important;
    padding-bottom:44px !important;
  }
  .home-hero-v3 .home-robot-composite{
    top:145px !important;
    right:-53vw !important;
    width:142vw !important;
  }
  .home-hero-v3 .home-robot-body{
    transform:scale(1.01) !important;
    transform-origin:50% 42% !important;
  }
  .home-hero-v3 .home-robot-head{
    transform:translate(-2%, -27%) scale(1.08) !important;
    transform-origin:50% 58% !important;
  }
  .home-hero-v3 h1,
  .home-hero-v3 .hero-subtitle,
  .home-hero-v3 .hero-body,
  .home-hero-v3 .hero-actions{
    width:100% !important;
    max-width:258px !important;
  }
  .home-hero-v3 .hero-copy > .hero-actions{
    width:190px !important;
    max-width:190px !important;
    margin-left:0 !important;
    margin-right:auto !important;
  }
  .home-hero-v3 h1{
    font-size:clamp(34px,10vw,45px) !important;
    line-height:.92 !important;
  }
  .home-hero-v3 .hero-subtitle{
    width:198px !important;
    max-width:198px !important;
    font-size:20px !important;
    line-height:1.2 !important;
  }
  .home-hero-v3.home-premium-hero .hero-copy > .hero-subtitle{
    width:198px !important;
    max-width:198px !important;
  }
  .home-hero-v3.home-premium-hero .hero-copy > .hero-body{
    width:248px !important;
    max-width:248px !important;
  }
  .home-hero-v3 .hero-body{
    max-width:248px !important;
    font-size:14px !important;
    display:block !important;
    white-space:normal !important;
    overflow-wrap:break-word !important;
    word-break:normal !important;
    line-height:1.55 !important;
  }
  .home-hero-v3 .hero-actions{
    width:190px !important;
    max-width:190px !important;
    align-self:flex-start !important;
    align-items:center !important;
    gap:10px !important;
  }
  .home-hero-v3 .hero-actions .button{
    width:190px !important;
    min-width:0 !important;
    height:40px !important;
    padding:0 14px !important;
    font-size:11.5px !important;
    justify-content:center !important;
  }
  .home-hero-v3 .hero-actions .button:first-child{
    width:190px !important;
  }
  .home-hero-v3 .hero-actions .button:last-child{
    width:190px !important;
  }
}
