﻿/* ===== LEGANCY BOUTIQUE - DESIGN PREMIUM SOMBRE V4 ===== */
/* Style luxe, futuriste, animations elegantes, 100% responsive */

:root {
  --bg: #0a0a0a;
  --bg-secondary: #131313;
  --bg-tertiary: #1a1a1a;
  --card: rgba(255, 255, 255, 0.05);
  --card-hover: rgba(255, 255, 255, 0.08);
  --stroke: rgba(255, 255, 255, 0.08);
  --stroke-light: rgba(255, 255, 255, 0.04);
  --text: #ffffff;
  --text-muted: rgba(255, 255, 255, 0.7);
  --text-muted-2: rgba(255, 255, 255, 0.55);
  --accent: #ffffff;
  --primary-glow: #3b82f6;
  --secondary-glow: #8b5cf6;
  --success: #10b981;
  --danger: #ef4444;
  --spacing-xs: 8px;
  --spacing-sm: 12px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 48px;
  --radius: 16px;
  --radius-lg: 24px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }

html {
  overflow-x: hidden;
  width: 100%;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: clamp(12px, 1.5vw, 16px);
  line-height: 1.6;
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
  /* Fond noir marbré premium, subtil et non intrusif */
  background-image:
    radial-gradient(1400px 900px at 12% 14%, rgba(59, 130, 246, 0.06), transparent 62%),
    radial-gradient(1200px 700px at 80% 18%, rgba(139, 92, 246, 0.05), transparent 58%),
    radial-gradient(900px 600px at 35% 82%, rgba(59, 130, 246, 0.04), transparent 64%),
    linear-gradient(130deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.02) 18%, rgba(255, 255, 255, 0) 34%),
    linear-gradient(310deg, rgba(255, 255, 255, 0.03) 8%, rgba(255, 255, 255, 0.01) 26%, rgba(255, 255, 255, 0) 40%),
    linear-gradient(180deg, rgba(10, 10, 10, 0) 0%, rgba(10, 10, 10, 1) 100%);
  background-attachment: fixed;
  background-blend-mode: lighten, lighten, lighten, normal, normal, normal;
}

a { color: inherit; text-decoration: none; }

/* MAIN CONTAINER */
main {
  width: 100%;
  max-width: 100vw;
  overflow-x: hidden;
}

.header {
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(12px);
  background: rgba(10, 10, 10, 0.7);
  border-bottom: 1px solid var(--stroke);
}

.header-inner {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px clamp(8px, 1.5vw, 16px);
  gap: var(--spacing-sm);
  box-sizing: border-box;
  overflow-x: hidden;
}

.brand { display: flex; align-items: center; gap: var(--spacing-sm); flex-shrink: 0; }
.brand-logo { width: clamp(40px, 5vw, 56px); height: clamp(40px, 5vw, 56px); border-radius: 12px; object-fit: cover; border: 1px solid var(--stroke); }
.brand-text { display: flex; flex-direction: column; min-width: 0; }
.brand-name { font-weight: 900; letter-spacing: 0.08em; font-size: clamp(10px, 1.2vw, 12px); line-height: 1.2; }
.brand-tag { font-size: clamp(9px, 1vw, 11px); color: var(--text-muted-2); margin-top: 2px; }

.nav { display: flex; gap: clamp(8px, 1vw, 24px); align-items: center; flex: 1; justify-content: center; }
.nav a { font-size: clamp(10px, 1.1vw, 12px); color: var(--text-muted); transition: all 0.2s; }
.nav a:hover { color: var(--text); }

.nav .dropdown { position: relative; }
.nav .dropdown-toggle { background: transparent; border: none; color: var(--text-muted); font-size: clamp(10px, 1.1vw, 12px); padding: 6px 4px; cursor: pointer; transition: all 0.2s; }
.nav .dropdown-toggle:hover { color: var(--text); }

.nav .dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  display: none; min-width: 160px;
  background: var(--bg-secondary); border: 1px solid var(--stroke); padding: 6px;
  border-radius: var(--radius); box-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
  z-index: 200; backdrop-filter: blur(12px);
}

.nav .dropdown-menu a, .nav .dropdown-menu button {
  display: block; width: 100%; padding: 8px 12px;
  border: none; background: transparent; text-align: left;
  border-radius: 8px; cursor: pointer; transition: all 0.2s;
}

.nav .dropdown-menu a:hover, .nav .dropdown-menu button:hover {
  background: rgba(59, 130, 246, 0.15);
  color: var(--primary-glow);
}

.nav .dropdown:hover .dropdown-menu { display: block; }
.nav .dropdown:focus-within .dropdown-menu { display: block; }

.header-actions { 
  display: flex; 
  gap: var(--spacing-sm); 
  align-items: center; 
  flex-shrink: 0;
  margin-left: auto;
}

.btn, .primary-btn, .secondary-btn, .wa-btn, .cart-btn, .chip, .icon-btn {
  border: 1px solid var(--stroke);
  background: var(--card);
  color: var(--text);
  padding: clamp(8px, 1.5vw, 14px) clamp(10px, 2vw, 16px);
  border-radius: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
  font-size: clamp(10px, 1.1vw, 12px);
  font-weight: 500;
  transition: all 0.3s;
  white-space: nowrap;
  width: fit-content;
  max-width: 100%;
}

