/* landing-home-fixes-v3
   Narrow, source-of-truth overrides for the landing header panel, trusted-logo
   marquee, and hero/proof/media section spacing. Loaded after landing.css. */

:root {
  --landing-menu-inner-pad: clamp(9px, .85vw, 12px);
  --trusted-logo-gap: clamp(14px, 1.7vw, 30px);
  --trusted-logo-duration: 36s;
  --landing-proof-margin-top: clamp(28px, 3vw, 52px);
  --landing-hero-media-gap: clamp(30px, 3vw, 54px);
  --landing-hero-cta-gap: clamp(28px, 2.55vw, 44px);
}

/* Header dropdown: the panel stays anchored by existing JS/CSS; this reset removes
   inherited centering and keeps every row's content starting from the same inset. */
.site-bar.site-bar--landing .site-menu-shell .site-menu-panel,
#site-menu-panel.site-menu-panel {
  width: clamp(252px, 22vw, 336px) !important;
  max-width: calc(100vw - 16px) !important;
  padding: var(--landing-menu-inner-pad) !important;
  display: none !important;
  align-items: stretch !important;
  align-content: start !important;
  justify-items: stretch !important;
  justify-content: stretch !important;
  text-align: left !important;
}

.site-bar.site-bar--landing.is-menu-open .site-menu-shell .site-menu-panel,
.site-bar.site-bar--landing.is-menu-open #site-menu-panel.site-menu-panel {
  display: grid !important;
  gap: 8px !important;
}

#site-menu-panel .site-menu-panel__section,
#site-menu-panel .site-menu-panel__auth,
#site-menu-panel .site-menu,
#site-menu-panel .site-menu--main,
#site-menu-panel .site-menu--more,
#site-menu-panel .site-menu__dropdown,
#site-menu-panel .site-menu__dropdown-menu {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box !important;
  justify-items: stretch !important;
  justify-content: stretch !important;
  align-content: start !important;
  text-align: left !important;
}

#site-menu-panel .site-menu-panel__section {
  padding: 0 !important;
  gap: 6px !important;
}

#site-menu-panel .site-menu-panel__title {
  margin: 1px 0 3px !important;
  padding: 0 6px !important;
  text-align: left !important;
}

#site-menu-panel .site-menu,
#site-menu-panel .site-menu--main,
#site-menu-panel .site-menu--more {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 6px !important;
  padding: 0 !important;
}

#site-menu-panel .site-menu a,
#site-menu-panel .site-menu__trigger,
#site-menu-panel .site-account-link {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 38px !important;
  padding: 0 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  box-sizing: border-box !important;
  text-align: left !important;
  font-size: clamp(12px, .76vw, 13px) !important;
  line-height: 1.18 !important;
}

#site-menu-panel .site-menu__trigger-label,
#site-menu-panel .site-account-link span:not(.site-account-link__icon) {
  min-width: 0 !important;
  flex: 1 1 auto !important;
  text-align: left !important;
  overflow-wrap: anywhere !important;
}

#site-menu-panel .site-menu__trigger-arrow {
  flex: 0 0 auto !important;
  margin-left: auto !important;
}

#site-menu-panel .site-menu__dropdown {
  position: static !important;
  display: grid !important;
  overflow: visible !important;
}

#site-menu-panel .site-menu__dropdown-menu {
  position: static !important;
  inset: auto !important;
  display: none !important;
  margin-top: 6px !important;
  padding: 6px !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: none !important;
  overflow: hidden !important;
}

#site-menu-panel .site-menu__dropdown.is-open .site-menu__dropdown-menu,
#site-menu-panel .site-menu__dropdown:focus-within .site-menu__dropdown-menu {
  display: grid !important;
  gap: 5px !important;
}

#site-menu-panel .site-menu__download,
#site-menu-panel .site-menu__download.is-empty {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 36px !important;
  padding: 8px 10px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 2px !important;
  align-items: center !important;
  justify-items: start !important;
  text-align: left !important;
}

#site-menu-panel .site-menu__download strong,
#site-menu-panel .site-menu__download span {
  min-width: 0 !important;
  justify-self: start !important;
  text-align: left !important;
  white-space: normal !important;
}

#site-menu-panel .site-menu__download strong {
  font-size: 12.25px !important;
  line-height: 1.18 !important;
}

#site-menu-panel .site-menu__download span {
  font-size: 11.5px !important;
  line-height: 1.22 !important;
}

/* Trusted logos: the JS already emits two .logo-band__set rows, with the second
   copy aria-hidden. These rules make that duplicated track the animated surface. */
@keyframes utapTrustedLogoSetMarqueeLeft {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-100%, 0, 0); }
}

#hero-proof-row.hero-proof-row {
  margin-top: var(--landing-proof-margin-top) !important;
  gap: clamp(16px, 1.8vw, 28px) !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  gap: clamp(10px, 1vw, 16px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-trust-copy.trusted-label,
#hero-trust-copy.trust-copy,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  color: #4b5565 !important;
  opacity: .68 !important;
  font-weight: 400 !important;
  line-height: 1.45 !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .trusted-logo-marquee,
#hero-proof-row .logo-band {
  --trusted-logo-gap: clamp(14px, 1.7vw, 30px);
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: calc(var(--landing-trusted-logo-size, 156px) * .68) !important;
  margin: 0 !important;
  padding: clamp(8px, .9vw, 14px) 0 !important;
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 8% 50%, rgba(123, 92, 255, .08), transparent 30%),
    radial-gradient(circle at 92% 50%, rgba(20, 196, 184, .08), transparent 32%) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important;
}

#hero-brand-band.logo-band::before,
#hero-brand-band.logo-band::after,
#hero-proof-row .logo-band::before,
#hero-proof-row .logo-band::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track {
  display: flex !important;
  align-items: center !important;
  width: max-content !important;
  max-width: none !important;
  min-width: max-content !important;
  gap: 0 !important;
  animation: none !important;
  will-change: auto !important;
}

#hero-brand-band:hover .logo-band__set,
#hero-brand-band:focus-within .logo-band__set,
#hero-proof-row .logo-band:hover .logo-band__set,
#hero-proof-row .logo-band:focus-within .logo-band__set {
  animation-play-state: paused !important;
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  min-width: max-content !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  gap: var(--trusted-logo-gap) !important;
  margin: 0 !important;
  padding: 0 var(--trusted-logo-gap) 0 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  animation: utapTrustedLogoSetMarqueeLeft var(--trusted-logo-duration) linear infinite !important;
  will-change: transform !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  width: var(--trusted-logo-width, var(--landing-trusted-logo-size, 156px)) !important;
  min-width: var(--trusted-logo-width, var(--landing-trusted-logo-size, 156px)) !important;
  max-width: var(--trusted-logo-width, var(--landing-trusted-logo-size, 156px)) !important;
  min-height: calc(var(--trusted-logo-max-height, 90px) + 2px) !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: var(--trusted-logo-width, var(--landing-trusted-logo-size, 156px)) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: var(--trusted-logo-max-height, calc(var(--landing-trusted-logo-size, 156px) * .58)) !important;
  object-fit: contain !important;
  object-position: center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .12)) !important;
}

/* Hero/proof/media boundary: reduce the artificial spacer between Applications
   and the original-template/media row without using negative margins. */
.hero-bottom {
  margin-top: var(--landing-hero-media-gap) !important;
}

.hero-media-row.hero-media-row--original-first {
  gap: clamp(20px, 2.4vw, 38px) !important;
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track {
    width: 100% !important;
    min-width: 0 !important;
    animation: none !important;
    transform: none !important;
    will-change: auto !important;
  }

  #hero-brand-band .logo-band__set,
  #hero-proof-row .logo-band__set {
    width: 100% !important;
    min-width: 0 !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    padding-right: 0 !important;
    animation: none !important;
    transform: none !important;
    will-change: auto !important;
  }

  #hero-brand-band .logo-band__set[aria-hidden="true"],
  #hero-proof-row .logo-band__set[aria-hidden="true"] {
    display: none !important;
  }
}

@media (max-width: 980px) {
  :root {
    --landing-proof-margin-top: clamp(24px, 5vw, 42px);
    --landing-hero-media-gap: clamp(24px, 5vw, 42px);
    --trusted-logo-gap: clamp(16px, 5vw, 32px);
  }

  .site-bar.site-bar--landing .site-menu-shell .site-menu-panel,
  #site-menu-panel.site-menu-panel {
    width: calc(100vw - 16px) !important;
  }

  #hero-brand-band.logo-band,
  #hero-proof-row .trusted-logo-marquee,
  #hero-proof-row .logo-band {
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 142px)), 38vw) !important;
    min-width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 142px)), 38vw) !important;
    max-width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 142px)), 38vw) !important;
  }

  #hero-brand-band .logo-chip img,
  #hero-proof-row .logo-chip img {
    width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 142px)), 38vw) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --landing-proof-margin-top: clamp(20px, 6vw, 34px);
    --landing-hero-media-gap: clamp(20px, 6vw, 34px);
    --trusted-logo-gap: clamp(14px, 6vw, 26px);
  }

  #site-menu-panel .site-menu a,
  #site-menu-panel .site-menu__trigger,
  #site-menu-panel .site-account-link {
    min-height: 40px !important;
    padding-inline: 9px !important;
    font-size: 13px !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip,
  #hero-brand-band .logo-chip img,
  #hero-proof-row .logo-chip img {
    width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 136px)), 42vw) !important;
    min-width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 136px)), 42vw) !important;
    max-width: min(var(--trusted-logo-width, var(--landing-trusted-logo-size, 136px)), 42vw) !important;
  }
}

/* Hero/template showcase: keep templates in one continuous row. The motion is
   carried by the duplicated track; hover/focus/tap only lifts a card visually,
   so the document never grows into a blank expanded area. */
:root {
  --trusted-section-width: min(100%, calc(100vw - clamp(20px, 4vw, 72px)));
  --hero-media-section-width: min(100%, 1540px);
  --hero-showcase-gap: clamp(16px, 1.65vw, 30px);
}

#hero-proof-row.hero-proof-row {
  grid-column: 1 / -1 !important;
  width: var(--trusted-section-width) !important;
  max-width: var(--trusted-section-width) !important;
  justify-self: center !important;
}

#hero-proof-row:has(> .hero-side-box[hidden]) .trusted-section,
#hero-proof-row:has(> .hero-side-box[hidden]) .hero-proof-row__brands,
#hero-proof-row:has(> .hero-side-box[data-utap-public-hidden="1"]) .trusted-section,
#hero-proof-row:has(> .hero-side-box[data-utap-public-hidden="1"]) .hero-proof-row__brands {
  grid-column: 1 / -1 !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: none !important;
  padding-inline: clamp(4px, .7vw, 12px) !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .trusted-logo-marquee,
#hero-proof-row .logo-band {
  --trusted-logo-gap: clamp(10px, 1.15vw, 22px);
  min-height: calc(var(--landing-trusted-logo-size, 156px) * .72) !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 1.35%, #000 98.65%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 1.35%, #000 98.65%, transparent 100%) !important;
}

.hero-bottom {
  width: var(--hero-media-section-width) !important;
  max-width: var(--hero-media-section-width) !important;
  justify-self: center !important;
}

.hero-media-row.hero-media-row--original-first {
  width: 100% !important;
  max-width: none !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(22px, 2.4vw, 38px) !important;
  overflow: visible !important;
}

.hero-gallery,
.hero-image-panel {
  overflow: visible !important;
}

.hero-media-row .hero-gallery__viewport,
#hero-gallery-viewport,
#hero-gallery-viewport .hero-carousel,
#hero-gallery-viewport .hero-carousel__mask {
  height: auto !important;
  min-height: 0 !important;
}

#hero-gallery-viewport,
#hero-gallery-viewport .hero-carousel__mask {
  overflow: hidden !important;
}

#hero-gallery-viewport .hero-carousel__track {
  display: flex !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
}

#hero-gallery-viewport .hero-carousel__set,
#hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  gap: var(--hero-showcase-gap) !important;
  padding-right: var(--hero-showcase-gap) !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  filter: none !important;
}

#hero-gallery-viewport .hero-carousel__slide::after {
  content: "Click to preview" !important;
}

#hero-gallery-viewport .hero-carousel__slide:has(video)::after,
#hero-gallery-viewport .hero-carousel__slide:has(.pdf-embed)::after,
#hero-gallery-viewport .hero-carousel__slide:has(.document-thumb)::after {
  content: "Click to preview" !important;
  display: inline-flex !important;
}

.hero-image-panel__viewport {
  transition:
    box-shadow 260ms ease,
    border-color 260ms ease !important;
}

.hero-image-panel__viewport.is-expanded,
.hero-image-panel__viewport:has(.hero-image-panel__zoom:hover),
.hero-image-panel__viewport:has(.hero-image-panel__zoom:focus-visible),
.hero-image-panel__viewport:has(.hero-image-panel__zoom:focus-within) {
  border-color: rgba(109, 71, 217, .22) !important;
  box-shadow: 0 22px 56px rgba(37, 35, 79, .12), 0 10px 26px rgba(91, 92, 240, .08) !important;
}

.hero-image-panel__zoom {
  cursor: zoom-in !important;
}

.hero-image-panel__viewport.is-expanded .hero-image-panel__zoom,
.hero-image-panel__zoom:hover,
.hero-image-panel__zoom:focus-visible {
  cursor: zoom-out !important;
}

.hero-image-panel__viewport.is-expanded .hero-image-panel__zoom-hint,
.hero-image-panel__zoom:hover .hero-image-panel__zoom-hint,
.hero-image-panel__zoom:focus-visible .hero-image-panel__zoom-hint {
  opacity: 1 !important;
  transform: translateX(-50%) translateY(0) !important;
}


.hero-image-lightbox__dialog {
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: 12px !important;
}

.hero-image-lightbox__stage {
  display: grid !important;
  place-items: center !important;
  min-width: 0 !important;
  min-height: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.hero-image-lightbox__frame {
  display: block !important;
  width: min(1180px, calc(100vw - clamp(24px, 6vw, 96px))) !important;
  height: min(760px, calc(100vh - clamp(72px, 10vw, 140px))) !important;
  border: 0 !important;
  border-radius: clamp(14px, 1.2vw, 22px) !important;
  background: #fff !important;
  box-shadow: 0 34px 96px rgba(0, 0, 0, .38) !important;
}

.hero-image-lightbox__caption:not([hidden]) {
  display: grid !important;
  justify-self: center !important;
  max-width: min(760px, calc(100vw - 40px)) !important;
  gap: 4px !important;
  padding: 10px 14px !important;
  border-radius: 16px !important;
  background: rgba(255, 255, 255, .90) !important;
  color: #25234f !important;
  text-align: center !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, .18) !important;
}

.hero-image-lightbox__caption[hidden] {
  display: none !important;
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel__track {
    width: 100% !important;
    min-width: 0 !important;
    animation: none !important;
    transform: none !important;
    overflow-x: auto !important;
    scroll-snap-type: x proximity !important;
    -webkit-overflow-scrolling: touch !important;
  }

  #hero-gallery-viewport .hero-carousel__set {
    min-width: 0 !important;
  }

  #hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
    display: none !important;
  }

  .hero-image-panel__viewport,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}

@media (max-width: 980px) {
  :root {
    --trusted-section-width: min(100%, 100vw - 20px);
    --hero-media-section-width: min(100%, 100vw - 28px);
    --trusted-logo-gap: clamp(10px, 3vw, 22px);
  }

  #hero-brand-band.logo-band,
  #hero-proof-row .trusted-logo-marquee,
  #hero-proof-row .logo-band {
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 3%, #000 97%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 3%, #000 97%, transparent 100%) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --trusted-logo-gap: clamp(8px, 4vw, 18px);
  }

  .hero-image-lightbox__frame {
    width: calc(100vw - 24px) !important;
    height: calc(100vh - 84px) !important;
  }
}

/* landing-home-fixes-v4
   Final polish for the continuous template showcase, clean image viewer, and
   wider trusted-logo coverage. Keep this last so it owns the public landing
   layout boundary without touching unrelated styles. */

:root {
  --trusted-section-width: min(1760px, calc(100vw - clamp(10px, 1.4vw, 28px)));
  --trusted-logo-gap: clamp(18px, 2.25vw, 48px);
  --hero-showcase-gap: clamp(28px, 2.65vw, 56px);
}

/* Hero/template strip: more breathing room without changing the card geometry.
   Hover/focus/tap still uses transform only, so the row never grows or creates
   a blank expanded area. */
#hero-gallery-viewport .hero-carousel {
  --hero-showcase-gap: clamp(28px, 2.65vw, 56px) !important;
  --hero-showcase-duration: 48s !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  padding-top: clamp(14px, 1.2vw, 20px) !important;
  padding-bottom: clamp(24px, 1.8vw, 34px) !important;
}

#hero-gallery-viewport .hero-carousel__set,
#hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
  gap: var(--hero-showcase-gap) !important;
  padding-right: var(--hero-showcase-gap) !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover,
#hero-gallery-viewport .hero-carousel__slide:focus-visible,
#hero-gallery-viewport .hero-carousel__slide:focus-within,
#hero-gallery-viewport .hero-carousel__slide.is-active {
  transform: translate3d(0, -8px, 0) scale(1.035) !important;
}

/* Trusted logos: full-bleed inside the hero shell, close to browser edges while
   preserving logo sizing variables and transparent/floating presentation. */
#hero-proof-row.hero-proof-row {
  width: var(--trusted-section-width) !important;
  max-width: var(--trusted-section-width) !important;
  position: relative !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-inline: 0 !important;
  justify-self: center !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  padding-inline: 0 !important;
}

#hero-trust-copy.trusted-label,
#hero-trust-copy.trust-copy,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  padding-inline: clamp(8px, 1.1vw, 18px) !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .trusted-logo-marquee,
#hero-proof-row .logo-band {
  --trusted-logo-gap: clamp(18px, 2.25vw, 48px);
  width: 100% !important;
  max-width: none !important;
  padding-inline: 0 !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 .85%, #000 99.15%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 .85%, #000 99.15%, transparent 100%) !important;
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"] {
  gap: var(--trusted-logo-gap) !important;
  padding-right: var(--trusted-logo-gap) !important;
}

/* Image viewer: no upload/helper text, no card footer, no crop. The stage is
   viewport-bounded and contains the selected media at its natural aspect ratio. */
.hero-image-lightbox {
  padding: clamp(12px, 2.2vw, 34px) !important;
}

.hero-image-lightbox__dialog {
  width: auto !important;
  max-width: calc(100vw - clamp(24px, 4vw, 68px)) !important;
  height: auto !important;
  max-height: calc(100svh - clamp(24px, 4vw, 68px)) !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) !important;
  place-items: center !important;
  gap: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: clamp(18px, 1.6vw, 28px) !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.hero-image-lightbox__stage {
  display: grid !important;
  place-items: center !important;
  width: auto !important;
  max-width: calc(100vw - clamp(24px, 4vw, 68px)) !important;
  height: auto !important;
  max-height: calc(100svh - clamp(24px, 4vw, 68px)) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: auto !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
  border-radius: clamp(16px, 1.35vw, 24px) !important;
}

