/** Shopify CDN: Minification failed

Line 60:10 Unexpected "{"
Line 60:19 Expected ":"
Line 64:10 Unexpected "{"
Line 64:19 Expected ":"
Line 74:10 Unexpected "{"
Line 74:19 Expected ":"
Line 80:10 Unexpected "{"
Line 80:19 Expected ":"
Line 80:32 Unexpected "{"
Line 80:41 Expected ":"
... and 17 more hidden warnings

**/
/* Timeline Video Accordion (TVA) */

.tva {
  /* Colors driven by Shopify scheme */
  --tva-bg: transparent;

  /* Sizing (can stay local unless you want theme-driven sizes) */
  --tva-gap: 28px;
  --tva-radius: var(--evr-radius-media-asym);

  --tva-progress-w: 5px;

  --tva-ease: cubic-bezier(.2,.8,.2,1);
  --tva-panel-ms: 360ms;
  --tva-media-ms: 450ms;

  color: var(--color-foreground);

  /* Let the theme handle background via "gradient" / section background.
     If you still need your stripe background, define it in a class that can be toggled. */
  background: transparent;
}

.evr-tva-section .custom-section-content {
  grid-column: 2 / span 2;
}

.tva .tva__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--tva-gap);
  align-items: center;
  grid-column: 2 / span 2;
}

.tva-pin {
  --tva-sticky-scroll: 115svh;
  background: transparent;
  position: relative;
  height: var(--tva-sticky-scroll, 115svh);
  overflow: clip; /* keeps pinned visuals clean */
  background: transparent;
}

#tva-pin-{{ section.id }} .tva-pin__bleed{
  height: 100%;
}

#tva-pin-{{ section.id }} .tva-pin__sticky{
  position: sticky;
  top: var(--tva-sticky-top, 0px);
  height: calc(100svh - var(--tva-sticky-top, 0px));
  min-height: calc(100svh - var(--tva-sticky-top, 0px));
  display: grid;
  align-items: center; /* optional: keep TVA vertically centered */
}

/* optional full-bleed breakout (safe even if you don’t need it) */
#tva-pin-{{ section.id }} .tva-pin__bleed{
  position: relative;
  height: 100%;
  background: transparent;
}

#tva-pin-{{ section.id }} #tva-{{ section.id }}{
  width: 100%;
}

/* The pinned viewport */
#tva-pin-{{ section.id }} .tva-pin__sticky{
  position: sticky;
  top: var(--tva-sticky-top, 0px);
  height: calc(100svh - var(--tva-sticky-top, 0px));
  min-height: calc(100svh - var(--tva-sticky-top, 0px));
  display: grid;
  align-items: center; /* optional: keep TVA vertically centered */
}

/* Ensure TVA itself can fill/behave predictably while pinned */
#tva-pin-{{ section.id }} #tva-{{ section.id }}{
  width: 100%;
}

/* On small screens, you often want less pin duration */
@media screen and (max-width: 749px){
  #tva-pin-{{ section.id }}{
    height: 115svh;
  }
  #tva-pin-{{ section.id }} .tva-pin__sticky{
    align-items: end; /* feels nicer on mobile */
  }
}

@media screen and (max-width: 749px) {
  .tva .tva__inner { grid-template-columns: 1fr; }
}

.tva__tagline { margin-bottom: 16px; }
.tva__tagline b, .tva__tagline strong { color: var(--color-primary); }

.tva__item { padding: 12px 0; }
.tva__item-row {
  display: grid;
  grid-template-columns: 14px 1fr;
  column-gap: 16px;
  align-items: start;
}

.tva__progress {
  width: 14px;
  display: flex;
  justify-content: center;
  position: relative;
}

/* Track height is set via JS per item: --tva-track-h */
.tva__progress::before {
  content: "";
  display: block;
  width: var(--tva-progress-w);
  height: var(--tva-track-h, 24px);
  border-radius: 999px;
  background: var(--color-foreground);
  transition: height var(--tva-panel-ms) var(--tva-ease), background 200ms ease;
}

/* FIX: center the fill exactly like the track */
.tva__progress-fill{
  position: absolute;
  top: 0;
  left: 50%;
  width: var(--tva-progress-w);
  height: var(--tva-track-h, 24px);

  transform: translateX(-50%);

  border-radius: 999px;
  overflow: hidden;

  opacity: 0;
  transition: opacity .15s ease, height var(--tva-panel-ms) var(--tva-ease);

  /* default progress */
  --tva-progress: 0;
}

