:root {
  --bg: #04060d;
  --bg-soft: #0b1220;
  --text: #edf4ff;
  --text-dim: #adbbd3;
  --line: rgba(177, 203, 255, 0.2);
  --cyan: #6bd8ff;
  --blue: #8a93ff;
  --teal: #4ce6c2;
  --violet: #7b72ff;
  --transform-shift: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: clip;
  font-family: "Manrope", sans-serif;
  color: var(--text);
  line-height: 1.6;
  background: radial-gradient(
      1200px 640px at 88% -10%,
      rgba(138, 147, 255, 0.16),
      transparent 62%
    ),
    radial-gradient(
      1000px 560px at 0% 15%,
      rgba(76, 230, 194, 0.1),
      transparent 65%
    ),
    var(--bg);
}

.site-noise,
.vignette {
  position: fixed;
  inset: 0;
  pointer-events: none;
}

.site-noise {
  z-index: -2;
  opacity: 0.2;
  background-image: radial-gradient(
    rgba(255, 255, 255, 0.14) 0.75px,
    transparent 0.75px
  );
  background-size: 3px 3px;
}

.vignette {
  z-index: -1;
  background: radial-gradient(
    circle at center,
    transparent 46%,
    rgba(0, 0, 0, 0.55) 100%
  );
}

main {
  position: relative;
}

.section {
  position: relative;
  isolation: isolate;
}

.eyebrow {
  margin: 0 0 0.85rem;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--cyan);
}

.hero {
  min-height: 100svh;
  padding: 7.5rem clamp(1.2rem, 4vw, 4.2rem) 5.4rem;
  display: grid;
  align-items: center;
  overflow: clip;
}

.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 160px;
  background: linear-gradient(to bottom, rgba(4, 6, 13, 0), rgba(4, 6, 13, 1));
  pointer-events: none;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: clip;
}

.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(26px);
  will-change: transform;
}

.orb-one {
  width: clamp(250px, 30vw, 440px);
  aspect-ratio: 1;
  left: 8%;
  top: 11%;
  background: radial-gradient(
    circle at 34% 34%,
    rgba(107, 216, 255, 0.56),
    rgba(107, 216, 255, 0)
  );
}

.orb-two {
  width: clamp(280px, 38vw, 620px);
  aspect-ratio: 1;
  right: -6%;
  bottom: -10%;
  background: radial-gradient(
    circle at 50% 50%,
    rgba(138, 147, 255, 0.53),
    rgba(138, 147, 255, 0)
  );
}

.orb-three {
  width: clamp(200px, 26vw, 400px);
  aspect-ratio: 1;
  left: 42%;
  top: 44%;
  background: radial-gradient(
    circle at 48% 48%,
    rgba(76, 230, 194, 0.45),
    rgba(76, 230, 194, 0)
  );
}

.grid-fade {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(
      rgba(255, 255, 255, 0.04) 1px,
      transparent 1px
    ),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(circle at center, black 35%, transparent 88%);
}

.bg-word {
  margin: 0;
  position: absolute;
  right: clamp(-3rem, -4vw, -1rem);
  top: clamp(0.8rem, 5vw, 3.5rem);
  font-family: "Syne", sans-serif;
  font-size: clamp(4rem, 20vw, 18rem);
  letter-spacing: -0.04em;
  color: rgba(237, 244, 255, 0.03);
  text-transform: uppercase;
  user-select: none;
  pointer-events: none;
  will-change: transform;
}

.hero-content {
  width: min(1220px, 100%);
  will-change: transform;
}