.hero-image-lightbox__image,
.hero-image-lightbox__media {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: calc(100svh - clamp(32px, 5vw, 84px)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  aspect-ratio: auto !important;
  border-radius: clamp(16px, 1.35vw, 24px) !important;
  background: #fff !important;
  box-shadow: 0 34px 96px rgba(0, 0, 0, .38) !important;
}

.hero-image-lightbox__frame {
  width: min(1180px, calc(100vw - clamp(24px, 4vw, 68px))) !important;
  height: min(820px, calc(100svh - clamp(32px, 5vw, 84px))) !important;
  max-width: 100% !important;
  max-height: calc(100svh - clamp(32px, 5vw, 84px)) !important;
}

.hero-image-lightbox__caption,
.hero-image-lightbox__caption:not([hidden]) {
  display: none !important;
}

.hero-image-lightbox__close {
  top: clamp(-18px, -1.1vw, -10px) !important;
  right: clamp(-18px, -1.1vw, -10px) !important;
  z-index: 5 !important;
}

@supports not (height: 100svh) {
  .hero-image-lightbox__dialog,
  .hero-image-lightbox__stage {
    max-height: calc(100vh - clamp(24px, 4vw, 68px)) !important;
  }

  .hero-image-lightbox__image,
  .hero-image-lightbox__media,
  .hero-image-lightbox__frame {
    max-height: calc(100vh - clamp(32px, 5vw, 84px)) !important;
  }
}

@media (max-width: 980px) {
  :root {
    --trusted-section-width: calc(100vw - 12px);
    --trusted-logo-gap: clamp(14px, 4vw, 34px);
    --hero-showcase-gap: clamp(20px, 4vw, 36px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: clamp(20px, 4vw, 36px) !important;
    --hero-showcase-duration: 40s !important;
  }
}

@media (max-width: 560px) {
  :root {
    --trusted-section-width: calc(100vw - 10px);
    --trusted-logo-gap: clamp(10px, 4vw, 22px);
    --hero-showcase-gap: 18px;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: 18px !important;
  }

  .hero-image-lightbox {
    padding: 10px !important;
  }

  .hero-image-lightbox__dialog,
  .hero-image-lightbox__stage {
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100svh - 20px) !important;
  }

  .hero-image-lightbox__image,
  .hero-image-lightbox__media,
  .hero-image-lightbox__frame {
    max-height: calc(100svh - 28px) !important;
  }

  .hero-image-lightbox__close {
    top: 8px !important;
    right: 8px !important;
  }
}

/* landing-home-fixes-v5
   Template cards now own enough vertical space for full-design previews.
   This keeps the existing marquee, viewer, and lift interaction intact while
   making the carousel media use real contain behavior instead of filling and
   risking clipped bottoms. */
:root {
  --trusted-section-width: calc(100vw - clamp(6px, 1vw, 18px));
  --hero-showcase-gap: clamp(26px, 2.35vw, 48px);
  --hero-showcase-card-width: clamp(238px, 18vw, 340px);
  --hero-showcase-card-height: clamp(370px, 28vw, 540px);
  --hero-showcase-card-pad: clamp(12px, 1.1vw, 20px);
}

#hero-proof-row.hero-proof-row {
  width: var(--trusted-section-width) !important;
  max-width: var(--trusted-section-width) !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .trusted-logo-marquee,
#hero-proof-row .logo-band {
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 .5%, #000 99.5%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 .5%, #000 99.5%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-gap: clamp(26px, 2.35vw, 48px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-showcase-duration: 52s !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  padding-top: clamp(16px, 1.4vw, 24px) !important;
  padding-bottom: clamp(28px, 2vw, 40px) !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  flex-basis: var(--hero-showcase-card-width) !important;
  width: var(--hero-showcase-card-width) !important;
  min-width: var(--hero-showcase-card-width) !important;
  height: var(--hero-showcase-card-height) !important;
}

#hero-gallery-viewport .hero-carousel__card {
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: var(--hero-showcase-card-pad) !important;
  overflow: hidden !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  flex: 0 1 auto !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  aspect-ratio: auto !important;
  border-radius: calc(var(--hero-showcase-radius, 24px) - 8px) !important;
  background: transparent !important;
}

#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  box-sizing: border-box !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
}

@media (max-width: 980px) {
  :root {
    --trusted-section-width: calc(100vw - 10px);
    --hero-showcase-gap: clamp(22px, 4vw, 38px);
    --hero-showcase-card-width: clamp(224px, 35vw, 320px);
    --hero-showcase-card-height: clamp(350px, 52vw, 500px);
    --hero-showcase-card-pad: clamp(10px, 2vw, 16px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: clamp(22px, 4vw, 38px) !important;
    --hero-showcase-card-width: clamp(224px, 35vw, 320px) !important;
    --hero-showcase-card-height: clamp(350px, 52vw, 500px) !important;
    --hero-showcase-duration: 44s !important;
  }
}

@media (max-width: 560px) {
  :root {
    --trusted-section-width: calc(100vw - 8px);
    --hero-showcase-gap: 20px;
    --hero-showcase-card-width: min(78vw, 300px);
    --hero-showcase-card-height: clamp(360px, 112vw, 500px);
    --hero-showcase-card-pad: 10px;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: 20px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-showcase-duration: 38s !important;
  }

  #hero-gallery-viewport .hero-carousel__slide:hover,
  #hero-gallery-viewport .hero-carousel__slide:focus-visible,
  #hero-gallery-viewport .hero-carousel__slide:focus-within,
  #hero-gallery-viewport .hero-carousel__slide.is-active {
    transform: translate3d(0, -5px, 0) scale(1.025) !important;
  }
}

/* landing-home-fixes-v6
   Transparent floating template previews, left-moving showcase motion, and
   pointer drag/swipe support. Keep this last so it owns only the public hero
   carousel boundary while preserving the current lightbox and trusted-logo row. */
@keyframes utapHeroTemplateShowcaseLeft {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-50%, 0, 0); }
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-gap: clamp(30px, 2.8vw, 60px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-showcase-card-pad: clamp(8px, .75vw, 14px) !important;
  --hero-showcase-duration: 54s !important;
  cursor: grab !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging {
  cursor: grabbing !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  touch-action: pan-y !important;
  cursor: inherit !important;
  padding-top: clamp(18px, 1.5vw, 26px) !important;
  padding-bottom: clamp(30px, 2.2vw, 46px) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel__set,
#hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
  gap: var(--hero-showcase-gap) !important;
  padding-right: var(--hero-showcase-gap) !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  touch-action: pan-y !important;
  cursor: zoom-in !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging .hero-carousel__slide,
#hero-gallery-viewport .hero-carousel.is-pointer-ready .hero-carousel__slide {
  cursor: grabbing !important;
}

#hero-gallery-viewport .hero-carousel__card {
  padding: var(--hero-showcase-card-pad) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;
  filter: none !important;
  transition: filter 300ms cubic-bezier(.22,.61,.36,1), transform 300ms cubic-bezier(.22,.61,.36,1) !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide:focus-visible .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide:focus-within .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide.is-active .hero-carousel__card {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  filter: drop-shadow(0 26px 44px rgba(37, 35, 79, .22)) drop-shadow(0 10px 24px rgba(91, 92, 240, .12)) !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  flex: 0 1 auto !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  aspect-ratio: auto !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-user-drag: none !important;
  pointer-events: none !important;
}

#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging .hero-carousel__slide::after {
  opacity: 0 !important;
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
    transform: none !important;
  }
}

@media (max-width: 980px) {
  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: clamp(24px, 4.4vw, 42px) !important;
    --hero-showcase-card-width: clamp(224px, 35vw, 320px) !important;
    --hero-showcase-card-height: clamp(350px, 52vw, 500px) !important;
    --hero-showcase-card-pad: clamp(8px, 1.6vw, 12px) !important;
    --hero-showcase-duration: 46s !important;
  }
}

@media (max-width: 560px) {
  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: 24px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-showcase-card-pad: 8px !important;
    --hero-showcase-duration: 40s !important;
  }
}

/* landing-home-fixes-v7
   Final carousel substrate:
   - no visible gallery/card box around template previews
   - leftward infinite marquee
   - click/tap owned by the slide button, not child media
   - drag state is frozen/resumed by JS using animation-delay
*/
.hero-gallery {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

.hero-gallery__viewport {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#hero-gallery-viewport {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

@keyframes utapHeroTemplateShowcaseLeft {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-50%, 0, 0); }
}

#hero-gallery-viewport .hero-carousel {
  cursor: grab !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging {
  cursor: grabbing !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
  touch-action: pan-y !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  cursor: zoom-in !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
  touch-action: pan-y !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging .hero-carousel__slide,
#hero-gallery-viewport .hero-carousel.is-pointer-ready .hero-carousel__slide {
  cursor: grabbing !important;
}

#hero-gallery-viewport .hero-carousel__card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;
  filter: none !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide:focus-visible .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide:focus-within .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__slide.is-active .hero-carousel__card {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  filter: drop-shadow(0 26px 44px rgba(37, 35, 79, .20)) drop-shadow(0 10px 24px rgba(91, 92, 240, .10)) !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-user-drag: none !important;
}

#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging .hero-carousel__slide::after,
#hero-gallery-viewport .hero-carousel.is-pointer-ready .hero-carousel__slide::after {
  opacity: 0 !important;
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
    transform: none !important;
  }
}



/* landing-home-fixes-v8
   Desktop arrows replace desktop mouse dragging. Touch swipe remains touch-only
   through landing.js. The marquee keeps moving left after arrow nudges, and the
   template/trusted rows use the viewport width without stretching media. */
:root {
  --trusted-section-width: calc(100vw - clamp(4px, .8vw, 16px));
  --hero-media-section-width: calc(100vw - clamp(6px, 1vw, 18px));
  --hero-showcase-gap: clamp(24px, 2.3vw, 48px);
}

#hero-brand-band,
#hero-proof-row,
#hero-brand-band.logo-band,
#hero-proof-row .trusted-logo-marquee,
#hero-proof-row .logo-band {
  width: var(--trusted-section-width) !important;
  max-width: var(--trusted-section-width) !important;
}

.hero-bottom {
  width: var(--hero-media-section-width) !important;
  max-width: var(--hero-media-section-width) !important;
  justify-self: center !important;
}

.hero-media-row.hero-media-row--original-first {
  width: 100% !important;
  max-width: none !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(18px, 2vw, 34px) !important;
  overflow: visible !important;
}

.hero-gallery,
.hero-gallery__viewport,
#hero-gallery-viewport {
  width: 100% !important;
  max-width: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-gap: clamp(24px, 2.3vw, 48px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-carousel-nav-size: clamp(38px, 3vw, 48px) !important;
  width: 100% !important;
  max-width: none !important;
  padding-left: clamp(10px, 1.1vw, 20px) !important;
  padding-right: clamp(10px, 1.1vw, 20px) !important;
  cursor: default !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#hero-gallery-viewport .hero-carousel.is-dragging {
  cursor: default !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  overflow: hidden !important;
  touch-action: pan-y !important;
  cursor: default !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 2%, #000 98%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 2%, #000 98%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track {
  animation-play-state: running !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 45 !important;
  display: inline-grid !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border: 1px solid rgba(255, 255, 255, .72) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .76) !important;
  color: #25234f !important;
  box-shadow: 0 18px 42px rgba(37, 35, 79, .14), 0 4px 14px rgba(91, 92, 240, .10) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 22px 50px rgba(37, 35, 79, .18), 0 8px 20px rgba(91, 92, 240, .14) !important;
}

#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  outline: 3px solid rgba(91, 92, 240, .30) !important;
  outline-offset: 3px !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: clamp(4px, .7vw, 14px) !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev:hover,
#hero-gallery-viewport .hero-carousel__nav--prev:focus-visible {
  transform: translateY(-50%) scale(1.055) !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: clamp(4px, .7vw, 14px) !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--next:hover,
#hero-gallery-viewport .hero-carousel__nav--next:focus-visible {
  transform: translateY(-50%) scale(1.055) !important;
}

#hero-gallery-viewport .hero-carousel__nav-icon {
  display: block !important;
  font-size: 28px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  transform: translateY(-1px) !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  cursor: zoom-in !important;
  touch-action: pan-y !important;
}

#hero-gallery-viewport .hero-carousel.is-pointer-ready .hero-carousel__slide,
#hero-gallery-viewport .hero-carousel.is-dragging .hero-carousel__slide {
  cursor: zoom-in !important;
}

@media (max-width: 980px) {
  :root {
    --trusted-section-width: calc(100vw - 8px);
    --hero-media-section-width: calc(100vw - 10px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: clamp(18px, 3vw, 32px) !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --trusted-section-width: calc(100vw - 6px);
    --hero-media-section-width: calc(100vw - 6px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-gap: 18px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-carousel-nav-size: 38px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--prev {
    left: 3px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--next {
    right: 3px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__nav:hover,
  #hero-gallery-viewport .hero-carousel__nav:focus-visible,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}




/* landing-home-fixes-v9
   Stable carousel arrows, slower marquee, light glass controls, and lightbox pause state.
   This block intentionally comes last so it wins over older carousel overrides above. */
html {
  scrollbar-gutter: stable;
}

:root {
  --trusted-section-width: calc(100vw - clamp(4px, .8vw, 16px));
  --hero-media-section-width: calc(100vw - clamp(6px, 1vw, 18px));
}

.hero-gallery,
.hero-gallery__viewport,
#hero-gallery-viewport {
  width: 100% !important;
  max-width: none !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-duration: 72s !important;
  --hero-showcase-gap: clamp(24px, 2.3vw, 48px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-carousel-nav-size: clamp(38px, 3vw, 46px) !important;
  position: relative !important;
  width: 100% !important;
  max-width: none !important;
  padding-left: clamp(8px, 1vw, 18px) !important;
  padding-right: clamp(8px, 1vw, 18px) !important;
  overflow: visible !important;
  cursor: default !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  overflow: hidden !important;
  touch-action: pan-y !important;
  cursor: default !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 2.5%, #000 97.5%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 2.5%, #000 97.5%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track {
  animation-play-state: running !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 80 !important;
  display: inline-grid !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border: 1px solid rgba(255, 255, 255, .46) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .34) !important;
  color: #25234f !important;
  box-shadow: 0 12px 30px rgba(37, 35, 79, .10), 0 2px 10px rgba(91, 92, 240, .08) !important;
  backdrop-filter: blur(16px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(140%) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  opacity: .88 !important;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease,
    opacity 180ms ease !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .58) !important;
  box-shadow: 0 16px 36px rgba(37, 35, 79, .14), 0 6px 18px rgba(91, 92, 240, .12) !important;
  opacity: 1 !important;
}

#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  outline: 3px solid rgba(91, 92, 240, .28) !important;
  outline-offset: 3px !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: clamp(8px, 1vw, 18px) !important;
  right: auto !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: clamp(8px, 1vw, 18px) !important;
  left: auto !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev:hover,
#hero-gallery-viewport .hero-carousel__nav--prev:focus-visible,
#hero-gallery-viewport .hero-carousel__nav--next:hover,
#hero-gallery-viewport .hero-carousel__nav--next:focus-visible {
  transform: translateY(-50%) scale(1.045) !important;
}

#hero-gallery-viewport .hero-carousel__nav-icon {
  display: block !important;
  font-size: 26px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  transform: translateY(-1px) !important;
  text-shadow: 0 1px 12px rgba(255, 255, 255, .58) !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  cursor: zoom-in !important;
  touch-action: pan-y !important;
}

#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) {
  transform: translate3d(0, 0, 0) scale(1) !important;
  z-index: 1 !important;
}

#hero-gallery-viewport .hero-carousel__slide:active {
  transform: translate3d(0, -4px, 0) scale(1.02) !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  -webkit-user-drag: none !important;
}

@media (max-width: 980px) {
  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 64s !important;
    --hero-showcase-gap: clamp(18px, 3vw, 32px) !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

@media (max-width: 560px) {
  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 58s !important;
    --hero-showcase-gap: 18px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-carousel-nav-size: 38px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--prev {
    left: 4px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--next {
    right: 4px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
  }

  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__nav:hover,
  #hero-gallery-viewport .hero-carousel__nav:focus-visible,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}


/* landing-home-fixes-v10
   Final correction for the recorded carousel behavior:
   - right arrow stays inside the visible viewport even when the showcase is full-bleed
   - both edges have the same fade treatment
   - controls are light/glass-like and sit above the fade without blocking slides
   - active click state no longer causes a visible jump
*/
:root {
  --trusted-section-width: calc(100vw - clamp(4px, .8vw, 16px));
  --hero-media-section-width: calc(100vw - clamp(6px, 1vw, 18px));
}

.hero-bottom {
  width: var(--hero-media-section-width) !important;
  max-width: var(--hero-media-section-width) !important;
  justify-self: center !important;
}

.hero-gallery,
.hero-gallery__viewport,
#hero-gallery-viewport {
  width: 100% !important;
  max-width: 100vw !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-duration: 78s !important;
  --hero-showcase-gap: clamp(24px, 2.3vw, 48px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-carousel-nav-size: clamp(38px, 3vw, 46px) !important;
  --hero-edge-fade: clamp(52px, 7vw, 132px) !important;
  position: relative !important;
  isolation: isolate !important;
  width: min(100%, 100vw) !important;
  max-width: 100vw !important;
  margin-inline: auto !important;
  padding-left: clamp(8px, 1vw, 18px) !important;
  padding-right: clamp(8px, 1vw, 18px) !important;
  overflow: visible !important;
  cursor: default !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel::before,
#hero-gallery-viewport .hero-carousel::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--hero-edge-fade) !important;
  z-index: 50 !important;
  pointer-events: none !important;
  opacity: 1 !important;
}

#hero-gallery-viewport .hero-carousel::before {
  left: 0 !important;
  background: linear-gradient(90deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .72) 44%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel::after {
  right: 0 !important;
  background: linear-gradient(270deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .72) 44%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  position: relative !important;
  z-index: 1 !important;
  overflow: hidden !important;
  touch-action: pan-y !important;
  cursor: default !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 7.5%, #000 92.5%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 7.5%, #000 92.5%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track {
  animation-play-state: running !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 120 !important;
  display: inline-grid !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border: 1px solid rgba(255, 255, 255, .58) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .42) !important;
  color: #25234f !important;
  box-shadow: 0 10px 26px rgba(37, 35, 79, .10), 0 2px 8px rgba(91, 92, 240, .08) !important;
  backdrop-filter: blur(18px) saturate(145%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(145%) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  opacity: .94 !important;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease,
    opacity 180ms ease !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .66) !important;
  box-shadow: 0 14px 32px rgba(37, 35, 79, .13), 0 5px 16px rgba(91, 92, 240, .11) !important;
  opacity: 1 !important;
}

#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  outline: 3px solid rgba(91, 92, 240, .28) !important;
  outline-offset: 3px !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: max(clamp(10px, 1.1vw, 20px), calc((100% - 100vw) / 2 + clamp(10px, 1.1vw, 20px))) !important;
  right: auto !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: max(clamp(10px, 1.1vw, 20px), calc((100% - 100vw) / 2 + clamp(10px, 1.1vw, 20px))) !important;
  left: auto !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev:hover,
#hero-gallery-viewport .hero-carousel__nav--prev:focus-visible,
#hero-gallery-viewport .hero-carousel__nav--next:hover,
#hero-gallery-viewport .hero-carousel__nav--next:focus-visible {
  transform: translateY(-50%) scale(1.045) !important;
}

#hero-gallery-viewport .hero-carousel__nav-icon {
  display: block !important;
  font-size: 26px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  transform: translateY(-1px) !important;
  text-shadow: 0 1px 12px rgba(255, 255, 255, .58) !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  cursor: zoom-in !important;
  touch-action: pan-y !important;
}

#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) {
  transform: translate3d(0, 0, 0) scale(1) !important;
  z-index: 1 !important;
}

