/* Auto-generated — homepage deferred (below-the-fold, load async). Run: node server/homepage-css-bundle.js */
@font-face {
  font-family: 'Geist Mono';
  src: url('/fonts/GeistMono-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: inherit;
}

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

button {
  font-family: inherit;
  cursor: pointer;
}

@property --announcement-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

@keyframes announcement-border-spin {
  to { --announcement-angle: 360deg; }
}

.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

.announcement-bar {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 6px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  text-decoration: none;
  position: relative;
  --announcement-angle: 0deg;
  animation: announcement-border-spin 6s linear infinite;
  transition: background var(--duration-160) var(--ease-out),
              transform var(--duration-160) var(--ease-out);
}

.announcement-bar::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--announcement-angle),
    rgba(148, 122, 252, 0.6) 0%,
    rgba(148, 122, 252, 0.15) 25%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(148, 122, 252, 0.15) 75%,
    rgba(148, 122, 252, 0.6) 100%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

.announcement-bar:hover {
  background: rgba(255, 255, 255, 0.06);
  transform: translateX(4px);
}

.announcement-bar__label {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: var(--color-neutral-600);
  border-radius: var(--radius-full);
  font-family: var(--font-sans);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-0);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
  position: relative;
  z-index: 1;
}

.announcement-bar__text {
  font-family: var(--font-sans);
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-regular);
  color: var(--color-neutral-300);
  line-height: 1;
  padding-right: 14px;
  position: relative;
  z-index: 1;
}

.announcement-bar:hover .announcement-bar__text {
  color: var(--color-neutral-200);
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-full);
  background: transparent;
}

.badge--md {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-14);
}

.badge-pill {
  width: var(--space-3);
  height: var(--space-1);
  border-radius: var(--radius-full);
  background: var(--label-purple);
}

.badge--brand {
  border-color: color-mix(in srgb, var(--color-purple-400) 20%, transparent);
  background: color-mix(in srgb, var(--color-purple-400) 8%, transparent);
  color: var(--color-purple-400);
}

.badge--success {
  border-color: color-mix(in srgb, var(--color-green-600) 20%, transparent);
  background: color-mix(in srgb, var(--color-green-600) 8%, transparent);
  color: var(--color-green-500);
}

.badge--warning {
  border-color: color-mix(in srgb, var(--color-yellow-500) 20%, transparent);
  background: color-mix(in srgb, var(--color-yellow-500) 8%, transparent);
  color: var(--color-yellow-400);
}

.badge--error {
  border-color: color-mix(in srgb, var(--color-red-600) 20%, transparent);
  background: color-mix(in srgb, var(--color-red-600) 8%, transparent);
  color: var(--color-red-500);
}

.section-title {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-4);
}

.section-subtitle {
  font-size: var(--font-size-18);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-10);
}

.section-intro {
  text-align: center;
  padding-bottom: var(--space-2);
}

.section-intro > .section-title:last-child {
  margin-bottom: var(--space-10);
}

.tag-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.tag-indicator {
  width: var(--space-3);
  height: var(--space-1);
  background: var(--label-purple);
  border-radius: var(--radius-full);
}

.tag-indicator--md {
  width: var(--space-4);
  height: var(--space-2);
}

.tag-indicator--blue    { background: var(--label-blue);    }

.tag-indicator--green   { background: var(--label-green);   }

.tag-indicator--red     { background: var(--label-red);     }

.tag-indicator--yellow  { background: var(--label-yellow);  }

.tag-indicator--orange  { background: var(--label-orange);  }

.tag-indicator--pink    { background: var(--label-pink);    }

.tag-indicator--neutral { background: var(--label-neutral); }

.tag-text {
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-regular);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-widest);
  color: var(--color-purple-400);
}

.tag-text--blue { color: var(--label-blue); }

.tag-label--divider {
  display: flex;
  width: 100%;
}

.tag-label--divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-card);
  align-self: center;
}

.bento-a {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  min-height: calc(100vh - var(--space-40));
}

.b__card {
  background: var(--bg-primary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  overflow: hidden;
  max-height: 800px;
  padding: 0;
}

.b__card.b--bg-image {
  background: transparent center / cover no-repeat;
  border: 1px solid var(--border-card);
  position: relative;
  isolation: isolate;
}

.b__card.b--bg-image::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--gradient-bento-scrim);
  z-index: 0;
}

.b__card.b--bg-image > * {
  position: relative;
  z-index: 1;
}

.b__card.b--full-height {
  min-height: 600px;
}

.b__card.b__banner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--space-12);
  margin-bottom: var(--space-4);
}

.b__card.b__text-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: var(--space-12);
}

.b__cell-icon.b--fill svg {
  fill: currentColor;
  stroke: none;
}

.b__card.b--cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-12);
  min-height: 600px;
  max-height: 600px;
  gap: var(--space-6);
}

.b__hero-overlay {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.b__hero-overlay .b__hero-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: var(--space-10) var(--space-8);
  z-index: 2;
}

.b__hero-overlay .b__hero-visual {
  position: absolute;
  inset: 0;
  min-height: 0;
}

.b__hero-overlay .b__hero-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.72) 0%,
    rgba(0, 0, 0, 0.35) 40%,
    rgba(0, 0, 0, 0.10) 70%,
    rgba(0, 0, 0, 0.45) 100%
  );
}

.b__hero-overlay .b__hero-subtitle {
  color: rgba(255, 255, 255, 0.7);
}

.b__hero-title {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.b__hero-subtitle {
  font-size: var(--font-size-16);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
}

.b__hero-visual {
  flex: 1;
  position: relative;
  overflow: hidden;
  min-height: 300px;
  background: var(--bg-secondary);
}

.b__cta {
  position: absolute;
  bottom: var(--space-8);
  left: var(--space-8);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  height: 40px;
  padding: 0 var(--space-6);
  background: var(--bg-inverse);
  color: var(--text-inverse);
  border: none;
  border-radius: var(--radius-5);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-regular);
  font-family: var(--font-sans);
  cursor: pointer;
  transition: transform var(--duration-160) var(--ease-out),
              box-shadow var(--duration-160) var(--ease-out);
  text-decoration: none;
}

.b__cta:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.4);
}

.b__features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}

.b__cell {
  display: flex;
  flex-direction: column;
}

.b__cell-inner {
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.b__cell:nth-child(odd)  { border-right: 1px solid var(--border-card); }

.b__cell:nth-child(-n+2) { border-bottom: 1px solid var(--border-card); }

.b__cell-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-2);
  background: transparent;
  border: 1px solid var(--border-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-6);
  flex-shrink: 0;
  transition: border-color var(--duration-240) var(--ease-out),
              background var(--duration-240) var(--ease-out),
              box-shadow var(--duration-240) var(--ease-out),
              transform var(--duration-160) var(--ease-out);
}

.b__cell-icon svg {
  width: 20px;
  height: 20px;
  color: var(--text-primary);
  stroke: currentColor;
  fill: none;
  transition: color var(--duration-240) var(--ease-out),
              transform var(--duration-240) var(--ease-out);
}

.b__cell:hover .b__cell-icon,
.b__card--interactive:hover .b__cell-icon {
  border-color: var(--color-purple-400);
  background: color-mix(in srgb, var(--color-purple-400) 6%, transparent);
  transform: scale(1.08);
}

.b__cell:hover .b__cell-icon svg,
.b__card--interactive:hover .b__cell-icon svg {
  color: var(--color-purple-400);
  transform: rotate(-6deg) scale(1.05);
}

.b__cell-title {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.b__cell-desc {
  font-size: var(--font-size-16);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
}

.link-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-14);
  color: var(--color-purple-400);
  margin-top: var(--space-6);
  text-decoration: none;
  transition: gap var(--duration-160) var(--ease-out);
}

.link-cta:hover {
  gap: var(--space-3);
}

.link-cta svg {
  width: 14px;
  height: 14px;
  color: currentColor;
}

.b__card--interactive {
  cursor: pointer;
  transition: border-color var(--duration-160) var(--ease-out),
              transform var(--duration-160) var(--ease-out);
}

.b__card--interactive:hover {
  border-color: var(--border-card);
  transform: translateY(-2px);
}

.bento-a--inv { direction: rtl; }

.bento-a--inv > * { direction: ltr; }

.bento-b {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: var(--space-4);
  min-height: calc(100vh - var(--space-40));
}

.bento-b .b__hero-visual {
  min-height: 360px;
}

.bento-b .b__features {
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
}

.bento-b .b__cell { border-bottom: none; }

.bento-b .b__cell:nth-child(odd) { border-right: none; }

.bento-b .b__cell:not(:last-child) {
  border-right: 1px solid var(--border-card);
}

.bento-1x1 {
  display: block;
}

.bento-1x1 .b__card {
  position: relative;
  min-height: 540px;
}

.bento-1x1 .b__hero-overlay {
  min-height: 540px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bento-1x1 .b__hero-content {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-12);
}

.bento-1x1 .b__hero-visual {
  min-height: 540px;
}

.bento-1x1 .b__cta {
  position: relative;
  bottom: auto;
  left: auto;
  margin-top: var(--space-8);
}

.bento-g {
  display: block;
}

.bento-g .b__features {
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 1fr;
}

.bento-g .b__cell { border-bottom: none; }

.bento-g .b__cell:nth-child(odd) { border-right: none; }

.bento-g .b__cell:not(:last-child) {
  border-right: 1px solid var(--border-card);
}

.bento-g--3col .b__features {
  grid-template-columns: repeat(3, 1fr);
}

.b--animated { animation: fadeInUp 0.8s var(--ease-out) forwards; }

.b--animated .b__features { opacity: 0; animation: fadeInUp 0.8s var(--ease-out) 0.25s forwards; }

.b--animated .b__cell:nth-child(1) { opacity: 0; animation: fadeInUp 0.6s var(--ease-out) 0.3s forwards; }

.b--animated .b__cell:nth-child(2) { opacity: 0; animation: fadeInUp 0.6s var(--ease-out) 0.4s forwards; }

.b--animated .b__cell:nth-child(3) { opacity: 0; animation: fadeInUp 0.6s var(--ease-out) 0.5s forwards; }

.b--animated .b__cell:nth-child(4) { opacity: 0; animation: fadeInUp 0.6s var(--ease-out) 0.6s forwards; }

.statement-section {
  padding: var(--space-30) 0;
  text-align: center;
}

.statement-text {
  max-width: 900px;
  margin: 0 auto;
}

.statement-title {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  margin-bottom: var(--space-6);
}

.statement-body {
  font-size: var(--font-size-24);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
}

.cta-section {
  padding: var(--space-16) 0;
  background: var(--bg-primary);
  text-align: center;
}

.cta-content {
  max-width: 600px;
  margin: 0 auto;
}

.cta-content.cta-bento {
  max-width: 1200px;
}

.container.cta-bento {
  padding: var(--space-20) var(--space-12);
}

.cta-title {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-4);
}

.cta-subtitle {
  font-size: var(--font-size-18);
  color: var(--text-secondary);
  margin-bottom: var(--space-10);
}

.cta-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

.cta-bento {
  position: relative;
  max-width: 1200px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: var(--space-20) var(--space-12);
  background: linear-gradient(180deg, #0a0a0f 0%, #0d0a18 50%, #120d1f 100%);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
  overflow: hidden;
  text-align: center;
  box-sizing: border-box;
}

.cta-bento > * {
  position: relative;
  z-index: 1;
}

.cta-bento::before {
  content: '';
  position: absolute;
  bottom: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 120%;
  height: 80%;
  background: radial-gradient(ellipse at center, rgba(148, 122, 252, 0.25) 0%, rgba(126, 58, 237, 0.12) 40%, transparent 70%);
  pointer-events: none;
}

.cta-bento .cta-bento-tag {
  display: block;
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-4);
}

.cta-bento .cta-title {
  color: var(--color-neutral-0);
  margin-bottom: var(--space-4);
}

.cta-bento .cta-subtitle {
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: var(--space-10);
}

.cta-bento .cta-actions {
  justify-content: center;
  width: fit-content;
  margin-inline: auto;
}

.logo-item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 32px;
  opacity: 0.5;
  transition: opacity var(--duration-160) var(--ease-out);
  color: var(--text-secondary);
  font-size: var(--font-size-18);
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-tight);
  white-space: nowrap;
}

.logo-item img {
  max-height: 24px;
  max-width: 100%;
  width: auto;
  height: auto;
  display: block;
  object-fit: contain;
}

.logo-item:hover { opacity: 0.8; }

.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.feature-section {
  padding: var(--space-20) 0;
}

.feature-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.feature--flipped .feature-grid {
  direction: rtl;
}

.feature--flipped .feature-grid > * {
  direction: ltr;
}

.feature-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.feature-title {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.feature-desc {
  font-size: var(--font-size-18);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-10);
}

.feature-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-10);
}

.feature-list li {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--font-size-16);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-1);
  transition: color var(--duration-240) var(--ease-out),
              background var(--duration-240) var(--ease-out),
              transform var(--duration-160) var(--ease-out);
  cursor: default;
}

.feature-list li:hover {
  color: var(--text-primary);
  background: color-mix(in srgb, var(--color-white) 3%, transparent);
  transform: translateX(4px);
}

.feature-list li svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  padding: var(--space-2);
  box-sizing: content-box;
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-1);
  color: var(--text-primary);
  transition: border-color var(--duration-240) var(--ease-out),
              color var(--duration-240) var(--ease-out),
              background var(--duration-240) var(--ease-out),
              box-shadow var(--duration-240) var(--ease-out);
}

.feature-list li:hover svg {
  border-color: var(--color-purple-400);
  color: var(--color-purple-400);
  background: color-mix(in srgb, var(--color-purple-400) 6%, transparent);
}

.feature-visual {
  position: relative;
  border-radius: var(--radius-3);
  overflow: hidden;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.feature-visual-placeholder {
  font-size: var(--font-size-14);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

.testimonial-section {
  padding: var(--space-20) 0;
}

.testimonial-card {
  position: relative;
  background: var(--bg-primary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  padding: var(--space-24) var(--space-20);
  overflow: hidden;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.testimonial-quote {
  font-size: var(--font-size-24);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-relaxed);
  color: var(--text-primary);
  max-width: 720px;
  margin-bottom: var(--space-12);
}

.testimonial-author {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  text-align: left;
}

.testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-18);
  color: var(--text-secondary);
  font-weight: var(--font-weight-medium);
}

.testimonial-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.testimonial-name {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
}

.testimonial-role {
  font-size: var(--font-size-14);
  color: var(--text-tertiary);
}

@keyframes scrollQuotes {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

.testimonial-scroll-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  min-height: 500px;
}

.testimonial-scroll-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-3);
  border: 1px solid var(--border-card);
  background: var(--bg-primary);
  display: flex;
  flex-direction: column;
  padding: var(--space-10);
}

.testimonial-scroll-panel {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-3);
  border: 1px solid var(--border-card);
  background: var(--bg-primary);
  min-height: 400px;
}

.testimonial-scroll-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 10;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, black 8%, black 92%, transparent 100%);
}

.testimonial-scroll-track {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-3);
  animation: scrollQuotes 30s linear infinite;
}

.testimonial-quote-mini {
  border-radius: var(--radius-2);
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  padding: var(--space-3);
}

.testimonial-quote-mini-text {
  font-size: var(--font-size-14);
  color: var(--text-primary);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-2);
}

.testimonial-quote-mini-author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.testimonial-quote-mini-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-12);
  color: var(--color-purple-400);
  flex-shrink: 0;
}

.testimonial-quote-mini-name {
  font-size: var(--font-size-12);
  color: var(--text-primary);
}

.testimonial-quote-mini-role {
  font-size: var(--font-size-10);
  color: var(--text-tertiary);
}

.faq-list {
  list-style: none;
  padding: 0;
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}

.faq-item {
  border-bottom: 1px solid var(--border-primary);
}

.faq-item:last-child {
  border-bottom: none;
}

.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-8) 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
  text-align: left;
  line-height: var(--line-height-normal);
  font-family: inherit;
}

.faq-question:hover {
  color: var(--color-purple-400);
}

.faq-chevron {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--text-tertiary);
  transition: transform var(--duration-160) var(--ease-out);
}

.faq-item.is-open .faq-chevron {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--duration-240) var(--ease-out);
}

.faq-answer-inner {
  padding: 0 0 var(--space-8);
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.faq--dark .faq-item {
  border-bottom: none;
  border-top: 1px solid var(--border-transparent);
}

.faq--dark .faq-item:last-child {
  border-bottom: 1px solid var(--border-transparent);
}

.metrics-strip {
  padding: var(--space-20) 0;
  background: var(--bg-primary);
}

.metrics-strip .b__cell-inner {
  align-items: center;
  text-align: center;
  justify-content: center;
}

.metric-value {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-none);
  letter-spacing: var(--letter-spacing-tighter);
  color: var(--text-primary);
}

.metric-label {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  line-height: var(--line-height-normal);
  max-width: 180px;
}

.code-block {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-1);
  overflow: hidden;
  font-family: var(--font-mono);
}

.code-block-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-card);
}

.code-block-dots {
  display: flex;
  gap: var(--space-1);
  flex-shrink: 0;
}

.code-block-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: var(--border-primary);
}

.code-block-filename {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
}

.code-block-body {
  padding: var(--space-6);
  overflow-x: auto;
}

.code-block pre {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--font-size-12);
  line-height: var(--line-height-loose);
  color: var(--text-secondary);
  white-space: pre;
}

.code-block-body [data-lang] { display: none; }

.code-block-body [data-lang].is-active { display: block; }

.code-block-header--tabs {
  padding: 0;
  gap: 0;
}

.code-block-tab {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--font-size-12);
  text-align: center;
  color: var(--text-tertiary);
  background: none;
  border: none;
  border-right: 1px solid var(--border-card);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color var(--duration-160) var(--ease-out),
              border-color var(--duration-160) var(--ease-out);
}

.code-block-tab:last-child { border-right: none; }

.code-block-tab:hover { color: var(--text-secondary); }

.code-block-tab.is-active {
  color: var(--text-primary);
  border-bottom-color: var(--color-purple-400);
}

.tok-kw   { color: var(--color-purple-300); }

.tok-type  { color: var(--color-yellow-400); }

.tok-fn    { color: var(--color-blue-300); }

.tok-str   { color: var(--color-green-500); }

.tok-num   { color: var(--color-orange-500); }

.tok-cmt   { color: var(--text-tertiary); font-style: italic; }

.tok-prop  { color: var(--color-blue-200); }

.dev-section {
  padding: var(--space-20) 0;
  background: var(--bg-primary);
}

.dev-section-inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-10);
}

.dev-section-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
  max-width: 680px;
  margin: 0 auto;
}

.dev-section-title {
  font-size: var(--font-size-32);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
}

.dev-section-desc {
  font-size: var(--font-size-16);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.dev-quote {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  border-left: 2px solid var(--color-purple-400);
  background: var(--bg-tertiary);
  border-radius: 0 var(--radius-1) var(--radius-1) 0;
}

.dev-quote-text {
  font-size: var(--font-size-14);
  color: var(--text-primary);
  line-height: var(--line-height-relaxed);
  font-style: italic;
}

.dev-quote-author {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  font-style: normal;
}

.article-section {
  padding: var(--space-20) 0;
  background: var(--bg-primary);
}

.article-section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--space-10);
}

.article-section-title {
  font-size: var(--font-size-24);
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
}

.article-section-link {
  font-size: var(--font-size-14);
  color: var(--text-tertiary);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-1);
  transition: color var(--duration-160) var(--ease-out);
}

.article-section-link:hover {
  color: var(--text-primary);
}

.article-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.article-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-secondary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  overflow: hidden;
  text-decoration: none;
  transition:
    border-color var(--duration-160) var(--ease-out),
    transform var(--duration-160) var(--ease-out);
}

.article-card:hover {
  border-color: var(--border-secondary);
  transform: translateY(-2px);
}

@media (prefers-reduced-motion: reduce) {
  .article-card:hover {
    transform: none;
  }
}

.article-card-thumb {
  aspect-ratio: 16 / 9;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border-card);
  overflow: hidden;
}

.article-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-5) var(--space-4);
  flex: 1;
}

.article-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.article-card-category {
  font-size: var(--font-size-10);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-purple-400);
}

.article-card-readtime {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
}

.article-card-title {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  line-height: var(--line-height-normal);
  letter-spacing: var(--letter-spacing-tight);
}

.article-card-desc {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  flex: 1;
}

.article-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-card);
  margin-top: auto;
}

.article-card-cta {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  transition: color var(--duration-160) var(--ease-out);
}

.article-card:hover .article-card-cta {
  color: var(--text-primary);
}

.hs-form-wrap {
  max-width: 480px;
}

.hs-form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}

.hs-form-label {
  font-family: var(--font-sans);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.hs-required {
  color: var(--color-red-500);
}

.hs-form-input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--font-size-16);
  color: var(--text-primary);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-1);
  outline: none;
  transition: border-color var(--duration-160) var(--ease-out),
              box-shadow var(--duration-160) var(--ease-out);
  box-sizing: border-box;
}

.hs-form-input::placeholder {
  color: var(--text-tertiary);
}

.hs-form-input:focus-visible {
  outline: 2px solid var(--color-purple-400);
  outline-offset: 2px;
}