.hero-kicker {
  margin: -0.35rem 0 0.8rem;
  color: #bdc9df;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

.hero-title {
  margin: 0;
  font-family: "Syne", sans-serif;
  font-size: clamp(3rem, 11vw, 10rem);
  line-height: 0.87;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}

.line-wrap {
  display: block;
  overflow: hidden;
}

.line {
  display: block;
  will-change: transform, opacity;
}

.hero-sub {
  margin: 1.45rem 0 0;
  max-width: 63ch;
  color: var(--text-dim);
  font-size: clamp(1rem, 1.8vw, 1.25rem);
}

.hero-meta {
  margin-top: 1.5rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.meta-card {
  border: 1px solid var(--line);
  border-radius: 0.82rem;
  padding: 0.78rem 0.85rem;
  background: rgba(9, 16, 30, 0.66);
  backdrop-filter: blur(7px);
  box-shadow: 0 12px 30px rgba(2, 5, 10, 0.35);
  will-change: transform, opacity;
}

.meta-card span {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9eb1cc;
}

.meta-card strong {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.98rem;
  font-weight: 800;
}

.cta {
  margin-top: 1.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.82rem 1.35rem;
  border-radius: 999px;
  text-decoration: none;
  border: 1px solid rgba(187, 223, 255, 0.55);
  color: #04121c;
  font-weight: 800;
  letter-spacing: 0.01em;
  background: linear-gradient(130deg, var(--cyan), var(--blue));
  box-shadow: 0 12px 30px rgba(107, 216, 255, 0.2);
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1),
    box-shadow 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.cta:hover,
.cta:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 18px 45px rgba(107, 216, 255, 0.34);
}

.scroll-indicator {
  position: absolute;
  left: 50%;
  bottom: 1.3rem;
  transform: translateX(-50%);
  display: grid;
  justify-items: center;
  gap: 0.35rem;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #bccbe2;
}

.scroll-indicator i {
  width: 1px;
  height: 42px;
  background: linear-gradient(
    to bottom,
    rgba(237, 244, 255, 0.08),
    rgba(237, 244, 255, 0.98)
  );
  animation: glide 1.8s ease-in-out infinite;
}

@keyframes glide {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.7;
  }
  50% {
    transform: translateY(10px);
    opacity: 1;
  }
}

.transform {
  min-height: 305svh;
  padding: 0 clamp(1.2rem, 4vw, 4.2rem);
  background: linear-gradient(
    160deg,
    rgba(10, 17, 31, 0.96),
    rgba(5, 8, 15, 0.98)
  );
  overflow: clip;
}

.transform::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(
      900px 560px at 16% 16%,
      rgba(76, 230, 194, 0.28),
      transparent 65%
    ),
    radial-gradient(
      980px 620px at 84% 68%,
      rgba(123, 114, 255, 0.3),
      transparent 68%
    );
  opacity: calc(0.1 + var(--transform-shift) * 0.9);
}

