@font-face {
  font-family: "NVIDIA-NALA";
  src: url("https://images.nvidia.com/etc/designs/nvidiaGDC/clientlibs_base/fonts/nvidia-sans/NALA/var/NVIDIASansVF_NALA_W_Wght.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --green: #76b900;
  --bg: #111111;
  --text-1: #f0f0f0;
  --text-2: #b7b7b7;
  --page-max-width: 1120px;
  --radius: 12px;
  --shadow: 0 2px 6px rgba(0, 0, 0, 0.6), 0 14px 40px rgba(0, 0, 0, 0.45);
}

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

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text-1);
  font-family: "NVIDIA-NALA", Arial, Helvetica, sans-serif;
  -webkit-font-smoothing: antialiased;
}

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

button {
  border: 0;
  background: none;
  color: inherit;
  cursor: pointer;
  font: inherit;
}

img,
video {
  display: block;
  max-width: 100%;
}

a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--green);
  outline-offset: 3px;
}

.cosmos3-page {
  --omni-fade-duration: 0.3s;
  --omni-fade-easing: ease;
  --cosmos3-hero-title-size: clamp(2.38rem, 4.75vw, 3.9rem);
  --cosmos3-hero-subtitle-size: clamp(1.18rem, 2.24vw, 1.77rem);
  --cosmos3-link-size: 1.03rem;
  --cosmos3-section-heading-size: clamp(1.63rem, 2.76vw, 2.36rem);
  --cosmos3-section-subheading-size: clamp(1.18rem, 1.85vw, 1.63rem);
  --cosmos3-section-body-size: 0.99rem;
  --cosmos3-omni-core-title-size: 1.57rem;
  --cosmos3-omni-core-subtitle-size: 1rem;
  --cosmos3-omni-core-label-size: clamp(0.67rem, 1.09vw, 0.9rem);
  --cosmos3-omni-intro-size: 0.97rem;
  --cosmos3-omni-control-size: 0.97rem;
  --cosmos3-benchmark-label-size: 0.86rem;
  --cosmos3-benchmark-body-size: 0.95rem;
  --cosmos3-caption-font-size: clamp(0.65rem, 0.81vw, 0.76rem);
  overflow-x: clip;
  overflow-y: visible;
  background: #111111;
  color: var(--text-1);
  font-size: 17px;
  line-height: 1.4;
  min-height: auto;
  padding: 0;
}

.cosmos3-hero {
  --cosmos3-hero-title-top: 50%;
  --cosmos3-hero-subtitle-top: 61%;
  --cosmos3-hero-links-bottom: clamp(94px, 10vh, 128px);
  position: relative;
  width: 100vw;
  max-width: 100vw;
  min-height: calc(100vh - 50px);
  min-height: calc(100svh - 50px);
  margin: 0 calc(50% - 50vw);
  padding: 92px max(clamp(20px, 5vw, 60px), calc((100vw - var(--page-max-width)) / 2 + 40px)) 112px;
  display: flex;
  overflow: hidden;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  isolation: isolate;
  text-align: center;
  background:
    radial-gradient(ellipse 70% 58% at 50% 18%, rgba(118, 185, 0, 0.08), transparent 50%),
    linear-gradient(180deg, #050505 0%, #111111 100%);
}

.cosmos3-hero-bg {
  position: absolute;
  inset: clamp(18px, 2.6vw, 34px) clamp(12px, 2.6vw, 34px) clamp(30px, 3.6vw, 48px);
  z-index: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: clamp(26px, 3.8vw, 52px);
  background: #050505;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.56);
  pointer-events: none;
}

.cosmos3-hero-bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.4;
  filter: saturate(1.08) brightness(1.14) contrast(1.05);
  transform: scale(1.05);
  transform-origin: 50% 50%;
}

.cosmos3-hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 58% 46% at 50% 36%, rgba(0, 0, 0, 0.26), rgba(0, 0, 0, 0.16) 44%, transparent 74%),
    radial-gradient(ellipse 76% 62% at 50% 50%, transparent 34%, rgba(0, 0, 0, 0.12) 78%, rgba(0, 0, 0, 0.24) 100%),
    linear-gradient(0deg, rgba(0, 0, 0, 0.1), transparent 30%, transparent 72%, rgba(0, 0, 0, 0.14));
}

.cosmos3-hero > *:not(.cosmos3-hero-bg) {
  position: relative;
  z-index: 1;
}

.cosmos3-hero .project-title {
  position: absolute;
  top: var(--cosmos3-hero-title-top);
  left: 50%;
  max-width: 900px;
  width: min(900px, calc(100% - 48px));
  margin: 0;
  transform: translate(-50%, calc(-50% + 3px));
  color: #fff;
  font-size: var(--cosmos3-hero-title-size);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  text-shadow: 0 8px 30px rgba(0, 0, 0, 0.38);
}

.title-special {
  color: var(--green);
}

.title-accent {
  color: rgba(255, 255, 255, 0.94);
}

.cosmos3-hero .project-subtitle {
  position: absolute;
  top: var(--cosmos3-hero-subtitle-top);
  left: 50%;
  max-width: 980px;
  width: min(980px, calc(100% - 48px));
  margin: 0;
  transform: translate(-50%, -50%);
  color: rgba(255, 255, 255, 0.8);
  font-size: var(--cosmos3-hero-subtitle-size);
  font-weight: 500;
  line-height: 1.24;
  text-align: center;
}

.cosmos3-hero .project-subtitle span {
  display: inline;
}

.cosmos3-hero .project-links {
  position: absolute;
  right: clamp(28px, 5vw, 78px);
  bottom: var(--cosmos3-hero-links-bottom);
  left: clamp(28px, 5vw, 78px);
  display: flex;
  flex-wrap: wrap;
  gap: clamp(14px, 2vw, 22px);
  justify-content: center;
}

.link-btn {
  position: relative;
  isolation: isolate;
  min-height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(118, 185, 0, 0.58);
  border-radius: 100px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.035)),
    linear-gradient(135deg, rgba(81, 127, 0, 0.52), rgba(118, 185, 0, 0.28) 58%, rgba(118, 185, 0, 0.08)),
    rgba(12, 18, 10, 0.86);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 14px 34px rgba(0, 0, 0, 0.32),
    0 0 24px rgba(118, 185, 0, 0.16);
  color: #fff;
  font-size: var(--cosmos3-link-size);
  font-weight: 600;
  padding: 13px 30px;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.link-btn:hover {
  border-color: var(--green);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.04)),
    linear-gradient(135deg, rgba(81, 127, 0, 0.74), rgba(118, 185, 0, 0.48) 58%, rgba(118, 185, 0, 0.18)),
    rgba(12, 18, 10, 0.9);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 16px 38px rgba(0, 0, 0, 0.36),
    0 0 30px rgba(118, 185, 0, 0.24);
}

.link-btn.secondary {
  border-color: rgba(118, 185, 0, 0.42);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.26);
}

.link-btn.secondary:hover {
  border-color: rgba(118, 185, 0, 0.72);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(81, 127, 0, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 12px 30px rgba(0, 0, 0, 0.3);
}

.cosmos3-hero .link-btn {
  min-height: 54px;
  padding: 13px 30px;
  font-size: var(--cosmos3-link-size);
  font-weight: 800;
}

.media-control {
  position: relative;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035)),
    rgba(8, 8, 8, 0.76);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(0, 0, 0, 0.28);
  color: #fff;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.media-control:hover {
  border-color: rgba(118, 185, 0, 0.78);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.04)),
    rgba(81, 127, 0, 0.72);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 12px 28px rgba(0, 0, 0, 0.32);
}

.media-control.volume-control.is-muted::after {
  content: "";
  position: absolute;
  inset: -3px;
  border: 2px solid #ffd633;
  border-radius: calc(var(--radius) + 3px);
  opacity: 0;
  pointer-events: none;
  animation: muted-volume-invite 1.8s ease-in-out infinite;
}

@keyframes muted-volume-invite {
  0%,
  100% {
    opacity: 0;
  }

  42%,
  62% {
    opacity: 0.95;
  }
}

.media-control svg,
.media-control img {
  width: 19px;
  height: 19px;
  display: block;
}

.media-control svg {
  fill: currentColor;
}

.media-control img {
  filter: invert(1);
  object-fit: contain;
}

.media-control .play-icon,
.media-control.is-paused .pause-icon,
.media-control .volume-muted-icon,
.media-control.is-muted .volume-on-icon {
  display: none;
}

.media-control.is-paused .play-icon,
.media-control.is-muted .volume-muted-icon {
  display: block;
}

.vision-language-media > .media-control.playback-control,
.video-overlay-card > .media-control.playback-control,
.result-video-card > .media-control.playback-control {
  position: absolute;
  right: var(--result-overlay-gap);
  bottom: var(--result-overlay-gap);
  z-index: 2;
}

