/* ===========================================================
 * Térinéo — Pages Produits Custom (CSS)
 * Scopé sous .terineo-scope pour ne pas écraser le thème
 * =========================================================== */

@font-face {
  font-family: 'Sunday Club';
  src: url('https://terineo.com/wp-content/uploads/2026/05/Sunday-Club.ttf') format('truetype');
  font-weight: 400 900;
  font-display: swap;
}

.terineo-scope {
  --brand-coral:        #D9594A;
  --brand-coral-light:  #EEB4AE;
  --brand-coral-dark:   #A34338;
  --brand-cream:        #FAEFD7;
  --brand-cream-soft:   #FCF6E4;
  --brand-paper:        #FEFAEE;
  --brand-ink:          #3B1F0E;
  --brand-ink-soft:     #5A3520;
  --brand-teal-deep:    #234B47;
  --brand-success:      #2E8B57;
  --brand-gray-100:     #EFE8D6;
  --brand-gray-300:     #D7CFB7;
  --brand-gray-500:     #8A7C68;
  --font-display: "Sunday Club", "Brush Script MT", cursive;
  --font-ui:      "Inter", -apple-system, "Helvetica Neue", sans-serif;
  --pad-x: clamp(20px, 5vw, 88px);
  --section-pad: clamp(64px, 8vw, 120px);

  font-family: var(--font-ui);
  color: var(--brand-ink);
  -webkit-font-smoothing: antialiased;
  background: var(--brand-paper);
}
.terineo-scope, .terineo-scope * { box-sizing: border-box; }
.terineo-scope a { color: inherit; }
.terineo-scope img { max-width: 100%; display: block; }

/* ============================================================
 * 1. HERO
 * ============================================================ */
.terineo-scope .ter-pp-hero{
  padding: clamp(24px, 4vw, 48px) var(--pad-x) var(--section-pad);
  background: var(--brand-paper);
}
.terineo-scope .ter-pp-hero-inner{
  max-width: 1400px; margin: 0 auto;
  display: grid; grid-template-columns: minmax(0, 460px) 1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 980px){
  .terineo-scope .ter-pp-hero-inner{ grid-template-columns: 1fr; gap: 32px; }
}

/* GALERIE — sticky à la Amazon : reste visible pendant le scroll de la colonne info */
.terineo-scope .ter-pp-gallery{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px;
  position: -webkit-sticky;
  position: sticky;
  top: 100px;
  align-self: start;
  min-width: 0;
}
@media (max-width: 980px){
  .terineo-scope .ter-pp-gallery{ position: static; }
}
.terineo-scope .ter-pp-gallery-main{
  grid-column: 1 / -1;
  aspect-ratio: 1/1;
  border-radius: 32px;
  overflow: hidden;
  background: var(--brand-cream-soft);
  position: relative;
}
.terineo-scope .ter-pp-gallery-main img{ width: 100%; height: 100%; object-fit: cover; }
.terineo-scope .ter-pp-gallery-thumb{
  aspect-ratio: 4/5;
  border-radius: 24px;
  overflow: hidden;
  background: var(--brand-cream-soft);
}
.terineo-scope .ter-pp-gallery-thumb img{ width: 100%; height: 100%; object-fit: cover; }

/* INFO — colonne droite, scrolle normalement (la galerie à gauche est sticky) */
.terineo-scope .ter-pp-info{
  align-self: start;
  min-width: 0; /* fix grid item overflow avec marquee */
}

.terineo-scope .ter-pp-info-top{
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; margin-bottom: 18px;
}
.terineo-scope .ter-pp-tag{
  background: var(--brand-cream); color: var(--brand-ink);
  font: 700 11px/1 var(--font-ui);
  letter-spacing: .14em; text-transform: uppercase;
  padding: 8px 14px; border-radius: 999px;
}
.terineo-scope .ter-pp-title{
  margin: 0 0 18px;
  font: 700 clamp(34px, 4vw, 52px)/1.05 var(--font-display);
  letter-spacing: -.02em;
  color: var(--brand-ink);
  text-wrap: balance;
}
.terineo-scope .ter-pp-desc{
  margin: 0 0 22px;
  font: 400 16px/1.6 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-price-row{
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 6px;
}
.terineo-scope .ter-pp-price{
  font: 700 28px/1 var(--font-ui);
  color: var(--brand-coral);
}
/* V2 PROMO : bloc prix avec badge + barré */
.terineo-scope .ter-pp-price-block{
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 8px;
  margin-bottom: 6px;
}
.terineo-scope .ter-pp-price-badge{
  display: inline-block;
  background: var(--brand-coral);
  color: #fff;
  padding: 5px 11px;
  border-radius: 999px;
  font: 700 10px/1 var(--font-ui);
  letter-spacing: .14em; text-transform: uppercase;
  white-space: nowrap;
}
.terineo-scope .ter-pp-price-old{
  font: 500 18px/1 var(--font-ui);
  color: var(--brand-gray-500);
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--brand-coral);
}
.terineo-scope .ter-pp-price .woocommerce-Price-amount,
.terineo-scope .ter-pp-price bdi{
  color: inherit; font: inherit;
}
.terineo-scope .ter-pp-unit{
  margin: 0;
  font: 500 13px/1 var(--font-ui);
  color: var(--brand-gray-500);
}
.terineo-scope .ter-pp-divider{
  height: 1px; background: rgba(59,31,14,.08);
  margin: 24px 0;
}