.primary-btn {
  background: linear-gradient(135deg, var(--primary-glow) 0%, #6366f1 100%);
  color: white;
  border: none;
  font-weight: 600;
}

.primary-btn:hover { transform: translateY(-2px); box-shadow: 0 15px 30px rgba(59, 130, 246, 0.3); }
.secondary-btn:hover, .wa-btn:hover, .cart-btn:hover, .chip:hover { background: var(--card-hover); border-color: rgba(255, 255, 255, 0.15); }

/* Bouton WhatsApp dans la section Best Sellers */
.wa-floating-btn {
  position: static;
  width: 44px;
  height: 44px;
  background: #25D366;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
  transition: all 0.3s ease;
  cursor: pointer;
  flex-shrink: 0;
}

.wa-floating-btn:hover {
  background: #128C7E;
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.5);
}

.wa-floating-btn svg {
  width: 22px;
  height: 22px;
}

/* Icône WhatsApp seulement (legacy) */
.wa-inline {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  background: #25D366;
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
  transition: all 0.3s ease;
  cursor: pointer;
  flex-shrink: 0;
}

.wa-inline:hover {
  background: #128C7E;
  transform: scale(1.06);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.5);
}

.wa-inline svg {
  width: 22px;
  height: 22px;
}

.back-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: clamp(12px, 2vh, 16px) 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.back-row .back-button {
  margin: 0;
}

.back-row .back-button svg {
  flex-shrink: 0;
}
.wa-btn.icon-only {
  padding: clamp(10px, 1.8vw, 14px);
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.wa-btn.icon-only svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.wa-btn.icon-only:hover {
  background: rgba(37, 211, 102, 0.15);
  border-color: #25D366;
  color: #25D366;
}

/* Bouton panier avec icône et badge */
.cart-btn.icon-with-badge {
  padding: clamp(10px, 1.8vw, 14px);
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 0;
}

.cart-btn.icon-with-badge svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.cart-btn.icon-with-badge .cart-count {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
}

.chip { padding: 8px 12px; font-size: 12px; }
.chip.active { background: var(--primary-glow); border-color: var(--primary-glow); color: white; }

.cart-count {
  background: var(--danger);
  color: white;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
}

.container { 
  width: 100%;
  max-width: 100vw;
  margin: 0 auto; 
  padding: 0;
  overflow-x: hidden;
  box-sizing: border-box;
}

/* ===== BOUTON RETOUR ===== */
.back-button {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: clamp(10px, 1.5vw, 12px) clamp(14px, 2vw, 18px);
  margin: clamp(16px, 2.5vh, 24px) 0 clamp(12px, 2vh, 20px) 0;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  color: var(--text);
  font-size: clamp(12px, 1.2vw, 14px);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
  backdrop-filter: blur(8px);
  min-height: 44px;
  flex-shrink: 0;
}

.back-button:hover {
  background: var(--card-hover);
  border-color: var(--primary-glow);
  color: var(--primary-glow);
  transform: translateX(-4px);
}

.back-button svg {
  width: 20px;
  height: 20px;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.back-button:hover svg {
  transform: translateX(-3px);
}

/* HERO */
.hero-wrapper {
  position: relative;
  width: 100%;
  height: 100vh;
  max-height: clamp(300px, 70vh, 680px);
  overflow: hidden;
  margin-bottom: clamp(32px, 5vh, 48px);
  animation: heroFadeIn 0.9s ease-out;
}

.hero-slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.hero-track {
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.hero-slide {
  position: relative;
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  overflow: hidden;
}

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.8) contrast(1.1);
}

.hero-slide::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(139, 92, 246, 0.08));
  z-index: 2;
}

.hero-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  text-align: center;
}

.hero-left { z-index: 15; }

.hero-title {
  font-size: clamp(28px, 8vw, 72px);
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 var(--spacing-lg) 0;
  background: linear-gradient(135deg, #ffffff 0%, rgba(255, 255, 255, 0.8) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: heroRise 0.7s ease-out;
}

.hero-subtitle {
  font-size: clamp(13px, 2.5vw, 18px);
  color: var(--text-muted);
  margin: 0 0 var(--spacing-lg) 0;
  max-width: 600px;
  animation: heroRise 0.9s ease-out 0.08s both;
}

.hero-buttons { display: flex; gap: var(--spacing-md); justify-content: center; flex-wrap: wrap; animation: heroRise 1s ease-out 0.12s both; }

.hero-controls {
  position: absolute;
  bottom: var(--spacing-lg);
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
}

.hero-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  transition: all 0.3s;
}

.hero-dot.active {
  background: var(--primary-glow);
  width: 24px;
  border-radius: 4px;
  box-shadow: 0 0 12px rgba(59, 130, 246, 0.35);
}

