/** Shopify CDN: Minification failed

Line 434:0 Unexpected "<"

**/
/* ============== Mobile overflow safety net ============== */
html, body { overflow-x: clip; }
@supports not (overflow-x: clip) { html, body { overflow-x: hidden; } }
img, video, iframe { max-width: 100%; height: auto; }

/* Header — let icons shrink on small mobile so they don't push body wider than vw */
@media (max-width: 640px) {
  .vu-header__line { padding-inline: 12px !important; gap: 8px !important; }
  .vu-header__icons { flex-shrink: 1 !important; min-width: 0 !important; }
  .vu-header__icon-link { padding: 0 4px !important; }
  .vu-header__search { min-width: 0; }
}

/* alpha-clone-vu — shared homepage primitives (v2 2026-05-11)
   Loaded once per vu-home-* section. Single source of truth for:
   - Section shell (padding, surfaces)
   - Section head (eyebrow, title, sub, link)
   - Buttons (primary / dark / ghost / outline / link)
   - Image card primitive (hover scale, chip arrow)
   - Snap-row mobile pattern
   - Reveal-on-scroll animations
   - Decorative utilities (grain, accent dot, divider)
*/

/* ============== Section shell ============== */
.vu-home-section {
  padding-block: clamp(48px, 6vw, 88px);
  background: var(--vu-c-bg);
  position: relative;
}
.vu-home-section--muted   { background: var(--vu-c-surface-muted); }
.vu-home-section--tinted  { background: var(--vu-c-surface-tinted); }
.vu-home-section--warm    { background: var(--vu-c-surface-tinted-strong); }
.vu-home-section--dark    { background: var(--vu-c-surface-dark); color: var(--vu-c-text-on-dark); }
.vu-home-section--dark .vu-section-title,
.vu-home-section--dark .vu-section-sub { color: var(--vu-c-text-on-dark); }
.vu-home-section--dark .vu-section-sub { color: var(--vu-c-text-on-dark-muted); }

.vu-home-section--tight { padding-block: clamp(32px, 4vw, 56px); }
.vu-home-section--flush-top { padding-top: 0; }

.vu-home-container {
  width: min(var(--vu-container), calc(100vw - var(--vu-gutter)));
  margin-inline: auto;
  position: relative;
}
.vu-home-container--narrow {
  width: min(var(--vu-container-narrow), calc(100vw - var(--vu-gutter)));
}
@media (max-width: 1024px) {
  .vu-home-container,
  .vu-home-container--narrow { width: calc(100vw - var(--vu-gutter-sm) * 2); }
}
@media (max-width: 640px) {
  .vu-home-container,
  .vu-home-container--narrow { width: calc(100vw - var(--vu-gutter-xs) * 2); }
}

/* ============== Section heading row ============== */
.vu-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--vu-sp-6);
  margin-bottom: clamp(24px, 3.4vw, 40px);
}
.vu-section-head--centered { align-items: center; flex-direction: column; text-align: center; }
.vu-section-head--centered .vu-section-sub { margin-inline: auto; }

.vu-section-head__text { display: flex; flex-direction: column; gap: var(--vu-sp-2); min-width: 0; }

.vu-section-head__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  width: fit-content;
  font: var(--vu-fw-semibold) var(--vu-fs-sm)/1 var(--vu-font-primary);
  color: var(--vu-c-accent);
  text-transform: uppercase;
  letter-spacing: var(--vu-tracking-wide);
}
.vu-section-head__eyebrow::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
  transform: translateY(-1px);
}

.vu-section-title {
  margin: 0;
  font-family: var(--vu-font-heading);
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: var(--vu-fw-regular);
  line-height: var(--vu-lh-tight);
  letter-spacing: var(--vu-tracking-tight);
  color: var(--vu-c-text);
  text-wrap: balance;
}
.vu-section-title em {
  font-style: italic;
  color: var(--vu-c-accent);
  font-weight: var(--vu-fw-regular);
}

.vu-section-sub {
  margin: 0;
  font-size: var(--vu-fs-md);
  line-height: var(--vu-lh-base);
  color: var(--vu-c-text-muted);
  max-width: 60ch;
  text-wrap: pretty;
}

.vu-section-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  font-size: var(--vu-fs-md);
  font-weight: var(--vu-fw-semibold);
  color: var(--vu-c-text);
  text-decoration: none;
  border-bottom: 1.5px solid currentColor;
  padding-bottom: 4px;
  transition: color var(--vu-dur-base) var(--vu-ease),
              border-color var(--vu-dur-base) var(--vu-ease),
              gap var(--vu-dur-base) var(--vu-ease);
}
.vu-section-link:hover { color: var(--vu-c-accent); gap: 12px; }
.vu-section-link svg { transition: transform var(--vu-dur-base) var(--vu-ease); }
.vu-section-link:hover svg { transform: translateX(2px); }