/* QTY SELECTOR — compteur −/+ moderne */
.terineo-scope .ter-pp-qty-label{
  font: 600 13px/1 var(--font-ui);
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--brand-ink-soft);
  margin-bottom: 12px;
}
.terineo-scope .ter-pp-qty-counter{
  display: inline-flex;
  align-items: center;
  background: var(--brand-cream-soft);
  border: 1.5px solid rgba(59,31,14,.10);
  border-radius: 999px;
  padding: 6px;
  gap: 0;
  transition: border-color .2s ease;
}
.terineo-scope .ter-pp-qty-counter:hover{
  border-color: rgba(59,31,14,.22);
}
.terineo-scope button.ter-pp-qty-counter-btn,
.terineo-scope .ter-pp-qty-counter-btn{
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  max-width: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  border-radius: 999px !important;
  border: 0 !important;
  background-color: transparent !important;
  background-image: none !important;
  color: var(--brand-ink) !important;
  font-family: var(--font-ui) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color .2s ease, color .2s ease, transform .15s ease;
  appearance: none !important;
  -webkit-appearance: none !important;
  padding: 0 !important;
  outline: 0 !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
}
.terineo-scope button.ter-pp-qty-counter-btn:hover,
.terineo-scope .ter-pp-qty-counter-btn:hover{
  background-color: var(--brand-coral) !important;
  background-image: none !important;
  color: #fff !important;
  border-radius: 999px !important;
  transform: scale(1.06);
}
.terineo-scope .ter-pp-qty-counter-btn:disabled{
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}
.terineo-scope .ter-pp-qty-counter-value{
  min-width: 56px;
  text-align: center;
  font: 700 20px/1 var(--font-ui);
  color: var(--brand-ink);
  user-select: none;
  padding: 0 8px;
}