.hs-form-error {
  font-family: var(--font-sans);
  font-size: var(--font-size-14);
  color: var(--color-red-500);
  background: var(--bg-error);
  border-radius: var(--radius-1);
  padding: var(--space-3);
  margin-bottom: var(--space-4);
}

.hs-form-submit {
  width: 100%;
  padding: var(--space-4);
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-medium);
  transition: transform var(--duration-160) var(--ease-out),
              opacity var(--duration-160) var(--ease-out);
}

.hs-form-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.hs-form-success p {
  font-family: var(--font-sans);
  font-size: var(--font-size-16);
  color: var(--text-primary);
  background: var(--bg-secondary);
  border-radius: var(--radius-2);
  padding: var(--space-6);
  text-align: center;
  margin: 0;
}

.contact-section {
  padding: var(--space-20) 0;
}

.contact-section-head {
  text-align: center;
  margin-bottom: var(--space-12);
}

.contact-section-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}

.contact-form-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  padding: var(--space-10);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-form .form-label {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-book);
  color: var(--text-secondary);
}

.contact-form .form-input,
.contact-form .form-select {
  padding: var(--space-3) var(--space-4);
  border-color: var(--border-secondary);
  outline: none;
}

.contact-form .form-input:focus,
.contact-form .form-select:focus {
  border-color: var(--border-brand);
}

.form-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23727272' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  background-size: 16px;
  padding-right: var(--space-10);
  cursor: pointer;
}

.form-checks {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  cursor: pointer;
  user-select: none;
}

.form-checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.form-checkbox-mark {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-0);
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
  transition: border-color var(--duration-160) var(--ease-out),
              background var(--duration-160) var(--ease-out);
}

.form-checkbox input[type="checkbox"]:checked + .form-checkbox-mark {
  background: var(--color-purple-400);
  border-color: var(--color-purple-400);
}

.form-checkbox input[type="checkbox"]:checked + .form-checkbox-mark::after {
  content: '';
  display: block;
  width: 8px;
  height: 5px;
  border-left: 1.5px solid var(--color-neutral-0);
  border-bottom: 1.5px solid var(--color-neutral-0);
  transform: rotate(-45deg) translateY(-1px);
}

.form-checkbox input[type="checkbox"]:focus-visible + .form-checkbox-mark {
  outline: 2px solid var(--border-focus);
  outline-offset: 2px;
}

.form-checkbox-label {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  line-height: var(--line-height-relaxed);
}

.form-checkbox-label a {
  color: var(--text-secondary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact-proof-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: sticky;
  top: var(--space-24);
}

.testimonial-card--g2 {
  gap: var(--space-6);
  background: var(--bg-primary);
}

.testimonial-g2-icon {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

.testimonial-g2-icon svg {
  width: 100%;
  height: 100%;
}

.testimonial-g2-label {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
}

.testimonial-card--g2 .testimonial-quote {
  font-size: var(--font-size-24);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: 0;
}

.testimonial-g2-stars {
  display: flex;
  gap: var(--space-1);
  color: var(--color-orange-500);
  justify-content: center;
}

.testimonial-g2-stars svg {
  width: 24px;
  height: 24px;
}

.testimonial-g2-author {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
}

.testimonial-avatar--lg {
  width: 64px;
  height: 64px;
  font-size: var(--font-size-24);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.form-group:last-of-type {
  margin-bottom: var(--space-6);
}

.form-label {
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
}

.form-input {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-4);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-1);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: var(--font-size-14);
  transition: border-color var(--duration-160) var(--ease-out);
  box-sizing: border-box;
}

.form-input::placeholder {
  color: var(--text-tertiary);
}

.form-input:focus {
  outline: none;
  border-color: var(--border-brand);
}

.form-privacy {
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  line-height: var(--line-height-relaxed);
  margin-top: var(--space-4);
}

.form-privacy a {
  color: var(--text-secondary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.form-btn-full {
  width: 100%;
}

.event-strip {
  padding: var(--space-8) 0;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border-card);
  border-bottom: 1px solid var(--border-card);
}

.event-strip-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-12);
  flex-wrap: wrap;
}

.event-strip-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.event-strip-item svg {
  width: var(--font-size-18);
  height: var(--font-size-18);
  flex-shrink: 0;
  color: var(--color-purple-400);
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.event-strip-label {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
}

.event-strip-value {
  font-size: var(--font-size-14);
  color: var(--text-primary);
  font-weight: var(--font-weight-medium);
}

.headshot-carousel-wrap {
  overflow: hidden;
}

.headshot-carousel-track {
  --_card-w: 300px;
  --_gap: var(--space-4);
  display: flex;
  gap: var(--_gap);
  transition: transform var(--duration-480) cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.headshot-card {
  flex-shrink: 0;
  width: var(--_card-w);
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-3);
  overflow: hidden;
  position: relative;
  background: var(--bg-primary);
  border: 1px solid var(--border-card);
}

.headshot-card__placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.headshot-card__placeholder svg {
  width: var(--font-size-56);
  height: var(--font-size-56);
  color: var(--text-tertiary);
  stroke: currentColor;
  fill: none;
  stroke-width: 1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.headshot-card__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.88) 0%, rgba(0, 0, 0, 0.4) 45%, transparent 70%);
}

.headshot-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-6);
}

.headshot-card__name {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-normal);
  color: var(--text-primary);
  margin-bottom: 2px;
}

.headshot-card__role {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--text-secondary);
}

.img-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.img-gallery__main {
  border-radius: var(--radius-3);
  border: 1px solid var(--border-card);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--bg-primary);
  position: relative;
}

.img-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity var(--duration-320) var(--ease-out);
}

.img-gallery__main-img.is-fading {
  opacity: 0;
}

.img-gallery__thumbs {
  display: flex;
  gap: var(--space-4);
  align-items: center;
}

.img-gallery__track-wrap {
  overflow-x: auto;
  flex: 1;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.img-gallery__track-wrap::-webkit-scrollbar {
  display: none;
}

.img-gallery__track {
  display: flex;
  gap: var(--space-4);
}

.img-gallery__thumb {
  flex-shrink: 0;
  width: 120px;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-2);
  border: 1px solid var(--border-secondary);
  overflow: hidden;
  opacity: 0.5;
  cursor: pointer;
  transition:
    opacity var(--duration-160) var(--ease-out),
    border-color var(--duration-160) var(--ease-out);
}

.img-gallery__thumb:hover {
  opacity: 0.8;
}

.img-gallery__thumb.is-active {
  opacity: 1;
  border-color: var(--border-active);
}

.img-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.img-gallery__placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(160deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-regular);
}

.metrics-strip-head {
  text-align: center;
  margin-bottom: var(--space-10);
}

.bento-section-head {
  text-align: center;
  margin-bottom: var(--space-10);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  align-items: start;
}

.pricing-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-3);
  padding: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  transition:
    transform var(--duration-160) var(--ease-out),
    border-color var(--duration-160) var(--ease-out);
}

.pricing-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-secondary);
}

.pricing-card--featured {
  background: var(--bg-secondary);
}

.pricing-card__tier {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.pricing-card__name {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-book);
  color: var(--text-primary);
  letter-spacing: var(--letter-spacing-tight);
}

.pricing-card__price {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.pricing-card__amount {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-book);
  color: var(--text-primary);
  letter-spacing: var(--letter-spacing-tight);
  line-height: var(--line-height-none);
}

.pricing-card__amount--custom {
  font-size: var(--font-size-32);
}

.pricing-card__period {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  font-weight: var(--font-weight-regular);
}

.pricing-card__price-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}

.pricing-card__price-label {
  font-size: var(--font-size-12);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  color: var(--text-tertiary);
  font-weight: var(--font-weight-regular);
}

.pricing-card__features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  flex: 1;
}

.pricing-card__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-regular);
  color: var(--text-secondary);
  line-height: var(--line-height-normal);
}

.pricing-card__feature svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pricing-card__cta {
  margin-top: auto;
}

.container {
  max-width: var(--max-w-container);
  padding-left: var(--space-page-x);
  padding-right: var(--space-page-x);
  margin: 0 auto;
}

.section {
  padding: var(--space-section-y) 0;
  background: var(--bg-primary);
}

.section--compact {
  padding: var(--space-section-y-sm) 0;
}

.hero {
  position: relative;
  overflow: hidden;
}

.hero--centered {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-40) var(--space-6) var(--space-30);
}

.hero--split {
  width: 100%;
  padding: var(--space-40) 0 var(--space-20);
}

.hero--split::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 100%, color-mix(in srgb, var(--color-purple-700) 12%, transparent) 0%, transparent 70%),
    radial-gradient(ellipse 80% 40% at 30% 80%, color-mix(in srgb, var(--color-purple-400) 8%, transparent) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 70% 90%, color-mix(in srgb, var(--color-purple-500) 6%, transparent) 0%, transparent 60%);
  pointer-events: none;
}

.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: var(--space-16);
  max-width: var(--max-w-container);
  margin: 0 auto;
  padding: 0 var(--space-8);
  position: relative;
  z-index: 1;
}

.hero-image {
  position: relative;
  z-index: 1;
  aspect-ratio: 1 / 1;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-2);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  animation: fadeInUp 0.8s var(--ease-out) 0.1s both;
}

.hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.hero .tag-label {
  margin-bottom: var(--space-6);
}

.hero .badge {
  margin-bottom: var(--space-6);
}

.hero--centered h1 {
  font-size: var(--font-size-80);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tighter);
  margin-top: var(--space-6);
  margin-bottom: var(--space-6);
  background: none;
  -webkit-background-clip: unset;
  -webkit-text-fill-color: var(--text-primary);
  background-clip: unset;
}

.hero--split h1 {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  margin-bottom: var(--space-6);
}

.hero-subtitle {
  font-size: var(--font-size-18);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-8);
}

.hero--centered .hero-subtitle {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.hero--home h1 {
  margin-top: var(--space-8);
  margin-bottom: var(--space-6);
}

.hero--home .hero-subtitle {
  margin-bottom: var(--space-10);
}

.hero-bg__n {
  position: absolute;
  border-radius: 50%;
  will-change: transform;
}

.hero-bg__ambient {
  position: absolute;
  left: -100px; top: 36%;
  width: calc(100% + 200px);
  height: 64%;
  background: radial-gradient(ellipse at 50% 80%, #0A0A2E 0%, #050510 50%, transparent 80%);
  opacity: 0.8;
}

.hero-bg__n1 {
  width: 1000px; height: 700px;
  left: calc(50% - 650px); top: 42%;
  background: radial-gradient(ellipse at 65% 65%, rgba(8,145,178,0.6) 0%, rgba(14,116,144,0.3) 30%, rgba(6,78,96,0.1) 55%, transparent 75%);
  animation: nebulaDrift1 25s ease-in-out infinite, nebulaBreath1 20s ease-in-out infinite;
}

.hero-bg__n2 {
  width: 1400px; height: 800px;
  left: calc(50% - 600px); top: 36%;
  background: radial-gradient(ellipse at 50% 70%, rgba(46,16,101,0.7) 0%, rgba(30,10,60,0.4) 35%, transparent 70%);
  animation: nebulaDrift2 30s ease-in-out infinite, nebulaBreath2 22s ease-in-out infinite;
}

.hero-bg__n3 {
  width: 1100px; height: 700px;
  left: calc(50% - 400px); top: 38%;
  background: radial-gradient(ellipse at 52% 72%, rgba(147,51,234,0.5) 0%, rgba(126,34,206,0.3) 25%, rgba(88,28,135,0.15) 50%, transparent 72%);
  animation: nebulaDrift3 28s ease-in-out infinite, nebulaBreath1 18s ease-in-out infinite;
}

.hero-bg__n4 {
  width: 800px; height: 500px;
  left: calc(50% - 250px); top: 44%;
  background: radial-gradient(ellipse at 50% 75%, rgba(192,132,252,0.55) 0%, rgba(168,85,247,0.3) 30%, rgba(107,33,168,0.1) 55%, transparent 72%);
  animation: nebulaDrift1 22s ease-in-out infinite reverse, nebulaBreath2 24s ease-in-out infinite;
}

.hero-bg__n5 {
  width: 1100px; height: 700px;
  left: calc(50% - 100px); top: 36%;
  background: radial-gradient(ellipse at 55% 68%, rgba(67,56,202,0.5) 0%, rgba(49,46,129,0.3) 30%, rgba(30,27,75,0.1) 55%, transparent 72%);
  animation: nebulaDrift2 26s ease-in-out infinite reverse, nebulaBreath1 20s ease-in-out infinite;
}

.hero-bg__n6 {
  width: 550px; height: 350px;
  left: calc(50% - 200px); top: 49%;
  background: radial-gradient(ellipse at 50% 85%, rgba(232,121,249,0.45) 0%, rgba(168,85,247,0.2) 40%, transparent 70%);
  animation: nebulaDrift3 20s ease-in-out infinite, nebulaBreath2 18s ease-in-out infinite;
}

.hero-bg__n7 {
  width: 280px; height: 160px;
  left: calc(50% - 80px); top: 54%;
  background: radial-gradient(ellipse at 50% 85%, rgba(245,208,254,0.4) 0%, rgba(192,132,252,0.15) 45%, transparent 75%);
  animation: nebulaDrift1 18s ease-in-out infinite, nebulaBreath1 16s ease-in-out infinite;
}

.hero-bg__planet {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 150vw;
  height: 150vw;
  transform: translateX(-50%) translateY(87%);
  border-radius: 50%;
  background: #030308;
  box-shadow: 0 -1px 0 0 rgba(147,51,234,0.3);
}

.hero-bg__rim {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 150vw;
  height: 150vw;
  transform: translateX(-50%) translateY(87%);
  border-radius: 50%;
  border: 1.5px solid transparent;
  background: none;
  box-shadow:
    0 0 0 1.5px rgba(147,51,234,0.2),
    0 0 40px 8px rgba(147,51,234,0.06);
  animation: rimPulse 16s ease-in-out infinite;
}

@keyframes nebulaDrift1 {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(30px, -10px); }
}

@keyframes nebulaDrift2 {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-25px, 8px); }
}

@keyframes nebulaDrift3 {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(20px, -7px); }
}

@keyframes nebulaBreath1 {
  0%, 100% { scale: 1; }
  50% { scale: 1.04; }
}

@keyframes nebulaBreath2 {
  0%, 100% { scale: 1; }
  50% { scale: 1.05; }
}

@keyframes rimPulse {
  0%, 100% { opacity: 0.15; }
  50% { opacity: 0.35; }
}

.hero-live {
  position: absolute;
  top: var(--space-40);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  letter-spacing: var(--letter-spacing-wide);
}

.hero-live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-green-500);
  animation: livePulse 2s ease-in-out infinite;
}

@keyframes livePulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

.hero-live-label {
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.hero-live-value {
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}

.hero,
.bench-hero-bento,
.cta-section {
  --letter-spacing-wide: var(--letter-spacing-hero);
  --letter-spacing-wider: var(--letter-spacing-hero);
  --letter-spacing-widest: var(--letter-spacing-hero);
}

.hero-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--font-size-14);
  color: var(--text-tertiary);
  margin-bottom: var(--space-10);
}

.hero-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.hero-image {
  position: relative;
  z-index: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeInUp 0.8s var(--ease-out) 0.15s both;
}

.hero-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-3);
}

.se-toast {
  position: fixed; bottom: var(--space-6, 24px); left: 50%; transform: translateX(-50%);
  padding: 10px var(--space-6, 24px); border-radius: var(--radius-2, 12px);
  background: var(--bg-elevated, #1a1a1a); color: var(--text-primary, #fff);
  font-size: var(--font-size-14, 14px); opacity: 0; transition: opacity 0.3s ease-out;
  z-index: 9999; pointer-events: none;
}

.se-toast.show { opacity: 1; }

.error-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-12);
}

.error-code {
  font-size: clamp(80px, 15vw, 160px);
  font-weight: var(--font-weight-regular);
  line-height: 1;
  background: linear-gradient(135deg, var(--color-purple-400), var(--color-blue-400));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-6);
}

.error-title {
  font-size: var(--font-size-32);
  color: var(--color-neutral-0);
  margin-bottom: var(--space-4);
}

.error-desc {
  font-size: var(--font-size-18);
  color: var(--color-neutral-400);
  max-width: 440px;
  margin-bottom: var(--space-12);
}

.hero--dark {
  --bg-primary:              var(--color-neutral-1000);
  --bg-secondary:            var(--color-neutral-900);
  --text-primary:            var(--color-neutral-0);
  --text-secondary:          rgba(255, 255, 255, 0.7);
  --text-tertiary:           rgba(255, 255, 255, 0.5);
  --border-primary:          rgba(255, 255, 255, 0.12);
  --border-transparent:      rgba(255, 255, 255, 0.12);
  --border-transparent-subtle: rgba(255, 255, 255, 0.08);

  width: 100%;
  background: var(--bg-primary);
  padding: calc(var(--space-40) + 80px) 0 var(--space-20);
  margin-top: 0;
}

.hero--dark.hero--split {
  padding: calc(var(--space-40) + 80px) 0 var(--space-20);
}

.hero--dark .hero-inner {
  grid-template-columns: 11fr 9fr;
}

.pricing-hero {
  min-height: 52vh;
  padding: var(--space-40) var(--space-6) var(--space-20);
}

.pricing-hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  text-align: center;
}

.pricing-hero-title {
  font-size: var(--font-size-64);
  font-weight: var(--font-weight-book);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  max-width: 760px;
}

.pricing-hero-subtitle {
  font-size: var(--font-size-18);
  font-weight: var(--font-weight-regular);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
  max-width: 560px;
}

.footer {
  background: var(--color-neutral-1000);
  border-top: 1px solid var(--color-neutral-900);
  padding: var(--space-18) 0 var(--space-16);
}

.footer-top {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-16);
}

.footer-brand {
  flex: 2;
}

.footer-brand-desc {
  font-size: var(--font-size-14);
  color: var(--color-neutral-400);
  line-height: var(--line-height-relaxed);
  max-width: 280px;
  margin-top: var(--space-4);
}

.footer-columns {
  flex: 3;
  display: flex;
  gap: var(--space-4);
}

.footer-column {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-column-title {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-regular);
  color: var(--color-neutral-0);
  margin-bottom: var(--space-2);
}

.footer-column a {
  font-size: var(--font-size-14);
  color: var(--color-neutral-400);
  transition: color var(--duration-160) var(--ease-out);
}

.footer-column a:hover {
  color: var(--color-neutral-0);
}

.footer-bottom {
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-neutral-900);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer-bottom-text {
  font-size: var(--font-size-12);
  color: var(--color-neutral-500);
}

.footer-bottom-links {
  display: flex;
  gap: var(--space-6);
}

.footer-bottom-links a {
  font-size: var(--font-size-12);
  color: var(--color-neutral-500);
  transition: color var(--duration-160) var(--ease-out);
}

.footer-bottom-links a:hover {
  color: var(--color-neutral-0);
}

.article-content ul li {
  margin-bottom: var(--space-2);
  position: relative;
  padding-left: var(--space-6);
}

.article-content ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 3px;
  width: 18px;
  height: 18px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none"><path d="M13 3C13 2.44772 12.5523 2 12 2C11.4477 2 11 2.44772 11 3C11 6.18838 10.331 8.25562 9.1178 9.53621C7.91616 10.8046 5.98995 11.5 3 11.5C2.44772 11.5 2 11.9477 2 12.5C2 13.0523 2.44772 13.5 3 13.5C5.98995 13.5 7.91616 14.1954 9.1178 15.4638C10.331 16.7444 11 18.8116 11 22C11 22.5523 11.4477 23 12 23C12.5523 23 13 22.5523 13 22C13 18.8116 13.669 16.7444 14.8822 15.4638C16.0838 14.1954 18.01 13.5 21 13.5C21.5523 13.5 22 13.0523 22 12.5C22 11.9477 21.5523 11.5 21 11.5C18.01 11.5 16.0838 10.8046 14.8822 9.53621C13.669 8.25562 13 6.18838 13 3Z" fill="%238B5CF6"/></svg>');
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
}

.article-content ul li ul {
  margin-top: var(--space-2);
  margin-bottom: var(--space-2);
  list-style: none;
}

.article-content ul li ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  background: var(--color-neutral-400);
  border-radius: 2px;
  flex-shrink: 0;
}

.article-preview {
  margin: var(--space-12) 0;
  padding: 0;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-3);
  transition: all var(--duration-160) var(--ease-out);
  text-decoration: none !important;
  display: flex;
  gap: var(--space-10);
  overflow: hidden;
}

.article-preview:hover {
  border-color: var(--color-purple-400);
  box-shadow: 0 4px 12px rgba(139, 92, 246, 0.1);
}

.article-preview-image {
  flex-shrink: 0;
  width: 280px;
  background: var(--bg-tertiary);
  overflow: hidden;
  display: flex;
  align-items: stretch;
}

.article-preview-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-240) var(--ease-out);
}

.article-preview:hover .article-preview-image img {
  transform: none;
}

.article-preview--balanced {
  padding: var(--space-6);
  gap: var(--space-6);
}

.article-preview--balanced .article-preview-image {
  width: 240px;
  padding: 0;
  background: transparent;
  align-items: center;
  transition: transform var(--duration-240) var(--ease-out);
}