/* Animations douces pour le hero */
@keyframes heroFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes heroRise {
  from { opacity: 0; transform: translateY(14px) scale(0.99); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes heroFloat {
  0% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
  100% { transform: translateY(0); }
}

.hero-controls { animation: heroFloat 9s ease-in-out infinite; }

/* Accessibilité : réduire l’animation si préférée */
@media (prefers-reduced-motion: reduce) {
  .hero-wrapper,
  .hero-title,
  .hero-subtitle,
  .hero-buttons,
  .hero-controls,
  .hero-track {
    animation: none !important;
    transition: none !important;
  }
}

.hero-catalogue-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: clamp(24px, 4vh, 48px) clamp(12px, 2vw, 32px) clamp(16px, 3vh, 32px);
}

.hero-catalogue-title h2 {
  font-size: clamp(24px, 6vw, 48px);
  margin: 0;
  font-weight: 900;
  letter-spacing: -0.01em;
}

/* SECTIONS */
.section {
  padding: clamp(24px, 4vh, 48px) clamp(12px, 2vw, 32px);
  margin-bottom: clamp(32px, 4vh, 48px);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow-x: hidden;
}

.section-head {
  margin-bottom: clamp(20px, 3vh, 32px);
}

.section-head h2 {
  font-size: clamp(20px, 5vw, 40px);
  margin: 0 0 clamp(16px, 2vh, 24px) 0;
  font-weight: 900;
}

.filters { display: flex; gap: var(--spacing-md); flex-wrap: wrap; justify-content: center; }

/* GRID - ADAPTIVE FLUID */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(150px, 20vw, 280px), 1fr));
  gap: clamp(12px, 2vw, 32px);
}

.product-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all 0.3s;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.product-card:hover {
  background: var(--card-hover);
  border-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(59, 130, 246, 0.15);
}

.product-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 1.05;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.3);
}

.product-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.3s;
}

.product-card:hover .product-image {
  transform: scale(1.06);
  filter: brightness(1.08);
}

.product-badge {
  position: absolute;
  top: clamp(6px, 1.5vw, 12px);
  right: clamp(6px, 1.5vw, 12px);
  background: linear-gradient(135deg, var(--danger) 0%, #dc2626 100%);
  color: white;
  padding: clamp(4px, 0.8vw, 6px) clamp(8px, 1.5vw, 12px);
  border-radius: 999px;
  font-size: clamp(9px, 1.1vw, 11px);
  font-weight: 700;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  width: auto;
  max-width: max-content;
  flex: 0 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.15);
  transition: all 0.15s ease;
  letter-spacing: 0.03em;
}

.product-badge:hover {
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
  transform: scale(1.05);
}

.badge-promo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--danger) 0%, #dc2626 100%);
  color: white;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  border: 1px solid rgba(255, 255, 255, 0.15);
  transition: all 0.15s ease;
  letter-spacing: 0.03em;
  width: auto;
  max-width: max-content;
  flex: 0 0 auto;
  align-self: flex-start;
}

.badge-promo:hover {
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
  transform: scale(1.05);
}

.product-info {
  padding: clamp(10px, 2vw, 16px);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(4px, 1vw, 8px);
}

.product-category {
  font-size: clamp(9px, 1vw, 11px);
  color: var(--primary-glow);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
}

.product-name {
  font-size: clamp(12px, 1.8vw, 14px);
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-price { display: flex; gap: clamp(6px, 1.5vw, 10px); align-items: center; margin-bottom: auto; margin-top: auto; }
.price-current { font-size: clamp(13px, 1.8vw, 16px); font-weight: 800; color: var(--primary-glow); }
.price-old { font-size: clamp(11px, 1.3vw, 13px); color: var(--text-muted-2); text-decoration: line-through; }

.product-actions { display: flex; gap: clamp(6px, 1.5vw, 12px); margin-top: clamp(8px, 1.5vw, 12px); }

.add-to-cart-btn {
  background: linear-gradient(135deg, var(--primary-glow) 0%, #6366f1 100%);
  border: none;
  color: white;
  padding: clamp(8px, 1.5vw, 12px) clamp(10px, 1.5vw, 14px);
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  font-size: clamp(10px, 1.2vw, 12px);
  transition: all 0.3s;
  width: fit-content;
}

.add-to-cart-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(59, 130, 246, 0.25); }

/* Quick Size Picker (on product cards) */
.quick-picker {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 200ms ease, opacity 200ms ease;
  margin-top: 0;
  background: transparent;
  border: none;
  padding: 0;
}

.quick-picker.open {
  max-height: 140px;
  opacity: 1;
  margin-top: clamp(8px, 1.5vw, 12px);
}

.quick-picker-content {
  padding: 8px 0;
  animation: slideUp 200ms ease;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.quick-picker-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.variant-pill-card {
  border: 1px solid #ffffff;
  background: #ffffff;
  color: #000000;
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: clamp(10px, 1.2vw, 12px);
  font-weight: 600;
  text-align: center;
  flex-shrink: 0;
  white-space: nowrap;
  min-width: 44px;
}

.variant-pill-card:hover {
  border-color: #ffffff;
  background: #f0f0f0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  transform: translateY(-1px);
}

.variant-pill-card:active {
  border-color: #000000;
  background: #000000;
  color: #ffffff;
  transform: scale(0.98);
}

/* PRODUCT DETAIL */
.product-detail {
  display: block;
  padding: clamp(24px, 4vh, 48px) clamp(12px, 2vw, 32px);
  max-width: 100%;
  width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
}

.product-layout {
  display: grid;
  grid-template-columns: 1fr 0.9fr;
  gap: clamp(24px, 5vw, 48px);
  margin-bottom: clamp(32px, 4vh, 48px);
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
  overflow-x: hidden;
}

.product-gallery-section { 
  display: flex; 
  flex-direction: column; 
  gap: var(--spacing-lg);
  max-width: 100%;
  overflow-x: hidden;
}
.product-purchase-section { display: flex; flex-direction: column; gap: var(--spacing-lg); justify-content: flex-start; align-items: flex-start; }

.product-purchase-section > :not(.add-to-cart-btn-large):not(.product-actions-large) {
  width: auto;
  flex: 0 0 auto;
}

.product-detail-name {
  align-self: flex-start;
  width: auto;
}

.product-detail-price {
  align-self: flex-start;
  width: auto;
}

.promo-badge-wrapper {
  display: inline-flex;
  width: auto;
  flex: 0 0 auto;
  align-self: flex-start;
}

.product-gallery { display: flex; flex-direction: column; gap: var(--spacing-md); }

.product-main-image {
  width: 100%;
  max-height: clamp(320px, 60vh, 520px); /* limite visuelle pour éviter le scroll excessif */
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--card);
}

.product-main-image img {
  width: 100%;
  height: 100%;
  object-fit: contain; /* privilégie la visibilité complète du produit */
  transition: all 0.3s;
}

.product-thumbnails { 
  display: flex; 
  gap: var(--spacing-md); 
  overflow-x: auto; 
  overflow-y: hidden;
  padding: 8px 0;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

.product-thumbnails::-webkit-scrollbar {
  height: 6px;
}

.product-thumbnails::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 3px;
}

.product-thumbnails::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.3);
  border-radius: 3px;
}

