/** Shopify CDN: Minification failed

Line 2506:3 Unexpected "="

**/
/* ============================================================
   ErgoThermoGlow™ — Theme Wireframe (Shopify-ready)
   Design System: Rose Gold / Deep Magenta / Charcoal / Off-white
   ============================================================ */

:root {
  /* Brand colors (theme settings — có thể chỉnh trong Editor) */
  --c-rose: #F3C6C2;
  --c-magenta: #D84B6B;
  --c-magenta-dark: #B83555;
  --c-charcoal: #2A2A2A;
  --c-offwhite: #FAFAFA;
  --c-line: #E8E8E8;
  --c-muted: #8A8A8A;

  /* Typography */
  --f-heading: 'Montserrat', system-ui, -apple-system, sans-serif;
  --f-body: 'Inter', 'Lexend', system-ui, -apple-system, sans-serif;

  /* Radius / Spacing */
  --r-pill: 100px;
  --r-card: 16px;
  --r-md: 12px;
  --r-sm: 8px;

  /* Shadows */
  --sh-soft: 0 4px 24px rgba(42,42,42,.06);
  --sh-hover: 0 10px 32px rgba(216,75,107,.18);

  /* Layout */
  --container: 1320px;
  --gap: 24px;
  --header-h: 76px;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--f-body);
  color: var(--c-charcoal);
  background: var(--c-offwhite);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

h1, h2, h3, h4 {
  font-family: var(--f-heading);
  font-weight: 700;
  color: var(--c-charcoal);
  line-height: 1.2;
  margin: 0 0 .5em;
}
h1 { font-size: clamp(2rem, 4vw, 3.25rem); letter-spacing: -.02em; }
h2 { font-size: clamp(1.5rem, 2.6vw, 2.25rem); letter-spacing: -.01em; }
h3 { font-size: 1.25rem; }

p { margin: 0 0 1em; color: #444; }

/* Layout */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}

.section { padding: 80px 0; position: relative; }
.section--tight { padding: 48px 0; }
.eyebrow {
  display: inline-block;
  font-family: var(--f-heading);
  font-size: .75rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--c-magenta);
  font-weight: 600;
  margin-bottom: 12px;
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--r-pill);
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .02em;
  transition: all .25s ease;
  border: 1.5px solid transparent;
  white-space: nowrap;
}
.btn--primary {
  background: var(--c-magenta);
  color: #fff;
}
.btn--primary:hover { background: var(--c-magenta-dark); box-shadow: var(--sh-hover); transform: translateY(-2px); }
.btn--ghost {
  background: transparent;
  color: var(--c-charcoal);
  border-color: var(--c-charcoal);
}
.btn--ghost:hover { background: var(--c-charcoal); color: #fff; }
.btn--dark {
  background: var(--c-charcoal);
  color: #fff;
}
.btn--dark:hover { background: #000; box-shadow: 0 10px 28px rgba(42,42,42,.28); transform: translateY(-2px); }
.btn--dark:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.btn--lg { padding: 18px 38px; font-size: 1rem; }
.btn--block { width: 100%; }

/* ============== HEADER ============== */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 50;
  background: rgba(250,250,250,.72);
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  border-bottom: 1px solid rgba(232,232,232,.5);
}
.site-header__inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand {
  font-family: var(--f-heading);
  font-weight: 800;
  font-size: 1.15rem;
  letter-spacing: -.01em;
  color: var(--c-charcoal);
  display: flex;
  align-items: center;
  gap: 8px;
}
.brand__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
}
.brand sup { font-size: .55em; color: var(--c-magenta); }

.nav { display: flex; gap: 32px; }
.nav a {
  font-size: .92rem;
  font-weight: 500;
  position: relative;
  padding: 6px 0;
  transition: color .2s;
}
.nav a::after {
  content: '';
  position: absolute; left: 0; bottom: 0;
  width: 0; height: 2px;
  background: var(--c-magenta);
  transition: width .25s;
}
.nav a:hover, .nav a.is-active { color: var(--c-magenta); }
.nav a:hover::after, .nav a.is-active::after { width: 100%; }

.header-cta { display: flex; align-items: center; gap: 8px; }

/* Language switcher */
.lang-switcher { position: relative; }
.lang-switcher__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--r-pill);
  font-family: var(--f-heading);
  font-size: .82rem;
  font-weight: 600;
  color: var(--c-charcoal);
  transition: background .15s, color .15s;
}
.lang-switcher__btn:hover { background: var(--c-rose); color: var(--c-magenta); }
.lang-switcher__flag {
  font-size: 1.05rem;
  line-height: 1;
}
.lang-switcher__code { letter-spacing: .04em; }
.lang-switcher__chev {
  width: 11px; height: 11px;
  transition: transform .2s;
}
.lang-switcher.is-open .lang-switcher__chev { transform: rotate(180deg); }
.lang-switcher__menu {
  position: absolute;
  top: 100%; right: 0;
  margin-top: 8px;
  background: #fff;
  border-radius: var(--r-md);
  box-shadow: 0 12px 36px rgba(0,0,0,.12);
  min-width: 180px;
  list-style: none;
  padding: 6px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity .2s, transform .2s;
  z-index: 60;
}
.lang-switcher.is-open .lang-switcher__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.lang-switcher__menu button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: var(--r-sm);
  font-size: .9rem;
  text-align: left;
  color: var(--c-charcoal);
  font-family: var(--f-body);
  transition: background .15s, color .15s;
}
.lang-switcher__menu button:hover { background: var(--c-offwhite); }
.lang-switcher__menu button.is-active {
  background: var(--c-rose);
  color: var(--c-magenta);
  font-weight: 600;
}
.lang-switcher__menu button .check {
  margin-left: auto;
  color: var(--c-magenta);
  font-weight: 700;
  opacity: 0;
}
.lang-switcher__menu button.is-active .check { opacity: 1; }

@media (max-width: 480px) {
  .lang-switcher__btn { padding: 6px 8px; font-size: .75rem; }
  .lang-switcher__code { display: none; }
  .lang-switcher__chev { display: none; }
}

/* Header cart icon button */
.cart-btn {
  position: relative;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: transparent;
  color: var(--c-charcoal);
  display: grid;
  place-items: center;
  transition: background .2s, color .2s, transform .15s;
  border: 1.5px solid transparent;
}
.cart-btn:hover {
  background: var(--c-rose);
  color: var(--c-magenta);
}
.cart-btn:active { transform: scale(.94); }
.cart-btn svg {
  width: 22px; height: 22px;
  stroke-width: 1.5;
}
.cart-btn__count {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 18px; height: 18px;
  padding: 0 5px;
  border-radius: 100px;
  background: var(--c-magenta);
  color: #fff;
  font-family: var(--f-heading);
  font-size: .68rem;
  font-weight: 700;
  display: grid; place-items: center;
  line-height: 1;
  border: 2px solid var(--c-offwhite);
  transform: scale(1);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1);
}
.cart-btn__count[data-empty="true"] {
  transform: scale(0);
}
.cart-btn.is-bumping .cart-btn__count {
  animation: cartBump .4s ease;
}
@keyframes cartBump {
  0% { transform: scale(1); }
  40% { transform: scale(1.4); }
  100% { transform: scale(1); }
}

/* Cart Drawer */
.cart-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(42,42,42,.45);
  backdrop-filter: blur(2px);
  z-index: 90;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.cart-drawer-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}
.cart-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 100%;
  max-width: 420px;
  background: #fff;
  z-index: 95;
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 40px rgba(0,0,0,.12);
}
.cart-drawer.is-open { transform: translateX(0); }

.cart-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--c-line);
  flex-shrink: 0;
}
.cart-drawer__title {
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1.1rem;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cart-drawer__title-count {
  background: var(--c-rose);
  color: var(--c-magenta);
  font-size: .72rem;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-weight: 700;
}
.cart-drawer__close {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--c-offwhite);
  display: grid; place-items: center;
  font-size: 1.4rem;
  color: var(--c-charcoal);
  transition: background .15s;
}
.cart-drawer__close:hover { background: var(--c-rose); color: var(--c-magenta); }

.cart-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 24px;
}

