
/* ════════════════════════════════════════════════════════════════
   Variables CSS — à surcharger au besoin
   ════════════════════════════════════════════════════════════════ */
:root {
  --ep-green:     #128C7E;
  --ep-green2:    #075E54;
  --ep-gold:      #F4A724;
  --ep-dark:      #0f172a;
  --ep-gray:      #64748b;
  --ep-light-bg:  #f8fafc;
  --ep-border:    #e2e8f0;
  --ep-radius:    .75rem;
  --ep-shadow:    0 4px 24px rgba(0,0,0,.07);
  --ep-font:      'Inter', 'Outfit', system-ui, sans-serif;
}

/* ════════════════════════ VITRINE — Fiche produit ════════════════ */

.product-detail { max-width: 1100px; margin: 0 auto; padding: 2.5rem 1.5rem; }
.product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 768px) { .product-layout { grid-template-columns: 1fr; } }

/* Galerie */
.product-gallery__main { border-radius: var(--ep-radius); overflow: hidden; aspect-ratio: 1;
  background: var(--ep-light-bg); border: 1px solid var(--ep-border); }
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.product-gallery__thumbs { display: flex; gap: .5rem; margin-top: .75rem; flex-wrap: wrap; }
.thumb { width: 70px; height: 70px; border-radius: .5rem; object-fit: cover; cursor: pointer;
  border: 2px solid transparent; transition: border-color .2s; }
.thumb:hover, .thumb--active { border-color: var(--ep-green); }

/* Infos produit */
.product-info__category { font-size: .8rem; color: var(--ep-green); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.product-info__name { font-size: 1.8rem; font-weight: 900; color: var(--ep-dark); margin: .5rem 0; }
.product-info__price { font-size: 2rem; font-weight: 800; color: var(--ep-green); margin: 1rem 0; }
.product-info__price small { font-size: 1rem; font-weight: 500; color: var(--ep-gray); }
.product-info__desc { color: var(--ep-gray); line-height: 1.8; margin-bottom: 1.5rem; }

/* Actions */
.product-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.qty-input { width: 80px; padding: .6rem .75rem; border: 1.5px solid var(--ep-border);
  border-radius: .6rem; font-size: 1rem; text-align: center; }

/* Badges */
.badge-stock { display: inline-flex; align-items: center; gap: .3rem; padding: .25rem .75rem;
  border-radius: 999px; font-size: .8rem; font-weight: 600; }
.badge-stock--ok  { background: #dcfce7; color: #16a34a; }
.badge-stock--low { background: #fef9c3; color: #a16207; }
.badge-stock--out { background: #fee2e2; color: #dc2626; }