@media (max-width: 640px) {
  .vu-section-head { flex-direction: column; align-items: flex-start; gap: var(--vu-sp-3); }
}

/* ============== Buttons ============== */
.vu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 13px 24px;
  border-radius: var(--vu-r-pill);
  font: var(--vu-fw-semibold) var(--vu-fs-md)/1 var(--vu-font-primary);
  text-decoration: none;
  cursor: pointer;
  border: 1.5px solid transparent;
  white-space: nowrap;
  transition: background var(--vu-dur-base) var(--vu-ease),
              color var(--vu-dur-base) var(--vu-ease),
              border-color var(--vu-dur-base) var(--vu-ease),
              box-shadow var(--vu-dur-base) var(--vu-ease),
              transform var(--vu-dur-fast) var(--vu-ease);
}
.vu-btn:active { transform: translateY(1px); }
.vu-btn:focus-visible { outline: none; box-shadow: var(--vu-focus-ring); }
.vu-btn svg { transition: transform var(--vu-dur-base) var(--vu-ease); }
.vu-btn:hover svg { transform: translateX(3px); }

.vu-btn--primary {
  background: var(--vu-c-accent);
  color: #fff;
  border-color: var(--vu-c-accent);
  box-shadow: 0 8px 24px rgba(236, 0, 46, 0.28);
}
.vu-btn--primary:hover {
  background: var(--vu-c-accent-hover);
  border-color: var(--vu-c-accent-hover);
  color: #fff;
  box-shadow: 0 12px 32px rgba(236, 0, 46, 0.35);
  transform: translateY(-1px);
}