/* Cart item */
.cart-item {
  display: flex;
  gap: 14px;
  padding: 16px 0;
  border-bottom: 1px solid var(--c-line);
}
.cart-item__thumb {
  flex-shrink: 0;
  width: 72px; height: 72px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--c-rose), #FFE3DF);
  display: grid; place-items: center;
  color: var(--c-magenta);
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .72rem;
}
.cart-item__main { flex: 1; min-width: 0; }
.cart-item__name {
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .92rem;
  color: var(--c-charcoal);
  margin: 0 0 4px;
  line-height: 1.3;
}
.cart-item__variant {
  font-size: .78rem;
  color: var(--c-muted);
  margin-bottom: 8px;
}
.cart-item__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.cart-item__qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--c-line);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.cart-item__qty button {
  width: 28px; height: 28px;
  font-size: .9rem;
  color: var(--c-charcoal);
  display: grid; place-items: center;
  transition: background .15s;
}
.cart-item__qty button:hover { background: var(--c-rose); color: var(--c-magenta); }
.cart-item__qty input {
  width: 32px;
  border: none;
  text-align: center;
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .88rem;
  color: var(--c-charcoal);
  background: transparent;
  padding: 0;
  -moz-appearance: textfield;
}
.cart-item__qty input::-webkit-outer-spin-button,
.cart-item__qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.cart-item__price {
  font-family: var(--f-heading);
  font-weight: 700;
  color: var(--c-magenta);
  font-size: .95rem;
}
.cart-item__remove {
  font-size: .75rem;
  color: var(--c-muted);
  text-decoration: underline;
  margin-top: 6px;
  display: inline-block;
}
.cart-item__remove:hover { color: var(--c-magenta); }

/* Empty cart */
.cart-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--c-muted);
}
.cart-empty__icon {
  width: 64px; height: 64px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: var(--c-offwhite);
  display: grid; place-items: center;
  color: var(--c-rose);
}
.cart-empty h4 { margin: 0 0 8px; color: var(--c-charcoal); }

/* Cart footer */
.cart-drawer__foot {
  flex-shrink: 0;
  padding: 20px 24px 24px;
  border-top: 1px solid var(--c-line);
  background: #fff;
}
.cart-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 14px;
}
.cart-subtotal__label {
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .95rem;
}
.cart-subtotal__value {
  font-family: var(--f-heading);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--c-magenta);
}
.cart-note {
  font-size: .78rem;
  color: var(--c-muted);
  text-align: center;
  margin: 10px 0 0;
}

/* Mobile: keep cart icon visible (override previous hide rule) */
@media (max-width: 768px) {
  .header-cta .btn--cta-desktop { display: none; }
  .cart-btn { width: 40px; height: 40px; }
  .cart-drawer { max-width: 100%; }
}

.hamburger { display: none; width: 36px; height: 36px; flex-direction: column; gap: 5px; justify-content: center; align-items: center; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--c-charcoal); border-radius: 2px; transition: .2s; }

/* Push content under fixed header */
main { padding-top: var(--header-h); }

/* ============== HERO ============== */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, var(--c-rose) 0%, #FFE9E7 50%, var(--c-offwhite) 100%);
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.hero__content h1 { margin-bottom: 16px; }
.hero__content p { font-size: 1.1rem; max-width: 520px; margin-bottom: 28px; }
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero__media {
  aspect-ratio: 4 / 5;
  background: linear-gradient(135deg, var(--c-magenta) 0%, var(--c-rose) 100%);
  border-radius: 24px;
  position: relative;
  overflow: hidden;
  box-shadow: var(--sh-hover);
}
.hero__media::after {
  content: '✦  Lifestyle Photo Placeholder  ✦';
  position: absolute;
  inset: 0;
  display: grid; place-items: center;
  color: rgba(255,255,255,.85);
  font-family: var(--f-heading);
  letter-spacing: .1em;
  font-size: .9rem;
}

/* ============== FEATURED PRODUCT BLOCK ============== */
.feature-product {
  background: #fff;
}
.feature-product__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.feature-product__visual {
  aspect-ratio: 1/1;
  background: linear-gradient(135deg, #FFF0EE, var(--c-rose));
  border-radius: var(--r-card);
  position: relative;
}
.feature-product__visual::after {
  content: 'ErgoThermoGlow™ Device';
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--f-heading); color: var(--c-magenta); font-weight: 600;
}

/* ============== COLLECTION TEASER ============== */
.collection-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
.collection-card {
  border-radius: var(--r-card);
  background: #fff;
  padding: 24px;
  box-shadow: var(--sh-soft);
  transition: transform .25s, box-shadow .25s;
}
.collection-card:hover { transform: translateY(-4px); box-shadow: var(--sh-hover); }
.collection-card__img {
  aspect-ratio: 4/3;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--c-rose), #FFE3DF);
  margin-bottom: 16px;
}
.collection-card h3 { margin: 0 0 4px; }
.collection-card p { color: var(--c-muted); font-size: .9rem; margin: 0; }

/* ============== BRAND MISSION ============== */
.mission {
  background: var(--c-offwhite);
  text-align: center;
}
.mission__text {
  font-family: var(--f-heading);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 600;
  max-width: 920px;
  margin: 0 auto;
  line-height: 1.3;
  color: var(--c-charcoal);
  letter-spacing: -.01em;
}
.mission__text em { color: var(--c-magenta); font-style: normal; }

/* ============== INSTAGRAM GRID ============== */
.ig-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.ig-tile {
  aspect-ratio: 1/1;
  border-radius: var(--r-sm);
  background: linear-gradient(135deg, var(--c-rose), #FFD9D4);
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: transform .25s;
}
.ig-tile:hover { transform: scale(1.04); }
.ig-tile::after {
  content: '@';
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--f-heading);
  color: rgba(216,75,107,.6);
  font-size: 1.5rem;
}

/* ============== PDP HERO LAYOUT ============== */
.pdp-hero { padding-top: 32px; }
.pdp-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 48px;
  align-items: flex-start;
}

/* Left: gallery — sticky to keep image in view */
.pdp-gallery {
  position: sticky;
  top: 96px;
  align-self: start;
  max-width: 620px;
  width: 100%;
}
.pdp-gallery__main {
  aspect-ratio: 1 / 1;
  width: 100%;
  border-radius: var(--r-card);
  background: #FFF;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.04);
}
.pdp-gallery__main::after { display: none !important; }
.pdp-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  padding: 8%;
}
.pdp-gallery__dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin: 14px 0 8px;
}
.pdp-gallery__dots .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--c-line);
  transition: width .2s, background .2s;
  cursor: pointer;
}
.pdp-gallery__dots .dot.is-active {
  width: 22px;
  background: var(--c-magenta);
  border-radius: 100px;
}
.pdp-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 12px;
}
.pdp-thumb {
  aspect-ratio: 1 / 1;
  border-radius: var(--r-sm);
  background: #fff;
  cursor: pointer;
  border: 2px solid transparent;
  overflow: hidden;
  transition: border-color .15s, transform .15s;
}
.pdp-thumb:hover { transform: translateY(-2px); border-color: var(--c-rose); }
.pdp-thumb.is-active { border-color: var(--c-magenta); }
.pdp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6%;
  display: block;
}

/* Right column scrolls naturally with page */
.purchase-block {
  min-width: 0;
}

/* Responsive: tablet stack */
@media (max-width: 1024px) {
  .pdp-hero__grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .pdp-gallery {
    position: static;
    max-width: 560px;
    margin: 0 auto;
  }
}
@media (max-width: 768px) {
  .pdp-hero { padding-top: 16px; }
  .pdp-gallery__main { aspect-ratio: 4/5; }
  .pdp-gallery__main img { padding: 6%; }
  .pdp-gallery__thumbs { gap: 6px; }
  .pdp-thumb img { padding: 4%; }
}
.pdp-gallery__main::after {
  content: '⌬';
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-size: 4rem;
  color: rgba(42,42,42,.15);
}

/* Press strip overlay (Vu dans:) */
.press-strip {
  position: absolute;
  top: 24px; right: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  z-index: 2;
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(6px);
  padding: 16px 18px;
  border-radius: var(--r-md);
}
.press-strip__label {
  font-family: var(--f-heading);
  font-size: .82rem;
  font-weight: 500;
  color: var(--c-charcoal);
  margin-bottom: 2px;
}
.press-logo {
  font-family: 'Times New Roman', Georgia, serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--c-charcoal);
  letter-spacing: .04em;
  line-height: 1;
}
.press-logo--space { letter-spacing: .3em; font-size: 1rem; }
.press-logo--box {
  background: var(--c-charcoal);
  color: #fff;
  padding: 3px 10px;
  font-size: .95rem;
  font-family: 'Times New Roman', Georgia, serif;
}

/* Pagination dots */
.gallery-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin: 12px 0;
}
.gallery-dots .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #D0D0D0;
  cursor: pointer;
  transition: background .2s;
}
.gallery-dots .dot.is-active { background: var(--c-charcoal); }


.pdp-thumb.is-active { border-color: var(--c-magenta); }

/* Media-mentions badge overlay (Vogue / Cosmopolitan / Elle / Forbes / Glamour) */
.pdp-gallery__main { display: flex; align-items: stretch; }
.pdp-gallery__main::after { display: none !important; }
.pdp-media-badge {
  position: absolute;
  top: 24px; right: 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  background: rgba(255,255,255,.92);
  padding: 14px 18px;
  border-radius: var(--r-md);
  backdrop-filter: blur(6px);
  z-index: 2;
  box-shadow: 0 4px 14px rgba(0,0,0,.06);
}
.pdp-media-badge__title {
  font-family: 'Georgia', 'Playfair Display', serif;
  font-style: italic;
  font-size: .85rem;
  color: var(--c-muted);
  letter-spacing: .02em;
}
.pdp-media-badge__logos {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .9rem;
  color: var(--c-charcoal);
  text-align: right;
  letter-spacing: .04em;
}
.pdp-media-badge__logos span { line-height: 1.1; }