#hero-gallery-viewport .hero-carousel__slide:active {
  transform: translate3d(0, -3px, 0) scale(1.012) !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover:active,
#hero-gallery-viewport .hero-carousel__slide:focus-visible:active,
#hero-gallery-viewport .hero-carousel__slide:focus-within:active {
  transform: translate3d(0, -8px, 0) scale(1.035) !important;
}

#hero-gallery-viewport .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video,
#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  background: transparent !important;
  border: 0 !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  -webkit-user-drag: none !important;
}

@media (max-width: 980px) {
  :root {
    --trusted-section-width: calc(100vw - 8px);
    --hero-media-section-width: calc(100vw - 10px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 68s !important;
    --hero-showcase-gap: clamp(18px, 3vw, 32px) !important;
    --hero-edge-fade: clamp(42px, 9vw, 96px) !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --trusted-section-width: calc(100vw - 6px);
    --hero-media-section-width: calc(100vw - 6px);
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 62s !important;
    --hero-showcase-gap: 18px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-carousel-nav-size: 38px !important;
    --hero-edge-fade: 42px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--prev {
    left: 6px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--next {
    right: 6px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel::before,
  #hero-gallery-viewport .hero-carousel::after {
    display: none !important;
  }

  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
  }

  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__nav:hover,
  #hero-gallery-viewport .hero-carousel__nav:focus-visible,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}


/* landing-home-fixes-v11
   Fix recorded regression:
   - keep the original hero/theme preview at its canonical contained width
   - let only the template carousel go wide/full-bleed
   - keep the right arrow inside the visible carousel viewport
   - keep both carousel edges faded symmetrically
*/
:root {
  --hero-standard-media-width: min(1120px, calc(100vw - clamp(28px, 4vw, 72px)));
  --hero-carousel-wide-width: min(1760px, calc(100vw - clamp(14px, 1.6vw, 30px)));
  --hero-carousel-edge-pad: clamp(12px, 1.35vw, 24px);
}

.hero-bottom {
  width: var(--hero-standard-media-width) !important;
  max-width: var(--hero-standard-media-width) !important;
  justify-self: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first {
  width: 100% !important;
  max-width: var(--hero-standard-media-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: clamp(24px, 3vw, 46px) !important;
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel {
  order: 1 !important;
  width: min(100%, 860px) !important;
  max-width: min(100%, 860px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-self: center !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport {
  min-height: clamp(300px, 27vw, 510px) !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport img,
.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport video {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery {
  order: 2 !important;
  position: relative !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: var(--hero-carousel-wide-width) !important;
  max-width: var(--hero-carousel-wide-width) !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  justify-self: center !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery__viewport,
.hero-media-row.hero-media-row--original-first #hero-gallery-viewport {
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-duration: 82s !important;
  --hero-showcase-gap: clamp(24px, 2.3vw, 48px) !important;
  --hero-showcase-card-width: clamp(238px, 18vw, 340px) !important;
  --hero-showcase-card-height: clamp(370px, 28vw, 540px) !important;
  --hero-carousel-nav-size: clamp(40px, 3vw, 48px) !important;
  --hero-edge-fade: clamp(56px, 7vw, 140px) !important;
  position: relative !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding-left: var(--hero-carousel-edge-pad) !important;
  padding-right: var(--hero-carousel-edge-pad) !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  isolation: isolate !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel::before,
#hero-gallery-viewport .hero-carousel::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--hero-edge-fade) !important;
  z-index: 60 !important;
  pointer-events: none !important;
  opacity: 1 !important;
}

#hero-gallery-viewport .hero-carousel::before {
  left: 0 !important;
  background: linear-gradient(90deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .78) 42%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel::after {
  right: 0 !important;
  background: linear-gradient(270deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .78) 42%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
  cursor: default !important;
  touch-action: pan-y !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track {
  animation-play-state: running !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 180 !important;
  display: inline-grid !important;
  visibility: visible !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border: 1px solid rgba(255, 255, 255, .74) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .62) !important;
  color: #25234f !important;
  box-shadow: 0 12px 30px rgba(37, 35, 79, .12), 0 3px 10px rgba(91, 92, 240, .08) !important;
  backdrop-filter: blur(18px) saturate(145%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(145%) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  opacity: .98 !important;
  transform: translateY(-50%) !important;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease,
    opacity 180ms ease !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: clamp(14px, 1.6vw, 30px) !important;
  right: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: clamp(14px, 1.6vw, 30px) !important;
  left: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .78) !important;
  box-shadow: 0 16px 36px rgba(37, 35, 79, .15), 0 6px 18px rgba(91, 92, 240, .11) !important;
  opacity: 1 !important;
  transform: translateY(-50%) scale(1.045) !important;
}

#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  outline: 3px solid rgba(91, 92, 240, .28) !important;
  outline-offset: 3px !important;
}

#hero-gallery-viewport .hero-carousel__nav-icon {
  display: block !important;
  font-size: 28px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  transform: translateY(-1px) !important;
  text-shadow: 0 1px 12px rgba(255, 255, 255, .7) !important;
}

#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) {
  transform: translate3d(0, 0, 0) scale(1) !important;
  z-index: 1 !important;
}

#hero-gallery-viewport .hero-carousel__slide:active {
  transform: translate3d(0, -3px, 0) scale(1.012) !important;
}

#hero-gallery-viewport .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video,
#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  background: transparent !important;
  border: 0 !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  -webkit-user-drag: none !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

@media (max-width: 980px) {
  :root {
    --hero-standard-media-width: calc(100vw - 22px);
    --hero-carousel-wide-width: calc(100vw - 10px);
    --hero-carousel-edge-pad: 8px;
  }

  .hero-media-row.hero-media-row--original-first .hero-image-panel {
    width: min(100%, 820px) !important;
    max-width: min(100%, 820px) !important;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 72s !important;
    --hero-showcase-gap: clamp(18px, 3vw, 32px) !important;
    --hero-edge-fade: clamp(42px, 9vw, 96px) !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--prev {
    left: 10px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--next {
    right: 10px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --hero-standard-media-width: calc(100vw - 16px);
    --hero-carousel-wide-width: calc(100vw - 6px);
    --hero-carousel-edge-pad: 6px;
  }

  .hero-media-row.hero-media-row--original-first .hero-image-panel {
    width: 100% !important;
    max-width: 100% !important;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 66s !important;
    --hero-showcase-gap: 18px !important;
    --hero-showcase-card-width: min(78vw, 300px) !important;
    --hero-showcase-card-height: clamp(360px, 112vw, 500px) !important;
    --hero-carousel-nav-size: 38px !important;
    --hero-edge-fade: 44px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--prev {
    left: 8px !important;
  }

  #hero-gallery-viewport .hero-carousel__nav--next {
    right: 8px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel::before,
  #hero-gallery-viewport .hero-carousel::after {
    display: none !important;
  }

  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
  }

  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}

/* v11 pause reinforcement: viewer-open state wins over hover/focus running rules. */
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

/* landing-home-fixes-v13
   Current upload responsive alignment pass.
   Source of truth for the hero proof row, trusted logos, applications card,
   and template carousel containment. This replaces the older viewport-breakout
   experiments with one safe page-width system. */
:root {
  --utap-page-gutter: clamp(16px, 4vw, 56px);
  --utap-page-gutter-tight: clamp(12px, 2.4vw, 34px);
  --utap-page-max: 1180px;
  --utap-page-width: min(var(--utap-page-max), calc(100vw - (var(--utap-page-gutter) * 2)));
  --utap-carousel-width: min(1180px, calc(100vw - (var(--utap-page-gutter-tight) * 2)));
  --utap-carousel-edge-pad: clamp(44px, 5vw, 76px);
  --utap-carousel-fade: clamp(24px, 4.4vw, 72px);
  --utap-application-width: min(960px, 100%);
}

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}

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

body,
.page,
.site-shell,
.landing-page,
.main-hero-wrap,
.hero-section,
.hero-wrap,
.hero-grid,
.hero-copy,
.hero-bottom,
.hero-media-row,
.hero-proof-row,
.trusted-section,
.hero-proof-row__brands,
.hero-gallery,
.hero-gallery__viewport,
#hero-gallery-viewport,
.hero-side-box {
  min-width: 0 !important;
  max-width: 100% !important;
}

.main-hero-wrap,
.hero-section,
.hero-wrap,
.hero-grid {
  overflow-x: hidden !important;
}

.hero-bottom,
#hero-proof-row.hero-proof-row {
  width: 100% !important;
  max-width: var(--utap-page-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  justify-self: center !important;
  box-sizing: border-box !important;
}

/* Trusted by + uTap Applications share one stable centered column. */
#hero-proof-row.hero-proof-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(18px, 2.2vw, 34px) !important;
  align-items: start !important;
  justify-items: center !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-rows: auto auto !important;
  gap: clamp(12px, 1.4vw, 20px) !important;
  align-items: center !important;
  justify-items: center !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-trust-copy.trusted-label,
#hero-trust-copy.trust-copy,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  width: 100% !important;
  max-width: min(100%, 860px) !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 clamp(4px, 1vw, 12px) !important;
  display: block !important;
  justify-self: center !important;
  color: #4b5565 !important;
  opacity: .68 !important;
  font-size: clamp(.88rem, .84vw, 1rem) !important;
  font-weight: 500 !important;
  line-height: 1.45 !important;
  letter-spacing: .006em !important;
  text-align: center !important;
  white-space: normal !important;
  overflow: visible !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  min-height: calc(var(--landing-trusted-logo-size, 156px) * .74) !important;
  margin: 0 auto !important;
  padding: clamp(10px, 1.15vw, 18px) 0 !important;
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 8% 50%, rgba(123, 92, 255, .09), transparent 34%),
    radial-gradient(circle at 92% 52%, rgba(20, 196, 184, .10), transparent 35%) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
}

#hero-brand-band.logo-band::before,
#hero-brand-band.logo-band::after,
#hero-proof-row .logo-band::before,
#hero-proof-row .logo-band::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  --trusted-marquee-gap: clamp(34px, 6vw, 110px);
  display: flex !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: var(--trusted-marquee-gap) !important;
  animation: utapTrustedLogoMarquee 38s linear infinite !important;
  will-change: transform !important;
}

#hero-brand-band:hover .logo-band__track,
#hero-brand-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track {
  animation-play-state: paused !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  min-width: max-content !important;
  width: auto !important;
  max-width: none !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--trusted-marquee-gap) !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: clamp(96px, 14vw, 168px) !important;
  min-height: calc(var(--trusted-logo-max-height, 90px) + 4px) !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip::before,
#hero-brand-band .logo-chip::after,
#hero-proof-row .logo-chip::before,
#hero-proof-row .logo-chip::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: auto !important;
  max-width: clamp(96px, 14vw, 168px) !important;
  height: auto !important;
  max-height: var(--trusted-logo-max-height, calc(var(--landing-trusted-logo-size, 156px) * .58)) !important;
  object-fit: contain !important;
  object-position: center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .13)) !important;
}

#hero-proof-row > .hero-side-box,
.hero-side-box {
  width: 100% !important;
  max-width: var(--utap-application-width) !important;
  min-width: 0 !important;
  margin: clamp(18px, 2vw, 30px) auto 0 !important;
  justify-self: center !important;
  align-self: start !important;
  transform: none !important;
  box-sizing: border-box !important;
}

.hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr)) !important;
  gap: clamp(10px, 1.4vw, 16px) !important;
}

/* Hero media and template carousel containment. */
.hero-bottom {
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first,
.hero-media-row {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-content: center !important;
  justify-items: center !important;
  align-items: stretch !important;
  gap: clamp(22px, 3vw, 42px) !important;
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first > *,
.hero-media-row > * {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel,
.hero-media-row .hero-image-panel {
  width: min(100%, 860px) !important;
  max-width: min(100%, 860px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-self: center !important;
  overflow: hidden !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport,
.hero-media-row .hero-image-panel__viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  min-height: clamp(300px, 27vw, 510px) !important;
  overflow: hidden !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport img,
.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport video,
.hero-media-row .hero-image-panel__viewport img,
.hero-media-row .hero-image-panel__viewport video {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery,
.hero-media-row .hero-gallery {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: var(--utap-carousel-width) !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 !important;
  justify-self: center !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery__viewport,
.hero-media-row.hero-media-row--original-first #hero-gallery-viewport,
.hero-media-row .hero-gallery__viewport,
.hero-media-row #hero-gallery-viewport,
#hero-gallery-viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-duration: 84s !important;
  --hero-showcase-gap: clamp(18px, 2.2vw, 38px) !important;
  --hero-showcase-card-width: clamp(220px, 17vw, 318px) !important;
  --hero-showcase-card-height: clamp(350px, 27vw, 515px) !important;
  --hero-carousel-nav-size: clamp(38px, 3vw, 46px) !important;
  --hero-edge-fade: var(--utap-carousel-fade) !important;
  position: relative !important;
  isolation: isolate !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding-left: var(--utap-carousel-edge-pad) !important;
  padding-right: var(--utap-carousel-edge-pad) !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  cursor: default !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel::before,
#hero-gallery-viewport .hero-carousel::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--hero-edge-fade) !important;
  z-index: 60 !important;
  pointer-events: none !important;
}

#hero-gallery-viewport .hero-carousel::before {
  left: 0 !important;
  background: linear-gradient(90deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .62) 48%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel::after {
  right: 0 !important;
  background: linear-gradient(270deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .62) 48%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  cursor: default !important;
  touch-action: pan-y !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  display: flex !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__set,
#hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: var(--hero-showcase-gap) !important;
  padding-right: var(--hero-showcase-gap) !important;
  flex-wrap: nowrap !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 180 !important;
  display: inline-grid !important;
  visibility: visible !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, .68) !important;
  background: rgba(255, 255, 255, .56) !important;
  color: #25234f !important;
  box-shadow: 0 12px 30px rgba(37, 35, 79, .11), 0 3px 10px rgba(91, 92, 240, .08) !important;
  backdrop-filter: blur(18px) saturate(145%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(145%) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  opacity: .96 !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: clamp(8px, 1.1vw, 16px) !important;
  right: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: clamp(8px, 1.1vw, 16px) !important;
  left: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .76) !important;
  box-shadow: 0 16px 36px rgba(37, 35, 79, .14), 0 6px 18px rgba(91, 92, 240, .10) !important;
  opacity: 1 !important;
  transform: translateY(-50%) scale(1.04) !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

#hero-gallery-viewport .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video,
#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  max-width: 100% !important;
  background: transparent !important;
  border: 0 !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  -webkit-user-drag: none !important;
}

@media (max-width: 980px) {
  :root {
    --utap-page-gutter: 18px;
    --utap-page-gutter-tight: 12px;
    --utap-page-width: calc(100vw - 36px);
    --utap-carousel-width: calc(100vw - 24px);
    --utap-carousel-edge-pad: 44px;
    --utap-carousel-fade: 42px;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 74s !important;
    --hero-showcase-gap: clamp(16px, 3vw, 28px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-page-gutter: 12px;
    --utap-page-gutter-tight: 8px;
    --utap-page-width: calc(100vw - 24px);
    --utap-carousel-width: calc(100vw - 16px);
    --utap-carousel-edge-pad: 38px;
    --utap-carousel-fade: 32px;
  }

  #hero-proof-row.hero-proof-row {
    gap: clamp(16px, 6vw, 28px) !important;
  }

  #hero-brand-band .logo-chip img,
  #hero-proof-row .logo-chip img {
    max-width: clamp(84px, 31vw, 132px) !important;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 68s !important;
    --hero-showcase-gap: 16px !important;
    --hero-showcase-card-width: min(72vw, 282px) !important;
    --hero-showcase-card-height: clamp(340px, 106vw, 480px) !important;
    --hero-carousel-nav-size: 38px !important;
  }

  .hero-media-row.hero-media-row--original-first,
  .hero-media-row {
    gap: clamp(18px, 6vw, 30px) !important;
    overflow: visible !important;
  }

  .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel::before,
  #hero-gallery-viewport .hero-carousel::after {
    display: none !important;
  }

  #hero-gallery-viewport .hero-carousel__track,
  #hero-proof-row .logo-band__track,
  #hero-brand-band .logo-band__track {
    animation: none !important;
  }

  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}

/* landing-home-fixes-v14
   Actual-upload alignment correction.
   Intent:
   - one shared wide page width for trusted logos, uTap Applications, original theme, and carousel
   - left-aligned internal content instead of centered/narrow blocks
   - no viewport breakout and no horizontal scroll
   - carousel fills the same safe width while the moving track is clipped only inside its own mask
*/
:root {
  --utap-section-gutter: clamp(22px, 3.2vw, 58px);
  --utap-section-width: min(1680px, calc(100vw - (var(--utap-section-gutter) * 2)));
  --utap-section-radius: clamp(22px, 1.6vw, 30px);
  --utap-section-card-bg: rgba(255, 255, 255, .64);
  --utap-section-card-border: rgba(188, 183, 219, .34);
  --utap-section-card-shadow: 0 24px 70px rgba(42, 39, 82, .10);
  --utap-carousel-control-space: clamp(46px, 4.2vw, 74px);
  --utap-carousel-fade: clamp(38px, 4.4vw, 76px);
}

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}

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

.main-hero-wrap,
.hero-section,
.hero-wrap,
.hero-grid,
.hero-copy,
.hero-bottom,
#hero-proof-row.hero-proof-row,
.trusted-section,
.hero-proof-row__brands,
.logo-band,
.logo-band__track,
.hero-side-box,
.hero-media-row,
.hero-gallery,
.hero-gallery__viewport,
#hero-gallery-viewport {
  min-width: 0 !important;
}

.main-hero-wrap,
.hero-section,
.hero-wrap,
.hero-grid {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

/* Shared section width: wide enough to fill the page, safe enough to avoid horizontal scroll. */
.hero-bottom,
#hero-proof-row.hero-proof-row {
  width: var(--utap-section-width) !important;
  max-width: var(--utap-section-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  justify-self: center !important;
  overflow: visible !important;
}

/* Trusted by + Applications: left aligned inside the shared wide section. */
#hero-proof-row.hero-proof-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(22px, 2.2vw, 36px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  text-align: left !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: stretch !important;
  align-self: start !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.25vw, 22px) !important;
  align-items: start !important;
  justify-items: start !important;
  text-align: left !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#hero-trust-copy.trusted-label,
#hero-trust-copy.trust-copy,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy,
.trust-copy {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: start !important;
  align-self: start !important;
  text-align: left !important;
  white-space: normal !important;
  overflow: visible !important;
  color: #4b5565 !important;
  opacity: .76 !important;
  font-size: clamp(.9rem, .86vw, 1.02rem) !important;
  font-weight: 650 !important;
  line-height: 1.42 !important;
  letter-spacing: .004em !important;
}

