/* ============================================================
   MIVAX — Premium Supplements Theme (NutraProfits-inspired)
   Palette: deep indigo/violet + gold accents
   Motion: 3D depth, parallax, marquee, reveal, floating
   RTL Arabic · Tajawal
   ============================================================ */

:root {
  /* ---- Core palette (NO red, NO green) ---- */
  --indigo-900: #1a1140;
  --indigo-800: #241656;
  --indigo-700: #2d1b69;
  --indigo-600: #3a2487;
  --violet-500: #6d4aff;
  --violet-400: #8466ff;
  --violet-300: #a48bff;
  --violet-tint: #f4f1fc;
  --violet-tint-2: #ece6fb;

  --gold-500: #e8b647;
  --gold-400: #f2c94c;
  --gold-300: #ffd66b;
  --gold-tint: #fbf3dd;

  --ink: #1a1333;
  --ink-soft: #4a4566;
  --muted: #6b6b80;
  --line: #e8e4f2;

  --bg: #ffffff;
  --bg-soft: #f8f7fc;
  --bg-tint: var(--violet-tint);

  /* Gradients */
  --grad-primary: linear-gradient(135deg, #2d1b69 0%, #6d4aff 100%);
  --grad-primary-soft: linear-gradient(135deg, #3a2487 0%, #8466ff 100%);
  --grad-gold: linear-gradient(135deg, #e8b647 0%, #ffd66b 100%);
  --grad-hero: radial-gradient(1200px 600px at 80% -10%, rgba(109,74,255,.18), transparent 60%),
               radial-gradient(900px 500px at 10% 10%, rgba(232,182,71,.12), transparent 55%),
               linear-gradient(180deg, #faf9ff 0%, #f4f1fc 100%);

  --terra: var(--violet-500);      /* alias used by buttons */
  --terra-deep: var(--indigo-700);
  --sage: var(--violet-500);
  --sage-deep: var(--indigo-700);

  /* Radii & shadows */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --shadow-sm: 0 4px 16px -8px rgba(45,27,105,.25);
  --shadow-md: 0 18px 40px -18px rgba(45,27,105,.35);
  --shadow-lg: 0 30px 70px -28px rgba(45,27,105,.45);
  --shadow-gold: 0 18px 40px -16px rgba(232,182,71,.5);

  --wrap: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
}

/* ---- Reset / base ---- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Tajawal", system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 24px; }

h1,h2,h3,h4 { margin: 0 0 .4em; line-height: 1.2; font-weight: 800; color: var(--ink); }

/* Brand wordmark serif */
.brand__name { font-family: "Cormorant Garamond", serif; font-weight: 700; letter-spacing: 2px; }

/* ============================================================
   ANIMATED PROMO MARQUEE (top bar)
   ============================================================ */
.promo-bar {
  background: var(--grad-primary);
  color: #fff;
  overflow: hidden;
  position: relative;
  font-size: 13.5px;
  font-weight: 600;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.promo-bar::after {
  /* subtle gold shimmer sweep */
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,214,107,.18) 50%, transparent 70%);
  background-size: 220% 100%;
  animation: shimmer 6s linear infinite;
  pointer-events: none;
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -120% 0; } }

.promo-bar__inner {
  display: inline-flex;
  white-space: nowrap;
  padding: 10px 0;
  will-change: transform;
  animation: marquee 26s linear infinite;
}
.promo-bar:hover .promo-bar__inner { animation-play-state: paused; }
.promo-bar__inner span.sep { opacity: .55; padding: 0 4px; }
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(50%); } /* RTL: content duplicated, slide half */
}

