
/* Language switcher in nav */

/* NAV */

.solutions-wrap,
.resources-wrap {
  position: relative;
  display: inline-flex;
}
.solutions-btn::after,
.resources-btn::after {
  content: "▾";
  font-size: 9px;
  transition: transform 0.15s;
  opacity: 0.7;
}
.solutions-wrap:hover .solutions-btn::after,
.resources-wrap:hover .resources-btn::after {
  transform: rotate(180deg);
}
/* BUTTONS */

/* VEE */
.vee-badge {
  display: inline-block;
}
@keyframes veeBlink {
  0%,
  86%,
  94%,
  100% {
    transform: scaleY(1);
  }
  90% {
    transform: scaleY(0.08);
  }
}

/* — SECTION WRAP — */
.wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
h2.section-title {
  font-size: clamp(36px, 5vw, 60px);
  font-weight: 900;
  letter-spacing: -2px;
  line-height: 1.02;
  margin-bottom: 18px;
}
h2.section-title .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899 80%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
p.section-sub {
  font-size: 17px;
  color: var(--w55);
  max-width: 640px;
  line-height: 1.55;
  margin-bottom: 48px;
}
section {
  padding: 90px 0;
  position: relative;
}

/* — HERO — */
.en-hero {
  min-height: 82vh;
  padding: 120px 0 100px;
  display: flex;
  align-items: center;
  text-align: center;
  background:
    radial-gradient(
      ellipse at 50% 35%,
      rgba(124, 58, 237, 0.28) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse at 20% 70%,
      rgba(236, 72, 153, 0.12) 0%,
      transparent 55%
    ),
    #050208;
}
.en-hero-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 40px;
}
.en-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 7px 16px 7px 12px;
  border-radius: 20px;
  background: rgba(124, 58, 237, 0.15);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(124, 58, 237, 0.35);
  font-size: 11px;
  font-weight: 800;
  color: var(--purple-soft);
  letter-spacing: 1.3px;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.en-hero-badge .vee-badge {
  width: 48px;
  height: 48px;
  display: inline-block;
  margin: -14px 6px -14px -10px;
  animation: veeBadgeIdle 3.8s ease-in-out infinite;
  filter: drop-shadow(0 6px 14px rgba(124, 58, 237, 0.6));
}
.en-hero h1 {
  font-size: clamp(48px, 6.5vw, 90px);
  font-weight: 900;
  letter-spacing: -3px;
  line-height: 0.98;
  margin-bottom: 22px;
  color: #fff;
}
.en-hero h1 .strike {
  position: relative;
  color: rgba(255, 255, 255, 0.45);
}
.en-hero h1 .strike::after {
  content: "";
  position: absolute;
  left: -4%;
  right: -4%;
  top: 50%;
  height: 6px;
  background: linear-gradient(90deg, #ec4899, #a78bfa);
  border-radius: 3px;
  transform: rotate(-2deg);
}
.en-hero h1 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.en-hero p.lede {
  font-size: 20px;
  color: var(--w80);
  line-height: 1.5;
  max-width: 620px;
  margin: 0 auto 10px;
}
.en-hero p.sub {
  font-size: 14px;
  color: var(--w55);
  max-width: 500px;
  margin: 0 auto 38px;
}
.en-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

/* — 02 · THREE ROOMS (zig-zag) — */
.en-rooms {
  background: #0a0712;
  border-top: 1px solid var(--w04);
}
.rooms-flow {
  margin-top: 56px;
  display: flex;
  flex-direction: column;
}
.room-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.room-row.flip .room-visual {
  order: 2;
}
.room-row.flip .room-copy {
  order: 1;
}

.room-copy {
  padding: 0 4px;
}
.room-num-large {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.6px;
  color: var(--purple-light);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.room-copy h3 {
  font-size: clamp(32px, 3.8vw, 48px);
  font-weight: 900;
  letter-spacing: -1.6px;
  line-height: 1;
  color: #fff;
  margin-bottom: 20px;
}
.room-copy h3 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.room-lede {
  font-size: 16px;
  color: var(--w80);
  line-height: 1.6;
  margin-bottom: 22px;
}
.room-chip-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}
.room-chip {
  padding: 5px 11px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.25);
  font-size: 11px;
  font-weight: 700;
  color: var(--purple-soft);
  letter-spacing: 0.1px;
}
.room-copy ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 22px;
}
.room-copy ul li {
  font-size: 14px;
  color: var(--w80);
  line-height: 1.55;
  padding-left: 20px;
  position: relative;
}
.room-copy ul li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--purple-light);
  font-weight: 800;
}
.room-outcome {
  padding-top: 16px;
  border-top: 1px dashed var(--w08);
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.room-outcome-label {
  font-size: 10px;
  font-weight: 800;
  color: var(--w35);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.room-outcome-value {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.2px;
}

/* Visual column */
.room-visual {
  position: relative;
  aspect-ratio: 4/3;
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 22px;
  padding: 28px;
  overflow: hidden;
  transition:
    transform 0.3s,
    border-color 0.3s;
}
.room-visual:hover {
  transform: translateY(-3px);
  border-color: rgba(124, 58, 237, 0.3);
}

/* Room 01 · Capture — phone mockup */
.rv-capture {
  background:
    radial-gradient(
      ellipse 400px 280px at 50% 45%,
      rgba(124, 58, 237, 0.18),
      transparent 65%
    ),
    #0a0612;
}
.rv-phone {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-4deg);
  width: 180px;
  aspect-ratio: 9/19;
  background: linear-gradient(180deg, #2d1f4a 0%, #1a1528 100%);
  border: 3px solid #0a0510;
  border-radius: 28px;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.6);
  padding: 22px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rv-phone::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 50%;
  transform: translateX(-50%);
  width: 54px;
  height: 6px;
  border-radius: 6px;
  background: #0a0510;
}
.rv-phone-brief {
  padding: 10px 12px;
  border-radius: 10px;
  background: linear-gradient(
    135deg,
    rgba(124, 58, 237, 0.25),
    rgba(236, 72, 153, 0.15)
  );
  border: 1px solid rgba(124, 58, 237, 0.4);
  font-size: 9px;
  color: #fff;
  line-height: 1.4;
}
.rv-phone-vee {
  font-size: 8px;
  font-weight: 800;
  color: var(--purple-light);
  letter-spacing: 1.1px;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.rv-phone-body {
  flex: 1;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.04),
    rgba(255, 255, 255, 0.01)
  );
  border: 1px dashed rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rv-phone-face {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #c4b5fd, #7c3aed);
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.5);
}
.rv-phone-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.rv-phone-record {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rv-phone-record::after {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ef4444;
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.5);
  animation: recPulse 2s ease-in-out infinite;
}
@keyframes recPulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.88);
  }
}
.rv-phone-timer {
  font-size: 10px;
  font-weight: 800;
  color: #ef4444;
  font-variant-numeric: tabular-nums;
}
.rv-phone-spacer {
  width: 34px;
}

/* Room 02 · Create — timeline editor */
.rv-create {
  background:
    radial-gradient(
      ellipse 400px 280px at 50% 50%,
      rgba(96, 165, 250, 0.1),
      transparent 65%
    ),
    #0a0612;
}
.rv-timeline {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 7px;
  justify-content: center;
}
.rv-tl-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 11px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  font-size: 10px;
  color: var(--w55);
}
.rv-tl-header .label {
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.2px;
}
.rv-tl-header .dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #60a5fa;
  box-shadow: 0 0 8px #60a5fa;
  margin-right: 6px;
}
.rv-track {
  height: 22px;
  border-radius: 6px;
  display: flex;
  gap: 3px;
  padding: 3px;
}
.rv-track.video {
  background: rgba(96, 165, 250, 0.08);
  border: 1px solid rgba(96, 165, 250, 0.22);
}
.rv-track.audio {
  background: rgba(167, 139, 250, 0.08);
  border: 1px solid rgba(167, 139, 250, 0.22);
}
.rv-track.subs {
  background: rgba(236, 72, 153, 0.08);
  border: 1px solid rgba(236, 72, 153, 0.22);
  padding: 6px 10px;
  color: #fff;
  font-size: 9.5px;
  font-weight: 600;
  display: flex;
  align-items: center;
}
.rv-blk {
  flex: 1;
  border-radius: 3px;
  background: linear-gradient(
    180deg,
    rgba(96, 165, 250, 0.55),
    rgba(96, 165, 250, 0.2)
  );
}
.rv-track.audio .rv-blk {
  background: linear-gradient(
    180deg,
    rgba(167, 139, 250, 0.55),
    rgba(167, 139, 250, 0.2)
  );
}
.rv-playhead {
  position: absolute;
  top: 54px;
  bottom: 42px;
  left: 40%;
  width: 2px;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(255, 255, 255, 0.7),
    transparent
  );
  box-shadow: 0 0 8px rgba(124, 58, 237, 0.7);
  animation: playheadMove 7s linear infinite;
}
@keyframes playheadMove {
  0%,
  100% {
    left: 14%;
  }
  50% {
    left: 80%;
  }
}
.rv-editor-note {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(5, 2, 8, 0.85);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 9.5px;
  font-weight: 700;
  color: var(--w80);
  display: flex;
  align-items: center;
  gap: 6px;
}
.rv-editor-note::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
}

/* Room 03 · Connect — platform stack */
.rv-connect {
  background:
    radial-gradient(
      ellipse 400px 280px at 50% 50%,
      rgba(236, 72, 153, 0.1),
      transparent 65%
    ),
    #0a0612;
}
.rv-platforms {
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
  height: 100%;
}
.rv-plat {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 10px 14px;
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.1px;
}
.rv-plat-icon {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 900;
}
.rv-plat.tt .rv-plat-icon {
  background: #000;
  color: #fff;
}
.rv-plat.ig .rv-plat-icon {
  background: linear-gradient(135deg, #f09433, #dc2743, #bc1888);
  color: #fff;
}
.rv-plat.yt .rv-plat-icon {
  background: #ff0000;
  color: #fff;
}
.rv-plat.li .rv-plat-icon {
  background: #0a66c2;
  color: #fff;
}
.rv-plat-status {
  margin-left: auto;
  padding: 3px 9px;
  border-radius: 100px;
  background: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.35);
  font-size: 9.5px;
  font-weight: 800;
  color: var(--green);
  letter-spacing: 0.3px;
}
.rv-sparkline {
  padding: 10px 14px;
  margin-top: 6px;
  border-radius: 11px;
  background: rgba(124, 58, 237, 0.08);
  border: 1px solid rgba(124, 58, 237, 0.22);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--w80);
}
.rv-sparkline-dots {
  color: var(--purple-light);
  font-family: monospace;
  letter-spacing: 2px;
  font-size: 13px;
}
.rv-sparkline strong {
  color: #fff;
  font-weight: 900;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  margin-left: auto;
}

/* Connecting flow line between rows */
.room-flow-line {
  height: 48px;
  position: relative;
}
.room-flow-line::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  border-left: 2px dashed rgba(124, 58, 237, 0.28);
}
.room-flow-line::after {
  content: "↓";
  position: absolute;
  left: 50%;
  bottom: -4px;
  transform: translateX(-50%);
  color: var(--purple-light);
  font-size: 18px;
  font-weight: 800;
  background: #0a0712;
  padding: 0 6px;
}

/* — 03 · 24H CLOCK (Gantt) — */
.en-clock {
  background: var(--dark);
}
.gantt {
  margin-top: 40px;
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 24px;
  padding: 40px 44px;
  position: relative;
}

/* Hour strip on top of the gantt tracks */
.gantt-head {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 28px;
  margin-bottom: 24px;
}
.gantt-head-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.4px;
  color: var(--w35);
  text-transform: uppercase;
  align-self: center;
}
.gantt-hours {
  position: relative;
  height: 22px;
}
.gantt-hour {
  position: absolute;
  top: 0;
  font-size: 11px;
  font-weight: 800;
  color: var(--w55);
  transform: translateX(-50%);
  font-variant-numeric: tabular-nums;
}
.gantt-hour.first {
  transform: none;
}
.gantt-hour.last {
  transform: translateX(-100%);
}