.product-thumbnails::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.5);
}

.product-thumbnail {
  width: 80px;
  height: 80px;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.3s;
  flex-shrink: 0;
}

.product-thumbnail img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: var(--card);
}

.product-thumbnail:hover, .product-thumbnail.active { border-color: var(--primary-glow); }

.product-details-info { display: flex; flex-direction: column; gap: var(--spacing-lg); margin-top: var(--spacing-lg); }

.product-detail-name { font-size: clamp(20px, 4vw, 32px); font-weight: 900; margin: 0; }

.product-detail-price { display: flex; align-items: baseline; gap: clamp(16px, 2vw, 24px); }
.product-detail-current-price { font-size: clamp(24px, 4vw, 40px); font-weight: 900; color: var(--primary-glow); }
.product-detail-old-price { font-size: clamp(16px, 2.5vw, 24px); color: var(--text-muted-2); text-decoration: line-through; }

.variant-selector { margin: 18px 0 12px; display: flex; flex-direction: column; gap: 8px; background: transparent; border: none; border-radius: 0; padding: 0; }
.variant-label { display: none; }
.variant-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.variant-pill { border: 1px solid #ffffff; background: #ffffff; color: #000000; padding: 8px 14px; border-radius: 999px; cursor: pointer; transition: all 0.2s ease; min-width: 44px; font-size: 13px; font-weight: 600; text-align: center; }
.variant-pill:hover { border-color: #ffffff; background: #f0f0f0; box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.variant-pill.is-selected { border-color: #000000; box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5); background: #000000; color: #ffffff; }
.variant-current { font-size: 12px; color: var(--text-muted); margin-top: 4px; }

.product-description { color: var(--text-muted); font-size: clamp(12px, 1.8vw, 15px); line-height: 1.8; }

.product-benefits { background: var(--card); border: 1px solid var(--stroke); border-radius: var(--radius); padding: var(--spacing-md); }
.product-benefits h3 { margin: 0 0 var(--spacing-md) 0; font-size: 14px; font-weight: 700; text-transform: uppercase; }

.benefits-list { list-style: none; margin: 0; padding: 0; }
.benefits-list li { padding: 8px 0; padding-left: 24px; position: relative; color: var(--text-muted); font-size: 13px; }
.benefits-list li::before { content: "✓"; position: absolute; left: 0; color: var(--success); font-weight: bold; }

.product-actions-large { display: flex; gap: clamp(12px, 2vw, 24px); }

.product-qty { display: flex; align-items: center; border: 1px solid var(--stroke); border-radius: 10px; background: var(--card); }
.qty-btn { background: transparent; border: none; color: var(--text); width: clamp(32px, 5vw, 40px); height: clamp(32px, 5vw, 40px); cursor: pointer; transition: all 0.2s; }
.qty-btn:hover { background: rgba(59, 130, 246, 0.1); }
.qty-input { background: transparent; border: none; color: var(--text); width: clamp(40px, 6vw, 50px); text-align: center; font-weight: 600; }

.add-to-cart-btn-large {
  background: linear-gradient(135deg, var(--primary-glow) 0%, #6366f1 100%);
  border: none;
  color: white;
  padding: clamp(12px, 2vw, 16px) clamp(20px, 4vw, 32px);
  border-radius: 12px;
  cursor: pointer;
  font-weight: 700;
  font-size: clamp(14px, 2vw, 18px);
  transition: all 0.3s;
  width: 100%;
  min-height: 48px;
}

.add-to-cart-btn-large:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(59, 130, 246, 0.25); }

.product-reviews { margin-top: var(--spacing-2xl); padding-top: var(--spacing-2xl); border-top: 1px solid var(--stroke); }
.product-reviews h3 { margin: 0 0 var(--spacing-lg) 0; font-size: 18px; font-weight: 900; }

.reviews-list { display: flex; flex-direction: column; gap: var(--spacing-lg); }

.review-card { background: var(--card); border: 1px solid var(--stroke); border-radius: var(--radius); padding: var(--spacing-md); }
.review-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--spacing-md); }
.review-author { font-weight: 600; font-size: 14px; }
.review-stars { color: var(--primary-glow); font-size: 12px; }
.review-text { color: var(--text-muted); font-size: 13px; line-height: 1.6; }
.cart-item-variant { font-size: 12px; color: var(--text-muted); margin: 4px 0 0; }