/* Trusted logos: fit inside the browser, start from the left, no duplicate marquee set. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: clamp(14px, 1.35vw, 22px) 0 !important;
  display: block !important;
  position: relative !important;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 0% 50%, rgba(123, 92, 255, .08), transparent 32%),
    radial-gradient(circle at 100% 52%, rgba(20, 196, 184, .09), transparent 32%) !important;
  box-shadow: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

#hero-brand-band.logo-band::before,
#hero-brand-band.logo-band::after,
#hero-proof-row .logo-band::before,
#hero-proof-row .logo-band::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  display: block !important;
  transform: none !important;
  animation: none !important;
  will-change: auto !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-proof-row .trusted-logo-marquee__set {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: clamp(24px, 4.2vw, 78px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  display: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 1 clamp(104px, 10.5vw, 172px) !important;
  width: auto !important;
  min-width: 92px !important;
  max-width: clamp(112px, 12vw, 184px) !important;
  min-height: clamp(54px, 5vw, 92px) !important;
  padding: clamp(6px, .8vw, 10px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip::before,
#hero-brand-band .logo-chip::after,
#hero-proof-row .logo-chip::before,
#hero-proof-row .logo-chip::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: auto !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: clamp(42px, 5.2vw, 88px) !important;
  object-fit: contain !important;
  object-position: center center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .12)) !important;
}

/* uTap Applications: same left edge as Trusted by and carousel, content starts left. */
#hero-proof-row > .hero-side-box,
.hero-side-box {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: clamp(18px, 2vw, 30px) 0 0 !important;
  padding: clamp(18px, 1.7vw, 28px) !important;
  justify-self: stretch !important;
  align-self: start !important;
  transform: none !important;
  text-align: left !important;
  border-radius: var(--utap-section-radius) !important;
  background: var(--utap-section-card-bg) !important;
  border: 1px solid var(--utap-section-card-border) !important;
  box-shadow: var(--utap-section-card-shadow) !important;
  overflow: hidden !important;
}

.hero-side-box__head {
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  justify-items: start !important;
  align-items: start !important;
  gap: 8px !important;
  text-align: left !important;
}

.hero-side-box__head strong,
.hero-side-box__head p {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: left !important;
}

.hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr)) !important;
  justify-content: start !important;
  justify-items: stretch !important;
  align-items: stretch !important;
  gap: clamp(12px, 1.4vw, 18px) !important;
}

.hero-side-card {
  width: 100% !important;
  min-width: 0 !important;
}

/* Original theme and carousel: same wide left/right edges, no viewport breakout. */
.hero-bottom {
  display: block !important;
}

.hero-media-row.hero-media-row--original-first,
.hero-media-row {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-items: stretch !important;
  align-items: stretch !important;
  gap: clamp(24px, 3vw, 46px) !important;
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first > *,
.hero-media-row > * {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel,
.hero-media-row .hero-image-panel {
  width: min(100%, 980px) !important;
  max-width: min(100%, 980px) !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  justify-self: start !important;
  overflow: hidden !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport,
.hero-media-row .hero-image-panel__viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  min-height: clamp(300px, 27vw, 510px) !important;
  overflow: hidden !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport img,
.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport video,
.hero-media-row .hero-image-panel__viewport img,
.hero-media-row .hero-image-panel__viewport video {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery,
.hero-media-row .hero-gallery {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-self: stretch !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-gallery__caption,
.hero-gallery__copy,
.hero-gallery__copy strong,
.hero-gallery__copy span {
  text-align: left !important;
  justify-self: start !important;
}

.hero-media-row.hero-media-row--original-first .hero-gallery__viewport,
.hero-media-row.hero-media-row--original-first #hero-gallery-viewport,
.hero-media-row .hero-gallery__viewport,
.hero-media-row #hero-gallery-viewport,
#hero-gallery-viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel {
  --hero-showcase-duration: 84s !important;
  --hero-showcase-gap: clamp(18px, 2.1vw, 36px) !important;
  --hero-showcase-card-width: clamp(230px, 15.8vw, 330px) !important;
  --hero-showcase-card-height: clamp(350px, 26vw, 520px) !important;
  --hero-carousel-nav-size: clamp(38px, 2.8vw, 46px) !important;
  --hero-edge-fade: var(--utap-carousel-fade) !important;
  position: relative !important;
  isolation: isolate !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding-left: var(--utap-carousel-control-space) !important;
  padding-right: var(--utap-carousel-control-space) !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  cursor: default !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel::before,
#hero-gallery-viewport .hero-carousel::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--hero-edge-fade) !important;
  z-index: 60 !important;
  pointer-events: none !important;
}

#hero-gallery-viewport .hero-carousel::before {
  left: 0 !important;
  background: linear-gradient(90deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .62) 46%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel::after {
  right: 0 !important;
  background: linear-gradient(270deg, rgba(248, 249, 255, .98) 0%, rgba(248, 249, 255, .62) 46%, rgba(248, 249, 255, 0) 100%) !important;
}

#hero-gallery-viewport .hero-carousel__mask {
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  cursor: default !important;
  touch-action: pan-y !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  display: flex !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  animation-name: utapHeroTemplateShowcaseLeft !important;
  animation-duration: var(--hero-showcase-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-gallery-viewport .hero-carousel.is-interacting .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-stepping .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-lightbox-paused .hero-carousel__track,
body.hero-image-lightbox-open #hero-gallery-viewport .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__set,
#hero-gallery-viewport .hero-carousel__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: var(--hero-showcase-gap) !important;
  padding-right: var(--hero-showcase-gap) !important;
  flex-wrap: nowrap !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 180 !important;
  display: inline-grid !important;
  visibility: visible !important;
  place-items: center !important;
  width: var(--hero-carousel-nav-size) !important;
  height: var(--hero-carousel-nav-size) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, .68) !important;
  background: rgba(255, 255, 255, .52) !important;
  color: #25234f !important;
  box-shadow: 0 12px 28px rgba(37, 35, 79, .10), 0 3px 10px rgba(91, 92, 240, .08) !important;
  backdrop-filter: blur(18px) saturate(145%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(145%) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  opacity: .96 !important;
  transform: translateY(-50%) !important;
}

#hero-gallery-viewport .hero-carousel__nav--prev {
  left: clamp(8px, 1vw, 16px) !important;
  right: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav--next {
  right: clamp(8px, 1vw, 16px) !important;
  left: auto !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  background: rgba(255, 255, 255, .72) !important;
  box-shadow: 0 16px 34px rgba(37, 35, 79, .13), 0 6px 18px rgba(91, 92, 240, .10) !important;
  opacity: 1 !important;
  transform: translateY(-50%) scale(1.04) !important;
}

#hero-gallery-viewport .hero-carousel[data-count="1"] .hero-carousel__nav {
  display: none !important;
}

#hero-gallery-viewport .hero-carousel__card,
#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video,
#hero-gallery-viewport .hero-carousel__card .document-thumb,
#hero-gallery-viewport .hero-carousel__card .pdf-embed {
  max-width: 100% !important;
  background: transparent !important;
  border: 0 !important;
}

#hero-gallery-viewport .hero-carousel__card img,
#hero-gallery-viewport .hero-carousel__card video {
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  -webkit-user-drag: none !important;
}

@media (min-width: 1280px) {
  .hero-side-box__items {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 980px) {
  :root {
    --utap-section-gutter: 18px;
    --utap-carousel-control-space: 44px;
    --utap-carousel-fade: 38px;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 74s !important;
    --hero-showcase-gap: clamp(16px, 3vw, 28px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-section-gutter: 12px;
    --utap-carousel-control-space: 38px;
    --utap-carousel-fade: 30px;
  }

  #hero-proof-row.hero-proof-row {
    gap: clamp(16px, 6vw, 28px) !important;
  }

  #hero-brand-band .logo-band__set,
  #hero-proof-row .logo-band__set,
  #hero-proof-row .trusted-logo-marquee__set {
    gap: clamp(14px, 6vw, 30px) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    flex-basis: clamp(84px, 30vw, 132px) !important;
    min-width: 78px !important;
  }

  #hero-gallery-viewport .hero-carousel {
    --hero-showcase-duration: 68s !important;
    --hero-showcase-gap: 16px !important;
    --hero-showcase-card-width: min(72vw, 282px) !important;
    --hero-showcase-card-height: clamp(340px, 106vw, 480px) !important;
    --hero-carousel-nav-size: 38px !important;
  }

  .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .hero-media-row.hero-media-row--original-first .hero-image-panel,
  .hero-media-row .hero-image-panel {
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-gallery-viewport .hero-carousel::before,
  #hero-gallery-viewport .hero-carousel::after {
    display: none !important;
  }

  #hero-gallery-viewport .hero-carousel__track {
    animation: none !important;
  }

  #hero-gallery-viewport .hero-carousel__nav,
  #hero-gallery-viewport .hero-carousel__slide,
  #hero-gallery-viewport .hero-carousel__card {
    transition: none !important;
  }
}





/* landing-home-fixes-v15
   Restore the trusted logos as a one-line continuous marquee and keep the
   hero carousel stable during hover/arrow interaction.
   This is intentionally scoped to the public hero proof/logo/gallery area. */

@keyframes utapTrustedLogoTrackLoopV15 {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-50%, 0, 0); }
}

/* Keep the section wide and safe, but let the logo glow fill the entire band. */
#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  overflow: hidden !important;
}

/* Trusted logos: one line, continuous end-to-end loop, no wrapping. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: clamp(18px, 1.8vw, 30px) 0 !important;
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 6% 48%, rgba(123, 92, 255, .14), rgba(123, 92, 255, .055) 26%, transparent 58%),
    radial-gradient(circle at 96% 50%, rgba(20, 196, 184, .14), rgba(20, 196, 184, .055) 28%, transparent 60%),
    linear-gradient(90deg, rgba(245, 242, 255, .42), rgba(255, 255, 255, .36) 50%, rgba(236, 249, 255, .46)) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
}

#hero-brand-band.logo-band::before,
#hero-brand-band.logo-band::after,
#hero-proof-row .logo-band::before,
#hero-proof-row .logo-band::after {
  display: none !important;
  content: none !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: 0 !important;
  transform: translate3d(0, 0, 0) !important;
  animation-name: utapTrustedLogoTrackLoopV15 !important;
  animation-duration: clamp(42s, 7vw, 74s) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: paused !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-proof-row .trusted-logo-marquee__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 clamp(34px, 4.2vw, 78px) 0 0 !important;
  gap: clamp(34px, 5.2vw, 96px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: clamp(88px, 7.8vw, 150px) !important;
  max-width: clamp(110px, 10vw, 184px) !important;
  min-height: clamp(58px, 4.8vw, 88px) !important;
  padding: clamp(6px, .65vw, 10px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: var(--trusted-logo-width, auto) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: var(--trusted-logo-max-height, clamp(44px, 5vw, 88px)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .12)) !important;
}

/* Hero carousel: hover/focus pauses, arrows step without immediate snap-back. */
#hero-gallery-viewport .hero-carousel:hover .hero-carousel__track,
#hero-gallery-viewport .hero-carousel:focus-within .hero-carousel__track,
#hero-gallery-viewport .hero-carousel.is-manual-hold .hero-carousel__track {
  animation-play-state: paused !important;
}

#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) {
  transform: translate3d(0, 0, 0) scale(1) !important;
  z-index: 1 !important;
}

#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) .hero-carousel__card {
  filter: none !important;
  box-shadow: none !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover,
#hero-gallery-viewport .hero-carousel__slide:focus-visible,
#hero-gallery-viewport .hero-carousel__slide:focus-within {
  transform: translate3d(0, -6px, 0) scale(1.025) !important;
  z-index: 32 !important;
}

/* Keep carousel controls pinned and light while the track is paused or moving. */
#hero-gallery-viewport .hero-carousel__nav {
  z-index: 220 !important;
}

@media (max-width: 980px) {
  #hero-brand-band .logo-band__set,
  #hero-proof-row .logo-band__set,
  #hero-proof-row .trusted-logo-marquee__set,
  #hero-brand-band .logo-band__set[aria-hidden="true"],
  #hero-proof-row .logo-band__set[aria-hidden="true"],
  #hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
    gap: clamp(28px, 7vw, 72px) !important;
    padding-right: clamp(28px, 7vw, 72px) !important;
  }
}

@media (max-width: 560px) {
  #hero-brand-band.logo-band,
  #hero-proof-row .logo-band,
  #hero-proof-row .trusted-logo-marquee {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    min-width: clamp(78px, 28vw, 124px) !important;
    max-width: clamp(88px, 34vw, 140px) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}

/* landing-home-fixes-v16
   Final scope for the current request:
   1) keep trusted brand chips as one continuous row, but make the glow/band use
      the real browser width instead of a narrow centered section;
   2) move uTap Applications out of the brand chip/proof row and let it live in
      the hero template/original-theme area below the CTA;
   3) avoid touching the now-working hero template carousel behavior. */

:root {
  --utap-proof-band-width: min(calc(100vw - clamp(18px, 2.2vw, 44px)), 1840px);
  --utap-template-block-width: min(calc(100vw - clamp(28px, 4vw, 96px)), 1680px);
  --utap-brand-band-height: clamp(136px, 10vw, 190px);
  --utap-brand-logo-gap: clamp(48px, 7.6vw, 132px);
}

html,
body,
.main-hero-wrap,
.browser-shell,
.hero-page,
.hero-stage,
.hero-copy {
  max-width: 100% !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body,
  .main-hero-wrap,
  .browser-shell,
  .hero-page,
  .hero-stage,
  .hero-copy {
    overflow-x: hidden !important;
  }
}

/* Proof row now only owns the trusted brand chips. It should be wide and clean,
   not a container for the application cards. */
#hero-proof-row.hero-proof-row {
  width: var(--utap-proof-band-width) !important;
  max-width: var(--utap-proof-band-width) !important;
  min-width: 0 !important;
  margin: clamp(42px, 5vw, 86px) auto clamp(26px, 3.2vw, 52px) !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(16px, 1.6vw, 28px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-trust-copy.trusted-label,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  justify-self: start !important;
  color: #4f586d !important;
  opacity: .78 !important;
  line-height: 1.35 !important;
  white-space: normal !important;
}

/* Trusted brand chip band: full-width looking, one row, no wrapping.
   The glow reaches the edges of this wide proof band. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: var(--utap-brand-band-height) !important;
  min-height: var(--utap-brand-band-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 2% 52%, rgba(124, 92, 255, .16), rgba(124, 92, 255, .07) 28%, transparent 62%),
    radial-gradient(circle at 98% 52%, rgba(20, 196, 184, .16), rgba(20, 196, 184, .07) 30%, transparent 64%),
    linear-gradient(90deg, rgba(245, 242, 255, .54) 0%, rgba(255, 255, 255, .38) 46%, rgba(235, 249, 255, .56) 100%) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 3.5%, #000 96.5%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 3.5%, #000 96.5%, transparent 100%) !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  height: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: 0 !important;
  transform: translate3d(0,0,0) !important;
  animation-name: utapTrustedLogoTrackLoopV15 !important;
  animation-duration: clamp(52s, 8vw, 86s) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  animation-play-state: running !important;
  will-change: transform !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: paused !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-proof-row .trusted-logo-marquee__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  height: 100% !important;
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 var(--utap-brand-logo-gap) 0 0 !important;
  gap: var(--utap-brand-logo-gap) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: clamp(112px, 8vw, 168px) !important;
  max-width: clamp(128px, 10vw, 196px) !important;
  min-height: clamp(70px, 5vw, 96px) !important;
  padding: clamp(6px, .6vw, 10px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: var(--trusted-logo-width, auto) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: var(--trusted-logo-max-height, clamp(48px, 5vw, 90px)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .12)) !important;
}

/* uTap Applications now lives in .hero-bottom with the original template block.
   Keep it aligned to that same lower hero/template width, not the brand band. */
.hero-bottom {
  width: var(--utap-template-block-width) !important;
  max-width: var(--utap-template-block-width) !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(24px, 3vw, 52px) !important;
  align-items: start !important;
  justify-items: stretch !important;
  overflow: visible !important;
}

.hero-bottom > .hero-side-box,
.hero-side-box {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  justify-self: stretch !important;
  align-self: start !important;
}

.hero-bottom > .hero-media-row.hero-media-row--original-first,
.hero-bottom > .hero-media-row {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  justify-self: stretch !important;
}

@media (max-width: 980px) {
  :root {
    --utap-proof-band-width: min(calc(100vw - 28px), 100%);
    --utap-template-block-width: min(calc(100vw - 28px), 100%);
    --utap-brand-band-height: clamp(118px, 18vw, 160px);
    --utap-brand-logo-gap: clamp(34px, 9vw, 76px);
  }

  #hero-proof-row.hero-proof-row {
    margin-top: clamp(32px, 7vw, 60px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-proof-band-width: min(calc(100vw - 18px), 100%);
    --utap-template-block-width: min(calc(100vw - 18px), 100%);
    --utap-brand-band-height: 112px;
    --utap-brand-logo-gap: clamp(26px, 10vw, 54px);
  }

  #hero-brand-band.logo-band,
  #hero-proof-row .logo-band,
  #hero-proof-row .trusted-logo-marquee {
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    min-width: clamp(84px, 29vw, 126px) !important;
    max-width: clamp(96px, 34vw, 142px) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}


/* landing-home-fixes-v17
   Canonical responsive ordering and containment for desktop, laptop, tablet,
   and mobile:
   - hero/original template block first;
   - Trusted brand chips immediately after the hero template caption;
   - uTap Applications below that in the same hero/template stack;
   - no horizontal overflow;
   - one-row continuous trusted logo marquee on every screen size. */

:root {
  --utap-canonical-gutter: clamp(10px, 2.2vw, 44px);
  --utap-canonical-width: min(calc(100vw - (var(--utap-canonical-gutter) * 2)), 1680px);
  --utap-canonical-gap: clamp(22px, 3vw, 52px);
  --utap-trusted-band-height: clamp(108px, 9.5vw, 172px);
  --utap-trusted-logo-gap: clamp(42px, 7.2vw, 126px);
}

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden !important;
  }
}