.cosmos3-hero .cosmos3-hero-scroll {
  position: absolute;
  left: 50%;
  bottom: 32px;
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  padding: 0;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.48);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.28);
  transform: translateX(-50%);
  color: rgba(255, 255, 255, 0.82);
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.cosmos3-hero .cosmos3-hero-scroll:hover {
  border-color: rgba(118, 185, 0, 0.66);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.032)),
    rgba(81, 127, 0, 0.3);
  color: #fff;
}

.cosmos3-section {
  --section-padding-y: 60px;
  --section-padding-x: clamp(16px, 4vw, 48px);
  --section-bg: #111111;
  --section-bg-rgb: 17, 17, 17;
  width: 100%;
  padding: var(--section-padding-y) var(--section-padding-x);
  border-top: 0;
  background: var(--section-bg);
  color: var(--text-1);
  scroll-margin-top: 64px;
}

.cosmos3-section > * {
  max-width: var(--page-max-width);
  margin-left: auto;
  margin-right: auto;
}

.cosmos3-section.is-reveal-ready > * {
  opacity: 0;
  transform: translate3d(0, 52px, 0) scale(0.985);
  transition:
    opacity 0.82s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.96s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

.cosmos3-section.is-reveal-ready > *:nth-child(2) {
  transition-delay: 90ms;
}

.cosmos3-section.is-reveal-ready > *:nth-child(3) {
  transition-delay: 150ms;
}

.cosmos3-section.is-reveal-visible > * {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.cosmos3-section.is-reveal-settled > * {
  will-change: auto;
}

.section-heading-block {
  position: relative;
  margin-bottom: 34px;
}

.section-heading-block.centered {
  text-align: center;
}

.section-heading-block h2,
.section-heading-block h3 {
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.22;
  text-wrap: balance;
}

.section-heading-block h2 {
  font-size: var(--cosmos3-section-heading-size);
}

.section-heading-block .nvidia-green {
  color: var(--green);
}

.result-task-label {
  margin: 0 0 10px;
  color: var(--green);
  font-size: clamp(0.82rem, 0.95vw, 0.93rem);
  font-weight: 700;
  line-height: 1.1;
}

.omni-title-mobile-copy {
  display: none;
}

.section-heading-block h3 {
  font-size: var(--cosmos3-section-subheading-size);
}

.section-heading-block p {
  max-width: 890px;
  margin: 13px 0 0;
  color: #999999;
  font-size: var(--cosmos3-section-body-size);
  font-weight: 500;
  line-height: 1.5;
  text-wrap: balance;
}

.result-section .section-heading-block p {
  color: #999999;
}

.omni-section .section-heading-block p {
  color: #999999;
}

.section-heading-block.centered p {
  margin-left: auto;
  margin-right: auto;
}

.omni-section {
  --omni-core-bg: rgb(41, 46, 35);
  --omni-core-bg-soft: rgb(51, 57, 44);
  --omni-core-border: rgba(118, 185, 0, 0.3);
  --omni-disabled-opacity: 0.2;
  --omni-transformer-mask: linear-gradient(
    to bottom,
    transparent 0%,
    transparent 5%,
    rgba(0, 0, 0, 0.02) 7%,
    rgba(0, 0, 0, 0.08) 9%,
    rgba(0, 0, 0, 0.22) 11%,
    rgba(0, 0, 0, 0.5) 12.5%,
    rgba(0, 0, 0, 0.78) 14%,
    rgba(0, 0, 0, 0.92) 16%,
    rgba(0, 0, 0, 0.98) 18%,
    #000 20%,
    #000 75%,
    rgba(0, 0, 0, 0.98) 77%,
    rgba(0, 0, 0, 0.92) 79%,
    rgba(0, 0, 0, 0.78) 81%,
    rgba(0, 0, 0, 0.5) 82.5%,
    rgba(0, 0, 0, 0.22) 84%,
    rgba(0, 0, 0, 0.08) 86%,
    rgba(0, 0, 0, 0.02) 88%,
    transparent 90%,
    transparent 100%
  );
  color: var(--text-1);
  line-height: 1.4;
  padding-bottom: 80px;
  padding-bottom: clamp(26px, 3vw, 42px);
}

.omni-section .section-heading-block {
  margin-bottom: clamp(38px, 4.8vw, 62px);
}

.omni-diagram-panel {
  --omni-core-radius: 22px;
  --omni-transformer-y: 18px;
  --omni-shared-y: -2px;
  --omni-core-text-pad-y: 7.55%;
  --omni-core-subtitle-y: 18.4%;
  --omni-core-title-size: var(--cosmos3-omni-core-title-size);
  --omni-arrow-balance-x: 4px;
  position: relative;
}

.omni-diagram {
  --omni-arrow-column-width: clamp(48px, 5.6vw, 78px);
  --omni-modality-column-width: minmax(142px, 158px);
  display: grid;
  grid-template-columns: var(--omni-modality-column-width) var(--omni-arrow-column-width) minmax(292px, 432px) var(--omni-arrow-column-width) var(--omni-modality-column-width);
  grid-template-rows: repeat(5, minmax(0, 1fr));
  justify-content: center;
  align-items: center;
  column-gap: clamp(12px, 1.4vw, 16px);
  row-gap: clamp(5px, 0.36vw, 7px);
  isolation: isolate;
  overflow: visible;
  padding: 14px 2px 18px;
}

.omni-modality {
  --omni-modality-icon-src: url("assets/icons/text.svg");
  --omni-modality-bg: #e0e0ff;
  --omni-modality-accent: #020273;
  --omni-modality-accent-rgb: 2, 2, 115;
  --omni-modality-text: #050505;
  position: relative;
  isolation: isolate;
  max-width: 158px;
  min-height: 62px;
  aspect-ratio: 681 / 248;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  overflow: hidden;
  border: 1px solid rgba(var(--omni-modality-accent-rgb), 0.16);
  border-radius: 15px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.38), rgba(255, 255, 255, 0) 62%),
    var(--omni-modality-bg);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
  color: var(--omni-modality-text);
  justify-self: stretch;
  opacity: var(--omni-disabled-opacity);
  padding: 0 12px;
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-modality::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 16% 0%, rgba(var(--omni-modality-accent-rgb), 0.18), transparent 42%),
    linear-gradient(90deg, rgba(var(--omni-modality-accent-rgb), 0.1), transparent 38%);
  opacity: 1;
  pointer-events: none;
}

.omni-modality[data-modality="text"] {
  --omni-modality-icon-src: url("assets/icons/text.svg");
  --omni-modality-bg: #e0e0ff;
  --omni-modality-accent: #020273;
  --omni-modality-accent-rgb: 2, 2, 115;
}

.omni-modality[data-modality="image"] {
  --omni-modality-icon-src: url("assets/icons/image.svg");
  --omni-modality-bg: #fff0e0;
  --omni-modality-accent: #c76402;
  --omni-modality-accent-rgb: 199, 100, 2;
}

.omni-modality[data-modality="video"] {
  --omni-modality-icon-src: url("assets/icons/video.svg");
  --omni-modality-bg: #fff0e0;
  --omni-modality-accent: #c76402;
  --omni-modality-accent-rgb: 199, 100, 2;
}

.omni-modality[data-modality="audio"] {
  --omni-modality-icon-src: url("assets/icons/audio.svg");
  --omni-modality-bg: #e3c7e3;
  --omni-modality-accent: #4d024e;
  --omni-modality-accent-rgb: 77, 2, 78;
}

.omni-modality[data-modality="action"] {
  --omni-modality-icon-src: url("assets/icons/action.svg");
  --omni-modality-bg: #d9e7d7;
  --omni-modality-accent: #3d6039;
  --omni-modality-accent-rgb: 61, 96, 57;
}

.omni-modality-icon,
.omni-modality-label {
  position: relative;
  z-index: 1;
}

.omni-modality-icon {
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  color: var(--omni-modality-accent);
}

.omni-modality-icon::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: currentColor;
  -webkit-mask: var(--omni-modality-icon-src) center / contain no-repeat;
  mask: var(--omni-modality-icon-src) center / contain no-repeat;
}