/* Lanes */
.gantt-lanes {
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
}
/* Vertical gridlines behind lanes */
.gantt-lanes::before {
  content: "";
  position: absolute;
  left: 188px;
  right: 0;
  top: 0;
  bottom: 0;
  background-image: repeating-linear-gradient(
    to right,
    transparent 0,
    transparent calc(25% - 1px),
    rgba(255, 255, 255, 0.05) calc(25% - 1px),
    rgba(255, 255, 255, 0.05) 25%
  );
  pointer-events: none;
}
.gantt-lane {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 28px;
  align-items: center;
}
.gantt-lane-label {
  display: flex;
  align-items: center;
  gap: 12px;
}
.gantt-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
}
.gantt-lane.you .gantt-dot {
  background: #a78bfa;
  box-shadow: 0 0 12px #a78bfa;
}
.gantt-lane.vee .gantt-dot {
  background: linear-gradient(135deg, #8b5cf6, #ec4899);
  box-shadow: 0 0 12px rgba(124, 58, 237, 0.7);
}
.gantt-lane.human .gantt-dot {
  background: #60a5fa;
  box-shadow: 0 0 12px #60a5fa;
}
.gantt-lane-name {
  font-size: 14px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.2px;
}
.gantt-lane-sub {
  font-size: 11px;
  color: var(--w55);
  margin-top: 2px;
  letter-spacing: 0.1px;
}

.gantt-track {
  position: relative;
  height: 48px;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--w08);
  border-radius: 12px;
}
.gantt-bar {
  position: absolute;
  top: 5px;
  bottom: 5px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11.5px;
  font-weight: 800;
  color: #fff;
  padding: 0 12px;
  letter-spacing: -0.1px;
  white-space: nowrap;
  overflow: hidden;
  opacity: 0;
  transform: scaleX(0.8);
  transform-origin: left;
  transition:
    opacity 0.5s,
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.gantt.on .gantt-bar {
  opacity: 1;
  transform: scaleX(1);
}
.gantt.on .gantt-bar.b1 {
  transition-delay: 0.1s;
}
.gantt.on .gantt-bar.b2 {
  transition-delay: 0.35s;
}
.gantt.on .gantt-bar.b3 {
  transition-delay: 0.6s;
}
.gantt.on .gantt-bar.b4 {
  transition-delay: 0.95s;
}
.gantt.on .gantt-bar.b5 {
  transition-delay: 1.25s;
}
.gantt.on .gantt-bar.b6 {
  transition-delay: 1.6s;
}

.gantt-lane.you .gantt-bar {
  background: linear-gradient(135deg, #c4b5fd, #8b5cf6);
  box-shadow: 0 4px 14px rgba(167, 139, 250, 0.4);
}
.gantt-lane.vee .gantt-bar {
  background: linear-gradient(135deg, #8b5cf6, #ec4899);
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.5);
}
.gantt-lane.human .gantt-bar {
  background: linear-gradient(135deg, #60a5fa, #2563eb);
  box-shadow: 0 4px 14px rgba(96, 165, 250, 0.4);
}

/* Tiny bars (You actions) get a floating label above */
.gantt-bar.mini {
  min-width: 16px;
  padding: 0;
}
.gantt-bar.mini .bar-label {
  position: absolute;
  top: -26px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 800;
  color: var(--w80);
  white-space: nowrap;
  background: var(--dark);
  padding: 3px 8px;
  border: 1px solid var(--w08);
  border-radius: 7px;
  letter-spacing: 0.1px;
}
.gantt-bar.mini .bar-label::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -4px;
  transform: translateX(-50%) rotate(45deg);
  width: 6px;
  height: 6px;
  background: var(--dark);
  border-right: 1px solid var(--w08);
  border-bottom: 1px solid var(--w08);
}

/* Wait zone — 14h-20h shaded */
.gantt-wait {
  position: absolute;
  left: 58.33%;
  width: 25%;
  top: -8px;
  bottom: -8px;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 6px,
    rgba(255, 255, 255, 0.03) 6px,
    rgba(255, 255, 255, 0.03) 12px
  );
  pointer-events: none;
  z-index: 0;
  border-radius: 12px;
}
.gantt-wait-label {
  position: absolute;
  left: 70.83%;
  top: -22px;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 800;
  color: var(--w35);
  letter-spacing: 1.4px;
  text-transform: uppercase;
}

/* Legend */
.gantt-legend {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px dashed var(--w08);
  display: flex;
  justify-content: center;
  gap: 28px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--w55);
}
.gantt-legend-item {
  display: flex;
  align-items: center;
  gap: 7px;
}
.gantt-legend-item strong {
  color: #fff;
  font-weight: 800;
}

/* Stop chips below — detailed breakdown */
.clock-stops-detail {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  margin-top: 30px;
  padding-top: 26px;
  border-top: 1px solid var(--w08);
}
.clock-stop-chip {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--w08);
  border-radius: 12px;
  padding: 14px;
  transition:
    border-color 0.2s,
    transform 0.2s;
}
.clock-stop-chip:hover {
  transform: translateY(-2px);
  border-color: rgba(124, 58, 237, 0.3);
}
.clock-stop-chip .h {
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.3px;
  margin-bottom: 5px;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.clock-stop-chip .t {
  font-size: 12px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.2px;
  margin-bottom: 4px;
}
.clock-stop-chip .d {
  font-size: 11px;
  color: var(--w55);
  line-height: 1.5;
}

/* — 04 · RELAY (AI + humans) — */
.en-split {
  background: #0a0712;
  border-top: 1px solid var(--w04);
}
.relay-track {
  max-width: 960px;
  margin: 56px auto 0;
  position: relative;
  padding: 20px 0;
}
.relay-track::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    180deg,
    rgba(124, 58, 237, 0.45) 0%,
    rgba(124, 58, 237, 0.45) 42%,
    rgba(96, 165, 250, 0.45) 46%,
    rgba(96, 165, 250, 0.45) 80%,
    rgba(124, 58, 237, 0.45) 84%,
    rgba(124, 58, 237, 0.45) 100%
  );
  transform: translateX(-50%);
  border-radius: 2px;
}

.relay-step {
  display: grid;
  grid-template-columns: 1fr 56px 1fr;
  align-items: center;
  gap: 20px;
  min-height: 110px;
  margin-bottom: 10px;
  position: relative;
}

.relay-badge {
  grid-column: 2;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  letter-spacing: -0.5px;
}
.relay-step.vee .relay-badge {
  background: linear-gradient(135deg, #8b5cf6, #ec4899);
  box-shadow:
    0 0 28px rgba(124, 58, 237, 0.45),
    0 8px 18px rgba(0, 0, 0, 0.4);
}
.relay-step.human .relay-badge {
  background: linear-gradient(135deg, #60a5fa, #2563eb);
  box-shadow:
    0 0 28px rgba(96, 165, 250, 0.4),
    0 8px 18px rgba(0, 0, 0, 0.4);
}

.relay-card {
  padding: 20px 24px;
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 16px;
  transition:
    border-color 0.25s,
    transform 0.25s;
  position: relative;
}
.relay-card:hover {
  transform: translateY(-2px);
  border-color: rgba(124, 58, 237, 0.35);
}
.relay-step.vee .relay-card {
  grid-column: 3;
  border-top: 2px solid rgba(139, 92, 246, 0.5);
}
.relay-step.human .relay-card {
  grid-column: 1;
  border-top: 2px solid rgba(96, 165, 250, 0.5);
}

/* Horizontal connector from badge to card */
.relay-step::after {
  content: "";
  position: absolute;
  top: 50%;
  height: 1px;
  background: linear-gradient(
    to var(--dir, right),
    rgba(124, 58, 237, 0.4),
    transparent
  );
  z-index: 1;
}
.relay-step.vee::after {
  left: 50%;
  right: calc(50% - 76px);
  --dir: right;
}
.relay-step.human::after {
  right: 50%;
  left: calc(50% - 76px);
  background: linear-gradient(to left, rgba(96, 165, 250, 0.4), transparent);
}

.relay-step-num {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.relay-step.vee .relay-step-num {
  color: var(--purple-light);
}
.relay-step.human .relay-step-num {
  color: #93c5fd;
}
.relay-card h4 {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.4px;
  color: #fff;
  margin-bottom: 6px;
}
.relay-card p {
  font-size: 13.5px;
  color: var(--w55);
  line-height: 1.55;
}

/* Handoff indicator when actor changes */
.relay-step.handoff {
  margin-top: 36px;
}
.relay-step.handoff::before {
  content: "baton passes";
  position: absolute;
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--purple-soft);
  background: #0a0712;
  padding: 3px 12px;
  border-radius: 100px;
  border: 1px solid rgba(124, 58, 237, 0.35);
  white-space: nowrap;
}

/* Post-relay note */
.relay-note {
  max-width: 640px;
  margin: 48px auto 0;
  padding: 18px 22px;
  background: rgba(96, 165, 250, 0.05);
  border: 1px solid rgba(96, 165, 250, 0.2);
  border-left: 2px solid rgba(96, 165, 250, 0.5);
  border-radius: 0 12px 12px 0;
  font-size: 13.5px;
  color: var(--w80);
  line-height: 1.6;
}
.relay-note strong {
  color: #fff;
  font-weight: 800;
}

/* — PROOF STRIP — */
.en-proof {
  background: var(--dark);
  border-top: 1px solid var(--w04);
  padding: 70px 0 80px;
}
.proof-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 32px;
}
.proof-title {
  font-size: clamp(26px, 3.2vw, 40px);
  font-weight: 900;
  letter-spacing: -1.2px;
  line-height: 1;
  color: #fff;
}
.proof-title .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.proof-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--purple-light);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.3);
  transition:
    gap 0.2s,
    background 0.2s;
}
.proof-link:hover {
  gap: 10px;
  background: rgba(124, 58, 237, 0.18);
}

/* — Case study grid — horizontal scroller (matches frontpage) — */
.case-grid-wrap {
  position: relative;
  margin: 8px 0 0;
}
.case-grid {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 30px 40px 26px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 3%,
    black 97%,
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 3%,
    black 97%,
    transparent 100%
  );
}
.case-grid::-webkit-scrollbar {
  display: none;
}

.case-card {
  flex-shrink: 0;
  width: 280px;
  aspect-ratio: 9 / 16;
  scroll-snap-align: start;
  position: relative;
  border-radius: 18px;
  transition:
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.55);
  background-size: cover;
  background-position: center;
  background-color: #0d0a14;
  text-decoration: none;
  color: inherit;
}
.case-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    180deg,
    rgba(13, 10, 20, 0) 0%,
    rgba(13, 10, 20, 0.25) 45%,
    rgba(5, 2, 8, 0.92) 100%
  );
  z-index: 1;
}
.case-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: 0.18;
  z-index: 2;
  pointer-events: none;
}
.case-card:hover {
  transform: translateY(-5px) scale(1.015);
  box-shadow:
    0 30px 68px rgba(0, 0, 0, 0.75),
    0 0 50px rgba(124, 58, 237, 0.22);
}

/* Brand tints per card */
.case-card[data-tint="teal"]::before {
  background: linear-gradient(
    180deg,
    rgba(30, 70, 65, 0.35) 0%,
    rgba(16, 40, 38, 0.55) 45%,
    rgba(5, 16, 16, 0.95) 100%
  );
}
.case-card[data-tint="amber"]::before {
  background: linear-gradient(
    180deg,
    rgba(82, 40, 15, 0.35) 0%,
    rgba(52, 24, 10, 0.6) 45%,
    rgba(16, 8, 4, 0.95) 100%
  );
}
.case-card[data-tint="coral"]::before {
  background: linear-gradient(
    180deg,
    rgba(90, 25, 50, 0.35) 0%,
    rgba(60, 16, 36, 0.6) 45%,
    rgba(20, 6, 14, 0.95) 100%
  );
}
.case-card[data-tint="purple"]::before {
  background: linear-gradient(
    180deg,
    rgba(50, 28, 86, 0.35) 0%,
    rgba(32, 18, 60, 0.6) 45%,
    rgba(12, 8, 26, 0.95) 100%
  );
}
.case-card[data-tint="blue"]::before {
  background: linear-gradient(
    180deg,
    rgba(24, 44, 78, 0.35) 0%,
    rgba(14, 28, 52, 0.6) 45%,
    rgba(6, 12, 22, 0.95) 100%
  );
}