/* ============================================================
   HEADER (sticky, glassy, animated)
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .4s var(--ease), background .4s var(--ease);
}
.site-header.is-scrolled { box-shadow: var(--shadow-sm); background: rgba(255,255,255,.94); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; height: 76px; }

.brand { display: inline-flex; align-items: center; gap: 12px; color: var(--indigo-700); }
.brand__mark { width: 38px; height: 38px; color: var(--violet-500); transition: transform .6s var(--ease-spring); }
.brand:hover .brand__mark { transform: rotate(-12deg) scale(1.08); }
.brand__wordmark { display: flex; flex-direction: column; line-height: 1; }
.brand__name { font-size: 24px; color: var(--indigo-800); }
.brand__tag { font-size: 9px; letter-spacing: 3px; color: var(--gold-500); font-weight: 700; margin-top: 3px; }

.nav { display: flex; align-items: center; gap: 28px; }
.nav a { position: relative; font-weight: 600; font-size: 15px; color: var(--ink-soft); padding: 6px 0; transition: color .25s; }
.nav a::after {
  content: ""; position: absolute; bottom: 0; right: 0; left: 0; height: 2px;
  background: var(--grad-primary); transform: scaleX(0); transform-origin: right;
  transition: transform .35s var(--ease); border-radius: 2px;
}
.nav a:hover { color: var(--violet-500); }
.nav a:hover::after { transform: scaleX(1); }

.site-header__actions { display: flex; align-items: center; gap: 14px; }
.iconbtn { position: relative; display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%;
  color: var(--indigo-700); background: var(--violet-tint); transition: transform .3s var(--ease-spring), background .3s; }
.iconbtn:hover { transform: translateY(-2px); background: var(--violet-tint-2); }
.iconbtn__badge { position: absolute; top: -2px; left: -2px; min-width: 18px; height: 18px; padding: 0 4px;
  background: var(--grad-gold); color: var(--indigo-900); font-size: 11px; font-weight: 800; border-radius: 9px;
  display: grid; place-items: center; box-shadow: var(--shadow-sm); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  position: relative; display: inline-flex; align-items: center; gap: 10px;
  font-family: inherit; font-weight: 700; cursor: pointer; border: none;
  border-radius: 50px; padding: 14px 30px; font-size: 16px; line-height: 1;
  transition: transform .3s var(--ease-spring), box-shadow .3s var(--ease), filter .3s;
  will-change: transform;
}
.btn svg { width: 18px; height: 18px; }
.btn--terra { background: var(--grad-primary); color: #fff; box-shadow: var(--shadow-md); }
.btn--terra:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); filter: brightness(1.05); }
.btn--gold { background: var(--grad-gold); color: var(--indigo-900); box-shadow: var(--shadow-gold); }
.btn--gold:hover { transform: translateY(-3px); }
.btn--outline { background: #fff; color: var(--indigo-700); border: 1.5px solid var(--line); box-shadow: var(--shadow-sm); }
.btn--outline:hover { transform: translateY(-3px); border-color: var(--violet-400); color: var(--violet-500); }
.btn--cream { background: #fff; color: var(--indigo-700); box-shadow: var(--shadow-md); }
.btn--cream:hover { transform: translateY(-3px); }
.btn--lg { padding: 17px 38px; font-size: 17px; }
.btn--sm { padding: 10px 20px; font-size: 14px; }

/* ============================================================
   HERO (3D depth + floating)
   ============================================================ */
.hero { position: relative; background: var(--grad-hero); padding: 70px 0 90px; overflow: hidden; }
.hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; }
.hero__orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity: .5; pointer-events: none; }
.hero__orb--1 { width: 380px; height: 380px; background: radial-gradient(circle, rgba(109,74,255,.45), transparent 70%); top: -80px; left: -60px; animation: float1 14s ease-in-out infinite; }
.hero__orb--2 { width: 320px; height: 320px; background: radial-gradient(circle, rgba(232,182,71,.4), transparent 70%); bottom: -60px; right: -40px; animation: float2 17s ease-in-out infinite; }
@keyframes float1 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(30px,40px) scale(1.1); } }
@keyframes float2 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-30px,-30px) scale(1.08); } }

.hero__text { position: relative; z-index: 2; }
.eyebrow { display: inline-block; font-size: 13px; font-weight: 800; letter-spacing: 2px; color: var(--violet-500); text-transform: uppercase; margin-bottom: 14px; }
.eyebrow--badge { display: inline-flex; align-items: center; gap: 8px; background: #fff; padding: 8px 16px; border-radius: 50px; box-shadow: var(--shadow-sm); color: var(--indigo-700); letter-spacing: 0; }
.eyebrow__pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--gold-500); box-shadow: 0 0 0 0 rgba(232,182,71,.6); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(232,182,71,.6); } 70% { box-shadow: 0 0 0 12px rgba(232,182,71,0); } 100% { box-shadow: 0 0 0 0 rgba(232,182,71,0); } }
.eyebrow--light { color: var(--gold-300); }