.omni-modality-label {
  flex: 0 1 auto;
  min-width: 0;
  color: var(--omni-modality-text);
  font-size: clamp(0.95rem, 1.03vw, 1.03rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.omni-modality[data-side="input"] {
  grid-column: 1;
}

.omni-modality[data-side="output"] {
  grid-column: 5;
}

.omni-modality[data-modality="text"],
.omni-arrow[data-modality="text"] {
  grid-row: 1;
}

.omni-modality[data-modality="image"],
.omni-arrow[data-modality="image"] {
  grid-row: 2;
}

.omni-modality[data-modality="video"],
.omni-arrow[data-modality="video"] {
  grid-row: 3;
}

.omni-modality[data-modality="audio"],
.omni-arrow[data-modality="audio"] {
  grid-row: 4;
}

.omni-modality[data-modality="action"],
.omni-arrow[data-modality="action"] {
  grid-row: 5;
}

.omni-modality.is-active {
  opacity: 1;
}

.omni-arrow img,
.omni-core-base {
  display: block;
  width: 100%;
  height: auto;
}

.omni-arrow img {
  position: relative;
  z-index: 1;
}

.omni-core {
  position: relative;
  grid-column: 3;
  grid-row: 1 / 6;
  display: flex;
  min-width: 270px;
  max-width: 432px;
  align-items: center;
  justify-self: stretch;
}

.omni-core-base {
  position: relative;
  z-index: 0;
  aspect-ratio: 3978 / 3712;
  overflow: hidden;
  border: 1px solid var(--omni-core-border);
  border-radius: var(--omni-core-radius);
  background:
    radial-gradient(circle at 50% 18%, rgba(118, 185, 0, 0.12), transparent 40%),
    linear-gradient(180deg, var(--omni-core-bg-soft), var(--omni-core-bg) 58%, rgb(34, 39, 30)),
    var(--omni-core-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 22px 48px rgba(0, 0, 0, 0.34);
  transform: scale(1.08);
  transform-origin: center;
}

.omni-core-base::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 18%, transparent 78%, rgba(0, 0, 0, 0.12)),
    radial-gradient(circle at 50% 54%, transparent 0 46%, rgba(118, 185, 0, 0.05) 66%, transparent 78%);
  pointer-events: none;
}

.omni-core-title,
.omni-core-subtitle {
  position: absolute;
  left: 50%;
  z-index: 3;
  display: block;
  transform: translateX(-50%);
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
}

.omni-core-title {
  top: var(--omni-core-text-pad-y);
  color: #ffffff;
  font-size: var(--omni-core-title-size);
  font-weight: 760;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.32);
}

.omni-core-subtitle {
  top: var(--omni-core-subtitle-y);
  color: rgba(118, 185, 0, 0.95);
  font-size: var(--cosmos3-omni-core-subtitle-size);
  font-weight: 520;
  transform: translateX(-50%);
}

.omni-core-layer {
  position: absolute;
  display: block;
  height: auto;
  pointer-events: none;
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-shared.is-center-inactive {
  opacity: 0.3;
}

.omni-transformer {
  top: 21.5%;
  z-index: 1;
  width: 36.3%;
  border-radius: 12px;
  transform: translateY(var(--omni-transformer-y));
}

.omni-transformer::before,
.omni-transformer::after {
  content: "";
  position: absolute;
  left: 50%;
  z-index: 2;
  width: 3px;
  height: 18px;
  transform: translateX(-50%);
  background: radial-gradient(circle, var(--omni-core-bg) 0 1.5px, transparent 1.9px) center / 100% 33.333% repeat-y;
  pointer-events: none;
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-transformer::before {
  top: 5px;
}

.omni-transformer::after {
  bottom: 10px;
}

.omni-transformer.is-center-inactive::before,
.omni-transformer.is-center-inactive::after {
  opacity: 0.5;
}

.omni-transformer-img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  border-radius: 11px;
  -webkit-mask-image: var(--omni-transformer-mask);
  mask-image: var(--omni-transformer-mask);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-transformer.is-center-inactive .omni-transformer-img {
  opacity: 0.3;
}

.omni-transformer--left {
  left: 9.1%;
}

.omni-transformer--right {
  left: 54.68%;
}

.omni-shared {
  left: 39%;
  /* Keeps the shared arrow visually centered on the transformer attention blocks. */
  top: calc(50.95% + var(--omni-transformer-y) - var(--omni-shared-y));
  z-index: 2;
  width: 25%;
  border-radius: 999px;
  transform: translateY(var(--omni-shared-y));
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-core-label {
  position: absolute;
  bottom: var(--omni-core-text-pad-y);
  z-index: 3;
  transform: translateX(-50%);
  color: rgba(255, 255, 255, 0.84);
  font-size: var(--cosmos3-omni-core-label-size);
  font-weight: 500;
  line-height: 1;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-core-label.is-center-inactive {
  opacity: 0.5;
}

.omni-core-label--left {
  left: 28.94%;
}

.omni-core-label--right {
  left: 71.14%;
}

.omni-arrow {
  --omni-arrow-offset-x: 0px;
  position: relative;
  isolation: isolate;
  width: 72%;
  max-width: 48px;
  min-width: 28px;
  justify-self: center;
  opacity: 0.24;
  transform: translateX(var(--omni-arrow-offset-x));
  transition: opacity var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  left: 2px;
  z-index: 0;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(118, 185, 0, 0.9) 50%, transparent);
  transform: translateY(-50%);
}

.omni-arrow.is-active {
  opacity: 0.9;
}

.omni-arrow--in {
  --omni-arrow-offset-x: calc(-1 * var(--omni-arrow-balance-x));
  grid-column: 2;
}

.omni-arrow--out {
  --omni-arrow-offset-x: var(--omni-arrow-balance-x);
  grid-column: 4;
}

.cosmos3-section.omni-controls-section {
  min-height: 0;
  padding-top: 20px;
  padding-bottom: 80px;
}

.omni-controls-intro {
  max-width: 760px;
  margin: 0 auto 24px;
  color: #999999;
  font-size: var(--cosmos3-omni-intro-size);
  line-height: 1.45;
  text-align: center;
}

.omni-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  justify-content: center;
  max-width: 1080px;
  margin: 0 auto;
}

.omni-control {
  position: relative;
  width: 100%;
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  isolation: isolate;
  appearance: none;
  border: 1px solid rgba(118, 185, 0, 0.42);
  border-radius: 100px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.26);
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-size: 0.93rem;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.2;
  padding: 11px 22px;
  text-align: center;
  white-space: nowrap;
  outline: 0;
  transition:
    background var(--omni-fade-duration) var(--omni-fade-easing),
    border-color var(--omni-fade-duration) var(--omni-fade-easing),
    box-shadow var(--omni-fade-duration) var(--omni-fade-easing);
}

.omni-control span {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  font-weight: inherit;
}

.omni-control:hover,
.omni-control:focus-visible,
.omni-control.is-active {
  border-color: rgba(118, 185, 0, 0.72);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(81, 127, 0, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 12px 30px rgba(0, 0, 0, 0.3);
  outline: none;
}

.benchmark-heading {
  margin-bottom: 42px;
}

.benchmark-heading p {
  color: #999999;
}

.benchmark-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2.4vw, 28px);
  align-items: stretch;
}

.benchmark-card {
  position: relative;
  min-height: clamp(240px, 18vw, 280px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.034)),
    rgba(255, 255, 255, 0.035);
  box-shadow: var(--shadow);
  padding: clamp(20px, 2.4vw, 30px) clamp(22px, 3vw, 34px);
  text-align: center;
}

.benchmark-card:not(.benchmark-summary-card)::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, rgba(118, 185, 0, 0.15), rgba(118, 185, 0, 0.9), rgba(118, 185, 0, 0.12));
}

.benchmark-card.is-featured {
  border-color: rgba(118, 185, 0, 0.38);
  background:
    linear-gradient(145deg, rgba(118, 185, 0, 0.14), rgba(255, 255, 255, 0.05) 46%, rgba(255, 255, 255, 0.03)),
    rgba(255, 255, 255, 0.04);
}

.benchmark-summary-card {
  grid-column: 1 / -1;
  justify-self: center;
  width: 100%;
  min-height: 0;
  align-items: center;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: clamp(20px, 3vw, 30px) 0 0;
  text-align: center;
}

.benchmark-card-label {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  margin-bottom: clamp(18px, 2vw, 24px);
  border: 1px solid rgba(118, 185, 0, 0.36);
  border-radius: 999px;
  background: rgba(118, 185, 0, 0.1);
  color: var(--green);
  font-size: var(--cosmos3-benchmark-label-size);
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
  padding: 5px 11px;
}

.benchmark-card-label-icon {
  font-size: 0.92em;
  line-height: 1;
  flex: 0 0 auto;
}

.benchmark-card h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.03rem, 1.38vw, 1.25rem);
  font-weight: 650;
  letter-spacing: 0;
  line-height: 1.28;
  text-wrap: balance;
}

.benchmark-card > p {
  max-width: 44rem;
  margin: clamp(16px, 1.8vw, 22px) 0 0;
  color: var(--text-2);
  font-size: var(--cosmos3-benchmark-body-size);
  line-height: 1.42;
}

.benchmark-card-link {
  width: fit-content;
  min-height: 42px;
  margin-top: clamp(18px, 2vw, 24px);
  font-size: 0.86rem;
  font-weight: 650;
  padding: 9px 19px;
}