/* CONTACT */
.contact-card {
  background: linear-gradient(135deg, var(--card) 0%, var(--bg-secondary) 100%);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 4vh, 48px) clamp(16px, 3vw, 32px);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2vh, 24px);
}

.contact-card h2 { font-size: clamp(18px, 4vw, 32px); margin: 0; font-weight: 900; }
.contact-card p { color: var(--text-muted); font-size: clamp(12px, 1.8vw, 15px); margin: 0; }

/* FOOTER */
.footer { 
  background: var(--bg-secondary); 
  border-top: 1px solid var(--stroke); 
  padding: clamp(32px, 5vh, 48px) clamp(12px, 2vw, 32px); 
  margin-top: clamp(32px, 4vh, 48px);
  width: 100%;
  max-width: 100vw;
  overflow-x: hidden;
  box-sizing: border-box;
}

.footer-grid {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(180px, 20vw, 280px), 1fr));
  gap: clamp(24px, 3vh, 48px);
  margin-bottom: clamp(24px, 3vh, 32px);
  box-sizing: border-box;
  padding: 0 clamp(12px, 2vw, 32px);
}

.footer-section h3 { font-size: clamp(12px, 1.5vw, 14px); font-weight: 700; text-transform: uppercase; margin: 0 0 clamp(12px, 1.5vh, 16px) 0; }
.footer-section ul { list-style: none; margin: 0; padding: 0; }
.footer-section li { margin-bottom: clamp(8px, 1.2vh, 12px); }
.footer-section a { color: var(--text-muted); font-size: clamp(11px, 1.3vw, 13px); transition: all 0.2s; }
.footer-section a:hover { color: var(--primary-glow); }

.footer-bottom {
  width: 100%;
  max-width: 100vw;
  margin: 0 auto;
  border-top: 1px solid var(--stroke);
  padding: clamp(16px, 2vh, 24px) clamp(12px, 2vw, 32px);
  text-align: center;
  color: var(--text-muted-2);
  font-size: clamp(11px, 1.2vw, 12px);
  box-sizing: border-box;
}

/* MODAL */
.modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.8); backdrop-filter: blur(4px); z-index: 300; align-items: center; justify-content: center; }
.modal.open { display: flex; }

.modal-content {
  background: var(--bg-secondary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  max-width: 500px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--spacing-lg);
}

.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--spacing-lg); }
.modal-header h2 { margin: 0; font-size: 20px; }
.modal-close { background: transparent; border: none; color: var(--text); font-size: 24px; cursor: pointer; transition: all 0.2s; }
.modal-close:hover { color: var(--primary-glow); }

/* RESPONSIVE : ADAPTATIF & FLUIDE */
/* Les styles fluides ci-dessus s'ajustent continuellement avec clamp() */
/* Breakpoints pour changements structuraux uniquement */

@media (max-width: 1024px) {
  /* Conserver le panier à droite entre 768px et 1024px */
  .header-inner { flex-wrap: nowrap; row-gap: 0; column-gap: clamp(8px, 1.5vw, 14px); }
  .brand { order: 1; min-width: 0; }
  .nav { order: 2; flex: 1; min-width: 0; overflow-x: auto; padding: clamp(4px, 0.8vh, 6px) 0; justify-content: flex-start; }
  .header-actions { order: 3; margin-left: auto; flex-shrink: 0; }
  .mobile-menu-toggle { order: 4; flex-shrink: 0; }
  .product-detail { grid-template-columns: 1fr; gap: clamp(16px, 3vh, 32px); }
}

@media (max-width: 768px) {
  .header-inner { padding: clamp(8px, 1.5vh, 12px) 0; }
  .nav a, .nav button { padding: clamp(4px, 0.8vh, 6px) clamp(6px, 1.2vw, 8px); border-radius: 8px; background: rgba(255, 255, 255, 0.03); }
  .cart-modal { align-items: flex-end; justify-content: center; }
  .cart-modal-content { border-radius: 16px 16px 0 0; }
  .checkout-modal { align-items: flex-end; justify-content: center; }
  .checkout-modal-content { border-radius: 16px 16px 0 0; max-height: 100%; }
  
  /* Menu mobile à droite après le panier */
  .brand {
    order: 1;
    flex: 1;
    min-width: 0;
  }
  
  .header-actions {
    order: 2;
    margin-left: auto;
    display: flex;
    justify-content: flex-end;
  }
  
  .mobile-menu-toggle {
    order: 3;
    margin-left: var(--spacing-sm);
  }
  
  .cart-item {
    grid-template-columns: clamp(44px, 8vw, 52px) 1fr clamp(40px, 8vw, 46px);
    grid-template-areas: "img info remove" "qty total total";
    row-gap: clamp(8px, 1.2vw, 10px);
    column-gap: clamp(8px, 1.2vw, 10px);
  }
  .cart-item-image { grid-area: img; width: clamp(44px, 8vw, 52px); height: clamp(44px, 8vw, 52px); }
  .cart-item-info { grid-area: info; }
  .cart-item-quantity { grid-area: qty; }
  .cart-item-total { grid-area: total; text-align: right; }
  .cart-item-remove { grid-area: remove; justify-self: end; }
}

