/* ============================================================
   PRODUCT — Template partagé pour les pages produits
   ============================================================ */

/* ---------- Hero ---------- */
.prd-hero{
  padding:var(--space-6) 0 var(--space-5);
  background:linear-gradient(135deg,#FAF6EF 0%,#F3EDE2 100%);
  position:relative;overflow:hidden;
}
.prd-hero::before{
  content:'';position:absolute;top:-200px;right:-150px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(92,199,62,.08) 0%,transparent 70%);
  pointer-events:none;
}
.prd-hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-8);
  align-items:center;position:relative;
}
@media (max-width:880px){.prd-hero-grid{grid-template-columns:1fr;gap:var(--space-5)}}

.prd-hero-text .eyebrow{margin-bottom:var(--space-3)}
.prd-hero-text h1{
  font-size:clamp(28px,4vw,46px);line-height:1.1;
  letter-spacing:-.02em;margin-bottom:var(--space-4);
}
.prd-hero-text h1 em{
  color:var(--accent);font-style:normal;font-weight:900;
}
.prd-hero-text p.lead{
  font-size:var(--t-md);color:var(--ink-soft);line-height:1.6;
  margin-bottom:var(--space-5);max-width:560px;
}
.prd-hero-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.prd-hero-bullets{
  list-style:none;padding:0;margin:var(--space-5) 0 0;
  display:flex;flex-wrap:wrap;gap:8px 18px;
}
.prd-hero-bullets li{
  font-size:13px;color:var(--ink-dim);font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
}
.prd-hero-bullets li::before{
  content:'✓';color:var(--accent);font-weight:800;font-size:14px;
}
.prd-hero-img{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  aspect-ratio:4/3;background:#FFFFFF;
  border:1px solid var(--line);
}
.prd-hero-img img{width:100%;height:100%;object-fit:contain;display:block;padding:24px}

/* ---------- USP (Pourquoi nous) ---------- */
.prd-usp{padding:var(--space-7) 0;background:var(--bg)}
.prd-usp-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:1100px;margin:0 auto;
}
@media (max-width:780px){.prd-usp-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.prd-usp-grid{grid-template-columns:1fr}}

.prd-usp-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 20px;text-align:left;
  transition:all .18s;
}
.prd-usp-card:hover{
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(92,199,62,.10);
}
.prd-usp-emoji{font-size:32px;line-height:1;margin-bottom:12px}
.prd-usp-card h3{
  font-size:16px;font-weight:700;color:var(--ink);
  margin-bottom:6px;line-height:1.25;letter-spacing:-.01em;
}
.prd-usp-card p{font-size:13.5px;color:var(--ink-dim);line-height:1.55;margin:0}

/* ---------- Variantes ---------- */
.prd-variants{padding:var(--space-8) 0}
.prd-section-head{text-align:center;max-width:680px;margin:0 auto var(--space-6)}
.prd-section-head h2{font-size:clamp(24px,3vw,36px);line-height:1.15;margin-bottom:var(--space-3)}
.prd-section-head h2 em{color:var(--accent);font-style:normal}
.prd-section-head p{color:var(--ink-soft);font-size:var(--t-base);line-height:1.6}

.prd-variants-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:880px){.prd-variants-grid{grid-template-columns:1fr}}