.benchmark-rank-highlight {
  color: #fff;
  font-weight: 800;
}

.benchmark-link-prompt {
  max-width: 100%;
  margin: 0;
  color: var(--text-2);
  font-size: var(--cosmos3-benchmark-body-size);
  font-weight: 400;
  line-height: 1.5;
}

.benchmark-summary-card .benchmark-summary-links {
  justify-content: center;
  margin-top: clamp(18px, 1.8vw, 24px);
  padding-top: 0;
}

.benchmark-summary-links .link-btn {
  width: fit-content;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(118, 185, 0, 0.62);
  border-radius: 100px;
  background: rgba(118, 185, 0, 0.12);
  color: #fff;
  cursor: pointer;
  font-size: 0.93rem;
  font-weight: 800;
  padding: 11px 22px;
  box-shadow: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.benchmark-summary-links .link-btn.secondary {
  border-color: rgba(118, 185, 0, 0.42);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.26);
}

.benchmark-summary-links .link-btn:hover,
.benchmark-summary-links .link-btn.secondary:hover {
  border-color: rgba(118, 185, 0, 0.72);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(81, 127, 0, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 12px 30px rgba(0, 0, 0, 0.3);
}

.benchmark-summary-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: auto;
  padding-top: clamp(26px, 3vw, 36px);
}

.cosmos3-page .page-nav {
  margin-top: clamp(40px, 5vw, 70px);
  margin-bottom: clamp(42px, 5vw, 72px);
}

.cosmos3-page .page-nav-btn {
  border-color: rgba(255, 255, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.52);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.24);
  color: rgba(255, 255, 255, 0.72);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.cosmos3-page .page-nav-btn:hover {
  border-color: rgba(118, 185, 0, 0.72);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(81, 127, 0, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 12px 30px rgba(0, 0, 0, 0.3);
  color: #fff;
}

.cosmos3-carousel {
  --carousel-media-height: clamp(228px, 37.1vw, 457px);
  --carousel-media-aspect: 16 / 9;
  --carousel-slide-width: min(100%, calc(var(--carousel-media-height) * var(--carousel-media-aspect)));
  --carousel-edge-fade: clamp(16px, 2.4vw, 28px);
  --result-overlay-gap: clamp(7px, 1.05vw, 10px);
  position: relative;
  width: min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2)));
  max-width: var(--page-max-width);
  margin: 0 auto;
}

.cosmos3-carousel::before,
.cosmos3-carousel::after {
  content: "";
  position: absolute;
  top: 0;
  height: var(--carousel-media-height);
  z-index: 2;
  width: var(--carousel-edge-fade);
  pointer-events: none;
  transition: opacity 0.16s ease;
}

.cosmos3-carousel::before {
  left: 0;
  background: linear-gradient(90deg, var(--section-bg) 0%, rgba(var(--section-bg-rgb), 0.92) 10%, rgba(var(--section-bg-rgb), 0.72) 28%, rgba(var(--section-bg-rgb), 0.38) 58%, rgba(var(--section-bg-rgb), 0.12) 82%, transparent 100%);
}

.cosmos3-carousel::after {
  right: 0;
  background: linear-gradient(270deg, var(--section-bg) 0%, rgba(var(--section-bg-rgb), 0.92) 10%, rgba(var(--section-bg-rgb), 0.72) 28%, rgba(var(--section-bg-rgb), 0.38) 58%, rgba(var(--section-bg-rgb), 0.12) 82%, transparent 100%);
}

.cosmos3-carousel.is-at-start::before,
.cosmos3-carousel.is-at-end::after {
  opacity: 0;
}

.carousel-viewport {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.carousel-viewport::-webkit-scrollbar {
  display: none;
}

.carousel-track {
  display: grid;
  grid-auto-columns: var(--carousel-slide-width);
  grid-auto-flow: column;
  grid-template-rows: max-content;
  align-items: flex-start;
  gap: 16px;
  padding: 0;
}

.carousel-slide {
  --carousel-slide-opacity: 0.4;
  --carousel-slide-active-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 20px 46px rgba(0, 0, 0, 0.38);
  position: relative;
  isolation: isolate;
  width: var(--carousel-slide-width);
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.026)),
    var(--section-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.34);
  opacity: var(--carousel-slide-opacity);
  scroll-snap-align: center;
  transition: opacity 0.22s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.carousel-slide.is-active,
.carousel-slide.is-carousel-focus {
  --carousel-slide-opacity: 1;
}

.carousel-slide.is-active {
  box-shadow: var(--carousel-slide-active-shadow);
}

.carousel-slide.is-clickable-preview {
  cursor: pointer;
}

.carousel-slide video {
  width: 100%;
  height: var(--carousel-media-height);
  display: block;
  aspect-ratio: var(--carousel-media-aspect);
  object-fit: cover;
  background: var(--section-bg);
}

.carousel-control-row {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin: clamp(14px, 1.55vw, 20px) auto 0;
}

.carousel-indicator {
  --carousel-indicator-gap: 7px;
  --carousel-dot-size: 14px;
  --carousel-dot-marker-size: 6px;
  --carousel-dot-active-size: 16px;
  --carousel-dot-active-marker-size: 8px;
  --carousel-dot-active-border: rgba(118, 185, 0, 0.72);
  --carousel-dot-active-shadow:
    inset 0 0 0 1px rgba(118, 185, 0, 0.2),
    0 0 16px rgba(118, 185, 0, 0.28);
  position: relative;
  z-index: 3;
  width: fit-content;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: var(--carousel-indicator-gap);
  min-height: 32px;
  margin: 0;
  padding: 7px 9px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028)),
    rgba(8, 8, 8, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.26);
}

.carousel-indicator[hidden] {
  display: none;
}

.media-control.carousel-volume-toggle {
  flex: 0 0 auto;
  width: auto;
  min-width: 86px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 0 12px 0 10px;
  border-radius: 999px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 12px 26px rgba(0, 0, 0, 0.26);
}

.media-control.carousel-volume-toggle:not(.is-muted) {
  border-color: rgba(118, 185, 0, 0.7);
  background:
    linear-gradient(180deg, rgba(118, 185, 0, 0.28), rgba(118, 185, 0, 0.1)),
    rgba(81, 127, 0, 0.32);
}

.carousel-volume-toggle img {
  width: 16px;
  height: 16px;
}

.media-control.carousel-volume-toggle.is-muted::after {
  border-radius: 999px;
}

.carousel-volume-label {
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1;
  color: rgba(255, 255, 255, 0.9);
}

.carousel-autoslide-label {
  flex: 0 0 auto;
  margin-left: 4px;
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
  color: rgba(255, 255, 255, 0.56);
  white-space: nowrap;
}

.carousel-autoslide-toggle {
  position: relative;
  flex: 0 0 auto;
  width: 30px;
  height: 16px;
  margin-left: 0;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  appearance: none;
  -webkit-appearance: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.035)),
    rgba(255, 255, 255, 0.08);
  cursor: pointer;
  opacity: 0.86;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.carousel-autoslide-toggle::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 3px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.46);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.28);
  transform: translateY(-50%);
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.carousel-autoslide-toggle:hover {
  border-color: rgba(255, 255, 255, 0.25);
  opacity: 1;
}

.carousel-autoslide-toggle:focus-visible {
  outline: 2px solid #76b900;
  outline-offset: 4px;
}

.carousel-autoslide-toggle.is-enabled {
  border-color: rgba(118, 185, 0, 0.62);
  background:
    linear-gradient(180deg, rgba(118, 185, 0, 0.32), rgba(118, 185, 0, 0.13)),
    rgba(118, 185, 0, 0.14);
  box-shadow:
    inset 0 0 0 1px rgba(118, 185, 0, 0.12),
    0 0 12px rgba(118, 185, 0, 0.18);
}

.carousel-autoslide-toggle.is-enabled::before {
  background: linear-gradient(180deg, rgba(191, 236, 118, 0.98), #76b900);
  box-shadow: 0 0 8px rgba(118, 185, 0, 0.34);
  transform: translate(14px, -50%);
}

.carousel-dot {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: var(--carousel-dot-size);
  height: var(--carousel-dot-size);
  padding: 2px;
  border: 1px solid transparent;
  border-radius: 999px;
  appearance: none;
  -webkit-appearance: none;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  opacity: 0.82;
  transition: width 0.2s ease, height 0.2s ease, background 0.2s ease, border-color 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}

.carousel-dot::before {
  content: "";
  display: block;
  width: var(--carousel-dot-marker-size);
  height: var(--carousel-dot-marker-size);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition: background 0.2s ease, box-shadow 0.2s ease;
}

.carousel-dot:hover {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.13);
  opacity: 1;
}