/* UPSELL */
.terineo-scope .ter-pp-upsell-label{
  margin-top: 24px;
  font: 600 13px/1 var(--font-ui);
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--brand-ink-soft);
  margin-bottom: 12px;
}
.terineo-scope .ter-pp-upsell{
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border: 1.5px solid rgba(59,31,14,.12);
  border-radius: 18px;
  cursor: pointer;
  transition: border-color .2s ease;
}
.terineo-scope .ter-pp-upsell:hover{ border-color: var(--brand-ink); }
.terineo-scope .ter-pp-upsell-img{
  width: 52px; height: 52px;
  border-radius: 14px;
  background: var(--brand-cream);
  object-fit: cover;
  flex-shrink: 0;
}
.terineo-scope .ter-pp-upsell-info{ flex: 1; min-width: 0; }
.terineo-scope .ter-pp-upsell-name{
  display: block;
  font: 600 14px/1.2 var(--font-ui);
  color: var(--brand-ink);
  margin-bottom: 4px;
}
.terineo-scope .ter-pp-upsell-price{
  font: 500 13px/1 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-upsell-price s{ color: var(--brand-gray-500); margin-right: 6px; }
.terineo-scope button.ter-pp-upsell-add,
.terineo-scope .ter-pp-upsell-add{
  appearance: none !important;
  -webkit-appearance: none !important;
  box-sizing: border-box !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  max-width: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  border: 0 !important;
  background-color: var(--brand-ink) !important;
  background-image: none !important;
  color: var(--brand-cream) !important;
  flex-shrink: 0 !important;
  flex-grow: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  outline: 0 !important;
  font: inherit !important;
  transition: background-color .2s ease, transform .2s ease;
  line-height: 1 !important;
}
.terineo-scope .ter-pp-upsell-add:hover{
  background-color: var(--brand-coral) !important;
  transform: scale(1.06);
}
.terineo-scope .ter-pp-upsell-add svg{
  width: 14px !important;
  height: 14px !important;
  color: inherit !important;
  flex-shrink: 0;
  transition: color .2s ease;
}
.terineo-scope .ter-pp-upsell-add.is-checked{
  background-color: var(--brand-success) !important;
  color: #fff !important;
}
.terineo-scope .ter-pp-upsell.is-checked{
  border-color: var(--brand-success);
  background: rgba(46,139,87,.04);
}

/* V2 PROMO : reco Pack Trio (réutilise le style upsell + accent coral) */
.terineo-scope .ter-pp-trio-label{
  margin-top: 16px;
}
.terineo-scope .ter-pp-trio-reco{
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border: 1.5px solid var(--brand-coral);
  border-radius: 18px;
  background: rgba(217,89,74,.05);
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
  position: relative;
}
.terineo-scope .ter-pp-trio-reco:hover{
  background: rgba(217,89,74,.10);
  transform: translateY(-1px);
}
.terineo-scope .ter-pp-trio-reco .ter-pp-upsell-price s{
  color: var(--brand-gray-500);
  margin-right: 4px;
  text-decoration-color: var(--brand-coral);
}
.terineo-scope .ter-pp-trio-reco .ter-pp-upsell-price strong{
  color: var(--brand-coral);
  font-weight: 700;
}
.terineo-scope .ter-pp-trio-add{
  background-color: var(--brand-coral) !important;
}
.terineo-scope .ter-pp-trio-add:hover{
  background-color: var(--brand-coral-dark) !important;
}
.terineo-scope .ter-pp-trio-add.is-checked{
  background-color: var(--brand-success) !important;
}

/* Toast notification "produit ajouté" — en BAS */
.terineo-scope .ter-pp-toast{
  position: fixed;
  bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(200%);
  background: var(--brand-success);
  color: #fff;
  padding: 18px 28px;
  border-radius: 999px;
  font: 700 15px/1.2 var(--font-ui);
  box-shadow: 0 -10px 60px rgba(0,0,0,.25), 0 0 0 4px rgba(46,139,87,.15);
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: transform .45s cubic-bezier(.2,.8,.2,1.05), opacity .25s ease, visibility 0s linear .25s;
  pointer-events: none;
  display: flex; align-items: center; gap: 14px;
  max-width: calc(100vw - 32px);
}
.terineo-scope .ter-pp-toast.is-visible{
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  visibility: visible;
  transition: transform .45s cubic-bezier(.2,.8,.2,1.05), opacity .25s ease, visibility 0s linear 0s;
}
.terineo-scope .ter-pp-toast svg{
  width: 22px; height: 22px;
  flex-shrink: 0;
}
/* Si la sticky bar est visible en mobile, on remonte le toast au-dessus */
@media (max-width: 980px){
  .terineo-scope .ter-pp-toast{
    bottom: 100px;
  }
}

/* CTA principal — taille normale, override propre des styles WC */
.terineo-scope .ter-pp-form{ margin: 0; }
.terineo-scope button.ter-pp-cta,
.terineo-scope .ter-pp-cta{
  /* Reset clean */
  appearance: none !important;
  -webkit-appearance: none !important;
  text-decoration: none !important;
  text-shadow: none !important;
  text-transform: uppercase !important;
  box-sizing: border-box !important;
  /* Layout */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 18px 28px !important;
  margin: 24px 0 0 !important;
  /* Couleurs */
  background-color: var(--brand-coral) !important;
  background-image: none !important;
  color: #fff !important;
  /* Bordures */
  border: 0 !important;
  border-radius: 999px !important;
  outline: 0 !important;
  /* Texture */
  font-family: var(--font-ui) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .12em !important;
  /* Comportement */
  cursor: pointer !important;
  vertical-align: baseline !important;
  /* Effet visuel */
  box-shadow: 0 14px 30px rgba(163,67,56,.28);
  transition: background-color .2s ease, transform .2s ease, box-shadow .25s ease;
  white-space: nowrap;
}
.terineo-scope .ter-pp-cta:hover,
.terineo-scope button.ter-pp-cta:hover{
  background-color: var(--brand-coral-dark) !important;
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(163,67,56,.4);
}
.terineo-scope .ter-pp-cta svg{
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0;
}
/* État WC après ajout */
.terineo-scope .ter-pp-cta.added,
.terineo-scope .ter-pp-cta.is-added{
  background: var(--brand-success) !important;
}

/* ACCORDÉONS */
.terineo-scope .ter-pp-accord{
  margin-top: 28px;
  display: flex; flex-direction: column;
  gap: 8px;
}
.terineo-scope .ter-pp-accord details{
  background: var(--brand-cream-soft);
  border: 1.5px solid rgba(59,31,14,.06);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .2s ease, background .2s ease;
}
.terineo-scope .ter-pp-accord details:hover{
  border-color: rgba(59,31,14,.18);
}
.terineo-scope .ter-pp-accord details[open]{
  border-color: var(--brand-coral);
  background: var(--brand-paper);
}
.terineo-scope .ter-pp-accord summary{
  list-style: none;
  cursor: pointer;
  padding: 18px 22px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
  font: 600 15px/1.3 var(--font-ui);
  color: var(--brand-ink);
  user-select: none;
}
.terineo-scope .ter-pp-accord summary::-webkit-details-marker{ display: none; }
.terineo-scope .ter-pp-accord summary::after{
  content: "+";
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--brand-cream);
  border-radius: 999px;
  font: 700 18px/1 var(--font-ui);
  color: var(--brand-ink);
  flex-shrink: 0;
  transition: background .25s ease, color .25s ease, transform .35s ease;
}
.terineo-scope .ter-pp-accord details[open] summary::after{
  content: "−";
  background: var(--brand-coral);
  color: #fff;
  transform: rotate(180deg);
}
.terineo-scope .ter-pp-accord-body{
  padding: 0 22px 20px;
  font: 400 14px/1.6 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-accord-body p{ margin: 0 0 8px; }
.terineo-scope .ter-pp-accord-body p:last-child{ margin: 0; }
.terineo-scope .ter-pp-accord-body strong{ color: var(--brand-ink); }

/* MARQUEE */
.terineo-scope .ter-pp-marquee{
  margin-top: 28px;
  height: 52px;
  display: flex;
  align-items: center;
  background: var(--brand-coral-dark);
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.terineo-scope .ter-pp-marquee-track{
  display: flex;
  align-items: center;
  gap: 32px;
  white-space: nowrap;
  width: max-content;
  padding-left: 32px;
  animation: terPpMarquee 22s linear infinite;
}
.terineo-scope .ter-pp-marquee-track > span{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #fff;
  flex-shrink: 0;
}
.terineo-scope .ter-pp-marquee-track svg{
  width: 12px;
  height: 12px;
  background: rgba(255,255,255,.22);
  border-radius: 999px;
  padding: 4px;
  box-sizing: content-box;
  color: #fff;
  flex-shrink: 0;
  display: block;
}
@keyframes terPpMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce){
  .terineo-scope .ter-pp-marquee-track{ animation: none; }
}

/* ============================================================
 * 2. STORY
 * ============================================================ */
.terineo-scope .ter-pp-story{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-cream-soft);
}
.terineo-scope .ter-pp-story-inner{
  max-width: 880px; margin: 0 auto;
  text-align: center;
}
.terineo-scope .ter-pp-eyebrow{
  display: inline-flex; align-items: center; gap: 14px;
  font: 600 11px/1 var(--font-ui);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--brand-coral);
  margin: 0 0 18px;
}
.terineo-scope .ter-pp-eyebrow::before,
.terineo-scope .ter-pp-eyebrow::after{
  content: ""; width: 36px; height: 2px;
  background: var(--brand-ink); border-radius: 2px;
}
.terineo-scope .ter-pp-h2{
  margin: 0 0 28px;
  font: 700 clamp(30px, 4vw, 48px)/1.05 var(--font-display);
  letter-spacing: -.02em;
  color: var(--brand-ink);
  text-wrap: balance;
}
.terineo-scope .ter-pp-h2 em{
  font-style: italic;
  color: var(--brand-coral);
  font-weight: 700;
}
.terineo-scope .ter-pp-story p{
  font: 400 17px/1.7 var(--font-ui);
  color: var(--brand-ink-soft);
  margin: 0 0 16px;
  max-width: 64ch;
  margin-left: auto; margin-right: auto;
}