.prd-variant{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:all .2s;
  display:flex;flex-direction:column;
}
.prd-variant:hover{
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(0,0,0,.08);
}
.prd-variant-img{aspect-ratio:5/3;background:#FFFFFF;overflow:hidden;border-bottom:1px solid var(--line)}
.prd-variant-img img{width:100%;height:100%;object-fit:contain;display:block;padding:14px}
.prd-variant-body{padding:22px 24px;flex:1;display:flex;flex-direction:column}
.prd-variant-tag{
  display:inline-block;padding:4px 12px;
  background:rgba(92,199,62,.10);color:var(--accent-hi);
  border-radius:var(--radius-full);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.10em;
  margin-bottom:10px;align-self:flex-start;
}
.prd-variant h3{
  font-size:19px;font-weight:700;color:var(--ink);
  margin-bottom:8px;line-height:1.2;letter-spacing:-.01em;
}
.prd-variant p{
  font-size:14px;color:var(--ink-soft);line-height:1.55;
  margin:0 0 14px;flex:1;
}
.prd-variant ul{
  list-style:none;padding:0;margin:0;
  font-size:13px;color:var(--ink-dim);
}
.prd-variant ul li{padding:4px 0;display:flex;gap:8px;align-items:flex-start}
.prd-variant ul li::before{content:'•';color:var(--accent);font-weight:800;flex-shrink:0}

/* ---------- Specs techniques ---------- */
.prd-specs{padding:var(--space-8) 0;background:var(--bg)}
.prd-specs-table{
  max-width:840px;margin:0 auto;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.prd-specs-row{
  display:grid;grid-template-columns:240px 1fr;gap:0;
  border-bottom:1px solid var(--line-soft);
}
.prd-specs-row:last-child{border-bottom:none}
.prd-specs-row dt{
  padding:18px 24px;
  background:rgba(0,0,0,.025);
  font-size:13px;font-weight:700;color:var(--ink-soft);
  text-transform:uppercase;letter-spacing:.08em;
  display:flex;align-items:center;
}
.prd-specs-row dd{
  padding:18px 24px;margin:0;
  font-size:14px;color:var(--ink);line-height:1.55;
}
@media (max-width:600px){
  .prd-specs-row{grid-template-columns:1fr;gap:0}
  .prd-specs-row dt{padding:12px 18px 6px;background:transparent;font-size:11px}
  .prd-specs-row dd{padding:0 18px 14px;font-size:13.5px}
}


/* ---------- Cas d'usage (Pour qui) ---------- */
.prd-personas{padding:var(--space-8) 0}
.prd-personas-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  max-width:1100px;margin:0 auto;
}
@media (max-width:880px){.prd-personas-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.prd-personas-grid{grid-template-columns:1fr}}

.prd-persona{
  padding:20px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;align-items:flex-start;gap:14px;
  transition:all .18s;
}
.prd-persona:hover{border-color:var(--accent);transform:translateX(2px)}
.prd-persona-emoji{font-size:28px;line-height:1;flex-shrink:0}
.prd-persona-text strong{
  display:block;font-size:14.5px;color:var(--ink);font-weight:700;
  margin-bottom:4px;letter-spacing:-.01em;
}
.prd-persona-text span{font-size:13px;color:var(--ink-dim);line-height:1.5}

/* ---------- Galerie réalisations (TOUTES les photos) ---------- */
.prd-gallery{padding:var(--space-8) 0;background:var(--bg)}
.prd-gallery-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);gap:10px;
  max-width:1240px;margin:0 auto;
}
@media (max-width:1100px){.prd-gallery-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:780px){.prd-gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:480px){.prd-gallery-grid{grid-template-columns:repeat(2,1fr)}}

.prd-gallery-item{
  aspect-ratio:1/1;background:#FFFFFF;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);overflow:hidden;
  position:relative;
  transition:all .2s;
}
.prd-gallery-item:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,.10);
  border-color:var(--accent);
}
.prd-gallery-item img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .35s;padding:6px}
.prd-gallery-item:hover img{transform:scale(1.04)}