.carousel-dot.is-active {
  width: var(--carousel-dot-active-size);
  height: var(--carousel-dot-active-size);
  border-color: var(--carousel-dot-active-border);
  background: rgba(118, 185, 0, 0.14);
  box-shadow: var(--carousel-dot-active-shadow);
  opacity: 1;
}

.carousel-dot.is-active::before {
  width: var(--carousel-dot-active-marker-size);
  height: var(--carousel-dot-active-marker-size);
  background: linear-gradient(180deg, rgba(170, 217, 96, 0.98), #76b900);
  box-shadow: 0 0 8px rgba(118, 185, 0, 0.32);
}

.carousel-dot:focus-visible {
  outline: 2px solid #76b900;
  outline-offset: 4px;
}

.carousel-dot--window.is-active {
  width: calc(var(--carousel-dot-active-marker-size) + var(--carousel-dot-active-marker-size) + var(--carousel-indicator-gap) + 6px);
  height: var(--carousel-dot-active-size);
  display: grid;
  grid-template-columns: repeat(2, var(--carousel-dot-active-marker-size));
  gap: var(--carousel-indicator-gap);
  justify-content: center;
  align-content: center;
  border-color: var(--carousel-dot-active-border);
  background: rgba(118, 185, 0, 0.14);
  box-shadow: var(--carousel-dot-active-shadow);
}

.carousel-dot--window.is-active::before,
.carousel-dot--window.is-active::after {
  content: "";
  display: block;
  width: var(--carousel-dot-active-marker-size);
  height: var(--carousel-dot-active-marker-size);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(170, 217, 96, 0.98), #76b900);
  box-shadow: 0 0 8px rgba(118, 185, 0, 0.32);
}

.vision-language-carousel {
  --image-grid-gap: 16px;
  --image-peek-width: clamp(72px, 8vw, 112px);
  --image-tile-size: calc((min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2))) - var(--image-grid-gap) - var(--image-peek-width)) / 2);
  --carousel-media-height: var(--image-tile-size);
  --carousel-media-aspect: 1 / 1;
  --carousel-slide-width: var(--image-tile-size);
  --carousel-edge-fade: min(clamp(22px, 3vw, 42px), calc(var(--image-peek-width) / 2));
  width: min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2)));
}

.vision-language-carousel .carousel-viewport {
  scroll-padding-inline: calc(var(--image-peek-width) / 2);
}

.vision-language-carousel .carousel-track {
  grid-auto-columns: var(--image-tile-size);
  grid-template-rows: var(--image-tile-size);
  gap: var(--image-grid-gap);
}

.vision-language-carousel .carousel-slide {
  --carousel-slide-active-shadow: none;
  width: var(--image-tile-size);
  height: var(--image-tile-size);
  display: block;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  scroll-snap-align: start;
}

.vision-language-card {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  display: grid;
  grid-template-rows: 56.25% minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.026)),
    var(--section-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 16px 38px rgba(0, 0, 0, 0.34);
}

.vision-language-media {
  position: relative;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: #080808;
}

.vision-language-media > img,
.vision-language-media > video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vision-language-media > img {
  object-fit: cover;
  background: #080808;
}

.carousel-slide .vision-language-media > video {
  aspect-ratio: auto;
}

.vision-annotation-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.14s ease;
}

.vision-language-media.is-annotation-active .vision-annotation-layer {
  opacity: 1;
}

.vision-annotation-dot {
  position: absolute;
  left: var(--vision-annotation-x, 50%);
  top: var(--vision-annotation-y, 50%);
  width: 14px;
  height: 14px;
  display: none;
  border: 2px solid rgba(255, 255, 255, 0.92);
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.35);
  transform: translate(-50%, -50%);
}

.vision-annotation-label {
  position: absolute;
  left: var(--vision-label-x, calc(var(--vision-annotation-x, 50%) + 13px));
  top: var(--vision-label-y, calc(var(--vision-annotation-y, 50%) - 13px));
  max-width: var(--vision-label-max-width, calc(100% - 18px));
  display: none;
  padding: 5px 8px;
  border: 1px solid rgba(118, 185, 0, 0.55);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.72);
  color: #fff;
  font-size: clamp(0.56rem, 0.76vw, 0.7rem);
  font-weight: 500;
  line-height: 1.18;
  overflow: visible;
  overflow-wrap: normal;
  text-overflow: clip;
  text-wrap: nowrap;
  white-space: nowrap;
  transform: none;
}

.vision-annotation-box {
  position: absolute;
  left: var(--vision-annotation-left, 0);
  top: var(--vision-annotation-top, 0);
  width: var(--vision-annotation-width, 0);
  height: var(--vision-annotation-height, 0);
  display: none;
  border: 2px solid var(--green);
  border-radius: 4px;
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(0, 0, 0, 0.38);
}

.vision-annotation-trajectory {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.vision-trajectory-line {
  fill: none;
  stroke: var(--green);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-opacity: 0.62;
  vector-effect: non-scaling-stroke;
}

.vision-trajectory-point {
  fill: var(--green);
  stroke: rgba(255, 255, 255, 0.92);
  stroke-width: 2;
  opacity: 0.5;
  vector-effect: non-scaling-stroke;
}

.vision-annotation-layer[data-vision-mode="point"] .vision-annotation-dot,
.vision-annotation-layer[data-vision-mode="point"] .vision-annotation-label,
.vision-annotation-layer[data-vision-mode="box"] .vision-annotation-box {
  display: block;
}

.vision-language-output {
  min-height: 0;
  overflow: auto;
  padding: clamp(10px, 1.2vw, 14px);
  border-top: 1px solid rgba(255, 255, 255, 0.19);
  background:
    linear-gradient(180deg, rgba(118, 185, 0, 0.08), rgba(255, 255, 255, 0.026) 34%),
    rgba(255, 255, 255, 0.028);
  box-shadow: inset 0 1px 0 rgba(118, 185, 0, 0.18);
  color: rgba(255, 255, 255, 0.76);
  font-size: clamp(0.65rem, 0.9vw, 0.82rem);
  line-height: 1.34;
  text-align: left;
}

.vision-language-output p {
  margin: 0;
}

.vision-language-output-text {
  margin: 0;
  color: inherit;
}

.vision-language-output-text p {
  margin: 0 0 0.7em;
}

.vision-language-output-text p:last-child {
  margin-bottom: 0;
}

.vision-language-step-list {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: 0.18em;
  line-height: 1.18;
}

.vision-language-step-list li::marker {
  color: var(--green);
  font-weight: 600;
}

.vision-tuple-pin {
  appearance: none;
  min-width: 0;
  margin: 0 0 0 0.46em;
  padding: 0.12em 0.42em;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(255, 181, 43, 0.68);
  border-radius: 999px;
  background: rgba(255, 181, 43, 0.1);
  color: #ffbf3f;
  font: inherit;
  font-size: 0.68em;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.01em;
  cursor: pointer;
  vertical-align: 0.08em;
  transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease;
}

.vision-tuple-pin:hover,
.vision-tuple-pin:focus-visible {
  border-color: rgba(255, 205, 77, 0.96);
  background: rgba(255, 181, 43, 0.22);
  color: #ffd76f;
  outline: none;
}

.vision-language-event-list {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.42em;
  font-family: inherit;
  line-height: 1.28;
}

.vision-language-time {
  color: var(--green);
  font-family: inherit;
  font-weight: 600;
}

.vision-language-output code {
  color: var(--green);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 0.94em;
}

.video-caption-text code {
  color: var(--green);
}

.vision-language-output strong {
  color: #fff;
  font-weight: 650;
}

.reason2gen-section .section-heading-block {
  margin-bottom: clamp(28px, 4vw, 50px);
}

.reason2gen-demo {
  width: min(calc(var(--page-max-width) * 0.8), calc((100vw - (var(--section-padding-x) * 2)) * 0.8));
  margin: 0 auto;
  display: grid;
  justify-items: center;
  gap: clamp(22px, 3vw, 34px);
}

.reason2gen-card {
  width: 100%;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.024)),
    var(--section-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 46px rgba(0, 0, 0, 0.34);
}

.reason2gen-panel {
  padding: clamp(16px, 1.8vw, 24px);
  background:
    linear-gradient(180deg, rgba(118, 185, 0, 0.08), rgba(255, 255, 255, 0.024) 42%),
    rgba(255, 255, 255, 0.028);
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(0.68rem, 0.82vw, 0.8rem);
  line-height: 1.42;
  text-align: left;
}

.reason2gen-panel + .reason2gen-video-frame,
.reason2gen-video-frame + .reason2gen-panel {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.reason2gen-panel p {
  margin: 0;
}

.reason2gen-output {
  max-height: clamp(180px, 21vw, 280px);
  overflow: auto;
  scrollbar-color: rgba(118, 185, 0, 0.72) rgba(255, 255, 255, 0.08);
  scrollbar-width: thin;
}

.reason2gen-output-text {
  display: grid;
  gap: 0.75em;
}

.reason2gen-panel code {
  color: var(--green);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 0.94em;
}

.reason2gen-video-frame {
  position: relative;
  overflow: hidden;
  background: #050505;
}

.reason2gen-video {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #050505;
}

.reason2gen-annotation-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.14s ease;
}