/* ============================================================
 * 3. INGRÉDIENTS
 * ============================================================ */
.terineo-scope .ter-pp-ing{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-paper);
}
.terineo-scope .ter-pp-ing-inner{ max-width: 1400px; margin: 0 auto; }
.terineo-scope .ter-pp-ing-head{
  margin: 0 auto 56px; max-width: 720px; text-align: center;
}
.terineo-scope .ter-pp-ing-head p{
  margin: 0;
  font: 400 16px/1.6 var(--font-ui);
  color: var(--brand-ink-soft);
  max-width: 56ch;
  margin: 0 auto;
}
.terineo-scope .ter-pp-ing-grid{
  display: flex; flex-wrap: wrap; gap: 20px;
  justify-content: center;
}
.terineo-scope .ter-pp-ing-card{
  flex: 1 1 calc(25% - 15px);
  max-width: calc(25% - 15px);
  min-width: 220px;
}
@media (max-width: 980px){
  .terineo-scope .ter-pp-ing-card{ flex-basis: calc(50% - 10px); max-width: calc(50% - 10px); }
}
@media (max-width: 480px){
  .terineo-scope .ter-pp-ing-card{ flex-basis: 100%; max-width: 100%; }
}
.terineo-scope .ter-pp-ing-card{
  background: var(--brand-cream-soft);
  border-radius: 24px;
  padding: 28px 24px;
  transition: transform .25s ease, box-shadow .25s ease;
}
.terineo-scope .ter-pp-ing-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(59,31,14,.08);
}
.terineo-scope .ter-pp-ing-img{
  width: 96px; height: 96px;
  border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  background: var(--brand-cream);
  margin-bottom: 20px;
  font: 700 32px Sunday Club;
}
.terineo-scope .ter-pp-ing-name{
  margin: 0 0 12px;
  font: 700 26px/1.15 var(--font-display);
  color: var(--brand-ink);
  letter-spacing: -.01em;
}
.terineo-scope .ter-pp-ing-text{
  margin: 0;
  font: 400 14.5px/1.55 var(--font-ui);
  color: var(--brand-ink-soft);
}