.main-hero-wrap,
.browser-shell,
.hero-page,
.hero-stage,
.hero-copy,
.hero-bottom,
.hero-media-row,
.hero-gallery,
.hero-image-panel,
#hero-gallery-viewport,
#hero-proof-row,
.hero-side-box,
.video-section {
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* The whole lower hero area uses one predictable stack, so desktop and mobile
   keep the same visual story and do not jump between different layouts. */
.hero-bottom {
  width: var(--utap-canonical-width) !important;
  max-width: var(--utap-canonical-width) !important;
  min-width: 0 !important;
  margin: clamp(28px, 3.4vw, 58px) auto 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "templates"
    "trusted"
    "apps" !important;
  gap: var(--utap-canonical-gap) !important;
  align-items: start !important;
  justify-items: stretch !important;
  overflow: visible !important;
}

.hero-bottom > .hero-media-row.hero-media-row--original-first,
.hero-bottom > .hero-media-row {
  grid-area: templates !important;
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  justify-self: stretch !important;
}

.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row {
  grid-area: trusted !important;
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-bottom > .hero-side-box,
.hero-side-box {
  grid-area: apps !important;
  order: 3 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  justify-self: stretch !important;
  align-self: start !important;
}

/* Trusted section: sits directly after the template/caption area, uses the same
   width as the hero template block, and keeps the label visible. */
#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(12px, 1.5vw, 24px) !important;
  align-items: start !important;
  justify-items: stretch !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-trust-copy.trusted-label,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  justify-self: stretch !important;
  color: #4f586d !important;
  opacity: .82 !important;
  line-height: 1.35 !important;
  white-space: normal !important;
}

/* Trusted brand chip marquee: one row only, safe viewport width, stretched glow,
   no wrapping on desktop/tablet/mobile. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: var(--utap-trusted-band-height) !important;
  min-height: var(--utap-trusted-band-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 0% 50%, rgba(124, 92, 255, .16), rgba(124, 92, 255, .07) 30%, transparent 62%),
    radial-gradient(circle at 100% 50%, rgba(20, 196, 184, .16), rgba(20, 196, 184, .07) 30%, transparent 64%),
    linear-gradient(90deg, rgba(246, 242, 255, .58) 0%, rgba(255, 255, 255, .44) 48%, rgba(235, 249, 255, .60) 100%) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%) !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  height: 100% !important;
  display: flex !important;
  flex-flow: row nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: 0 !important;
  transform: translate3d(0, 0, 0) !important;
  animation-name: utapTrustedLogoTrackLoopV15 !important;
  animation-duration: clamp(54s, 8vw, 88s) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  animation-play-state: running !important;
  will-change: transform !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: paused !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-proof-row .trusted-logo-marquee__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  height: 100% !important;
  display: flex !important;
  flex: 0 0 auto !important;
  flex-flow: row nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 var(--utap-trusted-logo-gap) 0 0 !important;
  gap: var(--utap-trusted-logo-gap) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: clamp(104px, 8vw, 166px) !important;
  max-width: clamp(124px, 10vw, 196px) !important;
  min-height: clamp(64px, 5vw, 94px) !important;
  padding: clamp(4px, .6vw, 10px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#hero-brand-band .logo-chip img,
#hero-proof-row .logo-chip img {
  display: block !important;
  width: var(--trusted-logo-width, auto) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: var(--trusted-logo-max-height, clamp(44px, 5vw, 88px)) !important;
  object-fit: contain !important;
  object-position: center center !important;
  filter: drop-shadow(0 12px 22px rgba(42, 39, 82, .12)) !important;
}

/* uTap Applications: same width system, responsive card grid, no sideways shift. */
.hero-side-box {
  padding: clamp(18px, 2.4vw, 38px) !important;
  border-radius: clamp(22px, 2vw, 34px) !important;
  overflow: visible !important;
}

.hero-side-box__head {
  width: 100% !important;
  max-width: 100% !important;
  text-align: left !important;
  margin: 0 0 clamp(14px, 1.5vw, 22px) !important;
}

.hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(12px, 1.5vw, 22px) !important;
  align-items: stretch !important;
}

.hero-side-card {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* Mobile/tablet: keep the same order, reduce gutters, stack app cards, keep
   logo marquee one row and hero media contained. */
@media (max-width: 980px) {
  :root {
    --utap-canonical-gutter: 14px;
    --utap-canonical-gap: clamp(18px, 5vw, 34px);
    --utap-trusted-band-height: clamp(102px, 18vw, 142px);
    --utap-trusted-logo-gap: clamp(30px, 9vw, 70px);
  }

  .hero-bottom {
    margin-top: clamp(22px, 6vw, 40px) !important;
  }

  .hero-media-row.hero-media-row--original-first,
  .hero-media-row {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  .hero-image-panel,
  .hero-gallery,
  .hero-image-panel__viewport,
  .hero-gallery__viewport,
  #hero-gallery-viewport {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-canonical-gutter: 9px;
    --utap-canonical-gap: 18px;
    --utap-trusted-band-height: 100px;
    --utap-trusted-logo-gap: clamp(24px, 9vw, 48px);
  }

  .hero-bottom {
    width: calc(100vw - 18px) !important;
    max-width: calc(100vw - 18px) !important;
  }

  #hero-trust-copy.trusted-label,
  #hero-proof-row .trusted-label,
  #hero-proof-row .trust-copy {
    font-size: clamp(12px, 3.4vw, 14px) !important;
    text-align: left !important;
  }

  #hero-brand-band.logo-band,
  #hero-proof-row .logo-band,
  #hero-proof-row .trusted-logo-marquee {
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    min-width: clamp(78px, 28vw, 116px) !important;
    max-width: clamp(90px, 34vw, 132px) !important;
    min-height: 58px !important;
  }

  .hero-side-box {
    padding: 18px !important;
    border-radius: 22px !important;
  }

  .hero-side-box__head {
    text-align: left !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}





/* landing-home-fixes-v18
   Current request:
   - uTap Applications belongs directly under the Create Profile CTA, before the
     original theme/template area;
   - original theme media should be visually centered and stable;
   - gallery/template wording should sit above the hero template carousel;
   - image clicks should open the in-page viewer/lightbox rather than only
     toggling a small local scale state;
   - all rules remain responsive and bounded on desktop, laptop, tablet, mobile. */

:root {
  --utap-v18-gutter: clamp(12px, 2.4vw, 48px);
  --utap-v18-content-width: min(1180px, calc(100vw - (var(--utap-v18-gutter) * 2)));
  --utap-v18-template-width: min(1280px, calc(100vw - (var(--utap-v18-gutter) * 2)));
  --utap-v18-app-width: min(1180px, calc(100vw - (var(--utap-v18-gutter) * 2)));
}

html,
body,
.main-hero-wrap,
.browser-shell,
.hero-page,
.hero-stage,
.hero-copy {
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body,
  .main-hero-wrap,
  .browser-shell,
  .hero-page,
  .hero-stage,
  .hero-copy {
    overflow-x: hidden !important;
  }
}

/* 1) uTap Applications: top placement directly after the CTA/feature area. */
.hero-copy > .hero-side-box.hero-side-box--top,
.hero-copy > #hero-side-box.hero-side-box {
  width: var(--utap-v18-app-width) !important;
  max-width: var(--utap-v18-app-width) !important;
  min-width: 0 !important;
  margin: clamp(24px, 3.2vw, 46px) auto clamp(34px, 4.4vw, 72px) !important;
  padding: clamp(18px, 2.1vw, 34px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 24px) !important;
  justify-self: center !important;
  align-self: start !important;
  border-radius: clamp(22px, 2vw, 34px) !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

.hero-copy > .hero-side-box.hero-side-box--top[hidden],
.hero-copy > #hero-side-box.hero-side-box[hidden],
.hero-copy > .hero-side-box.hero-side-box--top[data-utap-public-hidden="1"],
.hero-copy > #hero-side-box.hero-side-box[data-utap-public-hidden="1"] {
  display: none !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__head,
.hero-copy > #hero-side-box.hero-side-box .hero-side-box__head {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  text-align: left !important;
  justify-self: stretch !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
.hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(12px, 1.5vw, 22px) !important;
  align-items: stretch !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-card,
.hero-copy > #hero-side-box.hero-side-box .hero-side-card {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* 2) The lower hero section no longer owns the application card. It is the
      template/original-media stack only, followed by trusted brands. */
.hero-bottom {
  width: var(--utap-v18-template-width) !important;
  max-width: var(--utap-v18-template-width) !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "templates"
    "trusted" !important;
  gap: clamp(24px, 3vw, 50px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-bottom > .hero-media-row.hero-media-row--original-first,
.hero-bottom > .hero-media-row {
  grid-area: templates !important;
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(22px, 3.2vw, 54px) !important;
  justify-items: center !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row {
  grid-area: trusted !important;
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
}

/* 3) Original theme panel: centered in its available width, with the media
      centered inside the viewport. */
.hero-media-row.hero-media-row--original-first .hero-image-panel,
.hero-media-row .hero-image-panel {
  width: min(100%, 980px) !important;
  max-width: min(100%, 980px) !important;
  min-width: 0 !important;
  margin-inline: auto !important;
  justify-self: center !important;
  display: grid !important;
  grid-template-rows: minmax(0, auto) auto !important;
  gap: clamp(12px, 1.4vw, 20px) !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport,
.hero-media-row .hero-image-panel__viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  place-items: center !important;
  justify-items: center !important;
  align-items: center !important;
  overflow: hidden !important;
}

.hero-image-panel__zoom,
.hero-image-panel__zoom > img,
.hero-image-panel__media {
  justify-self: center !important;
  align-self: center !important;
  object-position: center center !important;
}

/* The original image now opens the in-page viewer. Do not create a local
   expanded state that changes layout size or feels like nothing happened. */
.hero-image-panel__viewport.is-expanded {
  box-shadow: 0 22px 56px rgba(37, 35, 79, .12), 0 10px 26px rgba(91, 92, 240, .08) !important;
}

.hero-image-panel__viewport.is-expanded .hero-image-panel__zoom {
  transform: none !important;
}

/* 4) Hero template wording/caption: place it above the carousel/templates. */
.hero-media-row.hero-media-row--original-first .hero-gallery,
.hero-media-row .hero-gallery {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(12px, 1.4vw, 22px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-gallery__caption {
  order: -1 !important;
  width: 100% !important;
  max-width: min(920px, 100%) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
}

.hero-gallery__copy,
.hero-gallery__copy strong,
.hero-gallery__copy span {
  width: 100% !important;
  max-width: 100% !important;
  text-align: center !important;
  justify-self: center !important;
}

.hero-gallery__copy strong {
  display: block !important;
  font-weight: 900 !important;
  color: #25234f !important;
}

.hero-gallery__copy span {
  display: block !important;
  margin-top: 6px !important;
  line-height: 1.5 !important;
  color: #5f6b82 !important;
}

/* Keep the carousel/viewer hit targets alive after layout reordering. */
#hero-gallery-viewport,
#hero-gallery-viewport .hero-carousel,
#hero-gallery-viewport .hero-carousel__mask {
  pointer-events: auto !important;
}

#hero-gallery-viewport .hero-carousel__slide {
  pointer-events: auto !important;
  cursor: zoom-in !important;
}

/* 5) Responsive behavior: same order, smaller gutters, no horizontal scroll. */
@media (max-width: 980px) {
  :root {
    --utap-v18-gutter: clamp(12px, 3.8vw, 28px);
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box {
    margin-top: clamp(20px, 5vw, 34px) !important;
    margin-bottom: clamp(26px, 6vw, 44px) !important;
    padding: clamp(16px, 4vw, 26px) !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
  .hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .hero-bottom {
    gap: clamp(22px, 6vw, 42px) !important;
  }

  .hero-media-row.hero-media-row--original-first .hero-image-panel,
  .hero-media-row .hero-image-panel {
    width: min(100%, 760px) !important;
    max-width: min(100%, 760px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v18-gutter: 10px;
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box,
  .hero-bottom {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box {
    margin-top: 20px !important;
    margin-bottom: 28px !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }

  .hero-gallery__caption {
    max-width: 100% !important;
  }

  .hero-gallery__copy strong {
    font-size: clamp(14px, 4vw, 17px) !important;
  }

  .hero-gallery__copy span {
    font-size: clamp(12px, 3.5vw, 14px) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-image-panel__zoom,
  .hero-image-panel__media,
  #hero-gallery-viewport .hero-carousel__slide {
    transition: none !important;
  }
}

/* landing-home-fixes-v19
   Recovery patch after the section-order regression:
   - restore the hero slogan to the top of the homepage in a centered, readable flow;
   - keep uTap Applications directly below the main Create Profile CTA without
     turning the hero into a side-by-side grid;
   - keep the original theme/template area below that, centered and stable;
   - keep Trusted brand chips below the template area as a one-row marquee;
   - do not alter carousel/viewer JavaScript behavior. */

:root {
  --utap-v19-page-gutter: clamp(12px, 2.4vw, 44px);
  --utap-v19-wide: min(1500px, calc(100vw - (var(--utap-v19-page-gutter) * 2)));
  --utap-v19-content: min(1180px, calc(100vw - (var(--utap-v19-page-gutter) * 2)));
  --utap-v19-template: min(1320px, calc(100vw - (var(--utap-v19-page-gutter) * 2)));
  --utap-v19-gap: clamp(22px, 3vw, 52px);
}

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden !important;
  }
}

.main-hero-wrap,
.browser-shell,
.hero-page,
.hero-stage,
.hero-copy,
.hero-bottom,
.hero-media-row,
.hero-gallery,
.hero-image-panel,
.hero-proof-row,
.trusted-section,
.logo-band,
.hero-side-box {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.main-hero-wrap,
.browser-shell,
.hero-page {
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  .main-hero-wrap,
  .browser-shell,
  .hero-page {
    overflow-x: hidden !important;
  }
}

/* Restore the top hero: title, description and CTA must be the first visual
   story, not a left rail beside the template preview. */
.hero-stage {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding: clamp(28px, 3vw, 54px) var(--utap-v19-page-gutter) clamp(44px, 5vw, 80px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-items: center !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-copy {
  width: 100% !important;
  max-width: var(--utap-v19-wide) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "title"
    "description"
    "cta"
    "apps"
    "bottom" !important;
  justify-items: center !important;
  align-items: start !important;
  gap: 0 !important;
  text-align: center !important;
  overflow: visible !important;
}

/* Force the slogan back to the top and prevent the one-word-per-line break
   caused by older 12-column hero overrides. */
.hero-copy > h1,
#hero-title {
  grid-area: title !important;
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: min(100%, 1120px) !important;
  max-width: 1120px !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 .12em .10em !important;
  color: #2b2750 !important;
  font-size: clamp(3rem, 5.15vw, 5.75rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -.058em !important;
  text-align: center !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  text-wrap: balance !important;
  overflow: visible !important;
}

.hero-title-accent {
  display: inline-block !important;
  margin: 0 !important;
  padding: 0 .18em .10em .04em !important;
  line-height: 1.04 !important;
  white-space: nowrap !important;
}

.hero-copy > p,
#hero-description {
  grid-area: description !important;
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin: clamp(10px, 1.1vw, 18px) auto 0 !important;
  padding: 0 !important;
  color: #5b6277 !important;
  font-size: clamp(1rem, 1.02vw, 1.14rem) !important;
  line-height: 1.68 !important;
  letter-spacing: normal !important;
  text-align: center !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  text-wrap: pretty !important;
}

.hero-actions {
  grid-area: cta !important;
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  min-height: 0 !important;
  margin: var(--landing-hero-cta-gap) auto 0 !important;
  padding: 0 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-direction: row !important;
  gap: 0 !important;
  text-align: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hero-actions::before,
.hero-actions::after {
  content: none !important;
  display: none !important;
}

.hero-actions .btn,
#hero-browse-templates.btn--large {
  min-width: min(100%, 300px) !important;
  max-width: min(100%, 440px) !important;
  min-height: clamp(54px, 4vw, 68px) !important;
}

/* The legacy feature checklist should not reserve a blank grid column. If the
   list is used later, it can still render, but it stays in normal centered flow. */
.feature-panel {
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  justify-self: center !important;
  width: min(100%, 780px) !important;
  max-width: 780px !important;
  margin: clamp(24px, 2.4vw, 36px) auto 0 !important;
}

/* uTap Applications: directly below the Create Profile CTA, not in the trusted
   logo area and not pushed to the right. */
.hero-copy > .hero-side-box.hero-side-box--top,
.hero-copy > #hero-side-box.hero-side-box {
  grid-area: apps !important;
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: min(100%, 1320px) !important;
  max-width: min(100%, 1320px) !important;
  min-width: 0 !important;
  margin: clamp(30px, 3.2vw, 50px) auto 0 !important;
  padding: clamp(18px, 2.1vw, 32px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 24px) !important;
  justify-self: center !important;
  align-self: start !important;
  border-radius: clamp(22px, 2vw, 34px) !important;
  background: rgba(255,255,255,.72) !important;
  border: 1px solid rgba(188,183,219,.34) !important;
  box-shadow: 0 22px 60px rgba(108, 95, 165, .10) !important;
  overflow: visible !important;
  box-sizing: border-box !important;
  text-align: left !important;
}

.hero-copy > .hero-side-box.hero-side-box--top[hidden],
.hero-copy > #hero-side-box.hero-side-box[hidden],
.hero-copy > .hero-side-box.hero-side-box--top[data-utap-public-hidden="1"],
.hero-copy > #hero-side-box.hero-side-box[data-utap-public-hidden="1"] {
  display: none !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__head,
.hero-copy > #hero-side-box.hero-side-box .hero-side-box__head {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  text-align: left !important;
  justify-self: stretch !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
.hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(12px, 1.5vw, 22px) !important;
  align-items: stretch !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-card,
.hero-copy > #hero-side-box.hero-side-box .hero-side-card {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* Lower stack: original template, hero carousel/templates, then trusted brand
   chips. Keep it contained and centered. */
.hero-bottom {
  grid-area: bottom !important;
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: var(--utap-v19-template) !important;
  max-width: var(--utap-v19-template) !important;
  min-width: 0 !important;
  margin: clamp(42px, 4.8vw, 78px) auto 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "templates"
    "trusted" !important;
  gap: clamp(28px, 3.2vw, 56px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-bottom > .hero-media-row.hero-media-row--original-first,
.hero-bottom > .hero-media-row {
  grid-area: templates !important;
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(24px, 3vw, 54px) !important;
  justify-items: center !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel,
.hero-media-row .hero-image-panel {
  width: min(100%, 980px) !important;
  max-width: min(100%, 980px) !important;
  min-width: 0 !important;
  margin-inline: auto !important;
  justify-self: center !important;
  display: grid !important;
  grid-template-rows: minmax(0, auto) auto !important;
  gap: clamp(12px, 1.4vw, 20px) !important;
}

.hero-media-row.hero-media-row--original-first .hero-image-panel__viewport,
.hero-media-row .hero-image-panel__viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  place-items: center !important;
  justify-items: center !important;
  align-items: center !important;
  overflow: hidden !important;
}

.hero-image-panel__zoom,
.hero-image-panel__zoom > img,
.hero-image-panel__media {
  justify-self: center !important;
  align-self: center !important;
  object-fit: contain !important;
  object-position: center center !important;
}

/* Put the "Customized branded themes..." wording above the template carousel,
   without pushing the main hero slogan away from the top. */
.hero-media-row.hero-media-row--original-first .hero-gallery,
.hero-media-row .hero-gallery {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 24px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
}

.hero-gallery__caption {
  order: -1 !important;
  width: 100% !important;
  max-width: min(980px, 100%) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
}

.hero-gallery__copy,
.hero-gallery__copy strong,
.hero-gallery__copy span {
  width: 100% !important;
  max-width: 100% !important;
  text-align: center !important;
  justify-self: center !important;
}

.hero-gallery__copy strong {
  display: block !important;
  font-weight: 900 !important;
  color: #25234f !important;
}

.hero-gallery__copy span {
  display: block !important;
  margin-top: 6px !important;
  line-height: 1.5 !important;
  color: #5f6b82 !important;
}

/* Trusted brand chips stay below the template section and remain a single-row
   continuous marquee. */
.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row {
  grid-area: trusted !important;
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#hero-proof-row .trusted-section,
#hero-proof-row .hero-proof-row__brands {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 24px) !important;
  justify-items: stretch !important;
  align-items: start !important;
  overflow: visible !important;
}

#hero-trust-copy.trusted-label,
#hero-proof-row .trusted-label,
#hero-proof-row .trust-copy {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #4f586d !important;
  opacity: .78 !important;
  line-height: 1.35 !important;
  text-align: left !important;
  justify-self: start !important;
  white-space: normal !important;
}

#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: clamp(116px, 9.5vw, 172px) !important;
  min-height: clamp(116px, 9.5vw, 172px) !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 2% 52%, rgba(124, 92, 255, .16), rgba(124, 92, 255, .07) 28%, transparent 62%),
    radial-gradient(circle at 98% 52%, rgba(20, 196, 184, .16), rgba(20, 196, 184, .07) 30%, transparent 64%),
    linear-gradient(90deg, rgba(245, 242, 255, .54) 0%, rgba(255, 255, 255, .38) 46%, rgba(235, 249, 255, .56) 100%) !important;
  box-shadow: none !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
  mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%) !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  height: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: 0 !important;
  animation-name: utapTrustedLogoTrackLoopV15 !important;
  animation-duration: clamp(46s, 7vw, 78s) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  will-change: transform !important;
}

#hero-brand-band .logo-band__set,
#hero-proof-row .logo-band__set,
#hero-proof-row .trusted-logo-marquee__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  height: 100% !important;
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: clamp(46px, 7vw, 120px) !important;
  padding-right: clamp(46px, 7vw, 120px) !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
}

#hero-brand-band .logo-chip,
#hero-proof-row .logo-chip {
  flex: 0 0 auto !important;
  display: grid !important;
  place-items: center !important;
  min-width: clamp(92px, 9vw, 170px) !important;
  max-width: clamp(104px, 10vw, 190px) !important;
  min-height: 72px !important;
  margin: 0 !important;
  padding: clamp(8px, .9vw, 16px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Keep carousel and viewer click targets alive. */
#hero-gallery-viewport,
#hero-gallery-viewport .hero-carousel,
#hero-gallery-viewport .hero-carousel__mask,
#hero-gallery-viewport .hero-carousel__slide,
.hero-image-panel__zoom {
  pointer-events: auto !important;
}

#hero-gallery-viewport .hero-carousel__slide,
.hero-image-panel__zoom {
  cursor: zoom-in !important;
}

/* Responsive: same order, smaller gutters, no horizontal scroll. */
@media (max-width: 980px) {
  :root {
    --utap-v19-page-gutter: clamp(12px, 3.8vw, 28px);
  }

  .hero-copy > h1,
  #hero-title {
    width: min(100%, 900px) !important;
    max-width: 900px !important;
    font-size: clamp(2.45rem, 8vw, 4.25rem) !important;
    line-height: 1.04 !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box {
    margin-top: clamp(24px, 5vw, 40px) !important;
    padding: clamp(16px, 4vw, 26px) !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
  .hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .hero-bottom {
    gap: clamp(24px, 6vw, 44px) !important;
  }

  .hero-media-row.hero-media-row--original-first .hero-image-panel,
  .hero-media-row .hero-image-panel {
    width: min(100%, 760px) !important;
    max-width: min(100%, 760px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v19-page-gutter: 10px;
  }

  .hero-stage {
    padding-top: clamp(22px, 7vw, 34px) !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .hero-copy > h1,
  #hero-title {
    width: min(100%, 360px) !important;
    max-width: 360px !important;
    font-size: clamp(2.3rem, 11vw, 3.35rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -.052em !important;
  }

  .hero-title-accent {
    white-space: normal !important;
  }

  .hero-copy > p,
  #hero-description {
    width: min(100%, 340px) !important;
    max-width: 340px !important;
    margin-top: 8px !important;
    font-size: clamp(.95rem, 4vw, 1.05rem) !important;
    line-height: 1.56 !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box,
  .hero-bottom {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box {
    margin-top: 22px !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }

  .hero-gallery__caption {
    max-width: 100% !important;
  }

  #hero-brand-band.logo-band,
  #hero-proof-row .logo-band,
  #hero-proof-row .trusted-logo-marquee {
    height: 104px !important;
    min-height: 104px !important;
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%) !important;
    mask-image: linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%) !important;
  }

  #hero-brand-band .logo-band__set,
  #hero-proof-row .logo-band__set,
  #hero-proof-row .trusted-logo-marquee__set,
  #hero-brand-band .logo-band__set[aria-hidden="true"],
  #hero-proof-row .logo-band__set[aria-hidden="true"],
  #hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
    gap: clamp(28px, 9vw, 58px) !important;
    padding-right: clamp(28px, 9vw, 58px) !important;
  }

  #hero-brand-band .logo-chip,
  #hero-proof-row .logo-chip {
    min-width: clamp(82px, 30vw, 126px) !important;
    max-width: clamp(92px, 36vw, 140px) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}



/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v18
   - keep hero slogan in the top hero story;
   - place uTap Applications immediately below the Create Profile CTA;
   - keep legacy feature panel from reserving space;
   - make template opening intentional: double-click/double-tap in JS;
   - remove active-scale jump while arrows center templates smoothly.
   ────────────────────────────────────────────────────────────── */

.hero-copy {
  grid-template-areas:
    "title"
    "description"
    "cta"
    "apps"
    "bottom" !important;
  justify-items: center !important;
}

/* This empty legacy checklist was sitting between the CTA and apps in the DOM
   and could push Applications away from the Create Profile button. */
.hero-copy > .feature-panel,
.feature-panel:has(#hero-feature-list:empty) {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  min-height: 0 !important;
}

.hero-copy > .hero-side-box.hero-side-box--top,
.hero-copy > #hero-side-box.hero-side-box {
  grid-area: apps !important;
  width: min(100%, 1320px) !important;
  max-width: min(100%, 1320px) !important;
  margin: clamp(22px, 2.5vw, 34px) auto 0 !important;
  justify-self: center !important;
  align-self: start !important;
}

.hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
.hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* Prevent the selected template from visually jumping when one click only
   selects/centers it. Hover can still give a soft premium lift. */
#hero-gallery-viewport .hero-carousel__slide,
#hero-gallery-viewport .hero-carousel__slide.is-active,
#hero-gallery-viewport .hero-carousel__slide.is-active:not(:hover):not(:focus-visible):not(:focus-within) {
  transform: translate3d(0, 0, 0) scale(1) !important;
}

#hero-gallery-viewport .hero-carousel__slide:hover,
#hero-gallery-viewport .hero-carousel__slide:focus-visible,
#hero-gallery-viewport .hero-carousel__slide:focus-within {
  transform: translate3d(0, -3px, 0) scale(1.01) !important;
}

#hero-gallery-viewport .hero-carousel__track {
  transition-timing-function: cubic-bezier(.22,.61,.36,1) !important;
}

#hero-gallery-viewport .hero-carousel__nav {
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 140 !important;
}