/* Card brand logo — top right, tilted, floating, fits brand name */
.case-card .case-brand-logo {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 8px 14px;
  border-radius: 10px;
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #0d0a14;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: -0.2px;
  white-space: nowrap;
  max-width: calc(100% - 28px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.5),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
  overflow: hidden;
  z-index: 4;
  animation: caseLogoFloat 3.6s ease-in-out infinite;
}
.case-card:nth-child(1) .case-brand-logo {
  animation-duration: 4.1s;
  animation-delay: 0s;
  --skew-a: -7deg;
  --skew-b: -4deg;
}
.case-card:nth-child(2) .case-brand-logo {
  animation-duration: 3.4s;
  animation-delay: -1.7s;
  --skew-a: -5deg;
  --skew-b: -3deg;
}
.case-card:nth-child(3) .case-brand-logo {
  animation-duration: 4.8s;
  animation-delay: -2.9s;
  --skew-a: -6deg;
  --skew-b: -3deg;
}
.case-card:nth-child(4) .case-brand-logo {
  animation-duration: 3.7s;
  animation-delay: -0.5s;
  --skew-a: -4deg;
  --skew-b: -6deg;
}
.case-card:nth-child(5) .case-brand-logo {
  animation-duration: 4.3s;
  animation-delay: -3.1s;
  --skew-a: -8deg;
  --skew-b: -5deg;
}
.case-card:nth-child(6) .case-brand-logo {
  animation-duration: 3.2s;
  animation-delay: -1.2s;
  --skew-a: -6deg;
  --skew-b: -4deg;
}
.case-card:nth-child(7) .case-brand-logo {
  animation-duration: 4.6s;
  animation-delay: -2.4s;
  --skew-a: -5deg;
  --skew-b: -2deg;
}
.case-card:nth-child(8) .case-brand-logo {
  animation-duration: 3.9s;
  animation-delay: -0.8s;
  --skew-a: -3deg;
  --skew-b: -5deg;
}
.case-card:nth-child(9) .case-brand-logo {
  animation-duration: 4s;
  animation-delay: -3.4s;
  --skew-a: -7deg;
  --skew-b: -4deg;
}
.case-card:nth-child(10) .case-brand-logo {
  animation-duration: 3.5s;
  animation-delay: -1.5s;
  --skew-a: -5deg;
  --skew-b: -7deg;
}
.case-card:nth-child(11) .case-brand-logo {
  animation-duration: 4.7s;
  animation-delay: -2.7s;
  --skew-a: -6deg;
  --skew-b: -3deg;
}
.case-card:nth-child(12) .case-brand-logo {
  animation-duration: 3.3s;
  animation-delay: -0.3s;
  --skew-a: -4deg;
  --skew-b: -2deg;
}
.case-card:nth-child(13) .case-brand-logo {
  animation-duration: 4.4s;
  animation-delay: -2s;
  --skew-a: -8deg;
  --skew-b: -6deg;
}
.case-card:nth-child(14) .case-brand-logo {
  animation-duration: 3.8s;
  animation-delay: -1s;
  --skew-a: -6deg;
  --skew-b: -4deg;
}
.case-card:nth-child(15) .case-brand-logo {
  animation-duration: 4.2s;
  animation-delay: -3.2s;
  --skew-a: -4deg;
  --skew-b: -2deg;
}
.case-card:nth-child(16) .case-brand-logo {
  animation-duration: 3.6s;
  animation-delay: -0.6s;
  --skew-a: -7deg;
  --skew-b: -5deg;
}
.case-card:nth-child(17) .case-brand-logo {
  animation-duration: 4.5s;
  animation-delay: -1.9s;
  --skew-a: -6deg;
  --skew-b: -4deg;
}
.case-card:nth-child(18) .case-brand-logo {
  animation-duration: 3.1s;
  animation-delay: -2.6s;
  --skew-a: -3deg;
  --skew-b: -1deg;
}
.case-card:nth-child(19) .case-brand-logo {
  animation-duration: 4.9s;
  animation-delay: -1.1s;
  --skew-a: -5deg;
  --skew-b: -3deg;
}
.case-card:nth-child(20) .case-brand-logo {
  animation-duration: 3.4s;
  animation-delay: -2.8s;
  --skew-a: -5deg;
  --skew-b: -7deg;
}
.case-card:nth-child(21) .case-brand-logo {
  animation-duration: 4.1s;
  animation-delay: -0.7s;
  --skew-a: -7deg;
  --skew-b: -5deg;
}
.case-card:nth-child(22) .case-brand-logo {
  animation-duration: 3.7s;
  animation-delay: -2.3s;
  --skew-a: -4deg;
  --skew-b: -6deg;
}
.case-card:nth-child(23) .case-brand-logo {
  animation-duration: 4.6s;
  animation-delay: -1.6s;
  --skew-a: -6deg;
  --skew-b: -3deg;
}
.case-card:nth-child(24) .case-brand-logo {
  animation-duration: 3.9s;
  animation-delay: -0.4s;
  --skew-a: -5deg;
  --skew-b: -3deg;
}
.case-card:nth-child(25) .case-brand-logo {
  animation-duration: 4.2s;
  animation-delay: -3s;
  --skew-a: -8deg;
  --skew-b: -6deg;
}
.case-card:nth-child(26) .case-brand-logo {
  animation-duration: 3.6s;
  animation-delay: -1.4s;
  --skew-a: -5deg;
  --skew-b: -2deg;
}
.case-card:nth-child(27) .case-brand-logo {
  animation-duration: 4.4s;
  animation-delay: -2.1s;
  --skew-a: -6deg;
  --skew-b: -4deg;
}
.case-card:nth-child(28) .case-brand-logo {
  animation-duration: 3.3s;
  animation-delay: -0.9s;
  --skew-a: -4deg;
  --skew-b: -7deg;
}
.case-card:nth-child(29) .case-brand-logo {
  animation-duration: 4.7s;
  animation-delay: -2.5s;
  --skew-a: -7deg;
  --skew-b: -3deg;
}

.case-card .case-card-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  z-index: 0;
  pointer-events: none;
  background: #0d0a14;
}

@keyframes caseLogoFloat {
  0%,
  100% {
    translate: 0 0;
    rotate: var(--skew-a, -6deg);
  }
  50% {
    translate: 0 -5px;
    rotate: var(--skew-b, -4deg);
  }
}
/* Video-type label — bottom-left, small uppercase */
.case-card .case-card-type {
  position: absolute;
  bottom: 14px;
  left: 14px;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.85);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  z-index: 4;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.7);
}
.case-brand-logo {
  scale: 1;
  transition: scale 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.case-brand-logo:hover {
  scale: 1.03;
}

/* Play button centered */
.case-card .case-play {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.95);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 32px rgba(124, 58, 237, 0.6);
  transition:
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.4s ease;
  z-index: 3;
  animation: playPulse 2.4s ease-in-out infinite;
}
.case-card .case-play::before {
  content: "";
  width: 0;
  height: 0;
  margin-left: 5px;
  border-left: 14px solid var(--dark);
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
}
.case-card:hover .case-play {
  transform: translate(-50%, -50%) scale(1.08);
  background: #fff;
  box-shadow: 0 12px 44px rgba(124, 58, 237, 0.8);
}
@keyframes playPulse {
  0%,
  100% {
    box-shadow:
      0 8px 32px rgba(124, 58, 237, 0.6),
      0 0 0 0 rgba(124, 58, 237, 0.5);
  }
  50% {
    box-shadow:
      0 8px 32px rgba(124, 58, 237, 0.6),
      0 0 0 14px rgba(124, 58, 237, 0);
  }
}

/* Card bottom — quote + attribution */
.case-card-bottom {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px 18px 18px;
  color: #fff;
  z-index: 3;
}
.case-card-bottom .case-quote {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.32;
  color: #fff;
  margin: 0 0 10px;
  font-style: italic;
  letter-spacing: -0.1px;
}
.case-card-bottom .case-name {
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.1px;
}
.case-card-bottom .case-role {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.55);
  margin-top: 2px;
}

/* Nav arrows */
.case-nav {
  position: absolute;
  top: 44%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(20, 17, 31, 0.95);
  border: 1px solid rgba(124, 58, 237, 0.32);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #fff;
  font-family: "Outfit", sans-serif;
  font-size: 22px;
  font-weight: 400;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
  transition:
    transform 0.2s,
    background 0.2s,
    border-color 0.2s,
    box-shadow 0.2s;
}
.case-nav.prev {
  left: 4px;
}
.case-nav.next {
  right: 4px;
}
.case-nav:hover {
  background: rgba(124, 58, 237, 0.24);
  border-color: rgba(124, 58, 237, 0.65);
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 10px 32px rgba(124, 58, 237, 0.4);
}

/* — 04 · FAQ — */
.en-faq {
  background: var(--dark);
}
.faq-list {
  max-width: 820px;
  margin: 32px auto 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.faq-item {
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color 0.2s;
}
.faq-item.open {
  border-color: rgba(124, 58, 237, 0.35);
}
.faq-q {
  width: 100%;
  padding: 20px 24px;
  border: none;
  background: transparent;
  font-family: var(--font);
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-align: left;
  letter-spacing: -0.2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.faq-q-icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(124, 58, 237, 0.15);
  color: var(--purple-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 400;
  flex-shrink: 0;
  transition:
    transform 0.2s,
    background 0.2s;
}
.faq-item.open .faq-q-icon {
  transform: rotate(45deg);
  background: rgba(124, 58, 237, 0.25);
}
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.faq-a-inner {
  padding: 0 24px 20px;
  font-size: 14.5px;
  color: var(--w80);
  line-height: 1.65;
}

/* — FINAL CTA — */
.en-final {
  padding: 100px 0 120px;
  text-align: center;
  background: radial-gradient(
    ellipse at 50% 50%,
    rgba(124, 58, 237, 0.18) 0%,
    transparent 60%
  );
}
.en-final-icon {
  width: 88px;
  height: 88px;
  margin: 0 auto 24px;
  display: block;
  filter: drop-shadow(0 8px 32px rgba(124, 58, 237, 0.5));
  animation: floaty 3.2s ease-in-out infinite;
}
@keyframes floaty {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}
.en-final h2 {
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 900;
  letter-spacing: -2.2px;
  line-height: 1.02;
  margin-bottom: 16px;
  color: #fff;
}
.en-final h2 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.en-final p {
  font-size: 17px;
  color: var(--w55);
  max-width: 540px;
  margin: 0 auto 40px;
}
.en-final-ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

/* — FOOTER — */

.cal-mock {
  padding: 24px 28px 28px;
}
.cal-month {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
}
.cal-arrow {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--w08);
  color: var(--w55);
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font);
}
.cal-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 20px;
}
.cal-day-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--w35);
  text-align: center;
  padding-bottom: 8px;
}
.cal-d {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--w80);
  border-radius: 8px;
}
.cal-d.empty {
  visibility: hidden;
}
.cal-d.off {
  color: var(--w15);
}
.cal-d.selected {
  background: var(--purple);
  color: #fff;
}
.cal-times-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--purple-light);
  margin-bottom: 12px;
}
.cal-times-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}
.cal-time {
  padding: 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  color: var(--w80);
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
}
.cal-time.active {
  background: rgba(124, 58, 237, 0.2);
  border-color: rgba(124, 58, 237, 0.5);
  color: #fff;
}
.cal-confirm {
  width: 100%;
  padding: 14px;
  border-radius: 12px;
  background: var(--purple);
  border: none;
  color: #fff;
  font-family: var(--font);
  font-size: 15px;
  font-weight: 700;
  box-shadow: 0 6px 24px rgba(124, 58, 237, 0.45);
}

/* RESPONSIVE */
@media (max-width: 1310px) {
  .room-row {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .room-row.flip .room-visual,
  .room-row.flip .room-copy {
    order: initial;
  }
  .room-visual {
    aspect-ratio: 4/3;
  }
  .clock-stops-detail {
    grid-template-columns: repeat(3, 1fr);
  }
  .gantt {
    padding: 24px 20px;
  }
  .gantt-head,
  .gantt-lane {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .gantt-lanes::before {
    display: none;
  }
  .relay-track::before {
    left: 24px;
  }
  .relay-step {
    grid-template-columns: 48px 1fr;
    gap: 16px;
    min-height: 0;
  }
  .relay-badge {
    grid-column: 1;
  }
  .relay-step.vee .relay-card,
  .relay-step.human .relay-card {
    grid-column: 2;
  }
  .relay-step::after {
    display: none;
  }
  .relay-step.handoff::before {
    left: 24px;
    transform: none;
  }
}
@media (max-width: 640px) {  .wrap {
    padding: 0 20px;
  }
  /* Inner-wrappers don't inherit .wrap's override — match the 20px gutter. */
  .en-hero-inner,
  .en-loop-inner,
  .en-tier-bridge .wrap {
    padding: 0 20px;
  }
  section {
    padding: 60px 0;
  }
  .clock-stops-detail {
    grid-template-columns: 1fr 1fr;
  }
  .govern-grid {
    grid-template-columns: 1fr !important;
  }
}

/* — 01 · WHAT'S IN THE ENGINE (bento) — */
.en-components {
  background: var(--dark);
}
.bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(190px, auto);
  gap: 14px;
  margin-top: 48px;
}
.bento-tile {
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 20px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  transition:
    border-color 0.25s,
    transform 0.25s,
    background 0.25s;
  position: relative;
  overflow: hidden;
}
.bento-tile:hover {
  transform: translateY(-3px);
  border-color: rgba(124, 58, 237, 0.4);
}
.bento-tile.span-2 {
  grid-column: span 2;
}
.bento-tile.span-2x2 {
  grid-column: span 2;
  grid-row: span 2;
  padding: 0;
}

.bento-tag {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--purple-light);
  margin-bottom: 16px;
}
.bento-title {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.6px;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 10px;
}
.bento-sub {
  font-size: 13.5px;
  color: var(--w55);
  line-height: 1.55;
}
.bento-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: rgba(124, 58, 237, 0.15);
  border: 1px solid rgba(124, 58, 237, 0.28);
  color: var(--purple-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  font-weight: 900;
  margin-bottom: 18px;
}