/* ============================================================
 * 4. RECETTES
 * ============================================================ */
.terineo-scope .ter-pp-rec{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-cream-soft);
}
.terineo-scope .ter-pp-rec-inner{ max-width: 1400px; margin: 0 auto; }
.terineo-scope .ter-pp-rec-head{ margin: 0 auto 48px; text-align: center; }
.terineo-scope .ter-pp-rec-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
/* Si une seule recette : carte centrée, taille raisonnable (sinon elle reste collée à gauche d'une grille 3-cols) */
.terineo-scope .ter-pp-rec-grid:has(> .ter-pp-rec-card:only-child){
  grid-template-columns: minmax(0, 420px);
  justify-content: center;
}
/* Si 2 recettes : 2 colonnes centrées au lieu de 3 dont la 3e vide */
.terineo-scope .ter-pp-rec-grid:has(> .ter-pp-rec-card:nth-child(2):last-child){
  grid-template-columns: repeat(2, minmax(0, 380px));
  justify-content: center;
}
@media (max-width: 980px){ .terineo-scope .ter-pp-rec-grid{ grid-template-columns: 1fr; } }
.terineo-scope .ter-pp-rec-card{
  border-radius: 24px;
  overflow: hidden;
  background: var(--brand-paper);
  transition: transform .3s ease, box-shadow .3s ease;
  cursor: pointer;
}
.terineo-scope .ter-pp-rec-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(59,31,14,.1);
}
.terineo-scope .ter-pp-rec-img{
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--brand-cream);
  position: relative;
}
.terineo-scope .ter-pp-rec-img img{
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease;
}
.terineo-scope .ter-pp-rec-card:hover .ter-pp-rec-img img{ transform: scale(1.05); }
.terineo-scope .ter-pp-rec-info{ padding: 24px; }
.terineo-scope .ter-pp-rec-meta{
  display: inline-flex; align-items: center; gap: 12px;
  font: 600 11px/1 var(--font-ui);
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--brand-coral);
  margin-bottom: 12px;
}
.terineo-scope .ter-pp-rec-meta svg{ width: 12px; height: 12px; }
.terineo-scope .ter-pp-rec-meta-time{
  display: inline-flex; align-items: center; gap: 5px;
  color: var(--brand-gray-500);
}
.terineo-scope .ter-pp-rec-name{
  margin: 0 0 8px;
  font: 700 22px/1.15 var(--font-display);
  color: var(--brand-ink);
  letter-spacing: -.01em;
}
.terineo-scope .ter-pp-rec-text{
  margin: 0;
  font: 400 14px/1.55 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-rec-link{
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 16px;
  font: 700 12px/1 var(--font-ui);
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--brand-coral);
  text-decoration: none;
}
.terineo-scope .ter-pp-rec-link svg{ width: 12px; height: 12px; transition: transform .25s ease; }
.terineo-scope .ter-pp-rec-card:hover .ter-pp-rec-link svg{ transform: translateX(4px); }

/* ============================================================
 * 5. COMPARATIF
 * ============================================================ */