@media (max-width: 540px) {
  body { font-size: clamp(12px, 1.3vw, 14px); }
  .header-inner { gap: clamp(6px, 1vw, 8px); }
  .grid { grid-template-columns: repeat(auto-fit, minmax(clamp(140px, 45vw, 180px), 1fr)); gap: clamp(10px, 1.5vw, 18px); }
  
  .cart-item {
    grid-template-columns: clamp(40px, 8vw, 48px) 1fr clamp(32px, 6vw, 40px);
    row-gap: clamp(6px, 1vw, 8px);
    column-gap: clamp(8px, 1.2vw, 10px);
  }
  .cart-item-image { width: clamp(40px, 8vw, 48px); height: clamp(40px, 8vw, 48px); }
}

@media (max-width: 400px) {
  .grid { grid-template-columns: 1fr 1fr; gap: clamp(8px, 1.2vw, 14px); }
  .checkout-modal-content { max-height: 95vh; }
  .cart-item { grid-template-columns: 1fr clamp(28px, 5vw, 32px); grid-template-areas: "info remove" "img img" "qty total"; }
  .cart-item-image { justify-self: start; width: clamp(36px, 7vw, 44px); height: clamp(36px, 7vw, 44px); }
  
  /* Ultra mobile fix - reduce padding on very small screens */
  .section {
    padding: clamp(16px, 2.5vh, 24px) clamp(8px, 1.5vw, 16px);
  }
  
  .product-detail {
    padding: clamp(12px, 2vh, 24px) clamp(8px, 1.5vw, 16px);
  }
  
  .back-row {
    margin: clamp(8px, 1.5vh, 12px) 0;
  }
}

/* ===== SYSTÈME D'AVIS CLIENTS ===== */
.product-reviews-section {
  margin-top: clamp(32px, 5vh, 48px);
  padding-top: clamp(24px, 4vh, 32px);
  border-top: 1px solid var(--stroke);
}

.reviews-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: clamp(20px, 3vh, 28px);
  flex-wrap: wrap;
  gap: clamp(12px, 2vw, 16px);
}

.reviews-header h3 {
  font-size: clamp(18px, 2.5vw, 24px);
  margin: 0;
  font-weight: 700;
}

.review-summary {
  display: flex;
  align-items: center;
  gap: clamp(8px, 1.5vw, 12px);
  background: rgba(255, 255, 255, 0.03);
  padding: clamp(8px, 1.5vw, 12px) clamp(12px, 2vw, 16px);
  border-radius: 12px;
  border: 1px solid var(--stroke);
}

.review-summary-text {
  display: flex;
  align-items: center;
  gap: clamp(6px, 1vw, 8px);
  font-size: clamp(12px, 1.4vw, 14px);
}

.review-summary-text strong {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 700;
  color: var(--primary-glow);
}

.review-count {
  color: var(--text-muted-2);
  font-size: clamp(11px, 1.3vw, 13px);
}

/* Formulaire d'ajout d'avis */
.review-form-container {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: clamp(16px, 3vw, 24px);
  margin-bottom: clamp(24px, 4vh, 32px);
}

.review-form-container h4 {
  margin: 0 0 clamp(16px, 2.5vh, 20px) 0;
  font-size: clamp(14px, 1.8vw, 18px);
  font-weight: 600;
}

.review-form .form-group {
  margin-bottom: clamp(14px, 2.5vh, 18px);
}

.review-form .form-group label {
  display: block;
  margin-bottom: clamp(6px, 1vh, 8px);
  font-size: clamp(11px, 1.3vw, 13px);
  color: var(--text-muted);
  font-weight: 500;
}

.review-form .form-input {
  width: 100%;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--stroke);
  border-radius: 10px;
  padding: clamp(8px, 1.5vw, 12px);
  color: var(--text);
  font-size: clamp(11px, 1.4vw, 14px);
  font-family: inherit;
  transition: all 0.2s;
}

.review-form .form-input:focus {
  outline: none;
  border-color: var(--primary-glow);
  background: rgba(59, 130, 246, 0.05);
}

.review-form textarea.form-input {
  resize: vertical;
  min-height: 80px;
}

/* Système d'étoiles cliquables */
.star-rating-input {
  display: flex;
  gap: clamp(4px, 0.8vw, 6px);
  margin-top: clamp(6px, 1vh, 8px);
}

.star-input {
  font-size: clamp(20px, 3vw, 28px);
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}

.star-input.filled {
  color: #fbbf24;
  text-shadow: 0 0 8px rgba(251, 191, 36, 0.5);
}

.star-input.empty {
  color: rgba(255, 255, 255, 0.2);
}

.star-input:hover {
  transform: scale(1.15);
}