.article-preview--balanced .article-preview-image img {
  border-radius: var(--radius-2);
  object-fit: contain;
  width: 100%;
  height: auto;
}

.article-preview--balanced .article-preview-content {
  padding: 0;
  transition: transform var(--duration-240) var(--ease-out);
}

.article-preview--balanced:hover .article-preview-image {
  transform: translateX(6px);
}

.article-preview--balanced:hover .article-preview-content {
  transform: translateX(6px);
}

.article-preview-content {
  flex: 1;
  padding: var(--space-10);
  display: flex;
  flex-direction: column;
}

.article-preview--balanced .article-preview-content {
  padding: 0;
}

.article-preview-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  font-size: var(--font-size-12);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.article-preview-tag {
  padding: 4px 8px;
  background: color-mix(in srgb, var(--color-purple-400) 15%, transparent);
  color: var(--color-purple-300);
  border: 1px solid color-mix(in srgb, var(--color-purple-500) 30%, transparent);
  border-radius: var(--radius-1);
  font-weight: var(--font-weight-medium);
}

.article-preview h4 {
  font-size: var(--font-size-18);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
  line-height: var(--line-height-tight);
}

.article-preview p {
  font-size: var(--font-size-14);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
  margin-bottom: var(--space-6);
}

.article-preview-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  color: var(--color-purple-600);
}

.article-preview-cta svg {
  width: 16px;
  height: 16px;
  transition: transform var(--duration-160) var(--ease-out);
}

.article-preview:hover .article-preview-cta svg {
  transform: translateX(4px);
}

.hero--article .badge {
  margin-bottom: var(--space-6);
  background: color-mix(in srgb, var(--color-purple-500) 15%, transparent);
  color: var(--color-purple-300);
  border: 1px solid color-mix(in srgb, var(--color-purple-500) 30%, transparent);
}

.article-hero-illustration {
  width: 100%;
  height: auto;
  border-radius: var(--radius-3);
  overflow: hidden;
  display: flex;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%, color-mix(in srgb, var(--color-purple-500) 15%, transparent) 0%, transparent 70%),
    radial-gradient(ellipse 50% 40% at 30% 60%, color-mix(in srgb, var(--color-purple-500) 8%, transparent) 0%, transparent 60%),
    var(--bg-primary);
  border: 1px solid var(--border-transparent-subtle);
}

.article-hero-illustration iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: var(--radius-3);
}

.article-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-12);
  max-width: var(--max-w-container);
  margin: 0 auto;
  padding: var(--space-12) var(--space-8) var(--space-24);
}

.article-toc {
  position: sticky;
  top: 120px;
  align-self: start;
  padding: var(--space-4);
  max-height: calc(100vh - 140px);
  overflow-y: auto;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-3);
}

.article-toc-label {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-regular);
  text-transform: uppercase;
  font-size: 10px;
  color: var(--text-tertiary);
  letter-spacing: 0.12em;
  display: block;
  padding-left: var(--space-4);
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
}

.article-toc-nav {
  display: flex;
  flex-direction: column;
}

.article-toc-link {
  display: block;
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-14);
  color: var(--text-tertiary);
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: all var(--duration-160) var(--ease-out);
  line-height: var(--line-height-normal);
}

.article-toc-link:hover { color: var(--text-secondary); }

.article-toc-link.is-active {
  color: var(--text-primary);
  font-weight: var(--font-weight-medium);
  border-left-color: var(--color-purple-400);
}

.article-toc-toggle {
  display: none;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-4) var(--space-6);
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-2);
  color: var(--text-secondary);
  font-size: var(--font-size-14);
  font-family: var(--font-sans);
  cursor: pointer;
}

.article-toc-toggle svg {
  width: 16px;
  height: 16px;
  transition: transform var(--duration-160) var(--ease-out);
}

.article-toc.is-open .article-toc-toggle svg { transform: rotate(180deg); }

.article-content h2 {
  font-size: var(--font-size-32);
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
  margin-top: var(--space-16);
  margin-bottom: var(--space-6);
  line-height: var(--line-height-tight);
}

.article-content section:first-child h2 { margin-top: 0; }

.article-content h3 {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  line-height: var(--line-height-snug);
}

.article-content p {
  font-size: var(--font-size-16);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
  margin-bottom: var(--space-6);
}

.article-content a { color: var(--color-purple-400); text-decoration: underline; text-underline-offset: 3px; }

.article-content a:hover { color: var(--color-purple-300); }

.article-content ul {
  color: var(--text-secondary);
  font-size: var(--font-size-16);
  line-height: var(--line-height-relaxed);
  padding-left: var(--space-8);
  margin-bottom: var(--space-6);
  list-style: none;
}

.article-content ul li { margin-bottom: var(--space-2); }

.article-content ul li ul { margin-top: var(--space-2); margin-bottom: var(--space-2); list-style: none; }

.article-content strong { color: var(--text-primary); font-weight: var(--font-weight-medium); }

.article-divider {
  border: none;
  border-top: 1px solid var(--border-primary);
  margin: var(--space-12) 0;
}

.article-cta { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-8); }

.article-callout {
  margin: var(--space-8) 0;
  padding: var(--space-8) var(--space-8) var(--space-8) var(--space-10);
  background: color-mix(in srgb, var(--color-purple-500) 5%, transparent);
  border-left: 3px solid var(--color-purple-400);
  border-radius: 0 var(--radius-2) var(--radius-2) 0;
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.article-callout strong { color: var(--color-purple-500); font-weight: var(--font-weight-medium); }

.article-callout a { color: var(--color-purple-500); }

@media (max-width: 768px) {
  .section {
    padding: var(--space-section-y-sm) 0;
  }

  .section--compact {
    padding: var(--space-12) 0;
  }

  .navbar {
    width: calc(100% - var(--space-8));
  }

  .navbar-links {
    display: none;
  }

  .feature-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .feature--flipped .feature-grid {
    direction: ltr;
  }

  .feature-visual {
    order: -1;
  }

  .bento-g .b__features,
  .bento-g--3col .b__features {
    grid-template-columns: 1fr;
  }

  .bento-g .b__cell:nth-child(odd) {
    border-right: none;
    border-bottom: 1px solid var(--border-card);
  }

  .bento-g .b__cell:last-child {
    border-bottom: none;
  }

  .bento-g--3col .b__cell:not(:last-child) {
    border-right: none;
    border-bottom: 1px solid var(--border-primary);
  }

  .testimonial-card {
    padding: var(--space-16) var(--space-8);
  }

  .cta-title {
    font-size: var(--font-size-32);
  }

  .footer-columns {
    flex-direction: column;
    gap: var(--space-8);
  }

  .footer-bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }

  /* Hero split — mobile */
  .hero--split { padding-top: var(--space-32); }
  .hero--split .hero-inner { grid-template-columns: 1fr; }

  /* Hero dark — mobile */
  .hero--dark { padding: var(--space-24) 0 var(--space-12); }
  .hero--dark h1 { font-size: var(--font-size-32); }
  .hero--dark .hero-subtitle { font-size: var(--font-size-16); }

  /* Contact section — mobile */
  .contact-section-inner { grid-template-columns: 1fr; }
  .contact-proof-side { position: static; }

  /* Article content — mobile */
  .article-layout { padding-top: var(--space-6); }
  .article-content h2 { font-size: var(--font-size-24); }
  .article-content h3 { font-size: var(--font-size-18); }
  .article-toc { top: 64px; padding: 0; border-bottom: none; }
  .article-toc-toggle { display: flex; }
  .article-toc-nav { display: none; flex-direction: column; background: var(--bg-secondary); border: 1px solid var(--border-primary); border-radius: var(--radius-2); padding: var(--space-4); margin-top: var(--space-2); }
  .article-toc.is-open .article-toc-nav { display: flex; }
  .article-toc-link { border-bottom: none; border-left: 2px solid transparent; white-space: normal; }
  .article-toc-link.is-active { border-bottom-color: transparent; border-left-color: var(--color-purple-400); }
}

.homepage-v3 .page-bottom-eclipse-clip {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(360px, 45vw, 720px);
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

.homepage-v3 .page-bottom-eclipse-clip--paused .page-bottom-eclipse,
.homepage-v3 .page-bottom-eclipse-clip--paused .page-bottom-eclipse-core {
  animation-play-state: paused;
}

.homepage-v3 .page-bottom-eclipse {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: clamp(800px, 100vw, 1600px);
  aspect-ratio: 1 / 1;
  /* Center of the disc sits just below the footer's base,
     so the top ~45% of the circle is visible rising above. */
  transform: translate(-50%, 55%);
  transform-origin: center bottom;
  pointer-events: none;
  z-index: 0;
  animation: testiEclipseBreathe 9s ease-in-out infinite;
}

.homepage-v3 .page-bottom-eclipse-halo {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(148, 122, 252, 0.60) 0%,
    rgba(120, 80, 220, 0.45) 20%,
    rgba(90, 50, 190, 0.30) 36%,
    rgba(60, 30, 150, 0.15) 52%,
    rgba(40, 15, 120, 0.05) 66%,
    transparent 80%);
  filter: blur(48px);
}

.homepage-v3 .page-bottom-eclipse-core {
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    #000 0%,
    #000 55%,
    rgba(0, 0, 0, 0.75) 72%,
    rgba(0, 0, 0, 0.35) 86%,
    transparent 100%);
  filter: blur(72px);
  animation: testiEclipseCoreBreathe 9s ease-in-out infinite;
}

.homepage-v3 .footer {
  background: transparent;
  position: relative;
  z-index: 1;
}

.homepage-v3 .stat-card {
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: none;
  padding: var(--space-10);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
  text-align: left;
}

.homepage-v3 .stat-card + .stat-card { border-left: 1px solid var(--border-card); }

.homepage-v3 .stat-value {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-medium);
  line-height: 1.1;
  color: var(--text-primary);
}

.homepage-v3 .stat-label {
  font-size: var(--hp-text-body);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
}

.homepage-v3 .stats-tabs {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: var(--max-w-container);
  --text-primary: #ffffff;
  --text-secondary: rgba(255,255,255,0.7);
  --text-tertiary: rgba(255,255,255,0.4);
  --border-transparent: rgba(255,255,255,0.1);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
}

.homepage-v3 .stats-tabs__nav {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: none;
  border: none;
  overflow: hidden;
  visibility: hidden;
}

.homepage-v3 .stats-tabs__tab {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-10) var(--space-6);
  background: none;
  border: none;
  cursor: pointer;
  text-align: center;
  transition: background var(--duration-240) var(--ease-out);
  z-index: 1;
}

.homepage-v3 .stats-tabs__tab:not(:first-child)::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 1px;
  background: rgba(255, 255, 255, 0.1);
  transition: opacity var(--duration-240) var(--ease-out);
}

.homepage-v3 .stats-tabs__tab.is-active::before,
.homepage-v3 .stats-tabs__tab.is-active + .stats-tabs__tab::before {
  opacity: 0;
}

.homepage-v3 .stats-tabs__tab:hover {
  background: none;
}

.homepage-v3 .stats-tabs__tab:hover .stats-tabs__value-base {
  color: var(--text-secondary);
}

.homepage-v3 .stats-tabs__tab:hover .stats-tabs__label {
  color: var(--text-secondary);
}

.homepage-v3 .stats-tabs__value {
  position: relative;
  display: inline-block;
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-medium);
  line-height: 1.1;
}

.homepage-v3 .stats-tabs__value-base {
  color: var(--text-tertiary);
}

.homepage-v3 .stats-tabs__value-reveal {
  position: absolute;
  inset: 0;
  color: var(--text-primary);
  clip-path: inset(0 100% 0 0);
}

.homepage-v3 .stats-tabs__tab.is-active .stats-tabs__value-reveal {
  animation: stats-value-reveal 4s linear forwards;
}

.homepage-v3 .stats-tabs__tab.is-active .stats-tabs__value-reveal.is-paused {
  animation-play-state: paused;
}

@keyframes stats-value-reveal {
  from { clip-path: inset(0 100% 0 0); }
  to   { clip-path: inset(0 0% 0 0); }
}

.homepage-v3 .stats-tabs__label {
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-regular);
  color: var(--text-tertiary);
  transition: color var(--duration-240) var(--ease-out);
}

.homepage-v3 .stats-tabs__tab.is-active .stats-tabs__label {
  color: var(--text-secondary);
}

.homepage-v3 .stats-tabs__indicator {
  display: none;
}

.homepage-v3 .stats-tabs__stage {
  display: none;
}

@media (max-width: 768px) {
  .homepage-v3 .stats-tabs__nav { grid-template-columns: 1fr; }
  .homepage-v3 .stats-tabs__tab:not(:first-child)::before {
    left: 15%;
    right: 15%;
    top: 0;
    bottom: auto;
    width: auto;
    height: 1px;
  }
  .homepage-v3 .stats-tabs__value { font-size: var(--font-size-32); }
  .homepage-v3 .stats-tabs__indicator { display: none; }
  .homepage-v3 .stats-tabs__stage { display: none; }
}

.homepage-v3 .white-section {
  background: var(--color-neutral-50);
  display: flex;
  flex-direction: column;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.homepage-v3 .features-section {
  padding: var(--space-20) max(var(--hp-gutter-x), var(--space-6));
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
  max-width: var(--max-w-container);
  margin: 0 auto;
  width: 100%;
}

.homepage-v3 .section-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-8);
}

.homepage-v3 .section-header > .tag-label,
.homepage-v3 .comparison-header > .tag-label {
  margin-bottom: 0;
}

.homepage-v3 .section-heading {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-tight);
  text-align: center;
  color: var(--color-neutral-1000);
}

.homepage-v3 .white-section .section-subtitle {
  font-size: calc(var(--hp-prose) + 1px);
  line-height: var(--line-height-relaxed);
  text-align: center;
  color: var(--color-neutral-500);
  max-width: 700px;
}

.homepage-v3 .wg-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.homepage-v3 .wg-row {
  display: flex;
  gap: var(--space-4);
  height: 398px;
}

.homepage-v3 .wg-card {
  display: flex;
  flex-direction: column;
  position: relative;
  border-radius: 23px;
  overflow: hidden;
  cursor: pointer;
  border: none;
  padding: 0;
  text-align: left;
  font: inherit;
  isolation: isolate;
  transition: transform var(--duration-240) var(--ease-out),
              box-shadow var(--duration-240) var(--ease-out);
}

.homepage-v3 .wg-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 48px -12px rgba(0, 80, 200, 0.18);
}

.homepage-v3 .wg-card:focus-visible {
  outline: 2px solid var(--color-purple-400);
  outline-offset: 3px;
}

.homepage-v3 .wg-card--sm { flex: 1; min-width: 0; }

.homepage-v3 .wg-card--lg { flex: 2; min-width: 0; }

.homepage-v3 .wg-card__title {
  position: relative;
  z-index: 2;
  font-size: var(--font-size-32);
  font-weight: var(--font-weight-book);
  line-height: 1.1;
  letter-spacing: -0.005em;
  color: white;
  padding: var(--space-8) var(--space-9) 0;
  margin: 0;
}

.homepage-v3 .wg-title-chip,
.homepage-v3 .wg-card__sub {
  display: none;
}

.homepage-v3 .wg-expand {
  position: absolute;
  bottom: var(--space-4);
  right: var(--space-4);
  z-index: 5;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: rgba(255,255,255,0.35);
  background: transparent;
  backdrop-filter: blur(8px);
  transition: all var(--duration-240) var(--ease-out);
}

.homepage-v3 .wg-card:hover .wg-expand {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.7);
  border-color: rgba(255,255,255,0.18);
}

.homepage-v3 .wg-card .wg-expand:hover {
  background: #fff;
  color: #000;
  border-color: #fff;
}

.homepage-v3 .wg-card--languages,
.homepage-v3 .wg-card--accuracy,
.homepage-v3 .wg-card--audio,
.homepage-v3 .wg-card--infra,
.homepage-v3 .wg-card--integrations {
  background-color: #000;
  position: relative;
}

.homepage-v3 .wg-card--languages::after,
.homepage-v3 .wg-card--accuracy::after,
.homepage-v3 .wg-card--audio::after,
.homepage-v3 .wg-card--infra::after,
.homepage-v3 .wg-card--integrations::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  filter: grayscale(1);
  opacity: .8;
  transition: filter var(--duration-480) var(--ease-out),
              opacity var(--duration-480) var(--ease-out);
  pointer-events: none;
}

.homepage-v3 .wg-card--languages:hover::after,
.homepage-v3 .wg-card--accuracy:hover::after,
.homepage-v3 .wg-card--audio:hover::after,
.homepage-v3 .wg-card--infra:hover::after,
.homepage-v3 .wg-card--integrations:hover::after {
  filter: grayscale(0);
  opacity: 1;
}

.homepage-v3 .wg-card--languages::after {
  background-image: url('/images/Homepage/Why-Gladia_homepage-bento_1.png');
}

.homepage-v3 .wg-card--accuracy::after {
  background-image: url('/images/Homepage/Why-Gladia_homepage-bento_2.png');
}

.homepage-v3 .wg-card--audio::after {
  background-image: url('/images/Homepage/Why-Gladia_homepage-bento_3.png');
}

.homepage-v3 .wg-card--infra::after {
  background-image: url('/images/Homepage/Why-Gladia_homepage-bento_4.png');
}

.homepage-v3 .wg-row--full {
  aspect-ratio: 2100 / 796;
}

.homepage-v3 .wg-card--full {
  flex: 1;
  min-width: 0;
}

.homepage-v3 .wg-card--integrations::after {
  background-image: url('/images/Homepage/Why-Gladia_homepage-bento_5.png');
}

.homepage-v3 .comparison-section {
  padding: var(--space-20) max(var(--hp-gutter-x), var(--space-6));
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
  max-width: var(--max-w-container);
  margin: 0 auto;
  width: 100%;
}

.homepage-v3 .comparison-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.homepage-v3 .comparison-heading {
  font-size: var(--font-size-40);
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-tight);
  text-align: center;
  color: var(--color-neutral-1000);
}

.homepage-v3 .comparison-subtitle {
  font-size: calc(var(--hp-prose) + 1px);
  line-height: var(--line-height-relaxed);
  text-align: center;
  color: var(--color-neutral-500);
  max-width: 660px;
}

.homepage-v3 .comparison-table-mobile-hint {
  display: none;
  margin: 0;
  padding: 0;
}

.homepage-v3 .comparison-gladia-focus {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  /* Same 6+8+8 as the former .comparison-table-clip: keeps column math aligned. */
  padding: 6px 8px;
}

.homepage-v3 .comparison-table {
  position: relative;
  border-radius: var(--radius-2);
  border: 1px solid var(--color-neutral-200);
  background: var(--color-neutral-0);
}

.homepage-v3 .comparison-table .ht-mob,
.homepage-v3 .comparison-table .ct-mob {
  display: none;
}

.homepage-v3 .comparison-table .table-row.header {
  border-top-left-radius: calc(var(--radius-2) - 1px);
  border-top-right-radius: calc(var(--radius-2) - 1px);
}

.homepage-v3 .comparison-table .table-row:last-child {
  border-bottom-left-radius: calc(var(--radius-2) - 1px);
  border-bottom-right-radius: calc(var(--radius-2) - 1px);
}

@property --gladia-border-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

@property --gladia-draw {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

.homepage-v3 .comparison-gladia-focus::before {
  content: "";
  position: absolute;
  top: -6px;
  bottom: -6px;
  left: calc(8px + 24px + (1.6 / 6.6) * (100% - 64px) - 6px);
  width: calc((1 / 6.6) * (100% - 64px) + 12px);
  padding: 1px; /* thickness of the animated border — uniform on all sides */
  border-radius: 14px;
  /* Conic gradient starting at the top-left corner, clockwise. Color stops
     are compressed into the 0°→--gladia-draw arc so the border is visually
     "drawn" as --gladia-draw grows from 0 to 360deg. Beyond --gladia-draw
     the gradient is transparent, so the ring is hidden past the drawn arc.
     When --gladia-draw reaches 360deg, the transparent stop width collapses
     to zero and the full blue→purple→blue ring is visible, with
     --gladia-border-angle rotating the `from` angle for the shimmer loop. */
  background: conic-gradient(
    from calc(315deg + var(--gladia-border-angle)),
    rgba(59, 130, 246, 0.55) 0deg,
    rgba(99, 102, 241, 0.55) calc(var(--gladia-draw) * 0.25),
    rgba(168, 85, 247, 0.55) calc(var(--gladia-draw) * 0.5),
    rgba(99, 102, 241, 0.55) calc(var(--gladia-draw) * 0.75),
    rgba(59, 130, 246, 0.55) var(--gladia-draw),
    transparent var(--gladia-draw) 360deg
  );
  /* Mask-composite trick: keep only the 1.5px padding ring visible so the
     gradient shows as a border while the interior stays fully transparent. */
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
  opacity: 1;
  visibility: visible;
  animation: gladia-col-border 5s linear infinite;
}

.homepage-v3 .comparison-section.reveal.is-visible .comparison-gladia-focus::before {
  animation:
    gladia-col-border 5s linear infinite,
    gladia-col-draw 0.85s cubic-bezier(0.4, 0, 0.2, 1) 0.45s forwards;
}

@keyframes gladia-col-border {
  to { --gladia-border-angle: 360deg; }
}

@keyframes gladia-col-draw {
  from { --gladia-draw: 0deg; }
  to   { --gladia-draw: 360deg; }
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .comparison-gladia-focus::before {
    opacity: 1;
    visibility: visible;
    animation: none;
    --gladia-draw: 360deg;
  }
  .homepage-v3 .comparison-section.reveal.is-visible .comparison-gladia-focus::before {
    opacity: 1;
    visibility: visible;
    animation: none;
    --gladia-draw: 360deg;
  }
}

.homepage-v3 .comparison-table .table-row {
  position: relative;
  z-index: 1;
}

.homepage-v3 .table-row {
  display: flex;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-neutral-100);
}