#hero-gallery-viewport .hero-carousel__nav:hover,
#hero-gallery-viewport .hero-carousel__nav:focus-visible {
  transform: translateY(-50%) scale(1.045) !important;
}

@media (max-width: 980px) {
  .hero-copy > .hero-side-box.hero-side-box--top .hero-side-box__items,
  .hero-copy > #hero-side-box.hero-side-box .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

@media (max-width: 560px) {
  .hero-copy > .hero-side-box.hero-side-box--top,
  .hero-copy > #hero-side-box.hero-side-box {
    margin-top: 18px !important;
  }
}


/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v19
   - keep Create Profile CTA and uTap Applications as separate editable blocks;
   - Applications is its own section below the CTA, not merged into hero-actions;
   - keep the restored hero title flow, double-click template viewing, and carousel centering.
   ────────────────────────────────────────────────────────────── */

.hero-stage {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "copy"
    "apps"
    "bottom" !important;
  justify-items: center !important;
  align-items: start !important;
}

.hero-copy {
  grid-area: copy !important;
  width: 100% !important;
  max-width: var(--utap-v19-wide, min(1500px, calc(100vw - 48px))) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "title"
    "description"
    "cta" !important;
  justify-items: center !important;
  align-items: start !important;
  gap: 0 !important;
  text-align: center !important;
}

.hero-copy > .hero-actions {
  grid-area: cta !important;
  position: relative !important;
  z-index: 3 !important;
  width: auto !important;
  max-width: 100% !important;
  margin: var(--landing-hero-cta-gap) auto 0 !important;
  padding: 0 !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Keep the app block independent from the CTA so it can be moved/edited without
   touching the Create Profile button. */
.hero-apps-section {
  grid-area: apps !important;
  width: min(100%, 1320px) !important;
  max-width: min(100%, 1320px) !important;
  min-width: 0 !important;
  margin: clamp(22px, 2.5vw, 36px) auto 0 !important;
  padding: 0 !important;
  display: block !important;
  justify-self: center !important;
  align-self: start !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.hero-apps-section > .hero-side-box.hero-side-box--top,
.hero-apps-section > #hero-side-box.hero-side-box {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: clamp(18px, 2.1vw, 32px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 24px) !important;
  justify-self: stretch !important;
  align-self: start !important;
  border-radius: clamp(22px, 2vw, 34px) !important;
  background: rgba(255,255,255,.74) !important;
  border: 1px solid rgba(188,183,219,.34) !important;
  box-shadow: 0 22px 60px rgba(108, 95, 165, .10) !important;
  text-align: left !important;
  overflow: visible !important;
  box-sizing: border-box !important;
  transform: none !important;
}

.hero-apps-section > .hero-side-box.hero-side-box--top[hidden],
.hero-apps-section > #hero-side-box.hero-side-box[hidden],
.hero-apps-section > .hero-side-box.hero-side-box--top[data-utap-public-hidden="1"],
.hero-apps-section > #hero-side-box.hero-side-box[data-utap-public-hidden="1"] {
  display: none !important;
}

.hero-apps-section > .hero-side-box.hero-side-box--top .hero-side-box__head,
.hero-apps-section > #hero-side-box.hero-side-box .hero-side-box__head {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  text-align: left !important;
  justify-self: stretch !important;
}

.hero-apps-section > .hero-side-box.hero-side-box--top .hero-side-box__items,
.hero-apps-section > #hero-side-box.hero-side-box .hero-side-box__items {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(12px, 1.5vw, 22px) !important;
  align-items: stretch !important;
}

.hero-apps-section > .hero-side-box.hero-side-box--top .hero-side-card,
.hero-apps-section > #hero-side-box.hero-side-box .hero-side-card {
  min-width: 0 !important;
  max-width: 100% !important;
}

.hero-bottom {
  grid-area: bottom !important;
  width: var(--utap-v19-template, min(1320px, calc(100vw - 48px))) !important;
  max-width: var(--utap-v19-template, min(1320px, calc(100vw - 48px))) !important;
  margin: clamp(42px, 4.8vw, 78px) auto 0 !important;
}

@media (max-width: 980px) {
  .hero-apps-section {
    width: min(100%, 860px) !important;
    max-width: min(100%, 860px) !important;
    margin-top: clamp(20px, 4vw, 32px) !important;
  }

  .hero-apps-section > .hero-side-box.hero-side-box--top,
  .hero-apps-section > #hero-side-box.hero-side-box {
    padding: clamp(16px, 4vw, 26px) !important;
  }

  .hero-apps-section > .hero-side-box.hero-side-box--top .hero-side-box__items,
  .hero-apps-section > #hero-side-box.hero-side-box .hero-side-box__items {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

@media (max-width: 560px) {
  .hero-apps-section,
  .hero-bottom {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

  .hero-apps-section {
    margin-top: 18px !important;
  }

  .hero-apps-section > .hero-side-box.hero-side-box--top,
  .hero-apps-section > #hero-side-box.hero-side-box {
    padding: 16px !important;
    border-radius: 22px !important;
  }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v20
   - keep every major hero/lower-home section as its own editable box;
   - Applications, Original Theme, Hero Templates, and Trusted Brand Chips
     are visually separate cards/sections, not merged into one container;
   - preserve v18/v19 template double-click viewer and arrow centering logic.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v20-section-width: min(1320px, calc(100vw - 48px));
  --utap-v20-original-width: min(980px, 100%);
  --utap-v20-card-radius: clamp(22px, 2vw, 34px);
  --utap-v20-card-border: 1px solid rgba(188, 183, 219, .38);
  --utap-v20-card-bg: rgba(255, 255, 255, .74);
  --utap-v20-card-shadow: 0 22px 60px rgba(72, 61, 126, .09);
}

/* Shared box primitive: each section can now be moved or edited separately. */
.hero-edit-box,
.hero-apps-box,
.hero-original-theme-box,
.hero-template-carousel-box,
.hero-brand-chip-box {
  box-sizing: border-box !important;
  min-width: 0 !important;
}

.hero-stage {
  grid-template-areas:
    "copy"
    "apps"
    "bottom" !important;
}

.hero-apps-section.hero-apps-box {
  grid-area: apps !important;
  width: var(--utap-v20-section-width) !important;
  max-width: var(--utap-v20-section-width) !important;
  margin: clamp(22px, 2.4vw, 34px) auto 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* The app content is one independent card; it is below the CTA but not inside it. */
.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: clamp(18px, 2vw, 30px) !important;
  border-radius: var(--utap-v20-card-radius) !important;
  border: var(--utap-v20-card-border) !important;
  background: var(--utap-v20-card-bg) !important;
  box-shadow: var(--utap-v20-card-shadow) !important;
  overflow: hidden !important;
}

.hero-bottom {
  width: var(--utap-v20-section-width) !important;
  max-width: var(--utap-v20-section-width) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: clamp(28px, 3vw, 52px) !important;
  margin: clamp(42px, 4.5vw, 72px) auto 0 !important;
  overflow: visible !important;
}

.hero-bottom > .hero-media-row.hero-media-row--original-first,
.hero-bottom > .hero-media-row {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: clamp(28px, 3vw, 52px) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

/* Box 1: Original Theme. Keep the preview centered inside its own card. */
.hero-original-theme-box,
.hero-media-row .hero-original-theme-box,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box {
  width: var(--utap-v20-original-width) !important;
  max-width: var(--utap-v20-original-width) !important;
  margin: 0 auto !important;
  padding: clamp(16px, 2vw, 28px) !important;
  border-radius: var(--utap-v20-card-radius) !important;
  border: var(--utap-v20-card-border) !important;
  background: rgba(255, 255, 255, .72) !important;
  box-shadow: var(--utap-v20-card-shadow) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(12px, 1.5vw, 20px) !important;
  justify-items: center !important;
  overflow: hidden !important;
}

.hero-original-theme-box .hero-image-panel__viewport {
  width: 100% !important;
  max-width: 100% !important;
  display: grid !important;
  place-items: center !important;
  justify-items: center !important;
  align-items: center !important;
  margin: 0 auto !important;
}

.hero-original-theme-box .hero-image-panel__zoom,
.hero-original-theme-box .hero-image-panel__zoom > img,
.hero-original-theme-box .hero-image-panel__media {
  margin-inline: auto !important;
  justify-self: center !important;
  align-self: center !important;
  object-fit: contain !important;
  object-position: center center !important;
}

/* Box 2: Hero Template carousel. It is a separate card from Original Theme. */
.hero-template-carousel-box,
.hero-media-row .hero-template-carousel-box,
.hero-media-row.hero-media-row--original-first .hero-template-carousel-box {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding: clamp(16px, 2vw, 28px) 0 clamp(16px, 2vw, 28px) !important;
  border-radius: var(--utap-v20-card-radius) !important;
  border: var(--utap-v20-card-border) !important;
  background: rgba(255, 255, 255, .46) !important;
  box-shadow: var(--utap-v20-card-shadow) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(16px, 1.8vw, 26px) !important;
  overflow: hidden !important;
}

.hero-template-carousel-box .hero-gallery__caption {
  order: -1 !important;
  width: min(980px, calc(100% - 32px)) !important;
  max-width: min(980px, calc(100% - 32px)) !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.hero-template-carousel-box #hero-gallery-viewport,
.hero-template-carousel-box .hero-gallery__viewport {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

/* Box 3: Trusted Brand Chips. Keep the marquee in its own box with its own glow. */
.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  overflow: visible !important;
}

.hero-brand-chip-box,
#hero-proof-row .hero-brand-chip-box,
#hero-proof-row .trusted-section.hero-brand-chip-box {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: clamp(16px, 1.8vw, 26px) !important;
  border-radius: var(--utap-v20-card-radius) !important;
  border: var(--utap-v20-card-border) !important;
  background: rgba(255, 255, 255, .42) !important;
  box-shadow: var(--utap-v20-card-shadow) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: clamp(14px, 1.6vw, 22px) !important;
  overflow: hidden !important;
}

.hero-brand-chip-box #hero-brand-band,
#hero-proof-row .hero-brand-chip-box .logo-band,
#hero-proof-row .hero-brand-chip-box .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  border-radius: clamp(18px, 1.6vw, 28px) !important;
  overflow: hidden !important;
}

@media (max-width: 980px) {
  :root {
    --utap-v20-section-width: min(860px, calc(100vw - 28px));
  }

  .hero-bottom {
    gap: clamp(24px, 5vw, 42px) !important;
  }

  .hero-template-carousel-box,
  .hero-brand-chip-box,
  .hero-apps-section.hero-apps-box > .hero-side-box,
  .hero-apps-section.hero-apps-box > #hero-side-box {
    border-radius: 26px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v20-section-width: calc(100vw - 20px);
  }

  .hero-apps-section.hero-apps-box,
  .hero-bottom {
    width: var(--utap-v20-section-width) !important;
    max-width: var(--utap-v20-section-width) !important;
  }

  .hero-original-theme-box,
  .hero-template-carousel-box,
  .hero-brand-chip-box,
  .hero-apps-section.hero-apps-box > .hero-side-box,
  .hero-apps-section.hero-apps-box > #hero-side-box {
    padding: 14px !important;
    border-radius: 22px !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v21
   - flatten Trusted Brand Chips and Hero Template carousel sections;
   - keep them as independently editable sections, but remove visible card boxes;
   - stretch the moving bands safely toward the browser edges;
   - do not touch JS/functionality.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v21-page-gutter: clamp(10px, 1.6vw, 28px);
  --utap-v21-edge-width: calc(100vw - (var(--utap-v21-page-gutter) * 2));
  --utap-v21-flat-band-radius: clamp(14px, 1.4vw, 24px);
}

/* Keep separate editable boxes, but make these two sections visually flat. */
.hero-template-carousel-box,
.hero-media-row .hero-template-carousel-box,
.hero-media-row.hero-media-row--original-first .hero-template-carousel-box,
.hero-brand-chip-box,
#hero-proof-row .hero-brand-chip-box,
#hero-proof-row .trusted-section.hero-brand-chip-box {
  width: var(--utap-v21-edge-width) !important;
  max-width: var(--utap-v21-edge-width) !important;
  margin-left: calc(50% - 50vw + var(--utap-v21-page-gutter)) !important;
  margin-right: calc(50% - 50vw + var(--utap-v21-page-gutter)) !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;
}

/* Template caption: normal readable text, not bold/card-like. */
.hero-template-carousel-box .hero-gallery__caption,
.hero-template-carousel-box .hero-gallery__caption p,
.hero-template-carousel-box .hero-gallery__caption strong,
.hero-template-carousel-box .hero-gallery__caption b,
.hero-template-carousel-box .hero-gallery__caption .section-lead,
.hero-template-carousel-box .hero-gallery__caption .hero-gallery__caption-text {
  font-weight: 400 !important;
  letter-spacing: normal !important;
  color: rgba(33, 36, 68, .78) !important;
}

.hero-template-carousel-box .hero-gallery__caption {
  width: min(1040px, calc(100% - 32px)) !important;
  max-width: min(1040px, calc(100% - 32px)) !important;
  margin: 0 auto clamp(12px, 1.4vw, 20px) !important;
  text-align: center !important;
  line-height: 1.55 !important;
}