.reason2gen-video-frame.is-annotation-active .reason2gen-annotation-layer {
  opacity: 1;
}

.reason2gen-annotation-dot {
  position: absolute;
  left: var(--reason2gen-annotation-x, 50%);
  top: var(--reason2gen-annotation-y, 50%);
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255, 255, 255, 0.92);
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.35);
  transform: translate(-50%, -50%);
}

.reason2gen-annotation-label {
  position: absolute;
  left: var(--reason2gen-label-x, calc(var(--reason2gen-annotation-x, 50%) + 13px));
  top: var(--reason2gen-label-y, calc(var(--reason2gen-annotation-y, 50%) - 13px));
  max-width: var(--reason2gen-label-max-width, calc(100% - 24px));
  padding: 7px 10px;
  border: 1px solid rgba(118, 185, 0, 0.55);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.72);
  color: #fff;
  font-size: clamp(0.66rem, 0.82vw, 0.76rem);
  font-weight: 500;
  line-height: 1.15;
  overflow: visible;
  overflow-wrap: normal;
  text-overflow: clip;
  text-wrap: nowrap;
  white-space: nowrap;
  transform: none;
}

.reason2gen-pin {
  appearance: none;
  min-width: 0;
  margin: 0 0.32em;
  padding: 0.12em 0.42em;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(255, 181, 43, 0.68);
  border-radius: 999px;
  background: rgba(255, 181, 43, 0.1);
  color: #ffbf3f;
  font: inherit;
  font-size: 0.68em;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.01em;
  cursor: pointer;
  vertical-align: 0.08em;
  transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease;
}

.reason2gen-pin:hover,
.reason2gen-pin:focus-visible {
  border-color: rgba(255, 205, 77, 0.96);
  background: rgba(255, 181, 43, 0.22);
  color: #ffd76f;
  outline: none;
}

.reason2gen-step-list {
  margin: 0;
  padding-left: 1.35rem;
  display: grid;
  gap: 0.24em;
  line-height: 1.22;
}

.reason2gen-step-list li::marker {
  color: var(--green);
  font-weight: 650;
}

.reason2gen-mode-controls {
  width: min(100%, 760px);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  justify-content: center;
  align-items: center;
  gap: clamp(12px, 1.6vw, 18px);
}

.reason2gen-mode-btn {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: 9px 18px;
  cursor: pointer;
  border-width: 1px;
  font-size: clamp(0.76rem, 0.82vw, 0.88rem);
  white-space: nowrap;
  text-wrap: nowrap;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 18px 38px rgba(0, 0, 0, 0.36),
    0 0 32px rgba(118, 185, 0, 0.22);
}

.reason2gen-mode-btn.is-active {
  border-color: var(--green);
}

.reason2gen-mode-btn:not(.is-active) {
  border-color: rgba(255, 255, 255, 0.2);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.024)),
    rgba(8, 8, 8, 0.7);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.28);
  color: rgba(255, 255, 255, 0.78);
}

.reason2gen-mode-btn:not(.is-active):hover {
  border-color: rgba(118, 185, 0, 0.68);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(81, 127, 0, 0.28);
  color: #fff;
}

.reason2gen-volume-toggle {
  margin-left: 2px;
}

.reason2gen-volume-toggle .carousel-volume-label {
  white-space: nowrap;
  text-wrap: nowrap;
}

.reason2gen-action {
  display: grid;
  place-items: center;
  padding: clamp(22px, 3vw, 34px);
  border-top: 1px solid rgba(118, 185, 0, 0.42);
  background:
    radial-gradient(ellipse at center top, rgba(118, 185, 0, 0.16), rgba(118, 185, 0, 0.035) 48%, transparent 76%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.012)),
    rgba(8, 8, 8, 0.96);
}

@media (max-width: 920px) {
  .reason2gen-demo {
    width: 100%;
  }

  .reason2gen-mode-controls {
    width: min(100%, 640px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reason2gen-mode-btn {
    white-space: normal;
    text-wrap: balance;
    line-height: 1.15;
  }

  .reason2gen-volume-toggle {
    grid-column: 1 / -1;
    justify-self: center;
    margin-left: 0;
  }
}

@media (max-width: 639px) {
  .reason2gen-section .section-heading-block {
    margin-bottom: 24px;
  }

  .reason2gen-demo {
    width: 100%;
    gap: 18px;
  }

  .reason2gen-panel {
    padding: 13px;
    font-size: 0.7rem;
  }

  .reason2gen-output {
    max-height: 220px;
  }

  .reason2gen-pin {
    padding: 0.16em 0.48em;
    font-size: 0.74em;
  }

  .reason2gen-mode-controls {
    width: 100%;
    grid-template-columns: 1fr;
    gap: 9px;
  }

  .reason2gen-mode-btn {
    min-height: 42px;
    padding: 8px 12px;
    font-size: 0.74rem;
  }

  .reason2gen-volume-toggle {
    grid-column: auto;
    min-width: 94px;
    height: 34px;
  }

  .reason2gen-action {
    padding: 16px 13px 18px;
  }
}

.vision-language-media .vision-language-prompt {
  top: var(--result-overlay-gap);
  bottom: auto;
}

.vision-language-media .vision-language-prompt:hover,
.vision-language-media .vision-language-prompt:focus-visible,
.vision-language-media .vision-language-prompt.is-open {
  top: var(--result-overlay-gap);
  bottom: auto;
  width: calc(100% - (var(--result-overlay-gap) * 2));
}

.image-generation-carousel {
  --image-grid-gap: 16px;
  --image-peek-width: clamp(72px, 8vw, 112px);
  --image-tile-size: calc((min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2))) - var(--image-grid-gap) - var(--image-peek-width)) / 2);
  --carousel-media-height: var(--image-tile-size);
  --carousel-media-aspect: 1 / 1;
  --carousel-slide-width: var(--image-tile-size);
  --carousel-edge-fade: min(clamp(22px, 3vw, 42px), calc(var(--image-peek-width) / 2));
  width: min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2)));
}

.image-generation-carousel .carousel-viewport {
  scroll-padding-inline: calc(var(--image-peek-width) / 2);
}

.image-generation-carousel .carousel-track {
  grid-auto-columns: var(--image-tile-size);
  grid-template-rows: var(--image-tile-size);
  gap: var(--image-grid-gap);
}

.image-generation-carousel .carousel-slide {
  --carousel-slide-active-shadow: none;
  width: var(--image-tile-size);
  height: var(--image-tile-size);
  display: block;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  scroll-snap-align: start;
}

.image-generation-card {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.026)),
    var(--section-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 16px 38px rgba(0, 0, 0, 0.34);
}

.image-generation-card > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.image-generation-card .video-caption-reveal:hover,
.image-generation-card .video-caption-reveal:focus-visible,
.image-generation-card .video-caption-reveal.is-open {
  width: calc(100% - (var(--result-overlay-gap) * 2));
}

.video-overlay-card {
  position: relative;
  width: 100%;
  height: var(--carousel-media-height);
  aspect-ratio: var(--carousel-media-aspect);
  overflow: hidden;
  border-radius: inherit;
  background: #080808;
}

.video-overlay-card video {
  width: 100%;
  height: 100%;
}

.carousel-slide .video-overlay-card video {
  aspect-ratio: auto;
  object-fit: cover;
}

.result-video-card {
  position: relative;
  width: 100%;
  height: var(--carousel-media-height);
  aspect-ratio: var(--carousel-media-aspect);
  overflow: hidden;
  border-radius: inherit;
  background: #080808;
}

.result-video-card > video:not(.inset-placeholder-video) {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
}

.result-video-card .inset-placeholder-video {
  position: absolute;
  top: var(--result-overlay-gap);
  left: var(--result-overlay-gap);
  z-index: 1;
  width: 35%;
  height: auto;
  aspect-ratio: var(--carousel-media-aspect);
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 10px 26px rgba(0, 0, 0, 0.38);
  opacity: 0.6;
  pointer-events: none;
}

.result-video-card .inset-placeholder-video--right {
  right: var(--result-overlay-gap);
  left: auto;
}

.inset-video-label {
  position: absolute;
  top: calc(var(--result-overlay-gap) + clamp(7px, 0.8vw, 10px));
  left: calc(var(--result-overlay-gap) + clamp(5px, 0.7vw, 8px));
  z-index: 3;
  max-width: calc(35% - clamp(10px, 1.3vw, 16px));
  overflow: hidden;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(0.49rem, 0.7vw, 0.64rem);
  font-weight: 500;
  line-height: 1.16;
  text-overflow: ellipsis;
  white-space: nowrap;
  pointer-events: none;
}