/* Gallery pagination dots */
.pdp-gallery__dots .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--c-line);
  transition: width .2s, background .2s;
}
.pdp-gallery__dots .dot.is-active {
  width: 20px;
  background: var(--c-magenta);
  border-radius: 100px;
}

/* Benefits checklist */
.benefits-check {
  list-style: none;
  padding: 0 0 16px;
  margin: 0 0 16px;
  border-bottom: 1px solid var(--c-line);
}
.benefits-check li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 6px 0;
  font-size: .95rem;
  color: #333;
}
.benefits-check__icon {
  flex-shrink: 0;
  width: 20px; height: 20px;
  border: 1.5px solid var(--c-rose);
  border-radius: 5px;
  background: #fff;
  display: grid; place-items: center;
  color: var(--c-magenta);
  font-size: .72rem;
  font-weight: 800;
  margin-top: 2px;
}
.benefits-check strong { color: var(--c-charcoal); font-weight: 600; }

/* Stock urgency */
.stock-urgency {
  padding: 4px 0 0;
  margin-bottom: 8px;
}
.stock-urgency__label {
  font-size: .9rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  color: var(--c-charcoal);
}
.stock-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--c-magenta);
  display: inline-block;
  animation: stockPulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes stockPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .35; transform: scale(.85); }
}
.stock-urgency__bar {
  height: 4px;
  background: #FFEBE9;
  border-radius: 100px;
  overflow: hidden;
}
.stock-urgency__bar > span {
  display: block;
  height: 100%;
  width: 18%;
  background: linear-gradient(90deg, var(--c-rose), var(--c-magenta));
  border-radius: 100px;
}

/* Bundle promo title */
.bundle-promo-title {
  text-align: center;
  font-family: var(--f-heading);
  font-weight: 700;
  letter-spacing: .12em;
  font-size: .92rem;
  margin: 22px 0 14px;
  color: var(--c-charcoal);
  text-transform: uppercase;
}

/* Bundle / variant selector */
.bundle-selector { border: none; padding: 0; margin: 0; }
.bundle-option {
  display: block;
  position: relative;
  border: 1.5px solid var(--c-line);
  border-radius: var(--r-card);
  margin-bottom: 12px;
  cursor: pointer;
  background: #fff;
  transition: border-color .2s, background .2s, box-shadow .2s;
  overflow: visible;
}
.bundle-option:hover { border-color: var(--c-rose); }
.bundle-option:has(input:checked) {
  border-color: var(--c-magenta);
  background: linear-gradient(180deg, #FFF6F4 0%, #fff 55%);
  box-shadow: 0 0 0 1px var(--c-magenta) inset;
}
.bundle-option input[type="radio"] {
  position: absolute; opacity: 0; pointer-events: none;
}
.bundle-option__inner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
}
.bundle-option__radio {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border: 2px solid var(--c-line);
  border-radius: 50%;
  position: relative;
  transition: border-color .15s;
}
.bundle-option:has(input:checked) .bundle-option__radio { border-color: var(--c-magenta); }
.bundle-option:has(input:checked) .bundle-option__radio::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 11px; height: 11px;
  border-radius: 50%;
  background: var(--c-magenta);
}
.bundle-option__thumb {
  flex-shrink: 0;
  width: 42px; height: 42px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  color: #fff;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .68rem;
}
.bundle-option__thumb--device { background: linear-gradient(135deg, var(--c-magenta), var(--c-rose)); }
.bundle-option__thumb--device::after { content: 'ETG'; }
.bundle-option__thumb--bundle { background: linear-gradient(135deg, var(--c-charcoal), var(--c-magenta)); }
.bundle-option__thumb--bundle::after { content: 'SET'; }
.bundle-option__info { flex: 1; min-width: 0; }
.bundle-option__title {
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .95rem;
  color: var(--c-charcoal);
  line-height: 1.3;
}
.bundle-option__save {
  font-size: .78rem;
  color: var(--c-muted);
  margin-top: 3px;
}
.bundle-option__price { text-align: right; flex-shrink: 0; }
.price-current {
  display: block;
  font-family: var(--f-heading);
  font-weight: 700;
  color: var(--c-charcoal);
  font-size: 1rem;
  line-height: 1.2;
}
.price-old {
  display: block;
  font-size: .82rem;
  color: var(--c-muted);
  text-decoration: line-through;
  margin-top: 2px;
}
.bundle-option__badge {
  position: absolute;
  top: -1px; right: 18px;
  background: var(--c-charcoal);
  color: #fff;
  font-family: var(--f-heading);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 5px 12px 6px;
  border-radius: 0 0 8px 8px;
  z-index: 2;
}