/* Creator hero tile */
.bento-hero {
  background:
    linear-gradient(
      180deg,
      rgba(5, 2, 8, 0.12) 0%,
      rgba(5, 2, 8, 0.45) 55%,
      rgba(5, 2, 8, 0.93) 100%
    ),
    url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-3.webp")
      center/cover no-repeat,
    var(--dark2);
}
.bento-hero-content {
  padding: 30px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.bento-hero-tag {
  align-self: flex-start;
  padding: 6px 12px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.28);
  border: 1px solid rgba(124, 58, 237, 0.45);
  backdrop-filter: blur(10px);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.6px;
  color: var(--purple-soft);
  text-transform: uppercase;
}
.bento-hero-text h3 {
  font-size: clamp(30px, 3.2vw, 48px);
  font-weight: 900;
  letter-spacing: -1.4px;
  color: #fff;
  line-height: 0.96;
  margin-bottom: 12px;
}
.bento-hero-text h3 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.bento-hero-text p {
  font-size: 14px;
  color: var(--w80);
  line-height: 1.5;
  max-width: 340px;
}

/* Secondary photo tile */
.bento-photo {
  background:
    linear-gradient(
      180deg,
      rgba(5, 2, 8, 0.35) 0%,
      rgba(5, 2, 8, 0.7) 45%,
      rgba(5, 2, 8, 0.95) 100%
    ),
    url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-4.webp")
      center/cover no-repeat,
    var(--dark2);
  border-color: rgba(124, 58, 237, 0.28);
}
.bento-photo .bento-tag {
  color: var(--purple-soft);
}
.bento-photo .bento-sub {
  color: var(--w80);
}
.bento-photo .bento-icon {
  background: rgba(124, 58, 237, 0.4);
  border-color: rgba(124, 58, 237, 0.6);
  color: #fff;
  backdrop-filter: blur(8px);
}
.bento-photo .plat-chip {
  background: rgba(5, 2, 8, 0.6);
  backdrop-filter: blur(8px);
  border-color: rgba(255, 255, 255, 0.15);
  color: #fff;
}

/* Vee tile — calm, one-of-many */
.bento-vee {
  background: var(--dark2);
  border-color: var(--w08);
}
.bento-vee-badge {
  width: 46px;
  height: 46px;
  border-radius: 13px;
  background: linear-gradient(135deg, #8b5cf6, #ec4899);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.28);
}
.bento-vee-badge svg {
  width: 70%;
  height: 70%;
}

/* Brand kit swatches */
.bento-swatches {
  display: flex;
  gap: 6px;
  margin-top: auto;
  padding-top: 18px;
}
.swatch {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  border: 1px solid var(--w08);
}
.swatch.s1 {
  background: #7c3aed;
}
.swatch.s2 {
  background: #ec4899;
}
.swatch.s3 {
  background: #14111f;
  border-color: var(--w15);
}
.swatch.s4 {
  background: #f3f0ff;
}
.swatch.s5 {
  background: #fbbf24;
}

/* Publishing platform chips */
.bento-platforms {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: 14px;
}
.plat-chip {
  padding: 4px 9px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--w08);
  font-size: 10px;
  font-weight: 700;
  color: var(--w80);
  letter-spacing: 0.2px;
}

/* Learning loop stat */
.bento-stat {
  font-size: 40px;
  font-weight: 900;
  letter-spacing: -2px;
  line-height: 1;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-top: auto;
  padding-top: 14px;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.bento-stat .loop-arrow-icon {
  font-size: 26px;
  -webkit-text-fill-color: #a78bfa;
}

/* Honesty marker */
.bento-honesty {
  font-size: 14px;
  color: var(--w55);
  line-height: 1.6;
  max-width: 640px;
  padding: 12px 16px;
  border-left: 2px solid rgba(124, 58, 237, 0.4);
  background: rgba(124, 58, 237, 0.04);
  border-radius: 0 8px 8px 0;
  margin-top: -32px;
  margin-bottom: 48px;
}
.bento-honesty em {
  font-style: italic;
  color: var(--w80);
}

/* Recap line */
.bento-recap {
  text-align: center;
  margin-top: 48px;
  font-size: 15px;
  font-weight: 700;
  color: var(--w80);
  letter-spacing: -0.2px;
}
.bento-recap .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 900;
}

@media (max-width: 900px) {
  .bento {
    grid-template-columns: 1fr;
  }
  .bento-tile.span-2,
  .bento-tile.span-2x2 {
    grid-column: auto;
    grid-row: auto;
  }
  .bento-tile.span-2x2 {
    min-height: 320px;
  }
}

/* — 05 · BRAND GOVERNANCE — */
.en-govern {
  background: var(--dark);
}
.govern-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 40px;
}
.govern-item {
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 18px;
  padding: 28px 26px;
  transition:
    border-color 0.25s,
    transform 0.25s;
  position: relative;
  overflow: hidden;
}
.govern-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(124, 58, 237, 0.5),
    transparent
  );
  opacity: 0;
  transition: opacity 0.25s;
}
.govern-item:hover {
  transform: translateY(-3px);
  border-color: rgba(124, 58, 237, 0.35);
}
.govern-item:hover::before {
  opacity: 1;
}
.govern-num {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 1.6px;
  color: var(--purple-light);
  margin-bottom: 14px;
  font-variant-numeric: tabular-nums;
}
.govern-item h4 {
  font-size: 19px;
  font-weight: 900;
  letter-spacing: -0.5px;
  color: #fff;
  margin-bottom: 10px;
  line-height: 1.15;
}
.govern-item p {
  font-size: 13.5px;
  color: var(--w55);
  line-height: 1.6;
}

/* — INTERLUDE · HUMAN — */
.en-interlude {
  padding: 0;
  background: #050208;
  border-top: 1px solid var(--w04);
  border-bottom: 1px solid var(--w04);
  position: relative;
  overflow: hidden;
}
.en-interlude-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 90px 40px;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 56px;
  align-items: center;
}
.en-interlude-photos {
  position: relative;
  aspect-ratio: 4/3;
}
.en-interlude-photo {
  position: absolute;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--w08);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
  background-size: cover;
  background-position: center;
}
.en-interlude-photo.p1 {
  top: 0;
  left: 0;
  width: 62%;
  height: 78%;
  transform: rotate(-2.5deg);
  z-index: 1;
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-1.webp");
}
.en-interlude-photo.p2 {
  bottom: 0;
  right: 0;
  width: 58%;
  height: 72%;
  transform: rotate(3deg);
  z-index: 2;
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-2.webp");
}
.en-interlude-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 55%,
    rgba(5, 2, 8, 0.35) 100%
  );
}
.en-interlude-tag {
  position: absolute;
  bottom: 12px;
  left: 12px;
  z-index: 3;
  padding: 6px 12px;
  border-radius: 100px;
  background: rgba(5, 2, 8, 0.7);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.4px;
  color: var(--purple-soft);
  text-transform: uppercase;
}
.en-interlude-copy {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.en-interlude-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.6px;
  color: var(--purple-light);
  text-transform: uppercase;
}
.en-interlude h2 {
  font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 900;
  letter-spacing: -2px;
  line-height: 1.02;
  color: #fff;
}
.en-interlude h2 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.en-interlude p {
  font-size: 17px;
  color: var(--w80);
  line-height: 1.6;
  max-width: 460px;
}
.en-interlude-stat {
  display: flex;
  gap: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--w08);
}
.en-interlude-stat-item .n {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -1px;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
  margin-bottom: 4px;
}
.en-interlude-stat-item .l {
  font-size: 11px;
  font-weight: 700;
  color: var(--w55);
  letter-spacing: 0.3px;
}
@media (max-width: 900px) {
  .en-interlude-inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 60px 20px;
  }
  .en-interlude-photos {
    aspect-ratio: 1/1;
  }
}

/* — 06 · LEARNING LOOP — */
.en-loop {
  background: #0a0712;
  border-top: 1px solid var(--w04);
}
.loop-frame {
  max-width: 720px;
  margin: 40px auto 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}
.loop-step {
  background: var(--dark2);
  border: 1px solid var(--w08);
  border-radius: 18px;
  padding: 24px 28px;
  transition:
    border-color 0.25s,
    transform 0.25s;
}
.loop-step[data-step="1"] {
  border-left: 3px solid #a78bfa;
}
.loop-step[data-step="2"] {
  border-left: 3px solid #60a5fa;
}
.loop-step[data-step="3"] {
  border-left: 3px solid #ec4899;
}
.loop-step:hover {
  transform: translateX(3px);
  border-color: rgba(124, 58, 237, 0.3);
}
.loop-step-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.loop-week {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.5px;
}
.loop-tag {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.12);
  color: var(--purple-light);
  border: 1px solid rgba(124, 58, 237, 0.25);
}
.loop-step p {
  font-size: 14px;
  color: var(--w80);
  line-height: 1.6;
}
.loop-arrow {
  text-align: center;
  color: var(--purple-light);
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  padding: 2px 0;
}
.loop-note {
  max-width: 720px;
  margin: 28px auto 0;
  padding: 18px 22px;
  background: rgba(124, 58, 237, 0.06);
  border: 1px solid rgba(124, 58, 237, 0.2);
  border-radius: 14px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 13px;
  color: var(--w80);
  line-height: 1.6;
}
.loop-note strong {
  color: #fff;
  font-weight: 800;
}
.loop-note-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  flex-shrink: 0;
  background: rgba(124, 58, 237, 0.2);
  color: var(--purple-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 900;
}

/* ═══════════════════════════════════════════════════════════
     VEE CHARACTER SYSTEM
     ═══════════════════════════════════════════════════════════ */
.vee-char {
  display: inline-block;
  position: relative;
  border-radius: 26%;
  background: linear-gradient(135deg, #8b5cf6, #6d28d9);
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.35);
  overflow: visible;
  flex-shrink: 0;
}
.vee-char svg {
  width: 100%;
  height: 100%;
  display: block;
}
.vee-char.s-24 {
  width: 24px;
  height: 24px;
}
.vee-char.s-34 {
  width: 34px;
  height: 34px;
}
.vee-char.s-44 {
  width: 44px;
  height: 44px;
}
.vee-char.s-52 {
  width: 52px;
  height: 52px;
}
.vee-char.s-80 {
  width: 80px;
  height: 80px;
  box-shadow: 0 8px 28px rgba(124, 58, 237, 0.45);
}
.vee-char .v-eye {
  transform-origin: center;
  animation: veeBlink2 3.4s ease-in-out infinite;
}
.vee-char .v-eye.delay {
  animation-delay: 0.05s;
}
@keyframes veeBlink2 {
  0%,
  92%,
  100% {
    transform: scaleY(1);
  }
  94%,
  96% {
    transform: scaleY(0.1);
  }
}
.vee-char.idle .v-eye-group {
  animation: veeLook2 4.8s ease-in-out infinite;
}
@keyframes veeLook2 {
  0%,
  100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-1.5px);
  }
  65% {
    transform: translateX(1.5px);
  }
}

/* ═══════════════════════════════════════════════════════════
     BRAND PHOTO TREATMENT
     ═══════════════════════════════════════════════════════════ */
.brand-photo {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid var(--w08);
  background-size: cover;
  background-position: center;
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.55);
  isolation: isolate;
}
.brand-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: 0.35;
  pointer-events: none;
}
.brand-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(
      ellipse 120% 80% at 50% 110%,
      rgba(60, 30, 10, 0.4) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 100% 60% at 50% -10%,
      rgba(20, 40, 80, 0.25) 0%,
      transparent 60%
    ),
    linear-gradient(180deg, transparent 45%, rgba(5, 2, 8, 0.55) 100%);
  pointer-events: none;
}
.brand-photo > * {
  position: relative;
  z-index: 3;
}
.brand-photo.tone-cold::after {
  background:
    radial-gradient(
      ellipse 120% 80% at 50% 110%,
      rgba(20, 30, 80, 0.45) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 100% 60% at 50% -10%,
      rgba(80, 20, 80, 0.2) 0%,
      transparent 60%
    ),
    linear-gradient(180deg, transparent 45%, rgba(5, 2, 8, 0.6) 100%);
}