.terineo-scope .ter-pp-vs{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-paper);
}
.terineo-scope .ter-pp-vs-inner{ max-width: 980px; margin: 0 auto; }
.terineo-scope .ter-pp-vs-head{ margin: 0 auto 48px; text-align: center; }
.terineo-scope .ter-pp-vs-table{
  background: var(--brand-cream-soft);
  border-radius: 32px;
  padding: 12px;
  overflow: hidden;
}
.terineo-scope .ter-pp-vs-row{
  display: grid; grid-template-columns: 1.2fr 1fr 1fr;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(59,31,14,.08);
}
.terineo-scope .ter-pp-vs-row:last-child{ border-bottom: 0; }
.terineo-scope .ter-pp-vs-row.is-head{ padding: 24px; }
.terineo-scope .ter-pp-vs-row.is-head > div{ text-align: center; }
.terineo-scope .ter-pp-vs-cell{
  font: 500 15px/1.4 var(--font-ui);
  color: var(--brand-ink);
}
.terineo-scope .ter-pp-vs-row > div:nth-child(2),
.terineo-scope .ter-pp-vs-row > div:nth-child(3){ text-align: center; }
.terineo-scope .ter-pp-vs-brand-coral{
  font: 700 22px/1 var(--font-display);
  color: var(--brand-coral);
}
.terineo-scope .ter-pp-vs-other{
  font: 500 14px/1.2 var(--font-ui);
  color: var(--brand-gray-500);
}
.terineo-scope .ter-pp-vs-icon{
  width: 32px; height: 32px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
}
.terineo-scope .ter-pp-vs-icon.yes{ background: rgba(46,139,87,.12); color: var(--brand-success); }
.terineo-scope .ter-pp-vs-icon.no{ background: rgba(217,89,74,.10); color: var(--brand-coral); }
.terineo-scope .ter-pp-vs-icon svg{ width: 16px; height: 16px; }
@media (max-width: 600px){
  .terineo-scope .ter-pp-vs-row{ padding: 14px 16px; }
  .terineo-scope .ter-pp-vs-cell{ font-size: 13px; }
}

/* ============================================================
 * 6. CROSS-SELL (rouge)
 * ============================================================ */