.homepage-v3 .table-row:last-child { border-bottom: none; }

.homepage-v3 .table-row.header {
  background: var(--color-neutral-50);
  border-bottom-color: var(--color-neutral-200);
}

.homepage-v3 .comparison-m-vendors {
  display: flex;
  flex: 5 1 0%;
  min-width: 0;
  align-items: stretch;
  box-sizing: border-box;
}

.homepage-v3 .comparison-m-others {
  display: contents;
}

.homepage-v3 .comparison-m-vendors .table-cell {
  flex: 1 1 0%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.homepage-v3 .table-cell {
  flex: 1;
  display: flex;
  align-items: center;
}

.homepage-v3 .table-row > .table-cell.feature-col { flex: 1.6 1 0%; }

.homepage-v3 .table-cell:not(:first-child) { justify-content: center; }

.homepage-v3 .header-text {
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-500);
}

.homepage-v3 .header-text.accent { color: var(--color-purple-400); }

.homepage-v3 .feature-name {
  font-size: var(--hp-text-compact);
  color: var(--color-neutral-700);
}

.homepage-v3 .table-icon { width: 20px; height: 20px; flex-shrink: 0; }

.homepage-v3 .icon-check { filter: invert(48%) sepia(79%) saturate(500%) hue-rotate(86deg) brightness(95%); }

.homepage-v3 .icon-check-gray { opacity: 0.55; filter: invert(48%) sepia(79%) saturate(500%) hue-rotate(86deg) brightness(95%); }

.homepage-v3 .icon-partial { opacity: 0.55; filter: invert(70%) sepia(50%) saturate(600%) hue-rotate(5deg) brightness(100%); }

.homepage-v3 .icon-x { opacity: 0.7; filter: invert(25%) sepia(90%) saturate(2000%) hue-rotate(345deg) brightness(85%); }

.homepage-v3 .cell-icon {
  width: 18px;
  height: 18px;
  display: inline-block;
  vertical-align: middle;
}

.homepage-v3 .cell-icon-check { color: var(--color-neutral-500, #8a8f98); }

.homepage-v3 .cell-icon-x { color: var(--color-neutral-400, #a3a8b0); opacity: 0.6; }

.homepage-v3 .table-row .comparison-m-vendors > .table-cell:nth-child(1) .cell-icon-check {
  color: var(--color-purple-400);
}

.homepage-v3 .ct-ico-ds {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  background-color: currentColor;
  -webkit-mask: var(--ct-ico-ds-url) center / contain no-repeat;
  mask: var(--ct-ico-ds-url) center / contain no-repeat;
}

.homepage-v3 .ct-mob .ct-ico.ct-ico-ds,
.homepage-v3 .ct-val-duo .ct-ico-ds {
  width: 20px;
  height: 20px;
}

.homepage-v3 .ct-ico-ds--check { --ct-ico-ds-url: url("/icons/Interface%20General/IconCheckmark2.svg"); }

.homepage-v3 .ct-ico-ds--x { --ct-ico-ds-url: url("/icons/Interface%20General/IconCrossMedium.svg"); }

.homepage-v3 .ct-ico-ds--partial { --ct-ico-ds-url: url("/icons/Interface%20General/IconCircleMinus.svg"); }

.homepage-v3 .ct-ico-ds--warn { --ct-ico-ds-url: url("/icons/Interface%20General/IconExclamationTriangle.svg"); }

.homepage-v3 .ct-ico-ds--card { --ct-ico-ds-url: url("/icons/Shopping%20%26%20Payment/IconCreditCard1.svg"); }

.homepage-v3 .ct-ico-ds--money { --ct-ico-ds-url: url("/icons/Crypto/IconCoinStack.svg"); }

.homepage-v3 .ct-ico-ds--globe { --ct-ico-ds-url: url("/icons/Location/IconGlobe.svg"); }

.homepage-v3 .ct-ico-ds--shield { --ct-ico-ds-url: url("/icons/Security/IconShieldCheck3.svg"); }

.homepage-v3 .ct-ico-ds--id { --ct-ico-ds-url: url("/icons/Security/IconPassport.svg"); }

.homepage-v3 .ct-ico-ds--default { --ct-ico-ds-url: url("/icons/Interface%20General/IconCheckCircle2.svg"); }

.homepage-v3 .ct-ico-ds--lock { --ct-ico-ds-url: url("/icons/Security/IconLock.svg"); }

.homepage-v3 .ct-ico-ds--unclear { --ct-ico-ds-url: url("/icons/Interface%20General/IconCircleQuestionmark.svg"); }

.homepage-v3 .ct-ico-ds--check-muted {
  --ct-ico-ds-url: url("/icons/Interface%20General/IconLoadingCircle.svg");
  width: 13px !important;
  height: 13px !important;
  color: var(--color-neutral-400);
}

.homepage-v3 .table-cell { font-size: var(--hp-text-compact); color: var(--color-neutral-400); text-align: center; }

.homepage-v3 .table-cell.feature-col { text-align: left; color: var(--color-neutral-700); }

.homepage-v3 .table-cell.val-no,
.homepage-v3 .table-cell.val-empty,
.homepage-v3 .table-cell.val-partial { color: var(--color-neutral-400); }

.homepage-v3 .cell-sm { font-size: var(--hp-text-ui); line-height: 1.4; }

.homepage-v3 .table-row .comparison-m-vendors > .table-cell:nth-child(1) {
  color: var(--color-purple-400);
}

.homepage-v3 .table-row .comparison-m-vendors > .table-cell:nth-child(1).val-no {
  color: var(--color-neutral-400);
}

.homepage-v3 .table-row.header .comparison-m-vendors > .table-cell:nth-child(1) .header-text.accent {
  font-weight: var(--font-weight-semibold);
}

.homepage-v3 .comparison-benchmark-cta {
  display: flex;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
  margin-top: var(--space-1);
  /* Align CTA track with table content start/end. */
  padding-inline: calc(8px + 24px + 1px);
}

.homepage-v3 .comparison-benchmark-cta__form {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  justify-content: center;
  margin: 0;
}

.homepage-v3 .comparison-benchmark-cta::before {
  content: "";
  flex: 1.6 1 0;
}

.homepage-v3 .comparison-benchmark-cta::after {
  content: "";
  flex: 4 1 0;
}

.homepage-v3 .comparison-benchmark-btn {
  width: 100%;
  max-width: 160px;
  height: 34px;
  padding: 0 var(--space-3);
  font-size: var(--hp-text-ui);
  line-height: 1;
  background: var(--color-purple-400);
  color: var(--color-neutral-0);
  border: 1px solid var(--color-purple-400);
  align-self: center;
  transition: transform 0.25s var(--ease-spring),
    box-shadow 0.25s var(--ease-out),
    background-color 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    opacity 0.2s var(--ease-out);
}

.homepage-v3 .comparison-benchmark-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px -10px rgba(148, 122, 252, 0.55);
  opacity: 0.95;
}

.homepage-v3 .comparison-benchmark-btn:focus-visible {
  outline: 2px solid var(--color-purple-300);
  outline-offset: 3px;
}

.homepage-v3 .comparison-table-container .comparison-benchmark-cta {
  display: none;
}

.homepage-v3 .comparison-table-container.is-expanded .comparison-benchmark-cta {
  display: flex;
}

.homepage-v3 .comparison-table-container { width: 100%; }

.homepage-v3 .comparison-table-clip {
  position: relative;
  max-height: 400px; /* 412 − 6px*2: vertical padding now on .comparison-gladia-focus */
  padding: 0;
  overflow: hidden;
  transition: max-height 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.homepage-v3 .comparison-table-container.is-expanded .comparison-table-clip {
  max-height: 1500px; /* was 1512: −12 (clip vertical padding now on .comparison-gladia-focus) */
}

.homepage-v3 .comparison-table-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100px;
  background: linear-gradient(to bottom, transparent, var(--color-neutral-0));
  pointer-events: none;
  transition: opacity 0.4s ease;
  z-index: 1;
}

.homepage-v3 .comparison-table-container.is-expanded .comparison-table-fade {
  opacity: 0;
}

.homepage-v3 .comparison-expand-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--space-4) 0 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-neutral-400);
  transition: color 0.2s ease;
}

.homepage-v3 .comparison-expand-btn:hover { color: var(--color-neutral-600); }

.homepage-v3 .comparison-expand-btn svg {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.homepage-v3 .comparison-table-container.is-expanded .comparison-expand-btn svg {
  transform: rotate(180deg);
}

.homepage-v3 .cta-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-6) max(var(--space-10), calc((100% - var(--max-w-container)) / 2));
  min-height: 148px;
  background: var(--color-neutral-0);
  border-top: 1px solid var(--color-neutral-200);
}

.homepage-v3 .cta-strip-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.homepage-v3 .cta-strip-title {
  font-size: var(--hp-text-body);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-relaxed);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-neutral-500);
}

.homepage-v3 .cta-strip-sub {
  font-size: var(--hp-prose);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-relaxed);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-neutral-1000);
}

.homepage-v3 .cta-strip-buttons { display: flex; gap: var(--space-4); }

.homepage-v3 .cta-strip-btn-accent {
  background: var(--color-purple-400);
  color: var(--color-neutral-0);
}

.homepage-v3 .cta-strip-btn-accent:hover { opacity: 0.9; }

.homepage-v3 .cta-strip-btn-outline {
  background: var(--color-neutral-0);
  color: var(--color-neutral-700);
  border-color: var(--color-neutral-200);
}

.homepage-v3 .integrations-section {
  background: var(--bg-primary);
  padding: var(--space-24) max(var(--hp-gutter-x), var(--space-6)) 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
  overflow: hidden;
}

.homepage-v3 .integrations-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  text-align: center;
  position: relative;
  z-index: 2;
  width: 780px;
  max-width: 100%;
}

.homepage-v3 .integrations-heading {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  text-align: center;
  color: var(--text-primary);
  max-width: 700px;
}

.homepage-v3 .integrations-sub {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  text-align: center;
  color: var(--text-secondary);
  max-width: 560px;
}

.homepage-v3 .orbits-viewport {
  position: relative;
  width: 100%;
  max-width: 1200px;
  aspect-ratio: 1 / 1;
  max-height: 680px;
}

.homepage-v3 .orbits-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 700px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(148,122,252,0.10) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.homepage-v3 .orbits-arcs {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: visible;
}

.homepage-v3 .orbits-arcs circle {
  fill: none;
  stroke: rgba(255,255,255,0.12);
  stroke-width: 1;
  stroke-dasharray: 6 8;
  stroke-dasharray: 6 8;
  opacity: 0;
  transition: opacity 0.8s var(--ease-out);
}

.homepage-v3 .integrations-section.is-visible .orbits-arcs circle { opacity: 1; }

.homepage-v3 .orbits-arcs circle:nth-child(1) { transition-delay: 0.1s; }

.homepage-v3 .orbits-arcs circle:nth-child(2) { transition-delay: 0.2s; }

.homepage-v3 .orbits-arcs circle:nth-child(3) { transition-delay: 0.3s; }

.homepage-v3 .orbits-arcs circle:nth-child(4) { transition-delay: 0.4s; }

.homepage-v3 .orbits-arcs circle:nth-child(5) { transition-delay: 0.5s; }

.homepage-v3 .orbits-arcs circle:nth-child(6) { transition-delay: 0.6s; }

.homepage-v3 .orbits-arcs circle:nth-child(7) { transition-delay: 0.7s; }

.homepage-v3 .orbits-nodes {
  position: absolute;
  inset: 0;
  z-index: 3;
}

.homepage-v3 .int-node {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: default;
  opacity: 0;
}

.homepage-v3 .integrations-section.is-visible .int-node {
  animation-name: int-enter, int-float;
  animation-duration: 0.6s, calc(3s + var(--i, 0) * 100ms);
  animation-timing-function: var(--ease-spring), var(--ease-in-out);
  animation-delay: calc(var(--i, 0) * 40ms + 200ms), calc(var(--i, 0) * 40ms + 900ms);
  animation-iteration-count: 1, infinite;
  animation-fill-mode: forwards, none;
}

@keyframes int-enter {
  from { opacity: 0; transform: scale(0.5) translateY(20px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes int-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(var(--float-y, -6px)); }
}

.homepage-v3 .int-node-dot {
  width: var(--dot-size, 48px);
  height: var(--dot-size, 48px);
  border-radius: 50%;
  background: #0a0a0f;
  border: 1px solid rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
  transition: transform var(--duration-240) var(--ease-spring),
              box-shadow var(--duration-240) var(--ease-out);
}

.homepage-v3 .int-node-dot svg {
  width: 55%;
  height: 55%;
}

.homepage-v3 .int-node-letter {
  font-size: var(--hp-text-lead);
  font-weight: var(--font-weight-medium);
  color: white;
  line-height: 1;
}

.homepage-v3 .int-node:hover .int-node-dot {
  transform: scale(1.15);
  border-color: rgba(255,255,255,0.25);
  box-shadow: 0 4px 20px rgba(0,0,0,0.6), 0 0 24px rgba(148,122,252,0.15);
}

.homepage-v3 .int-tooltip {
  position: absolute;
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  padding: 4px 10px;
  border-radius: var(--radius-1);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  font-size: var(--hp-text-ui);
  color: var(--text-primary);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-160) var(--ease-out),
              transform var(--duration-160) var(--ease-out);
}

.homepage-v3 .integrations-section.is-visible .int-tooltip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  transition-delay: calc(var(--i, 0) * 40ms + 600ms);
}

.homepage-v3 .int-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--bg-tertiary);
}

.homepage-v3 .orbits-center-node {
  position: absolute;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  box-shadow: none;
  border: 1.5px solid rgba(255,255,255,0.2);
  opacity: 0;
  transition: opacity 0.6s var(--ease-out) 0.1s;
}

.homepage-v3 .integrations-section.is-visible .orbits-center-node { opacity: 1; }

.homepage-v3 .testimonials-section {
  /* Transparent so the page-level starfield (anchored to the body)
     shows through from here down to the bottom of the document. */
  background: transparent;
  padding: var(--space-24) 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
  position: relative;
  isolation: isolate;
  /* NOTE: no `overflow: hidden` here — `.testimonials-bg` below is stretched
     to full viewport width and clips its own contents, so the section no
     longer needs to clip. Dropping this lets the background (including the
     cursor halo) escape the page-wrapper's max-width constraint. */
}

.homepage-v3 .testimonials-bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 50vw);
  width: 100vw;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.homepage-v3 .testimonials-dome {
  position: absolute;
  left: 50%;
  top: -8%;
  width: min(1600px, 150%);
  aspect-ratio: 2 / 1;
  transform: translateX(-50%);
  transform-origin: center top;
  pointer-events: none;
  /* half-disc: flat edge at top, rounded edge at bottom (descending dome) */
  border-radius: 0 0 50% 50% / 0 0 100% 100%;
}

.homepage-v3 .testimonials-dome-violet {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 60% 70% at 50% 0%,
    rgba(168, 132, 255, 0.72) 0%,
    rgba(138, 96, 240, 0.50) 20%,
    rgba(108, 62, 215, 0.30) 40%,
    rgba(78, 38, 170, 0.14) 60%,
    transparent 80%);
  filter: blur(42px);
  animation: testiDomeVioletDrift 22s ease-in-out infinite;
}

.homepage-v3 .testimonials-dome-core {
  position: absolute;
  inset: 10% 10% 15% 10%;
  border-radius: inherit;
  background: radial-gradient(ellipse 55% 60% at 50% 45%,
    rgba(6, 5, 12, 0.92) 0%,
    rgba(8, 6, 18, 0.70) 30%,
    rgba(10, 8, 24, 0.35) 55%,
    transparent 80%);
  filter: blur(80px);
  animation: testiDomeCoreDrift 26s ease-in-out infinite;
}

.homepage-v3 .testimonials-dome-rose {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse 70% 40% at 50% 100%,
    rgba(210, 100, 175, 0.28) 0%,
    rgba(180, 80, 160, 0.16) 28%,
    rgba(150, 70, 150, 0.08) 50%,
    transparent 75%);
  filter: blur(60px);
  mix-blend-mode: screen;
  animation: testiDomeRoseDrift 30s ease-in-out infinite;
}

.homepage-v3 .testimonials-bg--paused .testimonials-dome-violet,
.homepage-v3 .testimonials-bg--paused .testimonials-dome-core,
.homepage-v3 .testimonials-bg--paused .testimonials-dome-rose,
.homepage-v3 .testimonials-bg--paused .testimonials-orb {
  animation-play-state: paused;
}

@keyframes testiDomeVioletDrift {
  0%   { transform: translate3d(-6%, 0, 0)  scale(1);    opacity: 0.92; }
  25%  { transform: translate3d( 4%, 2%, 0) scale(1.05); opacity: 1;    }
  50%  { transform: translate3d( 8%, -1%, 0) scale(0.98); opacity: 0.95; }
  75%  { transform: translate3d(-3%, 3%, 0) scale(1.03); opacity: 1;    }
  100% { transform: translate3d(-6%, 0, 0)  scale(1);    opacity: 0.92; }
}

@keyframes testiDomeCoreDrift {
  0%   { transform: translate3d( 5%, 1%, 0)  scale(1);    opacity: 1;   }
  33%  { transform: translate3d(-4%, -2%, 0) scale(0.93); opacity: 0.88; }
  66%  { transform: translate3d(-6%, 3%, 0)  scale(1.04); opacity: 0.95; }
  100% { transform: translate3d( 5%, 1%, 0)  scale(1);    opacity: 1;   }
}

@keyframes testiDomeRoseDrift {
  0%   { transform: translate3d(-8%, 0, 0)   scale(1);    opacity: 0.9; }
  40%  { transform: translate3d( 10%, -3%, 0) scale(1.08); opacity: 1;   }
  75%  { transform: translate3d( 6%, 4%, 0)  scale(0.95); opacity: 0.85; }
  100% { transform: translate3d(-8%, 0, 0)   scale(1);    opacity: 0.9; }
}

.homepage-v3 .testimonials-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(110px);
  opacity: 0.55;
}

.homepage-v3 .testimonials-orb--violet {
  width: 48vw;
  height: 48vw;
  max-width: 720px;
  max-height: 720px;
  background: radial-gradient(circle at 50% 50%,
    rgba(168, 132, 255, 0.55) 0%,
    rgba(138, 96, 240, 0.3) 35%,
    transparent 70%);
  top: 18%;
  left: -12%;
  animation: testiOrbViolet 34s ease-in-out infinite;
}

.homepage-v3 .testimonials-orb--magenta {
  width: 42vw;
  height: 42vw;
  max-width: 640px;
  max-height: 640px;
  background: radial-gradient(circle at 50% 50%,
    rgba(210, 110, 195, 0.32) 0%,
    rgba(175, 85, 180, 0.18) 40%,
    transparent 72%);
  top: 42%;
  right: -10%;
  opacity: 0.45;
  animation: testiOrbMagenta 40s ease-in-out infinite;
}

.homepage-v3 .testimonials-orb--pink {
  width: 36vw;
  height: 36vw;
  max-width: 540px;
  max-height: 540px;
  background: radial-gradient(circle at 50% 50%,
    rgba(214, 148, 255, 0.38) 0%,
    rgba(168, 100, 230, 0.22) 40%,
    transparent 72%);
  bottom: 6%;
  left: 32%;
  opacity: 0.45;
  animation: testiOrbPink 46s ease-in-out infinite;
}

@keyframes testiOrbViolet {
  0%   { transform: translate3d(0, 0, 0)       scale(1);    }
  30%  { transform: translate3d(32vw, 8vh, 0)  scale(1.1);  }
  55%  { transform: translate3d(48vw, -6vh, 0) scale(0.95); }
  80%  { transform: translate3d(18vw, 12vh, 0) scale(1.05); }
  100% { transform: translate3d(0, 0, 0)       scale(1);    }
}

@keyframes testiOrbMagenta {
  0%   { transform: translate3d(0, 0, 0)         scale(1);    }
  25%  { transform: translate3d(-28vw, -10vh, 0) scale(1.08); }
  55%  { transform: translate3d(-48vw, 6vh, 0)   scale(0.92); }
  80%  { transform: translate3d(-20vw, -4vh, 0)  scale(1.04); }
  100% { transform: translate3d(0, 0, 0)         scale(1);    }
}

@keyframes testiOrbPink {
  0%   { transform: translate3d(0, 0, 0)        scale(1);    }
  33%  { transform: translate3d(-20vw, -14vh, 0) scale(1.12); }
  66%  { transform: translate3d(22vw, -8vh, 0)  scale(0.9);  }
  100% { transform: translate3d(0, 0, 0)        scale(1);    }
}