.inset-video-label--right {
  right: calc(var(--result-overlay-gap) + clamp(5px, 0.7vw, 8px));
  left: auto;
  text-align: right;
}

#inverse-dynamics .result-video-card .inset-placeholder-video {
  z-index: 2;
  opacity: 1;
}

.video-caption-reveal {
  --caption-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --caption-control-size: 42px;
  --caption-width-duration: 0.22s;
  --caption-height-duration: 0.18s;
  --caption-height-delay: 0.08s;
  --caption-font-size: var(--cosmos3-caption-font-size);
  --caption-line-height: 1.25;
  --caption-padding: clamp(9px, 1vw, 13px);
  --caption-text-duration: 0.16s;
  --caption-text-delay: calc(var(--caption-height-delay) + var(--caption-height-duration));
  --caption-collapse-delay: var(--caption-text-duration);
  --caption-width-collapse-delay: calc(var(--caption-collapse-delay) + var(--caption-height-duration));
  --caption-return-delay: calc(var(--caption-width-collapse-delay) + var(--caption-width-duration));
  position: absolute;
  left: var(--result-overlay-gap);
  bottom: var(--result-overlay-gap);
  z-index: 3;
  box-sizing: border-box;
  width: var(--caption-control-size);
  height: var(--caption-control-size);
  min-height: var(--caption-control-size);
  max-height: var(--caption-control-size);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035)),
    rgba(8, 8, 8, 0.76);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(0, 0, 0, 0.28);
  color: #fff;
  font-size: var(--caption-font-size);
  line-height: var(--caption-line-height);
  text-align: left;
  transition:
    width var(--caption-width-duration) var(--caption-ease) var(--caption-width-collapse-delay),
    max-height var(--caption-height-duration) var(--caption-ease) var(--caption-collapse-delay),
    padding var(--caption-height-duration) var(--caption-ease) var(--caption-collapse-delay),
    background var(--caption-height-duration) ease var(--caption-collapse-delay),
    border-color var(--caption-height-duration) ease var(--caption-collapse-delay),
    box-shadow var(--caption-height-duration) ease var(--caption-collapse-delay);
}

.video-caption-icon {
  position: absolute;
  top: calc(var(--caption-control-size) / 2);
  left: calc(var(--caption-control-size) / 2);
  width: 18px;
  height: auto;
  max-height: 18px;
  object-fit: contain;
  opacity: 1;
  transform: translate(-50%, -50%);
  transition:
    opacity 0.12s ease var(--caption-return-delay),
    transform 0.12s ease var(--caption-return-delay);
}

.video-caption-text {
  display: block;
  width: 100%;
  min-width: 0;
  max-height: none;
  opacity: 0;
  overflow: visible;
  color: #fff;
  hyphens: auto;
  text-align: left;
  text-align-last: left;
  transform: translateY(4px);
  transition:
    opacity var(--caption-text-duration) ease,
    transform var(--caption-text-duration) ease;
  transition-delay: 0s;
}

.video-caption-text code {
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 0.94em;
}

.video-caption-reveal:hover,
.video-caption-reveal:focus-visible,
.video-caption-reveal.is-open {
  left: var(--result-overlay-gap);
  bottom: var(--result-overlay-gap);
  width: 60%;
  height: auto;
  max-height: calc(100% - var(--result-overlay-gap) - var(--result-overlay-gap));
  overflow: auto;
  padding: var(--caption-padding);
  border-radius: var(--radius);
  border-color: rgba(118, 185, 0, 0.5);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.035)),
    rgba(8, 8, 8, 0.88);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 14px 34px rgba(0, 0, 0, 0.36);
  transition:
    width var(--caption-width-duration) var(--caption-ease),
    max-height var(--caption-height-duration) var(--caption-ease) var(--caption-height-delay),
    padding var(--caption-height-duration) var(--caption-ease) var(--caption-height-delay),
    background var(--caption-height-duration) ease var(--caption-height-delay),
    border-color var(--caption-height-duration) ease var(--caption-height-delay),
    box-shadow var(--caption-height-duration) ease var(--caption-height-delay);
}

.video-caption-reveal:hover .video-caption-icon,
.video-caption-reveal:focus-visible .video-caption-icon,
.video-caption-reveal.is-open .video-caption-icon {
  opacity: 0;
  transform: translate(-50%, -50%);
  transition-delay: 0s;
}

.video-caption-reveal:hover .video-caption-text,
.video-caption-reveal:focus-visible .video-caption-text,
.video-caption-reveal.is-open .video-caption-text {
  opacity: 1;
  transform: translateY(0);
  transition-delay: var(--caption-text-delay);
}

@media (max-width: 920px) {
  .cosmos3-page {
    --cosmos3-hero-title-size: clamp(2.3rem, 4.32vw, 2.8rem);
    --cosmos3-hero-subtitle-size: clamp(1.06rem, 1.98vw, 1.29rem);
    --cosmos3-link-size: 0.95rem;
    --cosmos3-section-heading-size: clamp(1.48rem, 3.28vw, 1.81rem);
    --cosmos3-section-subheading-size: clamp(1.16rem, 2.33vw, 1.37rem);
    --cosmos3-section-body-size: 0.95rem;
    --cosmos3-omni-core-title-size: clamp(1.22rem, 2.85vw, 1.44rem);
    --cosmos3-omni-core-subtitle-size: clamp(0.74rem, 1.8vw, 0.87rem);
    --cosmos3-omni-core-label-size: 0.74rem;
    --cosmos3-omni-intro-size: 0.93rem;
    --cosmos3-omni-control-size: 0.93rem;
    --cosmos3-benchmark-label-size: 0.78rem;
    --cosmos3-benchmark-body-size: 0.91rem;
    --cosmos3-caption-font-size: 0.65rem;
  }

  .cosmos3-section {
    --section-padding-y: 52px;
  }

  .omni-section .section-heading-block {
    margin-bottom: 34px;
  }

  .omni-diagram-panel {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    padding-bottom: 8px;
    scrollbar-color: rgba(118, 185, 0, 0.7) rgba(255, 255, 255, 0.08);
    scrollbar-width: thin;
  }

  .omni-diagram-panel::-webkit-scrollbar {
    height: 8px;
  }

  .omni-diagram-panel::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 999px;
  }

  .omni-diagram-panel::-webkit-scrollbar-thumb {
    background: rgba(118, 185, 0, 0.72);
    border-radius: 999px;
  }

  .omni-diagram {
    min-width: 760px;
    grid-template-columns: minmax(136px, 156px) clamp(40px, 5vw, 56px) minmax(270px, 360px) clamp(40px, 5vw, 56px) minmax(136px, 156px);
    column-gap: 12px;
    row-gap: 5px;
  }

  .omni-core {
    min-width: 250px;
  }

  .omni-diagram-panel {
    --omni-core-subtitle-y: 19.2%;
  }

  .omni-modality {
    min-height: 58px;
    gap: 9px;
    padding: 0 11px;
  }

  .omni-modality-icon {
    flex-basis: 29px;
    width: 29px;
    height: 29px;
  }

  .omni-modality-icon::before {
    width: 29px;
    height: 29px;
  }

  .omni-modality-label {
    font-size: clamp(0.89rem, 1.8vw, 0.97rem);
  }

  .omni-controls {
    width: 100%;
    max-width: 820px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
  }

  .omni-control {
    height: auto;
    min-height: 46px;
    padding: 11px 22px;
    white-space: normal;
  }

  .image-generation-carousel,
  .vision-language-carousel {
    --image-grid-gap: 14px;
    --image-peek-width: clamp(60px, 8vw, 88px);
    --image-tile-size: calc((min(var(--page-max-width), calc(100vw - (var(--section-padding-x) * 2))) - var(--image-grid-gap) - var(--image-peek-width)) / 2);
  }

  .benchmark-card-grid {
    grid-template-columns: 1fr;
  }

  .benchmark-card {
    min-height: 250px;
  }

  .benchmark-summary-card {
    min-height: 0;
  }
}

@media (min-width: 640px) and (max-height: 720px) {
  .cosmos3-hero {
    --cosmos3-hero-title-top: 45%;
    --cosmos3-hero-subtitle-top: 60%;
    --cosmos3-hero-links-bottom: clamp(58px, 8.5vh, 86px);
  }
}

@media (min-width: 640px) and (max-height: 560px) {
  .cosmos3-hero {
    --cosmos3-hero-title-top: 40%;
    --cosmos3-hero-subtitle-top: 60%;
    --cosmos3-hero-links-bottom: 46px;
  }
}

@media (min-width: 640px) and (max-height: 440px) {
  .cosmos3-hero {
    --cosmos3-hero-title-top: 36%;
    --cosmos3-hero-subtitle-top: 60%;
    --cosmos3-hero-links-bottom: 38px;
  }
}