/* Sub-items inside selected bundle */
.bundle-option__items {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding .25s;
  padding: 0 16px;
}
.bundle-option:has(input:checked) .bundle-option__items {
  max-height: 800px;
  padding: 4px 16px 14px;
}
.bundle-sub {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px dashed rgba(216,75,107,.25);
}
.bundle-sub__thumb {
  width: 40px; height: 40px;
  border-radius: var(--r-sm);
  flex-shrink: 0;
  display: grid; place-items: center;
  color: rgba(255,255,255,.9);
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .62rem;
}
.bundle-sub__thumb--device { background: linear-gradient(135deg, var(--c-magenta), var(--c-rose)); }
.bundle-sub__thumb--device::after { content: 'ETG'; }
.bundle-sub__thumb--serum { background: linear-gradient(135deg, #B5D3F0, #4A6FA5); }
.bundle-sub__thumb--serum::after { content: 'SR'; }
.bundle-sub__thumb--protocol { background: linear-gradient(135deg, var(--c-rose), #FFE3DF); color: var(--c-magenta); }
.bundle-sub__thumb--protocol::after { content: '21D'; }
.bundle-sub__name {
  flex: 1;
  font-size: .88rem;
  font-weight: 500;
  color: #333;
}
.bundle-sub__price { text-align: right; }
.bundle-sub__price .price-current { font-size: .92rem; }
.bundle-sub__price .price-old { font-size: .76rem; }
.bundle-sub-plus {
  display: grid; place-items: center;
  width: 22px; height: 22px;
  margin: -2px auto;
  border-radius: 50%;
  background: var(--c-rose);
  color: var(--c-magenta);
  font-weight: 800;
  font-size: .85rem;
  position: relative; z-index: 1;
}

/* SR only */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Mobile tweaks for new Hero */
@media (max-width: 768px) {
  .pdp-media-badge { top: 12px; right: 12px; padding: 10px 12px; }
  .pdp-media-badge__title { font-size: .72rem; }
  .pdp-media-badge__logos { font-size: .76rem; }
  .bundle-option__inner { gap: 10px; padding: 12px 14px; }
  .bundle-option__title { font-size: .9rem; }
  .bundle-option__save { font-size: .72rem; }
  .price-current { font-size: .92rem; }
  .price-old { font-size: .76rem; }
  .bundle-sub__name { font-size: .82rem; }
}

/* Purchase block — new structure */
.purchase-block { /* no sticky — too tall */ }
.purchase-block h1 { font-size: 1.75rem; margin-bottom: 8px; }

/* Tagline */
.pdp-tagline {
  font-size: 1.02rem;
  color: var(--c-charcoal);
  line-height: 1.55;
  margin: 0 0 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--c-line);
}
.pdp-tagline strong { color: var(--c-charcoal); font-weight: 700; }

/* Benefit list — green checkmarks, 2 columns */
.benefit-list {
  list-style: none;
  padding: 0;
  margin: 0 0 4px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
}
.benefit-list li {
  font-size: .9rem;
  line-height: 1.4;
  padding-left: 30px;
  position: relative;
  color: #444;
}
.benefit-list li::before {
  content: '';
  position: absolute;
  left: 0; top: 2px;
  width: 18px; height: 18px;
  border: 1.5px solid #4ADE80;
  border-radius: 4px;
  background: #fff;
}
.benefit-list li::after {
  content: '';
  position: absolute;
  left: 5px; top: 5px;
  width: 7px; height: 11px;
  border: solid #4ADE80;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.benefit-list li strong { color: var(--c-charcoal); font-weight: 700; }

/* Stock indicator */
.stock-indicator {
  margin: 22px 0 24px;
}
.stock-indicator__top {
  display: flex; align-items: center; gap: 10px;
  font-size: .92rem;
  margin-bottom: 10px;
  color: var(--c-charcoal);
}
.stock-indicator__top strong { font-weight: 700; }
.stock-indicator__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #E11D48;
  box-shadow: 0 0 0 0 rgba(225,29,72,.6);
  animation: stockPulse 1.6s infinite;
}
@keyframes stockPulse {
  0%   { box-shadow: 0 0 0 0 rgba(225,29,72,.55); }
  70%  { box-shadow: 0 0 0 8px rgba(225,29,72,0); }
  100% { box-shadow: 0 0 0 0 rgba(225,29,72,0); }
}
.stock-progress {
  width: 100%;
  height: 5px;
  background: #FDE4E2;
  border-radius: var(--r-pill);
  overflow: hidden;
}
.stock-progress__bar {
  height: 100%;
  background: linear-gradient(90deg, var(--c-magenta), #F472A2);
  border-radius: var(--r-pill);
  width: 25%;
  transition: width .4s;
}

/* Bundle heading */
.bundle-heading {
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .98rem;
  letter-spacing: .08em;
  color: var(--c-charcoal);
  padding: 14px 0;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  margin-bottom: 14px;
  text-transform: uppercase;
}
.bundle-heart { font-size: 1.1rem; }

/* Bundle options */
.bundle-options {
  display: flex; flex-direction: column;
  gap: 12px;
  margin-bottom: 20px;
}
.bundle-option {
  display: block;
  position: relative;
  padding: 16px;
  border: 2px solid var(--c-line);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color .2s, background .2s;
  background: #fff;
}
.bundle-option:hover { border-color: var(--c-rose); }
.bundle-option > input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.bundle-option.is-selected {
  border-color: var(--c-magenta);
  background: #FFFBFA;
}
.bundle-option__row {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  align-items: center;
  gap: 14px;
}
.bundle-option__radio {
  width: 22px; height: 22px;
  border: 2px solid #C8C8C8;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  transition: border-color .15s;
}
.bundle-option.is-selected .bundle-option__radio { border-color: var(--c-magenta); }
.bundle-option.is-selected .bundle-option__radio::after {
  content: '';
  position: absolute;
  inset: 3px;
  background: var(--c-magenta);
  border-radius: 50%;
}
.bundle-option__thumb {
  width: 52px; height: 52px;
  border-radius: 8px;
  background: linear-gradient(135deg, #F0F0F0, #DCDCDC);
  flex-shrink: 0;
  display: grid; place-items: center;
  color: #888;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .75rem;
}
.bundle-option__info { min-width: 0; }
.bundle-option__title {
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .98rem;
  color: var(--c-charcoal);
  line-height: 1.2;
  margin: 0 0 2px;
  display: block;
}
.bundle-option__save {
  font-size: .82rem;
  color: var(--c-muted);
  line-height: 1.2;
}
.bundle-option__prices {
  display: flex; flex-direction: column;
  align-items: flex-end;
  gap: 1px;
  flex-shrink: 0;
}
.bundle-option__price {
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1rem;
  color: var(--c-charcoal);
  line-height: 1.2;
}
.bundle-option__old {
  font-size: .82rem;
  color: var(--c-muted);
  text-decoration: line-through;
  line-height: 1.2;
}

/* Popular badge */
.bundle-popular-badge {
  position: absolute;
  top: -10px; right: 12px;
  background: var(--c-charcoal);
  color: #fff;
  padding: 4px 10px;
  border-radius: 4px;
  font-family: var(--f-heading);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  z-index: 1;
}

/* Bundle breakdown — visible when popular option selected */
.bundle-breakdown {
  display: none;
  flex-direction: column;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed #F0DAD7;
}
.bundle-option.is-selected .bundle-breakdown { display: flex; }

.breakdown-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
}
.breakdown-item__thumb {
  width: 44px; height: 44px;
  border-radius: 6px;
  background: linear-gradient(135deg, #F2F2F2, #E0E0E0);
  display: grid; place-items: center;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: .7rem;
  color: #888;
}
.breakdown-item__name {
  font-size: .88rem;
  font-weight: 500;
  color: var(--c-charcoal);
  line-height: 1.3;
}
.breakdown-item__price {
  text-align: right;
  display: flex; flex-direction: column;
  font-size: .85rem;
  line-height: 1.2;
}
.breakdown-item__price .price { font-weight: 700; color: var(--c-charcoal); }
.breakdown-item__price .price.free { color: #16A34A; }
.breakdown-item__price .old { color: var(--c-muted); text-decoration: line-through; font-size: .78rem; }

.breakdown-plus {
  width: 22px; height: 22px;
  margin: 2px auto;
  border-radius: 50%;
  background: var(--c-rose);
  display: grid; place-items: center;
  color: var(--c-magenta);
  font-weight: 700;
  font-size: .85rem;
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px #F0DAD7;
}

/* Black CTA */
.btn--dark {
  background: var(--c-charcoal);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.btn--dark:hover {
  background: #000;
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}

/* Payment methods */
.payment-methods {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.pay-icon {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 6px;
  padding: 6px 10px;
  font-family: var(--f-heading);
  font-size: .68rem;
  font-weight: 700;
  color: var(--c-charcoal);
  letter-spacing: .04em;
  min-width: 44px;
  text-align: center;
}

/* Trust-line under CTA */
.trust-line {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: .82rem;
  color: var(--c-muted);
  margin-top: 10px;
}
.trust-line::before { content: '🔒'; }

/* Old utility classes kept */
.price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.price { font-family: var(--f-heading); font-size: 1.75rem; color: var(--c-magenta); font-weight: 700; }
.price--old { font-size: 1.1rem; text-decoration: line-through; color: var(--c-muted); font-weight: 400; }
.badge {
  background: var(--c-magenta);
  color: #fff;
  font-size: .7rem;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-weight: 700;
  letter-spacing: .05em;
}
.swatches { display: flex; gap: 10px; margin: 16px 0 24px; }
.swatch {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid #fff;
  outline: 1.5px solid var(--c-line);
  cursor: pointer;
}
.swatch.is-active { outline-color: var(--c-magenta); }
.swatch--rose { background: var(--c-rose); }
.swatch--magenta { background: var(--c-magenta); }
.swatch--charcoal { background: var(--c-charcoal); }

.trust-list { list-style: none; padding: 0; margin: 20px 0 0; }
.trust-list li {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 0;
  font-size: .9rem;
}
.trust-list li::before {
  content: '✓';
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--c-rose);
  color: var(--c-magenta);
  display: grid; place-items: center;
  font-size: .8rem; font-weight: 700;
}

/* PDP HERO RESPONSIVE */
@media (max-width: 768px) {
  .press-strip {
    top: 12px; right: 12px;
    padding: 10px 12px;
    gap: 8px;
  }
  .press-strip__label { font-size: .72rem; }
  .press-logo { font-size: .9rem; }
  .press-logo--space { font-size: .8rem; letter-spacing: .2em; }
  .press-logo--box { font-size: .78rem; padding: 2px 7px; }

  .benefit-list { grid-template-columns: 1fr; gap: 10px; }
  .benefit-list li { font-size: .9rem; }

  .bundle-option__row { gap: 10px; grid-template-columns: auto auto 1fr auto; }
  .bundle-option__thumb { width: 44px; height: 44px; font-size: .7rem; }
  .bundle-option__title { font-size: .92rem; }
  .bundle-option__save { font-size: .76rem; }
  .bundle-option__price { font-size: .95rem; }
  .bundle-option__old { font-size: .78rem; }

  .breakdown-item { grid-template-columns: auto 1fr auto; gap: 10px; }
  .breakdown-item__thumb { width: 38px; height: 38px; font-size: .65rem; }
  .breakdown-item__name { font-size: .82rem; }
  .breakdown-item__price { font-size: .8rem; }

  .pay-icon { padding: 4px 8px; font-size: .62rem; min-width: 36px; }
}

/* PDP sections */
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
.feature-card {
  padding: 32px 24px;
  background: #fff;
  border-radius: var(--r-card);
  text-align: center;
  box-shadow: var(--sh-soft);
}
.feature-card__icon {
  width: 56px; height: 56px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  display: grid; place-items: center;
  color: #fff;
  font-family: var(--f-heading);
  font-weight: 700;
}

.ba-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.ba-box {
  aspect-ratio: 4/3;
  border-radius: var(--r-card);
  position: relative;
  overflow: hidden;
}
.ba-before { background: linear-gradient(135deg, #d4c4c2, #b0a0a0); }
.ba-after { background: linear-gradient(135deg, var(--c-rose), #FFE3DF); }
.ba-box::after {
  content: attr(data-label);
  position: absolute; top: 16px; left: 16px;
  background: rgba(255,255,255,.9);
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-family: var(--f-heading); font-weight: 600;
  font-size: .85rem;
  color: var(--c-charcoal);
}

table.compare {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: var(--r-card);
  overflow: hidden;
  box-shadow: var(--sh-soft);
}
table.compare th, table.compare td {
  padding: 16px 20px;
  text-align: left;
  border-bottom: 1px solid var(--c-line);
}
table.compare th {
  background: var(--c-charcoal);
  color: #fff;
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .92rem;
}
table.compare td.highlight { background: #FFF6F4; color: var(--c-magenta); font-weight: 600; }

.faq-item {
  background: #fff;
  border-radius: var(--r-md);
  padding: 18px 22px;
  margin-bottom: 12px;
  box-shadow: var(--sh-soft);
  cursor: pointer;
}
.faq-item summary {
  list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--f-heading);
  font-weight: 600;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-size: 1.5rem; color: var(--c-magenta); transition: .2s; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { margin: 12px 0 0; color: #555; }

/* Reviews */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.review-card { background: #fff; padding: 24px; border-radius: var(--r-card); box-shadow: var(--sh-soft); }
.stars { color: var(--c-magenta); letter-spacing: 2px; margin-bottom: 8px; }
.review-card__author { font-size: .85rem; color: var(--c-muted); margin-top: 12px; }

/* ============== COMBO / FREQUENTLY BOUGHT TOGETHER ============== */
.combo-block {
  background: linear-gradient(180deg, #FFF6F4 0%, #fff 100%);
}
.combo-card {
  background: #fff;
  border-radius: var(--r-card);
  padding: 36px;
  box-shadow: var(--sh-soft);
  border: 1px solid #FFE3DF;
}
.combo-visuals {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.combo-thumb {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  flex: 0 0 130px;
}
.combo-thumb__img {
  width: 130px; height: 130px;
  border-radius: var(--r-md);
  position: relative;
  overflow: hidden;
  display: grid; place-items: center;
  color: rgba(255,255,255,.9);
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: -.02em;
}
.combo-thumb__img--device { background: linear-gradient(135deg, var(--c-magenta), var(--c-rose)); }
.combo-thumb__img--device::after { content: 'ETG'; }
.combo-thumb__img--cleanser { background: linear-gradient(135deg, #B5D3F0, #E8F4FF); color: #4A6FA5; }
.combo-thumb__img--cleanser::after { content: 'AAC'; }
.combo-thumb__img--headband { background: linear-gradient(135deg, #F3C6C2, #FFE9E7); color: var(--c-magenta); }
.combo-thumb__img--headband::after { content: 'HB'; }
.combo-thumb__label {
  font-family: var(--f-heading);
  font-size: .82rem;
  font-weight: 600;
  color: var(--c-charcoal);
  text-align: center;
  max-width: 130px;
  line-height: 1.3;
}
.combo-plus {
  font-family: var(--f-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--c-magenta);
  margin-bottom: 28px;
  user-select: none;
}

.combo-list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  border-top: 1px solid var(--c-line);
}
.combo-item { border-bottom: 1px solid var(--c-line); }
.combo-item label {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 4px;
  cursor: pointer;
  transition: background .15s;
}
.combo-item label:hover { background: #FFF9F8; }
.combo-item input[type="checkbox"] {
  position: absolute; opacity: 0; pointer-events: none;
}
.combo-item__check {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border: 2px solid var(--c-line);
  border-radius: 6px;
  background: #fff;
  position: relative;
  transition: all .15s;
}
.combo-item input:checked + .combo-item__check {
  background: var(--c-magenta);
  border-color: var(--c-magenta);
}
.combo-item input:checked + .combo-item__check::after {
  content: '';
  position: absolute;
  left: 6px; top: 2px;
  width: 6px; height: 11px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.combo-item input:focus-visible + .combo-item__check {
  outline: 2px solid var(--c-magenta);
  outline-offset: 2px;
}
.combo-item__name {
  flex: 1;
  font-size: .95rem;
  font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.combo-item__tag {
  background: var(--c-rose);
  color: var(--c-magenta);
  font-family: var(--f-heading);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
.combo-item__price {
  font-family: var(--f-heading);
  font-weight: 700;
  color: var(--c-charcoal);
  font-size: 1rem;
  flex-shrink: 0;
}
.combo-item input:not(:checked) ~ .combo-item__name,
.combo-item input:not(:checked) ~ .combo-item__price {
  opacity: .45;
  text-decoration: line-through;
}

.combo-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px;
  background: linear-gradient(135deg, #FFF6F4, #FFEFEC);
  border-radius: var(--r-md);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.combo-total__label {
  font-family: var(--f-heading);
  font-size: .82rem;
  font-weight: 600;
  color: var(--c-muted);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.combo-total__price {
  display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
  margin-top: 4px;
}
.combo-total__price > span:first-child {
  font-family: var(--f-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--c-magenta);
  letter-spacing: -.02em;
}
.combo-total__old {
  font-size: 1.1rem;
  color: var(--c-muted);
  text-decoration: line-through;
  font-weight: 400;
}
.combo-cta {
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: 1rem;
  padding: 18px 28px;
}
.combo-cta:disabled {
  opacity: .5;
  cursor: not-allowed;
  background: var(--c-muted);
}
.combo-savings-note {
  text-align: center;
  font-size: .85rem;
  color: var(--c-muted);
  margin-top: 12px;
}
.combo-savings-note strong { color: var(--c-magenta); }

@media (max-width: 768px) {
  .combo-card { padding: 24px 20px; }
  .combo-visuals { gap: 8px; margin-bottom: 24px; }
  .combo-thumb { flex: 0 0 92px; }
  .combo-thumb__img { width: 92px; height: 92px; font-size: 1.2rem; }
  .combo-thumb__label { font-size: .72rem; max-width: 92px; }
  .combo-plus { font-size: 1.3rem; margin-bottom: 22px; }
  .combo-item label { padding: 14px 0; gap: 12px; }
  .combo-item__name { font-size: .88rem; gap: 6px; }
  .combo-item__price { font-size: .92rem; }
  .combo-total { padding: 16px; gap: 12px; }
  .combo-total__price > span:first-child { font-size: 1.5rem; }
  .combo-cta { font-size: .9rem; padding: 16px 20px; letter-spacing: .04em; }
}

/* Pain points */
.pains-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--gap); }
.pain-card {
  background: #fff; padding: 28px; border-radius: var(--r-card);
  border-left: 4px solid var(--c-magenta);
  box-shadow: var(--sh-soft);
}
.pain-card h3 { color: var(--c-magenta); }

/* ============== ABOUT PAGE ============== */
.about-content {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.05rem;
  color: #333;
}
.about-content h2 { margin-top: 2.5em; }
.about-content h2:first-child { margin-top: 0; }
.about-content p { margin-bottom: 1.2em; }
.about-content blockquote {
  border-left: 3px solid var(--c-magenta);
  padding: 8px 20px;
  font-family: var(--f-heading);
  font-style: italic;
  color: var(--c-charcoal);
  background: #FFF6F4;
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: 24px 0;
}

/* ============== CONTACT PAGE ============== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: flex-start;
}
.contact-info h2 { margin-bottom: 16px; }
.contact-info ul { list-style: none; padding: 0; margin: 24px 0; }
.contact-info li { padding: 10px 0; display: flex; gap: 12px; align-items: flex-start; }
.contact-info li::before {
  content: ''; flex-shrink: 0;
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  border-radius: 50%;
}

.contact-form {
  background: #fff;
  padding: 36px;
  border-radius: var(--r-card);
  box-shadow: var(--sh-soft);
}
.form-row { margin-bottom: 18px; }
.form-row label {
  display: block;
  font-family: var(--f-heading);
  font-size: .82rem;
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--c-charcoal);
  letter-spacing: .03em;
}
.form-row label .req { color: var(--c-magenta); }
.form-row input,
.form-row textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--c-line);
  border-radius: var(--r-md);
  background: #FBFBFB;
  font-family: var(--f-body);
  font-size: .95rem;
  transition: border-color .2s, background .2s;
}
.form-row input:focus,
.form-row textarea:focus {
  outline: none;
  border-color: var(--c-magenta);
  background: #fff;
}
.form-row textarea { min-height: 140px; resize: vertical; }
.form-hint { font-size: .8rem; color: var(--c-muted); margin: 8px 0 0; }

/* ============== FOOTER ============== */
.site-footer {
  background: var(--c-charcoal);
  color: #cfcfcf;
  padding: 64px 0 24px;
  margin-top: 80px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.3fr;
  gap: var(--gap);
}
.footer-col h4 {
  color: #fff;
  font-size: .95rem;
  margin-bottom: 16px;
  letter-spacing: .04em;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { padding: 4px 0; font-size: .9rem; }
.footer-col a:hover { color: var(--c-rose); }
.newsletter { display: flex; gap: 0; margin-top: 12px; }
.newsletter input {
  flex: 1;
  padding: 12px 16px;
  border: none;
  border-radius: var(--r-pill) 0 0 var(--r-pill);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-family: var(--f-body);
}
.newsletter input::placeholder { color: rgba(255,255,255,.5); }
.newsletter button {
  padding: 12px 24px;
  background: var(--c-magenta);
  color: #fff;
  border-radius: 0 var(--r-pill) var(--r-pill) 0;
  font-family: var(--f-heading);
  font-weight: 600;
}
.socials { display: flex; gap: 8px; margin-top: 16px; }
.social-dot {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  display: grid; place-items: center;
  font-size: .8rem;
  transition: background .2s;
}
.social-dot:hover { background: var(--c-magenta); }
.footer-bottom {
  margin-top: 48px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.1);
  font-size: .82rem;
  text-align: center;
  color: rgba(255,255,255,.4);
}

/* ============== MOBILE STICKY CTA ============== */
/* ============== STICKY MOBILE CTA (FIXED) ============== */
.sticky-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 40;
  background: #fff;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  border-top: 1px solid var(--c-line);
  box-shadow: 0 -4px 24px rgba(0,0,0,.08);
  text-decoration: none;
}
.sticky-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: var(--c-magenta);
  color: #fff;
  padding: 14px 20px;
  border-radius: var(--r-pill);
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .04em;
  transition: background .2s, transform .15s;
}
.sticky-cta:active .sticky-cta__btn { transform: scale(.97); }
.sticky-cta:hover .sticky-cta__btn { background: var(--c-magenta-dark); }

@media (max-width: 768px) {
  .sticky-cta { display: block; }
  body { padding-bottom: calc(96px + env(safe-area-inset-bottom)); }
}

/* ============== TABLE OVERFLOW WRAPPER ============== */
.table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--r-card);
  /* Visual hint that table is scrollable on mobile */
  background:
    linear-gradient(to right, #fff 30%, rgba(255,255,255,0)) left center / 40px 100% no-repeat,
    linear-gradient(to left, #fff 30%, rgba(255,255,255,0)) right center / 40px 100% no-repeat,
    linear-gradient(to right, rgba(216,75,107,.18), rgba(216,75,107,0)) left center / 14px 100% no-repeat,
    linear-gradient(to left, rgba(216,75,107,.18), rgba(216,75,107,0)) right center / 14px 100% no-repeat;
  background-attachment: local, local, scroll, scroll;
}
.table-wrap table.compare { min-width: 640px; margin: 0; }

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px) {
  .hero__grid, .feature-product__grid, .pdp-hero__grid, .contact-grid { grid-template-columns: 1fr; }
  .collection-grid, .features-grid, .reviews-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .ig-grid { grid-template-columns: repeat(4, 1fr); }
  .purchase-block { position: static; }

  /* Editor on tablet: overlay instead of push */
  body.is-editing { padding-right: 0; }
}
@media (max-width: 768px) {
  .section { padding: 56px 0; }
  .nav { display: none; }
  .hamburger { display: flex; }
  .header-cta .btn--cta-desktop { display: none; }
  .collection-grid, .features-grid, .reviews-grid, .pains-grid, .ba-grid { grid-template-columns: 1fr; }
  .ig-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .sticky-cta { display: block; }

  /* CRITICAL: clearance for sticky CTA so last content row isn't covered */
  body { padding-bottom: 96px; }
  html { scroll-padding-bottom: 96px; }
  main { padding-bottom: 0; }
  .site-footer { margin-bottom: 0; }

  .contact-form { padding: 24px; }

  /* Editor FAB: move higher above sticky CTA, shrink size, no text overlap */
  .editor-fab {
    bottom: 108px;          /* sticky-cta ~76px + 32px gap */
    right: 14px;
    padding: 10px 16px;
    font-size: .8rem;
    box-shadow: 0 6px 20px rgba(0,0,0,.22);
  }

  /* Editor panel becomes full-screen overlay on mobile (sidebar 320px doesn't fit) */
  body.is-editing { padding-right: 0; }
  .editor-panel { width: 100%; max-width: 100vw; }

  /* Show "swipe to scroll" hint on mobile */
  .scroll-hint { display: block !important; }

  /* Tables become horizontally scrollable instead of cropping text */
  table.compare { min-width: 580px; font-size: .88rem; }
  table.compare th, table.compare td { padding: 12px 14px; }
  table.compare th:first-child, table.compare td:first-child {
    position: sticky; left: 0;
    background: #fff;
    box-shadow: 2px 0 6px rgba(0,0,0,.04);
  }
  table.compare th:first-child { background: var(--c-charcoal); }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; }
  .pdp-gallery__thumbs { grid-template-columns: repeat(4, 1fr); }

  /* Very small screens: shrink FAB to icon-only to avoid crowding */
  .editor-fab {
    padding: 12px;
    font-size: 0;
    gap: 0;
    width: 48px; height: 48px;
    border-radius: 50%;
    justify-content: center;
  }
  .editor-fab__dot { width: 10px; height: 10px; }
  .editor-fab::after {
    content: '✎';
    font-size: 1.1rem;
    color: #fff;
  }

  /* Sticky CTA: ensure button fits comfortably */
  .sticky-cta { padding: 10px 12px; }
  .sticky-cta .btn { padding: 14px 18px; font-size: .92rem; }
}

/* ============== EDITOR (GemPages-like) ============== */
.editor-fab {
  position: fixed;
  right: 20px;
  bottom: 88px;
  z-index: 60;
  background: var(--c-charcoal);
  color: #fff;
  padding: 14px 22px;
  border-radius: var(--r-pill);
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .88rem;
  display: flex; align-items: center; gap: 8px;
  box-shadow: 0 8px 28px rgba(0,0,0,.25);
  transition: all .2s;
}
.editor-fab:hover { background: var(--c-magenta); transform: translateY(-2px); }
.editor-fab__dot { width: 8px; height: 8px; border-radius: 50%; background: #4ADE80; }

body.is-editing { padding-right: 320px; }
body.is-editing .editor-fab { display: none; }

.editor-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 320px;
  background: #fff;
  border-left: 1px solid var(--c-line);
  z-index: 70;
  transform: translateX(100%);
  transition: transform .3s;
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 40px rgba(0,0,0,.08);
}
body.is-editing .editor-panel { transform: translateX(0); }

.editor-panel__head {
  padding: 20px;
  border-bottom: 1px solid var(--c-line);
  display: flex; justify-content: space-between; align-items: center;
}
.editor-panel__head h3 { margin: 0; font-size: 1rem; }
.editor-close {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--c-offwhite);
  display: grid; place-items: center;
  font-size: 1.2rem;
  color: var(--c-charcoal);
}
.editor-close:hover { background: var(--c-rose); }

.editor-tabs {
  display: flex;
  border-bottom: 1px solid var(--c-line);
}
.editor-tab {
  flex: 1;
  padding: 12px;
  font-family: var(--f-heading);
  font-size: .8rem;
  font-weight: 600;
  color: var(--c-muted);
  border-bottom: 2px solid transparent;
}
.editor-tab.is-active { color: var(--c-magenta); border-bottom-color: var(--c-magenta); }

.editor-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}
.editor-tabpane { display: none; }
.editor-tabpane.is-active { display: block; }

.editor-section-list { list-style: none; padding: 0; margin: 0; }
.editor-section-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: #FBFBFB;
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  margin-bottom: 8px;
  cursor: grab;
  font-size: .88rem;
  transition: border-color .15s, transform .15s;
}
.editor-section-item:hover { border-color: var(--c-magenta); }
.editor-section-item.sortable-ghost { opacity: .4; }
.editor-section-item.sortable-chosen { transform: scale(1.02); border-color: var(--c-magenta); }
.editor-section-item .handle {
  cursor: grab; color: var(--c-muted); user-select: none;
}
.editor-section-item .name { flex: 1; font-weight: 500; }
.editor-section-item .toggle {
  width: 28px; height: 16px;
  background: var(--c-magenta);
  border-radius: 100px;
  position: relative;
}
.editor-section-item .toggle::after {
  content: ''; position: absolute;
  top: 2px; right: 2px;
  width: 12px; height: 12px;
  background: #fff; border-radius: 50%;
  transition: .2s;
}
.editor-section-item.is-hidden .toggle { background: #ccc; }
.editor-section-item.is-hidden .toggle::after { right: auto; left: 2px; }

.color-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--c-line);
}
.color-row label { flex: 1; font-size: .88rem; font-weight: 500; }
.color-row input[type="color"] {
  width: 40px; height: 32px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--c-line);
  cursor: pointer;
  background: none;
}

.device-tabs {
  display: flex; gap: 8px;
  margin-bottom: 16px;
}
.device-tab {
  flex: 1;
  padding: 10px;
  background: #FBFBFB;
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  font-family: var(--f-heading);
  font-size: .75rem;
  font-weight: 600;
}
.device-tab.is-active { background: var(--c-magenta); color: #fff; border-color: var(--c-magenta); }

/* Section editing hover overlay */
body.is-editing [data-editable-section] {
  position: relative;
  outline: 2px dashed transparent;
  outline-offset: -2px;
  transition: outline-color .15s;
}
body.is-editing [data-editable-section]:hover { outline-color: var(--c-magenta); }
body.is-editing [data-editable-section]::before {
  content: attr(data-label);
  position: absolute;
  top: 8px; left: 8px;
  background: var(--c-magenta);
  color: #fff;
  padding: 4px 10px;
  border-radius: var(--r-sm);
  font-family: var(--f-heading);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .04em;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .15s, transform .15s;
  z-index: 10;
  pointer-events: none;
}
body.is-editing [data-editable-section]:hover::before { opacity: 1; transform: translateY(0); }

[data-section-hidden="true"] { display: none !important; }

/* Device preview frames in body */
body.preview-tablet main,
body.preview-tablet .site-header__inner,
body.preview-tablet .site-footer .container { max-width: 900px; margin-left: auto; margin-right: auto; }
body.preview-mobile main,
body.preview-mobile .site-header__inner,
body.preview-mobile .site-footer .container { max-width: 440px; margin-left: auto; margin-right: auto; }
body.preview-tablet, body.preview-mobile { background: #EFEFEF; }

/* Helper */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-2 { margin-bottom: 32px; }
/* ============== PRODUCT RATING + TITLE ============== */
.product-rating {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  font-size: .92rem;
}
.product-rating__value {
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1rem;
  color: var(--c-charcoal);
}
.product-rating__stars {
  color: #22C55E;
  letter-spacing: 1px;
  font-size: 1rem;
}
.product-rating__count {
  color: var(--c-muted);
  font-size: .88rem;
}
.product-title {
  font-family: var(--f-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--c-charcoal);
  margin: 0 0 20px;
  letter-spacing: -.01em;
}

@media (max-width: 768px) {
  .product-title { font-size: 1.5rem; margin-bottom: 16px; }
  .product-rating { font-size: .85rem; }
}/* ============== UPLOADED IMAGES IN BUNDLE THUMBS ============== */
.bundle-option__thumb--img,
.bundle-sub__thumb--img {
  background: transparent !important;
  overflow: hidden;
  padding: 0;
}
.bundle-option__thumb--img::after,
.bundle-sub__thumb--img::after {
  content: none !important;
}
.bundle-option__thumb img,
.bundle-sub__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--r-sm);
  display: block;
}
/* ============== TESTIMONIAL SLIDER ============== */
.testimonial-slider {
  margin: 24px 0 16px;
  position: relative;
  background: var(--c-rose);
  border-radius: var(--r-card);
  padding: 16px 40px;
  overflow: hidden;
}
.testimonial-slider__track {
  display: flex;
  scroll-snap-type: x mandatory;
  overflow-x: auto;
  scroll-behavior: smooth;
  gap: 16px;
  scrollbar-width: none;
}
.testimonial-slider__track::-webkit-scrollbar { display: none; }
.testimonial-card {
  flex: 0 0 100%;
  scroll-snap-align: center;
  display: flex;
  gap: 14px;
  align-items: center;
}
.testimonial-card__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.testimonial-card__avatar--text {
  background: var(--c-magenta);
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--f-heading);
  font-weight: 700;
  font-size: 1.4rem;
}
.testimonial-card__main { flex: 1; min-width: 0; }
.testimonial-card__head {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .9rem;
  margin-bottom: 4px;
  font-family: var(--f-heading);
}
.testimonial-card__verified {
  width: 16px;
  height: 16px;
  background: var(--c-magenta);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: .65rem;
  font-weight: 700;
}
.testimonial-card__stars {
  color: #22C55E;
  font-size: .9rem;
  margin-left: auto;
  letter-spacing: 1px;
}
.testimonial-card__quote {
  font-size: .82rem;
  margin: 0;
  color: var(--c-charcoal);
  line-height: 1.45;
}
.testimonial-slider__nav {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #fff;
  color: var(--c-magenta);
  font-size: 1.4rem;
  border: none;
  cursor: pointer;
  z-index: 2;
  display: grid;
  place-items: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
  line-height: 1;
}
.testimonial-slider__nav--prev { left: 6px; }
.testimonial-slider__nav--next { right: 6px; }
.testimonial-slider__dots {
  display: flex;
  justify-content: center;
  gap: 5px;
  margin-top: 10px;
}
.testimonial-slider__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(216,75,107,.3);
  cursor: pointer;
  transition: background .15s;
}
.testimonial-slider__dot.is-active { background: var(--c-magenta); }

/* ============== INFO ACCORDIONS ============== */
.info-accordions { margin-top: 16px; }
.info-accordion {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  padding: 14px 18px;
  margin-bottom: 8px;
  cursor: pointer;
}
.info-accordion summary {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-heading);
  font-weight: 600;
  font-size: .92rem;
  letter-spacing: .04em;
  color: var(--c-charcoal);
}
.info-accordion summary::-webkit-details-marker { display: none; }
.info-accordion summary::after {
  content: '▾';
  margin-left: auto;
  transition: transform .2s;
  color: var(--c-muted);
  font-size: .9rem;
}
.info-accordion[open] summary::after { transform: rotate(180deg); }
.info-accordion__icon { font-size: 1rem; line-height: 1; }
.info-accordion__title { letter-spacing: .06em; }
.info-accordion__body {
  margin-top: 14px;
  font-size: .9rem;
  color: #444;
  line-height: 1.6;
}
.info-accordion__body p { margin: 0 0 12px; }
.info-accordion__body p:last-child { margin-bottom: 0; }
.info-accordion__body ul { padding-left: 20px; margin: 8px 0; }
.info-accordion__body li { margin-bottom: 6px; }
.info-accordion__body strong { color: var(--c-charcoal); font-weight: 600; }
/* ============== SMOOTH SCROLL TO SPECIAL OFFER ============== */
html { scroll-behavior: smooth; }
#special-offer {
  scroll-margin-top: 96px; /* né sticky header */
}

/* Highlight effect khi scroll tới */
@keyframes flash-magenta {
  0% { box-shadow: 0 0 0 0 rgba(216,75,107, 0); }
  25% { box-shadow: 0 0 0 6px rgba(216,75,107, .35); }
  100% { box-shadow: 0 0 0 0 rgba(216,75,107, 0); }
}
#special-offer.is-flashing .bundle-selector,
#special-offer.is-flashing > .bundle-promo-title {
  animation: flash-magenta 1.2s ease;
  border-radius: var(--r-card);
}

@media (max-width: 768px) {
  #special-offer { scroll-margin-top: 76px; }
}
ErgoLift™ Landing Page Sections
   ============================================================ */

/* ---- LP HERO ---- */
.lp-hero {
  padding: 120px 0 80px;
  background:
    radial-gradient(circle at 80% 20%, rgba(243,198,194,.4), transparent 50%),
    radial-gradient(circle at 10% 80%, rgba(216,75,107,.08), transparent 50%),
    var(--c-offwhite);
}
.lp-hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.lp-hero h1 { font-size: clamp(2.1rem, 4vw, 3.4rem); margin-bottom: 18px; }
.lp-hero__sub { font-size: 1.1rem; color: #555; margin-bottom: 28px; max-width: 540px; }
.trust-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px;
  margin: 28px 0 32px; list-style: none; padding: 0;
}
.trust-grid li {
  display: flex; gap: 10px; align-items: center;
  font-size: .95rem; font-weight: 500; color: var(--c-charcoal);
}
.trust-grid li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  flex-shrink: 0; display: grid; place-items: center;
  color: #fff; font-size: .7rem; font-weight: 800;
}
.lp-offer {
  display: inline-flex; flex-wrap: wrap; gap: 18px;
  padding: 18px 24px; background: #fff; border-radius: var(--r-card);
  box-shadow: var(--sh-soft); margin-bottom: 28px;
}
.lp-offer__item {
  font-size: .9rem; font-weight: 600; color: var(--c-charcoal);
  display: flex; align-items: center; gap: 6px;
}
.lp-offer__item strong { color: var(--c-magenta); font-weight: 800; font-size: 1.05rem; }
.lp-hero__media {
  aspect-ratio: 1/1; border-radius: 28px; position: relative; overflow: hidden;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), transparent 60%),
    linear-gradient(135deg, #fff 0%, var(--c-rose) 60%, var(--c-magenta) 130%);
  box-shadow: 0 30px 80px rgba(216,75,107,.18);
}
.lp-hero__media img { width: 100%; height: 100%; object-fit: cover; }

/* ---- LP SECTION HEAD ---- */
.lp-sec-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.lp-sec-head h2 { margin-bottom: 12px; }
.lp-sec-head p { color: var(--c-muted); font-size: 1.05rem; }

/* ---- LP UGC + TESTIMONIAL ---- */
.ugc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.ugc-tile {
  aspect-ratio: 3/4; border-radius: var(--r-card); position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--c-rose) 0%, #fff 50%, var(--c-rose) 100%);
  box-shadow: var(--sh-soft); transition: transform .3s;
}
.ugc-tile:hover { transform: translateY(-6px); }
.ugc-tile::after {
  content: attr(data-label); position: absolute; left: 16px; bottom: 16px;
  color: #fff; font-family: var(--f-heading); font-weight: 600; font-size: .85rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.4); z-index: 2;
}
.ugc-tile::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.35) 100%);
}
.testimonial-card {
  background: #fff; max-width: 720px; margin: 56px auto 0;
  padding: 40px; border-radius: var(--r-card); text-align: center;
  box-shadow: var(--sh-soft); position: relative;
}
.testimonial-card::before {
  content: '"'; position: absolute; top: -20px; left: 40px;
  font-family: Georgia, serif; font-size: 6rem; color: var(--c-magenta);
  line-height: 1; opacity: .15;
}
.testimonial-card p { font-size: 1.15rem; font-style: italic; color: var(--c-charcoal); margin-bottom: 16px; line-height: 1.6; }
.testimonial-card cite { font-style: normal; font-family: var(--f-heading); font-weight: 600; color: var(--c-magenta); font-size: .9rem; letter-spacing: .05em; }

/* ---- LP BENEFITS ---- */
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.benefit-card {
  background: #fff; padding: 36px 28px; border-radius: var(--r-card);
  box-shadow: var(--sh-soft); transition: transform .3s, box-shadow .3s;
  border-top: 4px solid var(--c-magenta);
}
.benefit-card:hover { transform: translateY(-6px); box-shadow: var(--sh-hover); }
.benefit-card__icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  display: grid; place-items: center; color: #fff;
  margin-bottom: 20px; font-size: 1.5rem;
}
.benefit-card h3 { font-size: 1.15rem; margin-bottom: 10px; }
.benefit-card__concern {
  display: inline-block; font-size: .72rem; font-weight: 700;
  letter-spacing: .15em; color: var(--c-magenta);
  text-transform: uppercase; margin-bottom: 10px;
}
.benefit-card p { color: #555; font-size: .95rem; margin: 0; }

/* ---- LP TECHNOLOGY ---- */
.tech-section { background: linear-gradient(180deg, var(--c-offwhite) 0%, #fff 100%); }
.tech-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.tech-card {
  text-align: center; padding: 32px 20px; background: #fff;
  border-radius: var(--r-card); border: 1px solid var(--c-line); transition: all .3s;
}
.tech-card:hover { border-color: var(--c-magenta); transform: translateY(-4px); }
.tech-card__num {
  font-family: var(--f-heading); font-size: 2.5rem; font-weight: 800;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  -webkit-background-clip: text; background-clip: text;
  color: transparent; line-height: 1; margin-bottom: 12px;
}
.tech-card h4 { font-size: 1rem; margin-bottom: 8px; }
.tech-card p { font-size: .88rem; color: var(--c-muted); margin: 0; }

/* ---- LP RESULTS ---- */
.results-section {
  background: radial-gradient(circle at 90% 10%, rgba(243,198,194,.3), transparent 60%), var(--c-offwhite);
}
.results-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.results-list { list-style: none; padding: 0; margin: 0; }
.results-list li {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 18px 0; border-bottom: 1px solid var(--c-line);
  font-size: 1.05rem; color: var(--c-charcoal);
}
.results-list li:last-child { border-bottom: none; }
.results-list li::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-magenta); margin-top: 10px; flex-shrink: 0;
}
.results-visual {
  aspect-ratio: 4/5; border-radius: 28px;
  background: linear-gradient(135deg, var(--c-rose) 0%, #fff 50%, rgba(216,75,107,.2) 100%);
  box-shadow: 0 24px 60px rgba(216,75,107,.15);
  display: grid; place-items: center; overflow: hidden;
}

/* ---- LP COMPARISON ---- */
.comparison-wrap {
  max-width: 920px; margin: 0 auto;
  background: #fff; border-radius: var(--r-card);
  overflow: hidden; box-shadow: var(--sh-soft);
}
.comparison-row {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  align-items: center; padding: 18px 28px;
  border-bottom: 1px solid var(--c-line); font-size: .95rem;
}
.comparison-row:last-child { border-bottom: none; }
.comparison-row--head {
  background: var(--c-charcoal); color: #fff;
  font-family: var(--f-heading); font-weight: 700;
  font-size: .85rem; letter-spacing: .1em;
  text-transform: uppercase; padding: 22px 28px;
}
.comparison-row--head .col-erg { color: var(--c-rose); }
.comparison-row > div { text-align: center; }
.comparison-row > div:first-child { text-align: left; font-weight: 500; }
.comparison-row .yes { color: var(--c-magenta); font-weight: 700; font-size: 1.2rem; }
.comparison-row .no { color: #ccc; font-size: 1.2rem; }

/* ---- LP ROUTINE ---- */
.routine-section { background: var(--c-charcoal); color: #fff; }
.routine-section h2, .routine-section .lp-sec-head p { color: #fff; }
.routine-section .lp-sec-head p { opacity: .7; }
.routine-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.routine-step {
  position: relative; padding: 32px 24px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-card); transition: background .3s;
}
.routine-step:hover { background: rgba(255,255,255,.08); border-color: var(--c-rose); }
.routine-step__num {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  display: grid; place-items: center; color: #fff;
  font-family: var(--f-heading); font-weight: 800; margin-bottom: 18px;
}
.routine-step h4 { color: #fff; font-size: 1.05rem; margin-bottom: 10px; }
.routine-step p { color: rgba(255,255,255,.65); font-size: .9rem; margin: 0; }

/* ---- LP TRUST & FAQ ---- */
.guarantee-card {
  max-width: 720px; margin: 0 auto 64px; padding: 40px;
  border-radius: var(--r-card);
  background: linear-gradient(135deg, #fff 0%, var(--c-rose) 200%);
  box-shadow: var(--sh-soft); text-align: center; border: 1px solid var(--c-line);
}
.guarantee-card__shield {
  width: 72px; height: 72px; margin: 0 auto 20px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-rose), var(--c-magenta));
  display: grid; place-items: center; color: #fff;
  font-size: 2rem; box-shadow: 0 12px 32px rgba(216,75,107,.3);
}
.guarantee-card h3 { font-size: 1.4rem; margin-bottom: 10px; }
.guarantee-card p { color: #555; margin: 0 auto; max-width: 480px; }

.faq-list { max-width: 760px; margin: 0 auto; }
.faq-list .faq-item {
  background: #fff; border-radius: var(--r-md);
  margin-bottom: 12px; box-shadow: var(--sh-soft); overflow: hidden;
}
.faq-list .faq-item summary {
  padding: 22px 28px; cursor: pointer;
  font-family: var(--f-heading); font-weight: 600; font-size: 1rem;
  color: var(--c-charcoal); list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  transition: color .2s;
}
.faq-list .faq-item summary::-webkit-details-marker { display: none; }
.faq-list .faq-item summary::after {
  content: '+'; font-size: 1.5rem; color: var(--c-magenta); transition: transform .3s;
}
.faq-list .faq-item[open] summary::after { transform: rotate(45deg); }
.faq-list .faq-item[open] summary { color: var(--c-magenta); }
.faq-item__body { padding: 0 28px 24px; color: #555; font-size: .95rem; line-height: 1.7; }

/* ---- LP FINAL CTA ---- */
.final-cta {
  padding: 80px 0;
  background:
    radial-gradient(circle at 30% 50%, rgba(216,75,107,.12), transparent 60%),
    linear-gradient(135deg, var(--c-rose) 0%, #fff 100%);
  text-align: center;
}
.final-cta h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); margin-bottom: 18px; }
.final-cta p { font-size: 1.1rem; max-width: 560px; margin: 0 auto 32px; color: #444; }
.price-display { display: inline-flex; align-items: baseline; gap: 12px; margin-bottom: 28px; }
.price-display__current {
  font-family: var(--f-heading); font-size: 3rem; font-weight: 800;
  color: var(--c-magenta); letter-spacing: -.02em;
}
.price-display__label {
  font-family: var(--f-heading); font-size: .9rem; font-weight: 600;
  letter-spacing: .15em; text-transform: uppercase; color: var(--c-muted);
}

/* ---- LP RESPONSIVE ---- */
@media (max-width: 960px) {
  .lp-hero__grid, .results-grid { grid-template-columns: 1fr; gap: 40px; }
  .benefits-grid { grid-template-columns: 1fr; }
  .tech-grid, .routine-grid, .ugc-grid { grid-template-columns: repeat(2, 1fr); }
  .comparison-row { grid-template-columns: 1.3fr 1fr 1fr; padding: 14px 18px; font-size: .85rem; }
}
@media (max-width: 560px) {
  .trust-grid { grid-template-columns: 1fr; }
  .tech-grid, .routine-grid, .ugc-grid { grid-template-columns: 1fr; }
  .lp-offer { flex-direction: column; gap: 10px; }
}