.homepage-v3 .testimonials-section > *:not(.testimonials-bg) {
  position: relative;
  z-index: 1;
}

.homepage-v3 .testimonials-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  text-align: center;
  max-width: 1200px;
}

.homepage-v3 .testimonials-heading {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
}

.homepage-v3 .testimonials-sub {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
}

.homepage-v3 .testimonials-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-template-rows: auto auto auto auto;
  grid-template-areas:
    "a a b b"
    "a a c d"
    "e e h h"
    "f g h h";
  gap: var(--space-4);
  width: 100%;
  max-width: var(--max-w-container);
  position: relative;
  isolation: isolate;
}

.homepage-v3 .testimonials-cursor-halo {
  position: absolute;
  top: 0;
  left: 0;
  width: 900px;
  height: 900px;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transform: translate3d(-50%, -50%, 0);
  background: radial-gradient(circle at 50% 50%,
    var(--halo-color, rgba(168, 132, 255, 0.22)) 0%,
    var(--halo-color-mid, rgba(168, 132, 255, 0.10)) 30%,
    transparent 70%);
  filter: blur(160px);
  transition:
    opacity 0.6s ease,
    background 0.8s ease;
  will-change: transform, opacity;
}

.homepage-v3 .testimonials-section.is-halo-active .testimonials-cursor-halo {
  opacity: 1;
}

.homepage-v3 .testimonials-section[data-halo="magenta"] {
  --halo-color: rgba(220, 120, 200, 0.24);
  --halo-color-mid: rgba(200, 100, 185, 0.1);
}

.homepage-v3 .testimonials-section[data-halo="rose"] {
  --halo-color: rgba(255, 140, 195, 0.24);
  --halo-color-mid: rgba(240, 120, 200, 0.1);
}

.homepage-v3 .testimonials-section[data-halo="violet"],
.homepage-v3 .testimonials-section:not([data-halo]) {
  --halo-color: rgba(180, 148, 255, 0.26);
  --halo-color-mid: rgba(180, 148, 255, 0.11);
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .testimonials-cursor-halo { display: none; }
}

.homepage-v3 .testimonial-card {
  position: relative;
  padding: var(--space-8);
  border-radius: var(--radius-3);
  background:
    linear-gradient(180deg,
      rgba(255, 255, 255, 0.045) 0%,
      rgba(255, 255, 255, 0.018) 55%,
      rgba(255, 255, 255, 0.028) 100%);
  backdrop-filter: blur(8px) saturate(180%);
  -webkit-backdrop-filter: blur(8px) saturate(180%);
  border: none;
  box-shadow:
    /* inner specular rim — bright hairline on top, darker on bottom */
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 -1px 0 rgba(0, 0, 0, 0.25),
    /* outer depth — soft, no hard edge */
    0 1px 1px rgba(0, 0, 0, 0.12),
    0 12px 32px -18px rgba(0, 0, 0, 0.55);
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--space-6);
  text-align: left;
  isolation: isolate;
  overflow: hidden;
  --card-glow: rgba(168, 132, 255, 0.18);
  --card-glow-secondary: rgba(168, 132, 255, 0.06);
  --mx: 50%;
  --my: 50%;
  transform: translateY(0);
  transition:
    transform var(--duration-320) var(--ease-out),
    box-shadow var(--duration-320) var(--ease-out),
    background var(--duration-320) var(--ease-out);
  will-change: transform;
}

.homepage-v3 .testimonial-card:hover,
.homepage-v3 .testimonial-card:focus-visible {
  transform: translateY(-4px);
  background:
    linear-gradient(180deg,
      rgba(255, 255, 255, 0.075) 0%,
      rgba(255, 255, 255, 0.03) 55%,
      rgba(255, 255, 255, 0.05) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.26),
    inset 0 0 0 1px rgba(255, 255, 255, 0.06),
    inset 0 -1px 0 rgba(0, 0, 0, 0.3),
    0 1px 1px rgba(0, 0, 0, 0.15),
    0 22px 44px -20px rgba(0, 0, 0, 0.65),
    0 10px 26px -14px var(--card-glow);
}

.homepage-v3 .testimonial-card:focus-visible {
  outline: 2px solid var(--color-purple-400, rgba(148, 122, 252, 0.85));
  outline-offset: 3px;
}

.homepage-v3 .testimonial-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(135deg,
      rgba(255, 255, 255, 0.08) 0%,
      rgba(255, 255, 255, 0.02) 22%,
      transparent 45%);
  pointer-events: none;
  z-index: 0;
  opacity: 0.6;
  transition: opacity 0.45s ease;
}

.homepage-v3 .testimonial-card:hover::after,
.homepage-v3 .testimonial-card:focus-visible::after {
  opacity: 1;
}

.homepage-v3 .testimonial-card.photo-card::after {
  display: none;
}

.homepage-v3 .testimonial-card.featured .testimonial-quote::before,
.homepage-v3 .testimonial-card.wide .testimonial-quote::before {
  content: none;
  position: absolute;
  top: -14px;
  left: -8px;
  font-family: var(--font-display, Georgia, serif);
  font-size: 140px;
  line-height: 1;
  font-weight: 400;
  color: rgba(148, 122, 252, 0.10);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  transition: color 0.5s ease, transform 0.5s var(--ease-out);
}

.homepage-v3 .testimonial-card.featured:hover .testimonial-quote::before,
.homepage-v3 .testimonial-card.wide:hover .testimonial-quote::before {
  color: rgba(148, 122, 252, 0.18);
  transform: translateY(-2px);
}

.homepage-v3 .testimonial-card[style*="grid-area:b"] .testimonial-quote::before,
.homepage-v3 .testimonial-card[style*="grid-area:e"] .testimonial-quote::before {
  color: rgba(130, 190, 255, 0.10);
}

.homepage-v3 .testimonial-card[style*="grid-area:b"]:hover .testimonial-quote::before,
.homepage-v3 .testimonial-card[style*="grid-area:e"]:hover .testimonial-quote::before {
  color: rgba(130, 190, 255, 0.18);
}

.homepage-v3 .testimonial-quote {
  position: relative;
  z-index: 1;
}

.homepage-v3 .testimonial-card[style*="grid-area:b"],
.homepage-v3 .testimonial-card[style*="grid-area:e"] {
  --card-glow: rgba(0, 120, 210, 0.14);
  --card-glow-secondary: rgba(148, 122, 252, 0.06);
}

.homepage-v3 .testimonial-card[style*="grid-area:d"],
.homepage-v3 .testimonial-card[style*="grid-area:g"] {
  --card-glow: rgba(80, 180, 200, 0.12);
  --card-glow-secondary: rgba(0, 84, 153, 0.06);
}

@property --border-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

@keyframes borderRotate {
  0%   { --border-angle: 0deg; }
  100% { --border-angle: 360deg; }
}

.homepage-v3 .testimonial-card.featured {
  padding: var(--space-10);
  grid-template-rows: auto 1fr auto;
  --card-glow: rgba(168, 132, 255, 0.22);
  --card-glow-secondary: rgba(108, 62, 215, 0.10);
  background:
    linear-gradient(180deg,
      rgba(168, 132, 255, 0.06) 0%,
      rgba(168, 132, 255, 0.015) 55%,
      rgba(168, 132, 255, 0.035) 100%);
}

.homepage-v3 .testimonial-card.featured:hover,
.homepage-v3 .testimonial-card.featured:focus-visible {
  background:
    linear-gradient(180deg,
      rgba(168, 132, 255, 0.10) 0%,
      rgba(168, 132, 255, 0.03) 55%,
      rgba(168, 132, 255, 0.06) 100%);
}

.homepage-v3 .testimonial-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.homepage-v3 .testimonial-company {
  display: flex;
  align-items: center;
  height: 22px;
}

.homepage-v3 .testimonial-company img {
  height: 100%;
  max-width: 110px;
  width: auto;
  object-fit: contain;
}

.homepage-v3 .testimonial-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 4px 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.02);
  white-space: nowrap;
  transition: border-color 0.3s ease, background-color 0.3s ease;
}

.homepage-v3 .testimonial-card:hover .testimonial-badge {
  background: rgba(148, 122, 252, 0.06);
}

.homepage-v3 .testimonial-card.featured .testimonial-badge {
  border-color: rgba(148, 122, 252, 0.3);
  color: rgba(186, 173, 255, 0.8);
}

.homepage-v3 .testimonial-card[style*="grid-area:b"] .testimonial-badge,
.homepage-v3 .testimonial-card[style*="grid-area:e"] .testimonial-badge {
  border-color: rgba(0, 120, 210, 0.25);
  color: rgba(130, 190, 255, 0.8);
}

.homepage-v3 .testimonial-card[style*="grid-area:d"] .testimonial-badge,
.homepage-v3 .testimonial-card[style*="grid-area:g"] .testimonial-badge {
  border-color: rgba(80, 180, 200, 0.25);
  color: rgba(140, 220, 230, 0.8);
}

.homepage-v3 .testimonial-card.photo-card {
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo {
  position: relative;
  width: 100%;
  flex: 1;
  min-height: 200px;
  overflow: hidden;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(1) brightness(0.85);
  transition: transform 0.6s var(--ease-out), filter 0.5s ease;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 42%;
  background: linear-gradient(to bottom,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(0, 0, 0, 0.25) 45%,
    transparent 100%);
  pointer-events: none;
  z-index: 1;
}

.homepage-v3 .testimonial-card.photo-card:hover .testimonial-photo img,
.homepage-v3 .testimonial-card.photo-card:focus-visible .testimonial-photo img {
  transform: scale(1.06);
  filter: grayscale(0.2) brightness(0.95);
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 60%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-6);
  pointer-events: none;
}

.homepage-v3 .testimonial-photo-logo {
  position: absolute;
  top: var(--space-5);
  left: var(--space-5);
  z-index: 2;
  height: 32px;
  display: flex;
  align-items: center;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.5));
}

.homepage-v3 .testimonial-photo-logo img {
  height: 100%;
  max-width: 150px;
  width: auto;
  object-fit: contain;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo-name {
  font-size: var(--hp-text-body);
  font-weight: var(--font-weight-medium);
  color: #fff;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo-role {
  font-size: var(--hp-text-ui);
  color: rgba(255,255,255,0.6);
  margin-top: 2px;
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo::before {
  height: 32%;
  background: linear-gradient(to bottom,
    rgba(0, 0, 0, 0.6) 0%,
    rgba(0, 0, 0, 0.3) 50%,
    transparent 100%);
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo-logo {
  top: var(--space-7);
  left: var(--space-7);
  height: 44px;
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo-logo img {
  max-width: 200px;
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo-overlay {
  padding: var(--space-10);
  background: linear-gradient(to top,
    rgba(0, 0, 0, 0.88) 0%,
    rgba(0, 0, 0, 0.55) 30%,
    rgba(0, 0, 0, 0.15) 55%,
    transparent 78%);
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo-name {
  font-size: var(--font-size-24);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--letter-spacing-tight);
  line-height: var(--line-height-tight);
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo-role {
  font-size: var(--hp-text-compact);
  color: rgba(255, 255, 255, 0.72);
  margin-top: 6px;
}

.homepage-v3 .testimonial-card.photo-card--hero .testimonial-photo img {
  object-position: center 30%;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote {
  position: absolute;
  inset: 0;
  background: rgba(10, 10, 12, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-8);
  opacity: 0;
  transform: translateY(12px);
  transition:
    opacity var(--duration-320) var(--ease-out),
    transform var(--duration-320) var(--ease-out);
  pointer-events: none;
}

.homepage-v3 .testimonial-card.photo-card:hover .testimonial-hover-quote,
.homepage-v3 .testimonial-card.photo-card:focus-visible .testimonial-hover-quote {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 768px) {
  .homepage-v3 .testimonial-card.photo-card .testimonial-photo-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.6) 35%, transparent 70%);
  }
  .homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote {
    position: absolute;
    inset: auto 0 0 0;
    height: auto;
    background: linear-gradient(to top, rgba(10,10,12,0.96) 60%, rgba(10,10,12,0) 100%);
    backdrop-filter: none;
    padding: var(--space-10) var(--space-6) var(--space-6);
    opacity: 1;
    transform: none;
  }
  .homepage-v3 .testimonial-card.photo-card .testimonial-photo-overlay {
    display: none;
  }
  .homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote p {
    font-size: var(--hp-prose);
  }
}

.homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote p {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--text-primary);
  margin: 0;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote .testimonial-badge {
  margin-top: var(--space-4);
  align-self: flex-start;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-neutral-900) 0%, var(--color-neutral-800) 100%);
}

.homepage-v3 .testimonial-card.photo-card .testimonial-photo-placeholder img {
  max-height: 36px;
  width: auto;
  filter: grayscale(0) brightness(1);
  object-fit: contain;
}

.homepage-v3 .testimonial-card.photo-card .testimonial-mobile-content {
  display: none;
}

.homepage-v3 .testimonial-quote {
  margin: 0;
}

.homepage-v3 .testimonial-quote p {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: #fff;
  margin: 0;
}

.homepage-v3 .testimonial-quote p span {
  color: rgba(255, 255, 255, 0.95);
  background: linear-gradient(135deg, rgba(255,255,255,1) 40%, rgba(186, 173, 255, 0.9) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.homepage-v3 .testimonial-card.featured .testimonial-quote p {
  font-size: var(--hp-prose);
  font-weight: var(--font-weight-regular);
  color: #fff;
  line-height: var(--line-height-relaxed);
}

.homepage-v3 .testimonial-card.featured .testimonial-quote p span {
  background: linear-gradient(135deg, rgba(255,255,255,1) 30%, rgba(186, 173, 255, 0.85) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.homepage-v3 .testimonial-card.featured[style*="grid-area:a"] .testimonial-quote p,
.homepage-v3 .testimonial-card.featured[style*="grid-area:a"] .testimonial-quote p span {
  color: #fff;
  background: none;
  -webkit-text-fill-color: #fff;
}

.homepage-v3 .testimonial-card.featured[style*="grid-area:a"] .testimonial-badge {
  color: #fff;
  border-color: #fff;
}

.homepage-v3 .testimonial-card.wide .testimonial-quote p {
  font-size: var(--hp-prose);
  font-weight: var(--font-weight-regular);
  color: #fff;
}

.homepage-v3 .testimonial-card[style*="grid-area:b"] .testimonial-quote p span,
.homepage-v3 .testimonial-card[style*="grid-area:e"] .testimonial-quote p span {
  background: linear-gradient(135deg, rgba(255,255,255,1) 40%, rgba(130, 190, 255, 0.85) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.homepage-v3 .testimonial-card[style*="grid-area:d"] .testimonial-quote p span,
.homepage-v3 .testimonial-card[style*="grid-area:g"] .testimonial-quote p span {
  background: linear-gradient(135deg, rgba(255,255,255,1) 40%, rgba(140, 220, 230, 0.85) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.homepage-v3 .testimonial-author {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center;
  gap: var(--space-3);
  position: relative;
  z-index: 1;
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  transition: border-color 0.3s ease;
}

.homepage-v3 .testimonial-card.featured .testimonial-author {
  grid-template-columns: 48px 1fr;
}

.homepage-v3 .testimonial-card:hover .testimonial-author {
  border-top-color: rgba(148, 122, 252, 0.15);
}

.homepage-v3 .testimonial-card[style*="grid-area:b"]:hover .testimonial-author,
.homepage-v3 .testimonial-card[style*="grid-area:e"]:hover .testimonial-author {
  border-top-color: rgba(130, 190, 255, 0.15);
}

.homepage-v3 .testimonial-avatar {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  object-fit: cover;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  color: var(--text-tertiary);
  flex-shrink: 0;
  grid-column: 1;
  grid-row: 1;
  filter: grayscale(1) brightness(0.95);
  transition:
    filter 0.4s ease,
    border-color 0.4s ease,
    opacity 0.3s ease,
    transform 0.4s var(--ease-out);
}

.homepage-v3 .testimonial-meta {
  grid-column: 2;
  grid-row: 1;
  transition: transform 0.4s var(--ease-out);
}

.homepage-v3 .testimonial-card:hover .testimonial-avatar {
  opacity: 0;
  transform: translateX(-12px);
}

.homepage-v3 .testimonial-card:hover .testimonial-meta {
  transform: translateX(calc(-44px - var(--space-3)));
}

.homepage-v3 .testimonial-card.featured:hover .testimonial-meta {
  transform: translateX(calc(-48px - var(--space-3)));
}

.homepage-v3 .testimonial-card:focus-visible .testimonial-avatar {
  filter: grayscale(0) brightness(1);
  border-color: rgba(148, 122, 252, 0.35);
}

.homepage-v3 .testimonial-card.featured .testimonial-avatar {
  width: 48px;
  height: 48px;
  background: rgba(148, 122, 252, 0.08);
  border-color: rgba(148, 122, 252, 0.2);
  color: var(--color-purple-400);
}

.homepage-v3 .testimonial-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  text-align: left;
}

.homepage-v3 .testimonial-name {
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  font-style: normal;
}

.homepage-v3 .testimonial-role {
  font-size: var(--hp-text-ui);
  color: var(--text-tertiary);
}

.homepage-v3 .statement-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.homepage-v3 .statement-section::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -35%;
  width: min(1100px, 95%);
  aspect-ratio: 2 / 1;
  transform: translateX(-50%);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  background:
    radial-gradient(ellipse at 50% 100%,
      rgba(148, 122, 252, 0.55) 0%,
      rgba(146, 91, 255, 0.40) 28%,
      rgba(124, 58, 237, 0.25) 52%,
      rgba(109, 40, 217, 0.10) 75%,
      transparent 100%),
    linear-gradient(to top,
      color-mix(in srgb, var(--color-purple-500) 45%, transparent) 0%,
      color-mix(in srgb, var(--color-purple-400) 30%, transparent) 35%,
      transparent 85%);
  filter: blur(80px);
  pointer-events: none;
  z-index: -1;
}

.homepage-v3 .statement-text {
  position: relative;
  z-index: 1;
}

.homepage-v3 .statement-body {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  font-weight: var(--font-weight-regular);
}

.homepage-v3 .statement-actions {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  justify-content: center;
  margin-top: var(--space-10);
}

.homepage-v3 .testimonials-grid.is-cursor-active {
  cursor: none;
}

.homepage-v3 .testimonials-grid.is-cursor-active .testimonial-card,
.homepage-v3 .testimonials-grid.is-cursor-active .testimonial-card * {
  cursor: none;
}

.testimonials-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 44px;
  height: 44px;
  pointer-events: none;
  z-index: 10000;
  opacity: 0;
  transform: translate3d(-200px, -200px, 0) translate(-50%, -50%) scale(0.7);
  transition: opacity 0.2s ease, scale 0.28s var(--ease-out, cubic-bezier(.22,1,.36,1));
  will-change: transform, opacity;
}

.testimonials-cursor.is-active {
  opacity: 1;
  scale: 1;
}

.testimonials-cursor-avatar {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  overflow: hidden;
  background: var(--color-neutral-900, #0a0a0b);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: var(--font-weight-medium);
  color: #fff;
  letter-spacing: 0.02em;
}

.testimonials-cursor-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.testimonials-cursor-avatar.is-logo {
  background: #fff;
  padding: 8px;
}

.testimonials-cursor-avatar.is-logo img {
  object-fit: contain;
  filter: invert(1);
}

.testimonials-cursor-meta { display: none; }

.testimonials-cursor-heart {
  position: absolute;
  top: -6px;
  right: -10px;
  width: 18px;
  height: 18px;
  color: #ff3e6c;
  filter: drop-shadow(0 2px 6px rgba(255, 62, 108, 0.55));
  transform: scale(0) rotate(-18deg);
  transform-origin: center;
  transition: transform 0.32s var(--ease-out, cubic-bezier(.22,1.4,.36,1));
  pointer-events: none;
}

.testimonials-cursor.is-active .testimonials-cursor-heart {
  transform: scale(1) rotate(0deg);
  transition-delay: 0.08s;
  animation: cursorHeartBeat 1.2s ease-in-out 0.32s infinite;
}

@keyframes cursorHeartBeat {
  0%, 100% { scale: 1; }
  25%      { scale: 1.18; }
  40%      { scale: 1; }
  55%      { scale: 1.12; }
  70%      { scale: 1; }
}

.testimonials-cursor-cta {
  position: absolute;
  top: 0;
  left: calc(100% + 10px);
  height: 44px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 18px 0 20px;
  background: #fff;
  color: #0a0a0c;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  letter-spacing: -0.005em;
  white-space: nowrap;
  box-shadow:
    0 12px 28px -10px rgba(0, 0, 0, 0.6),
    0 2px 6px rgba(0, 0, 0, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  opacity: 0;
  transform: translateX(-14px) scale(0.8);
  transform-origin: left center;
  pointer-events: none;
  transition:
    opacity 0.24s var(--ease-out, cubic-bezier(.22,1,.36,1)),
    transform 0.32s var(--ease-out, cubic-bezier(.22,1.2,.36,1));
  will-change: opacity, transform;
}

.testimonials-cursor.has-cta .testimonials-cursor-cta {
  opacity: 1;
  transform: translateX(0) scale(1);
}

.testimonials-cursor-cta-arrow {
  flex-shrink: 0;
  transition: transform 0.35s var(--ease-out, cubic-bezier(.22,1,.36,1));
}

.testimonials-cursor.has-cta .testimonials-cursor-cta-arrow {
  animation: cursorCtaArrowNudge 2.4s ease-in-out 0.4s infinite;
}

@keyframes cursorCtaArrowNudge {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(3px); }
}

.homepage-v3 .testimonial-card[data-case-study] {
  cursor: pointer;
}

.homepage-v3 .testimonial-card[data-case-study] > * {
  transition:
    filter 0.36s var(--ease-out, cubic-bezier(.22,1,.36,1)),
    opacity 0.32s ease;
  will-change: filter;
}

.homepage-v3 .testimonial-card[data-case-study]:hover > *,
.homepage-v3 .testimonial-card[data-case-study]:focus-within > * {
  filter: blur(6px) brightness(0.5) saturate(0.9);
}

.homepage-v3 .testimonial-card.photo-card[data-case-study]:hover .testimonial-hover-quote,
.homepage-v3 .testimonial-card.photo-card[data-case-study]:focus-within .testimonial-hover-quote {
  opacity: 0;
  transform: translateY(8px);
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .testimonial-card[data-case-study] > * {
    transition: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .testimonials-cursor.is-active .testimonials-cursor-heart {
    animation: none;
  }
  .testimonials-cursor-cta {
    transition: opacity 0.18s ease;
    transform: none;
  }
  .testimonials-cursor.has-cta .testimonials-cursor-cta {
    transform: none;
  }
  .testimonials-cursor.has-cta .testimonials-cursor-cta-arrow {
    animation: none;
  }
}

@media (max-width: 768px) {
  .testimonials-cursor { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .testimonials-cursor { display: none; }
}

@media (max-width: 960px) {
  .homepage-v3 .wg-row { flex-direction: column; height: auto; }
  .homepage-v3 .wg-row--full { height: auto; aspect-ratio: auto; }
  .homepage-v3 .wg-card--sm,
  .homepage-v3 .wg-card--lg,
  .homepage-v3 .wg-card--full { width: 100%; height: auto; min-height: 280px; flex: none; }
  .homepage-v3 .wg-card__logos { position: static; margin-top: var(--space-6); padding: 0 var(--space-9) var(--space-8); }
  .homepage-v3 .wg-card--integrations .wg-card__desc { padding-bottom: 0; }
  .homepage-v3 .orbits-viewport { max-height: 500px; }
  .homepage-v3 .testimonials-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "a a"
      "b b"
      "c d"
      "e e"
      "f g"
      "h h";
  }
}

.homepage-v3.is-video-lightbox-open {
  overflow: hidden;
}

.homepage-v3 .video-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  place-items: center;
  padding: var(--space-6);
}

.homepage-v3 .video-lightbox[aria-hidden="false"] {
  display: grid;
}

.homepage-v3 .video-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.homepage-v3 .video-lightbox__dialog {
  position: relative;
  width: min(825px, 100%);
  margin-top: clamp(20px, 4vh, 48px);
  border-radius: var(--radius-3);
  border: 1px solid var(--border-card);
  background: #050506;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.58);
  overflow: hidden;
  z-index: 1;
}

.homepage-v3 .video-lightbox__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: var(--text-primary);
  background: rgba(0, 0, 0, 0.35);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.homepage-v3 .video-lightbox__frame-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.homepage-v3 .video-lightbox__frame {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .testimonial-card,
  .homepage-v3 .testimonial-card::before,
  .homepage-v3 .testimonial-card::after,
  .homepage-v3 .testimonial-card .testimonial-avatar,
  .homepage-v3 .testimonial-card.photo-card .testimonial-photo img,
  .homepage-v3 .testimonial-card.photo-card .testimonial-hover-quote,
  .homepage-v3 .testimonial-card.featured .testimonial-quote::before,
  .homepage-v3 .testimonial-card.wide .testimonial-quote::before {
    animation: none !important;
    transition: none !important;
  }
  .homepage-v3 .testimonial-card:hover,
  .homepage-v3 .testimonial-card:focus-visible {
    transform: none;
  }
  .homepage-v3 .testimonial-card:hover .testimonial-avatar {
    transform: none;
  }
}

.vbot-scan-frame {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1s ease;
}

.vbot-scan-frame.visible { opacity: 1; }

.vbot-scan-frame.breathe { animation: vbotFrameBreathe 3s ease-in-out infinite; }

.vbot-scan-edge { position: absolute; }

.vbot-scan-edge.top    { inset: 0 0 auto 0; height: 180px; background: linear-gradient(to bottom, rgba(148,122,252,0.3), transparent); }

.vbot-scan-edge.bottom { inset: auto 0 0 0; height: 180px; background: linear-gradient(to top, rgba(148,122,252,0.3), transparent); }

.vbot-scan-edge.left   { inset: 0 auto 0 0; width: 180px; background: linear-gradient(to right, rgba(148,122,252,0.3), transparent); }

.vbot-scan-edge.right  { inset: 0 0 0 auto; width: 180px; background: linear-gradient(to left, rgba(148,122,252,0.3), transparent); }

@keyframes vbotFrameBreathe { 0%, 100% { opacity: 0.75; } 50% { opacity: 1; } }

.vbot-bar {
  position: fixed;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px 6px 6px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-5);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  cursor: pointer;
  z-index: 1000;
  transition: opacity var(--duration-480) var(--ease-out),
              transform var(--duration-480) var(--ease-out),
              border-color var(--duration-240) var(--ease-out),
              box-shadow var(--duration-240) var(--ease-out);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.3), 0 2px 8px rgba(0, 0, 0, 0.15);
  opacity: 0;
  pointer-events: none;
}

.vbot-bar.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  animation: vbotBarFloat 4s ease-in-out infinite;
}

@keyframes vbotBarFloat {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(-4px); }
}

.vbot-bar:hover {
  border-color: rgba(148, 122, 252, 0.3);
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.35), 0 4px 16px rgba(148, 122, 252, 0.1);
  animation-play-state: paused;
  transform: translateX(-50%) translateY(-2px);
}

.vbot-bar-icon {
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

.vbot-bar-icon svg { width: 18px; height: 18px; color: white; }

.vbot-bar-text {
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-regular);
  color: var(--text-secondary);
  white-space: nowrap;
  letter-spacing: -0.01em;
}

.vbot-panel {
  position: fixed;
  bottom: calc(var(--space-8) + 60px);
  left: 50%;
  transform: translateX(-50%) translateY(16px) scale(0.96);
  width: 400px;
  max-height: 520px;
  background: var(--bg-glass);
  border: 1px solid var(--border-transparent-subtle);
  border-radius: var(--radius-3);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-240) var(--ease-out),
              transform var(--duration-240) var(--ease-out),
              visibility var(--duration-240);
  overflow: hidden;
}

.vbot-panel.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0) scale(1);
}