/* Reusable corner-Vee + insight chip + feeling pill (lifted from brands hero) */
.photo-vee-corner {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 13px 7px 7px;
  background: rgba(5, 2, 8, 0.65);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(124, 58, 237, 0.3);
  border-radius: 100px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
}
.photo-vee-corner .v-name {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--purple-soft);
  text-transform: uppercase;
  line-height: 1;
}
.photo-vee-corner .v-status {
  font-size: 9px;
  font-weight: 700;
  color: var(--w55);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.photo-vee-corner .v-status::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
}
.photo-feeling {
  position: absolute;
  bottom: 18px;
  left: 18px;
  z-index: 4;
  padding: 7px 13px;
  border-radius: 100px;
  background: rgba(5, 2, 8, 0.72);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.2px;
  color: var(--purple-soft);
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.photo-feeling .pulse-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  animation: feelingPulse2 2.4s ease-in-out infinite;
}
@keyframes feelingPulse2 {
  0%,
  100% {
    box-shadow: 0 0 6px var(--green);
  }
  50% {
    box-shadow: 0 0 14px var(--green);
  }
}
.photo-insight {
  position: absolute;
  bottom: 70px;
  right: 16px;
  z-index: 4;
  max-width: 230px;
  padding: 10px 12px;
  background: rgba(18, 13, 32, 0.96);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(124, 58, 237, 0.4);
  border-radius: 12px;
  box-shadow:
    0 12px 32px rgba(0, 0, 0, 0.55),
    0 0 24px rgba(124, 58, 237, 0.22);
  display: flex;
  align-items: flex-start;
  gap: 9px;
  animation: insightFloat2 5s ease-in-out infinite;
}
@keyframes insightFloat2 {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}
.photo-insight .insight-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.photo-insight .insight-from {
  font-size: 8.5px;
  font-weight: 800;
  color: var(--purple-light);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.photo-insight .insight-msg {
  font-size: 11.5px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.2px;
  line-height: 1.4;
}
.photo-insight .insight-msg strong {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 900;
}

/* ═══════════════════════════════════════════════════════════
     ENGINE HERO — left-aligned copy + 2-photo tilted collage
     ═══════════════════════════════════════════════════════════ */
.en-hero {
  padding: 140px 0 80px;
  text-align: left;
  background:
    radial-gradient(
      ellipse at 30% 35%,
      rgba(124, 58, 237, 0.22) 0%,
      transparent 50%
    ),
    radial-gradient(
      ellipse at 70% 70%,
      rgba(236, 72, 153, 0.1) 0%,
      transparent 55%
    ),
    #050208;
}
.en-hero-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 72px;
  align-items: center;
  text-align: left;
}
.en-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}
.en-hero-tag {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 7px 16px 7px 12px;
  border-radius: 20px;
  background: rgba(124, 58, 237, 0.15);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(124, 58, 237, 0.3);
  font-size: 11px;
  font-weight: 800;
  color: var(--purple-soft);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  margin-bottom: 28px;
  overflow: visible;
}
.en-hero-tag .vee-badge {
  width: 50px;
  height: 50px;
  display: inline-block;
  flex-shrink: 0;
  margin: -17px 5px -17px -10px;
  animation: enHeroVeeBadgeIdle 3.8s ease-in-out infinite;
  filter: drop-shadow(0 7px 16px rgba(124, 58, 237, 0.6));
}
.en-hero-tag .vee-badge svg {
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
  transform-origin: center;
}
.en-hero-tag .vee-badge:hover svg {
  transform: scale(1.18);
}
@keyframes enHeroVeeBadgeIdle {
  0%,
  100% {
    transform: rotate(-10deg) translateY(0);
  }
  50% {
    transform: rotate(-5deg) translateY(-4px);
  }
}
.en-hero-tag .vee-badge svg circle[fill="rgba(210,230,255,0.92)"] {
  transform-box: fill-box;
  transform-origin: center;
  animation: veeBlink 4.3s infinite;
  animation-delay: -1.2s;
}
.en-hero h1 {
  font-size: clamp(46px, 6vw, 78px);
  font-weight: 900;
  letter-spacing: -3px;
  line-height: 0.98;
  color: #fff;
  margin-bottom: 22px;
  text-align: left;
}
.en-hero h1 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.en-hero p.lede {
  font-size: 19px;
  color: var(--w80);
  line-height: 1.55;
  max-width: 540px;
  margin: 0 0 14px;
  text-align: left;
}
.en-hero p.sub {
  font-size: 14px;
  color: var(--w55);
  max-width: 480px;
  margin: 0 0 36px;
  text-align: left;
}
.en-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: flex-start;
}

/* Two tilted photos, gen-z magazine-style overlap */
.en-hero-photos {
  position: relative;
  aspect-ratio: 1/1;
  width: 100%;
}
.en-hero-photo-card {
  position: absolute;
  border-radius: 22px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  border: 1px solid var(--w08);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.55);
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.en-hero-photo-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(5, 2, 8, 0.4) 100%);
  pointer-events: none;
}
.en-hero-photo-card.p1 {
  top: 0;
  left: 0;
  width: 62%;
  height: 70%;
  transform: rotate(-3.5deg);
  z-index: 1;
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-5.webp");
}
.en-hero-photo-card.p2 {
  bottom: 0;
  right: 0;
  width: 60%;
  height: 65%;
  transform: rotate(2.5deg);
  z-index: 2;
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-6.webp");
}
.en-hero-photo-card:hover {
  transform: rotate(0deg) scale(1.02);
  z-index: 5;
}
.en-hero-photo-tag {
  position: absolute;
  bottom: 14px;
  left: 14px;
  z-index: 3;
  padding: 6px 13px;
  border-radius: 100px;
  background: rgba(5, 2, 8, 0.75);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.4px;
  color: var(--purple-soft);
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════
     STAGE SECTIONS — 4 pillars (Capture · Create · Connect · Loop)
     ═══════════════════════════════════════════════════════════ */
.stage {
  background: var(--dark);
  border-top: 1px solid var(--w04);
  padding: 90px 0;
}
.stage.alt {
  background: #0a0712;
}
.stage-grid {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 56px;
  align-items: center;
}
.stage-grid.flip .stage-copy {
  order: 2;
}
.stage-grid.flip .stage-visual {
  order: 1;
}

.stage-copy {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}
.stage-num {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.3);
  font-size: 11px;
  font-weight: 800;
  color: var(--purple-light);
  letter-spacing: 1.6px;
  text-transform: uppercase;
}
.stage-copy h2 {
  font-size: clamp(42px, 5vw, 64px);
  font-weight: 900;
  letter-spacing: -2.4px;
  line-height: 0.96;
  color: #fff;
}
.stage-copy h2 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.stage-copy .stage-lede {
  font-size: 16px;
  color: var(--w80);
  line-height: 1.5;
  max-width: 460px;
  margin-top: 0;
}
/* Features — compact rows: arrow · bold title · short description */
.stage-features {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 8px 0 4px;
  padding-left: 4px;
}
.stage-feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  color: var(--w80);
  line-height: 1.45;
}
.stage-feature::before {
  content: "→";
  flex-shrink: 0;
  color: var(--purple-light);
  font-weight: 800;
  font-size: 13px;
  line-height: 1.5;
}
.stage-feature strong {
  color: #fff;
  font-weight: 800;
  margin-right: 2px;
}
.stage-feature em {
  font-style: normal;
  color: var(--w55);
}
/* Output = single italic caption, no heavy row */
.stage-output {
  font-size: 13px;
  color: var(--w55);
  font-style: italic;
  letter-spacing: 0.1px;
  margin-top: 10px;
  padding-top: 14px;
  border-top: 1px dashed var(--w08);
}
.stage-output .arrow {
  color: var(--purple-light);
  font-style: normal;
  margin: 0 4px;
  font-weight: 700;
}

/* Stage visual base (each stage gets a distinct mockup) */
.stage-visual {
  position: relative;
  aspect-ratio: 5/4;
  background: linear-gradient(180deg, var(--dark2) 0%, #0a0612 100%);
  border: 1px solid var(--w08);
  border-radius: 24px;
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.55);
  padding: 28px;
  /* overflow visible so polaroid photo cards can nudge outside */
}

/* Polaroid creator card — one per stage, tilted, tagged */
.stage-human-card {
  position: absolute;
  width: 38%;
  aspect-ratio: 4/5;
  border-radius: 14px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow:
    0 20px 40px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset;
  z-index: 6;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.stage-human-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 50%,
    rgba(5, 2, 8, 0.65) 100%
  );
  pointer-events: none;
}
.stage-human-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: 0.3;
  pointer-events: none;
  z-index: 1;
}
.stage-human-tag {
  position: absolute;
  bottom: 10px;
  left: 10px;
  z-index: 3;
  padding: 5px 10px;
  border-radius: 100px;
  background: rgba(5, 2, 8, 0.72);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.2px;
  color: var(--purple-soft);
  text-transform: uppercase;
}
.stage-human-card:hover {
  transform: rotate(0deg) scale(1.04);
  z-index: 10;
}

/* On mobile: contain the polaroid INSIDE the .stage-visual box so it doesn't
     overhang into the next stage's section label below. Slight tilt preserved. */
@media (max-width: 900px) {
  .sv-capture .stage-human-card {
    bottom: 12px !important;
    right: 12px !important;
    transform: rotate(4deg) !important;
  }
  .sv-create .stage-human-card {
    top: 12px !important;
    right: 12px !important;
    transform: rotate(-3deg) !important;
  }
  .sv-connect .stage-human-card {
    bottom: 12px !important;
    left: 12px !important;
    transform: rotate(-3deg) !important;
  }
}

/* Per-stage polaroid positions (tilt + overlap with the mockup) */
.sv-capture .stage-human-card {
  bottom: -18px;
  right: -24px;
  transform: rotate(6deg);
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-7.webp");
}
.sv-create .stage-human-card {
  top: -20px;
  right: -22px;
  transform: rotate(-5deg);
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-8.webp");
}
.sv-connect .stage-human-card {
  bottom: -24px;
  left: -20px;
  transform: rotate(-4deg);
  background-image: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-9.webp");
}

/* ──────────── SCROLL-TRIGGERED ANIMATIONS ──────────── */
/* Capture: notifications slide in staggered when visible */
.sv-capture .sv-notif {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 0.55s ease,
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  animation: none;
}
.sv-capture.on .sv-notif {
  opacity: 1;
  transform: translateY(0);
}
.sv-capture.on .sv-notif:nth-child(2) {
  transition-delay: 0.15s;
}
.sv-capture.on .sv-notif:nth-child(3) {
  transition-delay: 0.4s;
}
.sv-capture.on .sv-notif:nth-child(4) {
  transition-delay: 0.65s;
}

/* Create: playhead + timeline tracks animate in */
.sv-create .sv-playhead {
  animation-play-state: paused;
  opacity: 0;
}
.sv-create.on .sv-playhead {
  animation-play-state: running;
  opacity: 1;
  transition: opacity 0.4s ease 0.4s;
}
.sv-create .sv-track {
  opacity: 0;
  transform: scaleX(0.85);
  transform-origin: left;
  transition:
    opacity 0.5s ease,
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.sv-create.on .sv-track {
  opacity: 1;
  transform: scaleX(1);
}
.sv-create.on .sv-track:nth-child(2) {
  transition-delay: 0.1s;
}
.sv-create.on .sv-track:nth-child(3) {
  transition-delay: 0.25s;
}
.sv-create.on .sv-track:nth-child(4) {
  transition-delay: 0.4s;
}

/* Connect: platforms light up sequentially, then sparkline */
.sv-connect .sv-plat,
.sv-connect .sv-spark {
  opacity: 0;
  transform: translateX(-10px);
  transition:
    opacity 0.5s ease,
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.sv-connect.on .sv-plat,
.sv-connect.on .sv-spark {
  opacity: 1;
  transform: translateX(0);
}
.sv-connect.on .sv-plat:nth-child(1) {
  transition-delay: 0.15s;
}
.sv-connect.on .sv-plat:nth-child(2) {
  transition-delay: 0.3s;
}
.sv-connect.on .sv-plat:nth-child(3) {
  transition-delay: 0.45s;
}
.sv-connect.on .sv-plat:nth-child(4) {
  transition-delay: 0.6s;
}
.sv-connect.on .sv-spark {
  transition-delay: 0.8s;
}
/* LIVE pill subtle pulse when revealed */
.sv-connect.on .sv-plat-status {
  animation: livePulse 2.4s ease-in-out infinite;
}
@keyframes livePulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(52, 211, 153, 0);
  }
  50% {
    box-shadow: 0 0 0 4px rgba(52, 211, 153, 0.08);
  }
}