/* Hero template carousel: flat band, no visible card border/background. */
.hero-template-carousel-box #hero-gallery-viewport,
.hero-template-carousel-box .hero-gallery__viewport,
.hero-template-carousel-box .hero-gallery,
.hero-template-carousel-box .hero-carousel,
.hero-template-carousel-box .hero-carousel__mask {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.hero-template-carousel-box .hero-carousel {
  padding-inline: clamp(18px, 3vw, 56px) !important;
}

/* Trusted brand chips: flatten the container and make only the soft glow band visible. */
.hero-brand-chip-box .trusted-heading,
#hero-proof-row .hero-brand-chip-box .trusted-heading,
#hero-proof-row .trusted-section.hero-brand-chip-box .trusted-heading,
#hero-proof-row .hero-brand-chip-box h2,
#hero-proof-row .hero-brand-chip-box h3,
#hero-proof-row .hero-brand-chip-box p:first-child {
  width: min(1040px, calc(100% - 32px)) !important;
  max-width: min(1040px, calc(100% - 32px)) !important;
  margin: 0 auto clamp(14px, 1.5vw, 22px) !important;
}

.hero-brand-chip-box #hero-brand-band,
#hero-proof-row .hero-brand-chip-box .logo-band,
#hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
#hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
#hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
  width: 100% !important;
  max-width: 100% !important;
  min-height: clamp(96px, 9vw, 142px) !important;
  margin: 0 !important;
  padding-block: clamp(14px, 2vw, 26px) !important;
  padding-inline: clamp(16px, 3vw, 58px) !important;
  border: 0 !important;
  border-radius: var(--utap-v21-flat-band-radius) !important;
  background:
    radial-gradient(circle at 10% 50%, rgba(137, 110, 255, .18), transparent 34%),
    radial-gradient(circle at 92% 48%, rgba(18, 205, 211, .22), transparent 36%),
    linear-gradient(90deg, rgba(247, 244, 255, .72), rgba(255, 255, 255, .48) 45%, rgba(228, 251, 252, .72)) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

/* Prevent old card rules from leaving a tall empty box around the brand band. */
.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row {
  width: var(--utap-v21-edge-width) !important;
  max-width: var(--utap-v21-edge-width) !important;
  margin-left: calc(50% - 50vw + var(--utap-v21-page-gutter)) !important;
  margin-right: calc(50% - 50vw + var(--utap-v21-page-gutter)) !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Keep Original Theme and Applications as separate card boxes. Only flatten template/brand sections. */
.hero-original-theme-box,
.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box {
  border: var(--utap-v20-card-border) !important;
  background: var(--utap-v20-card-bg) !important;
  box-shadow: var(--utap-v20-card-shadow) !important;
}

@media (max-width: 980px) {
  :root {
    --utap-v21-page-gutter: clamp(8px, 2.2vw, 18px);
  }

  .hero-template-carousel-box .hero-carousel {
    padding-inline: clamp(10px, 2.8vw, 28px) !important;
  }

  .hero-brand-chip-box #hero-brand-band,
  #hero-proof-row .hero-brand-chip-box .logo-band,
  #hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
  #hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
    min-height: clamp(82px, 14vw, 116px) !important;
    padding-inline: clamp(12px, 3vw, 28px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v21-page-gutter: 8px;
  }

  .hero-template-carousel-box .hero-gallery__caption,
  .hero-brand-chip-box .trusted-heading,
  #hero-proof-row .hero-brand-chip-box .trusted-heading,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-heading,
  #hero-proof-row .hero-brand-chip-box h2,
  #hero-proof-row .hero-brand-chip-box h3,
  #hero-proof-row .hero-brand-chip-box p:first-child {
    width: calc(100% - 20px) !important;
    max-width: calc(100% - 20px) !important;
  }

  .hero-template-carousel-box .hero-carousel {
    padding-inline: 8px !important;
  }

  .hero-brand-chip-box #hero-brand-band,
  #hero-proof-row .hero-brand-chip-box .logo-band,
  #hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
  #hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
    min-height: 78px !important;
    padding-block: 10px !important;
    border-radius: 16px !important;
  }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v22
   - correct v21 double-breakout that made the Trusted brand band drift left;
   - keep Trusted Brand Chips and Hero Template carousel visually flat;
   - make Applications card softer/faded;
   - move the "Customized branded themes..." caption lower and normal weight;
   - CSS/layout only: no carousel/viewer JS behavior is changed.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v22-gutter: clamp(8px, 1.2vw, 22px);
  --utap-v22-flat-width: calc(100vw - (var(--utap-v22-gutter) * 2));
  --utap-v22-band-radius: clamp(12px, 1.2vw, 20px);
}

/* The outer section owns the full-bleed/edge-to-edge width once.
   Children must NOT repeat the breakout, otherwise the band shifts left. */
.hero-bottom > #hero-proof-row.hero-proof-row,
#hero-proof-row.hero-proof-row,
.hero-template-carousel-box,
.hero-media-row .hero-template-carousel-box,
.hero-media-row.hero-media-row--original-first .hero-template-carousel-box {
  position: relative !important;
  left: 50% !important;
  right: auto !important;
  width: var(--utap-v22-flat-width) !important;
  max-width: var(--utap-v22-flat-width) !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  transform: translateX(-50%) !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;
}

/* Reset inner brand box so it stays centered inside the one true full-width row. */
.hero-brand-chip-box,
#hero-proof-row .hero-brand-chip-box,
#hero-proof-row .trusted-section.hero-brand-chip-box {
  position: static !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;
}

/* Trusted heading: keep it aligned to the flat band, but do not create a card. */
.hero-brand-chip-box .trusted-heading,
#hero-proof-row .hero-brand-chip-box .trusted-heading,
#hero-proof-row .trusted-section.hero-brand-chip-box .trusted-heading,
#hero-proof-row .hero-brand-chip-box h2,
#hero-proof-row .hero-brand-chip-box h3,
#hero-proof-row .hero-brand-chip-box p:first-child {
  width: min(1280px, calc(100% - clamp(28px, 5vw, 92px))) !important;
  max-width: min(1280px, calc(100% - clamp(28px, 5vw, 92px))) !important;
  margin: 0 auto clamp(12px, 1.1vw, 18px) !important;
  padding: 0 !important;
  text-align: left !important;
}

/* Trusted band: flatter, lower height, centered, no visible outer box. */
.hero-brand-chip-box #hero-brand-band,
#hero-proof-row .hero-brand-chip-box .logo-band,
#hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
#hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
#hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
  position: relative !important;
  left: auto !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  min-height: clamp(72px, 6.8vw, 104px) !important;
  margin: 0 auto !important;
  padding-block: clamp(8px, 1.1vw, 16px) !important;
  padding-inline: clamp(18px, 4vw, 72px) !important;
  border: 0 !important;
  border-radius: var(--utap-v22-band-radius) !important;
  background:
    radial-gradient(circle at 12% 50%, rgba(137, 110, 255, .15), transparent 32%),
    radial-gradient(circle at 88% 50%, rgba(18, 205, 211, .18), transparent 34%),
    linear-gradient(90deg, rgba(247, 244, 255, .60), rgba(255, 255, 255, .34) 46%, rgba(228, 251, 252, .58)) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

/* Keep the logo row vertically compact inside the flatter band. */
#hero-proof-row .logo-track,
#hero-proof-row .trusted-logo-track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  min-height: 0 !important;
  align-items: center !important;
}

#hero-proof-row .logo-chip,
#hero-proof-row .trusted-logo-chip,
#hero-proof-row .logo-band__item,
#hero-proof-row .trusted-logo-marquee__item {
  margin-block: 0 !important;
}

/* Hero template carousel: flat and edge-to-edge, but no card outline. */
.hero-template-carousel-box #hero-gallery-viewport,
.hero-template-carousel-box .hero-gallery__viewport,
.hero-template-carousel-box .hero-gallery,
.hero-template-carousel-box .hero-carousel,
.hero-template-carousel-box .hero-carousel__mask {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.hero-template-carousel-box .hero-carousel {
  padding-inline: clamp(16px, 3.4vw, 70px) !important;
}

/* Bring the customized-themes wording lower, closer to its templates,
   and make it normal/prudent rather than bold. */
.hero-template-carousel-box .hero-gallery__caption {
  width: min(1080px, calc(100% - clamp(28px, 5vw, 92px))) !important;
  max-width: min(1080px, calc(100% - clamp(28px, 5vw, 92px))) !important;
  margin: clamp(34px, 5.2vw, 86px) auto clamp(18px, 2vw, 32px) !important;
  padding: 0 !important;
  text-align: center !important;
  line-height: 1.55 !important;
}

.hero-template-carousel-box .hero-gallery__caption,
.hero-template-carousel-box .hero-gallery__caption *,
.hero-template-carousel-box .hero-gallery__caption p,
.hero-template-carousel-box .hero-gallery__caption strong,
.hero-template-carousel-box .hero-gallery__caption b,
.hero-template-carousel-box .hero-gallery__caption .section-lead,
.hero-template-carousel-box .hero-gallery__caption .hero-gallery__caption-text {
  font-weight: 400 !important;
  letter-spacing: normal !important;
  color: rgba(33, 36, 68, .74) !important;
}

/* Applications card: keep it a separate editable box, but make the box more faded. */
.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box {
  background: rgba(255, 255, 255, .46) !important;
  border-color: rgba(202, 210, 238, .46) !important;
  box-shadow: 0 18px 54px rgba(43, 38, 96, .07) !important;
  backdrop-filter: blur(10px) saturate(1.02) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.02) !important;
}

.hero-apps-section.hero-apps-box .hero-side-card,
.hero-apps-section.hero-apps-box .hero-app-card,
.hero-apps-section.hero-apps-box .hero-side-box__card {
  background: rgba(255, 255, 255, .58) !important;
  border-color: rgba(202, 210, 238, .48) !important;
  box-shadow: 0 10px 26px rgba(43, 38, 96, .045) !important;
}

/* Tablet/mobile keeps the same canonical centered full-width logic. */
@media (max-width: 980px) {
  :root {
    --utap-v22-gutter: clamp(8px, 2vw, 16px);
  }

  .hero-brand-chip-box #hero-brand-band,
  #hero-proof-row .hero-brand-chip-box .logo-band,
  #hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
  #hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
    min-height: clamp(66px, 10vw, 92px) !important;
    padding-inline: clamp(14px, 3vw, 36px) !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    margin-top: clamp(28px, 6vw, 64px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v22-gutter: 8px;
  }

  .hero-brand-chip-box .trusted-heading,
  #hero-proof-row .hero-brand-chip-box .trusted-heading,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-heading,
  #hero-proof-row .hero-brand-chip-box h2,
  #hero-proof-row .hero-brand-chip-box h3,
  #hero-proof-row .hero-brand-chip-box p:first-child,
  .hero-template-carousel-box .hero-gallery__caption {
    width: calc(100% - 20px) !important;
    max-width: calc(100% - 20px) !important;
  }

  .hero-brand-chip-box #hero-brand-band,
  #hero-proof-row .hero-brand-chip-box .logo-band,
  #hero-proof-row .hero-brand-chip-box .trusted-logo-marquee,
  #hero-proof-row .trusted-section.hero-brand-chip-box .logo-band,
  #hero-proof-row .trusted-section.hero-brand-chip-box .trusted-logo-marquee {
    min-height: 64px !important;
    padding-block: 8px !important;
    border-radius: 14px !important;
  }

  .hero-template-carousel-box .hero-carousel {
    padding-inline: 8px !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    margin-top: 30px !important;
    margin-bottom: 16px !important;
  }
}


/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v23
   Scope: visual/layout only for the requested sections.
   - Brand chips move slowly to the right with one track animation.
   - Original Theme preview image is enlarged inside its own box.
   - Customized branded-themes caption is placed closer to the template images,
     and the "Customized branded themes" phrase is emphasized.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v23-logo-duration: 132s;
  --utap-v23-original-height: clamp(520px, 42vw, 720px);
}

/* Brand chips: the old rules animated the set/track left.
   This final rule makes only the duplicated track move right, slower and smooth. */
@keyframes utapTrustedLogoTrackLoopRightV23 {
  from { transform: translate3d(-50%, 0, 0); }
  to { transform: translate3d(0, 0, 0); }
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set,
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  animation: none !important;
  transform: none !important;
  will-change: auto !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  animation-name: utapTrustedLogoTrackLoopRightV23 !important;
  animation-duration: var(--utap-v23-logo-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-fill-mode: both !important;
  animation-direction: normal !important;
  will-change: transform !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: paused !important;
}

/* Original Theme: keep it as a separate editable box, but make the preview
   image feel intentional instead of sitting small in a large empty area. */
.hero-original-theme-box,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box {
  width: min(100%, 1080px) !important;
  max-width: min(100%, 1080px) !important;
  margin-inline: auto !important;
  padding: clamp(14px, 1.6vw, 24px) !important;
}

.hero-original-theme-box .hero-image-panel__viewport,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box .hero-image-panel__viewport {
  height: var(--utap-v23-original-height) !important;
  min-height: var(--utap-v23-original-height) !important;
  max-height: var(--utap-v23-original-height) !important;
  width: 100% !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
}

.hero-original-theme-box .hero-image-panel__zoom {
  width: 100% !important;
  height: 100% !important;
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.hero-original-theme-box .hero-image-panel__zoom > img,
.hero-original-theme-box .hero-image-panel__media,
.hero-original-theme-box .hero-image-panel__viewport .hero-image-panel__media {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: 0 auto !important;
}

/* Keep the title/caption close to the original theme card, not floating far away. */
.hero-original-theme-box .hero-image-panel__caption {
  width: min(100%, 980px) !important;
  margin: clamp(12px, 1vw, 16px) auto 0 !important;
  text-align: left !important;
}

/* Template wording: move it nearer to the carousel images below it.
   The phrase itself is emphasized through JS-added span markup. */
.hero-template-carousel-box .hero-gallery__caption {
  width: min(1180px, calc(100% - clamp(28px, 5vw, 96px))) !important;
  max-width: min(1180px, calc(100% - clamp(28px, 5vw, 96px))) !important;
  margin: clamp(52px, 5.6vw, 96px) auto clamp(8px, .8vw, 14px) !important;
  padding: 0 !important;
  text-align: center !important;
  line-height: 1.45 !important;
}

.hero-template-carousel-box .hero-gallery__copy {
  display: inline !important;
}

.hero-template-carousel-box .hero-gallery__caption,
.hero-template-carousel-box .hero-gallery__caption p,
.hero-template-carousel-box .hero-gallery__caption span,
.hero-template-carousel-box .hero-gallery__caption strong,
.hero-template-carousel-box .hero-gallery__caption b,
.hero-template-carousel-box .hero-gallery__caption .section-lead,
.hero-template-carousel-box .hero-gallery__caption .hero-gallery__caption-text {
  font-weight: 400 !important;
  letter-spacing: normal !important;
  color: rgba(33, 36, 68, .76) !important;
}

.hero-template-carousel-box .hero-gallery-caption-emphasis {
  display: inline !important;
  font-size: clamp(1.15rem, 1.65vw, 1.75rem) !important;
  font-weight: 820 !important;
  line-height: 1.08 !important;
  letter-spacing: -.025em !important;
  color: rgba(33, 32, 72, .96) !important;
}

.hero-template-carousel-box .hero-gallery-caption-rest {
  display: inline !important;
  font-size: clamp(.95rem, 1.02vw, 1.12rem) !important;
  font-weight: 400 !important;
  color: rgba(66, 72, 102, .78) !important;
}

/* Reduce the whitespace between the caption and the actual template cards. */
.hero-template-carousel-box #hero-gallery-viewport,
.hero-template-carousel-box .hero-gallery__viewport {
  margin-top: 0 !important;
}

.hero-template-carousel-box .hero-carousel {
  padding-top: clamp(0px, .4vw, 8px) !important;
}

/* Responsive tuning keeps the same intent on tablets and phones. */
@media (max-width: 980px) {
  :root {
    --utap-v23-logo-duration: 118s;
    --utap-v23-original-height: clamp(440px, 68vw, 640px);
  }

  .hero-template-carousel-box .hero-gallery__caption {
    margin-top: clamp(38px, 7vw, 70px) !important;
    margin-bottom: 10px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v23-logo-duration: 108s;
    --utap-v23-original-height: clamp(380px, 112vw, 560px);
  }

  .hero-original-theme-box,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box {
    padding: 10px !important;
  }

  .hero-original-theme-box .hero-image-panel__caption {
    text-align: center !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    width: calc(100% - 22px) !important;
    max-width: calc(100% - 22px) !important;
    margin-top: 34px !important;
    margin-bottom: 8px !important;
  }

  .hero-template-carousel-box .hero-gallery-caption-emphasis {
    font-size: clamp(1.05rem, 5.4vw, 1.35rem) !important;
  }

  .hero-template-carousel-box .hero-gallery-caption-rest {
    font-size: clamp(.86rem, 3.7vw, .98rem) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}





/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v24
   Scope: final visual correction only.
   - Keep brand chips moving slowly to the right instead of stopping on hover.
   - Make Original Theme and uTap Applications boxes much softer/faded.
   - Make the customized-branded-themes caption use the same typography as
     the Trusted by heading, with no emphasis split.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v24-brand-duration: 188s;
  --utap-v24-soft-border: rgba(207, 214, 241, .26);
  --utap-v24-soft-bg: rgba(255, 255, 255, .34);
  --utap-v24-soft-bg-inner: rgba(255, 255, 255, .24);
  --utap-v24-soft-shadow: 0 18px 56px rgba(47, 43, 96, .035);
  --utap-v24-soft-shadow-inner: 0 10px 28px rgba(47, 43, 96, .025);
}

@keyframes utapTrustedLogoTrackLoopRightV24 {
  0% { transform: translate3d(-50%, 0, 0); }
  100% { transform: translate3d(0, 0, 0); }
}

/* Brand chips: restore motion by making the track the only animated element.
   The previous pause-on-hover made the row appear frozen while the cursor was
   over the logo area, so this keeps it running unless reduced-motion is active. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  overflow: hidden !important;
  isolation: isolate !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: translate3d(-50%, 0, 0);
  animation: utapTrustedLogoTrackLoopRightV24 var(--utap-v24-brand-duration) linear infinite !important;
  animation-play-state: running !important;
  will-change: transform !important;
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set,
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: var(--trusted-logo-gap, clamp(28px, 4vw, 72px)) !important;
  min-width: max-content !important;
  animation: none !important;
  transform: none !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: running !important;
}

/* Soften uTap Applications: keep it editable as a box, but make the big card
   and the small app cards fade into the page like the Original Theme treatment. */
.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box,
.hero-side-box.hero-apps-box,
#hero-side-box.hero-apps-box,
.hero-apps-section .hero-side-box {
  background: var(--utap-v24-soft-bg) !important;
  border-color: var(--utap-v24-soft-border) !important;
  box-shadow: var(--utap-v24-soft-shadow) !important;
  backdrop-filter: blur(14px) saturate(1.05) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.05) !important;
}

.hero-apps-section.hero-apps-box .hero-side-card,
.hero-apps-section.hero-apps-box .hero-app-card,
.hero-apps-section.hero-apps-box .hero-side-box__card,
.hero-apps-section .hero-side-card,
.hero-apps-section .hero-app-card,
.hero-apps-section .hero-side-box__card {
  background: var(--utap-v24-soft-bg-inner) !important;
  border-color: rgba(207, 214, 241, .24) !important;
  box-shadow: var(--utap-v24-soft-shadow-inner) !important;
}

/* Soften Original Theme card and its internal viewport without changing the image. */
.hero-original-theme-box,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box {
  background: var(--utap-v24-soft-bg) !important;
  border-color: var(--utap-v24-soft-border) !important;
  box-shadow: var(--utap-v24-soft-shadow) !important;
  backdrop-filter: blur(14px) saturate(1.05) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.05) !important;
}