.vbot-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border-transparent-subtle);
}

.vbot-header-title {
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  display: flex; align-items: center; gap: var(--space-2);
}

.vbot-header-logo { width: 20px; height: 20px; color: white; }

.vbot-close {
  background: none; border: none;
  color: var(--text-tertiary);
  cursor: pointer;
  padding: 4px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-1);
  transition: background var(--duration-160) var(--ease-out);
}

.vbot-close:hover { background: var(--bg-glass-light); }

.vbot-messages {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-4) var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-4);
  min-height: 200px;
  max-height: 340px;
}

.vbot-msg {
  max-width: 85%;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-2);
  font-size: var(--hp-text-compact);
  line-height: var(--line-height-relaxed);
  opacity: 0; filter: blur(8px); transform: translateY(20px);
  animation: vbotMsgIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes vbotMsgIn {
  0%   { opacity: 0; filter: blur(8px); transform: translateY(20px); }
  100% { opacity: 1; filter: blur(0px); transform: translateY(0); }
}

.vbot-msg.user {
  align-self: flex-end;
  background: var(--color-purple-400);
  color: white;
  border-bottom-right-radius: 4px;
}

.vbot-msg.bot {
  align-self: flex-start;
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-bottom-left-radius: 4px;
}

.vbot-msg.system {
  align-self: center;
  font-size: var(--hp-text-ui);
  color: var(--text-tertiary);
  background: none;
  padding: 4px 0;
}

.vbot-welcome {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px;
  padding: var(--space-8) var(--space-6);
  text-align: center;
  animation: vbotMsgIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0; filter: blur(8px); transform: translateY(20px);
}

.vbot-welcome-text {
  font-size: var(--hp-text-compact);
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

.vbot-welcome-powered {
  font-size: var(--hp-text-ui);
  color: var(--text-tertiary);
  letter-spacing: var(--letter-spacing-wide);
}

.vbot-welcome-powered a { color: var(--color-purple-400); text-decoration: none; }

.vbot-live {
  padding: 0 var(--space-6) var(--space-2);
  min-height: 0; max-height: 80px; overflow: hidden;
  transition: max-height var(--duration-240) var(--ease-out), padding var(--duration-240) var(--ease-out);
}

.vbot-live:empty { max-height: 0; padding: 0 var(--space-6); }

.vbot-live-text {
  font-size: var(--hp-text-ui);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
  background: var(--bg-tertiary);
  border-radius: var(--radius-1);
  padding: 6px var(--space-2);
  border-left: 2px solid var(--color-purple-400);
}

.vbot-live-text .vbot-live-partial { color: var(--text-tertiary); font-style: italic; }

.vbot-msg.bot b { font-weight: var(--font-weight-medium); }

.vbot-msg.bot a {
  color: var(--color-purple-400);
  text-decoration: none;
  border-bottom: 1px solid rgba(148, 122, 252, 0.3);
  transition: border-color var(--duration-80) var(--ease-out);
}

.vbot-msg.bot a:hover { border-color: var(--color-purple-400); }

.vbot-compare { margin-top: 6px; display: flex; flex-direction: column; gap: 4px; }

.vbot-bar-row { display: flex; align-items: center; gap: 8px; font-size: var(--hp-text-ui); }

.vbot-bar-label { width: 72px; flex-shrink: 0; text-align: right; color: var(--text-secondary); }

.vbot-bar-track { flex: 1; height: 14px; background: rgba(255,255,255,0.06); border-radius: var(--radius-full); overflow: hidden; }

.vbot-bar-fill {
  height: 100%; border-radius: var(--radius-full); background: var(--color-purple-400);
  display: flex; align-items: center; justify-content: flex-end; padding-right: 6px;
  font-size: var(--font-size-10); color: white; font-weight: var(--font-weight-medium);
  transition: width 0.6s var(--ease-out);
}

.vbot-bar-fill.accent { background: var(--color-neutral-500); }

.vbot-stat-row { display: flex; gap: 8px; margin-top: 6px; }

.vbot-stat { flex: 1; background: rgba(255,255,255,0.04); border-radius: var(--radius-1); padding: 6px 8px; text-align: center; }

.vbot-stat-val { font-size: var(--hp-text-body); font-weight: var(--font-weight-medium); color: var(--color-purple-400); }

.vbot-stat-label { font-size: var(--hp-text-ui); color: var(--text-tertiary); margin-top: 2px; }

.vbot-typing { align-self: flex-start; display: flex; gap: 4px; padding: var(--space-2) var(--space-4); }

.vbot-typing span {
  width: 6px; height: 6px; border-radius: var(--radius-full);
  background: var(--text-tertiary); animation: vbotBounce 1.2s infinite;
}

.vbot-typing span:nth-child(2) { animation-delay: 0.15s; }

.vbot-typing span:nth-child(3) { animation-delay: 0.3s; }

@keyframes vbotBounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-6px); opacity: 1; }
}

.vbot-controls {
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--border-transparent-subtle);
  gap: var(--space-4);
  user-select: none;
  -webkit-user-select: none;
}

.vbot-mic {
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  border: 2px solid var(--border-transparent);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--duration-160) var(--ease-out);
}

.vbot-mic:disabled { opacity: 0.35; cursor: not-allowed; }

.vbot-mic:not(:disabled):hover { border-color: var(--color-purple-400); background: rgba(148, 122, 252, 0.15); }

.vbot-mic.recording { border-color: var(--color-red-500); background: rgba(239, 68, 68, 0.15); animation: vbotPulseRec 1.5s infinite; }

.vbot-mic:active { transform: scale(0.92); }

.vbot-mic svg { width: 22px; height: 22px; fill: currentColor; }

.vbot-mic.recording svg { color: var(--color-red-500); }

@keyframes vbotPulseRec {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.3); }
  50% { box-shadow: 0 0 0 10px rgba(239, 68, 68, 0); }
}

.vbot-hint { font-size: var(--hp-text-ui); color: var(--text-tertiary); }

@media (max-width: 480px) {
  .vbot-panel { width: calc(100vw - var(--space-8)); left: 50%; bottom: calc(var(--space-4) + 60px); }
  .vbot-bar-text { display: none; }
  .vbot-bar { padding: 10px 16px; }
}

.homepage-v3 .bento-detail {
  position: fixed;
  inset: 0;
  /* #wf-nav-host: 100100; overlay modals must sit above the fixed bar */
  z-index: 100200;
  display: flex;
  align-items: stretch;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--duration-320) var(--ease-out),
    visibility 0s linear var(--duration-320);
}

.homepage-v3 .bento-detail.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity var(--duration-320) var(--ease-out),
    visibility 0s linear 0s;
}

.homepage-v3 .bento-detail__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 12, 18, 0.42);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.homepage-v3 .bento-detail__panel {
  position: relative;
  z-index: 1;
  align-self: center;
  width: 100%;
  max-width: min(var(--max-w-container), calc(100vw - var(--space-12)));
  max-height: min(94vh, 880px);
  margin: auto 0;
  display: flex;
  flex-direction: column;
  background: var(--color-neutral-0);
  border-radius: var(--radius-3);
  border: 1px solid var(--color-neutral-200);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 24px 64px rgba(0, 0, 0, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.04);
  transform: translateY(14px);
  opacity: 0;
  transition:
    transform var(--duration-480) var(--ease-out),
    opacity var(--duration-320) var(--ease-out);
}

.homepage-v3 .bento-detail.is-open .bento-detail__panel {
  transform: translateY(0);
  opacity: 1;
}

.homepage-v3 .bento-detail__close {
  position: absolute;
  top: var(--space-6);
  right: var(--space-6);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--color-neutral-300) 40%, transparent);
  border-radius: var(--radius-1);
  background: color-mix(in srgb, var(--color-neutral-50) 80%, var(--color-neutral-0));
  color: var(--color-neutral-600);
  cursor: pointer;
  transition:
    background var(--duration-160) var(--ease-out),
    border-color var(--duration-160) var(--ease-out),
    color var(--duration-160) var(--ease-out);
}

.homepage-v3 .bento-detail__close:hover {
  background: var(--color-neutral-100);
  border-color: var(--color-neutral-200);
  color: var(--color-neutral-900);
}

.homepage-v3 .bento-detail__close:focus-visible {
  outline: 2px solid var(--color-purple-400);
  outline-offset: 2px;
}

.homepage-v3 .bento-detail__close svg {
  display: block;
}

.homepage-v3 .bento-detail__scroller {
  overflow-y: auto;
  padding: var(--space-20) clamp(var(--space-8), 4vw, var(--space-16)) var(--space-12);
  -webkit-overflow-scrolling: touch;
}

.homepage-v3 .bento-detail__main > .tag-label {
  margin-bottom: var(--space-8);
}

.homepage-v3 .bento-detail__title {
  font-size: clamp(var(--font-size-32), 3.5vw, var(--font-size-40));
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-neutral-1000);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--space-6);
  max-width: min(32rem, 100%);
}

.homepage-v3 .bento-detail__lead {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--color-neutral-600);
  margin: 0 0 var(--space-8);
  max-width: 52ch;
}

.homepage-v3 .bento-detail__body {
  font-size: var(--hp-prose);
  line-height: 1.65;
  color: var(--color-neutral-600);
  max-width: 52ch;
}

.homepage-v3 .bento-detail__body p {
  margin: 0 0 var(--space-4);
}

.homepage-v3 .bento-detail__body p:last-child {
  margin-bottom: 0;
}

.homepage-v3 .bento-detail__body a {
  color: var(--color-purple-400);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
}

.homepage-v3 .bento-detail__body a:hover {
  text-decoration: underline;
}

.homepage-v3 .bento-detail__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  gap: clamp(var(--space-8), 3vw, var(--space-14));
  align-items: start;
}

.homepage-v3 .bento-detail__main {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.homepage-v3 .bento-detail__main .bento-detail__lead,
.homepage-v3 .bento-detail__main .bento-detail__body {
  max-width: 58ch;
}

.homepage-v3 .bento-detail__stats {
  list-style: none;
  margin: 0 0 var(--space-8);
  padding: var(--space-5) var(--space-6);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-2);
}

.homepage-v3 .bento-detail__stats li {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.homepage-v3 .bento-detail__stat-value {
  font-size: clamp(var(--font-size-24), 2vw, var(--font-size-28));
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-neutral-1000);
  line-height: 1.1;
}

.homepage-v3 .bento-detail__stat-label {
  font-size: var(--hp-text-ui);
  line-height: 1.35;
  color: var(--color-neutral-600);
}

.homepage-v3 .bento-detail__capabilities {
  margin-top: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-neutral-200);
}

.homepage-v3 .bento-detail__subheading {
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-neutral-700);
  margin: 0 0 var(--space-4);
}

.homepage-v3 .bento-detail__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4) var(--space-7);
}

.homepage-v3 .bento-detail__bullets li {
  position: relative;
  padding-left: var(--space-6);
  min-width: 0;
  font-size: 14px;
}

.homepage-v3 .bento-detail__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-purple-100);
  box-shadow: inset 0 0 0 2px var(--color-purple-400);
}

.homepage-v3 .bento-detail__bullets strong {
  display: block;
  font-size: clamp(15px, 1.2vw, 16px);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-1000);
  margin-bottom: 2px;
  line-height: 1.35;
}

.homepage-v3 .bento-detail__bullets span {
  display: block;
  font-size: clamp(13px, 1.05vw, 14px);
  line-height: 1.5;
  color: var(--color-neutral-600);
}

.homepage-v3 .bento-detail__cta {
  margin-top: var(--space-10);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.homepage-v3 .bento-detail__aside {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  min-width: 0;
}

.homepage-v3 .bento-detail__quote {
  margin: 0;
  padding: var(--space-6);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-2);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-purple-100) 45%, transparent) 0%, var(--color-neutral-0) 65%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.homepage-v3 .bento-detail__quote-logo {
  height: 22px;
  display: flex;
  align-items: center;
}

.homepage-v3 .bento-detail__quote-logo img {
  max-height: 22px;
  width: auto;
  filter: invert(1) brightness(0.1);
  opacity: 0.85;
}

.homepage-v3 .bento-detail__quote blockquote {
  margin: 0;
  font-size: var(--hp-text-body);
  line-height: 1.55;
  color: var(--color-neutral-900);
  letter-spacing: var(--letter-spacing-tight);
}

.homepage-v3 .bento-detail__quote blockquote p {
  margin: 0;
}

.homepage-v3 .bento-detail__quote figcaption {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-200);
}

.homepage-v3 .bento-detail__quote-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--color-neutral-200);
  flex: 0 0 auto;
}

.homepage-v3 .bento-detail__quote-avatar--initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-purple-100);
  color: var(--color-purple-400);
  font-size: var(--hp-text-ui);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.04em;
}

.homepage-v3 .bento-detail__quote figcaption cite {
  display: block;
  font-style: normal;
  font-size: var(--hp-text-compact);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-1000);
  line-height: 1.2;
}

.homepage-v3 .bento-detail__quote figcaption span {
  display: block;
  font-size: var(--hp-text-ui);
  color: var(--color-neutral-600);
  margin-top: 2px;
}

.homepage-v3 .bento-detail__statcard {
  position: relative;
  margin: 0;
  padding: var(--space-8) var(--space-6);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-2);
  background:
    radial-gradient(120% 90% at 0% 0%, color-mix(in srgb, var(--color-purple-100) 70%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, var(--color-neutral-0) 0%, color-mix(in srgb, var(--color-purple-100) 20%, var(--color-neutral-0)) 100%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  overflow: hidden;
}

.homepage-v3 .bento-detail__statcard-eyebrow {
  font-size: var(--hp-text-ui);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-purple-400);
}

.homepage-v3 .bento-detail__statcard-eyebrow--logo {
  display: inline-flex;
  align-items: center;
  height: 18px;
}

.homepage-v3 .bento-detail__statcard-eyebrow--logo img {
  height: 100%;
  width: auto;
  display: block;
}

.homepage-v3 .bento-detail__statcard-figure {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  line-height: 0.9;
}

.homepage-v3 .bento-detail__statcard-value {
  font-size: clamp(40px, 6.5vw, 72px);
  font-weight: var(--font-weight-regular);
  letter-spacing: -0.01em;
  color: var(--color-neutral-1000);
  line-height: 0.9;
  display: inline-flex;
  align-items: flex-start;
}

.homepage-v3 .bento-detail__statcard-unit {
  font-size: 0.55em;
  font-weight: var(--font-weight-medium);
  margin-left: 0.05em;
  color: var(--color-purple-400);
  line-height: 1;
  padding-top: 0.12em;
}