/* CAPTURE visual — phone mockup with Vee briefs */
.sv-capture {
  background:
    radial-gradient(
      ellipse 380px 280px at 50% 50%,
      rgba(251, 146, 60, 0.12),
      transparent 65%
    ),
    linear-gradient(180deg, var(--dark2), #0a0612);
}
.sv-phone {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-3deg);
  width: 200px;
  aspect-ratio: 9/19;
  background: linear-gradient(180deg, #1a1326 0%, #0a0612 100%);
  border: 4px solid #050208;
  border-radius: 32px;
  padding: 36px 10px 14px;
  box-shadow:
    0 50px 100px rgba(0, 0, 0, 0.6),
    0 0 50px rgba(124, 58, 237, 0.15);
  display: flex;
  flex-direction: column;
  gap: 5px;
  overflow: hidden;
}
.sv-phone::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 16px;
  background: #050208;
  border-radius: 10px;
}
.sv-phone-time {
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  font-weight: 800;
  color: var(--w80);
  padding: 0 4px 4px;
}
.sv-notif {
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 8px 10px;
  animation: notifSlide2 0.6s ease-out backwards;
}
.sv-notif:nth-child(2) {
  animation-delay: 0.3s;
}
.sv-notif:nth-child(3) {
  animation-delay: 0.6s;
}
.sv-notif:nth-child(4) {
  animation-delay: 0.9s;
}
@keyframes notifSlide2 {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.sv-notif.hot {
  background: linear-gradient(
    135deg,
    rgba(251, 146, 60, 0.25),
    rgba(236, 72, 153, 0.18)
  );
  border-color: rgba(251, 146, 60, 0.45);
}
.sv-notif-head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 3px;
}
.sv-notif-vee {
  width: 16px;
  height: 16px;
  border-radius: 4px;
  background: linear-gradient(135deg, #8b5cf6, #ec4899);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 8px;
  font-weight: 900;
}
.sv-notif-from {
  font-size: 8.5px;
  font-weight: 800;
  color: #fff;
}
.sv-notif-time {
  margin-left: auto;
  font-size: 8px;
  color: var(--w55);
}
.sv-notif-title {
  font-size: 10.5px;
  font-weight: 800;
  color: #fff;
  line-height: 1.25;
  margin-bottom: 1px;
}
.sv-notif-body {
  font-size: 9px;
  color: var(--w80);
  line-height: 1.35;
}

/* CREATE visual — timeline editor */
.sv-create {
  background:
    radial-gradient(
      ellipse 380px 280px at 50% 50%,
      rgba(96, 165, 250, 0.12),
      transparent 65%
    ),
    linear-gradient(180deg, var(--dark2), #0a0612);
}
.sv-editor {
  position: absolute;
  inset: 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}
.sv-editor-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  font-size: 10.5px;
}
.sv-editor-header .file {
  color: #fff;
  font-weight: 800;
  letter-spacing: -0.2px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sv-editor-header .file::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #60a5fa;
  box-shadow: 0 0 8px #60a5fa;
}
.sv-editor-header .time {
  color: var(--w55);
  font-variant-numeric: tabular-nums;
}
.sv-track {
  height: 28px;
  border-radius: 7px;
  padding: 4px;
  display: flex;
  gap: 3px;
}
.sv-track.video {
  background: rgba(96, 165, 250, 0.08);
  border: 1px solid rgba(96, 165, 250, 0.22);
}
.sv-track.audio {
  background: rgba(167, 139, 250, 0.08);
  border: 1px solid rgba(167, 139, 250, 0.22);
}
.sv-track.subs {
  background: rgba(236, 72, 153, 0.08);
  border: 1px solid rgba(236, 72, 153, 0.22);
  padding: 7px 11px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  display: flex;
  align-items: center;
}
.sv-blk {
  flex: 1;
  border-radius: 4px;
  background: linear-gradient(
    180deg,
    rgba(96, 165, 250, 0.55),
    rgba(96, 165, 250, 0.2)
  );
}
.sv-track.audio .sv-blk {
  background: linear-gradient(
    180deg,
    rgba(167, 139, 250, 0.55),
    rgba(167, 139, 250, 0.2)
  );
}
.sv-playhead {
  position: absolute;
  top: 80px;
  bottom: 100px;
  left: 38%;
  width: 2px;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(255, 255, 255, 0.7),
    transparent
  );
  box-shadow: 0 0 8px rgba(124, 58, 237, 0.7);
  animation: playheadMove2 7s linear infinite;
}
@keyframes playheadMove2 {
  0%,
  100% {
    left: 14%;
  }
  50% {
    left: 80%;
  }
}
.sv-editor-note {
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 7px 11px;
  border-radius: 8px;
  background: rgba(5, 2, 8, 0.85);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 10px;
  font-weight: 700;
  color: var(--w80);
  display: flex;
  align-items: center;
  gap: 7px;
  z-index: 3;
}
.sv-editor-note::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
}

/* CONNECT visual — platform stack with sparkline */
.sv-connect {
  background:
    radial-gradient(
      ellipse 380px 280px at 50% 50%,
      rgba(236, 72, 153, 0.12),
      transparent 65%
    ),
    linear-gradient(180deg, var(--dark2), #0a0612);
}
.sv-platforms {
  position: absolute;
  inset: 28px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  justify-content: center;
}
.sv-plat {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  font-size: 12.5px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.1px;
}
.sv-plat-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}
.sv-plat-icon svg {
  width: 16px;
  height: 16px;
  display: block;
}
/* Per-platform brand colors */
.sv-plat.tt .sv-plat-icon {
  background: #000;
  position: relative;
}
/* TikTok's signature cyan/magenta glow */
.sv-plat.tt .sv-plat-icon::before,
.sv-plat.tt .sv-plat-icon::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  mix-blend-mode: screen;
  pointer-events: none;
}
.sv-plat.tt .sv-plat-icon::before {
  background: radial-gradient(circle at 30% 40%, #25f4ee 0%, transparent 45%);
  opacity: 0.55;
}
.sv-plat.tt .sv-plat-icon::after {
  background: radial-gradient(circle at 70% 60%, #fe2c55 0%, transparent 45%);
  opacity: 0.55;
}
.sv-plat.tt .sv-plat-icon svg {
  position: relative;
  z-index: 1;
}
.sv-plat.ig .sv-plat-icon {
  background: linear-gradient(
    135deg,
    #feda77 0%,
    #f58529 25%,
    #dd2a7b 55%,
    #8134af 80%,
    #515bd4 100%
  );
}
.sv-plat.yt .sv-plat-icon {
  background: #ff0000;
}
.sv-plat.li .sv-plat-icon {
  background: #0a66c2;
}
.sv-plat-status {
  margin-left: auto;
  padding: 3px 10px;
  border-radius: 100px;
  background: rgba(52, 211, 153, 0.15);
  border: 1px solid rgba(52, 211, 153, 0.35);
  font-size: 9.5px;
  font-weight: 800;
  color: var(--green);
  letter-spacing: 0.3px;
}
.sv-spark {
  padding: 11px 14px;
  margin-top: 4px;
  border-radius: 12px;
  background: rgba(124, 58, 237, 0.08);
  border: 1px solid rgba(124, 58, 237, 0.22);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--w80);
}
.sv-spark-dots {
  color: var(--purple-light);
  font-family: monospace;
  letter-spacing: 2px;
  font-size: 13px;
}
.sv-spark strong {
  color: #fff;
  font-weight: 900;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  margin-left: auto;
}

/* ═══════════════════════════════════════════════════════════
     STAGE 04 · THE LOOP — full-bleed cycle visualization
     ═══════════════════════════════════════════════════════════ */
.en-loop-new {
  background:
    radial-gradient(
      ellipse at 50% 40%,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse at 50% 80%,
      rgba(236, 72, 153, 0.1) 0%,
      transparent 55%
    ),
    #0a0712;
  border-top: 1px solid var(--w04);
  padding: 110px 0;
  position: relative;
  overflow: hidden;
  /* Skip rendering entirely when off-screen — massive perf win */
  content-visibility: auto;
  contain-intrinsic-size: 1400px;
}
/* Pause feed + Vee animations when section isn't in viewport */
.en-loop-new:not(.on-screen) .feed-chip,
.en-loop-new:not(.on-screen) .loop-vee-center .vee-char,
.en-loop-new:not(.on-screen) .loop-vee-center .vee-char::before {
  animation-play-state: paused;
}
.en-loop-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
.loop-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 64px;
}
.loop-header .stage-num {
  display: inline-flex;
}
.loop-header h2 {
  font-size: clamp(42px, 5vw, 64px);
  font-weight: 900;
  letter-spacing: -2.4px;
  line-height: 0.96;
  color: #fff;
  margin: 22px 0 18px;
}
.loop-header h2 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.loop-header p {
  font-size: 17px;
  color: var(--w80);
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════
     LIVE ENGINE DASHBOARD — Vee at work, real-time readings
     ═══════════════════════════════════════════════════════════ */
.loop-dashboard {
  max-width: 880px;
  margin: 0 auto 72px;
  background: linear-gradient(180deg, var(--dark2) 0%, #0a0612 100%);
  border: 1px solid rgba(124, 58, 237, 0.22);
  border-radius: 22px;
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.55),
    0 0 60px rgba(124, 58, 237, 0.12);
  overflow: hidden;
}

/* Top bar */
.ld-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  background: linear-gradient(
    135deg,
    rgba(139, 92, 246, 0.12),
    rgba(236, 72, 153, 0.06)
  );
  border-bottom: 1px solid var(--w08);
}
.ld-bar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 10px var(--green);
  animation: ldLivePulse 2s ease-in-out infinite;
}
@keyframes ldLivePulse {
  0%,
  100% {
    box-shadow: 0 0 8px var(--green);
  }
  50% {
    box-shadow:
      0 0 16px var(--green),
      0 0 24px rgba(52, 211, 153, 0.5);
  }
}
.ld-bar-title {
  font-size: 12px;
  font-weight: 900;
  color: #fff;
  letter-spacing: 0.2px;
}
.ld-bar-meta {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--w55);
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
}
.ld-bar-meta .spin {
  display: inline-block;
  animation: ldSpin 4s linear infinite;
}
@keyframes ldSpin {
  to {
    transform: rotate(360deg);
  }
}

