:root {
  --black: #050505;
  --coal: #0a0a0a;
  --charcoal: #111111;
  --gold: #d4af37;
  --deep-gold: #a77a18;
  --cream: #f5e6b8;
  --white: #ffffff;
  --muted: #b5b1aa;
  --line: rgba(212, 175, 55, 0.22);
  --surface: rgba(255, 255, 255, 0.035);
  --head: "Cormorant Garamond", "Cinzel", "Playfair Display", Georgia, serif;
  --display: "Cinzel", Georgia, serif;
  --body: "Manrope", "Inter", Arial, sans-serif;
  --max: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--black);
  color: var(--white);
  font-family: var(--body);
  line-height: 1.58;
  overflow-x: hidden;
}
body.menu-open, body.modal-open { overflow: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; }
p { color: var(--muted); margin: 14px 0; }
ul { margin: 0; padding: 0; list-style: none; }

.skip-link {
  position: fixed; top: -60px; left: 16px; z-index: 1000;
  padding: 10px 14px; color: var(--black); background: var(--gold); font-weight: 800;
}
.skip-link:focus { top: 16px; }
.section-inner { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.section-dark, .section-band { position: relative; padding: clamp(64px, 8vw, 112px) 0; }
.section-dark {
  background:
    radial-gradient(circle at 76% 12%, rgba(212,175,55,.10), transparent 32%),
    linear-gradient(180deg, var(--black), #080807 52%, var(--black));
}
.section-band {
  background:
    radial-gradient(circle at 8% 80%, rgba(212,175,55,.07), transparent 30%),
    linear-gradient(180deg, #111111, #090909);
}
.grain::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .28;
  background-image: radial-gradient(rgba(255,255,255,.13) .6px, transparent .6px);
  background-size: 5px 5px;
  mask-image: linear-gradient(to bottom, transparent, #000 20%, #000 75%, transparent);
}
.eyebrow {
  margin: 0 0 13px; color: var(--gold); font-size: 11px; font-weight: 900;
  text-transform: uppercase; letter-spacing: .18em;
}
h1, h2, h3 {
  margin: 0; color: var(--white); font-family: var(--head); font-weight: 700;
  line-height: .99; letter-spacing: 0;
}
h1 { font-size: clamp(48px, 6vw, 84px); text-transform: uppercase; }
h2 { font-size: clamp(36px, 4.5vw, 66px); }
h3 { font-family: var(--display); font-size: 18px; line-height: 1.25; text-transform: uppercase; }
.section-heading { max-width: 790px; margin-bottom: clamp(30px, 5vw, 46px); }
.section-heading p { max-width: 660px; font-size: 17px; }
.badge {
  display: inline-flex; min-height: 34px; align-items: center; width: fit-content; padding: 0 13px;
  margin: 0 0 16px; color: var(--cream); border: 1px solid rgba(212,175,55,.5);
  background: rgba(212,175,55,.07); font-size: 11px; font-weight: 900;
  text-transform: uppercase; letter-spacing: .16em;
}
.button {
  display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 24px;
  border: 1px solid rgba(245,230,184,.6); border-radius: 2px;
  background: linear-gradient(132deg, #f7e7aa 0%, var(--gold) 40%, #91640e 100%);
  color: #090602; font-size: 13px; font-weight: 900;
  box-shadow: 0 18px 54px rgba(212,175,55,.2);
  transition: transform .18s ease, box-shadow .18s ease;
}
.button:hover { transform: translateY(-2px); box-shadow: 0 22px 62px rgba(212,175,55,.34); }
.button-secondary {
  color: var(--cream); background: rgba(255,255,255,.025); border-color: rgba(212,175,55,.45); box-shadow: none;
}
.button-small { min-height: 42px; padding-inline: 19px; }
.button-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }

/* Global store components: translate cleanly to Shopify header/footer sections. */
.site-header {
  position: sticky; top: 0; z-index: 80; height: 82px;
  background: rgba(5,5,5,.82); border-bottom: 1px solid rgba(212,175,55,.16);
  backdrop-filter: blur(22px);
}
.nav-shell {
  width: min(var(--max), calc(100% - 32px)); height: 82px; margin: 0 auto;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px;
}
.brand-link {
  width: clamp(92px, 10vw, 148px); height: 70px; display: flex; align-items: center;
  min-width: 0; overflow: visible;
}
.brand-logo { width: auto; max-width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 0 15px rgba(212,175,55,.26)); }
.nav-links, .nav-actions { display: flex; align-items: center; gap: 21px; }
.nav-links { justify-content: center; }
.nav-links a, .icon-link {
  color: rgba(255,255,255,.72); font-size: 12.5px; font-weight: 800; transition: color .18s ease;
}
.nav-links a.active, .nav-links a:hover, .icon-link:hover { color: var(--cream); }
.nav-links a.active::after {
  content: ""; display: block; height: 1px; margin-top: 6px; background: var(--gold);
}
.menu-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--menu-border); background: transparent; padding: 11px; }
.menu-toggle span { display: block; height: 2px; margin: 5px 0; background: var(--menu-icon); }
.menu-toggle svg { stroke: var(--menu-icon); color: var(--menu-icon); }

.hero {
  position: relative; overflow: hidden; min-height: calc(100svh - 82px); display: grid; align-items: center;
  padding: clamp(40px, 6vw, 72px) 0 clamp(56px, 8vw, 86px);
}
.hero-bg, .hero-bg img, .hero::before { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-bg img { object-fit: cover; object-position: center; filter: contrast(1.08) saturate(.94); opacity: .62; }
.hero::before {
  content: ""; z-index: 1;
  background:
    radial-gradient(circle at 76% 48%, rgba(212,175,55,.20), transparent 26%),
    linear-gradient(90deg, rgba(5,5,5,.97), rgba(5,5,5,.80) 43%, rgba(5,5,5,.35) 74%, rgba(5,5,5,.84)),
    linear-gradient(180deg, transparent 54%, var(--black));
}
.hero-grid {
  position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, 1fr) minmax(350px, .83fr);
  align-items: center; gap: clamp(34px, 5vw, 80px);
}
.hero-copy { max-width: 700px; }
.hero-copy h1 { text-shadow: 0 12px 44px rgba(0,0,0,.7); }
.hero-sub { max-width: 585px; margin-top: 20px; color: rgba(255,255,255,.82); font-size: 18px; }
.hero-line { color: var(--cream); font-weight: 700; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.hero-stage {
  position: relative; min-height: 500px; display: grid; place-items: center;
}
.product-orbit {
  position: absolute; width: min(500px, 93%); aspect-ratio: 1; border-radius: 50%;
  border: 1px solid rgba(212,175,55,.32);
  background: radial-gradient(circle, rgba(212,175,55,.17), transparent 64%);
  box-shadow: inset 0 0 92px rgba(212,175,55,.08);
}
.product-jar { position: relative; z-index: 1; filter: drop-shadow(0 32px 54px rgba(0,0,0,.86)); }
.hero-jar { width: min(545px, 96%); }
.price-ticket {
  position: absolute; right: 0; bottom: 10%; z-index: 2; min-width: 170px; padding: 15px 18px;
  background: rgba(5,5,5,.84); border: 1px solid var(--line); backdrop-filter: blur(14px);
}
.price-ticket strong { display: block; color: var(--gold); font-family: var(--display); font-size: 27px; }
.price-ticket span { color: var(--muted); font-size: 12px; font-weight: 700; }
.hero .reveal { opacity: 1; transform: none; }

.home-style-switcher {
  position: sticky; top: 82px; z-index: 70;
  background: rgba(5,5,5,.86);
  border-bottom: 1px solid rgba(212,175,55,.18);
  backdrop-filter: blur(18px);
}
.home-style-inner {
  min-height: 68px; display: flex; align-items: center; justify-content: space-between;
  gap: 18px; padding: 10px 0;
}
.home-style-copy { display: grid; gap: 2px; min-width: 210px; }
.home-style-kicker {
  color: var(--gold); font-size: 10px; font-weight: 900; letter-spacing: .18em;
  text-transform: uppercase;
}
.home-style-copy strong {
  color: var(--cream); font-family: var(--display); font-size: 13px; letter-spacing: .04em;
  text-transform: uppercase;
}
.home-style-options {
  display: grid; grid-template-columns: repeat(2, minmax(180px, 1fr)); gap: 10px;
}
.home-style-option {
  min-height: 48px; padding: 8px 13px; border: 1px solid rgba(212,175,55,.24);
  background: rgba(255,255,255,.035); color: rgba(255,255,255,.76);
  text-align: left; transition: border-color .2s ease, background .2s ease, transform .2s ease;
}
.home-style-option:hover { transform: translateY(-1px); border-color: rgba(212,175,55,.48); }
.home-style-option span {
  display: block; color: var(--gold); font-size: 10px; font-weight: 900; letter-spacing: .14em;
  text-transform: uppercase;
}
.home-style-option strong {
  display: block; margin-top: 2px; color: inherit; font-size: 12px; line-height: 1.15;
  text-transform: uppercase;
}
.home-style-option.is-active {
  color: #100b05;
  border-color: rgba(245,230,184,.70);
  background: linear-gradient(132deg, #f7e7aa 0%, var(--gold) 46%, #9c7014 100%);
  box-shadow: 0 16px 44px rgba(212,175,55,.20);
}
.home-style-option.is-active span { color: #4d3407; }

html[data-home-version="signature"] .hero {
  min-height: calc(100svh - 150px);
  padding-top: clamp(32px, 4vw, 54px);
}
html[data-home-version="signature"] .hero-grid {
  grid-template-columns: minmax(0, .92fr) minmax(390px, 1fr);
}
html[data-home-version="signature"] .hero-stage {
  min-height: clamp(520px, 48vw, 650px);
  isolation: isolate;
}
html[data-home-version="signature"] .hero-stage::before {
  content: ""; position: absolute; inset: 7% 2% 3% 7%; z-index: -1;
  border: 1px solid rgba(212,175,55,.20);
  background:
    linear-gradient(135deg, rgba(212,175,55,.10), transparent 46%),
    rgba(255,255,255,.025);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 28px 110px rgba(0,0,0,.42);
}
html[data-home-version="signature"] .hero-jar { width: min(510px, 96%); }
html[data-home-version="signature"] .product-orbit {
  width: min(570px, 102%);
  border-radius: 0;
  transform: rotate(-3deg);
}
html[data-home-version="signature"] .price-ticket {
  right: 5%; bottom: 13%;
}
html[data-home-version="signature"] .hero-bullets {
  display: flex; flex-wrap: wrap; gap: 10px; max-width: 650px; margin-top: 24px;
}
html[data-home-version="signature"] .hero-bullets li {
  width: fit-content; padding: 10px 12px;
  border: 1px solid rgba(212,175,55,.24); background: rgba(5,5,5,.34);
  color: rgba(255,255,255,.86); font-size: 12px; font-weight: 800;
}

html[data-home-version="editorial"] .hero {
  min-height: calc(100svh - 150px);
  padding-top: clamp(30px, 4vw, 52px);
  background: #080604;
}
html[data-home-version="editorial"] .hero::before {
  background:
    linear-gradient(90deg, rgba(5,5,5,.58), rgba(5,5,5,.92) 48%, rgba(5,5,5,.98)),
    radial-gradient(circle at 22% 44%, rgba(212,175,55,.20), transparent 28%),
    linear-gradient(180deg, transparent 55%, var(--black));
}
html[data-home-version="editorial"] .hero-bg img {
  object-position: 30% center;
  opacity: .44;
  filter: contrast(1.16) saturate(.78);
}
html[data-home-version="editorial"] .hero-grid {
  grid-template-columns: minmax(380px, .94fr) minmax(0, .86fr);
}
html[data-home-version="editorial"] .hero-stage {
  order: 1; min-height: clamp(500px, 45vw, 610px);
}
html[data-home-version="editorial"] .hero-copy {
  order: 2; max-width: 600px; justify-self: end;
  padding: clamp(24px, 4vw, 44px) 0 clamp(24px, 4vw, 44px) clamp(20px, 4vw, 52px);
  border-left: 1px solid rgba(212,175,55,.22);
}
html[data-home-version="editorial"] .hero-copy h1 {
  font-size: clamp(44px, 5vw, 76px);
  text-transform: none;
}
html[data-home-version="editorial"] .hero-sub { font-size: 17px; }
html[data-home-version="editorial"] .hero-jar { width: min(485px, 94%); }
html[data-home-version="editorial"] .product-orbit {
  width: min(540px, 104%);
  border-radius: 0;
  background:
    linear-gradient(135deg, rgba(212,175,55,.18), transparent 44%),
    radial-gradient(circle, rgba(212,175,55,.18), transparent 64%);
  transform: rotate(4deg);
}
html[data-home-version="editorial"] .price-ticket {
  right: auto; left: 2%; bottom: 12%;
}
html[data-home-version="editorial"] .hero-meta {
  display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px;
  margin: 24px 0 0;
}
html[data-home-version="editorial"] .hero-meta span {
  padding: 15px; border: 1px solid rgba(212,175,55,.24); background: rgba(255,255,255,.035);
}
html[data-home-version="editorial"] .hero-bullets {
  display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px 14px;
  margin-top: 24px;
}
html[data-home-version="editorial"] .hero-bullets li {
  position: relative; padding-left: 18px; color: rgba(255,255,255,.84); font-size: 13px; font-weight: 800;
}
html[data-home-version="editorial"] .hero-bullets li::before {
  content: ""; position: absolute; left: 0; top: 9px; width: 7px; height: 7px;
  background: var(--gold); transform: rotate(45deg);
}

html[data-home-version="signature"] .trust-strip,
html[data-home-version="editorial"] .trust-strip {
  border-top: 1px solid rgba(212,175,55,.18);
}
html[data-home-version="signature"] .section-band,
html[data-home-version="editorial"] .section-band {
  background:
    radial-gradient(circle at 12% 12%, rgba(212,175,55,.08), transparent 24%),
    linear-gradient(180deg, #12100c, #070706);
}
html[data-home-version="signature"] .section-dark,
html[data-home-version="editorial"] .section-dark {
  background:
    radial-gradient(circle at 82% 16%, rgba(212,175,55,.11), transparent 28%),
    linear-gradient(180deg, #050505, #0c0a07 54%, #050505);
}
html[data-home-version="editorial"] .product-layout,
html[data-home-version="editorial"] [data-shopify-section="results-section"] .split,
html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .split {
  grid-template-columns: minmax(0, .98fr) minmax(320px, .78fr);
}
html[data-home-version="editorial"] [data-shopify-section="results-section"] .section-heading,
html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .media-frame {
  order: 2;
}
html[data-home-version="editorial"] [data-shopify-section="results-section"] .compare-block,
html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .split > div {
  order: 1;
}

.stat-line {
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line); background: #070707;
}
.stat-line div { padding: 24px 20px; text-align: center; border-right: 1px solid var(--line); }
.stat-line div:last-child { border-right: 0; }
.stat-line strong { display: block; color: var(--cream); font-family: var(--display); font-size: 17px; text-transform: uppercase; }
.stat-line span { color: var(--muted); font-size: 13px; }

.cards-4, .cards-3 {
  display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px;
}
.cards-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.lux-card {
  border: 1px solid var(--line); background: var(--surface); padding: 25px;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.lux-card:hover { transform: translateY(-4px); border-color: rgba(212,175,55,.48); background: rgba(212,175,55,.055); }
.lux-card .card-number {
  display: block; margin-bottom: 26px; color: var(--gold); font-family: var(--display); font-size: 18px;
}
.lux-card p { margin-bottom: 0; font-size: 14px; }
.visual-wide {
  margin-top: 24px; border: 1px solid var(--line); overflow: hidden; max-height: 450px;
}
.visual-wide img { width: 100%; height: 450px; object-fit: cover; object-position: center 36%; }

.split {
  display: grid; grid-template-columns: minmax(300px, .88fr) minmax(0, 1.12fr); gap: clamp(32px, 6vw, 82px);
  align-items: center;
}
.media-frame {
  position: relative; border: 1px solid var(--line); overflow: hidden; background: #090909;
  box-shadow: 0 30px 84px rgba(0,0,0,.36);
}
.media-frame img { width: 100%; height: 540px; object-fit: cover; }
.customer-frame img { object-fit: contain; background: #090909; padding: 12px; }
.media-tag {
  position: absolute; left: 18px; bottom: 18px; background: rgba(5,5,5,.84); border: 1px solid var(--line);
  color: var(--cream); padding: 10px 13px; font-size: 12px; font-weight: 800; text-transform: uppercase;
}

.compare-block { position: relative; }
.compare-view {
  position: relative; height: 525px; overflow: hidden; border: 1px solid var(--line);
  background: #060504; cursor: ew-resize; touch-action: none; user-select: none;
}
.compare-view picture, .compare-view img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 26%; }
.compare-after { clip-path: inset(0 0 0 52%); z-index: 1; }
.compare-handle {
  position: absolute; top: 0; bottom: 0; left: 52%; z-index: 3; width: 2px; background: var(--cream);
  box-shadow: 0 0 22px rgba(245,230,184,.7); transform: translateX(-50%);
}
.compare-handle::after {
  content: "< >"; position: absolute; left: 50%; top: 50%; display: grid; place-items: center;
  width: 46px; height: 46px; transform: translate(-50%,-50%); border-radius: 50%;
  background: var(--black); border: 1px solid var(--gold); color: var(--gold); font-size: 11px; font-weight: 900;
}
.compare-badges { position: absolute; inset: auto 18px 18px; display: flex; justify-content: space-between; z-index: 4; pointer-events: none; }
.compare-badges span {
  background: rgba(5,5,5,.75); border: 1px solid var(--line); padding: 8px 12px; color: var(--cream);
  font-size: 11px; font-weight: 900; text-transform: uppercase;
}
.compare-range { width: 100%; height: 28px; margin-top: 18px; accent-color: var(--gold); cursor: ew-resize; }

.real-transformation {
  padding-block: clamp(54px, 6vw, 90px);
  border-top: 1px solid rgba(212,175,55,.16);
  border-bottom: 1px solid rgba(212,175,55,.16);
}
.result-trust-badge {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  margin-top: 8px;
  border: 1px solid rgba(212,175,55,.44);
  background: rgba(212,175,55,.08);
  color: var(--cream);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.real-result-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 3vw, 28px);
}
.real-result-card {
  position: relative;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,.28);
  background: #060504;
  box-shadow: 0 28px 74px rgba(0,0,0,.34);
}
.real-result-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  filter: saturate(.98) contrast(1.02);
}
.real-result-card span {
  position: absolute;
  left: 16px;
  top: 16px;
  z-index: 2;
  padding: 9px 13px;
  border: 1px solid rgba(212,175,55,.42);
  background: rgba(5,5,5,.82);
  color: var(--cream);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .16em;
}

.product-layout {
  display: grid; grid-template-columns: minmax(310px, .9fr) minmax(0, 1.1fr); align-items: center;
  gap: clamp(34px, 6vw, 88px);
}
.product-stage {
  position: relative; min-height: 500px; display: grid; place-items: center;
}
.product-stage::before {
  content: ""; position: absolute; bottom: 15%; width: 92%; height: 120px;
  background: radial-gradient(ellipse, rgba(212,175,55,.30), transparent 68%);
}
.product-main { width: min(650px, 100%); }
.price-row { display: flex; gap: 15px; align-items: center; margin: 22px 0; flex-wrap: wrap; }
.price { font-family: var(--display); color: var(--cream); font-weight: 800; font-size: clamp(38px, 4vw, 54px); }
.price-stack {
  display: inline-grid;
  gap: 4px;
  line-height: 1;
}
.compare-price {
  color: rgba(245,230,184,.56);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .10em;
}
.compare-price s {
  text-decoration-color: rgba(212,175,55,.90);
  text-decoration-thickness: 2px;
}
.sale-price {
  color: var(--cream);
  font-family: var(--display);
  font-size: clamp(38px, 4vw, 54px);
  font-weight: 900;
}
.discount-label {
  width: fit-content;
  padding: 5px 8px;
  border: 1px solid rgba(212,175,55,.34);
  background: rgba(212,175,55,.08);
  color: var(--gold);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .10em;
}
.hero-price-stack .sale-price,
.ticket-price-stack .sale-price,
.launch-price-stack .sale-price {
  color: var(--gold);
}
.hero-price-stack .sale-price,
.ticket-price-stack .sale-price {
  font-size: 28px;
}
.ticket-price-stack {
  margin-bottom: 6px;
}
.feature-list { display: grid; gap: 12px; margin: 25px 0 30px; }
.feature-list li { position: relative; padding-left: 27px; color: rgba(255,255,255,.84); font-weight: 700; }
.feature-list li::before {
  content: ""; position: absolute; left: 0; top: 10px; width: 9px; height: 9px; transform: rotate(45deg);
  background: var(--gold); box-shadow: 0 0 14px rgba(212,175,55,.7);
}

.launch-offer {
  margin-top: 26px;
  padding: 22px;
  border: 1px solid rgba(212,175,55,.34);
  background:
    linear-gradient(135deg, rgba(212,175,55,.12), transparent 46%),
    rgba(255,255,255,.035);
  box-shadow: 0 22px 64px rgba(0,0,0,.22);
}
.launch-offer > strong {
  display: block;
  color: var(--cream);
  font-family: var(--display);
  font-size: 18px;
  line-height: 1.18;
  text-transform: uppercase;
}
.launch-price {
  display: block;
  margin: 10px 0 13px;
  color: var(--gold);
  font-family: var(--display);
  font-size: 34px;
  font-weight: 900;
}
.launch-price-stack {
  margin: 10px 0 13px;
}
.launch-price-stack .sale-price {
  font-size: 34px;
}
.launch-offer ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px 14px;
}
.launch-offer li {
  position: relative;
  padding-left: 20px;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  font-weight: 800;
}
.launch-offer li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gold);
}