.transform-layers {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.layer {
  position: absolute;
  border: 1px solid rgba(177, 203, 255, 0.14);
  border-radius: 999px;
  will-change: transform;
}

.layer-a {
  width: min(58vw, 640px);
  height: min(58vw, 640px);
  top: 6%;
  right: -12%;
}

.layer-b {
  width: min(40vw, 450px);
  height: min(40vw, 450px);
  left: -9%;
  bottom: 13%;
}

.layer-c {
  width: min(23vw, 280px);
  height: min(23vw, 280px);
  left: 40%;
  top: 48%;
}

.transform-pin {
  height: 100svh;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(1rem, 3vw, 2.2rem);
  align-items: center;
  width: min(1220px, 100%);
  margin: 0 auto;
}

.transform-content {
  will-change: transform;
}

.scale-headline {
  margin: 0;
  max-width: 13ch;
  font-family: "Syne", sans-serif;
  font-size: clamp(2.35rem, 8vw, 7.15rem);
  line-height: 0.93;
  letter-spacing: -0.02em;
  will-change: transform, opacity;
}

.section-copy {
  margin: 1.4rem 0 0;
  max-width: 55ch;
  color: var(--text-dim);
  font-size: clamp(1rem, 1.8vw, 1.2rem);
}

.story-stack {
  display: grid;
  gap: 0.7rem;
}

.story-step {
  border: 1px solid var(--line);
  border-radius: 0.84rem;
  padding: 0.84rem 0.9rem;
  background: rgba(9, 15, 28, 0.72);
  backdrop-filter: blur(8px);
  box-shadow: 0 14px 38px rgba(2, 5, 10, 0.35);
  transform: translateY(32px) scale(0.96);
  opacity: 0.15;
  will-change: transform, opacity;
}

.story-index {
  margin: 0;
  color: var(--cyan);
  font-size: 0.73rem;
  letter-spacing: 0.14em;
  font-weight: 700;
}

.story-step h3 {
  margin: 0.36rem 0 0;
  font-family: "Syne", sans-serif;
  font-size: 1.05rem;
  line-height: 1.1;
}

.story-step p {
  margin: 0.5rem 0 0;
  color: var(--text-dim);
  font-size: 0.9rem;
}

.showcase {
  height: 100svh;
  border-top: 1px solid rgba(177, 203, 255, 0.16);
  border-bottom: 1px solid rgba(177, 203, 255, 0.16);
  background: #04070d;
  overflow: hidden;
}

.showcase-header {
  position: absolute;
  top: clamp(0.9rem, 3.4vw, 2.8rem);
  left: clamp(1.2rem, 4vw, 4.2rem);
  right: clamp(1.2rem, 4vw, 4.2rem);
  z-index: 4;
  pointer-events: none;
}

.showcase-header h2 {
  margin: 0;
  max-width: 11ch;
  font-family: "Syne", sans-serif;
  font-size: clamp(1.7rem, 4.2vw, 3.8rem);
  line-height: 0.98;
}

.showcase-progress {
  margin-top: 0.95rem;
  width: min(360px, 72vw);
  height: 3px;
  border-radius: 999px;
  background: rgba(177, 203, 255, 0.15);
  overflow: hidden;
}

.showcase-progress span {
  display: block;
  width: 100%;
  height: 100%;
  transform-origin: left center;
  transform: scaleX(0);
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  will-change: transform;
}

.showcase-track {
  height: 100%;
  display: flex;
  will-change: transform;
}

.showcase-panel {
  position: relative;
  flex: 0 0 100vw;
  display: grid;
  place-items: center;
  padding: clamp(5.6rem, 9.6vw, 9rem) clamp(1.2rem, 6vw, 8rem)
    clamp(2rem, 5vw, 4.2rem);
}

.showcase-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.panel-one::before {
  background: radial-gradient(
    980px 580px at 72% 72%,
    rgba(76, 230, 194, 0.18),
    transparent 66%
  );
}

.panel-two::before {
  background: radial-gradient(
    980px 580px at 30% 70%,
    rgba(123, 114, 255, 0.2),
    transparent 66%
  );
}

.panel-three::before {
  background: radial-gradient(
    980px 580px at 66% 30%,
    rgba(107, 216, 255, 0.16),
    transparent 66%
  );
}

.panel-four::before {
  background: radial-gradient(
    980px 580px at 35% 70%,
    rgba(138, 147, 255, 0.18),
    transparent 66%
  );
}

.showcase-media {
  position: absolute;
  inset: 22% 11% 16%;
  border-radius: 1.5rem;
  border: 1px solid rgba(177, 203, 255, 0.13);
  will-change: transform, opacity;
}

.media-one {
  background: linear-gradient(
      135deg,
      rgba(107, 216, 255, 0.12),
      rgba(107, 216, 255, 0)
    ),
    linear-gradient(180deg, #0e1f2f, #07111d);
}

.media-two {
  background: linear-gradient(
      135deg,
      rgba(138, 147, 255, 0.15),
      rgba(138, 147, 255, 0)
    ),
    linear-gradient(180deg, #171a34, #0b0f22);
}

.media-three {
  background: linear-gradient(
      135deg,
      rgba(76, 230, 194, 0.13),
      rgba(76, 230, 194, 0)
    ),
    linear-gradient(180deg, #0f2a25, #081513);
}

.media-four {
  background: linear-gradient(
      135deg,
      rgba(123, 114, 255, 0.13),
      rgba(123, 114, 255, 0)
    ),
    linear-gradient(180deg, #171e36, #0d1221);
}

.showcase-card {
  position: relative;
  z-index: 2;
  width: min(560px, 88vw);
  border: 1px solid var(--line);
  border-radius: 1rem;
  padding: clamp(1.2rem, 2vw, 1.8rem);
  background: linear-gradient(
    165deg,
    rgba(9, 15, 28, 0.84),
    rgba(10, 17, 31, 0.5)
  );
  box-shadow: 0 30px 55px rgba(2, 5, 10, 0.6);
  backdrop-filter: blur(10px);
  transform-style: preserve-3d;
  will-change: transform, opacity;
}

.project-number {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--cyan);
}

.showcase-card h3 {
  margin: 0.5rem 0 0;
  font-family: "Syne", sans-serif;
  font-size: clamp(1.5rem, 2.2vw, 2.2rem);
  line-height: 1.03;
}

.showcase-card p {
  margin: 0.76rem 0 0;
  color: var(--text-dim);
}

.project-tags {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.project-tags li {
  border: 1px solid rgba(177, 203, 255, 0.26);
  border-radius: 999px;
  padding: 0.26rem 0.58rem;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #d5e2f8;
}

.closing {
  min-height: 100svh;
  padding: clamp(5rem, 12vw, 9rem) clamp(1.2rem, 4vw, 4.2rem);
  display: grid;
  place-content: center;
  justify-items: center;
  text-align: center;
  background: linear-gradient(180deg, #05070d, #050811);
}

.closing-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

.halo {
  position: absolute;
  border-radius: 50%;
  filter: blur(34px);
  will-change: transform;
}

.halo-one {
  width: min(52vw, 660px);
  aspect-ratio: 1;
  left: 10%;
  top: 10%;
  background: radial-gradient(
    circle at center,
    rgba(138, 147, 255, 0.3),
    rgba(138, 147, 255, 0)
  );
}

.halo-two {
  width: min(46vw, 580px);
  aspect-ratio: 1;
  right: 8%;
  bottom: 8%;
  background: radial-gradient(
    circle at center,
    rgba(76, 230, 194, 0.24),
    rgba(76, 230, 194, 0)
  );
}

.closing-title {
  margin: 0;
  max-width: 16ch;
  font-family: "Syne", sans-serif;
  font-size: clamp(2.2rem, 6.8vw, 6rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
}

.closing-copy {
  margin: 1.25rem 0 0;
  max-width: 62ch;
  color: var(--text-dim);
}

.cta-ghost {
  color: var(--text);
  border-color: rgba(177, 203, 255, 0.38);
  background: rgba(9, 16, 30, 0.66);
}

.cta-ghost:hover,
.cta-ghost:focus-visible {
  color: #05111b;
  background: linear-gradient(130deg, var(--teal), var(--cyan));
}

.reveal {
  will-change: transform, opacity;
}

@media (max-width: 1100px) {
  .transform-pin {
    grid-template-columns: 1fr;
    align-content: center;
  }

  .story-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-meta {
    grid-template-columns: 1fr;
    max-width: 520px;
  }
}

@media (max-width: 780px) {
  .transform {
    min-height: 330svh;
  }

  .story-stack {
    grid-template-columns: 1fr;
  }

  .showcase-panel {
    padding-top: 8rem;
  }

  .showcase-media {
    inset: 25% 6% 14%;
  }

  .showcase-header h2 {
    max-width: 12ch;
  }
}

@media (max-width: 620px) {
  .hero {
    padding-top: 6.6rem;
  }

  .hero-title {
    font-size: clamp(2.5rem, 16vw, 5rem);
  }

  .showcase-header {
    top: 1rem;
  }

  .showcase-progress {
    width: min(260px, 72vw);
  }
}