/* Processing row */
.ld-processing {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 20px 22px;
  border-bottom: 1px solid var(--w08);
  background: rgba(124, 58, 237, 0.04);
}
.ld-processing-vee {
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  border-radius: 14px;
  background: linear-gradient(135deg, #8b5cf6, #6d28d9);
  box-shadow:
    0 8px 22px rgba(124, 58, 237, 0.4),
    0 0 0 0 rgba(124, 58, 237, 0.4);
  animation: ldProcessingPulse 3s ease-in-out infinite;
}
@keyframes ldProcessingPulse {
  0%,
  100% {
    box-shadow:
      0 8px 22px rgba(124, 58, 237, 0.4),
      0 0 0 0 rgba(124, 58, 237, 0);
  }
  50% {
    box-shadow:
      0 8px 22px rgba(124, 58, 237, 0.55),
      0 0 0 10px rgba(124, 58, 237, 0.06);
  }
}
.ld-processing-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.6px;
  color: var(--purple-light);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.ld-processing-text {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.2px;
}
.ld-processing-text .dots::after {
  content: "…";
  display: inline-block;
  animation: ldDots 1.4s steps(4, end) infinite;
  width: 16px;
  overflow: hidden;
  vertical-align: bottom;
}
@keyframes ldDots {
  0% {
    width: 0;
  }
  100% {
    width: 16px;
  }
}

/* Stage columns */
.ld-stages {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid var(--w08);
}
.ld-stage {
  padding: 18px 20px;
  border-right: 1px solid var(--w08);
  position: relative;
}
.ld-stage:last-child {
  border-right: none;
}
.ld-stage-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.ld-stage-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  box-shadow: 0 0 8px currentColor;
}
.ld-stage.capture .ld-stage-dot {
  background: #fb923c;
  color: #fb923c;
}
.ld-stage.create .ld-stage-dot {
  background: #60a5fa;
  color: #60a5fa;
}
.ld-stage.connect .ld-stage-dot {
  background: #ec4899;
  color: #ec4899;
}
.ld-stage-name {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 1.4px;
  color: #fff;
  text-transform: uppercase;
}
.ld-spark {
  display: flex;
  align-items: end;
  gap: 3px;
  height: 24px;
  margin-bottom: 10px;
}
.ld-spark-bar {
  flex: 1;
  border-radius: 2px;
  animation: ldSparkPulse 3s ease-in-out infinite;
}
.ld-stage.capture .ld-spark-bar {
  background: linear-gradient(180deg, #fb923c, rgba(251, 146, 60, 0.25));
}
.ld-stage.create .ld-spark-bar {
  background: linear-gradient(180deg, #60a5fa, rgba(96, 165, 250, 0.25));
}
.ld-stage.connect .ld-spark-bar {
  background: linear-gradient(180deg, #ec4899, rgba(236, 72, 153, 0.25));
}
.ld-spark-bar:nth-child(1) {
  animation-delay: 0s;
}
.ld-spark-bar:nth-child(2) {
  animation-delay: 0.2s;
}
.ld-spark-bar:nth-child(3) {
  animation-delay: 0.4s;
}
.ld-spark-bar:nth-child(4) {
  animation-delay: 0.6s;
}
.ld-spark-bar:nth-child(5) {
  animation-delay: 0.8s;
}
@keyframes ldSparkPulse {
  0%,
  100% {
    opacity: 0.75;
    transform: scaleY(1);
  }
  50% {
    opacity: 1;
    transform: scaleY(1.12);
  }
}
.ld-stage-stat {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.5px;
  line-height: 1;
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums;
}
.ld-stage-meta {
  font-size: 11px;
  color: var(--w55);
  line-height: 1.45;
}
.ld-stage-meta strong {
  color: var(--w80);
  font-weight: 700;
}

/* Observations feed */
.ld-obs-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px 8px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--w55);
  text-transform: uppercase;
}
.ld-obs-head .small {
  color: var(--w35);
  letter-spacing: 0.2px;
  text-transform: none;
  font-weight: 600;
  font-size: 10px;
}
.ld-obs {
  padding: 4px 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ld-obs-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 4px;
  border-bottom: 1px solid var(--w04);
  font-size: 12.5px;
  color: var(--w80);
  line-height: 1.4;
}
.ld-obs-row:last-child {
  border-bottom: none;
}
.ld-obs-arrow {
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
  width: 18px;
  text-align: center;
}
.ld-obs-row.ok .ld-obs-arrow {
  color: var(--green);
}
.ld-obs-row.info .ld-obs-arrow {
  color: var(--purple-light);
}
.ld-obs-row.warn .ld-obs-arrow {
  color: #fbbf24;
}
.ld-obs-row .hl {
  color: #fff;
  font-weight: 800;
}

/* ═══════════════════════════════════════════════════════════
     VEE'S MEMORY — concrete "notes on Sara" mockup + polaroid
     ═══════════════════════════════════════════════════════════ */
.loop-memory-head {
  text-align: center;
  margin-bottom: 36px;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}
.loop-memory-head h3 {
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 900;
  letter-spacing: -1.2px;
  color: #fff;
  margin-bottom: 10px;
}
.loop-memory-head h3 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.loop-memory-head p {
  font-size: 14.5px;
  color: var(--w55);
  line-height: 1.6;
}

.loop-memory-wrap {
  max-width: 1040px;
  margin: 0 auto 60px;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 48px;
  align-items: center;
}

/* Left: polaroid of Sara (the subject of the notes) */
.loop-memory-polaroid {
  position: relative;
  aspect-ratio: 4/5;
  max-width: 340px;
  margin: 0 auto;
  border-radius: 18px;
  overflow: hidden;
  background: url("https://vedio-public-production.b-cdn.net/website/images/photos/photo-4.webp")
    center/cover no-repeat;
  border: 1px solid var(--w08);
  box-shadow: 0 32px 70px rgba(0, 0, 0, 0.6);
  transform: rotate(-3deg);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.loop-memory-polaroid:hover {
  transform: rotate(0deg) scale(1.02);
}
.loop-memory-polaroid::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: 0.3;
  pointer-events: none;
}
.loop-memory-polaroid::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(
    180deg,
    transparent 55%,
    rgba(5, 2, 8, 0.55) 100%
  );
  pointer-events: none;
}
/* Wrap holds polaroid + Vee face so the glow can extend past the polaroid's clipped edge */
.loop-memory-polaroid-wrap {
  position: relative;
  max-width: 340px;
  margin: 0 auto;
}
.loop-memory-polaroid-vee {
  position: absolute;
  top: -26px;
  right: -26px;
  z-index: 5;
  width: 92px;
  height: 92px;
  display: block;
  filter: drop-shadow(0 12px 28px rgba(124, 58, 237, 0.6));
  pointer-events: none;
  /* Stronger float + wobble — clearly alive */
  animation: polaroidVeeFloat 4.2s ease-in-out infinite;
  transform-origin: center center;
}
.loop-memory-polaroid-vee svg {
  width: 100%;
  height: 100%;
  display: block;
}
@keyframes polaroidVeeFloat {
  0% {
    transform: translateY(0) rotate(4deg);
  }
  20% {
    transform: translateY(-10px) rotate(14deg);
  }
  40% {
    transform: translateY(-6px) rotate(10deg);
  }
  60% {
    transform: translateY(-12px) rotate(6deg);
  }
  80% {
    transform: translateY(-4px) rotate(12deg);
  }
  100% {
    transform: translateY(0) rotate(4deg);
  }
}
/* Smile breathing — widen/relax (clearly visible) */
.polaroid-vee-smile {
  transform-origin: 28px 38px;
  animation: polaroidVeeSmile 3.4s ease-in-out infinite;
}
@keyframes polaroidVeeSmile {
  0%,
  100% {
    transform: scaleY(1) scaleX(1);
  }
  40% {
    transform: scaleY(1.35) scaleX(1.08);
  }
  60% {
    transform: scaleY(0.85) scaleX(0.96);
  }
}

.loop-memory-polaroid-tag {
  position: absolute;
  bottom: 14px;
  left: 14px;
  z-index: 3;
  padding: 7px 12px;
  border-radius: 100px;
  background: rgba(5, 2, 8, 0.75);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.2px;
  color: var(--purple-soft);
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.loop-memory-polaroid-tag::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
}
.loop-memory-caption {
  margin-top: 20px;
  text-align: center;
  font-size: 13px;
  color: var(--w55);
  line-height: 1.5;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}
.loop-memory-caption strong {
  color: #fff;
  font-weight: 800;
}

/* Right: Vee's notes mockup — notebook feel */
/* ──── Scattered sticky-note cards (gen-z) ──── */
.mem-scatter-wrap {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.mem-scatter-header {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 13px 7px 7px;
  background: rgba(18, 13, 32, 0.85);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(124, 58, 237, 0.28);
  border-radius: 100px;
  align-self: flex-start;
  font-size: 11px;
  font-weight: 700;
  color: var(--w80);
  letter-spacing: 0.1px;
}
.mem-scatter-header strong {
  color: #fff;
  font-weight: 800;
}
.mem-scatter-header .vee-char {
  margin: -2px 0;
}

.mem-scatter {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 6px 10px 10px;
  position: relative;
}
.mem-note {
  background: linear-gradient(180deg, var(--dark2) 0%, #0e0a18 100%);
  border: 1px solid var(--w08);
  border-radius: 14px;
  padding: 13px 15px 14px;
  box-shadow:
    0 18px 36px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset;
  rotate: var(--rot, 0deg);
  transition:
    rotate 0.3s cubic-bezier(0.22, 1, 0.36, 1),
    translate 0.3s cubic-bezier(0.22, 1, 0.36, 1),
    scale 0.3s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.3s;
  max-width: 340px;
  position: relative;
}
.mem-note:hover {
  rotate: 0deg;
  translate: 0 -3px;
  scale: 1.03;
  box-shadow:
    0 22px 46px rgba(0, 0, 0, 0.6),
    0 0 24px rgba(124, 58, 237, 0.25);
  z-index: 10;
}
.mem-note-head {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 6px;
}
.mem-note-icon {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: rgba(124, 58, 237, 0.12);
  border: 1px solid rgba(124, 58, 237, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.mem-note-category {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.4px;
  color: var(--purple-light);
  text-transform: uppercase;
}
.mem-note-title {
  font-size: 13.5px;
  font-weight: 800;
  color: #fff;
  line-height: 1.35;
  letter-spacing: -0.2px;
  margin-bottom: 3px;
}
.mem-note-title .hl {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.mem-note-ctx {
  font-size: 11.5px;
  color: var(--w55);
  line-height: 1.45;
}
.mem-note-time {
  position: absolute;
  top: 12px;
  right: 13px;
  font-size: 9px;
  font-weight: 800;
  color: var(--w35);
  letter-spacing: 0.4px;
  text-transform: uppercase;
}
/* Per-category tint */
.mem-note.voice .mem-note-icon {
  background: rgba(124, 58, 237, 0.14);
  border-color: rgba(124, 58, 237, 0.35);
}
.mem-note.audience .mem-note-icon {
  background: rgba(96, 165, 250, 0.14);
  border-color: rgba(96, 165, 250, 0.35);
}
.mem-note.brand .mem-note-icon {
  background: rgba(236, 72, 153, 0.14);
  border-color: rgba(236, 72, 153, 0.35);
}
.mem-note.winner .mem-note-icon {
  background: rgba(52, 211, 153, 0.14);
  border-color: rgba(52, 211, 153, 0.35);
}
.mem-note.taste .mem-note-icon {
  background: rgba(251, 146, 60, 0.14);
  border-color: rgba(251, 146, 60, 0.35);
}
.mem-note.voice .mem-note-category {
  color: var(--purple-light);
}
.mem-note.audience .mem-note-category {
  color: #93c5fd;
}
.mem-note.brand .mem-note-category {
  color: #f472b6;
}
.mem-note.winner .mem-note-category {
  color: #34d399;
}
.mem-note.taste .mem-note-category {
  color: #fb923c;
}

/* Assorted offsets per note — scattered, not stacked */
.mem-scatter .mem-note:nth-child(1) {
  --rot: -6deg;
  margin-left: 18px;
}
.mem-scatter .mem-note:nth-child(2) {
  --rot: 4.5deg;
  margin-left: -10px;
  margin-top: -10px;
  scale: 0.96;
}
.mem-scatter .mem-note:nth-child(3) {
  --rot: -3.5deg;
  margin-left: 32px;
  margin-top: -6px;
}
.mem-scatter .mem-note:nth-child(4) {
  --rot: 7deg;
  margin-left: -14px;
  margin-top: -14px;
  scale: 1.02;
}
.mem-scatter .mem-note:nth-child(5) {
  --rot: -2.5deg;
  margin-left: 22px;
  margin-top: -8px;
  scale: 0.97;
}
.mem-scatter .mem-note:nth-child(6) {
  --rot: 5.5deg;
  margin-left: -6px;
  margin-top: -10px;
}

.mem-scatter-foot {
  margin-top: 6px;
  margin-left: 12px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--w55);
  letter-spacing: 0.2px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.mem-scatter-foot::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  animation: loopMemoryPulse 2.4s ease-in-out infinite;
}

.loop-memory-phone {
  position: relative;
  background: linear-gradient(180deg, var(--dark2) 0%, #0a0612 100%);
  border: 1px solid var(--w08);
  border-radius: 22px;
  padding: 0;
  box-shadow:
    0 32px 80px rgba(0, 0, 0, 0.55),
    0 0 40px rgba(124, 58, 237, 0.15);
  overflow: hidden;
}
.loop-memory-head-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: linear-gradient(
    135deg,
    rgba(139, 92, 246, 0.14),
    rgba(236, 72, 153, 0.08)
  );
  border-bottom: 1px solid var(--w08);
}
.loop-memory-head-vee {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}
.loop-memory-head-text {
  flex: 1;
  min-width: 0;
}
.loop-memory-head-title {
  font-size: 13px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.2px;
  line-height: 1.2;
}
.loop-memory-head-sub {
  font-size: 10.5px;
  color: var(--w55);
  letter-spacing: 0.1px;
  margin-top: 2px;
}
.loop-memory-head-meta {
  font-size: 10px;
  font-weight: 800;
  color: var(--purple-light);
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.12);
  border: 1px solid rgba(124, 58, 237, 0.3);
}
.loop-memory-entries {
  padding: 10px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.loop-memory-entry {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 12px;
  align-items: start;
  padding: 12px 6px;
  border-bottom: 1px solid var(--w04);
  transition: background 0.2s;
}
.loop-memory-entry:last-child {
  border-bottom: none;
}
.loop-memory-entry:hover {
  background: rgba(255, 255, 255, 0.015);
}
.loop-memory-icon {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
}
.loop-memory-entry.audience .loop-memory-icon {
  background: rgba(96, 165, 250, 0.12);
  border-color: rgba(96, 165, 250, 0.28);
}
.loop-memory-entry.brand .loop-memory-icon {
  background: rgba(236, 72, 153, 0.12);
  border-color: rgba(236, 72, 153, 0.28);
}
.loop-memory-entry.winner .loop-memory-icon {
  background: rgba(52, 211, 153, 0.12);
  border-color: rgba(52, 211, 153, 0.28);
}
.loop-memory-entry.taste .loop-memory-icon {
  background: rgba(251, 146, 60, 0.12);
  border-color: rgba(251, 146, 60, 0.28);
}
.loop-memory-entry-text {
  min-width: 0;
}
.loop-memory-entry-line {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  line-height: 1.35;
  letter-spacing: -0.1px;
}
.loop-memory-entry-line .hl {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.loop-memory-entry-ctx {
  font-size: 11px;
  color: var(--w55);
  margin-top: 3px;
  letter-spacing: 0.1px;
}
.loop-memory-entry-time {
  font-size: 10px;
  font-weight: 700;
  color: var(--w35);
  letter-spacing: 0.2px;
  white-space: nowrap;
  padding-top: 4px;
}
.loop-memory-footer {
  padding: 12px 20px;
  background: rgba(255, 255, 255, 0.02);
  border-top: 1px solid var(--w08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 10.5px;
  color: var(--w55);
}
.loop-memory-footer-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  animation: loopMemoryPulse 2.4s ease-in-out infinite;
  display: inline-block;
  margin-right: 6px;
}
@keyframes loopMemoryPulse {
  0%,
  100% {
    box-shadow: 0 0 6px var(--green);
  }
  50% {
    box-shadow: 0 0 14px var(--green);
  }
}

/* ─── Timeline Vee expressions (replace static dots) ─── */
.loop-stop-vee {
  width: 36px;
  height: 36px;
  margin: 0 auto 12px;
  border-radius: 26%;
  background: linear-gradient(135deg, #8b5cf6, #6d28d9);
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.4);
  transition: transform 0.3s;
}
.loop-stop:hover .loop-stop-vee {
  transform: scale(1.1);
}
.loop-stop.now .loop-stop-vee {
  box-shadow:
    0 0 20px rgba(124, 58, 237, 0.8),
    0 4px 14px rgba(124, 58, 237, 0.5);
  animation: loopStopNowPulse 3s ease-in-out infinite;
}
@keyframes loopStopNowPulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.08);
  }
}

@media (max-width: 900px) {
  .loop-memory-wrap {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .loop-memory-polaroid {
    max-width: 260px;
  }
}

/* ═══════════════════════════════════════════════════════════
     RESPONSIVE
     ═══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .en-hero-grid,
  .stage-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .stage-grid.flip .stage-copy,
  .stage-grid.flip .stage-visual {
    order: initial;
  }
  .loop-learns-grid {
    grid-template-columns: 1fr;
  }
  .loop-compound-stops {
    grid-template-columns: repeat(2, 1fr);
  }
  .loop-cycle {
    aspect-ratio: 1/1;
  }
  .loop-node {
    font-size: 11px;
    min-width: 130px;
  }
  .ld-stages {
    grid-template-columns: 1fr;
  }
  .ld-stage {
    border-right: none;
    border-bottom: 1px solid var(--w08);
  }
  .ld-stage:last-child {
    border-bottom: none;
  }
}

/* ═══════════════════════════════════════════════════════════
     AUDIT ADD-ONS (2026-04-21)
     ═══════════════════════════════════════════════════════════ */

/* Trust strip — customer logos under hero */
.en-trust {
  background: #0a0712;
  border-top: 1px solid var(--w04);
  border-bottom: 1px solid var(--w04);
  padding: 26px 0;
}
.en-trust-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  gap: 26px;
  flex-wrap: wrap;
  justify-content: center;
}
.en-trust-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--w35);
  flex-shrink: 0;
}
.en-trust-logos {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  justify-content: center;
}
.en-trust-logo {
  font-family: "Outfit", sans-serif;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: -0.4px;
  color: var(--w55);
  transition: color 0.2s;
  font-variant: all-small-caps;
}
.en-trust-logo:hover {
  color: #fff;
}
.en-trust-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--w15);
  flex-shrink: 0;
}
@media (max-width: 900px) {
  .en-trust-inner {
    gap: 14px;
  }
  .en-trust-logos {
    gap: 12px;
  }
  .en-trust-logo {
    font-size: 13px;
  }
}

