/** Shopify CDN: Minification failed

Line 23:0 All "@import" rules must come first

**/
/* ==============================================
   APAISEO — Custom CSS (matches section HTML)
   Colors: #3B735E, #F5F0EB, #1a1a1a, #f3f3f3
   ============================================== */
:root {
  --ap-green: #3B735E;
  --ap-beige: #F5F0EB;
  --ap-dark: #1a1a1a;
  --ap-gray: #f3f3f3;
  --ap-dark-section: #2e2a39;
  --ap-stars: #F2C94C;
  --ap-text-secondary: #555;
  --ap-radius: 12px;
  --ap-radius-sm: 6px;
}

/* ---- LOGO STYLING ---- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital@1&display=swap');
.header__logo {
  text-decoration: none !important;
}
.header__logo img { display: none !important; }
.ap-logo-text {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  color: #3B735E;
  letter-spacing: 0;
}
.ap-logo-text sup {
  font-size: 10px;
  font-style: normal;
  vertical-align: super;
  top: -0.6em;
  position: relative;
}
@media (max-width: 768px) {
  .ap-logo-text { font-size: 26px; }
  .ap-logo-text sup { font-size: 8px; }
}

/* ---- HIDE ACCOUNT ICON ---- */
.header__icon-account { display: none !important; }

/* ---- HIDE FULLSTACK ELEMENTS ON PRODUCT PAGE ---- */
/* Hide "En promotion" badge on gallery only (keep price badge) */
.product-media-gallery .badge,
.product-media-gallery__media .badge { display: none !important; }

/* Hide Fullstack sticky ATC bar at bottom */
.sticky-add-to-cart,
sticky-add-to-cart,
[data-ref="sticky-add-to-cart"] { display: none !important; }

/* Hide Fullstack's own ATC button (we use our ap-pi one) */
.product-section__product-info > .product-form-component,
.product-section__product-info .product-add-to-cart-button { display: none !important; }

/* Hide dynamic checkout buttons (Shop Pay, Google Pay etc.) */
.product-section .shopify-payment-button,
.product-section [class*="accelerated"] { display: none !important; }

/* Hide breadcrumb */
.breadcrumb, .breadcrumbs { display: none !important; }

/* Hide quantity selector */
.product-quantity-selector { display: none !important; }

/* Hide recommended products */
.product-recommendations { display: none !important; }

/* ---- PRICE STYLE (like SPINEA) ---- */
.product-section .price-container .prices {
  font-size: 28px !important;
  display: flex !important;
  align-items: baseline !important;
  gap: 8px !important;
}
.product-section .price-container .price {
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--ap-green) !important;
}
.product-section .price-container .compare-at-price {
  font-size: 16px !important;
  color: #999 !important;
}
/* Badge NOIR comme SPINEA */
.product-section .price-container .badge {
  background: #1a1a1a !important;
  color: #fff !important;
  border-radius: 20px !important;
  padding: 5px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.3px !important;
}
.product-section .price-container .badge .badge__text,
.product-section .price-container .badge .badge__savings {
  color: #fff !important;
}
.product-section .price-container .badge .badge__savings::before {
  content: "-";
}

