.hero{
  min-height:720px;
  display:grid;
  grid-template-columns:1.03fr .97fr;
  gap:40px;
  padding:28px 58px 48px;
  position:relative;
}

.hero-kicker{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin:54px 0 42px;
}
.hero-kicker::before{
  content:"01";
  font-variant-numeric:tabular-nums;
}
.hero-kicker::after{
  content:"";
  width:42px;height:1px;background:#111;opacity:.5;
}

h1{
  margin:0;
  font-size:clamp(72px, 10vw, 148px);
  line-height:.82;
  letter-spacing:-.095em;
  max-width:780px;
  font-weight:950;
  position:relative;
  z-index:4;
}
h1 .script{
  display:inline-block;
  font-family: Georgia, "Times New Roman", serif;
  font-style:italic;
  font-weight:400;
  letter-spacing:-.09em;
  transform:translateY(.04em);
}
h1 .dot{color:var(--orange)}

.intro{
  max-width:390px;
  margin:44px 0 34px;
  font-size:18px;
  line-height:1.35;
  color:#1b1715;
  letter-spacing:-.04em;
}

.magnet{
  --x:0px;--y:0px;
  transform:translate(var(--x), var(--y));
  transition:transform .18s var(--ease);
}
.orb-link{
  display:inline-grid;
  place-items:center;
  width:184px;
  height:184px;
  border:1.3px solid rgba(0,0,0,.6);
  border-radius:999px;
  position:absolute;
  left:45%;
  top:47%;
  z-index:6;
  font-size:56px;
  background:rgba(255,250,248,.15);
  backdrop-filter:blur(8px);
  cursor:pointer;
  overflow:hidden;
}
.orb-link::before{
  content:"";
  position:absolute;
  width:18px;height:18px;
  background:#050505;
  border-radius:50%;
  left:14px;
  bottom:37px;
  animation:orbitDot 7s linear infinite;
  transform-origin:78px -55px;
}
.orb-link::after{
  content:"";
  position:absolute;
  inset:12px;
  border-radius:999px;
  border:1px dashed rgba(0,0,0,.18);
  animation:spin 14s linear infinite reverse;
}
.orb-link span{
  transform:translateY(-4px);
  transition:.35s var(--ease);
}
.orb-link:hover span{transform:translate(10px,-14px) rotate(10deg)}
@keyframes orbitDot{to{transform:rotate(360deg)}}

.visual{
  position:relative;
  min-height:610px;
  isolation:isolate;
}
.blob{
  --scroll-x:0px;
  --scroll-y:0px;
  --scroll-rotate:0deg;
  position:absolute;
  inset:46px -98px 78px -88px;
  filter:blur(.2px);
  z-index:1;
  will-change:transform;
  animation:blobDrift 13s cubic-bezier(.45,0,.55,1) infinite alternate;
}
.blob svg{
  width:100%;
  height:100%;
  overflow:visible;
  transform-origin:center;
  animation:blobPuddle 15s cubic-bezier(.45,0,.55,1) infinite alternate;
  will-change:transform;
}
.blob-shape{
  transform-origin:center;
  transform-box:fill-box;
  animation:morph 16s cubic-bezier(.45,0,.55,1) infinite alternate;
}
.blob-highlight{
  transform-origin:center;
  transform-box:fill-box;
  animation:highlightDrift 11s cubic-bezier(.45,0,.55,1) infinite alternate;
}
@keyframes blobDrift{
  0%{
    transform:
      translate3d(calc(var(--scroll-x) - 46px), calc(var(--scroll-y) + 26px), 0)
      rotate(calc(var(--scroll-rotate) - 2deg))
      scale(.94, 1.1);
  }
  100%{
    transform:
      translate3d(calc(var(--scroll-x) + 54px), calc(var(--scroll-y) - 30px), 0)
      rotate(calc(var(--scroll-rotate) + 2deg))
      scale(1.1, .94);
  }
}
@keyframes blobPuddle{
  0%{
    transform:translate3d(-12px, 8px, 0) skew(-2deg, 1deg) scale(1.03, .97);
  }
  50%{
    transform:translate3d(14px, -7px, 0) skew(2deg, -1deg) scale(.96, 1.05);
  }
  100%{
    transform:translate3d(20px, 4px, 0) skew(-1deg, 2deg) scale(1.06, .95);
  }
}
@keyframes morph{
  0%{d:path("M82,187 C19,131 47,32 129,28 C203,24 265,80 276,150 C286,219 243,281 162,278 C111,276 103,225 82,187 Z")}
  50%{d:path("M56,195 C0,135 46,35 137,36 C224,37 300,75 290,158 C279,248 211,286 129,264 C61,246 115,256 56,195 Z")}
  100%{d:path("M73,205 C5,148 36,43 130,44 C212,45 302,53 297,144 C292,240 220,298 124,261 C45,231 140,267 73,205 Z")}
}
@keyframes highlightDrift{
  0%{transform:translate(-24px, 10px) rotate(-10deg) scale(.86)}
  100%{transform:translate(30px, -22px) rotate(12deg) scale(1.18)}
}