.tva__progress-fill::before{
  content: "";
  position: absolute;
  inset: 0;
  background: var(--color-foreground-heading);

  transform: scaleY(var(--tva-progress));
  transform-origin: top;

  transition: transform 0s linear;
}

.tva__item.is-active .tva__progress-fill { opacity: 1; }
.tva__item.is-active .tva__progress::before { background: var(--color-border); }

.tva__title {
  margin: 0;
  transition: font-size var(--tva-panel-ms) var(--tva-ease);
}

.tva__btn {
  all: unset;
  cursor: pointer;
  display: inline-block;
  color: var(--color-foreground);
}
.tva__item.is-active .tva__btn { color: var(--color-foreground-heading); }

/* ---------
   Panel smooth open/close (NO hidden/display:none)
--------- */
.tva__panel {
  margin-top: 10px;

  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--tva-panel-ms) var(--tva-ease), opacity var(--tva-panel-ms) var(--tva-ease);
  opacity: 0;
}
.tva__item.is-active .tva__panel {
  grid-template-rows: 1fr;
  opacity: 1;
}

.tva__panel-inner {
  overflow: hidden;
}

.tva__text {
  color: var(--color-foreground);
  opacity: 0.92;
  line-height: 1.55;
  max-width: 52ch;
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  letter-spacing: var(--font-paragraph--letter-spacing);
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
}

/* CTA */
.tva__cta { margin-top: 18px; }
.tva__cta-btn {
}

/* Right / media */
.tva__media {
  width: 100%;
  border-radius: var(--tva-radius);
  overflow: hidden;
  position: relative;
  min-height: 280px;
}

/* NEW: media items are stacked and fade only */
.tva__media-item {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;

  opacity: 0;
  pointer-events: none;

  /* pure fade */
  transition: opacity 450ms var(--tva-ease);
  will-change: opacity;

  z-index: 1;
}

.tva__media-item.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}

/* previous item fading out (keeps it rendered during crossfade) */
.tva__media-item.is-fade-out {
  opacity: 0;
  pointer-events: none;
  z-index: 1;
}

.tva__stage {
  position: relative;
  width: 100%;
  height: 100%;
}

/* Base media */
.tva__video,
.tva__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: left;
}

.tva__apng { 
  image-rendering: auto;
  object-fit: contain;
}

/* Left framing only for normal video slides */
.tva__media-item[data-slide-type="video"] .tva__video,
.tva__media-item[data-slide-type="video"] .tva__img {
  object-position: left;
}

/* If aspect ratio is enforced */
.tva[data-aspect="true"] .tva__media { aspect-ratio: var(--tva-aspect, 1 / 1); }

/* ---------------------------
   Phone frame slide (your fix kept)
---------------------------- */
.tva__phone {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.tva__phone-canvas {
  position: relative;
  aspect-ratio: var(--phone-ar, 2048 / 1813);
  width: auto;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
}

.tva__media-item[data-slide-type="phone_frame"] .tva__phone-canvas {
  width: auto;
  height: 100%;
  max-width: 100%;
}

.tva__frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 2;
  pointer-events: none;
}

/* -------------------------------------------------------
   Fade ONLY the phone frame image (bottommost 5%)
   ------------------------------------------------------- */
.tva__frame{
  --tva-frame-fade: 5%;

  -webkit-mask-image: linear-gradient(
    to top,
    transparent 0%,
    rgba(0,0,0,1) var(--tva-frame-fade),
    rgba(0,0,0,1) 100%
  );
  mask-image: linear-gradient(
    to top,
    transparent 0%,
    rgba(0,0,0,1) var(--tva-frame-fade),
    rgba(0,0,0,1) 100%
  );

  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 2;
  pointer-events: none;
}


.tva__screen-wrap {
  position: absolute;
  top: var(--screen-top, 10%);
  right: var(--screen-right, 10%);
  bottom: var(--screen-bottom, 10%);
  left: var(--screen-left, 10%);
  border-radius: var(--screen-radius, 14px);
  overflow: hidden;
  z-index: 1;
}

.tva__screen {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: top;
  border: 5px solid transparent;
}

/* Placeholder */
.tva__placeholder {
  padding: 40px;
  color: var(--color-foreground);
}

/* Animation presets (kept; still usable on inner elements) */
.tva [data-anim="none"] { opacity: 1; transform: none; }
.tva [data-anim]:not([data-anim="none"]) {
  will-change: transform, opacity;
  opacity: 0;
  transform: translateY(8px);
}
.tva [data-anim="fade"] { transform: none; }
.tva [data-anim="fade_up"] { transform: translateY(10px); }
.tva [data-anim="fade_left"] { transform: translateX(10px); }
.tva [data-anim="scale"] { transform: scale(0.98); }