.hero__title { font-size: clamp(34px, 5vw, 58px); font-weight: 900; letter-spacing: -.5px; }
.hero__title--accent { display: block; background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__lede { font-size: 18px; color: var(--ink-soft); max-width: 540px; margin: 18px 0 30px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 34px; }
.hero__trust { display: flex; flex-wrap: wrap; gap: 24px; }
.trust { display: flex; align-items: center; gap: 12px; }
.trust__icon { font-size: 26px; }
.trust b { display: block; font-size: 15px; color: var(--ink); }
.trust span { font-size: 13px; color: var(--muted); }

/* Hero media — 3D tilt frame */
.hero__media { position: relative; z-index: 2; perspective: 1200px; }
.hero__frame {
  position: relative; border-radius: var(--r-xl); overflow: visible;
  transform-style: preserve-3d; transform: rotateY(-7deg) rotateX(4deg);
  transition: transform .6s var(--ease);
  animation: heroFloat 6s ease-in-out infinite;
}
.hero__frame img { border-radius: var(--r-xl); box-shadow: var(--shadow-lg); }
@keyframes heroFloat { 0%,100% { transform: rotateY(-7deg) rotateX(4deg) translateY(0); } 50% { transform: rotateY(-4deg) rotateX(2deg) translateY(-14px); } }
.hero__sticker {
  position: absolute; bottom: -22px; left: -22px; width: 120px; height: 120px; border-radius: 50%;
  background: var(--grad-gold); color: var(--indigo-900); display: grid; place-items: center; text-align: center;
  box-shadow: var(--shadow-gold); transform: translateZ(60px); animation: spinHint 9s ease-in-out infinite;
}
@keyframes spinHint { 0%,100% { transform: translateZ(60px) rotate(-6deg); } 50% { transform: translateZ(60px) rotate(6deg); } }
.hero__sticker__big { font-size: 34px; font-weight: 900; line-height: 1; }
.hero__sticker__small { font-size: 11px; font-weight: 700; margin-top: 3px; }
.hero__chip {
  position: absolute; background: rgba(255,255,255,.95); backdrop-filter: blur(8px);
  padding: 10px 16px; border-radius: 50px; font-size: 13px; font-weight: 700; color: var(--indigo-700);
  box-shadow: var(--shadow-md); display: inline-flex; align-items: center; gap: 8px;
}
.hero__chip--top { top: 20px; right: -16px; transform: translateZ(50px); animation: chipFloat 5s ease-in-out infinite; }
.hero__chip--bot { bottom: 60px; right: -10px; transform: translateZ(40px); animation: chipFloat 5s ease-in-out infinite .8s; }
.hero__chip__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--violet-500); }
@keyframes chipFloat { 0%,100% { transform: translateZ(50px) translateY(0); } 50% { transform: translateZ(50px) translateY(-10px); } }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-head { text-align: center; max-width: 640px; margin: 0 auto 48px; }
.section-title { font-size: clamp(26px, 3.4vw, 40px); font-weight: 900; }
.section-title--light { color: #fff; }
.section-sub { color: var(--muted); font-size: 17px; margin-top: 6px; }

/* ============================================================
   VALUE PROPS (3D hover cards)
   ============================================================ */
.valueprops { padding: 64px 0; }
.valueprops__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.valueprop {
  display: flex; gap: 16px; align-items: flex-start; background: #fff; border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 26px 22px; box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
}
.valueprop:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.valueprop__icon { flex: 0 0 50px; width: 50px; height: 50px; display: grid; place-items: center; border-radius: 14px;
  background: var(--grad-primary); color: #fff; box-shadow: var(--shadow-sm); }
.valueprop__icon svg { width: 26px; height: 26px; }
.valueprop h3 { font-size: 17px; margin-bottom: 4px; }
.valueprop p { font-size: 14px; color: var(--muted); margin: 0; }

/* ============================================================
   CATEGORIES (chips)
   ============================================================ */
.categories { padding: 40px 0 20px; }
.cats { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.cat {
  display: inline-flex; align-items: center; gap: 10px; background: #fff; border: 1.5px solid var(--line);
  border-radius: 50px; padding: 12px 22px; font-weight: 700; color: var(--indigo-700); font-size: 15px;
  box-shadow: var(--shadow-sm); transition: transform .35s var(--ease-spring), border-color .3s, color .3s, background .3s;
}
.cat span { display: grid; place-items: center; min-width: 24px; height: 24px; padding: 0 6px; border-radius: 12px;
  background: var(--violet-tint); color: var(--violet-500); font-size: 13px; }
.cat:hover { transform: translateY(-4px) scale(1.03); border-color: var(--violet-400); background: var(--grad-primary); color: #fff; }
.cat:hover span { background: rgba(255,255,255,.2); color: #fff; }

/* ============================================================
   PRODUCTS GRID (3D tilt cards)
   ============================================================ */
.products { padding: 56px 0 70px; }
.grid, .mivax-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 26px; }
.card {
  position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  overflow: hidden; box-shadow: var(--shadow-sm); transform-style: preserve-3d;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .3s;
}
.card:hover { box-shadow: var(--shadow-lg); border-color: var(--violet-300); }
.card__media { position: relative; display: block; background: var(--violet-tint); aspect-ratio: 1/1; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.card:hover .card__media img { transform: scale(1.07); }
.card__badge {
  position: absolute; top: 14px; right: 14px; z-index: 2; background: var(--grad-gold); color: var(--indigo-900);
  font-size: 12px; font-weight: 800; padding: 5px 13px; border-radius: 50px; box-shadow: var(--shadow-sm);
}
.card__body { padding: 18px 18px 20px; }
.card__cat { font-size: 12px; font-weight: 700; color: var(--violet-500); }
.card__cat a { color: inherit; }
.card__title { font-size: 17px; font-weight: 800; margin: 4px 0 8px; min-height: 2.4em; color: var(--ink); }
.card__rating { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); margin-bottom: 8px; }
.card__stars { color: var(--gold-500); }
.card__rating__num { font-weight: 800; color: var(--ink); }
.card__price { display: flex; flex-direction: column; align-items: flex-start; gap: 0; margin-bottom: 8px; line-height: 1.25; }
.card__price del { order: 1; color: var(--muted); font-weight: 500; font-size: 14px; margin: 0; opacity: .8; }
.card__price del .woocommerce-Price-amount { white-space: nowrap; }
.card__price ins { order: 2; text-decoration: none; font-size: 22px; font-weight: 900; color: var(--indigo-700); }
.card__price ins .woocommerce-Price-amount { white-space: nowrap; }
.card__price .woocommerce-Price-amount { white-space: nowrap; }
.card__price bdi { white-space: nowrap; unicode-bidi: isolate; }
.card__price .woocommerce-Price-currencySymbol { margin-inline-start: 3px; }
.card__compliance { font-size: 11px; color: var(--muted); background: var(--bg-soft); border-radius: 8px; padding: 5px 10px; display: inline-block; margin-bottom: 14px; }
.card__foot { display: flex; gap: 8px; }
.card__btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--grad-primary); color: #fff; font-weight: 700; font-size: 14px; padding: 11px 14px; border-radius: 10px;
  transition: transform .3s var(--ease-spring), filter .3s; }
.card__btn svg { width: 16px; height: 16px; }
.card__btn:hover { transform: translateY(-2px); filter: brightness(1.06); }
.card__btn--alt { flex: 0 0 auto; background: var(--violet-tint); color: var(--indigo-700); }
.card__btn--alt:hover { background: var(--violet-tint-2); }

/* ============================================================
   STORY / ABOUT (dark gradient + floating stat cards)
   ============================================================ */
.story { position: relative; padding: 90px 0; color: #fff; overflow: hidden; }
.story__bg { position: absolute; inset: 0; background: var(--grad-primary); }
.story__bg::after { content: ""; position: absolute; inset: 0;
  background: radial-gradient(700px 400px at 85% 20%, rgba(232,182,71,.25), transparent 60%),
              radial-gradient(600px 400px at 10% 90%, rgba(132,102,255,.3), transparent 60%); }
.story__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.story__text p { color: rgba(255,255,255,.85); font-size: 17px; }
.story__media { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 18px; perspective: 1000px; }
.story__card {
  background: rgba(255,255,255,.1); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--r-lg); padding: 28px 22px; text-align: center; color: #fff;
  transition: transform .5s var(--ease-spring);
}
.story__card:hover { transform: translateY(-8px) rotateX(6deg); }
.story__card--2, .story__card--4 { transform: translateY(26px); }
.story__num { display: block; font-size: 40px; font-weight: 900; background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.story__label { font-size: 14px; color: rgba(255,255,255,.8); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials { padding: 70px 0; background: var(--bg-soft); }
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.testi { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.testi:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.testi__stars { color: var(--gold-500); font-size: 16px; margin-bottom: 12px; }
.testi p { font-size: 15px; color: var(--ink-soft); margin: 0 0 16px; }
.testi footer { font-size: 14px; color: var(--muted); }
.testi footer b { color: var(--indigo-700); }

/* ============================================================
   FAQ
   ============================================================ */
.faq { padding: 70px 0; }
.faq__list { max-width: 760px; margin: 0 auto; }
.faq details { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); margin-bottom: 14px;
  padding: 4px 22px; box-shadow: var(--shadow-sm); transition: box-shadow .3s; overflow: hidden; }
.faq details[open] { box-shadow: var(--shadow-md); }
.faq summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center;
  font-weight: 700; color: var(--indigo-700); padding: 16px 0; font-size: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq .caret { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%;
  background: var(--violet-tint); color: var(--violet-500); font-size: 18px; transition: transform .3s var(--ease), background .3s; }
.faq details[open] .caret { transform: rotate(45deg); background: var(--grad-primary); color: #fff; }
.faq details p { margin: 0 0 16px; color: var(--ink-soft); font-size: 15px; line-height: 1.8; }

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta { position: relative; padding: 70px 0; overflow: hidden; }
.cta__bg { position: absolute; inset: 0; background: var(--grad-primary); }
.cta__bg::after { content: ""; position: absolute; inset: 0; background: radial-gradient(600px 300px at 80% 50%, rgba(232,182,71,.25), transparent 60%); }
.cta__inner { position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; color: #fff; }
.cta__inner h2 { color: #fff; font-size: clamp(24px,3vw,34px); }
.cta__inner p { color: rgba(255,255,255,.85); margin: 0; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--indigo-900); color: rgba(255,255,255,.8); padding: 60px 0 0; }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; padding-bottom: 40px; }
.footer h4 { color: #fff; font-size: 16px; margin-bottom: 16px; }
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer ul li { margin-bottom: 10px; font-size: 14px; }
.footer ul li a:hover { color: var(--gold-300); }
.brand--footer .brand__name { color: #fff; }
.brand--footer .brand__mark { color: var(--gold-400); }
.footer__about { font-size: 14px; margin: 16px 0; max-width: 280px; line-height: 1.7; }
.footer__pays { display: flex; gap: 8px; flex-wrap: wrap; }
.footer__pays .pay { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15); border-radius: 6px;
  padding: 4px 10px; font-size: 12px; font-weight: 700; color: #fff; }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px;
  border-top: 1px solid rgba(255,255,255,.1); padding: 20px 0; font-size: 13px; color: rgba(255,255,255,.6); }

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta {
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%); z-index: 60;
  display: none; align-items: center; gap: 10px; background: var(--grad-primary); color: #fff;
  font-weight: 800; padding: 14px 28px; border-radius: 50px; box-shadow: var(--shadow-lg);
}
.sticky-cta svg { width: 18px; height: 18px; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .valueprops__grid { grid-template-columns: repeat(2,1fr); }
  .grid, .mivax-grid { grid-template-columns: repeat(3,1fr); }
  .testi-grid { grid-template-columns: 1fr; }
}
@media (max-width: 880px) {
  .hero__inner { grid-template-columns: 1fr; gap: 40px; }
  .hero__media { order: -1; max-width: 460px; margin: 0 auto; }
  .story__inner { grid-template-columns: 1fr; gap: 36px; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .nav { display: none; }
  .site-header__cta { display: none; }
  .grid, .mivax-grid { grid-template-columns: repeat(2,1fr); gap: 14px; }
  .valueprops__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .card__title { font-size: 14px; }
  .card__foot { flex-direction: column; }
  .card__btn--alt { width: 100%; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; text-align: center; }
  .sticky-cta { display: inline-flex; }
  .cta__inner { flex-direction: column; text-align: center; }
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
  .hero__frame { transform: none; }
}

/* ============================================================
   SINGLE PRODUCT PAGE + COD FORM + TRUST + RELATED + REVIEWS
   Palette: indigo/violet + gold (vars from top of file)
   ============================================================ */
.mivax-single{ padding: 40px 0 80px; }
.mivax-single__inner{ max-width: 1180px; margin: 0 auto; padding: 0 20px; }

/* product summary layout */
.mivax-single div.product{ display:grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items:start; }
.mivax-single div.product .woocommerce-product-gallery{ position:relative; border-radius:24px; overflow:hidden;
  box-shadow: 0 30px 60px -20px rgba(45,27,105,.35); background:#fff; transform: perspective(1200px) rotateY(2deg); }
.mivax-single div.product .woocommerce-product-gallery img{ border-radius:24px; }
.mivax-single div.product .summary{ padding-top: 8px; }
.mivax-single .product_title{ font-size: clamp(1.8rem,3vw,2.6rem); font-weight:900; color: var(--ink,#1a1230); line-height:1.2; margin:0 0 14px; }
.mivax-single .woocommerce-product-rating{ margin-bottom: 16px; }
.mivax-single .price{ color: var(--terra-deep,#2d1b69) !important; font-weight:900 !important; font-size:1.7rem !important; }
.mivax-single .price del{ color:#9b94ad !important; font-weight:500 !important; font-size:1.1rem !important; opacity:.8; }
.mivax-single .price ins{ text-decoration:none; }
.mivax-single .woocommerce-product-details__short-description{ color:#574d6e; line-height:1.85; margin:14px 0; font-size:1.02rem; }
.mivax-single .onsale{ position:absolute; top:16px; inset-inline-start:16px; z-index:3;
  background: linear-gradient(135deg,#e8b647,#f2c94c); color:#3a2a00; font-weight:800; padding:8px 16px; border-radius:999px;
  box-shadow:0 8px 20px -6px rgba(232,182,71,.6); }

/* default add to cart - keep but secondary */
.mivax-single form.cart{ margin: 18px 0 6px; display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.mivax-single form.cart .quantity input{ width:72px; padding:12px; border:1.5px solid #e4def2; border-radius:12px; text-align:center; }
.mivax-single .single_add_to_cart_button{ background:#fff !important; color:var(--terra,#6d4aff) !important;
  border:2px solid var(--terra,#6d4aff) !important; font-weight:800 !important; border-radius:14px !important; padding:14px 26px !important;
  transition:.25s; }
.mivax-single .single_add_to_cart_button:hover{ background:var(--terra,#6d4aff) !important; color:#fff !important; transform:translateY(-2px); }

/* ---- COD FORM ---- */
.mivax-cod{ clear:both; max-width:720px; margin:40px auto 0; background: linear-gradient(160deg,#fbfaff,#f3eefe);
  border:1.5px solid #e7dffb; border-radius:24px; padding:30px; position:relative; overflow:hidden;
  box-shadow: 0 24px 50px -24px rgba(45,27,105,.3); }
.mivax-cod::before{ content:""; position:absolute; top:-40px; inset-inline-end:-40px; width:160px; height:160px;
  background:radial-gradient(circle, rgba(232,182,71,.28), transparent 70%); border-radius:50%; }
.mivax-cod__head{ display:flex; gap:14px; align-items:center; margin-bottom:18px; position:relative; }
.mivax-cod__icon{ font-size:2rem; background:#fff; width:54px; height:54px; display:grid; place-items:center; border-radius:16px;
  box-shadow:0 10px 22px -10px rgba(45,27,105,.4); animation: mivaxFloat 3.5s ease-in-out infinite; }
.mivax-cod__title{ margin:0; font-size:1.25rem; font-weight:900; color:var(--terra-deep,#2d1b69); }
.mivax-cod__sub{ margin:4px 0 0; font-size:.9rem; color:#6b6182; }
.mivax-cod__row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.mivax-field{ display:flex; flex-direction:column; gap:6px; }
.mivax-field>span{ font-size:.86rem; font-weight:700; color:#473d63; }
.mivax-field input, .mivax-field textarea{ padding:13px 15px; border:1.5px solid #e2dbf3; border-radius:13px; background:#fff;
  font-family:inherit; font-size:1rem; color:#2b2342; transition:.2s; }
.mivax-field input:focus, .mivax-field textarea:focus{ outline:none; border-color:var(--terra,#6d4aff);
  box-shadow:0 0 0 4px rgba(109,74,255,.12); }
.mivax-field textarea{ resize:vertical; }
.mivax-qty{ display:flex; align-items:center; gap:0; border:1.5px solid #e2dbf3; border-radius:13px; overflow:hidden; background:#fff; width:fit-content; }
.mivax-qty__btn{ width:44px; height:48px; border:none; background:#f4eefe; color:var(--terra,#6d4aff); font-size:1.3rem; font-weight:800; cursor:pointer; transition:.15s; }
.mivax-qty__btn:hover{ background:var(--terra,#6d4aff); color:#fff; }
.mivax-qty input{ width:60px; height:48px; border:none; text-align:center; font-size:1.05rem; font-weight:700; -moz-appearance:textfield; }
.mivax-qty input::-webkit-outer-spin-button,.mivax-qty input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.mivax-cod__total{ display:flex; flex-direction:row; flex-wrap:nowrap; justify-content:space-between; align-items:center; gap:12px; padding:16px 18px; background:#fff;
  border-radius:14px; margin:6px 0 16px; border:1px dashed #d9cffa; }
.mivax-cod__total span{ color:#6b6182; font-weight:600; white-space:nowrap; }
.mivax-cod__total strong{ font-size:1.5rem; color:var(--terra-deep,#2d1b69); font-weight:900; white-space:nowrap; direction:ltr; }
.mivax-cod__total strong .woocommerce-Price-amount{ color:var(--terra-deep,#2d1b69) !important; white-space:nowrap; }
.mivax-cod__total strong bdi{ direction:rtl; unicode-bidi:isolate; }
.mivax-cod__submit{ width:100%; border:none; cursor:pointer; padding:17px; border-radius:15px; font-size:1.12rem; font-weight:900;
  color:#fff; background:linear-gradient(135deg,var(--terra-deep,#2d1b69),var(--terra,#6d4aff));
  display:flex; align-items:center; justify-content:center; gap:10px; transition:.25s;
  box-shadow:0 16px 32px -12px rgba(109,74,255,.6); }
.mivax-cod__submit:hover:not(:disabled){ transform:translateY(-3px); box-shadow:0 22px 40px -12px rgba(109,74,255,.7); }
.mivax-cod__submit:disabled{ opacity:.7; cursor:not-allowed; }
.mivax-cod__submit svg{ width:20px; height:20px; }
.mivax-cod__note{ text-align:center; font-size:.82rem; color:#8478a0; margin:12px 0 0; }
.mivax-cod__msg{ margin-top:14px; padding:14px 16px; border-radius:13px; font-weight:700; text-align:center; }
.mivax-cod__msg.is-ok{ background:#eaf9f0; color:#1c7a45; border:1.5px solid #b9ebcd; }
.mivax-cod__msg.is-err{ background:#fdeef0; color:#b3203a; border:1.5px solid #f5c6cf; }

/* ---- TRUST STRIP ---- */
.mivax-single__trust{ max-width:1180px; margin:48px auto 0; padding:0 20px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.trust-item{ display:flex; gap:12px; align-items:center; background:#fff; border:1px solid #ece7f7; border-radius:18px; padding:18px 20px;
  box-shadow:0 14px 30px -20px rgba(45,27,105,.25); transition:.25s; }
.trust-item:hover{ transform:translateY(-4px); box-shadow:0 22px 40px -20px rgba(45,27,105,.35); }
.trust-ic{ font-size:1.7rem; background:linear-gradient(135deg,#f4eefe,#fff); width:48px; height:48px; display:grid; place-items:center; border-radius:14px; }
.trust-item strong{ display:block; color:var(--terra-deep,#2d1b69); font-size:1rem; }
.trust-item small{ color:#8478a0; }

/* ---- RELATED PRODUCTS ---- */
.related.products, .upsells.products{ max-width:1180px; margin:60px auto 0; padding:0 20px; clear:both; }
.related.products>h2, .upsells.products>h2{ font-size:1.7rem; font-weight:900; color:var(--terra-deep,#2d1b69); margin-bottom:24px; text-align:center; }
.related.products ul.products, .upsells.products ul.products{ display:grid !important; grid-template-columns:repeat(4,1fr); gap:22px; list-style:none; margin:0; padding:0; }
.related.products ul.products li.product, .upsells.products ul.products li.product{ background:#fff; border:1px solid #ece7f7; border-radius:20px; overflow:hidden;
  box-shadow:0 14px 34px -22px rgba(45,27,105,.3); transition:.3s; width:auto !important; margin:0 !important; padding:0 !important; text-align:center; }
.related.products li.product:hover, .upsells.products li.product:hover{ transform:translateY(-6px); box-shadow:0 26px 50px -22px rgba(45,27,105,.4); }
.related.products li.product img, .upsells.products li.product img{ margin:0 !important; border-radius:0 !important; }
.related.products li.product .woocommerce-loop-product__title, .upsells.products li.product .woocommerce-loop-product__title{ padding:14px 14px 4px !important; font-size:1rem !important; font-weight:800 !important; color:var(--ink,#1a1230); }
.related.products li.product .price, .upsells.products li.product .price{ color:var(--terra-deep,#2d1b69) !important; font-weight:900; display:block; padding:0 14px; }
.related.products li.product .button, .upsells.products li.product .button{ margin:12px 14px 18px !important; display:inline-block;
  background:linear-gradient(135deg,var(--terra-deep,#2d1b69),var(--terra,#6d4aff)) !important; color:#fff !important; border-radius:12px !important; font-weight:800 !important; padding:11px 20px !important; }

/* ---- REVIEWS / TABS ---- */
.woocommerce-tabs{ max-width:1180px; margin:56px auto 0; padding:0 20px; }
.woocommerce-tabs ul.tabs{ display:flex; gap:10px; list-style:none; padding:0; margin:0 0 24px; border-bottom:2px solid #ece7f7; flex-wrap:wrap; }
.woocommerce-tabs ul.tabs li{ margin:0; }
.woocommerce-tabs ul.tabs li a{ display:inline-block; padding:12px 22px; font-weight:800; color:#7a7090; text-decoration:none; border-radius:12px 12px 0 0; }
.woocommerce-tabs ul.tabs li.active a{ color:var(--terra-deep,#2d1b69); border-bottom:3px solid var(--terra,#6d4aff); background:#f7f3ff; }
.woocommerce-tabs .panel{ color:#574d6e; line-height:1.85; }
#reviews .comment-text{ background:#faf8ff; border:1px solid #ece7f7; border-radius:16px; padding:18px 20px; margin-bottom:14px; }
#reviews .star-rating span{ color:#e8b647 !important; }
#reviews .comment-form input, #reviews .comment-form textarea{ border:1.5px solid #e2dbf3; border-radius:12px; padding:12px; }
#reviews .comment-form .submit{ background:linear-gradient(135deg,var(--terra-deep,#2d1b69),var(--terra,#6d4aff)) !important; color:#fff !important; border:none !important; border-radius:12px !important; font-weight:800 !important; padding:13px 26px !important; }

/* ---- RESPONSIVE ---- */
@media (max-width: 900px){
  .mivax-single div.product{ grid-template-columns:1fr; gap:28px; }
  .mivax-single div.product .woocommerce-product-gallery{ transform:none; }
  .mivax-single__trust{ grid-template-columns:1fr 1fr; }
  .related.products ul.products, .upsells.products ul.products{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 560px){
  .mivax-cod__row{ grid-template-columns:1fr; }
  .mivax-cod{ padding:20px; }
  .mivax-single__trust{ grid-template-columns:1fr; }
  .related.products ul.products, .upsells.products ul.products{ grid-template-columns:1fr; }
}

/* ---- CUSTOM RELATED (mivax cards) ---- */
.mivax-related{ max-width:1180px; margin:64px auto 0; padding:0 20px; }
.mivax-related__title{ font-size:1.8rem; font-weight:900; color:var(--terra-deep,#2d1b69); text-align:center; margin-bottom:28px; position:relative; }
.mivax-related__title::after{ content:""; display:block; width:64px; height:4px; border-radius:999px; margin:12px auto 0; background:linear-gradient(90deg,var(--terra,#6d4aff),#e8b647); }
.mivax-related__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
@media (max-width:900px){ .mivax-related__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .mivax-related__grid{ grid-template-columns:1fr; } }