.homepage-v3 .bento-detail__statcard-caption {
  margin: 0;
  font-size: var(--hp-text-body);
  line-height: 1.5;
  color: var(--color-neutral-700);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-200);
}

.homepage-v3 .bento-detail__statcard-caption strong {
  display: block;
  font-size: var(--hp-text-lead);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-1000);
  margin-bottom: var(--space-1);
}

.homepage-v3 .bento-detail__trust {
  padding: var(--space-5) var(--space-6);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-2);
  background: var(--color-neutral-0);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.homepage-v3 .bento-detail__trust-label {
  font-size: var(--hp-text-ui);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-neutral-600);
}

.homepage-v3 .bento-detail__trust-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-5);
}

.homepage-v3 .bento-detail__trust-logos img {
  height: 18px;
  width: auto;
  filter: invert(1) brightness(0.1);
  opacity: 0.7;
}

.homepage-v3 .bento-detail__trust-logos--text {
  gap: var(--space-2);
}

.homepage-v3 .bento-detail__trust-logos--text span {
  display: inline-flex;
  align-items: center;
  padding: 4px var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  font-size: var(--hp-text-ui);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-700);
  letter-spacing: 0.01em;
}

@media (max-width: 960px) {
  .homepage-v3 .bento-detail__layout {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-8);
  }

  .homepage-v3 .bento-detail__aside {
    position: static;
  }

  .homepage-v3 .bento-detail__bullets {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .bento-detail,
  .homepage-v3 .bento-detail__panel {
    transition: none;
  }

  .homepage-v3 .bento-detail.is-open .bento-detail__panel {
    transform: none;
  }
}

.homepage-v3 .hiw-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-6);
  padding: var(--space-16) var(--hp-gutter-x) var(--space-16);
  max-width: var(--max-w-container);
  margin: 0 auto;
}

.homepage-v3 .hiw-header-title {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
  max-width: none;
  white-space: nowrap;
}

.homepage-v3 .hiw-header-sub {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
  max-width: 600px;
}

.homepage-v3 .hiw-section {
  background: var(--bg-primary);
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  position: relative;
}

.homepage-v3 .hiw-col-text {
  flex: 0 0 auto;
  width: min(600px, 38vw);
  display: flex;
  flex-direction: column;
  padding-right: var(--space-6);
  margin-left: max(var(--space-10), calc((100vw - 1400px) / 2 + var(--space-20)));
}

.homepage-v3 .hiw-step {
  min-height: 85vh;
  display: flex;
  align-items: center;
  padding: var(--space-10) 0;
}

.homepage-v3 .hiw-step:first-child {
  padding-top: var(--space-4);
}

.homepage-v3 .hiw-step:last-child {
  min-height: 140vh;
  padding-bottom: 40vh;
}

.homepage-v3 .hiw-col-diagram {
  flex: 0 0 48%;
  min-width: 0;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  margin-left: auto;
  margin-right: max(var(--space-10), calc((100vw - 1400px) / 2));
  border-radius: 0 32px 0 0;
  overflow: hidden;
}

.homepage-v3 .hiw-diagram-stage {
  position: relative;
  width: 100%;
  height: 100%;
  background-color: #050506;
  background-image: radial-gradient(circle, rgba(255,255,255,0.05) 1.2px, transparent 1.2px);
  background-size: 14.3px 11.2px;
  overflow: hidden;
  border-radius: 0 32px 0 0;
}

.homepage-v3 .hiw-diagram-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(to right, var(--bg-primary, #000) 0%, transparent 22%),
    linear-gradient(to top, var(--bg-primary, #000) 0%, transparent 18%);
}

.homepage-v3 .hiw-diagram-stage::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(to bottom, transparent 0%, var(--color-neutral-800) 30%, var(--color-neutral-800) 70%, transparent 100%) right / 1px 100% no-repeat,
    linear-gradient(to right, transparent 0%, var(--color-neutral-800) 30%, var(--color-neutral-800) 70%, transparent 100%) top / 100% 1px no-repeat;
}

.homepage-v3 .hiw-phase [data-hiw-anim] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s ease-out, transform 0.55s ease-out;
  transition-delay: calc(var(--anim-order, 0) * 110ms);
}

.homepage-v3 .hiw-phase.is-revealed [data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-phase.is-past,
.homepage-v3 .hiw-flow-line.is-past {
  opacity: 0.25;
  transition: opacity 0.5s ease-out;
}

.homepage-v3 .hiw-phase [data-hiw-line] {
  stroke-dasharray: var(--line-len, 300);
  stroke-dashoffset: var(--line-len, 300);
  transition: stroke-dashoffset 0.7s ease-out;
  transition-delay: calc(var(--anim-order, 0) * 110ms);
}

.homepage-v3 .hiw-phase.is-revealed [data-hiw-line] {
  stroke-dashoffset: 0;
}

.homepage-v3 .hiw-step-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  opacity: 0.25;
  transform: translateY(12px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.homepage-v3 .hiw-step.is-active .hiw-step-text {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-step-text > .badge {
  align-self: flex-start;
  color: color-mix(in srgb, var(--text-primary) 78%, var(--text-secondary) 22%);
}

.homepage-v3 .hiw-heading {
  font-size: var(--font-size-48);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
}

.homepage-v3 .hiw-subtitle {
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
  max-width: 520px;
}

.homepage-v3 .hiw-features {
  list-style: none;
  padding: var(--space-6) 0 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.homepage-v3 .hiw-features li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--hp-prose);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary);
}

.homepage-v3 .hiw-features li svg {
  flex-shrink: 0;
  color: var(--color-purple-400);
  /* Align the checkmark with the cap-height of the first line of text */
  margin-top: 0.45em;
}

.homepage-v3 .hiw-cta-row {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  padding-top: var(--space-4);
}

.homepage-v3 .hiw-diagram-flow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(160px, 22vh, 260px);
  width: 100%;
  padding: 50vh 32px 60vh;
  position: relative;
  will-change: transform;
  transition: transform 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}

.homepage-v3 .hiw-phase {
  width: 100%;
  display: flex;
  justify-content: center;
  transition: opacity 0.5s ease-out;
  position: relative;
  z-index: 1;
}

.homepage-v3 .hiw-tree-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 500px;
  margin-top: -24px;
  margin-bottom: -24px;
}

.homepage-v3 .hiw-tree-stem {
  width: 1px;
  height: 28px;
  background: var(--border-card);
}

.homepage-v3 .hiw-tree-branches {
  position: relative;
  width: calc(100% - (100% - 24px) / 3);
  height: 24px;
}

.homepage-v3 .hiw-tree-branches::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--border-card);
}

.homepage-v3 .hiw-tree-drop {
  position: absolute;
  top: 0;
  width: 1px;
  height: 100%;
  background: var(--border-card);
}

.homepage-v3 .hiw-tree-drop:nth-child(1) { left: 0; }

.homepage-v3 .hiw-tree-drop:nth-child(2) { left: 50%; }

.homepage-v3 .hiw-tree-drop:nth-child(3) { right: 0; }

.homepage-v3 .hiw-capture-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 500px;
  padding: 0 24px;
  border-radius: 0;
  background: transparent;
  overflow: hidden;
}

.homepage-v3 .hiw-capture-sources {
  display: flex;
  gap: 12px;
  justify-content: center;
}

.homepage-v3 .hiw-source-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 12px;
  background: #111113;
  border: 1px solid var(--border-card);
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 13px;
  color: #fff;
  white-space: nowrap;
}

.homepage-v3 .hiw-source-pill svg {
  flex-shrink: 0;
  color: rgba(255,255,255,0.5);
}

.homepage-v3 .hiw-capture-lines {
  display: flex;
  justify-content: center;
  width: 100%;
}

.homepage-v3 .hiw-capture-lines svg {
  width: 100%;
  max-width: 300px;
  height: auto;
}

.homepage-v3 .hiw-capture-result {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 12px;
  background: #fff;
  color: #000;
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 13px;
  font-weight: var(--font-weight-regular);
}

.homepage-v3 .sv-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.homepage-v3 .sv-dot-sm {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.homepage-v3 .sv-mono-muted {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-tertiary);
  letter-spacing: 0.02em;
}

.homepage-v3 .sv-mono-value {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-secondary);
}

.homepage-v3 .sv-check {
  color: #22C55E;
  font-size: 12px;
  font-weight: var(--font-weight-regular);
}

.homepage-v3 .sv-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-secondary);
}

.homepage-v3 .sv-status-badge--green {
  border-color: rgba(34, 197, 94, 0.2);
  color: #22C55E;
}

.homepage-v3 .sv-transcript-card {
  background: #111113;
  border: 1px solid var(--border-card);
  border-radius: 12px;
  width: 100%;
  max-width: 500px;
  position: relative;
  z-index: 1;
}

.homepage-v3 .sv-transcript-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.homepage-v3 .sv-transcript-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.homepage-v3 .sv-transcript-title {
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 13px;
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
}

.homepage-v3 .sv-transcript-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.homepage-v3 .sv-transcript-body {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.homepage-v3 .sv-transcript-line {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.homepage-v3 .sv-transcript-line .sv-dot-sm {
  margin-top: 5px;
  flex-shrink: 0;
}

.homepage-v3 .sv-ts {
  flex-shrink: 0;
  min-width: 32px;
}

.homepage-v3 .sv-transcript-text {
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-secondary);
}

.homepage-v3 .sv-transcript-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
  margin: 0 16px;
}

.homepage-v3 .sv-transcript-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
}

.homepage-v3 .sv-enrich-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 400px;
}

.homepage-v3 .sv-enrich-stack .sv-enrich-card {
  flex: 1;
  min-width: 0;
}

.homepage-v3 .sv-enrich-card {
  background: #111113;
  border: none;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 0 43px 6px rgba(0,0,0,0.8);
  isolation: isolate;
}

.homepage-v3 .sv-enrich-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  pointer-events: none;
  z-index: 1;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.homepage-v3 .sv-enrich-card--purple::before {
  background: linear-gradient(
    var(--enrich-border-angle, 150deg),
    #947afc 0%,
    rgba(148,122,252,0.5) 10%,
    rgba(148,122,252,0.22) 22%,
    rgba(148,122,252,0.1) 35%,
    rgba(148,122,252,0.04) 55%,
    rgba(148,122,252,0.015) 75%,
    transparent 100%
  );
}

.homepage-v3 .sv-enrich-card--orange::before {
  background: linear-gradient(
    var(--enrich-border-angle, 150deg),
    #ff630f 0%,
    rgba(255,99,15,0.5) 10%,
    rgba(255,99,15,0.22) 22%,
    rgba(255,99,15,0.1) 35%,
    rgba(255,99,15,0.04) 55%,
    rgba(255,99,15,0.015) 75%,
    transparent 100%
  );
}

.homepage-v3 .sv-enrich-card--yellow::before {
  background: linear-gradient(
    var(--enrich-border-angle, 150deg),
    #f2cb45 0%,
    rgba(242,203,69,0.5) 10%,
    rgba(242,203,69,0.22) 22%,
    rgba(242,203,69,0.1) 35%,
    rgba(242,203,69,0.04) 55%,
    rgba(242,203,69,0.015) 75%,
    transparent 100%
  );
}

.homepage-v3 .sv-enrich-card-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  background: transparent;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px 12px 0 0;
}

.homepage-v3 .sv-enrich-card-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 11px;
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
  line-height: 1.3;
}

.homepage-v3 .sv-enrich-card-header .sv-mono-muted {
  font-size: 10px;
  color: var(--text-tertiary);
}

.homepage-v3 .sv-enrich-card-body {
  padding: 10px 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
}

.homepage-v3 .sv-entity-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 8px;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--font-weight-regular);
}

.homepage-v3 .sv-entity-tag--blue {
  background: rgba(59, 130, 246, 0.08);
  color: #3B82F6;
}

.homepage-v3 .sv-entity-tag--purple {
  background: rgba(148, 122, 252, 0.08);
  color: #947AFC;
}

.homepage-v3 .sv-entity-tag--amber {
  background: rgba(245, 158, 11, 0.08);
  color: #F59E0B;
}

.homepage-v3 .sv-sentiment-body {
  flex-wrap: nowrap;
  gap: 6px;
  padding: 10px 12px;
}

.homepage-v3 .sv-sentiment-label {
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 11px;
  color: #a3a3a3;
  flex-shrink: 0;
}

.homepage-v3 .sv-sentiment-bar {
  flex: 1;
  height: 4px;
  background: #1a1a1e;
  border-radius: 2px;
  overflow: hidden;
}

.homepage-v3 .sv-sentiment-fill {
  width: 91%;
  height: 100%;
  background: #22C55E;
  border-radius: 2px;
}

.homepage-v3 .sv-sentiment-value {
  font-family: var(--font-mono);
  font-size: 8px;
  color: #22C55E;
  flex-shrink: 0;
  text-transform: uppercase;
  letter-spacing: 0.96px;
}

.homepage-v3 .sv-topics-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.homepage-v3 .sv-topic-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 8px;
  text-transform: uppercase;
}

.homepage-v3 .sv-topic-tag--purple {
  background: rgba(148, 122, 252, 0.08);
  color: #947AFC;
}

.homepage-v3 .sv-topic-tag--blue {
  background: rgba(59, 130, 246, 0.08);
  color: #3B82F6;
}

.homepage-v3 .sv-integrate-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 335px;
  position: relative;
  background: transparent;
  padding: 24px;
}

.homepage-v3 .sv-integrate-path {
  flex-shrink: 0;
  display: block;
  overflow: visible;
  margin: -12px 0;
  position: relative;
  z-index: 0;
}

.homepage-v3 .sv-integrate-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}

.homepage-v3 .sv-integrate-group--right {
  align-items: flex-end;
}

.homepage-v3 .sv-integrate-group--left {
  align-items: flex-start;
}

.homepage-v3 .sv-integrate-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  background: rgba(34, 197, 94, 0.09);
  border: 1px solid rgba(34, 197, 94, 0.15);
  color: #22C55E;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--font-weight-regular);
  line-height: 1;
  white-space: nowrap;
}

.homepage-v3 .sv-integrate-badge-check {
  font-family: var(--font-mono);
  font-size: 10px;
}

.homepage-v3 .sv-integrate-card {
  background: #111113;
  border: 1px solid var(--border-card);
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  width: 233px;
  box-shadow: 0 0 43px rgba(0, 0, 0, 0.8);
}

.homepage-v3 .sv-integrate-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: transparent;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px 12px 0 0;
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 13px;
  font-weight: var(--font-weight-regular);
  color: var(--text-primary);
}

.homepage-v3 .sv-integrate-card-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 16px;
}

.homepage-v3 .sv-integrate-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
}

.homepage-v3 .sv-integrate-row .sv-mono-value {
  color: #fafafa;
}

.homepage-v3 .sv-integrate-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
}

.homepage-v3 .sv-integrate-stem {
  width: 1px;
  height: 37px;
  background: rgba(255, 255, 255, 0.06);
}

.homepage-v3 .sv-pipeline-done {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 24px;
  border-radius: 9999px;
  background: #22C55E;
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 13px;
  font-weight: var(--font-weight-regular);
  color: white;
}

.homepage-v3 .sv-pipeline-footer {
  font-family: "Suisse Intl", var(--font-sans);
  font-size: 11px;
  color: #3f3f46;
  padding-top: 24px;
  text-align: center;
}

@property --enrich-border-angle {
  syntax: '<angle>';
  initial-value: 150deg;
  inherits: false;
}

@property --tc-trace-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

@keyframes hiwBorderSweep {
  from { --enrich-border-angle: 110deg; }
  to   { --enrich-border-angle: 150deg; }
}

@keyframes hiwDrawLine {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

@keyframes hiwBarFill {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

@keyframes hiwTypeReveal {
  from { clip-path: inset(0 100% 0 0); }
  to   { clip-path: inset(0 0% 0 0); }
}

@keyframes hiwFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes hiwFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes hiwDotPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0.45); }
  50%      { box-shadow: 0 0 6px 2px rgba(34,197,94,0.3); }
}

@keyframes hiwGlowPulse {
  0%, 100% { box-shadow: 0 0 8px 1px rgba(34,197,94,0.12); }
  50%      { box-shadow: 0 0 18px 5px rgba(34,197,94,0.25); }
}

@keyframes hiwShimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(200%); }
}

@keyframes hiwSpectrum {
  0%, 100% { transform: scaleY(1); }
  50%      { transform: scaleY(var(--sp, 1.4)); }
}

@keyframes hiwDotSlide {
  0%   { opacity: 0; transform: translateY(-18px); }
  15%  { opacity: 1; }
  78%  { opacity: 1; }
  100% { opacity: 0; transform: translateY(18px); }
}

@keyframes hiwBorderTrace {
  0%   { --tc-trace-angle: 0deg;   opacity: 0; }
  3%   { opacity: 1; }
  78%  { --tc-trace-angle: 360deg; opacity: 1; }
  100% { --tc-trace-angle: 360deg; opacity: 0.2; }
}

@keyframes hiwCardGlow {
  0%   { box-shadow: 0 0 0 0 rgba(160,150,255,0), 0 0 0 0 rgba(160,150,255,0), inset 0 0 0 0 rgba(160,150,255,0), inset 0 0 0 0 rgba(160,150,255,0); }
  40%  { box-shadow: 0 0 80px 24px rgba(160,150,255,0.065), 0 0 160px 60px rgba(160,150,255,0.03), inset 0 0 28px 6px rgba(160,150,255,0.065), inset 0 0 50px 16px rgba(160,150,255,0.03); }
  100% { box-shadow: 0 0 0 0 rgba(160,150,255,0), 0 0 0 0 rgba(160,150,255,0), inset 0 0 0 0 rgba(160,150,255,0), inset 0 0 0 0 rgba(160,150,255,0); }
}

