/**
 * Product LP + storefront conversion polish (TikTok / Snapchat cold traffic).
 *
 * @package MarameBeauty
 */

/* —— Hero & primary CTA —— */
.site-main--product-lp .product-hero {
  background: linear-gradient(180deg, var(--cream) 0%, var(--white) 42%);
}

.site-main--product-lp .product-title {
  font-size: clamp(1.375rem, 4.5vw, 2rem);
  letter-spacing: -0.02em;
}

.site-main--product-lp .product-desc {
  font-size: 1.0625rem;
  line-height: 1.8;
}

.site-main--product-lp .product-promo-banner {
  background: linear-gradient(90deg, rgba(200, 169, 110, 0.18), rgba(200, 169, 110, 0.06));
  font-weight: 700;
  animation: marame-promo-pulse 2.5s ease-in-out infinite;
}

@keyframes marame-promo-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200, 169, 110, 0.25); }
  50% { box-shadow: 0 0 0 6px rgba(200, 169, 110, 0); }
}

.site-main--product-lp #product-add-to-cart.btn-primary {
  width: 100%;
  min-height: 3.25rem;
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 8px 28px rgba(139, 109, 60, 0.35);
  transition: transform 0.15s ease, box-shadow 0.2s ease;
}

.site-main--product-lp #product-add-to-cart.btn-primary:active {
  transform: scale(0.98);
}

.site-main--product-lp .tier-option.selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(200, 169, 110, 0.35), var(--shadow-gold);
}

.site-main--product-lp .tier-option.highlighted {
  background: linear-gradient(135deg, rgba(200, 169, 110, 0.08), rgba(255, 255, 255, 0.95));
}

.site-main--product-lp .quantity-selector-card {
  border: 1px solid rgba(200, 169, 110, 0.25);
  box-shadow: var(--shadow-card);
}

/* —— Sticky mobile CTA —— */
.sticky-add-to-cart.visible {
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
}

.sticky-cta-full {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 1.0625rem;
}

.sticky-cta-price {
  font-weight: 800;
  opacity: 0.95;
  padding: 0.125rem 0.5rem;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 0.5rem;
}

/* —— Social proof (reviews) — matches Next ProductReviewsSection bg-charcoal —— */
.site-main--product-lp .reviews-section {
  background: var(--charcoal);
  border-block: none;
}

.site-main--product-lp .reviews-section .section-header {
  margin-bottom: 2.5rem;
}

.site-main--product-lp .review-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold);
}

/* —— Science / pain —— */
.site-main--product-lp .science-claim-box {
  background: linear-gradient(135deg, rgba(200, 169, 110, 0.08), rgba(255, 255, 255, 0.9));
}

.site-main--product-lp .science-doctor-quote {
  font-size: 1.0625rem;
  border-inline-start: 3px solid var(--gold);
  padding-inline-start: 1rem;
}

/* —— Comparison —— */
.site-main--product-lp .comparison-col-ours {
  transform: scale(1.02);
  z-index: 1;
}

@media (max-width: 767px) {
  .site-main--product-lp .comparison-columns {
    gap: 1.25rem;
  }
}

/* —— FAQ trust —— */
.site-main--product-lp .faq-item.open {
  border-color: rgba(200, 169, 110, 0.35);
  box-shadow: var(--shadow-card);
}

/* —— Homepage polish (same ICP) —— */
.hero-section .hero-title {
  font-size: clamp(1.75rem, 5vw, 2.75rem);
}

.hero-section .btn-primary {
  min-height: 3rem;
  font-weight: 800;
}

.trust-bar-section .trust-bar-item {
  font-weight: 700;
}

.featured-products .product-card--v2 .product-card-cta {
  font-size: 0.9375rem;
}

.final-cta .btn-primary {
  min-height: 3.25rem;
  font-size: 1.125rem;
}

/* —— Mobile product gallery —— */
@media (max-width: 1023px) {
  .site-main--product-lp .product-main-image {
    border-radius: 1rem;
    box-shadow: var(--shadow-gold-lg);
  }

  .site-main--product-lp .product-thumbnails {
    gap: 0.375rem;
  }

  .site-main--product-lp .product-trust-bar {
    margin-block: 0.5rem 0;
  }
}