/* Stage output — restyle as OUTPUT pill */
.stage-output {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--purple-light);
  font-style: normal;
  margin-top: 18px;
  padding: 8px 14px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.28);
  border-top: 1px solid rgba(124, 58, 237, 0.28); /* override dashed */
}
.stage-output::before {
  content: "OUTPUT";
  font-weight: 900;
  color: #fff;
  padding: 2px 7px;
  border-radius: 100px;
  background: rgba(124, 58, 237, 0.45);
  font-size: 9px;
  letter-spacing: 1.6px;
}
.stage-output .arrow {
  color: var(--purple-light);
  margin: 0 2px;
  font-weight: 800;
}

/* Interlude bridge line */
.en-interlude-bridge {
  margin-top: 22px !important;
  font-size: 14px !important;
  font-style: italic;
  color: var(--w55) !important;
  max-width: none !important;
}
.en-interlude-bridge .accent {
  display: inline-block;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-style: normal;
  margin-left: 4px;
  animation: bridgeArrow 1.8s ease-in-out infinite;
}
@keyframes bridgeArrow {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(3px);
  }
}
/* Four stats now — tighten gap */
.en-interlude-stat {
  gap: 20px !important;
  flex-wrap: wrap;
}

/* Inline stat in loop-header paragraph — bold gradient, slightly larger */
.loop-header-stat {
  font-size: 1.18em;
  font-weight: 900;
  letter-spacing: -0.3px;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  white-space: nowrap;
}

/* "+82 more observations" sticky note */
.mem-note.more {
  background: linear-gradient(
    135deg,
    rgba(124, 58, 237, 0.14),
    rgba(236, 72, 153, 0.08)
  );
  border: 1px dashed rgba(124, 58, 237, 0.4);
  padding: 18px 18px 20px;
  max-width: 220px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.mem-note-more-n {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: -1.2px;
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.mem-note-more-l {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--w80);
  line-height: 1.35;
}

/* Tier bridge cards */
.en-tier-bridge {
  background: #0a0712;
  border-top: 1px solid var(--w04);
  padding: 90px 0;
}
.en-tier-bridge .wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
.tier-bridge-head {
  text-align: center;
  margin-bottom: 48px;
}
.tier-bridge-head h2 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 900;
  letter-spacing: -1.8px;
  line-height: 1;
  color: #fff;
  margin-top: 16px;
}
.tier-bridge-head h2 .accent {
  background: linear-gradient(135deg, #a78bfa, #ec4899);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.tier-bridge-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.tier-card {
  display: flex;
  flex-direction: column;
  padding: 32px 28px 28px;
  background: linear-gradient(180deg, var(--dark2) 0%, #0e0a18 100%);
  border: 1px solid var(--w08);
  border-radius: 22px;
  text-decoration: none;
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.35s,
    box-shadow 0.45s;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
/* Top ribbon — tier-colored gradient strip along the top edge */
.tier-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--tier-color) 20%,
    var(--tier-color2) 80%,
    transparent
  );
  opacity: 0.6;
  transition:
    opacity 0.35s,
    height 0.35s;
}
/* Soft tier-tinted glow on hover */
.tier-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse at 50% -10%,
    var(--tier-glow) 0%,
    transparent 55%
  );
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
  z-index: -1;
}
.tier-card:hover {
  transform: translateY(-6px);
  border-color: var(--tier-color);
  box-shadow:
    0 30px 70px rgba(0, 0, 0, 0.55),
    0 0 50px var(--tier-glow);
}
.tier-card:hover::before {
  opacity: 1;
}
.tier-card:hover::after {
  opacity: 1;
  height: 4px;
}

/* Per-tier colors — pure brand purple depth ramp (light → main → deep) */
.tier-card.tier-core {
  --tier-color: #c4b5fd;
  --tier-color2: #a78bfa;
  --tier-glow: rgba(167, 139, 250, 0.22);
}
.tier-card.tier-pro {
  --tier-color: #a78bfa;
  --tier-color2: #7c3aed;
  --tier-glow: rgba(124, 58, 237, 0.32);
}
.tier-card.tier-max {
  --tier-color: #7c3aed;
  --tier-color2: #5b21b6;
  --tier-glow: rgba(91, 33, 182, 0.32);
}

/* Big glyph — tier name wordmark, top-left, floating */
.tier-card-glyph {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--tier-color), var(--tier-color2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.8px;
  color: #fff;
  line-height: 1;
  box-shadow:
    0 10px 26px var(--tier-glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
  margin-bottom: 22px;
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    rotate 0.45s;
  rotate: -4deg;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}
.tier-card:hover .tier-card-glyph {
  transform: translateY(-3px) scale(1.06);
  rotate: 3deg;
}

.tier-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 16px;
}
.tier-card-label {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--w55);
}
/* Bigger, solid pills — reads as a real tier badge */
.tier-card-pill {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  padding: 7px 14px;
  border-radius: 100px;
  background: linear-gradient(135deg, var(--tier-color), var(--tier-color2));
  color: #fff;
  box-shadow:
    0 6px 18px var(--tier-glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.tier-card-title {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.7px;
  color: #fff;
  line-height: 1.12;
  margin-bottom: 10px;
}
.tier-card-title .accent {
  background: linear-gradient(135deg, var(--tier-color), var(--tier-color2));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.tier-card-sub {
  font-size: 13.5px;
  color: var(--w55);
  line-height: 1.5;
  margin-bottom: 26px;
  flex-grow: 1;
}
/* CTA — button-like pill at bottom */
.tier-card-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  padding: 11px 18px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--w08);
  align-self: flex-start;
  transition:
    gap 0.25s,
    background 0.25s,
    border-color 0.25s,
    padding 0.25s;
}
.tier-card:hover .tier-card-link {
  gap: 12px;
  background: linear-gradient(135deg, var(--tier-color), var(--tier-color2));
  border-color: transparent;
}
.tier-card-link .arrow {
  font-weight: 800;
  transition: transform 0.25s;
}
.tier-card:hover .tier-card-link .arrow {
  transform: translateX(2px);
}
@media (max-width: 900px) {
  .tier-bridge-grid {
    grid-template-columns: 1fr;
  }
}

/* FAQ compare link — below the list */
.faq-compare-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  max-width: 820px;
  margin: 40px auto 0;
  padding: 22px 26px;
  background: rgba(124, 58, 237, 0.06);
  border: 1px solid rgba(124, 58, 237, 0.22);
  border-radius: 16px;
  text-decoration: none;
  transition:
    background 0.2s,
    border-color 0.2s,
    transform 0.25s;
}
.faq-compare-link:hover {
  background: rgba(124, 58, 237, 0.12);
  border-color: rgba(124, 58, 237, 0.4);
  transform: translateY(-2px);
}
.faq-compare-label {
  font-size: 14px;
  color: var(--w80);
  font-weight: 600;
}
.faq-compare-cta {
  font-size: 13px;
  font-weight: 800;
  color: var(--purple-light);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

/* Final CTA — Vee badge replaces static icon */
.en-final-vee {
  display: block;
  width: 88px;
  height: 88px;
  margin: 0 auto 24px;
  filter: drop-shadow(0 8px 32px rgba(124, 58, 237, 0.55));
  animation: finalVeeFloat 3.2s ease-in-out infinite;
}
@keyframes finalVeeFloat {
  0%,
  100% {
    transform: translateY(0) rotate(-3deg);
  }
  50% {
    transform: translateY(-8px) rotate(2deg);
  }
}

/* Hide name/role pills on photos — they overflow when art changes */
.en-hero-photo-tag,
.stage-human-tag,
.loop-memory-polaroid-tag {
  display: none !important;
}

/* Remove the faint 1px outline on photo cards — looks odd with shuffled art */
.stage-human-card,
.loop-photo-node,
.loop-memory-polaroid {
  border: none !important;
}
.stage-human-card {
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.55) !important;
}

/* Unified "jump" hover on every image card */
.bento-hero,
.bento-photo,
.case-story-video,
.stage-human-card,
.loop-photo-node,
.loop-memory-polaroid {
  transition:
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.32s ease !important;
}
.bento-hero:hover,
.bento-photo:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55) !important;
}
.stage-human-card:hover {
  transform: rotate(0deg) translateY(-8px) scale(1.04) !important;
  z-index: 10 !important;
}
.loop-memory-polaroid:hover {
  transform: rotate(0deg) translateY(-8px) scale(1.02) !important;
}
.loop-photo-node.capture:hover,
.loop-photo-node.create:hover,
.loop-photo-node.connect:hover {
  transform: translate(-50%, calc(-50% - 8px)) rotate(0deg) scale(1.06) !important;
}

/* Drop the faint outline on the engine-hero photo cards (the two tilted polaroids) */
.en-hero-photo-card {
  border: none !important;
}

/* Strip outline + hide pills on the remaining engine photo cards */
.en-interlude-photo,
.brand-photo {
  border: none !important;
}
.en-interlude-tag {
  display: none !important;
}