.vu-btn--dark {
  background: var(--vu-c-text);
  color: #fff;
  border-color: var(--vu-c-text);
}
.vu-btn--dark:hover { background: #2a1a1a; color: #fff; transform: translateY(-1px); box-shadow: var(--vu-shadow-md); }

.vu-btn--ghost {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(10px);
}
.vu-btn--ghost:hover { background: rgba(255, 255, 255, 0.22); color: #fff; border-color: rgba(255, 255, 255, 0.85); }

.vu-btn--outline {
  background: transparent;
  color: var(--vu-c-text);
  border-color: var(--vu-c-text);
}
.vu-btn--outline:hover { background: var(--vu-c-text); color: #fff; }

.vu-btn--soft {
  background: var(--vu-c-accent-soft);
  color: var(--vu-c-accent);
  border-color: transparent;
}
.vu-btn--soft:hover { background: var(--vu-c-accent); color: #fff; }

.vu-btn--link {
  background: transparent; border-color: transparent;
  color: var(--vu-c-text); padding: 0 4px; min-height: 0;
  border-bottom: 1.5px solid currentColor; border-radius: 0;
}
.vu-btn--link:hover { color: var(--vu-c-accent); }

.vu-btn--sm { min-height: 38px; padding: 9px 18px; font-size: var(--vu-fs-sm); }
.vu-btn--lg { min-height: 54px; padding: 16px 30px; font-size: var(--vu-fs-lg); }
.vu-btn--full { width: 100%; }

/* ============== Card primitive (image hero card) ============== */
.vu-img-card {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--vu-r-lg);
  background: var(--vu-c-surface-muted);
  text-decoration: none;
  color: inherit;
  isolation: isolate;
  transition: box-shadow var(--vu-dur-base) var(--vu-ease),
              transform var(--vu-dur-base) var(--vu-ease);
}
.vu-img-card:hover { box-shadow: var(--vu-shadow-card-hover); transform: translateY(-3px); }
.vu-img-card:focus-visible { outline: none; box-shadow: var(--vu-focus-ring); }

.vu-img-card__media {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform var(--vu-dur-slower) var(--vu-ease);
}
.vu-img-card:hover .vu-img-card__media { transform: scale(1.06); }

.vu-img-card__overlay {
  position: absolute;
  inset: 0;
  background: var(--vu-c-overlay-gradient);
  pointer-events: none;
  transition: opacity var(--vu-dur-base) var(--vu-ease);
}

.vu-img-card__caption {
  position: absolute;
  inset: auto 0 0 0;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--vu-sp-3);
  padding: var(--vu-sp-5) var(--vu-sp-5) var(--vu-sp-4);
  color: #fff;
}
.vu-img-card__label {
  flex: 1;
  font-size: var(--vu-fs-md);
  font-weight: var(--vu-fw-semibold);
  line-height: 1.25;
  letter-spacing: 0.01em;
}
.vu-img-card__chip {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.42);
  backdrop-filter: blur(8px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  transition: background var(--vu-dur-base) var(--vu-ease),
              border-color var(--vu-dur-base) var(--vu-ease),
              transform var(--vu-dur-base) var(--vu-ease);
}
.vu-img-card:hover .vu-img-card__chip {
  background: var(--vu-c-accent);
  border-color: var(--vu-c-accent);
  transform: rotate(-45deg);
}
.vu-img-card:hover .vu-img-card__chip svg { transform: rotate(45deg); }

/* ============== Horizontal snap-scroll on mobile ============== */
.vu-snap-row {
  display: grid;
  gap: var(--vu-sp-4);
}
@media (max-width: 768px) {
  .vu-snap-row {
    grid-auto-flow: column;
    grid-auto-columns: minmax(72%, 1fr);
    grid-template-columns: none !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: var(--vu-gutter-xs);
    margin-inline: calc(var(--vu-gutter-xs) * -1);
    padding: 4px var(--vu-gutter-xs);
    scrollbar-width: none;
  }
  .vu-snap-row::-webkit-scrollbar { display: none; }
  .vu-snap-row > * { scroll-snap-align: start; }
}

/* ============== Reveal-on-scroll ============== */
.vu-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms var(--vu-ease-out), transform 700ms var(--vu-ease-out);
  will-change: opacity, transform;
}
.vu-reveal[data-visible="true"] { opacity: 1; transform: none; }
.vu-reveal--stagger > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 600ms var(--vu-ease-out), transform 600ms var(--vu-ease-out);
}
.vu-reveal--stagger[data-visible="true"] > *:nth-child(1)  { transition-delay:   0ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(2)  { transition-delay:  80ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(3)  { transition-delay: 160ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(4)  { transition-delay: 240ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(5)  { transition-delay: 320ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(6)  { transition-delay: 400ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(7)  { transition-delay: 480ms; opacity: 1; transform: none; }
.vu-reveal--stagger[data-visible="true"] > *:nth-child(n+8){ transition-delay: 560ms; opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .vu-reveal,
  .vu-reveal--stagger > * { opacity: 1; transform: none; transition: none; }
}

/* ============== Decorative utilities ============== */
.vu-grain {
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0.04;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0   0 0 0 0 0   0 0 0 0 0   0 0 0 0.8 0'/></filter><rect width='180' height='180' filter='url(%23n)'/></svg>");
}

.vu-divider {
  height: 1px;
  background: var(--vu-c-line);
  border: 0;
  margin-block: var(--vu-sp-12);
}

.vu-eyebrow-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: var(--vu-c-accent-soft);
  color: var(--vu-c-accent);
  border-radius: var(--vu-r-pill);
  font: var(--vu-fw-semibold) var(--vu-fs-xs)/1 var(--vu-font-primary);
  text-transform: uppercase;
  letter-spacing: var(--vu-tracking-wide);
  width: fit-content;
}
.vu-eyebrow-pill::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* Visually-hidden helper */
.vu-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ============== Marquee primitive ============== */
.vu-marquee {
  display: flex;
  overflow: hidden;
  position: relative;
  width: 100%;
  --vu-marquee-gap: 48px;
  --vu-marquee-duration: 36s;
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.vu-marquee__track {
  display: flex;
  gap: var(--vu-marquee-gap);
  flex-shrink: 0;
  padding-right: var(--vu-marquee-gap);
  animation: vu-marquee-scroll var(--vu-marquee-duration) linear infinite;
}
.vu-marquee:hover .vu-marquee__track { animation-play-state: paused; }
@keyframes vu-marquee-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(calc(-100% - var(--vu-marquee-gap))); }
}
@media (prefers-reduced-motion: reduce) {
  .vu-marquee__track { animation: none; }
}

/* ============== Soft parallax helper (CSS-only translate driven by scroll on supporting browsers) ============== */
@supports (animation-timeline: scroll()) {
  .vu-parallax {
    animation: vu-parallax 1s linear both;
    animation-timeline: scroll();
  }
  @keyframes vu-parallax {
    from { transform: translateY(-4%); }
    to   { transform: translateY(4%); }
  }
}

/* ============== Counter-up (number ticks via animation) ============== */
.vu-count-up {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

/* ============== Reveal observer (wired by vu-home.js) ============== */

</content>
</invoke>