.terineo-scope .ter-pp-cross{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-coral);
  color: #fff;
}
.terineo-scope .ter-pp-cross-inner{ max-width: 1400px; margin: 0 auto; }
.terineo-scope .ter-pp-cross-head{ margin: 0 auto 48px; text-align: center; }
.terineo-scope .ter-pp-cross-head .ter-pp-eyebrow{ color: #fff; opacity: .8; }
.terineo-scope .ter-pp-cross-head .ter-pp-eyebrow::before,
.terineo-scope .ter-pp-cross-head .ter-pp-eyebrow::after{ background: #fff; }
.terineo-scope .ter-pp-cross-head h2{
  margin: 0;
  font: 700 clamp(30px, 4vw, 48px)/1.05 var(--font-display);
  letter-spacing: -.02em;
  color: #fff;
}
.terineo-scope .ter-pp-cross-head h2 em{
  font-style: italic; color: var(--brand-cream); font-weight: 700;
}
.terineo-scope .ter-pp-cross-grid{
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 980px; margin: 0 auto;
}
@media (max-width: 600px){ .terineo-scope .ter-pp-cross-grid{ grid-template-columns: 1fr; } }
.terineo-scope .ter-pp-cross-card{
  background: rgba(255,255,255,.06);
  border-radius: 28px;
  padding: 24px;
  text-align: center;
  transition: transform .3s ease, background .3s ease;
  cursor: pointer;
}
.terineo-scope .ter-pp-cross-card:hover{
  transform: translateY(-6px);
  background: rgba(255,255,255,.12);
}
.terineo-scope .ter-pp-cross-tag{
  display: inline-block;
  padding: 6px 12px; margin-bottom: 16px;
  background: var(--brand-ink); color: var(--brand-cream);
  border-radius: 999px;
  font: 700 10px/1 var(--font-ui);
  letter-spacing: .12em; text-transform: uppercase;
}
.terineo-scope .ter-pp-cross-img-wrap{
  aspect-ratio: 1/1;
  border-radius: 20px;
  background: var(--brand-cream);
  overflow: hidden;
  margin-bottom: 20px;
}
.terineo-scope .ter-pp-cross-img-wrap img{ width: 100%; height: 100%; object-fit: cover; }
.terineo-scope .ter-pp-cross-name{
  margin: 0 0 6px;
  font: 700 22px/1.15 var(--font-display);
  color: #fff;
}
.terineo-scope .ter-pp-cross-price{
  font: 600 16px/1 var(--font-ui);
  color: var(--brand-cream);
  margin-bottom: 18px;
}
.terineo-scope .ter-pp-cross-price .woocommerce-Price-amount,
.terineo-scope .ter-pp-cross-price bdi{ color: inherit; font: inherit; }
.terineo-scope .ter-pp-cross-cta{
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%;
  padding: 14px 22px;
  background: var(--brand-ink); color: var(--brand-cream);
  border: 0; border-radius: 999px;
  font: 700 12px/1 var(--font-ui);
  letter-spacing: .12em; text-transform: uppercase;
  cursor: pointer; text-decoration: none;
  transition: background .2s ease, transform .2s ease;
}
.terineo-scope .ter-pp-cross-cta:hover{
  background: #1d1109;
  transform: translateY(-2px);
}
.terineo-scope .ter-pp-cross-cta svg{ width: 14px; height: 14px; }

/* ============================================================
 * 7. FAQ + SUPPORT
 * ============================================================ */
.terineo-scope .ter-pp-faq{
  padding: var(--section-pad) var(--pad-x);
  background: var(--brand-paper);
}
.terineo-scope .ter-pp-faq-inner{
  max-width: 1300px; margin: 0 auto;
  display: grid; grid-template-columns: 1.5fr 1fr;
  gap: 56px; align-items: start;
}
@media (max-width: 980px){ .terineo-scope .ter-pp-faq-inner{ grid-template-columns: 1fr; } }
.terineo-scope .ter-pp-faq h2{
  margin: 0 0 32px;
  font: 700 clamp(30px, 4vw, 48px)/1.05 var(--font-display);
  color: var(--brand-ink);
}
.terineo-scope .ter-pp-faq details{ border-bottom: 1px solid rgba(59,31,14,.10); }
.terineo-scope .ter-pp-faq details:first-of-type{ border-top: 1px solid rgba(59,31,14,.10); }
.terineo-scope .ter-pp-faq summary{
  list-style: none;
  cursor: pointer;
  padding: 24px 4px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
  font: 600 22px/1.35 var(--font-display);
  color: var(--brand-ink);
  letter-spacing: -.005em;
}
.terineo-scope .ter-pp-faq summary::-webkit-details-marker{ display: none; }
.terineo-scope .ter-pp-faq summary::after{
  content: "+";
  font: 400 20px/1 var(--font-ui);
  color: var(--brand-ink);
}
.terineo-scope .ter-pp-faq details[open] summary::after{ content: "−"; }
.terineo-scope .ter-pp-faq-body{
  padding: 0 4px 22px;
  font: 400 14.5px/1.6 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-faq-support{
  background: var(--brand-cream-soft);
  border-radius: 24px;
  padding: 32px;
  text-align: center;
}
.terineo-scope .ter-pp-faq-support-icon{
  width: 56px; height: 56px;
  border-radius: 999px;
  background: var(--brand-coral); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.terineo-scope .ter-pp-faq-support-icon svg{ width: 24px; height: 24px; }
.terineo-scope .ter-pp-faq-support h3{
  margin: 0 0 10px;
  font: 700 22px/1.2 var(--font-display);
  color: var(--brand-ink);
}
.terineo-scope .ter-pp-faq-support p{
  margin: 0 0 22px;
  font: 400 14px/1.5 var(--font-ui);
  color: var(--brand-ink-soft);
}
.terineo-scope .ter-pp-faq-support a{
  display: block;
  padding: 14px 20px;
  border-radius: 999px;
  font: 700 12px/1 var(--font-ui);
  letter-spacing: .12em; text-transform: uppercase;
  text-decoration: none;
  transition: background .2s ease, color .2s ease, transform .2s ease;
  margin-bottom: 8px;
}
.terineo-scope .ter-pp-faq-support a.primary{
  background: var(--brand-ink); color: var(--brand-cream);
}
.terineo-scope .ter-pp-faq-support a.primary:hover{
  background: var(--brand-coral);
  transform: translateY(-2px);
}
.terineo-scope .ter-pp-faq-support a.secondary{
  background: var(--brand-paper);
  color: var(--brand-ink);
  border: 1.5px solid rgba(59,31,14,.12);
}
.terineo-scope .ter-pp-faq-support a.secondary:hover{ border-color: var(--brand-ink); }

/* ============================================================
 * 8. TRUST BADGES
 * ============================================================ */
.terineo-scope .ter-pp-trust{
  padding: clamp(40px, 6vw, 72px) var(--pad-x);
  background: var(--brand-cream-soft);
  border-top: 1px solid rgba(59,31,14,.06);
}
.terineo-scope .ter-pp-trust-grid{
  max-width: 1300px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 600px){ .terineo-scope .ter-pp-trust-grid{ grid-template-columns: 1fr; } }
.terineo-scope .ter-pp-trust-item{
  display: flex; align-items: center; gap: 16px;
  padding: 22px 24px;
  background: var(--brand-paper);
  border-radius: 18px;
}
.terineo-scope .ter-pp-trust-icon{
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(217,89,74,.12);
  color: var(--brand-coral);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.terineo-scope .ter-pp-trust-icon svg{ width: 22px; height: 22px; }
.terineo-scope .ter-pp-trust-text strong{
  display: block;
  font: 700 15px/1.2 var(--font-display);
  color: var(--brand-ink);
  margin-bottom: 4px;
}
.terineo-scope .ter-pp-trust-text span{
  font: 400 13px/1.4 var(--font-ui);
  color: var(--brand-gray-500);
}

/* ============================================================
 * STICKY ADD-TO-CART (apparaît au scroll)
 * ============================================================ */
.terineo-scope .ter-pp-sticky{
  position: fixed;
  bottom: 0; left: 0; right: 0;
  padding: 14px 20px calc(14px + env(safe-area-inset-bottom));
  background: var(--brand-paper);
  border-top: 1px solid rgba(59,31,14,.10);
  z-index: 50;
  box-shadow: 0 -8px 30px rgba(59,31,14,.10);
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
  display: flex; align-items: center; gap: 16px;
}
.terineo-scope .ter-pp-sticky.is-visible{ transform: translateY(0); }
.terineo-scope .ter-pp-sticky-inner{
  width: 100%; max-width: 1100px; margin: 0 auto;
  display: flex; align-items: center; gap: 20px;
}
.terineo-scope .ter-pp-sticky-thumb{
  width: 60px; height: 60px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--brand-cream);
  flex-shrink: 0;
}
.terineo-scope .ter-pp-sticky-thumb img{ width: 100%; height: 100%; object-fit: cover; }
.terineo-scope .ter-pp-sticky-info{ flex: 1; min-width: 0; }
.terineo-scope .ter-pp-sticky-name{
  display: block;
  font: 700 19px/1.2 var(--font-display);
  color: var(--brand-ink);
  letter-spacing: -.01em;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.terineo-scope .ter-pp-sticky-price{
  font: 700 17px/1 var(--font-ui);
  color: var(--brand-coral);
}
.terineo-scope .ter-pp-sticky-price .woocommerce-Price-amount,
.terineo-scope .ter-pp-sticky-price bdi{ color: inherit; font: inherit; }
.terineo-scope button.ter-pp-sticky-cta,
.terineo-scope .ter-pp-sticky-cta{
  appearance: none !important;
  -webkit-appearance: none !important;
  text-decoration: none !important;
  text-shadow: none !important;
  text-transform: uppercase !important;
  box-sizing: border-box !important;
  flex-shrink: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 16px 32px !important;
  background-color: var(--brand-coral) !important;
  background-image: none !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  outline: 0 !important;
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .12em !important;
  cursor: pointer !important;
  transition: background-color .2s ease, transform .2s ease;
  white-space: nowrap;
}
.terineo-scope button.ter-pp-sticky-cta:hover,
.terineo-scope .ter-pp-sticky-cta:hover{
  background-color: var(--brand-coral-dark) !important;
  background-image: none !important;
  color: #fff !important;
  border-radius: 999px !important;
  transform: translateY(-1px);
}
.terineo-scope .ter-pp-sticky-cta svg{ width: 14px !important; height: 14px !important; flex-shrink: 0; }

@media (max-width: 600px){
  .terineo-scope .ter-pp-sticky{ padding: 10px 14px calc(10px + env(safe-area-inset-bottom)); }
  .terineo-scope .ter-pp-sticky-inner{ gap: 12px; }
  .terineo-scope .ter-pp-sticky-thumb{ width: 50px; height: 50px; border-radius: 12px; }
  .terineo-scope .ter-pp-sticky-name{ font-size: 16px; }
  .terineo-scope .ter-pp-sticky-price{ font-size: 15px; }
  .terineo-scope .ter-pp-sticky-cta{
    padding: 14px 20px !important;
    font-size: 12px !important;
    letter-spacing: .08em !important;
  }
}
@media (max-width: 380px){
  .terineo-scope .ter-pp-sticky-cta-label{ display: none; }
  .terineo-scope .ter-pp-sticky-cta{ padding: 14px 16px; }
}