.conversion-trust {
  padding: clamp(26px, 4vw, 46px) 0;
  background: #050505;
  border-top: 1px solid rgba(212,175,55,.16);
  border-bottom: 1px solid rgba(212,175,55,.16);
}
.conversion-trust-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.conversion-trust-card {
  min-height: 92px;
  display: grid;
  align-content: center;
  gap: 9px;
  padding: 18px;
  border: 1px solid rgba(212,175,55,.30);
  background: rgba(255,255,255,.03);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.conversion-trust-card:hover {
  transform: translateY(-3px);
  border-color: rgba(212,175,55,.58);
  background: rgba(212,175,55,.07);
}
.conversion-trust-card span {
  color: var(--gold);
  font-weight: 900;
}
.conversion-trust-card strong {
  color: var(--cream);
  font-size: 12px;
  line-height: 1.25;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.audience-list { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 25px; }
.audience-list span {
  border: 1px solid var(--line); background: rgba(212,175,55,.05); padding: 12px;
  color: var(--cream); text-align: center; font-size: 11px; font-weight: 900; text-transform: uppercase;
}
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.step {
  min-height: 170px; padding: 23px; border: 1px solid var(--line); background: var(--surface);
  display: grid; align-content: space-between;
}
.step span { color: var(--gold); font-family: var(--display); font-weight: 800; }
.step strong { font-family: var(--head); font-size: 25px; line-height: 1.1; }

.proof-grid {
  display: grid; grid-template-columns: 1.05fr .95fr .95fr; gap: 16px;
}
.proof-card {
  position: relative; border: 1px solid var(--line); background: #080808; overflow: hidden; min-height: 425px;
}
.proof-card img { height: 100%; width: 100%; object-fit: cover; }
.proof-card:first-child img { object-fit: contain; padding: 12px; }
.proof-card::after { content: ""; position: absolute; inset: 45% 0 0; background: linear-gradient(transparent, rgba(5,5,5,.92)); }
.proof-content { position: absolute; left: 20px; right: 20px; bottom: 18px; z-index: 1; }
.proof-content p { margin: 6px 0 0; font-size: 13px; }
.play {
  display: grid; place-items: center; width: 52px; height: 52px; margin-bottom: 18px;
  border-radius: 50%; background: var(--cream); box-shadow: 0 0 32px rgba(212,175,55,.45);
}
.play::after {
  content: ""; margin-left: 3px; border-left: 15px solid var(--black);
  border-top: 10px solid transparent; border-bottom: 10px solid transparent;
}

.reel-row {
  display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px;
}
.reel {
  position: relative; min-height: 500px; padding: 0; border: 1px solid var(--line); background: #080808;
  overflow: hidden; text-align: left;
}
.reel img { width: 100%; height: 100%; min-height: 500px; object-fit: cover; }
.reel::after { content: ""; position: absolute; inset: 34% 0 0; background: linear-gradient(transparent, rgba(5,5,5,.94)); }
.reel .play { position: absolute; top: 18px; right: 18px; z-index: 1; }
.reel h3 { position: absolute; left: 18px; bottom: 20px; z-index: 1; }
.reviews-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.review {
  min-height: 225px; padding: 29px; border: 1px solid var(--line); background: var(--surface);
}
.stars { color: var(--gold); font-family: var(--display); font-size: 16px; margin-bottom: 20px; }
.review blockquote { margin: 0 0 20px; color: rgba(255,255,255,.87); font-size: 16px; }
.review figcaption { color: var(--gold); font-weight: 800; font-size: 13px; }
.review figcaption strong,
.review figcaption span {
  display: block;
}
.review figcaption span {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
}

.founder-story { padding-block: 72px; }
.founder-grid {
  display: grid;
  grid-template-columns: minmax(320px, .86fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
}
.founder-visual {
  min-height: 430px;
  border: 1px solid rgba(212,175,55,.22);
  overflow: hidden;
  background: #080808;
}
.founder-visual img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  object-position: center 32%;
  filter: saturate(.9) contrast(1.05);
}
.founder-copy blockquote {
  margin: 20px 0;
  padding-left: 20px;
  border-left: 2px solid var(--gold);
  color: var(--cream);
  font-family: var(--display);
  font-size: clamp(25px, 3vw, 38px);
  line-height: 1.12;
}
.founder-signature {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(212,175,55,.22);
}
.founder-signature strong,
.founder-signature span {
  display: block;
}
.founder-signature strong {
  color: var(--cream);
  font-family: var(--display);
  font-size: 18px;
  text-transform: uppercase;
}
.founder-signature span {
  margin-top: 3px;
  color: var(--gold);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.mission-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.mission-card { padding: 28px; border: 1px solid var(--line); background: var(--surface); }
.mission-card span { display: block; margin-bottom: 21px; color: var(--gold); font-family: var(--display); font-weight: 800; }

.faq-layout { display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(30px,6vw,82px); }
.accordion { display: grid; gap: 12px; }
details { border: 1px solid var(--line); background: var(--surface); }
summary { cursor: pointer; padding: 19px 22px; color: var(--cream); font-weight: 800; }
details p { margin: 0; padding: 0 22px 20px; }

.conversion {
  display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 30px;
  padding: clamp(28px,5vw,54px); border: 1px solid var(--line);
  background:
    radial-gradient(circle at 82% 50%, rgba(212,175,55,.18), transparent 30%),
    rgba(255,255,255,.03);
}
.conversion img { width: min(585px,100%); justify-self: center; }

/* Internal pages */
.page-hero {
  position: relative; min-height: 450px; display: grid; align-items: end; overflow: hidden;
  padding: 58px 0;
}
.page-hero .page-bg, .page-hero .page-bg img { position: absolute; inset: 0; width: 100%; height: 100%; }
.page-hero .page-bg img { object-fit: cover; opacity: .38; }
.page-hero::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(5,5,5,.98), rgba(5,5,5,.63)), linear-gradient(0deg, var(--black), transparent 55%);
}
.page-hero-content { position: relative; z-index: 1; max-width: 760px; }
.page-hero p { max-width: 620px; font-size: 18px; }
.breadcrumbs { margin-bottom: 24px; color: var(--gold); font-size: 12px; font-weight: 800; text-transform: uppercase; }
.breadcrumbs a { color: var(--muted); }

.product-page-grid {
  display: grid; grid-template-columns: .94fr 1.06fr; gap: clamp(32px,6vw,78px); align-items: start;
}
.product-gallery { position: sticky; top: 102px; }
.product-gallery-main {
  position: relative; min-height: 575px; display: grid; place-items: center; border: 1px solid var(--line);
  background: radial-gradient(circle at 50% 74%, rgba(212,175,55,.19), transparent 33%), #080808;
}
.product-gallery-main img { max-width: 90%; max-height: 510px; object-fit: contain; }
.thumbs { display: flex; gap: 10px; margin-top: 12px; }
.thumb {
  width: 86px; height: 86px; border: 1px solid var(--line); background: #080808; display: grid; place-items: center;
}
.thumb.selected { border-color: var(--gold); }
.thumb img { width: 76px; height: 76px; object-fit: contain; }
.purchase h1 { font-size: clamp(39px,4vw,58px); text-transform: none; }
.purchase .subcopy { color: var(--cream); }
.quantity { display: flex; align-items: center; gap: 12px; margin-top: 24px; }
.stepper { display: flex; border: 1px solid var(--line); height: 48px; }
.stepper button { width: 46px; border: 0; background: transparent; }
.stepper input { width: 46px; border: 0; text-align: center; background: transparent; }
.purchase-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 25px; }
.purchase-actions .button:first-child { grid-column: 1 / -1; }
.info-panels { margin-top: 32px; display: grid; gap: 10px; }

.gallery-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 16px;
}
.gallery-tile {
  position: relative; border: 1px solid var(--line); background: #080808; overflow: hidden;
}
.gallery-tile img { width: 100%; height: 410px; object-fit: cover; }
.gallery-tile.customer img { object-fit: contain; padding: 10px; }
.gallery-tile .tile-copy { padding: 18px; }
.gallery-tile p { font-size: 13px; margin-bottom: 0; }
.disclaimer {
  margin-top: 24px; padding: 18px 20px; border-left: 2px solid var(--gold);
  color: var(--muted); background: rgba(212,175,55,.045); font-size: 13px;
}

.contact-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(30px,6vw,82px); }
.contact-stack { display: grid; gap: 12px; }
.contact-tile { border: 1px solid var(--line); padding: 21px; background: var(--surface); }
.contact-tile span { display: block; color: var(--gold); font-size: 11px; font-weight: 900; text-transform: uppercase; margin-bottom: 8px; }
.contact-form { display: grid; gap: 13px; border: 1px solid var(--line); padding: clamp(20px,4vw,34px); background: var(--surface); }
.field { display: grid; gap: 7px; }
.field label { color: var(--cream); font-size: 13px; font-weight: 800; }
.field input, .field textarea, .field select {
  width: 100%; min-height: 48px; padding: 12px 14px; border: 1px solid var(--line);
  background: #090909; color: var(--white);
}
.field textarea { min-height: 120px; resize: vertical; }

.policy { max-width: 840px; }
.policy h2 { margin: 42px 0 13px; font-size: clamp(28px,4vw,40px); }
.policy p, .policy li { font-size: 16px; color: var(--muted); }
.policy ul { display: grid; gap: 9px; list-style: disc; padding-left: 20px; }

