/* ============================================================
   EFFECTS LAYER
   ============================================================ */

/* ---- SCROLL PROGRESS BAR ---- */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--gold), var(--accent));
  background-size: 200% 100%;
  z-index: 9999;
  transition: width .05s linear;
  animation: shimmer 2s linear infinite;
}
@keyframes shimmer {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}


/* ---- SCROLL REVEAL ---- */
[data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .75s cubic-bezier(.22,1,.36,1),
              transform .75s cubic-bezier(.22,1,.36,1);
}
[data-reveal="left"]  { transform: translateX(-48px); }
[data-reveal="right"] { transform: translateX(48px); }
[data-reveal="scale"] { transform: scale(.94); }
[data-reveal].revealed {
  opacity: 1;
  transform: none;
}
[data-delay="1"] { transition-delay: .1s; }
[data-delay="2"] { transition-delay: .2s; }
[data-delay="3"] { transition-delay: .3s; }
[data-delay="4"] { transition-delay: .4s; }
[data-delay="5"] { transition-delay: .5s; }
[data-delay="6"] { transition-delay: .6s; }

/* ---- SPLIT TEXT ---- */
.split-word {
  display: inline-block;
  overflow: hidden;
}
.split-word-inner {
  display: inline-block;
  transform: translateY(105%);
  opacity: 0;
  transition: transform .9s cubic-bezier(.16,1,.3,1), opacity .9s ease;
}
.split-word-inner.revealed {
  transform: translateY(0);
  opacity: 1;
}

/* ---- PARALLAX ---- */
.parallax-wrap {
  overflow: hidden;
  position: relative;
}
.parallax-img {
  will-change: transform;
  transition: none;
  transform-origin: center center;
}

/* ---- 3D CARD TILT ---- */
.product-card {
  transform-style: preserve-3d;
  will-change: transform;
  /* override the base hover transform — JS handles it */
}
.product-card:hover { transform: none; }
.product-card.tilt-active { box-shadow: var(--shadow-lg) !important; }

/* ---- MAGNETIC BUTTON ---- */
.btn--primary, .btn--sage {
  position: relative;
  transition: transform .4s cubic-bezier(.34,1.56,.64,1),
              background var(--trans), box-shadow var(--trans);
}

/* ---- MARQUEE STRIP ---- */
.marquee-strip {
  background: var(--text);
  color: rgba(255,255,255,.7);
  padding: 14px 0;
  overflow: hidden;
  position: relative;
}
.marquee-track {
  display: flex;
  gap: 0;
  will-change: transform;
  width: max-content;
}
.marquee-content {
  display: flex;
  align-items: center;
  gap: 48px;
  padding-right: 48px;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.marquee-content .dot {
  width: 4px; height: 4px;
  background: var(--accent);
  border-radius: 50%;
  flex-shrink: 0;
}
.marquee-content .star {
  color: var(--gold);
  font-size: 14px;
}

/* ---- HERO PARALLAX WRAPPER ---- */
.hero__visual.parallax-wrap { overflow: hidden; }
.hero__visual .parallax-img {
  width: 100%;
  height: 115%; /* extra height for parallax travel */
  object-fit: cover;
  position: absolute;
  top: -7.5%;
  left: 0;
}

/* ---- IMAGE REVEAL ON SCROLL ---- */
.img-reveal-wrap {
  overflow: hidden;
  position: relative;
}
.img-reveal-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--surface-2);
  transform-origin: right;
  transform: scaleX(1);
  transition: transform .9s cubic-bezier(.77,0,.18,1);
  z-index: 1;
}
.img-reveal-wrap.revealed::after {
  transform: scaleX(0);
}
.img-reveal-wrap img {
  transform: scale(1.06);
  transition: transform .9s cubic-bezier(.77,0,.18,1);
}
.img-reveal-wrap.revealed img {
  transform: scale(1);
}

/* ---- FLOATING BADGE (hero overlay) ---- */
.hero__overlay {
  animation: floatBadge 4s ease-in-out infinite;
}
@keyframes floatBadge {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-8px); }
}

/* ---- STAGGER GRID ---- */
.stagger-grid > * {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .6s cubic-bezier(.22,1,.36,1),
              transform .6s cubic-bezier(.22,1,.36,1);
}
.stagger-grid.revealed > *:nth-child(1) { opacity:1; transform:none; transition-delay: .05s; }
.stagger-grid.revealed > *:nth-child(2) { opacity:1; transform:none; transition-delay: .15s; }
.stagger-grid.revealed > *:nth-child(3) { opacity:1; transform:none; transition-delay: .25s; }
.stagger-grid.revealed > *:nth-child(4) { opacity:1; transform:none; transition-delay: .35s; }
.stagger-grid.revealed > *:nth-child(5) { opacity:1; transform:none; transition-delay: .45s; }
.stagger-grid.revealed > *:nth-child(6) { opacity:1; transform:none; transition-delay: .55s; }
.stagger-grid.revealed > *:nth-child(n+7) { opacity:1; transform:none; transition-delay: .65s; }

/* ---- COUNTER ---- */
[data-counter] {
  display: inline-block;
  min-width: 2ch;
}

/* ---- HIGHLIGHT TEXT POP ---- */
.highlight-pop {
  position: relative;
  display: inline;
}
.highlight-pop::after {
  content: '';
  position: absolute;
  left: -.1em; right: -.1em;
  bottom: -.05em;
  height: .35em;
  background: var(--accent-lt);
  z-index: -1;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .6s cubic-bezier(.22,1,.36,1);
}
.highlight-pop.revealed::after { transform: scaleX(1); }

/* ---- PAGE ENTER ANIMATION ---- */
@keyframes pageEnter {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
main, .hero, .trust-bar, section, .container:first-of-type {
  /* handled by JS reveal — no base animation here */
}
body { animation: pageEnter .4s ease both; }

/* ---- PRODUCT CARD SHINE ---- */
.product-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 40%,
    rgba(255,255,255,.12) 50%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity var(--trans);
  pointer-events: none;
  z-index: 2;
  border-radius: var(--radius);
}
.product-card:hover::before {
  opacity: 1;
  animation: cardShine .8s ease forwards;
}
@keyframes cardShine {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

/* ---- SECTION BLOB (decorative) ---- */
.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  opacity: .15;
  z-index: 0;
  animation: blobDrift 10s ease-in-out infinite alternate;
}
.blob--1 { width: 400px; height: 400px; background: var(--accent); top: -100px; right: -100px; }
.blob--2 { width: 300px; height: 300px; background: var(--sage);  bottom: -80px; left: -60px; animation-delay: -3s; }
@keyframes blobDrift {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(40px, 30px) scale(1.08); }
}