/* ---- GLOBAL BUTTON ---- */
.ap-btn { display: inline-block; font-family: 'Poppins', sans-serif; font-size: 16px; font-weight: 600; text-decoration: none; border: none; cursor: pointer; transition: background 0.3s, transform 0.2s; }
.ap-btn--primary { background: var(--ap-green); color: #fff; padding: 16px 32px; border-radius: var(--ap-radius-sm); }
.ap-btn--primary:hover { background: #2f6350; transform: translateY(-1px); }

/* ---- ANIMATIONS ---- */
.ap-animate { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
.ap-animate.ap-visible, .ap-animate.ap-revealed { opacity: 1; transform: translateY(0); }

/* Scroll reveal — auto-applied by JS */
.ap-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.ap-reveal.ap-revealed {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger cards */
.ap-testimonials__card.ap-reveal:nth-child(2) { transition-delay: 0.1s; }
.ap-testimonials__card.ap-reveal:nth-child(3) { transition-delay: 0.2s; }
.ap-health__card.ap-reveal:nth-child(2) { transition-delay: 0.08s; }
.ap-health__card.ap-reveal:nth-child(3) { transition-delay: 0.16s; }
.ap-health__card.ap-reveal:nth-child(4) { transition-delay: 0.24s; }
.ap-health__card.ap-reveal:nth-child(5) { transition-delay: 0.32s; }
.ap-health__card.ap-reveal:nth-child(6) { transition-delay: 0.40s; }
@media (prefers-reduced-motion: reduce) {
  .ap-reveal, .ap-animate { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ==================== COUNTDOWN ==================== */
.ap-countdown { display: flex; align-items: center; justify-content: center; gap: 24px; padding: 10px 20px; font-family: 'Poppins', sans-serif; }
.ap-countdown__text { text-align: right; }
.ap-countdown__text h2 { color: #fff; font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; margin: 0; line-height: 1.3; font-weight: 700; }
.ap-countdown__text p { color: #fff; font-size: 12px; margin: 2px 0 0; opacity: .85; }
.ap-countdown__timer { display: flex; align-items: flex-start; gap: 4px; }
.ap-countdown__timer .cd-block { display: flex; flex-direction: column; align-items: center; }
.ap-countdown__timer .cd-num { color: #fff; font-weight: 700; font-size: 20px; font-variant-numeric: tabular-nums; min-width: 28px; text-align: center; }
.ap-countdown__timer .cd-label { color: #fff; font-size: 8px; text-transform: capitalize; opacity: .8; }
.ap-countdown__timer .cd-sep { color: #fff; font-weight: 700; font-size: 20px; line-height: 1; padding: 0 1px; }
@media (max-width: 480px) {
  .ap-countdown { gap: 16px; padding: 8px 12px; }
  .ap-countdown__text h2 { font-size: 13px; }
  .ap-countdown__text p { font-size: 10px; }
  .ap-countdown__timer .cd-num { font-size: 16px; min-width: 22px; }
  .ap-countdown__timer .cd-sep { font-size: 16px; }
}

/* ==================== HERO ==================== */
.ap-hero { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-hero__container { max-width: 1300px; margin: 0 auto; padding: 0 40px; }
.ap-hero__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.ap-hero__heading { font-size: 48px; font-weight: 600; color: var(--ap-dark); margin: 0 0 16px; line-height: 1.15; }
.ap-hero__desc { font-size: 16px; color: var(--ap-text-secondary); line-height: 1.7; margin: 0 0 24px; }
.ap-hero__desc p { margin: 0 0 12px; }
.ap-hero__media { border-radius: var(--ap-radius); overflow: hidden; }
.ap-hero__img { width: 100%; height: auto; display: block; border-radius: var(--ap-radius); }
.ap-hero__placeholder { width: 100%; aspect-ratio: 1; background: #ddd; border-radius: var(--ap-radius); display: flex; align-items: center; justify-content: center; color: #999; font-size: 14px; }
@media (max-width: 768px) {
  .ap-hero { padding: 30px 0; }
  .ap-hero__container { padding: 0 20px; }
  .ap-hero__grid { grid-template-columns: 1fr; gap: 24px; }
  .ap-hero__heading { font-size: 32px; }
  .ap-hero__desc { font-size: 14px; }
  .ap-hero__media { order: -1; }
}

/* ==================== LOGOS MARQUEE ==================== */
.ap-logos { padding: 40px 0; font-family: 'Poppins', sans-serif; }
.ap-logos__container { max-width: 1300px; margin: 0 auto; padding: 0 40px; }
.ap-logos__title { text-align: center; text-transform: uppercase; letter-spacing: 3px; font-size: 14px; color: #888; margin: 0 0 28px; font-weight: 500; }
.ap-logos__marquee { overflow: hidden; width: 100%; }
.ap-logos__track { display: flex; width: max-content; animation: ap-marquee 30s linear infinite; align-items: center; }
.ap-logos__track:hover { animation-play-state: paused; }
@keyframes ap-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ap-logos__item { display: flex; align-items: center; flex-shrink: 0; }
.ap-logos__img { height: 55px; width: auto; margin: 0 50px; }
.ap-logos__text-logo { font-family: 'Poppins', serif; font-size: 22px; font-weight: 600; color: #1a1a1a; margin: 0 50px; white-space: nowrap; letter-spacing: 0.5px; flex-shrink: 0; }
@media (max-width: 768px) {
  .ap-logos { padding: 28px 0; }
  .ap-logos__container { padding: 0 0; }
  .ap-logos__img { height: 40px; margin: 0 30px; }
  .ap-logos__text-logo { font-size: 16px; margin: 0 30px; }
}

/* ==================== IMAGE + TEXT ==================== */
.ap-imgtext { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-imgtext__container { max-width: 1300px; margin: 0 auto; padding: 0 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.ap-imgtext--reverse .ap-imgtext__container { direction: rtl; }
.ap-imgtext--reverse .ap-imgtext__container > * { direction: ltr; }
.ap-imgtext__media { border-radius: var(--ap-radius); overflow: hidden; }
.ap-imgtext__img { width: 100%; height: auto; display: block; border-radius: var(--ap-radius); }
.ap-imgtext__video { width: 100%; border-radius: var(--ap-radius); aspect-ratio: 1 / 1; object-fit: cover; }
.ap-imgtext__placeholder { width: 100%; aspect-ratio: 1; background: #ddd; border-radius: var(--ap-radius); display: flex; align-items: center; justify-content: center; color: #999; font-size: 14px; }
.ap-imgtext__heading { font-size: 28px; font-weight: 600; margin: 0 0 16px; line-height: 1.3; }
.ap-imgtext__text { font-size: 15px; line-height: 1.7; }
.ap-imgtext__text p { margin: 0 0 12px; }
.ap-imgtext__stat { font-style: italic; color: var(--ap-text-secondary); margin-top: 16px; font-size: 14px; }
@media (max-width: 768px) {
  .ap-imgtext { padding: 30px 0; }
  .ap-imgtext__container { grid-template-columns: 1fr; gap: 24px; padding: 0 20px; direction: ltr !important; }
  .ap-imgtext__media { order: -1; }
  .ap-imgtext__heading { font-size: 22px; }
  .ap-imgtext__text { font-size: 14px; }
}

/* ==================== TESTIMONIALS ==================== */
.ap-testimonials { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-testimonials__container { max-width: 1300px; margin: 0 auto; padding: 0 40px; }
.ap-testimonials__title { text-align: center; font-size: 32px; font-weight: 600; margin: 0 0 32px; color: var(--ap-dark); }
.ap-testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ap-testimonials__card { background: #fff; border-radius: var(--ap-radius); box-shadow: 0 2px 12px rgba(0,0,0,0.06); overflow: hidden; }
.ap-testimonials__card-img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.ap-testimonials__card-img-placeholder { width: 100%; aspect-ratio: 1; background: #ddd; display: flex; align-items: center; justify-content: center; color: #999; font-size: 13px; }
.ap-testimonials__card-body { padding: 20px; }
.ap-testimonials__stars { display: flex; gap: 2px; margin-bottom: 10px; }
.ap-testimonials__star { width: 16px; height: 16px; color: var(--ap-stars); }
.ap-testimonials__star--empty { color: #ddd; }
.ap-testimonials__quote { font-size: 13px; font-style: italic; line-height: 1.6; color: #333; margin: 0 0 12px; }
.ap-testimonials__author { font-size: 12px; font-weight: 600; color: var(--ap-dark); }
.ap-testimonials__verified { font-size: 11px; color: var(--ap-green); margin-left: 4px; }
@media (max-width: 768px) {
  .ap-testimonials { padding: 30px 0; }
  .ap-testimonials__container { padding: 0 20px; }
  .ap-testimonials__title { font-size: 24px; margin-bottom: 20px; }
  .ap-testimonials__grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ==================== TRUST BAR ==================== */
.ap-trust { padding: 14px 0; font-family: 'Poppins', sans-serif; }
.ap-trust__container { display: flex; justify-content: center; align-items: center; gap: 40px; max-width: 1300px; margin: 0 auto; padding: 0 40px; }
.ap-trust__item { display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.ap-trust__icon { flex-shrink: 0; }
.ap-trust__icon svg { width: 22px; height: 22px; }
.ap-trust__label { font-size: 12px; font-weight: 500; color: #fff; }
@media (max-width: 768px) {
  .ap-trust__container { flex-direction: column; gap: 8px; padding: 14px 24px; align-items: flex-start; }
  .ap-trust__label { font-size: 11px; }
}

/* ==================== HEALTH GRID ==================== */
.ap-health { padding: 80px 20px; font-family: 'Poppins', sans-serif; text-align: center; }
.ap-health__container { max-width: 900px; margin: 0 auto; }
.ap-health__header { margin-bottom: 40px; }
.ap-health__title { font-size: 28px; font-weight: 700; color: var(--ap-dark); margin: 0 0 12px; }
.ap-health__subtitle { font-size: 14px; color: var(--ap-text-secondary); max-width: 700px; margin: 0 auto; line-height: 1.6; }
.ap-health__subtitle p { margin: 0; }
.ap-health__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ap-health__card { background: #fff; border-radius: var(--ap-radius); border: 1px solid #e0e0e0; padding: 30px 20px; text-align: center; }
.ap-health__card-icon { margin-bottom: 12px; display: flex; justify-content: center; }
.ap-health__card-icon svg { width: 110px; height: 110px; }
.ap-health__card-icon img.ap-health__card-img { width: 150px; height: 150px; object-fit: contain; display: block; margin: 0 auto; }
.ap-health__card-title { font-size: 15px; font-weight: 600; color: var(--ap-dark); margin: 0 0 10px; }
.ap-health-toggle { font-size: 13px; color: var(--ap-text-secondary); cursor: pointer; border: none; background: none; font-family: 'Poppins', sans-serif; text-decoration: underline; display: inline-flex; align-items: center; gap: 4px; padding: 4px 8px; }
.ap-health-toggle:hover { color: var(--ap-green); }
.ap-health-toggle .arrow { transition: transform 0.3s; display: inline-block; font-size: 10px; }
.ap-health-toggle.active .arrow { transform: rotate(180deg); }
.ap-health__card-desc { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, margin-top 0.3s ease; font-size: 13px; color: var(--ap-text-secondary); line-height: 1.6; margin-top: 0; text-align: left; padding: 0 8px; }
.ap-health__card-desc p { margin: 0; }
.ap-health__card-details { display: flex; flex-direction: column; align-items: center; }
@media (max-width: 768px) {
  .ap-health { padding: 30px 12px; }
  .ap-health__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .ap-health__title { font-size: 22px; }
  .ap-health__card-icon svg { width: 40px; height: 40px; }
}

/* ==================== COMPARISON TABLE ==================== */
.ap-compare { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-compare__container { max-width: 700px; margin: 0 auto; padding: 0 20px; }
.ap-compare__title { text-align: center; font-size: 28px; font-weight: 600; margin: 0 0 12px; color: var(--ap-dark); }
.ap-compare__subtitle { text-align: center; font-size: 14px; color: var(--ap-text-secondary); margin: 0 0 32px; line-height: 1.6; }
.ap-compare__subtitle p { margin: 0; }
.ap-compare__table { width: 100%; border-collapse: separate; border-spacing: 0; }
.ap-compare__table th, .ap-compare__table td { padding: 14px 16px; text-align: center; font-size: 14px; }
.ap-compare__table th:first-child, .ap-compare__table td:first-child { text-align: left; font-weight: 600; }
.ap-compare__header th { font-weight: 600; font-size: 15px; }
.ap-compare__brand-col { background: var(--ap-dark-section); color: #fff; border-radius: 8px 8px 0 0; }
.ap-compare__others-col { background: var(--ap-gray); border-radius: 8px 8px 0 0; color: var(--ap-dark); }
.ap-compare__table tbody td { border-bottom: 1px solid #eee; }
.ap-compare__table tbody td:nth-child(2) { background: rgba(46,42,57,0.03); }
.ap-compare__check { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: #53af01; }
.ap-compare__check svg { width: 14px; height: 14px; }
.ap-compare__cross { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: #dbdbdb; }
.ap-compare__cross svg { width: 12px; height: 12px; }
@media (max-width: 768px) {
  .ap-compare__table th, .ap-compare__table td { padding: 10px 8px; font-size: 12px; }
  .ap-compare__title { font-size: 22px; }
}

/* ==================== BONUS GIFT ==================== */
.ap-bonus { padding: 70px 20px; font-family: 'Poppins', sans-serif; }
.ap-bonus__container { max-width: 1000px; margin: 0 auto; display: flex; align-items: center; gap: 40px; }
.ap-bonus__media { flex: 1; min-width: 0; }
.ap-bonus__img { width: 100%; height: auto; border-radius: 16px; display: block; }
.ap-bonus__placeholder { width: 100%; aspect-ratio: 1; background: #ddd; border-radius: 16px; display: flex; align-items: center; justify-content: center; color: #999; font-size: 14px; }
.ap-bonus__content { flex: 1; min-width: 0; }
.ap-bonus__heading { font-size: 28px; font-weight: 500; color: var(--ap-dark); margin: 0 0 16px; }
.ap-bonus__pricing { font-size: 24px; margin: 0 0 20px; display: flex; align-items: baseline; gap: 8px; }
.ap-bonus__old-price { text-decoration: line-through; color: #999; }
.ap-bonus__free { font-weight: 700; color: var(--ap-green); }
.ap-bonus__desc { font-size: 14px; color: #333; line-height: 1.6; }
.ap-bonus__desc p { margin: 0 0 12px; }
@media (max-width: 768px) {
  .ap-bonus__container { flex-direction: column; gap: 24px; }
  .ap-bonus__heading { font-size: 22px; }
  .ap-bonus__pricing { font-size: 20px; }
  .ap-bonus__desc { font-size: 13px; }
}

/* ==================== GUARANTEE ==================== */
.ap-guarantee { padding: 70px 20px; font-family: 'Poppins', sans-serif; text-align: center; }
.ap-guarantee__container { max-width: 600px; margin: 0 auto; }
.ap-guarantee__badge { width: 120px; height: 120px; margin: 0 auto 24px; display: block; }
.ap-guarantee__badge img { width: 100%; height: 100%; object-fit: contain; border-radius: 50%; }
.ap-guarantee__badge-placeholder { width: 120px; height: 120px; border-radius: 50%; background: #ddd; margin: 0 auto 24px; display: flex; align-items: center; justify-content: center; color: #999; font-size: 11px; }
.ap-guarantee__heading { font-size: 32px; font-weight: 500; color: var(--ap-dark); margin: 0 0 20px; }
.ap-guarantee__text { font-size: 15px; color: var(--ap-text-secondary); line-height: 1.7; }
.ap-guarantee__text p { margin: 0 0 12px; }
@media (max-width: 768px) {
  .ap-guarantee__heading { font-size: 22px; }
  .ap-guarantee__text { font-size: 13px; }
  .ap-guarantee__badge, .ap-guarantee__badge-placeholder { width: 90px; height: 90px; }
}

/* ==================== FAQ ==================== */
.ap-faq { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-faq__container { max-width: 800px; margin: 0 auto; padding: 0 20px; }
.ap-faq__caption { text-align: center; text-transform: uppercase; letter-spacing: 2px; font-size: 12px; color: #888; margin: 0 0 8px; }
.ap-faq__title { text-align: center; font-size: 28px; font-weight: 600; margin: 0 0 32px; color: var(--ap-dark); }
.ap-faq__list { list-style: none; padding: 0; margin: 0; }
.ap-faq__item { border-top: 1px solid #eee; }
.ap-faq__item summary { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; cursor: pointer; list-style: none; }
.ap-faq__item summary::-webkit-details-marker { display: none; }
.ap-faq__item summary { font-size: 16px; font-weight: 500; color: var(--ap-dark); }
.ap-faq__caret { transition: transform 0.3s; flex-shrink: 0; margin-left: 12px; width: 16px; height: 16px; }
.ap-faq__item[open] .ap-faq__caret { transform: rotate(180deg); }
.ap-faq__answer { padding: 0 0 16px; font-size: 14px; color: var(--ap-text-secondary); line-height: 1.7; }
.ap-faq__answer p { margin: 0 0 8px; }
@media (max-width: 768px) {
  .ap-faq { padding: 30px 0; }
  .ap-faq__title { font-size: 22px; margin-bottom: 20px; }
  .ap-faq__item summary { font-size: 14px; }
}

/* ==================== CONTACT ==================== */
.ap-contact { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-contact__container { max-width: 1300px; margin: 0 auto; padding: 0 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.ap-contact__media { border-radius: var(--ap-radius); overflow: hidden; }
.ap-contact__img { width: 100%; height: auto; display: block; border-radius: var(--ap-radius); }
.ap-contact__placeholder { width: 100%; aspect-ratio: 1; background: #ddd; border-radius: var(--ap-radius); display: flex; align-items: center; justify-content: center; color: #999; font-size: 14px; }
.ap-contact__heading { font-size: 32px; font-weight: 600; margin: 0 0 16px; color: var(--ap-dark); }
.ap-contact__text { font-size: 15px; color: var(--ap-text-secondary); line-height: 1.7; margin: 0 0 24px; }
.ap-contact__text p { margin: 0 0 12px; }
@media (max-width: 768px) {
  .ap-contact { padding: 30px 0; }
  .ap-contact__container { grid-template-columns: 1fr; gap: 24px; padding: 0 20px; }
  .ap-contact__heading { font-size: 24px; }
  .ap-contact__media { order: -1; }
}

/* ==================== REVIEWS ==================== */
.ap-reviews { padding: 80px 0; font-family: 'Poppins', sans-serif; }
.ap-reviews__container { max-width: 800px; margin: 0 auto; padding: 0 20px; }
.ap-reviews__title { text-align: center; font-size: 28px; font-weight: 600; margin: 0 0 24px; color: var(--ap-dark); }
.ap-reviews__list { display: flex; flex-direction: column; gap: 16px; }
.ap-reviews__card { background: #fff; border: 1px solid #eee; border-radius: var(--ap-radius); padding: 20px; }
.ap-reviews__stars { display: flex; gap: 2px; margin-bottom: 8px; }
.ap-reviews__star { width: 16px; height: 16px; color: var(--ap-stars); }
.ap-reviews__star--empty { color: #ddd; }
.ap-reviews__text { font-size: 14px; color: #333; line-height: 1.6; margin: 0 0 12px; }
.ap-reviews__text p { margin: 0; }
.ap-reviews__meta { display: flex; justify-content: space-between; align-items: center; }
.ap-reviews__author { font-size: 13px; font-weight: 600; color: var(--ap-dark); }
.ap-reviews__verified { font-size: 11px; color: var(--ap-green); margin-left: 6px; }
.ap-reviews__date { font-size: 12px; color: #999; }
@media (max-width: 768px) {
  .ap-reviews { padding: 30px 0; }
  .ap-reviews__title { font-size: 22px; }
}

/* ==================== PRODUCT PROOF INLINE ==================== */
.ap-pi { font-family: 'Poppins', sans-serif; margin-top: 4px; }

/* Description courte — NO background, like SPINEA */
.ap-pi__desc-box { background: none; border-radius: 0; padding: 0; margin-bottom: 14px; }
.ap-pi__desc-box p { font-size: 15px; line-height: 1.65; color: #333; margin: 0; }

/* Bénéfices — tighter like SPINEA */
.ap-pi__benefits { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.ap-pi__benefit { display: flex; align-items: center; gap: 10px; font-size: 14px; color: #333; line-height: 1.4; }
.ap-pi__bicon { width: 20px; height: 20px; flex-shrink: 0; color: var(--ap-green); }

/* Cadeau PDF */
.ap-pi__gift-box { border: 1.5px solid #e0e0e0; border-radius: 10px; padding: 14px; margin-bottom: 14px; }
.ap-pi__gift-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.ap-pi__gift-tag { font-size: 13px; font-weight: 600; color: var(--ap-green); text-transform: uppercase; }
.ap-pi__gift-badge { font-size: 11px; font-weight: 600; color: var(--ap-green); background: #e8f5e2; padding: 4px 12px; border-radius: 4px; white-space: nowrap; }
.ap-pi__gift-content { display: flex; align-items: center; gap: 12px; }
.ap-pi__gift-img { width: 70px; height: auto; border-radius: 6px; flex-shrink: 0; }
.ap-pi__gift-text { font-size: 13px; line-height: 1.5; color: #333; }
.ap-pi__gift-text strong { font-size: 14px; display: block; margin-bottom: 3px; color: var(--ap-dark); }
.ap-pi__gift-text p { margin: 0; color: #666; font-size: 12px; }

/* Bouton ATC */
.ap-pi__atc-btn { display: block; width: 100%; text-align: center; background: var(--ap-green); color: #fff; font-size: 16px; font-weight: 700; font-family: 'Poppins', sans-serif; padding: 16px; border: none; border-radius: 8px; text-transform: uppercase; letter-spacing: 1.5px; cursor: pointer; transition: background 0.3s, transform 0.15s; }
.ap-pi__atc-btn:hover { background: #2f6350; transform: translateY(-1px); }

/* Badges paiement */
.ap-pi__payments { display: flex; justify-content: center; gap: 6px; margin: 10px 0; flex-wrap: wrap; }
.ap-pi__pay-icon { width: 42px; height: 26px; }

/* Date offre */
.ap-pi__offer-date { text-align: center; font-size: 14px; color: var(--ap-green); margin: 0 0 14px; }

/* Bannière offre */
.ap-pi__offer-banner { margin-bottom: 14px; border-radius: 12px; overflow: hidden; }
.ap-pi__offer-img { width: 100%; height: auto; display: block; }

/* Livraison */
.ap-pi__delivery { display: flex; align-items: center; gap: 10px; font-size: 14px; color: #333; margin-bottom: 14px; justify-content: center; }

/* Trust box */
.ap-pi__trust-box { background: #f9f9f9; border-radius: 10px; padding: 16px; margin-bottom: 14px; }
.ap-pi__trust-main { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.ap-pi__trust-main svg { flex-shrink: 0; margin-top: 2px; }
.ap-pi__trust-main strong { font-size: 14px; display: block; margin-bottom: 3px; color: var(--ap-dark); }
.ap-pi__trust-main p { font-size: 12px; color: #666; margin: 0; line-height: 1.5; }
.ap-pi__trust-badges { display: flex; justify-content: space-around; gap: 8px; border-top: 1px solid #e8e8e8; padding-top: 10px; }
.ap-pi__trust-badge { display: flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 500; color: var(--ap-green); white-space: nowrap; }

/* Témoignage inline */
.ap-pi__testimonial { display: flex; align-items: flex-start; gap: 12px; background: #f9f9f9; border-radius: 10px; padding: 14px; margin-bottom: 16px; }
.ap-pi__testi-img { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.ap-pi__testi-quote { font-size: 13px; font-style: italic; color: var(--ap-green); line-height: 1.5; margin: 0 0 6px; }
.ap-pi__testi-meta { display: flex; align-items: center; gap: 6px; font-size: 13px; }
.ap-pi__testi-meta strong { color: var(--ap-dark); }
.ap-pi__testi-stars { color: var(--ap-stars); font-size: 13px; letter-spacing: 1px; }

/* Accordéons */
.ap-pi__accordions { border-top: 1px solid #eee; margin-top: 4px; }
.ap-pi__acc { border-bottom: 1px solid #eee; }
.ap-pi__acc summary { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; cursor: pointer; list-style: none; font-size: 15px; font-weight: 500; color: var(--ap-dark); }
.ap-pi__acc summary::-webkit-details-marker { display: none; }
.ap-pi__acc summary svg { transition: transform 0.3s; flex-shrink: 0; }
.ap-pi__acc[open] summary svg { transform: rotate(180deg); }
.ap-pi__acc-body { padding: 0 0 14px; font-size: 14px; color: var(--ap-text-secondary); line-height: 1.7; }
.ap-pi__acc-body p { margin: 0 0 8px; }

/* Hide Fullstack duplicate ATC form above proof */
.product-section__product-info > .product-form-component { display: none !important; }

@media (max-width: 768px) {
  .ap-pi__trust-badges { flex-direction: column; gap: 8px; align-items: flex-start; }
  .ap-pi__payments { gap: 4px; }
  .ap-pi__pay-icon { width: 38px; height: 24px; }
}

/* ==================== UPSELL POPUP ==================== */
.ap-upsell-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 99999;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; transition: opacity 0.3s ease;
}
.ap-upsell-overlay.ap-upsell-visible { opacity: 1; }
.ap-upsell-popup {
  background: #fff; border-radius: 16px; padding: 32px 28px; max-width: 380px; width: 100%;
  text-align: center; position: relative; font-family: 'Poppins', sans-serif;
  transform: translateY(20px) scale(0.95); transition: transform 0.3s ease;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15);
}
.ap-upsell-visible .ap-upsell-popup { transform: translateY(0) scale(1); }
.ap-upsell-close {
  position: absolute; top: 12px; right: 16px; background: none; border: none;
  font-size: 28px; color: #999; cursor: pointer; line-height: 1;
}
.ap-upsell-close:hover { color: #333; }
.ap-upsell-badge {
  display: inline-block; background: #3B735E; color: #fff; font-size: 11px;
  font-weight: 700; padding: 4px 14px; border-radius: 20px; margin-bottom: 16px;
  letter-spacing: 0.5px;
}
.ap-upsell-title { font-size: 20px; font-weight: 600; color: #1a1a1a; margin: 0 0 16px; }
.ap-upsell-img { width: 160px; height: 160px; object-fit: cover; border-radius: 12px; margin: 0 auto 16px; display: block; }
.ap-upsell-product { font-size: 15px; font-weight: 500; color: #333; margin: 0 0 8px; }
.ap-upsell-pricing { font-size: 18px; margin: 0 0 20px; }
.ap-upsell-old { text-decoration: line-through; color: #999; margin-right: 8px; }
.ap-upsell-new { font-weight: 700; color: #3B735E; }
.ap-upsell-add {
  display: block; width: 100%; background: #3B735E; color: #fff; border: none;
  padding: 14px; border-radius: 8px; font-size: 15px; font-weight: 600;
  cursor: pointer; font-family: 'Poppins', sans-serif; transition: background 0.3s;
}
.ap-upsell-add:hover { background: #2f6350; }
.ap-upsell-skip {
  display: block; width: 100%; background: none; border: none; color: #999;
  font-size: 13px; padding: 12px; cursor: pointer; font-family: 'Poppins', sans-serif;
  text-decoration: underline;
}
.ap-upsell-skip:hover { color: #666; }