.error-message {
  color: var(--danger);
  font-size: clamp(10px, 1.2vw, 12px);
  margin-top: clamp(4px, 0.6vh, 6px);
  display: block;
}

/* Liste des avis */
.reviews-list-container {
  margin-top: clamp(24px, 4vh, 32px);
}

.reviews-list-container h4 {
  margin: 0 0 clamp(16px, 2.5vh, 20px) 0;
  font-size: clamp(14px, 1.8vw, 18px);
  font-weight: 600;
}

.no-reviews {
  text-align: center;
  padding: clamp(24px, 4vh, 32px);
  background: rgba(255, 255, 255, 0.02);
  border: 1px dashed var(--stroke);
  border-radius: var(--radius);
  color: var(--text-muted);
}

.no-reviews p {
  margin: 0;
  font-size: clamp(12px, 1.4vw, 14px);
}

/* Carte d'avis individuel */
.review-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  padding: clamp(14px, 2.5vw, 18px);
  margin-bottom: clamp(12px, 2vh, 16px);
  transition: all 0.3s;
}

.review-card:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(59, 130, 246, 0.3);
  transform: translateY(-2px);
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: clamp(10px, 1.5vh, 12px);
  flex-wrap: wrap;
  gap: clamp(8px, 1.2vw, 10px);
}

.review-author {
  display: flex;
  align-items: center;
  gap: clamp(10px, 1.5vw, 12px);
}

.review-avatar {
  width: clamp(32px, 5vw, 40px);
  height: clamp(32px, 5vw, 40px);
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-glow) 0%, var(--secondary-glow) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: clamp(14px, 2vw, 18px);
  color: white;
  flex-shrink: 0;
}

.review-info {
  display: flex;
  flex-direction: column;
  gap: clamp(2px, 0.4vh, 3px);
}

.review-name {
  font-weight: 600;
  font-size: clamp(12px, 1.5vw, 14px);
}

.review-date {
  font-size: clamp(10px, 1.2vw, 12px);
  color: var(--text-muted-2);
}

.review-stars {
  display: flex;
  gap: clamp(2px, 0.4vw, 3px);
}

.review-stars .star {
  font-size: clamp(14px, 2vw, 16px);
}

.review-stars .star.filled {
  color: #fbbf24;
  text-shadow: 0 0 6px rgba(251, 191, 36, 0.4);
}

.review-stars .star.empty {
  color: rgba(255, 255, 255, 0.2);
}

.review-text {
  color: var(--text-muted);
  font-size: clamp(11px, 1.4vw, 13px);
  line-height: 1.6;
  margin: 0;
}

/* Animations */
@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

/* Responsive pour les avis */
@media (max-width: 768px) {
  .reviews-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .review-header {
    flex-direction: column;
    gap: clamp(8px, 1.5vh, 10px);
  }

  .review-stars {
    align-self: flex-start;
  }

  /* Limite supplémentaire des visuels produit en mobile/tablette */
  .product-main-image {
    max-height: clamp(260px, 55vh, 420px);
    aspect-ratio: 3 / 4;
  }
}

@media (max-width: 540px) {
  .star-input {
    font-size: clamp(18px, 4vw, 24px);
  }

  .review-form-container {
    padding: clamp(12px, 2.5vw, 16px);
  }

}

.hidden { display: none; }

@media (max-width: 768px) {
  .product-layout {
    grid-template-columns: 1fr;
  }

  .product-gallery-section { order: 1; }
  .product-purchase-section { order: 2; }
  .product-details-info { order: 3; }

  .add-to-cart-btn-large { width: 100%; }
  .product-actions-large { flex-direction: column; }

  /* Quick picker responsive */
  .quick-picker.open {
    max-height: 120px;
  }

  .variant-pill-card {
    padding: 5px 10px;
    font-size: 10px;
    min-width: 40px;
  }

  .quick-picker-options {
    gap: 5px;
  }
}

/* ===== MENU MOBILE - RESPONSIVE ===== */

/* Bouton hamburger - Caché par défaut, visible sur mobile */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  padding: 8px;
  background: transparent;
  border: 1px solid var(--stroke);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}

.mobile-menu-toggle:hover {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.05);
}

.mobile-menu-toggle[aria-expanded="true"] {
  background: rgba(255, 255, 255, 0.08);
}

/* Icône hamburger - 3 traits horizontaux */
.hamburger-icon {
  display: block;
  position: relative;
  width: 24px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s ease;
}

.hamburger-icon::before,
.hamburger-icon::after {
  content: '';
  position: absolute;
  left: 0;
  width: 24px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s ease;
}

.hamburger-icon::before {
  top: -7px;
}

.hamburger-icon::after {
  top: 7px;
}

/* Animation quand le menu est ouvert */
.mobile-menu-toggle[aria-expanded="true"] .hamburger-icon::before {
  transform: translateY(8px) rotate(45deg);
}

.mobile-menu-toggle[aria-expanded="true"] .hamburger-icon {
  opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] .hamburger-icon::after {
  transform: translateY(-8px) rotate(-45deg);
}