.site-footer {
  padding: 66px 0 22px; border-top: 1px solid var(--line); background: #030303;
}
.footer-grid { display: grid; grid-template-columns: 1.25fr repeat(3,1fr); gap: 28px; }
.footer-logo { width: 116px; height: 104px; object-fit: contain; margin-bottom: 15px; }
.footer-brand p { max-width: 270px; }
.site-footer h2 {
  margin: 0 0 15px; color: var(--cream); font-family: var(--display); font-size: 15px; text-transform: uppercase;
}
.site-footer a { display: block; width: fit-content; margin: 9px 0; color: rgba(255,255,255,.68); font-size: 14px; }
.site-footer a:hover { color: var(--gold); }
.footer-bottom {
  width: min(var(--max), calc(100% - 32px)); margin: 40px auto 0; padding-top: 19px;
  display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap;
  border-top: 1px solid rgba(212,175,55,.15); color: #837e75; font-size: 12px;
}
.footer-bottom a { display: inline; color: var(--gold); }
.footer-contact-list { display: grid; gap: 8px; }
.footer-contact-link span {
  min-width: 74px;
  display: inline-block;
  color: var(--gold);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.footer-trust-badges {
  margin: 30px auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-trust-badges span {
  padding: 9px 12px;
  border: 1px solid rgba(212,175,55,.22);
  background: rgba(212,175,55,.07);
  color: var(--cream);
  font-size: 12px;
  font-weight: 800;
}

.social-float-stack {
  position: fixed;
  right: max(20px, env(safe-area-inset-right));
  bottom: max(20px, env(safe-area-inset-bottom));
  z-index: 95;
  display: grid;
  gap: 12px;
  pointer-events: none;
}
.social-float {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  pointer-events: auto;
  transform: translateZ(0);
  transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
}
.social-float svg {
  width: 24px;
  height: 24px;
  display: block;
  fill: currentColor;
}
.social-float-whatsapp {
  background: #25d366;
  box-shadow: 0 16px 34px rgba(37, 211, 102, .28), 0 8px 24px rgba(0,0,0,.30);
}
.social-float-instagram {
  background:
    radial-gradient(circle at 32% 108%, #fdf497 0 20%, #fd5949 44%, transparent 45%),
    linear-gradient(135deg, #405de6 0%, #833ab4 35%, #c13584 60%, #e1306c 78%, #fd1d1d 100%);
  box-shadow: 0 16px 34px rgba(193, 53, 132, .26), 0 8px 24px rgba(0,0,0,.30);
}
.social-float:hover {
  transform: translateY(-4px) scale(1.04);
  filter: saturate(1.08);
}
.social-float:focus-visible {
  outline: 2px solid var(--cream);
  outline-offset: 4px;
}

.media-modal {
  position: fixed; inset: 0; z-index: 120; display: none; place-items: center; padding: 28px;
  background: rgba(0,0,0,.88); backdrop-filter: blur(14px);
}
.media-modal.is-open { display: grid; }
.modal-sheet { position: relative; max-width: min(540px,95vw); }
.media-modal img { max-height: 80svh; width: 100%; object-fit: contain; border: 1px solid var(--line); background: var(--black); }
.media-modal p { margin: 10px 0 0; text-align: center; color: var(--cream); }
.modal-close {
  position: absolute; right: -12px; top: -12px; z-index: 2; width: 42px; height: 42px;
  border: 1px solid var(--line); background: var(--black);
}
.modal-close::after { content: "X"; color: var(--gold); font-weight: 900; }
.toast {
  position: fixed; right: 20px; bottom: 20px; z-index: 100; padding: 14px 18px;
  border: 1px solid var(--line); background: #10100f; color: var(--cream);
  transform: translateY(20px); opacity: 0; pointer-events: none; transition: .2s ease;
}
.toast.is-visible { transform: translateY(0); opacity: 1; }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity .62s ease, transform .62s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .nav-shell { grid-template-columns: auto 1fr auto; justify-content: space-between; }
  .menu-toggle { display: block; }
  .nav-links { display: none; }
  .nav-actions { display: flex !important; gap: 8px !important; align-items: center; }
  .nav-actions .icon-link,
  .nav-actions .button-small,
  .nav-actions a.button { display: none !important; }
  .nav-actions .theme-toggle {
    display: inline-flex !important;
    height: 34px !important;
    padding: 0 10px !important;
    font-size: 10px !important;
    letter-spacing: .12em !important;
    gap: 5px !important;
    white-space: nowrap !important;
    position: static !important;
    transform: none !important;
  }
  .nav-actions .theme-toggle svg { width: 12px !important; height: 12px !important; }
  .site-header.is-open .nav-links {
    display: flex; position: fixed; left: 16px; right: 16px;
    background: rgba(5,5,5,.98); border: 1px solid var(--line);
    backdrop-filter: blur(18px);
    top: 92px; flex-direction: column; align-items: stretch; gap: 0; padding: 16px;
    max-height: calc(100svh - 220px); overflow-y: auto;
  }
  .site-header.is-open .nav-links a {
    padding: 14px 12px; border-bottom: 1px solid rgba(212,175,55,.12);
    color: var(--cream); font-size: 14px;
  }
  .site-header.is-open .nav-links a:last-child { border-bottom: 0; }
  .site-header.is-open .nav-links a.active::after { display: none; }
  .hero-grid, .split, .product-layout, .product-page-grid, .faq-layout, .conversion, .contact-grid { grid-template-columns: 1fr; }
  .cards-4, .steps, .footer-grid { grid-template-columns: repeat(2,1fr); }
  .proof-grid, .gallery-grid, .reviews-grid, .mission-grid { grid-template-columns: 1fr; }
  .product-gallery { position: static; }
  .hero-stage { min-height: 430px; }
}

@media (max-width: 700px) {
  .site-header {
    height: 80px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 9999 !important;
  }
  .nav-shell {
    height: 80px !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    padding: 10px 16px !important;
    gap: 10px !important;
  }
  .brand-link {
    justify-self: start !important;
    width: auto;
    height: 70px !important;
  }
  .brand-logo { max-height: 60px !important; width: auto !important; }
  .nav-links { display: none !important; }
  .nav-actions {
    justify-self: center !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
  }
  .nav-actions .icon-link,
  .nav-actions .button-small,
  .nav-actions a.button { display: none !important; }
  .nav-actions .theme-toggle {
    position: static !important;
    transform: none !important;
    margin: 0 auto !important;
    height: 36px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    line-height: 1 !important;
    letter-spacing: .12em !important;
    white-space: nowrap !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .nav-actions .theme-toggle svg { width: 12px !important; height: 12px !important; }
  .menu-toggle {
    justify-self: end !important;
    width: 42px !important;
    height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid var(--menu-border) !important;
    background: transparent !important;
    padding: 8px !important;
  }
  .menu-toggle span {
    display: block !important;
    width: 18px !important;
    height: 2px !important;
    background: var(--menu-icon) !important;
    border-radius: 10px !important;
    margin: 3px 0 !important;
  }
  .section-dark, .section-band { padding: 58px 0; }
  .hero { min-height: auto; padding: 46px 0 56px; }
  .hero-grid { gap: 25px; }
  h1 { font-size: clamp(36px, 11vw, 49px); }
  h2 { font-size: clamp(34px, 10vw, 46px); }
  .hero-sub { font-size: 15px; }
  .hero-actions, .button-row, .purchase-actions { flex-direction: column; display: flex; }
  .site-header.is-open .nav-actions { flex-direction: column; }
  .button { width: 100%; }
  .hero-stage { min-height: 355px; }
  .hero-jar { width: min(360px,95%); }
  .price-ticket { bottom: 0; left: 0; right: 0; }
  .stat-line, .cards-4, .cards-3, .steps, .footer-grid, .audience-list { grid-template-columns: 1fr; }
  .stat-line div { border-right: 0; border-bottom: 1px solid var(--line); }
  .stat-line div:last-child { border-bottom: 0; }
  .visual-wide img, .media-frame img, .compare-view { height: 385px; }
  .product-stage { min-height: 385px; }
  .proof-grid { display: flex; gap: 13px; overflow-x: auto; scroll-snap-type: x mandatory; }
  .proof-card { flex: 0 0 86%; min-height: 400px; scroll-snap-align: center; }
  .reel-row { display: flex; gap: 13px; overflow-x: auto; scroll-snap-type: x mandatory; }
  .reel { flex: 0 0 82%; min-height: 435px; scroll-snap-align: center; }
  .reel img { min-height: 435px; }
  .page-hero { min-height: 390px; }
  .product-gallery-main { min-height: 410px; }
  .product-gallery-main img { max-height: 360px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-tile img { height: 370px; }
  .footer-bottom { display: grid; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; scroll-behavior: auto !important; }
}

/* ============================================================
   ZLYN — Modular section additions (mapped to Shopify sections)
   ============================================================ */

.hero-meta { display: flex; flex-wrap: wrap; gap: 18px 28px; margin-top: 22px; color: var(--cream); font-size: 13px; }
.hero-meta strong { display: inline-block; margin-right: 6px; color: var(--gold); font-family: var(--display); font-size: 18px; }
.hero-bullets {
  display: grid; grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px 18px; margin: 22px 0 4px; padding: 0;
}
.hero-bullets li {
  position: relative; padding-left: 22px; color: rgba(255,255,255,.84);
  font-size: 14px; font-weight: 600;
}
.hero-bullets li::before {
  content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 8px;
  transform: rotate(45deg); background: var(--gold); box-shadow: 0 0 12px rgba(212,175,55,.6);
}

/* Trust strip */
.trust-strip {
  position: relative; padding: 22px 0; background: #070707;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.trust-grid {
  display: grid; grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 0; align-items: center;
}
.trust-cell {
  padding: 14px 16px; text-align: center;
  border-right: 1px solid var(--line);
}
.trust-cell:last-child { border-right: 0; }
.trust-cell strong {
  display: block; color: var(--cream); font-family: var(--display);
  font-size: 13px; text-transform: uppercase; letter-spacing: .12em;
}
.trust-cell span { display: block; margin-top: 4px; color: var(--muted); font-size: 12px; }

.why-zlyn { padding-block: 46px; }
.why-zlyn .section-heading { margin-bottom: 18px; }
.why-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.why-chip {
  min-height: 78px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 14px;
  border: 1px solid rgba(212,175,55,.24);
  background: linear-gradient(145deg, rgba(212,175,55,.10), rgba(255,255,255,.025));
  color: var(--cream);
  font-weight: 800;
  font-size: 13px;
}
.why-chip span {
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 22px;
  border: 1px solid rgba(212,175,55,.55);
  border-radius: 50%;
  color: var(--gold);
  font-size: 12px;
}

/* Ingredients */
.ingredients-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px;
}
.ingredient-card {
  position: relative; padding: 28px 26px;
  border: 1px solid var(--line); background: var(--surface);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.ingredient-card:hover { transform: translateY(-4px); border-color: rgba(212,175,55,.55); background: rgba(212,175,55,.06); }
.ingredient-mark {
  display: block; width: 38px; height: 38px; margin-bottom: 18px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--cream), var(--gold) 60%, var(--deep-gold));
  box-shadow: 0 0 22px rgba(212,175,55,.4);
}
.ingredient-card h3 { margin-bottom: 10px; }
.ingredient-card p { margin: 0; font-size: 14px; }

/* Product feature meta */
.price-meta { color: var(--muted); font-size: 13px; font-weight: 700; letter-spacing: .04em; }
.product-meta-list { display: grid; gap: 10px; margin: 0 0 22px; }
.product-meta-list div {
  display: grid; grid-template-columns: 160px 1fr; gap: 14px;
  padding: 12px 0; border-top: 1px solid var(--line);
}
.product-meta-list div:last-child { border-bottom: 1px solid var(--line); }
.product-meta-list dt { color: var(--gold); font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .14em; }
.product-meta-list dd { margin: 0; color: rgba(255,255,255,.86); font-size: 14px; font-weight: 600; }

/* How-to-use 5 columns */
.steps-5 { grid-template-columns: repeat(5, minmax(0,1fr)); }
.steps-5 .step strong { font-size: 18px; }
.steps-5 .step p { margin: 8px 0 0; font-size: 13px; }

/* About page blocks */
.about-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; }
.about-block { padding: 30px; border: 1px solid var(--line); background: var(--surface); }
.about-block h2 { margin-bottom: 14px; font-size: clamp(24px, 2.6vw, 32px); }
.about-block p { margin: 0; font-size: 15.5px; }

/* Page hero compact (PDP, policy) */
.page-hero.compact { min-height: 280px; padding: 44px 0 24px; }
.page-hero.compact::after { background: linear-gradient(90deg, rgba(5,5,5,.96), rgba(5,5,5,.86)); }

/* Contact support note */
.contact-tile.support-note p { margin: 6px 0 0; color: var(--muted); font-size: 13px; }
.contact-tile.support-note { background: rgba(212,175,55,.06); border-color: rgba(212,175,55,.36); }

/* Policy pages */
.policy { max-width: 880px; }
.policy .policy-intro { font-size: 17px; color: rgba(255,255,255,.86); margin-bottom: 26px; }
.policy h2 {
  margin: 38px 0 12px; font-size: clamp(22px, 2.6vw, 30px);
  color: var(--cream); font-family: var(--display); text-transform: uppercase; letter-spacing: .04em;
  padding-bottom: 8px; border-bottom: 1px solid var(--line);
}
.policy p { font-size: 15.5px; line-height: 1.72; margin: 10px 0; color: var(--muted); }
.policy a { color: var(--gold); border-bottom: 1px solid rgba(212,175,55,.4); }
.policy-update { margin-top: 38px; padding-top: 18px; border-top: 1px solid var(--line); font-size: 13px; }

/* PDP info-list inside details */
.info-list { margin: 0; padding: 0 22px 18px; display: grid; gap: 8px; list-style: disc; }
.info-list li { color: rgba(255,255,255,.82); font-size: 14.5px; line-height: 1.6; }
.info-list li strong { color: var(--cream); }
.purchase-title { font-family: var(--head); font-size: clamp(30px, 4vw, 46px); margin: 8px 0 6px; line-height: 1.05; }

/* PDP price stack */
.purchase .price-row { gap: 18px; align-items: baseline; flex-wrap: wrap; }
.purchase .price { font-size: clamp(34px, 4vw, 48px); }

/* Footer disclaimer block */
.footer-disclaimer { margin: 28px auto 0; padding-top: 22px; border-top: 1px solid rgba(212,175,55,.12); }
.footer-disclaimer p { max-width: 920px; margin: 0; color: #837e75; font-size: 12.5px; line-height: 1.65; }

/* ===== Responsive ===== */
@media (max-width: 1050px) {
  .hero-bullets { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .trust-cell:nth-child(3n) { border-right: 0; }
  .trust-cell:nth-child(n+4) { border-top: 1px solid var(--line); }
  .ingredients-grid { grid-template-columns: 1fr; }
  .steps-5 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .about-grid { grid-template-columns: 1fr; }
  .product-meta-list div { grid-template-columns: 130px 1fr; }
}

@media (max-width: 700px) {
  .trust-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .trust-cell { border-right: 0; border-bottom: 1px solid var(--line); }
  .trust-cell:nth-child(2n) { border-right: 0; }
  .trust-cell:last-child { border-bottom: 0; }
  .steps-5 { grid-template-columns: 1fr; }
  .product-meta-list div { grid-template-columns: 1fr; gap: 4px; }
  .hero-meta { gap: 10px 18px; font-size: 12.5px; }
  .hero-meta strong { font-size: 16px; }
}

/* ============================================================================
 * Video Stories — premium horizontal carousel (replaces the old reels grid)
 * ========================================================================== */
.video-stories {
  position: relative;
  padding: clamp(70px, 9vw, 130px) 0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(212,175,55,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(212,175,55,.06), transparent 65%),
    var(--ink, #050505);
  color: var(--cream, #f1ead8);
  overflow: hidden;
}
.video-stories .section-inner { position: relative; }

.video-stories-heading { max-width: 720px; margin: 0 auto clamp(28px, 4vw, 44px); text-align: center; }
.video-stories-heading .eyebrow { color: var(--gold, #d4af37); letter-spacing: .28em; text-transform: uppercase; font-size: 12px; margin: 0 0 14px; }
.video-stories-heading h1,
.video-stories-heading h2 { font-family: var(--head, "Cinzel", serif); font-weight: 700; line-height: 1.05; margin: 0 0 14px; font-size: clamp(30px, 4.4vw, 54px); }
.video-stories-subtitle { color: #c8bfa9; font-size: clamp(15px, 1.2vw, 17px); line-height: 1.6; margin: 0; }

.video-stories-shell {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}

.video-stories-track {
  display: flex;
  gap: 22px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 8px 4px 24px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(212,175,55,.35) transparent;
}
.video-stories-track::-webkit-scrollbar { height: 6px; }
.video-stories-track::-webkit-scrollbar-track { background: transparent; }
.video-stories-track::-webkit-scrollbar-thumb { background: rgba(212,175,55,.25); border-radius: 999px; }
.video-stories-track:focus-visible { outline: 2px solid var(--gold, #d4af37); outline-offset: 4px; border-radius: 14px; }

.video-card {
  flex: 0 0 auto;
  width: 280px;
  scroll-snap-align: start;
  transition: transform .35s ease, box-shadow .35s ease;
}
.video-card-frame {
  position: relative;
  aspect-ratio: 9 / 16;
  border-radius: 22px;
  overflow: hidden;
  background: #0b0b0b;
  border: 1px solid rgba(212,175,55,.28);
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,.85),
    0 0 0 1px rgba(212,175,55,.08) inset,
    0 0 30px -10px rgba(212,175,55,.18);
  isolation: isolate;
}
.video-card-media {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  background: #000;
  display: block;
}
.video-card-overlay {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 16px 16px 18px;
  background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.55) 55%, rgba(0,0,0,0) 100%);
  color: var(--cream, #f1ead8);
  pointer-events: none;
  z-index: 1;
}
.video-card-badge {
  display: inline-block;
  font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.55);
  color: var(--gold, #d4af37);
  background: rgba(0,0,0,.45);
  margin-bottom: 8px;
  font-weight: 600;
}
.video-card-title {
  font-family: var(--head, "Cinzel", serif);
  font-size: 17px; line-height: 1.2; margin: 0 0 4px;
  color: #fff;
}
.video-card-desc {
  margin: 0;
  font-size: 12.5px; line-height: 1.45; color: #c8bfa9;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.video-instagram-link {
  width: fit-content;
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 13px;
  padding: 0 13px;
  border: 1px solid rgba(245,230,184,.54);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(64,93,230,.92), rgba(193,53,132,.92) 48%, rgba(253,89,73,.92)),
    rgba(5,5,5,.62);
  color: #fff;
  box-shadow: 0 14px 34px rgba(193,53,132,.24);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .09em;
  pointer-events: auto;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.video-instagram-link:hover {
  transform: translateY(-2px);
  filter: saturate(1.08);
  box-shadow: 0 18px 42px rgba(193,53,132,.34);
}
.video-instagram-link:focus-visible {
  outline: 2px solid var(--cream);
  outline-offset: 3px;
}

@media (hover: hover) {
  .video-card:hover { transform: translateY(-4px); }
  .video-card:hover .video-card-frame {
    box-shadow:
      0 36px 70px -30px rgba(0,0,0,.9),
      0 0 0 1px rgba(212,175,55,.18) inset,
      0 0 50px -10px rgba(212,175,55,.32);
    border-color: rgba(212,175,55,.55);
  }
}

/* Arrow buttons */
.video-stories-arrow {
  flex: 0 0 auto;
  width: 44px; height: 44px;
  border-radius: 999px;
  background: rgba(15,12,8,.7);
  color: var(--gold, #d4af37);
  border: 1px solid rgba(212,175,55,.4);
  cursor: pointer;
  display: inline-flex;
  align-items: center; justify-content: center;
  transition: background .25s ease, border-color .25s ease, transform .2s ease, opacity .25s ease;
  backdrop-filter: blur(6px);
}
.video-stories-arrow svg { width: 20px; height: 20px; }
.video-stories-arrow:hover { background: rgba(212,175,55,.15); border-color: rgba(212,175,55,.7); }
.video-stories-arrow:active { transform: scale(.95); }
.video-stories-arrow[disabled] { opacity: .25; cursor: default; pointer-events: none; }
.video-stories-arrow:focus-visible { outline: 2px solid var(--gold, #d4af37); outline-offset: 3px; }

.video-stories-cta { text-align: center; margin-top: clamp(28px, 4vw, 44px); }

/* Tablet — 2 visible (~46% of inner width) */
@media (max-width: 1100px) {
  .video-stories-shell { grid-template-columns: 1fr; }
  .video-stories-arrow { display: none; }
  .video-card { width: clamp(240px, 44vw, 300px); }
}

/* Mobile — 1 mostly visible */
@media (max-width: 640px) {
  .video-stories-track { gap: 14px; padding: 6px 4px 20px; }
  .video-card { width: 78vw; max-width: 320px; }
  .video-card-frame { border-radius: 18px; }
  .video-card-overlay { padding: 12px 14px 14px; }
  .video-card-title { font-size: 15px; }
  .video-card-desc { font-size: 12px; }
}

/* ============================================================================
 * ZLYN — Mobile UX, Theme Toggle, Preloader, Order Flow, Product Redesign
 *
 * All additions are appended to the existing stylesheet so the desktop look
 * remains intact. Theme tokens are introduced as semantic CSS variables and
 * overridden inside [data-theme="light"]. Mobile-only optimisations live
 * inside @media (max-width: 640px).
 * ========================================================================== */

/* ----- Semantic theme tokens (default = dark luxury) --------------------- */
:root {
  --bg:         #050505;
  --bg-1:       #0a0a0a;
  --bg-2:       #111111;
  --surface-1:  rgba(255,255,255,.04);
  --surface-2:  rgba(255,255,255,.07);
  --text:       #ffffff;
  --text-soft:  #b5b1aa;
  --line-soft:  rgba(212,175,55,.22);
  --line-strong:rgba(212,175,55,.55);
  --gold-soft:  rgba(212,175,55,.12);
  --menu-icon:  #f7d66b;
  --menu-border: rgba(215,178,69,.45);
}

/* Smooth theme switch */
html { color-scheme: dark; }
html[data-theme="light"] { color-scheme: light; }
html, body, .site-header, .site-footer, .section-dark, .section-band,
.purchase, .video-card-frame, .button, .button-secondary {
  transition: background-color .35s ease, color .35s ease, border-color .35s ease;
}

/* ----- Light theme overrides --------------------------------------------- */
html[data-theme="light"] {
  --bg:         #faf6ec;
  --bg-1:       #ffffff;
  --bg-2:       #f3ecd8;
  --surface-1:  rgba(0,0,0,.04);
  --surface-2:  rgba(0,0,0,.07);
  --text:       #1c1610;
  --text-soft:  #5a5246;
  --line-soft:  rgba(167, 122, 24, 0.30);
  --line-strong:rgba(167, 122, 24, 0.65);
  --gold-soft:  rgba(167, 122, 24, 0.10);
  --menu-icon:  #17130b;
  --menu-border: rgba(184,137,32,.45);
}
html[data-theme="light"] body { background: var(--bg); color: var(--text); }
html[data-theme="light"] p { color: var(--text-soft); }
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4 { color: #14110c; }

/* Header / nav - premium cream-gold light mode */
html[data-theme="light"] .site-header {
  background: rgba(255,250,236,.92);
  border-bottom: 1px solid rgba(184,137,32,.28);
  backdrop-filter: blur(18px);
}
html[data-theme="light"] .site-header .nav-links a,
html[data-theme="light"] .site-header .icon-link { color: #17130b; }
html[data-theme="light"] .site-header .nav-links a:hover,
html[data-theme="light"] .site-header .icon-link:hover { color: #b88920; }
html[data-theme="light"] .site-header .nav-links a.active { color: #b88920; }
html[data-theme="light"] .site-header .nav-links a.active::after { background: #b88920; }
html[data-theme="light"] .menu-toggle span { background: #b88920; }
html[data-theme="light"] .brand-logo { filter: drop-shadow(0 0 12px rgba(184,137,32,.35)); }

/* Footer - premium cream-gold light mode */
html[data-theme="light"] .site-footer {
  background: linear-gradient(180deg, #fffaf0, #f7f0e0);
  color: #17130b;
  border-top-color: rgba(184,137,32,.28);
}
html[data-theme="light"] .site-footer h2,
html[data-theme="light"] .site-footer p,
html[data-theme="light"] .footer-brand p { color: #17130b; }
html[data-theme="light"] .site-footer a { color: #5f5749; }
html[data-theme="light"] .site-footer a:hover { color: #b88920; }
html[data-theme="light"] .footer-bottom { color: #5f5749; border-top-color: rgba(184,137,32,.20); }
html[data-theme="light"] .footer-bottom a { color: #b88920; }
html[data-theme="light"] .footer-trust-badges span {
  background: rgba(184,137,32,.08);
  border-color: rgba(184,137,32,.26);
  color: #17130b;
}
html[data-theme="light"] .footer-contact-link span { color: #b88920; }

/* Sections / cards - premium cream-gold light mode */
html[data-theme="light"] .section-dark {
  background:
    radial-gradient(circle at 76% 12%, rgba(184,137,32,.10), transparent 32%),
    linear-gradient(180deg, #fffaf0, #fff7e8 52%, #fffaf0);
  color: #17130b;
}
html[data-theme="light"] .section-band {
  background:
    radial-gradient(circle at 8% 80%, rgba(184,137,32,.08), transparent 30%),
    linear-gradient(180deg, #ffffff, #fffaf0);
  color: #17130b;
}
html[data-theme="light"] .video-stories {
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(184,137,32,.12), transparent 60%),
    linear-gradient(180deg, #fffaf0, #fff7e8);
  color: #17130b;
}
html[data-theme="light"] .video-stories-subtitle { color: #5f5749; }
html[data-theme="light"] .video-card-frame {
  background: #ffffff;
  border-color: rgba(184,137,32,.28);
}
html[data-theme="light"] .video-card-overlay {
  background: linear-gradient(to top, rgba(255,250,240,.96) 0%, rgba(255,250,240,.55) 55%, rgba(255,250,240,0) 100%);
  color: #17130b;
}
html[data-theme="light"] .video-card-title { color: #17130b; }
html[data-theme="light"] .video-card-desc { color: #5f5749; }
html[data-theme="light"] .video-card-badge { color: #b88920; border-color: rgba(184,137,32,.55); background: rgba(255,255,255,.65); }
html[data-theme="light"] .video-stories-arrow { color: #b88920; background: rgba(255,255,255,.75); border-color: rgba(184,137,32,.35); }
html[data-theme="light"] .video-stories-arrow:hover { background: rgba(184,137,32,.12); }

/* Buttons in light - premium dark/gold */
html[data-theme="light"] .button {
  background: #17130b;
  color: #fff8e7;
  border-color: #17130b;
}
html[data-theme="light"] .button:hover { background: #2a2118; }
html[data-theme="light"] .button-secondary {
  background: transparent;
  color: #b88920;
  border-color: rgba(184,137,32,.55);
}

/* Generic surfaces (cards, panels) inside sections — premium cream-gold */
html[data-theme="light"] details,
html[data-theme="light"] .accordion details,
html[data-theme="light"] .info-panels details {
  background: #ffffff;
  border: 1px solid rgba(184,137,32,.28);
  color: #17130b;
}
html[data-theme="light"] summary { color: #17130b; }
html[data-theme="light"] .badge { color: #b88920; background: rgba(184,137,32,.10); border-color: rgba(184,137,32,.45); }
html[data-theme="light"] .feature-list li,
html[data-theme="light"] .info-list li,
html[data-theme="light"] .product-meta-list dt,
html[data-theme="light"] .product-meta-list dd { color: #17130b; }
html[data-theme="light"] .breadcrumbs { color: #5f5749; }
html[data-theme="light"] .breadcrumbs a { color: #b88920; }

/* Theme toggle reflects current state */
html[data-theme="light"] .theme-toggle .label-dark { display: none; }
html[data-theme="light"] .theme-toggle .label-light { display: inline; }
.theme-toggle .label-light { display: none; }
.theme-toggle .label-dark { display: inline; }

/* ============================================================================
 * Light Mode Hero Fixes — maintain readability on image backgrounds
 * ========================================================================== */

/* Hero text colors in light mode - keep cream/white with shadows */
html[data-theme="light"] .hero,
html[data-theme="light"] .zlyn-hero,
html[data-theme="light"] .hero-section {
  color: #fff8e7;
}

html[data-theme="light"] .hero h1,
html[data-theme="light"] .zlyn-hero h1,
html[data-theme="light"] .hero-section h1 {
  color: #fff8e7 !important;
  text-shadow: 0 8px 30px rgba(0,0,0,.55);
}

html[data-theme="light"] .hero h2,
html[data-theme="light"] .zlyn-hero h2,
html[data-theme="light"] .hero-section h2 {
  color: #fff8e7 !important;
  text-shadow: 0 6px 24px rgba(0,0,0,.5);
}

html[data-theme="light"] .hero p,
html[data-theme="light"] .zlyn-hero p,
html[data-theme="light"] .hero-section p,
html[data-theme="light"] .hero li,
html[data-theme="light"] .hero-sub,
html[data-theme="light"] .hero-line {
  color: rgba(255,248,231,.88) !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5);
}

html[data-theme="light"] .hero-bullets li {
  color: rgba(255,248,231,.88) !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5);
}

html[data-theme="light"] .hero-meta,
html[data-theme="light"] .hero-meta strong {
  color: #fff8e7 !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5);
}

/* Hero overlay for light mode - stronger gradient */
html[data-theme="light"] .hero::before,
html[data-theme="light"] .zlyn-hero::before,
html[data-theme="light"] .hero-section::before {
  background:
    linear-gradient(90deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.55) 42%, rgba(255,250,240,.10) 100%),
    radial-gradient(circle at 76% 42%, rgba(212,168,74,.22), transparent 36%);
}

/* Product price card in hero - light mode */
html[data-theme="light"] .price-ticket,
html[data-theme="light"] .price-card,
html[data-theme="light"] .hero-price,
html[data-theme="light"] .product-price-card {
  background: rgba(20,14,8,.92) !important;
  color: #fff8e7 !important;
  border-color: rgba(212,168,74,.45) !important;
}

html[data-theme="light"] .price-ticket strong,
html[data-theme="light"] .price-ticket span {
  color: #fff8e7 !important;
}

/* Buttons in hero - light mode */
html[data-theme="light"] .hero .button {
  background: linear-gradient(132deg, #f7e7aa 0%, #d4af37 40%, #91640e 100%) !important;
  color: #090602 !important;
  border-color: rgba(245,230,184,.6) !important;
}

html[data-theme="light"] .hero .button-secondary {
  background: rgba(20,14,8,.85) !important;
  color: #fff8e7 !important;
  border-color: rgba(212,168,74,.55) !important;
}

html[data-theme="light"] .hero-actions .button,
html[data-theme="light"] .hero-actions .button-secondary {
  text-shadow: none;
}

/* Page hero - light mode fixes for image backgrounds */
html[data-theme="light"] .page-hero {
  color: #fff8e7;
}

html[data-theme="light"] .page-hero h1,
html[data-theme="light"] .page-hero h2 {
  color: #fff8e7 !important;
  text-shadow: 0 8px 30px rgba(0,0,0,.55);
}

html[data-theme="light"] .page-hero p {
  color: rgba(255,248,231,.88) !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5);
}

html[data-theme="light"] .page-hero::after {
  background: linear-gradient(90deg, rgba(0,0,0,.92), rgba(0,0,0,.72)), linear-gradient(0deg, var(--black), transparent 55%);
}

/* Video sections with image backgrounds - keep cream text in light mode */
html[data-theme="light"] .proof-card::after,
html[data-theme="light"] .reel::after {
  background: linear-gradient(transparent, rgba(0,0,0,.94));
}

html[data-theme="light"] .proof-content p,
html[data-theme="light"] .reel h3 {
  color: rgba(255,248,231,.92) !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5);
}

/* Media tag overlays */
html[data-theme="light"] .media-tag {
  background: rgba(20,14,8,.88) !important;
  color: #fff8e7 !important;
  border-color: rgba(212,168,74,.45) !important;
}

/* Compare badges */
html[data-theme="light"] .compare-badges span {
  background: rgba(20,14,8,.82) !important;
  color: #fff8e7 !important;
  border-color: rgba(212,168,74,.45) !important;
}


/* ============================================================================
 * Preloader — premium ZLYN intro
 * ========================================================================== */
#zlyn-preloader {
  position: fixed; inset: 0; z-index: 9999;
  display: grid; place-items: center;
  background: radial-gradient(ellipse at center, #0c0a08 0%, #050505 70%);
  color: #f5e6b8;
  text-align: center;
  transition: opacity .55s ease, visibility .55s ease;
}
#zlyn-preloader[hidden] { opacity: 0; visibility: hidden; pointer-events: none; }
.zlyn-preloader-inner { display: grid; gap: 18px; place-items: center; padding: 24px; }
.zlyn-preloader-logo {
  width: clamp(96px, 22vw, 140px);
  height: auto;
  filter: drop-shadow(0 4px 18px rgba(212,175,55,.35));
  animation: zlyn-pulse 2.4s ease-in-out infinite;
}
.zlyn-preloader-tag {
  font-family: "Cinzel", serif;
  letter-spacing: .42em;
  font-size: 12px;
  color: #d4af37;
  margin: 0;
  text-transform: uppercase;
}
.zlyn-preloader-bar {
  position: relative;
  width: clamp(160px, 36vw, 220px);
  height: 2px;
  background: rgba(212,175,55,.18);
  overflow: hidden;
  border-radius: 2px;
}
.zlyn-preloader-bar::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, #d4af37 40%, #f5e6b8 60%, transparent);
  animation: zlyn-loadline 1.4s ease-in-out infinite;
}
@keyframes zlyn-pulse { 0%, 100% { transform: scale(1); opacity: .9; } 50% { transform: scale(1.04); opacity: 1; } }
@keyframes zlyn-loadline { 0% { transform: translateX(-100%); } 50% { transform: translateX(0%); } 100% { transform: translateX(100%); } }
@media (prefers-reduced-motion: reduce) {
  .zlyn-preloader-logo, .zlyn-preloader-bar::after { animation: none; }
}


/* ============================================================================
 * Theme toggle button (lives inside .nav-actions and inside .drawer-actions)
 * ========================================================================== */
.theme-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  height: 36px; padding: 0 14px;
  border-radius: 999px;
  background: rgba(212,175,55,.08);
  color: var(--gold);
  border: 1px solid rgba(212,175,55,.45);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.theme-toggle:hover { background: rgba(212,175,55,.18); }
.theme-toggle svg { width: 14px; height: 14px; }
html[data-theme="light"] .theme-toggle {
  background: rgba(167,122,24,.10);
  color: #8a630f;
  border-color: rgba(167,122,24,.45);
}


/* ============================================================================
 * Premium mobile drawer (slide-in from right with glass + gold)
 * ========================================================================== */
.drawer-scrim {
  position: fixed; inset: 0; z-index: 90;
  background: rgba(0,0,0,.6);
  opacity: 0; visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
  backdrop-filter: blur(4px);
}
body.menu-open .drawer-scrim { opacity: 1; visibility: visible; }

.drawer-panel {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 91;
  width: min(86vw, 380px);
  height: 100dvh;
  max-height: 100dvh;
  overflow-y: auto;
  background:
    radial-gradient(600px 280px at 100% -10%, rgba(212,175,55,.18), transparent 60%),
    linear-gradient(180deg, #0b0a08, #050505);
  border-left: 1px solid rgba(212,175,55,.28);
  box-shadow: -30px 0 80px rgba(0,0,0,.65);
  transform: translateX(100%);
  transition: transform .42s cubic-bezier(.65,.05,.36,1);
  display: flex; flex-direction: column;
  padding: 18px 22px calc(24px + env(safe-area-inset-bottom));
  color: #f1ead8;
  -webkit-overflow-scrolling: touch;
}
body.menu-open .drawer-panel { transform: translateX(0); }

html[data-theme="light"] .drawer-panel {
  background:
    radial-gradient(600px 280px at 100% -10%, rgba(167,122,24,.16), transparent 60%),
    linear-gradient(180deg, #fffaee, #f3ecd8);
  border-left: 1px solid rgba(167,122,24,.30);
  color: #1c1610;
}

.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(212,175,55,.18);
  margin-bottom: 18px;
}
.drawer-head img { width: min(132px, 42vw); height: auto; object-fit: contain; }
.drawer-close {
  width: 38px; height: 38px;
  border-radius: 999px;
  background: rgba(212,175,55,.08);
  border: 1px solid rgba(212,175,55,.35);
  color: #d4af37;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .25s ease, background .25s ease;
}
.drawer-close:hover { background: rgba(212,175,55,.18); transform: rotate(90deg); }
.drawer-close svg { width: 16px; height: 16px; }

.drawer-links {
  display: flex; flex-direction: column;
  gap: 2px;
  margin: 0 -22px;
  padding: 4px 0;
}
.drawer-links a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 22px;
  color: inherit;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .04em;
  border-bottom: 1px solid rgba(212,175,55,.08);
  transition: background .2s ease, color .2s ease, padding-left .25s ease;
}
.drawer-links a:hover, .drawer-links a.active {
  background: rgba(212,175,55,.08);
  color: var(--gold);
  padding-left: 28px;
}
.drawer-links a::after {
  content: "›"; color: rgba(212,175,55,.6); font-size: 22px; line-height: 1; transform: translateY(-2px);
}

.drawer-actions {
  margin-top: auto;
  display: grid; gap: 10px;
  padding-top: 16px;
  border-top: 1px solid rgba(212,175,55,.18);
}
.drawer-actions .button { width: 100%; }
.drawer-actions .theme-toggle { justify-content: center; height: 40px; }

.drawer-footer {
  margin-top: 14px;
  font-size: 11px;
  color: rgba(212,175,55,.7);
  letter-spacing: .18em;
  text-transform: uppercase;
  text-align: center;
}
.drawer-footer span {
  display: block;
}
.drawer-footer span + span {
  margin-top: 4px;
  color: rgba(245,230,184,.72);
  font-size: 10px;
  letter-spacing: .12em;
}

/* Hide drawer panel/scrim when not on mobile so they never overlay desktop */
@media (min-width: 901px) {
  .drawer-scrim, .drawer-panel { display: none !important; }
}


/* ============================================================================
 * Order modal (premium frontend-ready order form)
 * ========================================================================== */
.order-modal {
  position: fixed; inset: 0; z-index: 95;
  display: grid; place-items: center;
  background: rgba(0,0,0,.72);
  opacity: 0; visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
  padding: 16px;
  backdrop-filter: blur(6px);
}
.order-modal.is-open { opacity: 1; visibility: visible; }
.order-modal-sheet {
  width: min(560px, 100%);
  max-height: 92vh;
  overflow-y: auto;
  background: linear-gradient(180deg, #0c0a08, #050505);
  border: 1px solid rgba(212,175,55,.35);
  border-radius: 18px;
  padding: clamp(18px, 3vw, 26px);
  color: #f1ead8;
  box-shadow: 0 30px 80px rgba(0,0,0,.7);
  transform: translateY(20px) scale(.98);
  transition: transform .35s cubic-bezier(.4,.0,.2,1);
}
.order-modal.is-open .order-modal-sheet { transform: translateY(0) scale(1); }
html[data-theme="light"] .order-modal-sheet {
  background: linear-gradient(180deg, #fffaee, #f3ecd8);
  border-color: rgba(167,122,24,.40);
  color: #1c1610;
}
.order-modal-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.order-modal-head h2 { font-size: clamp(22px, 4vw, 28px); margin: 0; }
.order-modal-head p { margin: 4px 0 0; font-size: 13px; }
.order-modal-close {
  flex: 0 0 auto;
  width: 36px; height: 36px;
  border-radius: 999px;
  background: rgba(212,175,55,.1);
  border: 1px solid rgba(212,175,55,.4);
  color: #d4af37;
  cursor: pointer;
}
.order-form {
  display: grid; gap: 12px;
  grid-template-columns: 1fr 1fr;
}
.order-form .field { display: flex; flex-direction: column; gap: 6px; }
.order-form .field.span-2 { grid-column: 1 / -1; }
.order-form label { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 700; }
.order-form input,
.order-form textarea,
.order-form select {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(212,175,55,.3);
  border-radius: 10px;
  padding: 12px 14px;
  color: inherit;
  font-size: 15px;
  outline: none;
  transition: border-color .2s ease, background .2s ease;
}
.order-form input:focus,
.order-form textarea:focus,
.order-form select:focus { border-color: var(--gold); background: rgba(212,175,55,.08); }
html[data-theme="light"] .order-form input,
html[data-theme="light"] .order-form textarea,
html[data-theme="light"] .order-form select {
  background: rgba(255,255,255,.7);
  border-color: rgba(167,122,24,.35);
}
.order-form textarea { min-height: 70px; resize: vertical; }

.order-summary {
  margin-top: 8px;
  padding: 14px 16px;
  border: 1px solid rgba(212,175,55,.3);
  border-radius: 12px;
  background: rgba(212,175,55,.06);
  display: grid; gap: 6px;
  font-size: 14px;
}
.order-summary .row { display: flex; justify-content: space-between; }
.order-summary .row.total { border-top: 1px dashed rgba(212,175,55,.4); padding-top: 8px; margin-top: 4px; font-size: 16px; font-weight: 800; color: var(--gold); }
html[data-theme="light"] .order-summary { background: rgba(167,122,24,.08); border-color: rgba(167,122,24,.35); }
html[data-theme="light"] .order-summary .row.total { color: #8a630f; }
.order-form-actions { grid-column: 1 / -1; display: grid; gap: 10px; margin-top: 6px; }
.order-form-actions .button { width: 100%; }
.order-form-message {
  grid-column: 1 / -1;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px dashed rgba(212,175,55,.4);
  background: rgba(212,175,55,.06);
  color: var(--gold);
  font-size: 13px;
  display: none;
}
.order-form-message.is-shown { display: block; }


/* ============================================================================
 * Product page redesign — mobile e-commerce flow
 * ========================================================================== */
.product-page-grid { gap: clamp(28px, 4vw, 56px); }

.product-gallery-main {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: #0a0a0a;
  border: 1px solid rgba(212,175,55,.22);
  aspect-ratio: 4 / 3;
}
.product-gallery-main img { width: 100%; height: 100%; object-fit: contain; padding: 16px; background: radial-gradient(circle at 50% 35%, rgba(212,175,55,.14), transparent 60%); }
html[data-theme="light"] .product-gallery-main { background: #fff8e6; border-color: rgba(167,122,24,.30); }
html[data-theme="light"] .product-gallery-main img { background: radial-gradient(circle at 50% 35%, rgba(167,122,24,.10), transparent 60%); }

.thumbs { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.thumb {
  width: 72px; height: 72px;
  padding: 0;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(212,175,55,.25);
  overflow: hidden;
  cursor: pointer;
  transition: border-color .2s ease, transform .2s ease;
}
.thumb img { width: 100%; height: 100%; object-fit: cover; }
.thumb.selected, .thumb:hover { border-color: var(--gold); transform: translateY(-2px); }

.purchase .price { font-family: var(--display); font-size: clamp(28px, 4vw, 38px); color: var(--gold); }

.purchase-actions { display: grid; gap: 10px; }
.purchase-actions .button { width: 100%; }

.product-info-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin: 14px 0 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px dashed rgba(212,175,55,.3);
  background: rgba(212,175,55,.04);
  font-size: 13px;
}
.product-info-row strong { color: var(--gold); display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .14em; margin-bottom: 2px; }
html[data-theme="light"] .product-info-row { background: rgba(167,122,24,.06); border-color: rgba(167,122,24,.30); }
html[data-theme="light"] .product-info-row strong { color: #8a630f; }

.product-share-row {
  display: flex; gap: 10px; flex-wrap: wrap; margin-top: 10px;
}
.product-share-row .icon-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 38px; padding: 0 14px;
  font-size: 12px;
  border-radius: 999px;
  background: rgba(212,175,55,.08);
  border: 1px solid rgba(212,175,55,.35);
  color: var(--gold);
  cursor: pointer;
}
.product-share-row .icon-btn:hover { background: rgba(212,175,55,.18); }
.product-share-row .icon-btn svg { width: 14px; height: 14px; }


/* ============================================================================
 * MOBILE OPTIMISATIONS — only at <= 640px (do NOT touch desktop)
 * ========================================================================== */
@media (max-width: 640px) {
  /* Tighter section padding on mobile */
  .section-dark, .section-band, .video-stories { padding: 48px 0 !important; }
  .section-heading { margin-bottom: 22px; }
  .section-heading p { font-size: 14px; }

  /* Smaller hero/heading sizes */
  h1 { font-size: clamp(32px, 9vw, 44px) !important; }
  h2 { font-size: clamp(26px, 7vw, 34px) !important; }
  h3 { font-size: 16px; }
  .eyebrow { font-size: 10px; letter-spacing: .22em; }

  /* Tighten paragraphs and lists */
  p { margin: 10px 0; font-size: 14.5px; line-height: 1.55; }

  /* Section inner uses tighter side padding */
  .section-inner { width: calc(100% - 24px); }

  /* Product page stacks naturally and gallery sits at top */
  .product-page-grid { grid-template-columns: 1fr !important; }
  .product-page-grid,
  .product-gallery,
  .product-gallery-main,
  .purchase {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
  .product-gallery-main { aspect-ratio: 1 / 1; border-radius: 14px; }
  .thumb { width: 60px; height: 60px; }
  .purchase-title { font-size: 22px !important; }

  /* Mobile drawer hides desktop nav-links and inline nav-actions */
  .nav-links { display: none; }
  .nav-actions { display: none !important; }
  .nav-actions .theme-toggle { display: inline-flex !important; }
  .menu-toggle { display: inline-flex; }

  /* Compact footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 22px; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }

  /* Order modal full-bleed on small phones */
  .order-modal { padding: 0; }
  .order-modal-sheet { border-radius: 16px 16px 0 0; max-height: 96vh; align-self: end; }

  /* Order form single column */
  .order-form { grid-template-columns: 1fr; }

  /* Reels / video card mobile sizing already handled */

  /* Reduce-margin for "split" feature blocks */
  .split { gap: 24px !important; }
  .feature-list li { font-size: 13.5px; }

  /* Don't allow horizontal scroll on body */
  body { overflow-x: hidden; }
}

/* Tablet */
@media (min-width: 641px) and (max-width: 900px) {
  .product-page-grid { grid-template-columns: 1fr !important; }
  .nav-links { display: none; }
  .nav-actions { display: none !important; }
  .menu-toggle { display: inline-flex; }
}

/* Larger phones / small tablets keep 2-column footer */
@media (min-width: 481px) and (max-width: 900px) {
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Hide menu toggle on desktop */
@media (min-width: 901px) {
  .menu-toggle { display: none; }
}

/* ============================================================================
 * ZLYN — Mobile Fix Pass (compact homepage, horizontal swipe sections,
 * drawer cut fix, mobile theme toggle visibility)
 *
 * Targets the REAL class names found in script.js:
 *   - Problem      → .cards-3 / .lux-card
 *   - Ingredients  → .ingredients-grid / .ingredient-card / .ingredient-mark
 *   - How To Use   → .steps.steps-5 / .step
 *   - Reviews      → .reviews-grid / .review
 *   - Trust strip  → .trust-grid / .trust-cell
 *
 * All overrides scoped under @media (max-width: 768px) so desktop is intact.
 * ========================================================================== */
@media (max-width: 768px) {

  /* ----- Compact section padding ---------------------------------------- */
  .section-dark, .section-band, .video-stories,
  .trust-strip, .page-hero {
    padding-block: 38px !important;
  }
  .section-heading { margin-bottom: 20px !important; }
  .eyebrow { font-size: 11px !important; letter-spacing: .18em !important; margin: 0 0 10px !important; }
  h1 { font-size: clamp(32px, 9vw, 42px) !important; line-height: 1.05 !important; }
  h2 { font-size: clamp(25px, 7vw, 31px) !important; line-height: 1.1 !important; margin-bottom: 8px !important; }
  h3 { font-size: 15px !important; }
  p  { font-size: 15px !important; line-height: 1.5 !important; }
  .section-heading p { font-size: 14px !important; }

  /* ----- Show theme toggle in mobile header (hide other actions) -------- */
  .nav-actions { display: inline-flex !important; gap: 6px !important; align-items: center; }
  .nav-actions .icon-link,
  .nav-actions .button-small,
  .nav-actions a.button { display: none !important; }
  .nav-actions .theme-toggle {
    display: inline-flex !important;
    height: 32px !important;
    padding: 0 10px !important;
    font-size: 10.5px !important;
    letter-spacing: .12em !important;
    gap: 5px !important;
  }
  .nav-actions .theme-toggle svg { width: 12px !important; height: 12px !important; }

  /* ----- Drawer: dynamic viewport height + safe-area + scroll guard ----- */
  .drawer-panel {
    height: 100dvh !important;
    max-height: 100dvh !important;
    overflow-y: auto;
    padding-bottom: calc(24px + env(safe-area-inset-bottom)) !important;
    -webkit-overflow-scrolling: touch;
  }
  .drawer-panel .drawer-actions { padding-bottom: env(safe-area-inset-bottom); }

  /* ============================================================
   * Horizontal swipe carousels — Problem / Ingredients / Steps / Reviews / Trust
   * ============================================================ */
  .cards-3,
  .why-grid,
  .ingredients-grid,
  .steps.steps-5,
  .steps,
  .reviews-grid {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    scroll-snap-type: x mandatory !important;
    gap: 14px !important;
    padding: 4px 20px 14px !important;
    margin-left: -20px !important;
    margin-right: -20px !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cards-3::-webkit-scrollbar,
  .why-grid::-webkit-scrollbar,
  .ingredients-grid::-webkit-scrollbar,
  .steps::-webkit-scrollbar,
  .reviews-grid::-webkit-scrollbar,
  .trust-grid::-webkit-scrollbar { display: none !important; }

  .lux-card,
  .why-chip,
  .ingredient-card,
  .step,
  .review {
    flex: 0 0 78vw !important;
    width: 78vw !important;
    min-width: 78vw !important;
    max-width: 78vw !important;
    min-height: auto !important;
    padding: 20px !important;
    scroll-snap-align: start !important;
    margin: 0 !important;
  }

  .founder-grid {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
  .founder-story { padding-block: 44px !important; }
  .founder-visual,
  .founder-visual img {
    min-height: 300px !important;
  }
  .footer-trust-badges {
    gap: 8px !important;
  }
  .footer-trust-badges span {
    flex: 1 1 calc(50% - 8px);
    text-align: center;
  }

  /* Trust strip special - smaller cards */
  .trust-cell {
    flex: 0 0 46vw !important;
    width: 46vw !important;
    min-width: 46vw !important;
    max-width: 46vw !important;
    padding: 14px !important;
    scroll-snap-align: start !important;
    margin: 0 !important;
  }

  /* Step cards keep a slight min-height so 3-line copy fits cleanly */
  .step { min-height: 200px !important; }
  .step span { font-size: 22px !important; }
  .step strong { font-size: 15px !important; }
  .step p { font-size: 13.5px !important; }

  /* Ingredient mark (golden disc) — smaller on mobile */
  .ingredient-mark {
    width: 36px !important;
    height: 36px !important;
    margin-bottom: 10px !important;
  }
  .ingredient-card h3 { font-size: 16px !important; margin-bottom: 6px !important; }
  .ingredient-card p { font-size: 13.5px !important; }

  /* Problem cards */
  .lux-card .card-number { font-size: 22px !important; margin-bottom: 6px !important; }
  .lux-card h3 { font-size: 16px !important; }
  .lux-card p { font-size: 13.5px !important; }

  /* Review cards */
  .review { min-height: 240px !important; }
  .review .stars { font-size: 14px !important; letter-spacing: .12em; }
  .review blockquote { font-size: 14.5px !important; line-height: 1.5 !important; margin: 8px 0 12px !important; }
  .review figcaption { font-size: 12px !important; }

  /* Subtle "swipe more" gradient on the right edge of each scroller */
  .cards-3, .ingredients-grid, .steps, .reviews-grid {
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 22px), transparent 100%);
            mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 22px), transparent 100%);
  }

  /* ----- Trust strip: 2-column compact chips ---------------------------- */
  .trust-strip { padding-block: 22px !important; }
  .trust-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    width: min(var(--max), calc(100% - 24px)) !important;
    max-width: calc(100% - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
    overflow: visible !important;
    scroll-snap-type: none !important;
  }
  .trust-cell {
    flex: initial !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 12px 14px !important;
    border-radius: 10px;
    background: rgba(212,175,55,.06);
    border: 1px solid rgba(212,175,55,.22);
    min-height: 0 !important;
    text-align: left !important;
  }
  .trust-cell strong {
    font-size: 11.5px !important;
    letter-spacing: .08em !important;
    text-transform: uppercase;
    color: var(--gold);
    display: block;
    margin-bottom: 2px;
  }
  .trust-cell span { font-size: 12.5px !important; line-height: 1.35 !important; }

  /* ----- Product page: image must show without awkward crop ------------- */
  .product-gallery-main img { object-fit: contain !important; padding: 14px !important; }

  /* ----- Product page mobile e-commerce style --------------------------- */
  .purchase-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }
  .purchase-actions .button {
    width: 100% !important;
    min-height: 48px !important;
  }
  .info-panels details {
    margin-bottom: 8px !important;
  }
  .info-panels details summary {
    padding: 14px 16px !important;
    font-size: 14px !important;
  }
  .info-panels details p,
  .info-panels details li {
    font-size: 13px !important;
    padding: 0 16px 14px !important;
  }

  /* Lifestyle / customer images keep cover */
  .customer-frame img,
  .media-frame img,
  .hero-visual img { object-fit: cover; }

  /* Tighter purchase block spacing */
  .purchase-title { font-size: 22px !important; line-height: 1.18 !important; }
  .purchase .price { font-size: 26px !important; }
  .purchase .subcopy { font-size: 14px !important; }
  .purchase .product-meta-list { gap: 6px !important; }
  .info-panels details summary { font-size: 14.5px !important; padding: 12px 14px !important; }
  .info-panels details p,
  .info-panels details li { font-size: 13.5px !important; }

  /* Sticky bottom buy-bar when on product page (always visible) */
  .product-page-grid + .product-mobile-buybar,
  .product-mobile-buybar { display: flex !important; }
  .product-mobile-buybar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    display: none;
    gap: 8px; padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
    background: rgba(8,7,6,.92);
    border-top: 1px solid rgba(212,175,55,.3);
    backdrop-filter: blur(10px);
  }
  .product-mobile-buybar .button { flex: 1; min-height: 46px; padding: 0 14px; font-size: 13px; }

  /* Light-theme variant of the buy-bar */
}

/* Light-theme buy-bar (outside the media query because it's still mobile-only,
   but the variable lookup happens at runtime) */
@media (max-width: 768px) {
  html[data-theme="light"] .product-mobile-buybar {
    background: rgba(255,250,236,.95);
    border-top-color: rgba(167,122,24,.3);
  }
  html[data-theme="light"] .trust-cell {
    background: rgba(167,122,24,.08);
    border-color: rgba(167,122,24,.30);
  }
  html[data-theme="light"] .trust-cell strong { color: #8a630f; }
}

/* Slightly larger phones (>=480px) keep 1.4 cards visible */
@media (min-width: 480px) and (max-width: 768px) {
  .lux-card, .ingredient-card, .step, .review {
    flex-basis: 62vw !important;
    width: 62vw !important;
    min-width: 62vw !important;
    max-width: 62vw !important;
  }
}

@media (min-width: 769px) {
  html[data-theme="light"] body {
    background: #fff8ee;
    color: #17130b;
  }

  html[data-theme="light"] p,
  html[data-theme="light"] .section-heading p {
    color: rgba(23, 19, 11, .72);
  }

  html[data-theme="light"] h1,
  html[data-theme="light"] h2,
  html[data-theme="light"] h3,
  html[data-theme="light"] h4 {
    color: #17130b;
  }

  html[data-theme="light"] .site-header {
    background: rgba(255, 248, 238, .94);
    border-bottom-color: rgba(200, 154, 43, .26);
  }

  html[data-theme="light"] .section-dark,
  html[data-theme="light"] .section-band,
  html[data-theme="light"] .video-stories {
    background: #fff8ee;
    color: #17130b;
  }

  html[data-theme="light"] .lux-card,
  html[data-theme="light"] .ingredient-card,
  html[data-theme="light"] .step,
  html[data-theme="light"] .review,
  html[data-theme="light"] .trust-cell,
  html[data-theme="light"] details,
  html[data-theme="light"] .purchase,
  html[data-theme="light"] .product-info-row,
  html[data-theme="light"] .media-frame,
  html[data-theme="light"] .video-card-frame {
    background: #fff;
    border-color: rgba(200, 154, 43, .24);
    color: #17130b;
  }

  html[data-theme="light"] .eyebrow,
  html[data-theme="light"] .lux-card .card-number,
  html[data-theme="light"] .ingredient-mark,
  html[data-theme="light"] .trust-cell strong,
  html[data-theme="light"] .nav-links a.active,
  html[data-theme="light"] .nav-links a:hover,
  html[data-theme="light"] .icon-link:hover {
    color: #c89a2b;
  }

  html[data-theme="light"] .nav-links a.active::after {
    background: #c89a2b;
  }

  .site-header {
    height: 84px;
  }

  .site-header .header-inner {
    width: min(var(--max), calc(100% - 40px));
    height: 84px;
    grid-template-columns: minmax(96px, 148px) minmax(420px, 1fr) auto auto;
    gap: 18px;
  }

  .site-header .site-logo {
    width: clamp(96px, 10vw, 148px);
    max-width: 148px;
    height: 62px;
  }

  .site-header .brand-logo {
    max-width: 148px;
    max-height: 62px;
  }

  .site-header .desktop-nav {
    justify-self: center;
    gap: clamp(14px, 1.5vw, 24px);
  }

  .site-header .theme-toggle {
    justify-self: end;
    margin-left: clamp(8px, 1vw, 16px);
  }

  .site-header .nav-actions {
    gap: 12px;
  }

  .theme-toggle .theme-toggle-icon,
  .theme-toggle .theme-toggle-mobile-text {
    display: none;
  }

  .site-header .theme-toggle {
    width: 158px;
    height: 40px;
    padding: 3px;
    border-radius: 999px;
    border: 1px solid rgba(212, 175, 55, .62);
    background: rgba(8, 7, 5, .58);
    color: #f7d66b;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.035), 0 14px 34px rgba(0,0,0,.22);
    letter-spacing: 0;
    text-transform: none;
  }

  .theme-switch {
    position: relative;
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    overflow: hidden;
  }

  .theme-switch-thumb {
    position: absolute;
    inset: 3px auto 3px 3px;
    width: calc(50% - 3px);
    border-radius: 999px;
    background: linear-gradient(135deg, #f8e8ad, #c89a2b);
    box-shadow: 0 8px 18px rgba(0,0,0,.28);
    transition: transform .32s ease;
  }

  .theme-switch-option {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: rgba(255, 248, 226, .72);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .02em;
    transition: color .28s ease;
  }

  html[data-theme="light"] .site-header .theme-toggle {
    background: rgba(255,255,255,.74);
    border-color: rgba(200, 154, 43, .66);
    color: #17130b;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.45), 0 12px 28px rgba(200,154,43,.12);
  }

  html[data-theme="dark"] .theme-switch-thumb {
    transform: translateX(calc(100% + 0px));
  }

  html[data-theme="light"] .theme-switch-day,
  html[data-theme="dark"] .theme-switch-night {
    color: #17130b;
  }

  html[data-theme="light"] .theme-switch-night {
    color: rgba(23, 19, 11, .56);
  }

  .hero {
    min-height: calc(100svh - 84px);
    padding: clamp(24px, 3.8vw, 46px) 0 clamp(58px, 7vw, 84px);
  }

  .hero-grid {
    grid-template-columns: minmax(0, .98fr) minmax(430px, .92fr);
    gap: clamp(42px, 5vw, 92px);
  }

  .hero-stage {
    min-height: 560px;
  }

  .product-orbit {
    width: min(585px, 98%);
  }

  .hero-jar {
    width: min(650px, 96%);
  }

  .price-ticket {
    right: clamp(8px, 2vw, 34px);
    bottom: 4%;
  }

  html[data-theme="light"] .hero {
    background: #050505;
    color: #fff8e7;
  }

  html[data-theme="light"] .hero::before {
    background:
      radial-gradient(circle at 76% 48%, rgba(200,154,43,.24), transparent 28%),
      linear-gradient(90deg, rgba(5,5,5,.98), rgba(5,5,5,.78) 43%, rgba(5,5,5,.36) 74%, rgba(5,5,5,.86)),
      linear-gradient(180deg, transparent 54%, #050505);
  }

  html[data-theme="light"] .hero h1,
  html[data-theme="light"] .hero h2,
  html[data-theme="light"] .hero h3,
  html[data-theme="light"] .hero p,
  html[data-theme="light"] .hero li,
  html[data-theme="light"] .hero-sub,
  html[data-theme="light"] .hero-line,
  html[data-theme="light"] .hero-meta,
  html[data-theme="light"] .hero-meta strong {
    color: #fff8e7 !important;
  }

  html[data-theme="light"] .price-ticket {
    background: rgba(12, 9, 5, .9) !important;
    border-color: rgba(200, 154, 43, .48) !important;
  }

  html[data-theme="light"] .price-ticket strong {
    color: #c89a2b !important;
  }

  html[data-theme="light"] .price-ticket span {
    color: rgba(255, 248, 231, .78) !important;
  }
}

@media (min-width: 769px) and (max-width: 1100px) {
  .site-header .header-inner {
    grid-template-columns: 76px minmax(380px, 1fr) auto auto;
    gap: 12px;
  }

  .site-header .site-logo {
    width: 68px;
  }

  .site-header .desktop-nav {
    gap: 13px;
  }

  .nav-links a,
  .icon-link {
    font-size: 11.5px;
  }

  .site-header .theme-toggle {
    width: 144px;
  }

  .button-small {
    padding-inline: 15px;
  }

  .hero-grid {
    grid-template-columns: minmax(0, .95fr) minmax(360px, .88fr);
    gap: 36px;
  }

  .hero-stage {
    min-height: 500px;
  }

  .hero-jar {
    width: min(455px, 94%);
  }

  .product-orbit {
    width: min(520px, 98%);
  }
}

/* ============================================================================
 * Universal responsive header reset
 * Desktop and mobile behavior are intentionally split at 769px.
 * ========================================================================== */
@media (min-width: 769px) {
  .site-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 9999 !important;
    height: 88px !important;
    min-height: 88px !important;
    background: rgba(5, 5, 5, .86) !important;
    border-bottom: 1px solid rgba(212, 175, 55, .16) !important;
    backdrop-filter: blur(22px) !important;
  }

  [data-theme="light"] .site-header {
    background: rgba(255, 248, 238, .94) !important;
    border-bottom-color: rgba(200, 154, 43, .26) !important;
  }

  .site-header .header-inner {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(118px, 178px) 1fr auto auto !important;
    align-items: center !important;
    height: 88px !important;
    min-height: 88px !important;
    padding: 0 48px !important;
    gap: 14px !important;
    box-sizing: border-box !important;
  }

  .site-logo {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-self: start !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    width: clamp(118px, 12vw, 178px) !important;
    max-width: 178px !important;
    height: 78px !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .site-logo img,
  .brand-logo {
    display: block !important;
    width: auto !important;
    max-width: 178px !important;
    max-height: 78px !important;
    object-fit: contain !important;
  }

  .desktop-nav,
  .nav-links {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: flex !important;
    justify-self: center !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(14px, 1.45vw, 24px) !important;
  }

  .theme-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: center !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    display: inline-flex !important;
    width: 158px !important;
    height: 40px !important;
    padding: 3px !important;
    margin: 0 !important;
    border-radius: 999px !important;
    border: 1px solid rgba(212, 175, 55, .62) !important;
    background: rgba(8, 7, 5, .58) !important;
    color: #f7d66b !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.035), 0 14px 34px rgba(0,0,0,.22) !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
  }

  [data-theme="light"] .theme-toggle {
    background: rgba(255,255,255,.74) !important;
    border-color: rgba(200, 154, 43, .66) !important;
    color: #17130b !important;
  }

  .theme-toggle-icon,
  .theme-toggle-mobile-text {
    display: none !important;
  }

  .theme-switch {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    align-items: center !important;
    width: 100% !important;
    height: 100% !important;
    border-radius: inherit !important;
    overflow: hidden !important;
  }

  .theme-switch-thumb {
    position: absolute !important;
    inset: 3px auto 3px 3px !important;
    width: calc(50% - 3px) !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #f8e8ad, #c89a2b) !important;
    box-shadow: 0 8px 18px rgba(0,0,0,.28) !important;
    transition: transform .32s ease !important;
  }

  [data-theme="dark"] .theme-switch-thumb {
    transform: translateX(100%) !important;
  }

  .theme-switch-option {
    position: relative !important;
    z-index: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
    font-size: 0 !important;
    font-weight: 900 !important;
    letter-spacing: .02em !important;
    color: rgba(255, 248, 226, .72) !important;
  }

  .theme-switch-day::before,
  .theme-switch-night::before {
    font-size: 11px !important;
  }

  .theme-switch-day::before {
    content: "\2600  Day";
  }

  .theme-switch-night::before {
    content: "\263E  Night";
  }

  [data-theme="light"] .theme-switch-day,
  [data-theme="dark"] .theme-switch-night {
    color: #17130b !important;
  }

  [data-theme="light"] .theme-switch-night {
    color: rgba(23, 19, 11, .56) !important;
  }

  .header-actions,
  .nav-actions {
    grid-column: 4 !important;
    grid-row: 1 !important;
    display: flex !important;
    justify-self: end !important;
    align-items: center !important;
    gap: 14px !important;
  }

  .header-whatsapp,
  .header-shop,
  .header-actions .icon-link,
  .header-actions .button-small,
  .header-actions a.button {
    display: inline-flex !important;
  }

  .mobile-menu-toggle,
  .menu-toggle {
    display: none !important;
  }
}

@media (max-width: 768px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  .site-header {
    height: 82px !important;
    min-height: 82px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 9999 !important;
    background: rgba(4, 3, 2, 0.96) !important;
    border-bottom: 1px solid rgba(215, 178, 69, 0.22) !important;
  }

  [data-theme="light"] .site-header {
    background: rgba(255, 250, 240, 0.96) !important;
    border-bottom: 1px solid rgba(184, 137, 32, 0.22) !important;
  }

  .site-header .header-inner {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(112px, 124px) minmax(0, 1fr) 48px !important;
    align-items: center !important;
    height: 82px !important;
    min-height: 82px !important;
    padding: 8px 16px !important;
    column-gap: 10px !important;
    box-sizing: border-box !important;
  }

  .site-logo {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-self: start !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    width: 122px !important;
    max-width: 122px !important;
    height: 72px !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .site-logo img,
  .brand-logo {
    display: block !important;
    width: auto !important;
    max-width: 122px !important;
    max-height: 72px !important;
    object-fit: contain !important;
  }

  .theme-toggle {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: center !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 !important;
    width: auto !important;
    max-width: 146px !important;
    height: 38px !important;
    padding: 0 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    font-size: 11px !important;
    line-height: 1 !important;
    letter-spacing: .13em !important;
    text-transform: uppercase !important;
    border: 1px solid rgba(215, 178, 69, .45) !important;
    color: #f6d76b !important;
    background: rgba(0,0,0,.18) !important;
  }

  .theme-toggle-icon {
    display: inline-flex !important;
  }

  .theme-toggle-mobile-text.label-dark {
    display: inline-flex !important;
  }

  .theme-toggle-mobile-text.label-light {
    display: none !important;
  }

  [data-theme="light"] .theme-toggle-mobile-text.label-dark {
    display: none !important;
  }

  [data-theme="light"] .theme-toggle-mobile-text.label-light {
    display: inline-flex !important;
  }

  .theme-switch {
    display: none !important;
  }

  [data-theme="light"] .theme-toggle {
    color: #17130b !important;
    border-color: rgba(184, 137, 32, .45) !important;
    background: rgba(255,255,255,.65) !important;
  }

  .mobile-menu-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: center !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    border-radius: 0 !important;
    border: 1px solid rgba(215,178,69,.45) !important;
    background: transparent !important;
  }

  .mobile-menu-toggle span {
    display: block !important;
    width: 20px !important;
    height: 2px !important;
    border-radius: 99px !important;
    background: #f6d76b !important;
    margin: 0 !important;
  }

  [data-theme="light"] .mobile-menu-toggle {
    border-color: rgba(184,137,32,.45) !important;
  }

  [data-theme="light"] .mobile-menu-toggle span {
    background: #17130b !important;
  }

  .desktop-nav,
  .nav-links,
  .header-actions,
  .nav-actions,
  .header-whatsapp,
  .header-shop,
  .desktop-only {
    display: none !important;
  }

  .site-header + *,
  main {
    margin-top: 0 !important;
  }

  body.menu-open .site-header {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .hero-stage {
    min-height: clamp(465px, 68vw, 540px) !important;
    align-items: start !important;
    justify-items: center !important;
    padding-top: 24px !important;
    box-sizing: border-box !important;
  }

  .hero-stage .product-orbit {
    top: 4px !important;
    bottom: auto !important;
  }

  .hero-stage .price-ticket {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
  }

  .compare-view {
    height: min(78vh, 460px) !important;
    min-height: 360px !important;
  }

  .compare-badges {
    inset: auto 12px 12px !important;
  }

  .compare-badges span {
    padding: 7px 9px !important;
    font-size: 10px !important;
  }

  .compare-range {
    display: block !important;
    margin-top: 14px !important;
  }

  .compare-handle {
    display: block !important;
  }
}

@media (max-width: 340px) {
  .cards-3,
  .ingredients-grid,
  .steps.steps-5,
  .steps,
  .reviews-grid {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-inline: 0 !important;
    width: 100% !important;
  }

  .lux-card,
  .ingredient-card,
  .step,
  .review {
    flex-basis: 84vw !important;
    min-width: 84vw !important;
    max-width: 84vw !important;
  }
}

/* ============================================================================
 * Light mode readability pass
 * Keeps image-overlay/hero areas dramatic, fixes normal cards and text surfaces.
 * ========================================================================== */
html[data-theme="light"] {
  --bg: #fff8ee;
  --surface: #ffffff;
  --line: rgba(200, 154, 43, .24);
  --muted: rgba(23, 19, 11, .68);
  --cream: #17130b;
  --gold: #c89a2b;
}

html[data-theme="light"] body {
  background: #fff8ee !important;
  color: #17130b !important;
}

html[data-theme="light"] .section-dark,
html[data-theme="light"] .section-band,
html[data-theme="light"] .trust-strip {
  background:
    radial-gradient(circle at 84% 8%, rgba(200,154,43,.08), transparent 28%),
    #fff8ee !important;
  color: #17130b !important;
}

html[data-theme="light"] .video-stories {
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(200,154,43,.12), transparent 60%),
    #fff8ee !important;
  color: #17130b !important;
}

html[data-theme="light"] .section-heading h1,
html[data-theme="light"] .section-heading h2,
html[data-theme="light"] .section-heading h3,
html[data-theme="light"] .split h2,
html[data-theme="light"] .product-copy h2,
html[data-theme="light"] .faq-layout h2,
html[data-theme="light"] .conversion h2,
html[data-theme="light"] .launch-offer > strong,
html[data-theme="light"] .conversion-trust-card strong,
html[data-theme="light"] .review h3,
html[data-theme="light"] .lux-card h3,
html[data-theme="light"] .ingredient-card h3,
html[data-theme="light"] .step strong,
html[data-theme="light"] .mission-card h3,
html[data-theme="light"] summary {
  color: #17130b !important;
  text-shadow: none !important;
}

html[data-theme="light"] .section-heading p,
html[data-theme="light"] .split p,
html[data-theme="light"] .lux-card p,
html[data-theme="light"] .ingredient-card p,
html[data-theme="light"] .step p,
html[data-theme="light"] .review blockquote,
html[data-theme="light"] .review figcaption span,
html[data-theme="light"] .launch-offer li,
html[data-theme="light"] .compare-price,
html[data-theme="light"] .mission-card p,
html[data-theme="light"] details p,
html[data-theme="light"] .product-copy p,
html[data-theme="light"] .video-stories-subtitle,
html[data-theme="light"] .disclaimer,
html[data-theme="light"] .stat-line span,
html[data-theme="light"] .trust-cell span,
html[data-theme="light"] .founder-copy p {
  color: rgba(23, 19, 11, .72) !important;
  text-shadow: none !important;
}

html[data-theme="light"] .eyebrow,
html[data-theme="light"] .stars,
html[data-theme="light"] .lux-card .card-number,
html[data-theme="light"] .ingredient-mark,
html[data-theme="light"] .step span,
html[data-theme="light"] .review figcaption,
html[data-theme="light"] .trust-cell strong,
html[data-theme="light"] .launch-price,
html[data-theme="light"] .sale-price,
html[data-theme="light"] .discount-label,
html[data-theme="light"] .launch-offer li::before,
html[data-theme="light"] .conversion-trust-card span,
html[data-theme="light"] .mission-card span,
html[data-theme="light"] .why-chip span,
html[data-theme="light"] .founder-copy blockquote,
html[data-theme="light"] .founder-signature span {
  color: #c89a2b !important;
}

html[data-theme="light"] .stat-line,
html[data-theme="light"] .lux-card,
html[data-theme="light"] .ingredient-card,
html[data-theme="light"] .step,
html[data-theme="light"] .review,
html[data-theme="light"] .mission-card,
html[data-theme="light"] details,
html[data-theme="light"] .contact-tile,
html[data-theme="light"] .contact-form,
html[data-theme="light"] .purchase,
html[data-theme="light"] .product-info-row,
html[data-theme="light"] .trust-cell,
html[data-theme="light"] .why-chip,
html[data-theme="light"] .real-result-card,
html[data-theme="light"] .launch-offer,
html[data-theme="light"] .conversion-trust-card,
html[data-theme="light"] .founder-visual {
  background: #ffffff !important;
  border-color: rgba(200, 154, 43, .24) !important;
  color: #17130b !important;
  box-shadow: 0 18px 44px rgba(38, 26, 8, .05) !important;
}

html[data-theme="light"] .lux-card:hover,
html[data-theme="light"] .ingredient-card:hover {
  background: #fffdfa !important;
  border-color: rgba(200, 154, 43, .48) !important;
}

html[data-theme="light"] .media-frame,
html[data-theme="light"] .visual-wide,
html[data-theme="light"] .compare-view,
html[data-theme="light"] .product-stage,
html[data-theme="light"] .product-gallery-main,
html[data-theme="light"] .gallery-tile,
html[data-theme="light"] .video-card-frame {
  background: #ffffff !important;
  border-color: rgba(200, 154, 43, .26) !important;
}

html[data-theme="light"] .conversion-trust,
html[data-theme="light"] .real-transformation {
  background: #fff8ee !important;
  border-color: rgba(200,154,43,.20) !important;
}

html[data-theme="light"] .real-result-card span {
  background: rgba(5,5,5,.84) !important;
  color: #fff8e7 !important;
  border-color: rgba(200,154,43,.52) !important;
}

html[data-theme="light"] .field label,
html[data-theme="light"] .quantity label,
html[data-theme="light"] .purchase .subcopy,
html[data-theme="light"] .product-meta-list dt,
html[data-theme="light"] .product-meta-list dd {
  color: #17130b !important;
}

html[data-theme="light"] .field input,
html[data-theme="light"] .field textarea,
html[data-theme="light"] .field select,
html[data-theme="light"] .stepper,
html[data-theme="light"] .stepper button,
html[data-theme="light"] .stepper input {
  background: #ffffff !important;
  color: #17130b !important;
  border-color: rgba(200, 154, 43, .26) !important;
}

html[data-theme="light"] .button-secondary {
  background: rgba(255, 255, 255, .72) !important;
  color: #8a630f !important;
  border-color: rgba(200, 154, 43, .46) !important;
}

html[data-theme="light"] .proof-card,
html[data-theme="light"] .reel {
  background: #080808 !important;
  border-color: rgba(200, 154, 43, .30) !important;
}

html[data-theme="light"] .proof-content p,
html[data-theme="light"] .reel h3,
html[data-theme="light"] .proof-content h3 {
  color: rgba(255, 248, 231, .92) !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5) !important;
}

html[data-theme="light"] .hero h1,
html[data-theme="light"] .hero h2,
html[data-theme="light"] .hero h3,
html[data-theme="light"] .hero p,
html[data-theme="light"] .hero li,
html[data-theme="light"] .hero-sub,
html[data-theme="light"] .hero-line,
html[data-theme="light"] .hero-meta,
html[data-theme="light"] .hero-meta strong {
  color: #fff8e7 !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.5) !important;
}

html[data-theme="light"] .home-style-switcher {
  background: rgba(255,248,238,.92) !important;
  border-bottom-color: rgba(200,154,43,.22) !important;
}
html[data-theme="light"] .home-style-copy strong {
  color: #17130b !important;
}
html[data-theme="light"] .home-style-option {
  background: #fffdfa !important;
  color: #17130b !important;
  border-color: rgba(200,154,43,.22) !important;
}
html[data-theme="light"] .home-style-option.is-active {
  background: linear-gradient(132deg, #f7e7aa 0%, #c89a2b 46%, #8f6412 100%) !important;
  color: #100b05 !important;
  border-color: rgba(143,100,18,.34) !important;
}
html[data-theme="light"][data-home-version="signature"] .hero-bullets li,
html[data-theme="light"][data-home-version="editorial"] .hero-meta span {
  background: rgba(20,14,8,.60) !important;
  border-color: rgba(245,230,184,.20) !important;
}

@media (max-width: 1024px) {
  .conversion-trust-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  html[data-home-version="signature"] .hero-grid,
  html[data-home-version="editorial"] .hero-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  html[data-home-version="editorial"] .hero-stage,
  html[data-home-version="editorial"] .hero-copy {
    order: initial;
  }

  html[data-home-version="editorial"] .hero-copy {
    justify-self: stretch;
    padding-left: 0;
    border-left: 0;
  }

  html[data-home-version="editorial"] .product-layout,
  html[data-home-version="editorial"] [data-shopify-section="results-section"] .split,
  html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .split {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .section-dark,
  .section-band {
    padding: 46px 0;
  }

  .real-transformation {
    padding-block: 42px;
  }

  .real-result-grid,
  .founder-grid {
    grid-template-columns: 1fr;
  }

  .real-result-card span {
    left: 12px;
    top: 12px;
    padding: 7px 10px;
    font-size: 10px;
  }

  .launch-offer {
    margin-top: 20px;
    padding: 18px;
  }

  .launch-offer ul {
    grid-template-columns: 1fr;
  }

  .conversion-trust-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .conversion-trust-card {
    min-height: 84px;
    padding: 14px;
  }

  .founder-visual,
  .founder-visual img {
    min-height: 340px;
  }

  .social-float-stack {
    right: max(14px, env(safe-area-inset-right));
    bottom: max(14px, env(safe-area-inset-bottom));
    gap: 10px;
  }

  .social-float {
    width: 48px;
    height: 48px;
  }

  .social-float svg {
    width: 22px;
    height: 22px;
  }

  .home-style-switcher {
    top: 82px;
  }

  .home-style-inner {
    width: min(100% - 24px, var(--max));
    min-height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
    padding: 10px 0 12px;
  }

  .home-style-copy {
    min-width: 0;
    text-align: center;
  }

  .home-style-copy strong {
    font-size: 12px;
  }

  .home-style-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .home-style-option {
    min-height: 46px;
    padding: 8px 10px;
    text-align: center;
  }

  .home-style-option strong {
    font-size: 10.5px;
  }

  html[data-home-version="signature"] .hero,
  html[data-home-version="editorial"] .hero {
    min-height: auto;
    padding-top: 34px;
  }

  html[data-home-version="signature"] .hero-stage,
  html[data-home-version="editorial"] .hero-stage {
    min-height: 360px;
  }

  html[data-home-version="signature"] .hero-stage::before {
    inset: 8% 0 5%;
  }

  html[data-home-version="signature"] .hero-jar,
  html[data-home-version="editorial"] .hero-jar {
    width: min(370px, 92vw);
  }

  html[data-home-version="signature"] .price-ticket,
  html[data-home-version="editorial"] .price-ticket {
    left: 50% !important;
    right: auto !important;
    bottom: 3% !important;
    width: min(230px, calc(100vw - 48px)) !important;
    min-width: 0 !important;
    transform: translateX(-50%) !important;
  }

  html[data-home-version="signature"] .hero-bullets,
  html[data-home-version="editorial"] .hero-bullets {
    display: grid;
    grid-template-columns: 1fr;
  }

  html[data-home-version="signature"] .hero-bullets li {
    width: 100%;
  }

  html[data-home-version="editorial"] .hero-meta {
    grid-template-columns: 1fr;
  }

  html[data-home-version="editorial"] [data-shopify-section="results-section"] .section-heading,
  html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .media-frame,
  html[data-home-version="editorial"] [data-shopify-section="results-section"] .compare-block,
  html[data-home-version="editorial"] [data-shopify-section="about-preview-section"] .split > div {
    order: initial;
  }
}

@media (max-width: 380px) {
  .home-style-inner {
    width: min(100% - 20px, var(--max));
  }

  .home-style-copy strong {
    display: none;
  }

  .home-style-option {
    min-height: 42px;
    padding-inline: 7px;
  }

  .home-style-option span {
    font-size: 9px;
  }

  .home-style-option strong {
    font-size: 9.5px;
  }
}

/* ==========================================================================
 * Product page + checkout modal ecommerce polish
 * Scoped to the product page sections/components only.
 * ========================================================================== */
[data-shopify-section="main-product"] {
  padding: clamp(46px, 6vw, 86px) 0;
  background:
    radial-gradient(circle at 16% 12%, rgba(212,175,55,.10), transparent 34%),
    linear-gradient(180deg, #090806, #050505 62%, #090806);
}

.page-hero.compact {
  min-height: 250px;
  padding: 44px 0 36px;
}

.product-page-grid {
  grid-template-columns: minmax(420px, .92fr) minmax(420px, .78fr);
  gap: clamp(32px, 5vw, 76px);
  align-items: start;
}

.product-gallery {
  position: sticky;
  top: 110px;
  display: grid;
  gap: 14px;
}

.product-gallery-main {
  min-height: clamp(520px, 46vw, 650px);
  border-radius: 24px;
  border: 1px solid rgba(212,175,55,.20);
  background:
    radial-gradient(circle at 50% 62%, rgba(212,175,55,.20), transparent 36%),
    linear-gradient(180deg, #fffefb, #f7efe0);
  box-shadow: 0 34px 90px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.76);
  overflow: hidden;
}

.product-gallery-main img {
  width: min(92%, 720px);
  max-width: 92%;
  max-height: 560px;
  object-fit: contain;
  padding: clamp(18px, 3vw, 34px);
  filter: drop-shadow(0 26px 32px rgba(0,0,0,.24));
}

.thumbs {
  gap: 12px;
}

.thumb {
  width: 82px;
  height: 82px;
  border-radius: 16px;
  border: 1px solid rgba(212,175,55,.22);
  background: #fffaf0;
  box-shadow: 0 12px 30px rgba(0,0,0,.16);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.thumb:hover,
.thumb.selected {
  transform: translateY(-2px);
  border-color: rgba(212,175,55,.62);
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
}

.thumb img {
  width: 72px;
  height: 72px;
  object-fit: contain;
}

.purchase {
  position: sticky;
  top: 110px;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(212,175,55,.22);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.025)),
    rgba(7,7,6,.86);
  box-shadow: 0 30px 80px rgba(0,0,0,.32);
  backdrop-filter: blur(14px);
}

.purchase-title {
  margin: 9px 0 10px;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.02;
  text-transform: none;
}

.rating-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 14px 0 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(212,175,55,.16);
}

.rating-row .stars {
  margin: 0;
  letter-spacing: .08em;
}

.purchase .subcopy {
  margin-top: 0;
  color: rgba(255,255,255,.76);
  font-size: 15px;
}

.purchase .price-row {
  align-items: end;
  gap: 18px;
  margin: 20px 0 18px;
  padding: 18px 0;
  border-top: 1px solid rgba(212,175,55,.14);
  border-bottom: 1px solid rgba(212,175,55,.14);
}

.purchase .sale-price {
  color: var(--gold);
  font-size: clamp(40px, 4vw, 56px);
}

.purchase .compare-price {
  color: rgba(245,230,184,.64);
}

.ingredient-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 16px 0;
}

.ingredient-chips .badge {
  min-height: 32px;
  margin: 0;
  padding-inline: 12px;
  border-radius: 999px;
  letter-spacing: .08em;
}

.purchase-trust-badges {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.purchase-trust-badges span {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(212,175,55,.22);
  border-radius: 14px;
  background: rgba(212,175,55,.055);
  color: var(--cream);
  font-size: 12px;
  font-weight: 900;
}

.purchase-trust-badges span::before {
  content: "✓";
  color: var(--gold);
  font-weight: 900;
}

.purchase .launch-offer {
  margin: 18px 0;
  border-radius: 18px;
  box-shadow: none;
}

.product-info-row {
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin-top: 18px;
  padding: 0;
  border: 0;
  background: transparent;
}

.product-info-row div {
  min-height: 58px;
  padding: 12px 14px;
  border: 1px solid rgba(212,175,55,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
}

.quantity {
  justify-content: space-between;
  padding: 14px 0;
  border-top: 1px solid rgba(212,175,55,.14);
  border-bottom: 1px solid rgba(212,175,55,.14);
}

.stepper {
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.035);
}

.purchase-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 20px;
}

.purchase-actions .button {
  width: 100%;
  min-height: 54px;
  border-radius: 14px;
}

.purchase-actions .button-secondary {
  background: rgba(255,255,255,.04);
}

.delivery-note {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid rgba(212,175,55,.16);
  border-radius: 16px;
  background: rgba(255,255,255,.028);
}

.delivery-note p {
  margin: 0 0 8px;
  font-size: 12.5px;
}

.delivery-note p:last-child {
  margin-bottom: 0;
}

.info-panels details {
  border-radius: 14px;
  overflow: hidden;
}

.product-mobile-buybar {
  display: none;
}

.order-modal {
  padding: 24px;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(18px);
}

.order-modal-sheet {
  width: min(760px, calc(100vw - 32px));
  max-height: min(88vh, 860px);
  padding: 0;
  border-radius: 24px;
  border: 1px solid rgba(212,175,55,.30);
  background:
    radial-gradient(circle at 88% 8%, rgba(212,175,55,.14), transparent 32%),
    #fff8ee;
  color: #17130b;
  box-shadow: 0 32px 110px rgba(0,0,0,.46);
  overflow: auto;
}

.order-modal-head {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 24px 26px 18px;
  margin-bottom: 0;
  border-bottom: 1px solid rgba(200,154,43,.18);
  background: rgba(255,248,238,.94);
  backdrop-filter: blur(14px);
}

.order-modal-head h2 {
  color: #17130b;
  font-size: clamp(28px, 4vw, 38px);
  line-height: 1.05;
}

.order-modal-head p {
  color: rgba(23,19,11,.68);
}

.order-modal-close {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border-color: rgba(200,154,43,.28);
  background: #17130b;
  color: #f7e7aa;
}

.order-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 24px 26px 28px;
}

.order-form .field {
  gap: 8px;
}

.order-form label {
  color: #7f5b10;
  font-size: 11px;
  font-weight: 900;
}

.order-form input,
.order-form textarea,
.order-form select {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(200,154,43,.22);
  background: #fff;
  color: #17130b;
  box-shadow: 0 10px 26px rgba(38,26,8,.04);
}

.order-form textarea {
  min-height: 96px;
}

.order-form input:focus,
.order-form textarea:focus,
.order-form select:focus {
  outline: none;
  border-color: #c89a2b;
  background: #fffdf8;
  box-shadow: 0 0 0 4px rgba(200,154,43,.13);
}

.order-form .field small {
  min-height: 16px;
  color: #b42318;
  font-size: 11px;
  font-weight: 800;
}

.order-form .field.has-error input,
.order-form .field.has-error textarea {
  border-color: rgba(180,35,24,.62);
  box-shadow: 0 0 0 4px rgba(180,35,24,.08);
}

.order-summary {
  display: grid;
  gap: 12px;
  padding: 20px;
  border-radius: 18px;
  border: 1px solid rgba(200,154,43,.28);
  background:
    linear-gradient(145deg, rgba(255,255,255,.82), rgba(255,248,238,.72)),
    rgba(200,154,43,.07);
  box-shadow: 0 18px 40px rgba(38,26,8,.07);
}

.order-summary .row {
  align-items: baseline;
  gap: 18px;
  color: rgba(23,19,11,.72);
}

.order-summary .row strong {
  max-width: 58%;
  color: #17130b;
  text-align: right;
}

.order-summary .row.offer strong {
  color: #a87915;
}

.order-summary .row.total {
  margin-top: 4px;
  padding-top: 13px;
  border-top: 1px dashed rgba(200,154,43,.44);
  color: #17130b;
}

.order-summary .row.total strong {
  color: #a87915;
  font-family: var(--display);
  font-size: 24px;
}

.order-form-actions {
  position: sticky;
  bottom: 0;
  z-index: 1;
  margin: 4px -26px -28px;
  padding: 16px 26px 22px;
  border-top: 1px solid rgba(200,154,43,.18);
  background: rgba(255,248,238,.94);
  backdrop-filter: blur(14px);
}

.order-form-actions .button {
  min-height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, #17130b, #050505);
  color: #f7e7aa;
}

.order-form-actions .button-secondary {
  color: #7d5b12;
  background: rgba(255,255,255,.72);
}

.order-form-actions .button.is-loading {
  opacity: .78;
  cursor: wait;
}

.order-form-message {
  border-radius: 14px;
  color: #17130b;
}

html[data-theme="light"] [data-shopify-section="main-product"] {
  background:
    radial-gradient(circle at 88% 6%, rgba(200,154,43,.12), transparent 34%),
    #fff8ee !important;
}

html[data-theme="light"] .purchase {
  background: rgba(255,255,255,.82) !important;
}

html[data-theme="light"] .purchase .subcopy,
html[data-theme="light"] .delivery-note p {
  color: rgba(23,19,11,.70) !important;
}

html[data-theme="light"] .purchase-trust-badges span,
html[data-theme="light"] .product-info-row div,
html[data-theme="light"] .delivery-note {
  background: #fff !important;
  border-color: rgba(200,154,43,.22) !important;
  color: #17130b !important;
}

@media (max-width: 1024px) {
  .product-page-grid {
    grid-template-columns: 1fr;
  }

  .product-gallery,
  .purchase {
    position: static;
  }

  .product-gallery-main {
    min-height: auto;
    aspect-ratio: 1 / .86;
  }

  .product-gallery-main img {
    max-height: 430px;
  }
}

@media (max-width: 768px) {
  body:has(.product-mobile-buybar) {
    padding-bottom: 86px;
  }

  .page-hero.compact {
    min-height: auto;
    padding: 32px 0 24px;
  }

  [data-shopify-section="main-product"] {
    padding: 24px 0 38px;
  }

  .product-gallery-main {
    border-radius: 18px;
    aspect-ratio: 1 / .78;
    min-height: 0;
  }

  .product-gallery-main img {
    max-height: 300px;
    padding: 16px;
  }

  .thumb {
    width: 64px;
    height: 64px;
    border-radius: 12px;
  }

  .thumb img {
    width: 56px;
    height: 56px;
  }

  .purchase {
    padding: 20px;
    border-radius: 18px;
  }

  .purchase-title {
    font-size: 28px !important;
  }

  .rating-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .purchase .sale-price {
    font-size: 38px;
  }

  .purchase-trust-badges,
  .product-info-row {
    grid-template-columns: 1fr 1fr;
  }

  .purchase-actions {
    display: none !important;
  }

  .product-mobile-buybar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 94;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 10px;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
    border-top: 1px solid rgba(212,175,55,.22);
    background: rgba(5,5,5,.92);
    backdrop-filter: blur(18px);
    box-shadow: 0 -18px 44px rgba(0,0,0,.30);
  }

  .product-mobile-buybar .button {
    min-height: 50px;
    border-radius: 14px;
    padding: 0 12px;
  }

  .social-float-stack {
    bottom: max(88px, calc(88px + env(safe-area-inset-bottom)));
  }

  .order-modal {
    align-items: end;
    padding: 0;
  }

  .order-modal-sheet {
    width: 100vw;
    max-height: 96svh;
    border-radius: 24px 24px 0 0;
  }

  .order-modal-head {
    padding: 20px 18px 16px;
  }

  .order-form {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 18px 18px 24px;
  }

  .order-form .field.span-2 {
    grid-column: auto;
  }

  .order-summary .row strong {
    max-width: 54%;
  }

  .order-form-actions {
    margin: 4px -18px -24px;
    padding: 14px 18px calc(18px + env(safe-area-inset-bottom));
  }
}

@media (max-width: 390px) {
  .purchase-trust-badges,
  .product-info-row {
    grid-template-columns: 1fr;
  }

  .order-summary .row {
    align-items: flex-start;
    flex-direction: column;
    gap: 2px;
  }

  .order-summary .row strong {
    max-width: 100%;
    text-align: left;
  }
}