.tva .is-active [data-anim]:not([data-anim="none"]),
.tva [data-anim].is-active {
  opacity: 1;
  transform: none;
  transition-property: opacity, transform;
  transition-timing-function: var(--tva-ease);
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  .tva__media-item { transition: none !important; opacity: 1 !important; transform: none !important; position: static !important; }
  .tva__panel { transition: none !important; opacity: 1 !important; }
  .tva [data-anim]:not([data-anim="none"]) { transition: none !important; opacity: 1 !important; transform: none !important; }
}

/* =========================
   TVA — Mobile layout (<=989px)
   Keeps desktop untouched
========================= */
.tva__mobile-top,
.tva__mobile-bottom {
  display: none;
}

@media screen and (max-width: 749px) {
  /* Hide desktop accordion column entirely on mobile */
  .tva__left {
    display: none !important;
  }

  /* Show mobile blocks */
  .tva__mobile-top,
  .tva__mobile-bottom {
    display: block;
  }

  .tva-pin {
    --tva-sticky-scroll: auto;
  }

  .tva__video,
  .tva__img {
    object-position: center;
  }

  .tva__video:first-of-type {
    object-position: left;
  }

  .evr-tva-section .custom-section-content {
    grid-column: 2 / span 1;
  }

  /* Make pinned section feel like screenshot: heading top, CTA bottom */
  #tva-pin-{{ section.id }} .tva-pin__sticky {
    align-items: stretch !important;
    height: unset !important;
  }

  /* Turn inner into 3-row layout:
     1) heading
     2) media
     3) content + controls + CTA (bottom) */
  .tva .tva__inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto 1fr auto;
    gap: 16px;
    align-items: stretch;
    min-height: 100%;
  }

  .tva__mobile-top {
    grid-row: 1;
  }

  .tva__right {
    grid-row: 2;
    display: grid;
    align-items: center;
  }

  /* Control media size on mobile (so text fits below like screenshot) */
  .tva__media {
    min-height: 0;
    height: clamp(260px, 46svh, 440px);
    border-radius: var(--evr-glass-radius);
  }

  /* If aspect ratio is forced, let height win on mobile */
  .tva[data-aspect="true"] .tva__media {
    aspect-ratio: auto !important;
  }

  .tva__mobile-bottom {
    grid-row: 3;
    display: grid;
    gap: 12px;
    align-content: end; /* keeps CTA at bottom */
    padding-bottom: max(10px, env(safe-area-inset-bottom));
  }

  /* --- Mobile slide content (swipe track) --- */
  .tva__m-viewport {
    overflow: hidden;
    touch-action: pan-y; /* allow vertical scroll, we handle horizontal swipe */
  }

  .tva__m-track {
    display: flex;
    width: 100%;
    will-change: transform;
    transition: transform 420ms var(--tva-ease);
  }

  .tva__m-slide {
    flex: 0 0 100%;
    width: 100%;
  }

  .tva__m-title {
    margin: 0 0 6px 0;
    color: var(--color-foreground-heading);
  }

  .tva__m-text {
    color: var(--color-foreground);
    opacity: 0.92;
    max-width: 60ch;
    font-size: var(--font-paragraph--size);
    line-height: var(--font-paragraph--line-height);
    letter-spacing: var(--font-paragraph--letter-spacing);
    font-family: var(--font-paragraph--family);
    font-style: var(--font-paragraph--style);
    font-weight: var(--font-paragraph--weight);
  }

  /* --- Horizontal controls (bars/dots like screenshot) --- */
  .tva__m-controls {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 6px;
  }

  .tva__m-dot {
    appearance: none;
    border: 0;
    padding: 0;
    width: 26px;
    height: 4px;
    border-radius: 999px;
    background: var(--color-foreground);
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }

  /* progress fill for active dot (optional but nice) */
  .tva__m-dot::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--color-foreground-heading);
    transform: scaleX(var(--tva-progress, 0));
    transform-origin: left;
    transition: transform 0s linear;
  }

  .tva__m-dot.is-active {
    background: var(--color-border);
    width: 90%;
  }

  .tva__m-cta {
    display: flex;
    justify-content: center;
    margin-top: 32px;
  }

  .tva__m-cta .tva__cta-btn {
    width: min(420px, 100%);
  }
}

@media screen and (max-width: 990px) and (orientation: landscape) {
  .tva-pin {
    --tva-sticky-scroll: auto;
  }

  #tva-pin-{{ section.id }} .tva-pin__sticky {
    height: unset !important;
  }
}