/* Backdrop - Arrière-plan assombri */
.mobile-menu-backdrop {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  z-index: 150;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.mobile-menu-backdrop.active {
  display: block;
  opacity: 1;
}

/* Menu mobile - Drawer latéral */
.mobile-menu {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: var(--header-height, 60px);
  left: -100%;
  width: 100%;
  max-width: 320px;
  height: calc(100vh - var(--header-height, 60px));
  background: var(--bg-secondary);
  border-right: 1px solid var(--stroke);
  z-index: 200;
  overflow-y: auto;
  transition: left 0.3s ease;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.8);
}

.mobile-menu.active {
  left: 0;
}

/* En-tête du menu mobile */
.mobile-menu-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--stroke);
  flex-shrink: 0;
  gap: var(--spacing-md);
}

.mobile-menu-title {
  font-weight: 600;
  font-size: 16px;
}

.mobile-menu-close {
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 28px;
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  border-radius: 8px;
}

.mobile-menu-close:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* Liens du menu mobile */
.mobile-menu-links {
  display: flex;
  flex-direction: column;
  padding: var(--spacing-md);
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.mobile-menu-links a {
  display: block;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--stroke);
  transition: all 0.2s ease;
  font-size: 14px;
  color: var(--text);
  text-align: left;
}

.mobile-menu-links a:hover {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--primary-glow);
  color: var(--primary-glow);
}

/* Sections du menu mobile */
.mobile-menu-section {
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--stroke);
  flex-shrink: 0;
}

.menu-section-label {
  margin: 0 0 var(--spacing-sm) 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Options de langue dans le menu */
.mobile-lang-options {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.mobile-lang-options .lang-option {
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--stroke);
  transition: all 0.2s ease;
  font-size: 14px;
  color: var(--text);
  cursor: pointer;
}

.mobile-lang-options .lang-option:hover {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--primary-glow);
  color: var(--primary-glow);
}

/* Actions du menu mobile (boutons bas du menu) */
.mobile-menu-actions {
  display: flex;
  flex-direction: column;
  padding: var(--spacing-lg);
  gap: var(--spacing-sm);
  margin-top: auto;
  flex-shrink: 0;
}

.mobile-menu-actions .wa-btn,
.mobile-menu-actions .cart-btn {
  width: 100%;
  justify-content: center;
}

/* ===== ACCORDÉONS MENU MOBILE ===== */

.menu-accordion-toggle {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: var(--spacing-md) 0;
  background: transparent;
  border: none;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 14px;
  font-weight: 500;
}

.menu-accordion-toggle:hover {
  color: var(--primary-glow);
}

.accordion-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: transform 0.3s ease;
  font-weight: 300;
}

.menu-accordion-toggle[aria-expanded="true"] .accordion-chevron {
  transform: rotate(90deg);
}

/* Contenu caché par défaut */
#lang-accordion,
#social-accordion {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.3s ease;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

/* Contenu visible quand ouvert */
#lang-accordion[aria-expanded="true"],
#social-accordion[aria-expanded="true"] {
  max-height: 500px;
  opacity: 1;
  visibility: visible;
  padding: var(--spacing-sm) 0 var(--spacing-md) 0;
}

#lang-accordion[aria-expanded="true"],
#social-accordion[aria-expanded="true"] {
  border-top: 1px solid var(--stroke);
  padding-top: var(--spacing-md);
}

/* ===== BREAKPOINTS RESPONSIFS - AFFICHAGE/MASQUAGE DU MENU ===== */

/* Par défaut : afficher la navigation standard, masquer le menu mobile */
@media (min-width: 769px) {
  .mobile-menu-toggle {
    display: none !important;
  }
  
  .mobile-menu-backdrop,
  .mobile-menu {
    display: none !important;
  }
  
  .nav {
    display: flex !important;
  }
}

/* Tablettes (768px et moins) */
@media (max-width: 768px) {
  /* Afficher le bouton hamburger */
  .mobile-menu-toggle {
    display: flex;
  }
  
  /* Masquer la navigation standard */
  .nav {
    display: none;
  }
  
  /* Ajuster le header pour le mobile */
  .header-inner {
    padding: clamp(6px, 1.2vh, 10px) 0;
    gap: clamp(4px, 0.8vw, 6px);
  }
  
  .brand {
    order: 1;
    margin-left: 0;
  }
  
  .header-actions {
    order: 2;
    margin-left: auto;
  }
  
  .mobile-menu-toggle {
    order: 3;
    margin-left: var(--spacing-sm);
  }
  
  /* Dimensionner le menu mobile pour petits écrans */
  .mobile-menu {
    max-width: 85vw;
    width: 85vw;
  }
}

/* Petits mobiles (540px et moins) */
@media (max-width: 540px) {
  .mobile-menu {
    max-width: 100%;
    width: 100%;
    border-radius: 0;
  }
  
  .mobile-menu-header {
    padding: var(--spacing-md);
  }
  
  .mobile-menu-section,
  .mobile-menu-links {
    padding: var(--spacing-md);
  }
  
  .mobile-menu-close {
    width: 28px;
    height: 28px;
    font-size: 24px;
  }
}

/* Très petits mobiles (400px et moins) */
@media (max-width: 400px) {
  .mobile-menu-header {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .mobile-menu-section,
  .mobile-menu-links {
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  .mobile-menu-actions {
    padding: var(--spacing-md);
  }
  
  .hamburger-icon::before,
  .hamburger-icon::after {
    width: 18px;
  }
  
  .hamburger-icon {
    width: 18px;
  }
}