.ghost-ring{
  position:absolute;
  width:480px;height:480px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:50%;
  right:-80px;top:36px;
  z-index:0;
  animation:spin 38s linear infinite;
}
.ghost-ring::before,.ghost-ring::after{
  content:"";
  position:absolute;
  inset:42px;
  border:1px solid rgba(255,90,54,.16);
  border-radius:50%;
}
.ghost-ring::after{
  inset:98px;
  border-color:rgba(140,53,255,.16);
}

.side-copy{
  position:absolute;
  right:64px;
  top:170px;
  width:260px;
  z-index:9;
  font-size:18px;
  line-height:1.35;
  text-align:left;
  color:#2a2421;
  letter-spacing:-.04em;
}

.thumbs{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  z-index:6;
}
.thumb{
  height:88px;
  border-radius:13px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.12);
  background:#111;
  position:relative;
  cursor:pointer;
  transition:.35s var(--ease);
}
.thumb:hover{transform:translateY(-8px) scale(1.02)}
.thumb b{
  position:absolute;
  left:14px;
  bottom:11px;
  font-size:14px;
  color:white;
  letter-spacing:-.04em;
  z-index:2;
}
.thumb:nth-child(1){background:radial-gradient(circle at 28% 50%, #111, #000 32%, #ff5a36 33%, #121 60%)}
.thumb:nth-child(2){background:linear-gradient(135deg,#f1c59c,#fff,#efe1d4)}
.thumb:nth-child(2) b{color:#111;font-family:Georgia,serif;font-size:24px;font-weight:400}
.thumb:nth-child(3){background:radial-gradient(circle at 50% 50%, #fff 0 8%, #a64bff 9% 14%, #080808 15% 100%)}
.thumb:nth-child(3)::before{
  content:"";
  position:absolute;
  inset:18px;
  border:2px solid #9d4eff;
  border-radius:51% 49% 48% 52%;
  filter:blur(1px);
  transform:rotate(24deg);
}

.marquee{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  background:rgba(255,255,255,.35);
  white-space:nowrap;
}
.marquee-track{
  display:inline-flex;
  gap:38px;
  padding:20px 0;
  animation:marquee 22s linear infinite;
  font-weight:900;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.marquee span{display:inline-flex;align-items:center;gap:38px}
.marquee i{
  width:8px;height:8px;border-radius:50%;background:var(--orange);display:inline-block;
}
@keyframes marquee{to{transform:translateX(-50%)}}

.section{
  padding:90px 58px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:30px;
  margin-bottom:42px;
}
.eyebrow{
  color:var(--purple);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  margin-bottom:14px;
}
h2{
  margin:0;
  font-size:clamp(42px, 6vw, 92px);
  line-height:.88;
  letter-spacing:-.08em;
  max-width:800px;
}
.section-lead{
  max-width:360px;
  font-size:18px;
  line-height:1.35;
  color:var(--muted);
  letter-spacing:-.04em;
}

.cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.card{
  min-height:245px;
  padding:26px;
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,255,255,.4);
  position:relative;
  overflow:hidden;
  transition:.45s var(--ease);
}
.card::before{
  content:"";
  position:absolute;
  inset:auto -30% -40% -30%;
  height:120px;
  background:radial-gradient(circle, rgba(255,90,54,.25), transparent 65%);
  opacity:0;
  transition:.45s var(--ease);
}
.card:hover{transform:translateY(-12px);background:#fff}
.card:hover::before{opacity:1}
.card small{
  display:block;
  font-weight:900;
  opacity:.45;
  margin-bottom:58px;
}
.card h3{
  font-size:26px;
  line-height:.95;
  letter-spacing:-.07em;
  margin:0 0 18px;
}
.card p{
  color:var(--muted);
  margin:0;
  line-height:1.45;
  font-size:14px;
}

.split{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:22px;
  align-items:stretch;
}
.panel{
  border:1px solid var(--line);
  border-radius:30px;
  background:rgba(255,255,255,.42);
  padding:36px;
  min-height:430px;
  overflow:hidden;
  position:relative;
}
.panel.dark{
  background:#070707;
  color:white;
  border-color:rgba(255,255,255,.12);
}
.panel.dark p{color:rgba(255,255,255,.7)}
.bubble-list{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:36px;
}
.bubble{
  border:1px solid currentColor;
  border-radius:999px;
  padding:12px 16px;
  font-weight:850;
  font-size:13px;
  letter-spacing:-.03em;
}
.project-card{
  margin-top:34px;
  border-radius:28px;
  min-height:260px;
  padding:24px;
  color:white;
  background:
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.58)),
    radial-gradient(circle at 70% 35%, rgba(255,255,255,.9), transparent 5%),
    radial-gradient(circle at 48% 20%, #eef4ff, #2a2d33 35%, #050505 70%);
  display:flex;
  align-items:end;
  justify-content:space-between;
  overflow:hidden;
  position:relative;
}
.project-card::before{
  content:"";
  position:absolute;
  inset:20% -10% -40%;
  background:linear-gradient(130deg, transparent 20%, rgba(255,255,255,.25), transparent 55%);
  transform:rotate(-12deg);
}
.project-card h3{font-size:48px;margin:0;letter-spacing:-.08em}
.round-arrow{
  width:58px;height:58px;
  border-radius:50%;
  background:#fff;
  color:#000;
  display:grid;
  place-items:center;
  font-size:28px;
  flex:none;
  position:relative;
  z-index:2;
}

.contact{
  padding:90px 58px 48px;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:50px;
  align-items:start;
}
.contact h2{font-size:clamp(56px,8vw,128px)}
form{
  display:grid;
  gap:14px;
}
input,textarea{
  width:100%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.55);
  border-radius:18px;
  padding:18px 20px;
  outline:none;
  transition:.25s var(--ease);
}
textarea{min-height:160px;resize:vertical}
input:focus,textarea:focus{
  border-color:rgba(255,90,54,.7);
  box-shadow:0 0 0 5px rgba(255,90,54,.08);
  background:white;
}
.submit{
  border:0;
  background:#0a0a0a;
  color:white;
  border-radius:999px;
  padding:18px 24px;
  font-weight:900;
  cursor:pointer;
  display:flex;
  justify-content:center;
  gap:12px;
  transition:.25s var(--ease);
}
.submit:hover{transform:translateY(-4px);background:var(--orange)}
@media (max-width:980px){
  .hero{grid-template-columns:1fr;padding:16px 24px 38px;min-height:0}
  .hero-kicker{margin:42px 0 34px}
  .visual{min-height:460px}
  .orb-link{width:134px;height:134px;left:auto;right:24px;top:20px;font-size:40px}
  .side-copy{left:0;right:auto;top:265px;width:260px}
  .blob{inset:50px -90px 80px -80px}
  .thumbs{gap:10px}
  .section,.contact{padding:64px 24px}
  .section-head{display:block}
  .section-lead{margin-top:18px}
  .cards{grid-template-columns:1fr}
  .split,.contact{grid-template-columns:1fr}
}