/* ---------- FAQ produit ---------- */
.prd-faq{padding:var(--space-8) 0}
.prd-faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.prd-faq-item{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all .2s;
}
.prd-faq-item[open]{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.prd-faq-item summary{
  padding:18px 24px;padding-right:56px;
  font-family:var(--font-display);
  font-size:15px;font-weight:700;color:var(--ink);
  cursor:pointer;list-style:none;position:relative;line-height:1.35;
}
.prd-faq-item summary::-webkit-details-marker{display:none}
.prd-faq-item summary::after{
  content:'+';position:absolute;right:24px;top:50%;
  transform:translateY(-50%);
  font-size:22px;font-weight:300;color:var(--accent);
  transition:transform .25s;
}
.prd-faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.prd-faq-item summary:hover{background:rgba(92,199,62,.03)}
.prd-faq-content{
  padding:0 24px 18px;
  font-size:14px;color:var(--ink-soft);line-height:1.65;
  border-top:1px solid var(--line-soft);
}
.prd-faq-content p:first-child{padding-top:14px;margin-top:0}

/* ---------- CTA final ---------- */
.prd-cta-final{
  padding:var(--space-8) 0;
  background:linear-gradient(135deg,#162E0D 0%,#0E2020 100%);
  color:#FAF6EF;text-align:center;
  position:relative;overflow:hidden;
}
.prd-cta-final::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(92,199,62,.18) 0%,transparent 60%);
  pointer-events:none;
}
.prd-cta-final-inner{position:relative;max-width:620px;margin:0 auto;padding:0 20px}
.prd-cta-final h2{
  color:#FAF6EF;font-size:clamp(26px,3.2vw,38px);
  line-height:1.15;margin-bottom:var(--space-3);
}
.prd-cta-final h2 em{color:#A8C84A;font-style:normal}
.prd-cta-final p{
  color:rgba(250,246,239,.78);font-size:var(--t-base);
  line-height:1.6;margin:0 auto var(--space-5);max-width:480px;
}
.prd-cta-final .btn-row{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
}
.prd-cta-final .btn-primary{
  background:var(--accent);color:#fff;border:none;
  padding:14px 28px;border-radius:10px;
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  font-size:13px;text-decoration:none;
  transition:all .2s;display:inline-flex;align-items:center;gap:8px;
}
.prd-cta-final .btn-primary:hover{
  transform:translateY(-2px);background:var(--accent-hi);
  box-shadow:0 8px 24px rgba(92,199,62,.32);
}
.prd-cta-final .btn-ghost{
  background:transparent;color:#FAF6EF;
  border:1px solid rgba(250,246,239,.30);
  padding:14px 28px;border-radius:10px;
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  font-size:13px;text-decoration:none;
  transition:all .2s;
}
.prd-cta-final .btn-ghost:hover{
  background:rgba(250,246,239,.08);border-color:rgba(250,246,239,.50);
}

/* === Compat accent vert (override historique site) === */
[class*="accent-2"]:not(.prd-faq-content):not(.prd-faq-item),em{color:#5CC73E !important}
[class*="eyebrow"]::before,[class*="eyebrow"]::after{display:none !important;content:none !important}

/* === Placeholders graphiques pour les variantes (matchent toujours le texte) === */
.prd-variant-illus{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:#fff;
  background:linear-gradient(135deg,#5CC73E 0%,#3F8C28 100%);
  position:relative;overflow:hidden;
}
.prd-variant-illus::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.18) 0%,transparent 60%);
  pointer-events:none;
}
.prd-illus-emoji{
  font-size:78px;line-height:1;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.25));
  position:relative;z-index:1;
}
.prd-illus-label{
  font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:.10em;
  opacity:.92;position:relative;z-index:1;
  text-align:center;padding:0 16px;
}
/* Variantes de couleurs */
.prd-illus--carmin{background:linear-gradient(135deg,#B90E4E 0%,#8B0A3A 100%)}
.prd-illus--dark  {background:linear-gradient(135deg,#1C1814 0%,#2E2820 100%)}
.prd-illus--olive {background:linear-gradient(135deg,#6B8B1F 0%,#4D6815 100%)}

/* ---------- Mini CTA inline (remplace variantes + personas) ---------- */
.prd-mini-cta{
  padding:var(--space-5) 0;
}
.prd-mini-cta-inner{
  max-width:1100px;margin:0 auto;
  background:linear-gradient(135deg,#162E0D 0%,#0E2020 100%);
  color:#FAF6EF;
  border-radius:var(--radius-lg);
  padding:24px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  flex-wrap:wrap;
  box-shadow:0 12px 32px rgba(0,0,0,.10);
}
.prd-mini-cta-text{display:flex;flex-direction:column;gap:4px;flex:1;min-width:240px}
.prd-mini-cta-text strong{
  font-family:var(--font-display);
  font-size:18px;font-weight:800;color:#FAF6EF;
  letter-spacing:-.01em;
}
.prd-mini-cta-text span{
  font-size:14px;color:rgba(250,246,239,.78);
}
.prd-mini-cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;
  background:var(--accent);color:#fff;
  border-radius:10px;text-decoration:none;
  font-weight:700;font-size:14px;letter-spacing:.04em;
  text-transform:uppercase;
  transition:all .2s;flex-shrink:0;
  box-shadow:0 4px 14px rgba(92,199,62,.30);
}
.prd-mini-cta-btn:hover{
  background:var(--accent-hi);transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(92,199,62,.42);
}
@media (max-width:560px){
  .prd-mini-cta-inner{padding:20px 22px;flex-direction:column;align-items:stretch;text-align:center;gap:16px}
  .prd-mini-cta-btn{justify-content:center}
}

/* ============================================================
   Tier 1 SEO — composants ajoutés sur les pages produit
   (metadata bar, TOC, témoignage, sources)
   ============================================================ */

/* --- Metadata bar (auteur + dates + reading time) --- */
.prd-meta{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  margin:var(--space-3) 0 var(--space-4);
  font-size:13.5px;color:var(--ink-soft);
}
.prd-meta .meta-item{display:inline-flex;align-items:center;gap:6px}
.prd-meta a{color:var(--ink-soft);text-decoration:none;font-weight:600}
.prd-meta a:hover{color:var(--accent)}
.prd-meta .dot{width:3px;height:3px;background:var(--ink-dim);border-radius:50%}

/* --- Table des matières interactive --- */
.prd-toc-section{padding:var(--space-4) 0;background:transparent}
.prd-toc{
  background:#FAF6EF;border-radius:8px;padding:18px 22px;
  max-width:780px;margin:0 auto;
}
.prd-toc summary{
  font-family:'Quicksand',sans-serif;font-size:15px;font-weight:700;
  color:#14100C;cursor:pointer;outline:none;list-style:none;
  display:flex;align-items:center;gap:10px;
}
.prd-toc summary::-webkit-details-marker{display:none}
.prd-toc summary::before{content:'▸';color:var(--accent);transition:transform .2s ease}
.prd-toc[open] summary::before{transform:rotate(90deg)}
.prd-toc ol{margin:14px 0 0 0;padding:0;list-style:none;counter-reset:toc}
.prd-toc li{counter-increment:toc;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.prd-toc li:last-child{border-bottom:none}
.prd-toc li::before{content:counter(toc) ".";color:var(--accent);font-weight:700;margin-right:10px}
.prd-toc a{color:var(--ink);text-decoration:none;font-size:14px}
.prd-toc a:hover{color:var(--accent)}

/* --- Bloc témoignage client --- */
.prd-testimonial-section{padding:var(--space-5) 0;background:#fff}
.prd-testimonial{
  background:#FAF6EF;border-radius:8px;padding:24px 26px;
  max-width:780px;margin:0 auto;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  position:relative;
}
.prd-testimonial::before{
  content:'"';position:absolute;top:-10px;left:18px;
  font-size:60px;color:var(--accent);
  font-family:Georgia,serif;line-height:1;
}
.prd-testimonial p{
  font-size:16px;line-height:1.6;color:#14100C;
  margin:0 0 12px;font-style:italic;
}
.prd-testimonial cite{
  display:block;font-style:normal;font-size:13.5px;
  color:var(--ink-soft);font-weight:600;
}
.prd-testimonial cite strong{color:#14100C;font-weight:700}

/* --- Bloc sources externes --- */
.prd-sources-section{padding:var(--space-4) 0 var(--space-6);background:#fff}
.prd-sources{
  background:#FAF6EF;border-radius:8px;padding:18px 22px;
  max-width:780px;margin:0 auto;
}
.prd-sources h3{
  font-family:'Quicksand',sans-serif;font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-soft);margin:0 0 12px;
}
.prd-sources ul{margin:0;padding:0;list-style:none}
.prd-sources li{padding:6px 0;font-size:14px;color:#4F4A42;line-height:1.5}
.prd-sources li::before{content:'→';color:var(--accent);font-weight:700;margin-right:10px}
.prd-sources a{color:#14100C;text-decoration:none;font-weight:600}
.prd-sources a:hover{color:var(--accent)}