.homepage-v3 .hiw-phase[data-hiw-phase="0"] .hiw-source-pill[data-hiw-anim] {
  opacity: 1;
  transform: none;
  transition: none;
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line {
  transform-box: fill-box;
  transform-origin: center;
  animation: hiwSpectrum ease-in-out infinite alternate;
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line:nth-child(1) {
  --sp: 1.6;
  animation-duration: 0.65s;
  animation-delay: calc(var(--anim-order, 5) * 110ms + 700ms);
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line:nth-child(2) {
  --sp: 0.5;
  animation-duration: 0.5s;
  animation-delay: calc(var(--anim-order, 5) * 110ms + 800ms);
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line:nth-child(3) {
  --sp: 1.5;
  animation-duration: 0.7s;
  animation-delay: calc(var(--anim-order, 5) * 110ms + 650ms);
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line:nth-child(4) {
  --sp: 0.6;
  animation-duration: 0.55s;
  animation-delay: calc(var(--anim-order, 5) * 110ms + 750ms);
}

.homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line:nth-child(5) {
  --sp: 1.7;
  animation-duration: 0.6s;
  animation-delay: calc(var(--anim-order, 5) * 110ms + 850ms);
}

.homepage-v3 .hiw-flow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  box-shadow:
    0 0 6px 2px rgba(255,255,255,0.8),
    0 0 20px 6px rgba(255,255,255,0.3);
  opacity: 0;
  align-self: center;
  margin-top: -23px;
  margin-bottom: -23px;
  position: relative;
  z-index: 10;
  pointer-events: none;
}

.homepage-v3 .hiw-flow-dot.is-active {
  animation: hiwDotSlide 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation-delay: 100ms;
}

.homepage-v3 .hiw-diagram-flow {
  position: relative;
}

.homepage-v3 .hiw-flow-line-back {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.homepage-v3 .hiw-flow-line {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.homepage-v3 .hiw-trace-overlay {
  position: absolute;
  top: 0;
  left: 0;
  overflow: visible;
}

.homepage-v3 .hiw-trace-persist {
  stroke: rgba(148, 122, 252, 0.32);
  stroke-width: 0.75;
  fill: none;
  stroke-linecap: round;
}

.homepage-v3 .hiw-trace-outer,
.homepage-v3 .hiw-trace-tip {
  fill: none;
  stroke-linecap: round;
}

.homepage-v3 .hiw-trace-outer {
  stroke: rgba(148, 122, 252, 0.32);
  stroke-width: 0.85;
}

.homepage-v3 .hiw-trace-tip {
  stroke: rgba(255, 255, 255, 0.92);
  stroke-width: 1;
  filter: drop-shadow(0 0 2px rgba(148, 122, 252, 0.5));
}

.homepage-v3 .hiw-flow-dot {
  display: none;
}

.homepage-v3 .tc-trace-svg {
  display: none !important;
}

.homepage-v3 .tc-trace-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"].is-revealed .sv-transcript-card[data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
  transition: none;
  background: rgba(17, 17, 19, var(--tc-bg-alpha, 0.15));
  animation: hiwCardGlow 2.2s ease-in-out 350ms both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"].is-revealed .sv-transcript-card [data-hiw-anim] {
  opacity: 0;
  transform: translateY(16px);
  transition-delay: 0ms;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m0 .sv-transcript-header[data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m1 .sv-status-badge .sv-dot-sm {
  border-radius: 50%;
  animation: hiwDotPulse 1.8s ease-in-out infinite;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m1 .sv-transcript-line:nth-child(1)[data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m1 .sv-transcript-line:nth-child(1) .sv-transcript-text {
  animation: hiwTypeReveal 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m1 .sv-transcript-line:nth-child(1) .sv-ts {
  animation: hiwFadeIn 0.5s ease-out both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m1 .sv-transcript-line:nth-child(1) .sv-dot-sm {
  animation: hiwFadeIn 0.4s ease-out both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m2 .sv-transcript-line:nth-child(2)[data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m2 .sv-transcript-line:nth-child(2) .sv-transcript-text {
  animation: hiwTypeReveal 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m2 .sv-transcript-line:nth-child(2) .sv-ts {
  animation: hiwFadeIn 0.5s ease-out both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m2 .sv-transcript-line:nth-child(2) .sv-dot-sm {
  animation: hiwFadeIn 0.4s ease-out both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m3 .sv-transcript-divider {
  transform-origin: left;
  animation: hiwDrawLine 0.6s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m4 .sv-transcript-footer[data-hiw-anim] {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .hiw-phase[data-hiw-phase="1"] .sv-transcript-card.tc-m4 .sv-transcript-footer .sv-mono-muted {
  animation: hiwFadeUp 0.5s ease-out both;
}

.homepage-v3 .tc-trace-done .tc-trace-svg {
  transition: opacity 1.5s ease-out;
  opacity: 0;
}

.homepage-v3 .hiw-phase.is-revealed .sv-enrich-card::before {
  animation: hiwBorderSweep 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
  animation-delay: calc(var(--anim-order, 0) * 110ms);
}

.homepage-v3 .hiw-phase.is-revealed .sv-entity-tag {
  animation: hiwFadeUp 0.45s ease-out both;
}

.homepage-v3 .hiw-phase.is-revealed .sv-entity-tag:nth-child(1) { animation-delay: calc(var(--anim-order, 0) * 110ms + 800ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-entity-tag:nth-child(2) { animation-delay: calc(var(--anim-order, 0) * 110ms + 940ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-entity-tag:nth-child(3) { animation-delay: calc(var(--anim-order, 0) * 110ms + 1080ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-sentiment-fill {
  transform-origin: left;
  animation: hiwBarFill 1s cubic-bezier(0.4, 0, 0.2, 1) both;
  animation-delay: calc(var(--anim-order, 0) * 110ms + 800ms);
}

.homepage-v3 .hiw-phase.is-revealed .sv-sentiment-value {
  animation: hiwFadeIn 0.5s ease-out both;
  animation-delay: calc(var(--anim-order, 0) * 110ms + 1500ms);
}

.homepage-v3 .hiw-phase.is-revealed .sv-topic-tag {
  animation: hiwFadeUp 0.45s ease-out both;
}

.homepage-v3 .hiw-phase.is-revealed .sv-topic-tag:nth-child(1) { animation-delay: calc(var(--anim-order, 0) * 110ms + 800ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-topic-tag:nth-child(2) { animation-delay: calc(var(--anim-order, 0) * 110ms + 960ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-enrich-card-header {
  border-bottom-color: transparent;
  background-image: linear-gradient(rgba(255,255,255,0.06), rgba(255,255,255,0.06));
  background-size: 0% 1px;
  background-position: bottom left;
  background-repeat: no-repeat;
  transition: background-size 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.homepage-v3 .hiw-phase.is-revealed .sv-enrich-card-header {
  background-size: 100% 1px;
  transition-delay: calc(var(--anim-order, 0) * 110ms + 600ms);
}

.homepage-v3 .hiw-phase.is-revealed .sv-enrich-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.03), transparent);
  z-index: 2;
  pointer-events: none;
  animation: hiwShimmer 1.4s ease-in-out both;
  animation-delay: calc(var(--anim-order, 0) * 110ms + 1200ms);
}

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-badge-check {
  display: inline-block;
  animation: hiwFadeIn 0.4s ease-out both;
}

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(1) .sv-integrate-badge-check { animation-delay: calc(1 * 110ms + 750ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(2) .sv-integrate-badge-check { animation-delay: calc(3.5 * 110ms + 750ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(3) .sv-integrate-badge-check { animation-delay: calc(6 * 110ms + 750ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-card .sv-check {
  display: inline-block;
  animation: hiwFadeIn 0.35s ease-out both;
}

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(1) .sv-check { animation-delay: calc(1 * 110ms + 1050ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(2) .sv-check { animation-delay: calc(3.5 * 110ms + 1050ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(3) .sv-check { animation-delay: calc(6 * 110ms + 1050ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-divider {
  transform-origin: left;
  animation: hiwDrawLine 0.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(1) .sv-integrate-divider { animation-delay: calc(1 * 110ms + 900ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(2) .sv-integrate-divider { animation-delay: calc(3.5 * 110ms + 900ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-integrate-group:nth-child(3) .sv-integrate-divider { animation-delay: calc(6 * 110ms + 900ms); }

.homepage-v3 .hiw-phase.is-revealed .sv-pipeline-done {
  animation: hiwFadeUp 0.6s ease-out both,
             hiwGlowPulse 2.8s ease-in-out infinite;
  animation-delay: calc(8 * 110ms + 650ms), calc(8 * 110ms + 1300ms);
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .hiw-phase.is-revealed .hiw-capture-result svg line,
  .homepage-v3 .hiw-phase.is-revealed .sv-status-badge .sv-dot-sm,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-text,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-line .sv-ts,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-line .sv-dot-sm,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-divider,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-footer .sv-mono-muted,
  .homepage-v3 .hiw-phase.is-revealed .sv-entity-tag,
  .homepage-v3 .hiw-phase.is-revealed .sv-sentiment-fill,
  .homepage-v3 .hiw-phase.is-revealed .sv-sentiment-value,
  .homepage-v3 .hiw-phase.is-revealed .sv-topic-tag,
  .homepage-v3 .hiw-phase.is-revealed .sv-enrich-card::before,
  .homepage-v3 .hiw-phase.is-revealed .sv-enrich-card::after,
  .homepage-v3 .hiw-phase.is-revealed .sv-integrate-badge-check,
  .homepage-v3 .hiw-phase.is-revealed .sv-integrate-card .sv-check,
  .homepage-v3 .hiw-phase.is-revealed .sv-integrate-divider,
  .homepage-v3 .hiw-phase.is-revealed .sv-pipeline-done,
  .homepage-v3 .hiw-flow-dot.is-active,
  .homepage-v3 .hiw-phase.is-revealed .sv-transcript-card {
    animation: none !important;
  }
  .homepage-v3 .hiw-phase.is-revealed .sv-enrich-card-header {
    background-size: 100% 1px !important;
    transition: none !important;
  }
  .homepage-v3 .tc-trace-svg {
    display: none !important;
  }
  .homepage-v3 .hiw-phase[data-hiw-phase="1"].is-revealed .sv-transcript-card[data-hiw-anim] {
    opacity: 1 !important;
    background: #111113 !important;
    border-color: var(--border-card) !important;
    box-shadow: none !important;
    animation: none !important;
    transition: none !important;
  }
  .homepage-v3 .hiw-phase[data-hiw-phase="1"].is-revealed .sv-transcript-card [data-hiw-anim] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

@media (min-width: 769px) and (max-width: 960px) {
  .homepage-v3 .hiw-header-title {
    font-size: var(--font-size-40);
    line-height: 1.15;
  }
}

@media (max-width: 960px) {
  .homepage-v3 .hiw-header {
    padding: var(--space-10) var(--space-6) var(--space-6);
  }
  .homepage-v3 .hiw-header-title {
    white-space: normal;
  }
  .homepage-v3 .hiw-section {
    flex-direction: column;
    padding: var(--space-10) var(--space-6);
    width: 100%;
    margin-left: 0;
  }
  .homepage-v3 .hiw-col-text {
    flex: none;
    width: 100%;
    margin-left: 0;
    padding-right: 0;
  }
  .homepage-v3 .hiw-step {
    min-height: auto;
    padding: var(--space-8) 0;
  }
  .homepage-v3 .hiw-step:first-child {
    padding-top: var(--space-8);
  }
  .homepage-v3 .hiw-step:last-child {
    min-height: auto;
    padding-bottom: var(--space-8);
  }
  .homepage-v3 .hiw-step-text {
    opacity: 1;
    transform: none;
  }
  /* Colonne diagramme = fenêtre hauteur viewport : le flow interne se déplace
     via transform (même logique que desktop) ; tracé SVG (hiw-flow-line) reste visible. */
  .homepage-v3 .hiw-col-diagram {
    position: sticky;
    top: 0;
    align-self: start;
    width: 100%;
    height: min(100dvh, 100vh);
    min-height: min(100dvh, 100vh);
    max-height: min(100dvh, 100vh);
    padding: 0;
    margin-left: 0;
    margin-right: 0;
    z-index: 0;
  }
  .homepage-v3 .hiw-diagram-stage {
    height: 100%;
    min-height: 0;
    max-height: min(100dvh, 100vh);
    padding: 0;
    overflow: hidden;
  }
  .homepage-v3 .hiw-diagram-flow {
    padding: 24px 16px 40px;
    gap: clamp(40px, 7vh, 100px);
  }
  .homepage-v3 .sv-enrich-stack {
    flex-direction: column;
    gap: 16px;
  }
  .homepage-v3 .hiw-capture-panel {
    padding: 20px 16px;
  }
  .homepage-v3 .hiw-capture-sources {
    flex-wrap: wrap;
  }
  .homepage-v3 .sv-transcript-card,
  .homepage-v3 .sv-enrich-card {
    width: 100%;
  }
  .homepage-v3 .sv-integrate-stack {
    width: 100%;
    background-image: none;
  }
  .homepage-v3 .sv-integrate-path {
    display: none;
  }
  .homepage-v3 .sv-integrate-group--right,
  .homepage-v3 .sv-integrate-group--left {
    align-items: center;
  }
  .homepage-v3 .sv-integrate-card {
    width: 100%;
    max-width: 280px;
  }
  .homepage-v3 .sv-integrate-group + .sv-integrate-group {
    margin-top: 16px;
  }
  .homepage-v3 .sv-integrate-stem {
    height: 24px;
  }
}

@media (max-width: 768px) {
  .homepage-v3 .hiw-header-title {
    font-size: 32px;
  }
  .homepage-v3 .hiw-header-sub,
  .homepage-v3 .hiw-subtitle {
    font-size: 18px;
  }
  .homepage-v3 .hiw-heading {
    font-size: 32px;
  }
  .homepage-v3 .hiw-features {
    gap: 12px;
  }
  .homepage-v3 .hiw-features li {
    font-size: 16px;
  }
}

@keyframes hpFadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes hpFadeUpBlur {
  from { opacity: 0; transform: translateY(14px); filter: blur(6px); }
  to   { opacity: 1; transform: translateY(0);    filter: blur(0); }
}

@keyframes hpScaleIn {
  from { opacity: 0; transform: scale(0.94); }
  to   { opacity: 1; transform: scale(1); }
}

.homepage-v3 .tag-label .tag-indicator {
  position: relative;
  animation: hpSoftPulse 2.4s ease-in-out infinite;
}

.homepage-v3 .tag-label .tag-indicator::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  pointer-events: none;
  animation: hpTagRingPulse 2.8s ease-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .homepage-v3 .tag-label .tag-indicator,
  .homepage-v3 .tag-label .tag-indicator::after { animation: none; }
}

.homepage-v3 .reveal .tag-label,
.homepage-v3 .reveal .section-heading,
.homepage-v3 .reveal .section-subtitle,
.homepage-v3 .reveal .comparison-heading,
.homepage-v3 .reveal .comparison-subtitle,
.homepage-v3 .reveal .testimonials-heading,
.homepage-v3 .reveal .testimonials-sub,
.homepage-v3 .reveal .statement-body,
.homepage-v3 .reveal .statement-actions {
  opacity: 0;
  transform: translateY(14px);
  filter: blur(4px);
  transition: opacity 0.7s var(--ease-out),
              transform 0.7s var(--ease-out),
              filter 0.7s var(--ease-out);
}

.homepage-v3 .reveal.is-visible .tag-label,
.homepage-v3 .reveal.is-visible .section-heading,
.homepage-v3 .reveal.is-visible .section-subtitle,
.homepage-v3 .reveal.is-visible .comparison-heading,
.homepage-v3 .reveal.is-visible .comparison-subtitle,
.homepage-v3 .reveal.is-visible .testimonials-heading,
.homepage-v3 .reveal.is-visible .testimonials-sub,
.homepage-v3 .reveal.is-visible .statement-body,
.homepage-v3 .reveal.is-visible .statement-actions {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.homepage-v3 .reveal.is-visible .tag-label               { transition-delay: 0.05s; }

.homepage-v3 .reveal.is-visible .section-heading,
.homepage-v3 .reveal.is-visible .comparison-heading,
.homepage-v3 .reveal.is-visible .testimonials-heading    { transition-delay: 0.18s; }

.homepage-v3 .reveal.is-visible .section-subtitle,
.homepage-v3 .reveal.is-visible .comparison-subtitle,
.homepage-v3 .reveal.is-visible .testimonials-sub,
.homepage-v3 .reveal.is-visible .statement-body          { transition-delay: 0.55s; }

.homepage-v3 .reveal.is-visible .statement-actions       { transition-delay: 0.70s; }

.homepage-v3 .hiw-header.reveal .tag-label,
.homepage-v3 .hiw-header.reveal .hiw-header-title,
.homepage-v3 .hiw-header.reveal .hiw-header-sub {
  opacity: 0;
  transform: translateY(14px);
  filter: blur(4px);
  transition: opacity 0.7s var(--ease-out),
              transform 0.7s var(--ease-out),
              filter 0.7s var(--ease-out);
}

.homepage-v3 .hiw-header.reveal.is-visible .tag-label         { transition-delay: 0.05s; opacity: 1; transform: translateY(0); filter: blur(0); }

.homepage-v3 .hiw-header.reveal.is-visible .hiw-header-title  { transition-delay: 0.18s; opacity: 1; transform: translateY(0); filter: blur(0); }

.homepage-v3 .hiw-header.reveal.is-visible .hiw-header-sub    { transition-delay: 0.32s; opacity: 1; transform: translateY(0); filter: blur(0); }

.homepage-v3 .features-section.reveal .wg-card {
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  transition: opacity 0.7s var(--ease-out),
              transform 0.7s var(--ease-out);
}

.homepage-v3 .features-section.reveal.is-visible .wg-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.homepage-v3 .features-section.reveal.is-visible .wg-row:nth-child(1) .wg-card:nth-child(1) { transition-delay: 0.25s; }

.homepage-v3 .features-section.reveal.is-visible .wg-row:nth-child(1) .wg-card:nth-child(2) { transition-delay: 0.35s; }

.homepage-v3 .features-section.reveal.is-visible .wg-row:nth-child(2) .wg-card:nth-child(1) { transition-delay: 0.45s; }

.homepage-v3 .features-section.reveal.is-visible .wg-row:nth-child(2) .wg-card:nth-child(2) { transition-delay: 0.55s; }

.homepage-v3 .features-section.reveal.is-visible .wg-row:nth-child(3) .wg-card:nth-child(1) { transition-delay: 0.65s; }

.homepage-v3 .wg-card__title {
  transition: transform 0.35s var(--ease-out);
}

.homepage-v3 .wg-card:hover .wg-card__title { transform: translateY(-2px); }

.homepage-v3 .wg-card:hover .wg-expand      { transform: rotate(45deg); }

.homepage-v3 .wg-card .wg-expand:hover      { transform: rotate(45deg) scale(1.08); }

.homepage-v3 .comparison-section.reveal .comparison-table .table-row {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.55s var(--ease-out),
              transform 0.55s var(--ease-out),
              background-color 0.2s ease;
}

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row {
  opacity: 1;
  transform: translateY(0);
}

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(1)  { transition-delay: 0.35s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(2)  { transition-delay: 0.42s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(3)  { transition-delay: 0.49s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(4)  { transition-delay: 0.56s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(5)  { transition-delay: 0.63s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(6)  { transition-delay: 0.70s; }

.homepage-v3 .comparison-section.reveal.is-visible .comparison-table .table-row:nth-child(n+7){ transition-delay: 0.77s; }

.homepage-v3 .comparison-table .table-row:not(.header):hover {
  background-color: rgba(148, 122, 252, 0.05);
}

.homepage-v3 .comparison-table .table-row:not(.header) .cell-icon,
.homepage-v3 .comparison-table .table-row:not(.header) .feature-name {
  transition: transform 0.25s var(--ease-spring), color 0.2s ease;
}

.homepage-v3 .comparison-table .table-row:not(.header):hover .cell-icon-check { transform: scale(1.18); }

.homepage-v3 .comparison-table .table-row:not(.header):hover .feature-name    { color: var(--color-neutral-1000); }

.homepage-v3 .cta-strip {
  overflow: hidden;
  position: relative;
}

.homepage-v3 .cta-strip.reveal .cta-strip-text,
.homepage-v3 .cta-strip.reveal .cta-strip-buttons {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.7s var(--ease-out),
              transform 0.7s var(--ease-out);
}

.homepage-v3 .cta-strip.reveal.is-visible .cta-strip-text    { opacity: 1; transform: translateY(0); transition-delay: 0.08s; }

.homepage-v3 .cta-strip.reveal.is-visible .cta-strip-buttons { opacity: 1; transform: translateY(0); transition-delay: 0.22s; }

.homepage-v3 .cta-strip-btn-accent,
.homepage-v3 .cta-strip-btn-outline {
  transition: transform 0.25s var(--ease-spring),
              box-shadow 0.25s var(--ease-out),
              opacity var(--duration-160) var(--ease-out);
}

.homepage-v3 .cta-strip-btn-accent:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px -10px rgba(148, 122, 252, 0.55);
}

.homepage-v3 .cta-strip-btn-outline:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px -10px rgba(0, 0, 0, 0.18);
}

@keyframes testiCardEnter {
  0% {
    opacity: 0;
    filter: blur(14px);
    transform:
      translate3d(var(--enter-x, 0), var(--enter-y, 40px), 0)
      scale(var(--enter-scale, 0.88))
      rotate(var(--enter-rot, 0deg));
  }
  70% {
    opacity: 1;
    filter: blur(0);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translate3d(0, 0, 0) scale(1) rotate(0);
  }
}

.homepage-v3 .testimonials-section.reveal .testimonial-card {
  opacity: 0;
}

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:a"] { --enter-x: -36px; --enter-y: 28px;  --enter-scale: 0.9;  --enter-rot: -1.2deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:b"] { --enter-x:  22px; --enter-y: -24px; --enter-scale: 0.92; --enter-rot:  0.8deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:c"] { --enter-x: -14px; --enter-y: 44px;  --enter-scale: 0.85; --enter-rot: -0.6deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:d"] { --enter-x:  30px; --enter-y: 40px;  --enter-scale: 0.85; --enter-rot:  1.2deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:e"] { --enter-x: -22px; --enter-y: -26px; --enter-scale: 0.92; --enter-rot: -0.8deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:f"] { --enter-x: -30px; --enter-y: 48px;  --enter-scale: 0.85; --enter-rot: -1.2deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:g"] { --enter-x:  14px; --enter-y: 48px;  --enter-scale: 0.85; --enter-rot:  0.6deg; }

.homepage-v3 .testimonials-section.reveal .testimonial-card[style*="grid-area:h"] { --enter-x:  36px; --enter-y: 28px;  --enter-scale: 0.9;  --enter-rot:  1.2deg; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card {
  animation: testiCardEnter 1.1s cubic-bezier(.34, 1.4, .5, 1) both;
}

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:a"] { animation-delay: 0.30s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:b"] { animation-delay: 0.44s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:c"] { animation-delay: 0.58s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:d"] { animation-delay: 0.70s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:e"] { animation-delay: 0.52s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:f"] { animation-delay: 0.76s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:g"] { animation-delay: 0.88s; }

.homepage-v3 .testimonials-section.reveal.is-visible .testimonial-card[style*="grid-area:h"] { animation-delay: 0.64s; }

.homepage-v3 .statement-section.reveal .statement-title .statement-line {
  display: inline-block;
  opacity: 0;
  transform: translateY(16px);
  filter: blur(8px);
  transition: opacity 0.9s var(--ease-out),
              transform 0.9s var(--ease-out),
              filter 0.9s var(--ease-out);
}

.homepage-v3 .statement-section.reveal.is-visible .statement-title .statement-line {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.homepage-v3 .statement-section.reveal.is-visible .statement-title .statement-line:nth-child(1) { transition-delay: 0.10s; }

.homepage-v3 .statement-section.reveal.is-visible .statement-title .statement-line:nth-child(2) { transition-delay: 0.25s; }

.homepage-v3 .statement-section.reveal.is-visible .statement-title .statement-line:nth-child(3) { transition-delay: 0.40s; }

.homepage-v3 .statement-section.reveal.is-visible .statement-title .statement-line:nth-child(4) { transition-delay: 0.55s; }

@keyframes hpStatementDrift {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(-14px); }
}

.homepage-v3 .statement-section::before {
  animation: hpStatementDrift 9s ease-in-out infinite;
}

.homepage-v3 .wg-expand svg {
  transition: transform 0.25s var(--ease-out);
}

.homepage-v3 .wg-card:hover .wg-expand svg { transform: scale(1.1); }