.hero-original-theme-box .hero-image-panel__viewport,
.hero-original-theme-box .hero-image-panel__zoom,
.hero-original-theme-box .hero-image-panel__stage,
.hero-original-theme-box .hero-image-panel__frame {
  background: rgba(255, 255, 255, .20) !important;
  border-color: rgba(207, 214, 241, .20) !important;
  box-shadow: none !important;
}

/* Caption: same typography as the Trusted by heading. No big emphasis, no bold split. */
.hero-template-carousel-box .hero-gallery__caption,
.hero-template-carousel-box .hero-gallery__caption p,
.hero-template-carousel-box .hero-gallery__caption span,
.hero-template-carousel-box .hero-gallery__caption strong,
.hero-template-carousel-box .hero-gallery__caption b,
.hero-template-carousel-box .hero-gallery__caption .section-lead,
.hero-template-carousel-box .hero-gallery__caption .hero-gallery__caption-text,
.hero-template-carousel-box .hero-gallery-caption-emphasis,
.hero-template-carousel-box .hero-gallery-caption-rest {
  font-family: inherit !important;
  font-size: clamp(.92rem, .92vw, 1.02rem) !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
  letter-spacing: .01em !important;
  color: rgba(82, 91, 113, .82) !important;
}

.hero-template-carousel-box .hero-gallery__caption {
  width: min(1180px, calc(100% - clamp(28px, 5vw, 96px))) !important;
  max-width: min(1180px, calc(100% - clamp(28px, 5vw, 96px))) !important;
  margin: clamp(30px, 3.8vw, 62px) auto clamp(14px, 1.1vw, 22px) !important;
  padding: 0 !important;
  text-align: left !important;
}

.hero-template-carousel-box .hero-gallery-caption-emphasis,
.hero-template-carousel-box .hero-gallery-caption-rest {
  display: inline !important;
}

@media (max-width: 980px) {
  :root {
    --utap-v24-brand-duration: 168s;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    margin-top: clamp(24px, 4.8vw, 48px) !important;
    margin-bottom: 14px !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v24-brand-duration: 148s;
  }

  .hero-template-carousel-box .hero-gallery__caption,
  .hero-template-carousel-box .hero-gallery__caption p,
  .hero-template-carousel-box .hero-gallery__caption span,
  .hero-template-carousel-box .hero-gallery-caption-emphasis,
  .hero-template-carousel-box .hero-gallery-caption-rest {
    font-size: clamp(.86rem, 3.7vw, .98rem) !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    width: calc(100% - 22px) !important;
    max-width: calc(100% - 22px) !important;
    margin-top: 24px !important;
    margin-bottom: 12px !important;
    text-align: left !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}




/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v25
   Scope: requested visual/UX corrections only.
   - Brand chips keep moving to the right at a visible, smooth, calm speed.
   - Original Theme and uTap Applications boxes are much softer and smaller.
   - Template hover tells visitors to double-click to see the enlarged viewer.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v25-brand-duration: 96s;
  --utap-v25-original-height: clamp(390px, 34vw, 560px);
  --utap-v25-soft-border: rgba(207, 214, 241, .12);
  --utap-v25-soft-bg: rgba(255, 255, 255, .18);
  --utap-v25-soft-bg-inner: rgba(255, 255, 255, .16);
  --utap-v25-soft-shadow: 0 10px 30px rgba(47, 43, 96, .012);
}

@keyframes utapTrustedLogoTrackRightV25 {
  from { transform: translate3d(-50%, 0, 0); }
  to { transform: translate3d(0, 0, 0); }
}

/* Brand chips: v24 was too slow to read as movement on a live screen.
   This keeps the requested right direction, but uses a visible calm speed. */
#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  overflow: hidden !important;
  isolation: isolate !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: translate3d(-50%, 0, 0) !important;
  animation-name: utapTrustedLogoTrackRightV25 !important;
  animation-duration: var(--utap-v25-brand-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-direction: normal !important;
  animation-fill-mode: both !important;
  animation-play-state: running !important;
  will-change: transform !important;
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set,
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  animation: none !important;
  transform: none !important;
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: var(--trusted-logo-gap, clamp(28px, 4vw, 72px)) !important;
  min-width: max-content !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: running !important;
}

/* uTap Applications: keep the separate editable box, but make it fade into the page. */
.hero-apps-section.hero-apps-box {
  margin-top: clamp(16px, 1.8vw, 28px) !important;
}

.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box,
.hero-side-box.hero-apps-box,
#hero-side-box.hero-apps-box,
.hero-apps-section .hero-side-box {
  background: var(--utap-v25-soft-bg) !important;
  border-color: var(--utap-v25-soft-border) !important;
  box-shadow: var(--utap-v25-soft-shadow) !important;
  backdrop-filter: blur(10px) saturate(1.02) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.02) !important;
}

.hero-apps-section.hero-apps-box .hero-side-card,
.hero-apps-section.hero-apps-box .hero-app-card,
.hero-apps-section.hero-apps-box .hero-side-box__card,
.hero-apps-section .hero-side-card,
.hero-apps-section .hero-app-card,
.hero-apps-section .hero-side-box__card {
  background: var(--utap-v25-soft-bg-inner) !important;
  border-color: rgba(207, 214, 241, .12) !important;
  box-shadow: none !important;
}

/* Original Theme: smaller vertical footprint and softer boxes, without changing behavior. */
.hero-original-theme-box,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box {
  width: min(100%, 980px) !important;
  max-width: min(100%, 980px) !important;
  padding: clamp(10px, 1.2vw, 18px) !important;
  background: var(--utap-v25-soft-bg) !important;
  border-color: var(--utap-v25-soft-border) !important;
  box-shadow: var(--utap-v25-soft-shadow) !important;
}

.hero-original-theme-box .hero-image-panel__viewport,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box .hero-image-panel__viewport {
  height: var(--utap-v25-original-height) !important;
  min-height: var(--utap-v25-original-height) !important;
  max-height: var(--utap-v25-original-height) !important;
  background: rgba(255, 255, 255, .10) !important;
  border-color: rgba(207, 214, 241, .11) !important;
  box-shadow: none !important;
}

.hero-original-theme-box .hero-image-panel__zoom,
.hero-original-theme-box .hero-image-panel__stage,
.hero-original-theme-box .hero-image-panel__frame {
  background: transparent !important;
  border-color: rgba(207, 214, 241, .10) !important;
  box-shadow: none !important;
}

.hero-original-theme-box .hero-image-panel__caption {
  margin-top: clamp(10px, .85vw, 14px) !important;
}

/* Customized themes caption: match the Trusted by heading font treatment. */
.hero-template-carousel-box .hero-gallery__caption,
.hero-template-carousel-box .hero-gallery__caption p,
.hero-template-carousel-box .hero-gallery__caption span,
.hero-template-carousel-box .hero-gallery__caption strong,
.hero-template-carousel-box .hero-gallery__caption b,
.hero-template-carousel-box .hero-gallery-caption-emphasis,
.hero-template-carousel-box .hero-gallery-caption-rest {
  font-family: inherit !important;
  font-size: clamp(.92rem, .92vw, 1.02rem) !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
  letter-spacing: .01em !important;
  color: rgba(82, 91, 113, .82) !important;
}

.hero-template-carousel-box .hero-gallery__caption {
  margin: clamp(24px, 3vw, 46px) auto clamp(12px, 1vw, 18px) !important;
  text-align: left !important;
}

/* Hover helper for the template carousel. Browser title text is also set in JS,
   while this visual pill confirms the double-click behavior. */
#hero-gallery-viewport .hero-carousel__slide {
  cursor: zoom-in !important;
}

#hero-gallery-viewport .hero-carousel__slide::after {
  content: "Double-click to see" !important;
  bottom: 14px !important;
  background: rgba(37, 35, 79, .78) !important;
  box-shadow: 0 12px 26px rgba(37, 35, 79, .14) !important;
}

@media (max-width: 980px) {
  :root {
    --utap-v25-brand-duration: 86s;
    --utap-v25-original-height: clamp(350px, 58vw, 500px);
  }

  .hero-original-theme-box,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box {
    width: min(100%, 900px) !important;
  }
}

@media (max-width: 560px) {
  :root {
    --utap-v25-brand-duration: 76s;
    --utap-v25-original-height: clamp(300px, 92vw, 430px);
  }

  .hero-original-theme-box,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box {
    padding: 8px !important;
  }

  .hero-template-carousel-box .hero-gallery__caption {
    margin-top: 18px !important;
    margin-bottom: 10px !important;
    text-align: left !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #hero-brand-band .logo-band__track,
  #hero-proof-row .logo-band__track,
  #hero-proof-row .trusted-logo-marquee__track {
    animation: none !important;
    transform: none !important;
  }
}






/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v26
   Scope: original theme layout + balanced section visibility only.
   - Keep Original Theme image size, but use the empty space by placing copy
     beside the image on desktop/laptop.
   - Restore a visible premium card treatment for Original Theme and uTap Apps
     so the sections no longer feel invisible or empty.
   - Stack cleanly on tablet/mobile.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v26-panel-bg: rgba(255, 255, 255, .70);
  --utap-v26-panel-border: rgba(199, 205, 236, .42);
  --utap-v26-panel-shadow: 0 22px 68px rgba(48, 43, 96, .065);
  --utap-v26-inner-bg: rgba(255, 255, 255, .58);
  --utap-v26-inner-border: rgba(199, 205, 236, .34);
  --utap-v26-inner-shadow: 0 12px 34px rgba(48, 43, 96, .045);
}

/* uTap Applications: bring back enough visible structure without making the
   box heavy. This stays separate from the CTA and remains easy to edit. */
.hero-apps-section.hero-apps-box > .hero-side-box,
.hero-apps-section.hero-apps-box > #hero-side-box,
.hero-side-box.hero-apps-box,
#hero-side-box.hero-apps-box,
.hero-apps-section .hero-side-box {
  background: var(--utap-v26-panel-bg) !important;
  border: 1px solid var(--utap-v26-panel-border) !important;
  box-shadow: var(--utap-v26-panel-shadow) !important;
  backdrop-filter: blur(18px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
}

.hero-apps-section.hero-apps-box .hero-side-card,
.hero-apps-section.hero-apps-box .hero-app-card,
.hero-apps-section.hero-apps-box .hero-side-box__card,
.hero-apps-section .hero-side-card,
.hero-apps-section .hero-app-card,
.hero-apps-section .hero-side-box__card {
  background: var(--utap-v26-inner-bg) !important;
  border: 1px solid var(--utap-v26-inner-border) !important;
  box-shadow: var(--utap-v26-inner-shadow) !important;
}

/* Original Theme: use a two-column desktop layout so the text sits on the
   right side of the preview instead of floating underneath a large empty box. */
.hero-original-theme-box,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box {
  width: min(100%, 1180px) !important;
  max-width: min(100%, 1180px) !important;
  margin-inline: auto !important;
  display: grid !important;
  grid-template-columns: minmax(420px, 1fr) minmax(260px, 360px) !important;
  align-items: center !important;
  gap: clamp(22px, 3vw, 52px) !important;
  padding: clamp(18px, 2.2vw, 34px) !important;
  background: var(--utap-v26-panel-bg) !important;
  border: 1px solid var(--utap-v26-panel-border) !important;
  box-shadow: var(--utap-v26-panel-shadow) !important;
  backdrop-filter: blur(18px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
}

.hero-original-theme-box .hero-image-panel__viewport,
.hero-media-row.hero-media-row--original-first .hero-original-theme-box .hero-image-panel__viewport {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 100% !important;
  height: clamp(430px, 38vw, 620px) !important;
  min-height: clamp(430px, 38vw, 620px) !important;
  max-height: clamp(430px, 38vw, 620px) !important;
  background: var(--utap-v26-inner-bg) !important;
  border: 1px solid var(--utap-v26-inner-border) !important;
  box-shadow: var(--utap-v26-inner-shadow) !important;
}

.hero-original-theme-box .hero-image-panel__zoom,
.hero-original-theme-box .hero-image-panel__stage,
.hero-original-theme-box .hero-image-panel__frame {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.hero-original-theme-box .hero-image-panel__zoom > img,
.hero-original-theme-box .hero-image-panel__media,
.hero-original-theme-box .hero-image-panel__viewport .hero-image-panel__media {
  object-fit: contain !important;
  object-position: center center !important;
}

.hero-original-theme-box .hero-image-panel__caption {
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: clamp(18px, 2vw, 30px) !important;
  text-align: left !important;
  align-self: center !important;
  justify-self: stretch !important;
  border-radius: clamp(20px, 2vw, 30px) !important;
  background: rgba(255, 255, 255, .46) !important;
  border: 1px solid rgba(199, 205, 236, .26) !important;
  box-shadow: 0 12px 32px rgba(48, 43, 96, .035) !important;
}

.hero-original-theme-box .hero-image-panel__caption strong {
  display: block !important;
  margin: 0 0 .55rem !important;
  color: rgba(31, 29, 72, .94) !important;
  font-size: clamp(1.05rem, 1.15vw, 1.34rem) !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
  letter-spacing: -.015em !important;
}

.hero-original-theme-box .hero-image-panel__caption span {
  display: block !important;
  color: rgba(73, 84, 116, .86) !important;
  font-size: clamp(.92rem, .96vw, 1.02rem) !important;
  font-weight: 500 !important;
  line-height: 1.62 !important;
}

@media (max-width: 980px) {
  .hero-original-theme-box,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box {
    grid-template-columns: minmax(0, 1fr) !important;
    width: min(100%, 900px) !important;
    gap: clamp(14px, 3vw, 24px) !important;
    padding: clamp(14px, 2.4vw, 24px) !important;
  }

  .hero-original-theme-box .hero-image-panel__viewport,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box .hero-image-panel__viewport {
    grid-column: 1 !important;
    grid-row: 1 !important;
    height: clamp(360px, 62vw, 540px) !important;
    min-height: clamp(360px, 62vw, 540px) !important;
    max-height: clamp(360px, 62vw, 540px) !important;
  }

  .hero-original-theme-box .hero-image-panel__caption {
    grid-column: 1 !important;
    grid-row: 2 !important;
    text-align: center !important;
    margin: 0 auto !important;
    width: min(100%, 720px) !important;
  }
}

@media (max-width: 560px) {
  .hero-original-theme-box,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box {
    width: calc(100% - 18px) !important;
    padding: 10px !important;
    border-radius: 26px !important;
  }

  .hero-original-theme-box .hero-image-panel__viewport,
  .hero-media-row.hero-media-row--original-first .hero-original-theme-box .hero-image-panel__viewport {
    height: clamp(300px, 95vw, 450px) !important;
    min-height: clamp(300px, 95vw, 450px) !important;
    max-height: clamp(300px, 95vw, 450px) !important;
  }

  .hero-original-theme-box .hero-image-panel__caption {
    padding: 16px !important;
    border-radius: 22px !important;
  }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v27
   Scope: revert Trusted brand chips motion back to the LEFT.
   Keep the same slow, smooth continuous marquee behavior.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v27-brand-duration: 188s;
}

@keyframes utapTrustedLogoTrackLoopLeftV27 {
  0% { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  transform: translate3d(0, 0, 0) !important;
  animation: utapTrustedLogoTrackLoopLeftV27 var(--utap-v27-brand-duration) linear infinite !important;
  animation-play-state: running !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: running !important;
}



/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v28
   Scope: unlock Trusted brand chips movement.
   Root cause: older final overrides locked transform with !important, which
   prevents transform keyframes from visibly moving the row. This animation uses
   the individual translate property instead, so the chips move left smoothly
   without touching any carousel/viewer behavior.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v28-brand-duration: 84s;
}

@keyframes utapTrustedLogoTranslateLeftV28 {
  from { translate: 0 0; }
  to { translate: -50% 0; }
}

#hero-brand-band.logo-band,
#hero-proof-row .logo-band,
#hero-proof-row .trusted-logo-marquee {
  overflow: hidden !important;
  isolation: isolate !important;
}

#hero-brand-band .logo-band__track,
#hero-proof-row .logo-band__track,
#hero-proof-row .trusted-logo-marquee__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: max-content !important;
  min-width: max-content !important;
  transform: translate3d(0, 0, 0) !important;
  translate: 0 0;
  animation-name: utapTrustedLogoTranslateLeftV28 !important;
  animation-duration: var(--utap-v28-brand-duration) !important;
  animation-timing-function: linear !important;
  animation-iteration-count: infinite !important;
  animation-direction: normal !important;
  animation-fill-mode: none !important;
  animation-play-state: running !important;
  will-change: translate !important;
}

#hero-brand-band .logo-band__set,
#hero-brand-band .logo-band__set[aria-hidden="true"],
#hero-proof-row .logo-band__set,
#hero-proof-row .logo-band__set[aria-hidden="true"],
#hero-proof-row .trusted-logo-marquee__set,
#hero-proof-row .trusted-logo-marquee__set[aria-hidden="true"] {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-width: max-content !important;
  animation: none !important;
  transform: none !important;
  translate: 0 0 !important;
}

#hero-brand-band.logo-band:hover .logo-band__track,
#hero-brand-band.logo-band:focus-within .logo-band__track,
#hero-proof-row .logo-band:hover .logo-band__track,
#hero-proof-row .logo-band:focus-within .logo-band__track,
#hero-proof-row .trusted-logo-marquee:hover .trusted-logo-marquee__track,
#hero-proof-row .trusted-logo-marquee:focus-within .trusted-logo-marquee__track {
  animation-play-state: running !important;
}

@media (max-width: 720px) {
  :root { --utap-v28-brand-duration: 76s; }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v29
   Scope: move only the main hero Create Profile CTA lower.
   Does not affect the header CTA or any other hero/section layout.
   ────────────────────────────────────────────────────────────── */

.hero-copy > .hero-actions {
  position: relative !important;
  top: clamp(70px, 8vh, 130px) !important;
}

@media (max-width: 720px) {
  .hero-copy > .hero-actions {
    top: clamp(42px, 7vh, 76px) !important;
  }
}

/* ──────────────────────────────────────────────────────────────
   uTap landing hotfix v30
   Scope: move the main hero CTA lower in normal document flow.
   Root cause: v29 used relative top, which visually moved the CTA but did not
   reserve space, so the Applications card stayed in its old position and could
   collide with the button. This keeps the same visual drop, but uses margin so
   the Applications section and all lower sections flow down together.
   ────────────────────────────────────────────────────────────── */

:root {
  --utap-v30-hero-cta-flow-drop: clamp(70px, 8vh, 130px);
}

.hero-copy > .hero-actions {
  top: 0 !important;
  margin: calc(var(--landing-hero-cta-gap, clamp(28px, 2.55vw, 44px)) + var(--utap-v30-hero-cta-flow-drop)) auto 0 !important;
}

@media (max-width: 720px) {
  :root {
    --utap-v30-hero-cta-flow-drop: clamp(42px, 7vh, 76px);
  }
}