@media (max-width: 639px) {
  .cosmos3-page {
    --cosmos3-hero-title-size: clamp(1.9rem, 8.8vw, 2.34rem);
    --cosmos3-hero-subtitle-size: clamp(0.89rem, 3.9vw, 1.06rem);
    --cosmos3-link-size: 0.84rem;
    --cosmos3-section-heading-size: clamp(1.35rem, 5.7vw, 1.58rem);
    --cosmos3-section-subheading-size: clamp(1.12rem, 4.46vw, 1.29rem);
    --cosmos3-section-body-size: 0.89rem;
    --cosmos3-omni-core-title-size: 1.35rem;
    --cosmos3-omni-core-subtitle-size: 0.76rem;
    --cosmos3-omni-core-label-size: 0.67rem;
    --cosmos3-omni-intro-size: 0.86rem;
    --cosmos3-omni-control-size: 0.86rem;
    --cosmos3-benchmark-label-size: 0.74rem;
    --cosmos3-benchmark-body-size: 0.86rem;
    --cosmos3-caption-font-size: 0.64rem;
  }

  .cosmos3-hero {
    --cosmos3-hero-title-top: 48.5%;
    --cosmos3-hero-subtitle-top: 60.5%;
    --cosmos3-hero-links-bottom: 100px;
    min-height: 92vh;
    min-height: 92svh;
    padding: 76px 18px 98px;
  }

  .cosmos3-hero .project-title {
    width: min(680px, calc(100% - 36px));
  }

  .cosmos3-hero .project-subtitle {
    width: min(760px, calc(100% - 36px));
    line-height: 1.32;
  }

  .cosmos3-hero .project-subtitle span {
    display: block;
  }

  .cosmos3-hero .project-links {
    right: 18px;
    left: 18px;
    width: auto;
    display: grid;
    max-width: 360px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-right: auto;
    margin-left: auto;
  }

  .link-btn {
    min-height: 42px;
    padding: 9px 12px;
  }

  .cosmos3-hero .link-btn {
    min-height: 46px;
    padding: 10px 14px;
    font-size: 0.9rem;
  }

  .cosmos3-section {
    --section-padding-y: 40px;
    padding: var(--section-padding-y) 18px;
  }

  .section-heading-block {
    margin-bottom: 26px;
  }

  .omni-section .section-heading-block {
    margin-bottom: 30px;
  }

  #omni-title {
    line-height: 1.28;
  }

  .omni-title-modality,
  .omni-title-mobile-copy,
  .section-heading-block .nvidia-green {
    display: block;
  }

  .omni-title-desktop-copy {
    display: none;
  }

  #omni-title br {
    display: none;
  }

  .omni-section {
    padding-bottom: 12px;
  }

  .cosmos3-section.omni-controls-section {
    padding-top: 8px;
    padding-bottom: 80px;
  }

  .omni-diagram-panel {
    overflow-x: visible;
    padding-bottom: 0;
  }

  .omni-diagram {
    --omni-mobile-gap: 5px;
    min-width: 0;
    max-width: 390px;
    margin-right: auto;
    margin-left: auto;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    grid-template-rows: auto 30px auto 30px auto;
    column-gap: var(--omni-mobile-gap);
    row-gap: var(--omni-mobile-gap);
    padding: 4px 0 8px;
  }

  .omni-modality {
    width: 100%;
    max-width: none;
    min-height: 0;
    aspect-ratio: 1 / 1;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    border-radius: 12px;
    padding: 6px 4px;
    justify-self: center;
  }

  .omni-modality-icon {
    flex-basis: 26px;
    width: 26px;
    height: 26px;
  }

  .omni-modality-icon::before {
    width: 26px;
    height: 26px;
  }

  .omni-modality-label {
    max-width: 100%;
    font-size: clamp(0.61rem, 2.75vw, 0.74rem);
  }

  .omni-modality[data-side="input"][data-modality="text"] {
    grid-column: 1;
    grid-row: 1;
  }

  .omni-modality[data-side="input"][data-modality="image"] {
    grid-column: 2;
    grid-row: 1;
  }

  .omni-modality[data-side="input"][data-modality="video"] {
    grid-column: 3;
    grid-row: 1;
  }

  .omni-modality[data-side="input"][data-modality="audio"] {
    grid-column: 4;
    grid-row: 1;
  }

  .omni-modality[data-side="input"][data-modality="action"] {
    grid-column: 5;
    grid-row: 1;
  }

  .omni-modality[data-side="output"][data-modality="text"] {
    grid-column: 1;
    grid-row: 5;
  }

  .omni-modality[data-side="output"][data-modality="image"] {
    grid-column: 2;
    grid-row: 5;
  }

  .omni-modality[data-side="output"][data-modality="video"] {
    grid-column: 3;
    grid-row: 5;
  }

  .omni-modality[data-side="output"][data-modality="audio"] {
    grid-column: 4;
    grid-row: 5;
  }

  .omni-modality[data-side="output"][data-modality="action"] {
    grid-column: 5;
    grid-row: 5;
  }

  .omni-arrow {
    display: none;
  }

  .omni-arrow--in[data-modality="video"],
  .omni-arrow--out[data-modality="video"] {
    display: block;
    width: 24px;
    min-width: 0;
    max-width: 24px;
    justify-self: center;
    opacity: 0.24;
    transform: rotate(90deg);
  }

  .omni-arrow--in[data-modality="video"] {
    grid-column: 3;
    grid-row: 2;
  }

  .omni-arrow--out[data-modality="video"] {
    grid-column: 3;
    grid-row: 4;
  }

  .omni-arrow--in[data-modality="video"].is-mobile-flow-active,
  .omni-arrow--out[data-modality="video"].is-mobile-flow-active {
    opacity: 0.9;
  }

  .omni-core {
    grid-column: 2 / 5;
    grid-row: 3;
    width: 100%;
    min-width: 0;
    max-width: 260px;
    justify-self: center;
  }

  .omni-core-base {
    aspect-ratio: 320 / 132;
    transform: none;
  }

  .omni-core-title {
    top: 24%;
  }

  .omni-core-subtitle {
    top: 64%;
  }

  .omni-transformer,
  .omni-shared,
  .omni-core-label {
    display: none;
  }

  .omni-controls {
    max-width: 390px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .omni-control {
    min-height: 54px;
    padding: 9px 6px;
    font-size: clamp(0.61rem, 2.33vw, 0.7rem);
    white-space: normal;
  }

  .cosmos3-carousel {
    --carousel-media-height: calc((100vw - 36px) * 9 / 16);
    --carousel-slide-width: 100%;
    --carousel-edge-fade: 0px;
    --result-overlay-gap: 7px;
  }

  .cosmos3-carousel::before,
  .cosmos3-carousel::after {
    display: none;
  }

  .image-generation-carousel,
  .vision-language-carousel {
    --image-grid-gap: 10px;
    --image-peek-width: 48px;
    --image-tile-size: calc(100vw - 36px - var(--image-grid-gap) - var(--image-peek-width));
    --carousel-media-height: var(--image-tile-size);
    --carousel-slide-width: var(--image-tile-size);
    --carousel-edge-fade: 18px;
    width: calc(100vw - 36px);
  }

  .image-generation-carousel::before,
  .image-generation-carousel::after,
  .vision-language-carousel::before,
  .vision-language-carousel::after {
    display: block;
  }

  .carousel-track {
    gap: 12px;
  }

  .image-generation-carousel .carousel-track,
  .vision-language-carousel .carousel-track {
    gap: var(--image-grid-gap);
  }

  .image-generation-card,
  .vision-language-card {
    border-radius: 12px;
  }

  .vision-language-output {
    padding: 9px;
    line-height: 1.3;
  }

  .media-control {
    width: 36px;
    height: 36px;
    border-radius: 10px;
  }

  .video-caption-reveal {
    --caption-control-size: 36px;
    --caption-padding: 9px;
  }
}

@media (max-width: 639px) and (max-height: 740px) {
  .cosmos3-hero {
    --cosmos3-hero-title-top: 43%;
    --cosmos3-hero-subtitle-top: 57%;
    --cosmos3-hero-links-bottom: 58px;
  }
}

@media (max-width: 639px) and (max-height: 620px) {
  .cosmos3-hero {
    --cosmos3-hero-title-top: 38%;
    --cosmos3-hero-subtitle-top: 54%;
    --cosmos3-hero-links-bottom: 40px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .cosmos3-section.is-reveal-ready > * {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .media-control.volume-control.is-muted::after {
    animation: none;
    opacity: 0.8;
  }

  *,
  *::before,
  *::after {
    transition-duration: 0.001ms !important;
    animation-duration: 0.001ms !important;
  }
}
