/* ============================================================
   AVIX_3D — Design System
   Police: Rajdhani (display) + DM Sans (corps)
   Palette: #0a0a0a / #e62429 / #f4f4f4 / #1c1c1c
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap');

/* ─── Variables ─── */
:root {
  --red:        #e62429;
  --red-light:  #ff3137;
  --bg:         #0a0a0a;
  --surface:    #141414;
  --surface2:   #1c1c1c;
  --border:     #2a2a2a;
  --text:       #f0f0f0;
  --muted:      #888;
  --ease:       cubic-bezier(.4,0,.2,1);
  --radius:     10px;
  --shadow:     0 8px 32px rgba(0,0,0,.6);
}

/* ─── Reset ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior:smooth; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
}

.container { max-width:1240px; margin:0 auto; padding:0 24px; }

/* ─── Bandeau défilant ─── */
.announcement-banner {
  background: linear-gradient(90deg, #b01c20, var(--red), #b01c20);
  color:#fff;
  overflow:hidden;
  padding:9px 0;
  position:relative;
  z-index:1000;
}
.announcement-content {
  display:flex;
  animation:marquee 35s linear infinite;
  width:fit-content;
}
.announcement-item {
  padding:0 40px;
  white-space:nowrap;
  font-family:'Rajdhani',sans-serif;
  font-size:.92rem;
  font-weight:600;
  letter-spacing:.05em;
}
@keyframes marquee {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ─── HEADER ─── */
.main-header {
  position:sticky;
  top:0;
  z-index:900;
  background: rgba(10,10,10,.95);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--border);
}
.header-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:68px;
  gap:30px;
}

/* Logo */
.logo {
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--text);
  font-family:'Rajdhani',sans-serif;
  font-size:1.6rem;
  font-weight:700;
  letter-spacing:.04em;
  flex-shrink:0;
}
.logo img {
  width:38px;
  height:38px;
  border-radius:7px;
}
.logo span { color:var(--red); }

/* Nav principal */
.main-nav { display:flex; align-items:center; gap:4px; }

/* Lien simple */
.nav-link {
  display:flex;
  align-items:center;
  gap:5px;
  padding:8px 14px;
  color:var(--muted);
  text-decoration:none;
  font-size:.88rem;
  font-weight:500;
  border-radius:7px;
  transition:color .2s, background .2s;
  white-space:nowrap;
  cursor:pointer;
  background:transparent;
  border:none;
  font-family:'DM Sans',sans-serif;
}
.nav-link:hover, .nav-link.active { color:var(--text); background:var(--surface2); }
.nav-link svg { flex-shrink:0; transition:transform .25s var(--ease); }

/* ─── DROPDOWN ─── */
.dropdown { position:relative; }

.dropdown:hover .nav-link svg,
.dropdown.open .nav-link svg { transform:rotate(180deg); }

.dropdown-panel {
  position:absolute;
  top:calc(100% + 0px);
  left:50%;
  transform:translateX(-50%) translateY(-6px);
  min-width:220px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  padding:8px;
  padding-top:16px;
  margin-top:8px;
  box-shadow:var(--shadow);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s var(--ease), transform .2s var(--ease);
  z-index:9999;
}
.dropdown-panel::before {
  content:'';
  position:absolute;
  top:-16px;
  left:0;
  right:0;
  height:16px;
  background:transparent;
}
.dropdown:hover .dropdown-panel,
.dropdown.open .dropdown-panel {
  opacity:1;
  pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

.dropdown-item {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:8px;
  text-decoration:none;
  color:var(--muted);
  font-size:.86rem;
  font-weight:500;
  transition:all .15s;
  border:none;
  background:transparent;
  width:100%;
  cursor:pointer;
  text-align:left;
  font-family:'DM Sans',sans-serif;
}
.dropdown-item:hover { background:var(--surface2); color:var(--text); }
.dropdown-item .item-icon {
  width:30px;
  height:30px;
  border-radius:6px;
  background:var(--surface2);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.9rem;
  flex-shrink:0;
}
.dropdown-item:hover .item-icon { background:rgba(230,36,41,.15); }
.dropdown-separator {
  height:1px;
  background:var(--border);
  margin:6px 0;
}

/* Icône panier */
.nav-right { display:flex; align-items:center; gap:12px; }

.social-links { display:flex; gap:8px; }
.social-links a {
  width:34px; height:34px;
  border-radius:7px;
  background:var(--surface2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  transition:all .2s;
}
.social-links a:hover { background:var(--red); color:#fff; }

.cart-btn {
  position:relative;
  width:38px; height:38px;
  border-radius:9px;
  background:var(--surface2);
  border:none;
  cursor:pointer;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
}
.cart-btn:hover { background:var(--red); }
.cart-btn #cart-count {
  position:absolute;
  top:-5px; right:-5px;
  background:var(--red);
  color:#fff;
  font-size:.65rem;
  font-weight:700;
  min-width:17px;
  height:17px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 4px;
  border:2px solid var(--bg);
}

/* ─── HERO ─── */
.hero {
  min-height:72vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  position:relative;
  overflow:hidden;
  background:radial-gradient(ellipse at 60% 50%, rgba(230,36,41,.12) 0%, transparent 65%),
             linear-gradient(180deg,#0a0a0a 0%,#111 100%);
}
.hero::before {
  content:'';
  position:absolute;
  inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.015'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-content { position:relative; z-index:1; padding:40px 20px; max-width:860px; }
.hero-eyebrow {
  display:inline-block;
  background:rgba(230,36,41,.15);
  border:1px solid rgba(230,36,41,.3);
  color:var(--red);
  padding:5px 16px;
  border-radius:20px;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:22px;
  font-family:'Rajdhani',sans-serif;
}
.hero h1 {
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(2.6rem, 6vw, 5rem);
  font-weight:700;
  line-height:1.1;
  margin-bottom:22px;
  letter-spacing:-.01em;
}
.hero h1 em { color:var(--red); font-style:normal; }
.hero p {
  font-size:1.05rem;
  color:var(--muted);
  max-width:540px;
  margin:0 auto 36px;
}
.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ─── BOUTONS ─── */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 26px;
  border-radius:9px;
  font-size:.92rem;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  border:none;
  transition:all .2s var(--ease);
  font-family:'DM Sans',sans-serif;
}
.btn-primary { background:var(--red); color:#fff; }
.btn-primary:hover { background:var(--red-light); transform:translateY(-1px); box-shadow:0 6px 20px rgba(230,36,41,.4); }
.btn-outline { background:transparent; color:var(--text); border:1.5px solid var(--border); }
.btn-outline:hover { border-color:var(--muted); background:var(--surface2); transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--muted); border:1px solid var(--border); }
.btn-ghost:hover { color:var(--text); border-color:var(--border); background:var(--surface2); }
.btn-full { width:100%; justify-content:center; }
.btn-sm { padding:9px 18px; font-size:.83rem; }
.btn-lg { padding:15px 32px; font-size:1rem; }

/* ─── SECTION TITLES ─── */
.section-title {
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:700;
  letter-spacing:.02em;
  margin-bottom:8px;
}
.section-subtitle { color:var(--muted); font-size:.95rem; margin-bottom:40px; }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:32px; gap:20px; }

/* ─── CATÉGORIE HEADER ─── */
.cat-header {
  display:flex;
  align-items:center;
  gap:14px;
  margin:60px 0 28px;
}
.cat-header-line {
  flex:1;
  height:1px;
  background:var(--border);
}
.cat-header-label {
  display:flex;
  align-items:center;
  gap:8px;
  padding:7px 18px;
  border:1px solid var(--border);
  border-radius:20px;
  font-family:'Rajdhani',sans-serif;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  white-space:nowrap;
}
.cat-header-label span { font-size:1rem; }

/* ─── GRILLE PRODUITS ─── */
.product-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(290px,1fr));
  gap:22px;
}

/* ─── CARTE PRODUIT ─── */
.product-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;
  display:flex;
  flex-direction:column;
}
.product-card:hover {
  transform:translateY(-6px);
  border-color:rgba(230,36,41,.4);
  box-shadow:0 16px 40px rgba(0,0,0,.4);
}

.card-image {
  position:relative;
  width:100%;
  padding-bottom:100%;
  background:#111;
  overflow:hidden;
}
.card-image img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:transform .4s var(--ease);
}
.product-card:hover .card-image img { transform:scale(1.04); }
.card-badge {
  position:absolute;
  top:12px;
  left:12px;
  z-index:2;
  background:var(--red);
  color:#fff;
  padding:3px 10px;
  border-radius:5px;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.card-body {
  padding:20px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:8px;
}
.card-name {
  font-family:'Rajdhani',sans-serif;
  font-size:1.1rem;
  font-weight:700;
  line-height:1.2;
  color:var(--text);
}
.card-desc { font-size:.84rem; color:var(--muted); line-height:1.5; flex:1; }
.card-price {
  font-family:'Rajdhani',sans-serif;
  font-size:1.5rem;
  font-weight:700;
  color:var(--red);
}
.card-price small { font-size:.8rem; color:var(--muted); font-family:'DM Sans',sans-serif; font-weight:400; }
.card-actions { display:flex; gap:8px; margin-top:4px; }

/* ─── PANIER LATÉRAL ─── */
#overlay {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
  z-index:800;
  transition:opacity .3s;
}
#overlay.hidden { opacity:0; pointer-events:none; display:block !important; }

.cart-panel {
  position:fixed;
  right:0; top:0;
  width:380px;
  max-width:100vw;
  height:100vh;
  background:var(--surface);
  border-left:1px solid var(--border);
  z-index:1000;
  display:flex;
  flex-direction:column;
  transition:transform .35s var(--ease);
  box-shadow:-12px 0 40px rgba(0,0,0,.5);
}
.cart-panel.hidden { transform:translateX(100%); }

.cart-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 22px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.cart-header h3 {
  font-family:'Rajdhani',sans-serif;
  font-size:1.2rem;
  font-weight:700;
  letter-spacing:.04em;
}
.cart-header button {
  width:32px; height:32px;
  border-radius:7px;
  background:var(--surface2);
  border:none;
  color:var(--text);
  cursor:pointer;
  font-size:1.1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
}
.cart-header button:hover { background:var(--red); }

#liste-panier {
  flex:1;
  overflow-y:auto;
  padding:12px 22px;
  list-style:none;
}

.panier-item {
  display:grid;
  grid-template-columns:1fr auto auto auto;
  align-items:center;
  gap:10px;
  padding:12px 0;
  border-bottom:1px solid var(--border);
  font-size:.85rem;
}
.panier-item button {
  background:var(--surface2);
  color:var(--text);
  border:none;
  width:24px; height:24px;
  border-radius:5px;
  cursor:pointer;
  font-size:.85rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
}
.panier-item button:hover { background:var(--red); }

.cart-footer {
  padding:16px 22px;
  border-top:1px solid var(--border);
  flex-shrink:0;
}

/* code promo */
.promo-block {
  margin-bottom:14px;
}
.promo-block label {
  display:block;
  font-size:.78rem;
  font-weight:600;
  color:var(--muted);
  margin-bottom:6px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.promo-row { display:flex; gap:8px; }
.promo-row input {
  flex:1;
  padding:9px 12px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--text);
  font-size:.85rem;
  font-family:'DM Sans',sans-serif;
  outline:none;
  transition:border-color .2s;
}
.promo-row input:focus { border-color:var(--red); }
.promo-row button {
  padding:9px 14px;
  background:var(--red);
  color:#fff;
  border:none;
  border-radius:8px;
  cursor:pointer;
  font-size:.83rem;
  font-weight:600;
  transition:background .2s;
  font-family:'DM Sans',sans-serif;
}
.promo-row button:hover { background:var(--red-light); }
#status-promo { font-size:.78rem; margin-top:6px; }

#total-panier { font-size:.88rem; color:var(--muted); margin-bottom:10px; }
#paypal-button-container { margin-top:8px; }

/* ─── HAMBURGER MENU ─── */
.hamburger-btn {
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:38px; height:38px;
  background:var(--surface2);
  border:none;
  border-radius:9px;
  cursor:pointer;
  padding:9px;
  transition:background .2s;
  flex-shrink:0;
}
.hamburger-btn:hover { background:var(--red); }
.hamburger-btn span {
  display:block;
  height:2px;
  background:var(--text);
  border-radius:2px;
  transition:transform .3s var(--ease), opacity .3s;
}
.hamburger-btn.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger-btn.open span:nth-child(2) { opacity:0; }
.hamburger-btn.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Menu mobile déroulant */
.mobile-nav {
  display:none;
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
  z-index:890;
}
.mobile-nav.open { display:block; }
.mobile-nav-panel {
  position:absolute;
  top:0; left:0;
  width:300px;
  height:100%;
  background:var(--surface);
  border-right:1px solid var(--border);
  overflow-y:auto;
  box-shadow:12px 0 40px rgba(0,0,0,.5);
  transform:translateX(-100%);
  transition:transform .32s var(--ease);
}
.mobile-nav.open .mobile-nav-panel { transform:translateX(0); }
.mobile-nav-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 20px;
  border-bottom:1px solid var(--border);
}
.mobile-nav-header .logo { font-size:1.3rem; }
.mobile-nav-close {
  width:32px; height:32px;
  border-radius:7px;
  background:var(--surface2);
  border:none;
  color:var(--text);
  cursor:pointer;
  font-size:1.1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
}
.mobile-nav-close:hover { background:var(--red); }

.mobile-nav-section {
  padding:8px 12px;
}
.mobile-nav-category {
  font-family:'Rajdhani',sans-serif;
  font-size:.72rem;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:16px 8px 8px;
}
.mobile-nav-link {
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 10px;
  color:var(--muted);
  text-decoration:none;
  font-size:.88rem;
  font-weight:500;
  border-radius:8px;
  transition:all .15s;
}
.mobile-nav-link:hover { background:var(--surface2); color:var(--text); }
.mobile-nav-link .item-icon {
  width:30px; height:30px;
  border-radius:6px;
  background:var(--surface2);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.mobile-nav-link:hover .item-icon { background:rgba(230,36,41,.15); }
.mobile-nav-divider {
  height:1px;
  background:var(--border);
  margin:8px 0;
}
.mobile-nav-socials {
  display:flex;
  gap:10px;
  padding:16px 10px;
}
.mobile-nav-coming {
  opacity:.5;
  pointer-events:none;
}

/* ─── POPUP CONFIGURATION ─── */
.popup {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.8);
  backdrop-filter:blur(6px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2000;
  padding:20px;
}
.popup.hidden { display:none; }

.popup-content {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:28px;
  width:100%;
  max-width:480px;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:var(--shadow);
}
.popup-content h3 {
  font-family:'Rajdhani',sans-serif;
  font-size:1.4rem;
  font-weight:700;
  margin-bottom:22px;
  color:var(--red);
  letter-spacing:.03em;
}
.option-block { margin-bottom:20px; }
.option-block > p,
.option-block > label {
  font-size:.78rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
  display:block;
}
.options { display:flex; gap:8px; flex-wrap:wrap; }

.color-btn {
  width:38px; height:38px;
  border:3px solid transparent;
  border-radius:50%;
  cursor:pointer;
  transition:all .2s;
}
.color-btn:hover { transform:scale(1.1); }
.color-btn.active { box-shadow:0 0 0 3px var(--bg), 0 0 0 5px var(--red); }

.cable-btn {
  padding:9px 14px;
  background:var(--surface2);
  border:1.5px solid var(--border);
  color:var(--text);
  border-radius:8px;
  cursor:pointer;
  font-size:.82rem;
  font-weight:500;
  transition:all .2s;
  font-family:'DM Sans',sans-serif;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.cable-btn:hover { border-color:var(--red); }
.cable-btn.active { background:var(--red); border-color:var(--red); color:#fff; }

.popup-actions {
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:24px;
}
.popup-actions .prix-popup {
  text-align:center;
  font-family:'Rajdhani',sans-serif;
  font-size:1.8rem;
  font-weight:700;
  color:var(--red);
  margin-bottom:4px;
}
.popup-actions-row { display:flex; gap:10px; }
.popup-actions-row button { flex:1; }

.pack-btn {
  background:var(--surface2);
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:16px;
  cursor:pointer;
  transition:all .2s;
  position:relative;
  text-align:center;
  font-family:'DM Sans',sans-serif;
  color:var(--text);
  width:100%;
}
.pack-btn:hover { border-color:var(--red); }
.pack-btn.active { border-color:var(--red); background:rgba(230,36,41,.08); }
.pack-btn.featured { border-color:rgba(230,36,41,.4); }
.pack-choices { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.pack-badge {
  position:absolute; top:-9px; left:50%; transform:translateX(-50%);
  background:var(--red); color:#fff;
  padding:2px 10px; border-radius:10px;
  font-size:.65rem; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; white-space:nowrap;
}
.pack-name { font-weight:700; font-size:.95rem; margin-bottom:4px; }
.pack-price { font-family:'Rajdhani',sans-serif; font-size:1.4rem; font-weight:700; color:var(--red); }
.pack-desc { font-size:.75rem; color:var(--muted); margin-top:3px; }
.pack-save { font-size:.72rem; color:#4caf50; font-weight:600; margin-top:2px; }

/* Info box dans popup */
.info-box {
  background:rgba(230,36,41,.07);
  border-left:3px solid var(--red);
  padding:12px 14px;
  border-radius:8px;
  margin:14px 0;
  font-size:.82rem;
  color:var(--muted);
  line-height:1.5;
}
.info-box strong { color:var(--red); }

/* Champ texte dans popup */
.popup-input {
  width:100%;
  padding:10px 12px;
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:8px;
  color:var(--text);
  font-size:.9rem;
  outline:none;
  font-family:'DM Sans',sans-serif;
  transition:border-color .2s;
  margin-top:6px;
}
.popup-input:focus { border-color:var(--red); }

/* ─── AVIS ─── */
.avis-section { padding:60px 0; }
.avis-wrapper {
  position:relative;
  padding:0 50px;
  max-width:1100px;
  margin:0 auto;
}
.avis-cards-wrapper {
  display:grid;
  grid-template-columns:1fr 1.4fr 1fr;
  gap:20px;
  align-items:center;
}
.avis-card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:14px;
  padding:24px;
  min-height:160px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
  transition:all .4s var(--ease);
}
.avis-card.avis-side { opacity:.6; transform:scale(.92); }
.avis-card.avis-center { border-color:var(--red); box-shadow:0 8px 24px rgba(230,36,41,.2); opacity:1; }
.avis-nav {
  position:absolute;
  top:50%; transform:translateY(-50%);
  background:var(--red); color:#fff;
  border:none; width:38px; height:38px;
  border-radius:50%;
  cursor:pointer;
  font-size:1.3rem;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s;
}
.avis-nav:hover { background:var(--red-light); }
#avis-prev { left:0; }
#avis-next { right:0; }
#moyenne { text-align:center; margin-bottom:24px; color:var(--muted); font-size:.9rem; }

/* ─── CONTACT ─── */
.contact-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:36px;
  max-width:680px;
  margin:0 auto 60px;
}
.contact-card h3 {
  font-family:'Rajdhani',sans-serif;
  font-size:1.5rem;
  font-weight:700;
  margin-bottom:20px;
  color:var(--text);
}
.form-field { margin-bottom:14px; }
.form-field label {
  display:block;
  font-size:.78rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:6px;
}
.form-field input,
.form-field textarea {
  width:100%;
  padding:11px 14px;
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:8px;
  color:var(--text);
  font-size:.9rem;
  font-family:'DM Sans',sans-serif;
  outline:none;
  transition:border-color .2s;
}
.form-field input:focus,
.form-field textarea:focus { border-color:var(--red); }
.form-field textarea { min-height:120px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
#form-status { margin-top:10px; font-size:.85rem; }

/* ─── PAGES PRODUIT DÉTAIL ─── */
.product-detail { padding:50px 0 80px; }
.detail-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:start;
}
.detail-photos { position:sticky; top:90px; }

.main-photo {
  width:100%;
  padding-bottom:90%;
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  margin-bottom:14px;
}
.main-photo img {
  position:absolute;
  inset:0; width:100%; height:100%;
  object-fit:contain;
  transition:transform .4s var(--ease);
}
.thumbnail-row {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(72px,1fr));
  gap:10px;
}
.thumb {
  padding-bottom:100%;
  position:relative;
  border-radius:9px;
  border:2px solid transparent;
  background:var(--surface);
  overflow:hidden;
  cursor:pointer;
  transition:border-color .2s;
}
.thumb img {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;
}
.thumb.active, .thumb:hover { border-color:var(--red); }
.carousel-arrows { position:absolute; inset:0; display:flex; align-items:center; justify-content:space-between; padding:12px; pointer-events:none; }
.carousel-arrows button {
  pointer-events:all;
  width:36px; height:36px;
  border-radius:8px;
  background:rgba(10,10,10,.75);
  border:1px solid var(--border);
  color:var(--text);
  cursor:pointer;
  font-size:1rem;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s;
}
.carousel-arrows button:hover { background:var(--red); border-color:var(--red); }

.detail-info { display:flex; flex-direction:column; gap:20px; }
.detail-info h1 {
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:700;
  line-height:1.15;
}
.detail-price {
  font-family:'Rajdhani',sans-serif;
  font-size:2rem;
  font-weight:700;
  color:var(--red);
}
.detail-price small { font-size:.9rem; color:var(--muted); font-family:'DM Sans',sans-serif; font-weight:400; }
.detail-desc { color:var(--muted); line-height:1.7; font-size:.93rem; }

/* Option blocks sur page détail */
.opt-label {
  font-size:.75rem;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.09em;
  margin-bottom:8px;
  display:block;
}
.opt-group { margin-bottom:18px; }

/* Feature blocks */
.feature-blocks { margin-top:60px; display:flex; flex-direction:column; gap:16px; }
.feature-block {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:28px 30px;
}
.feature-block h3 {
  font-family:'Rajdhani',sans-serif;
  font-size:1.3rem;
  font-weight:700;
  color:var(--red);
  margin-bottom:10px;
}
.feature-block p { color:var(--muted); line-height:1.7; font-size:.9rem; }
.feature-images {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px,1fr));
  gap:12px;
  margin-top:16px;
}
.feature-images img {
  width:100%;
  aspect-ratio:1;
  object-fit:contain;
  background:#000;
  border-radius:9px;
  border:1px solid var(--border);
}

/* ─── COMPATIBILITÉ TAGS ─── */
.compat-tags { display:flex; flex-wrap:wrap; gap:7px; margin-top:8px; }
.compat-tag {
  background:rgba(230,36,41,.1);
  border:1px solid rgba(230,36,41,.25);
  color:var(--red);
  padding:3px 11px;
  border-radius:15px;
  font-size:.75rem;
  font-weight:600;
}

/* ─── FOOTER ─── */
footer {
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:28px 0;
  text-align:center;
  color:var(--muted);
  font-size:.82rem;
}
footer a { color:var(--red); text-decoration:none; }
footer a:hover { text-decoration:underline; }
footer .footer-inner { display:flex; flex-direction:column; gap:8px; align-items:center; }

/* ─── UTILITAIRES ─── */
.hidden { display:none !important; }
.text-red { color:var(--red); }
.mt-60 { margin-top:60px; }
.mb-60 { margin-bottom:60px; }

/* "Coming soon" badge */
.badge-coming {
  background:rgba(255,165,0,.12);
  border:1px solid rgba(255,165,0,.3);
  color:#ffaa00;
  padding:3px 10px;
  border-radius:5px;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px) {
  .detail-grid { grid-template-columns:1fr; gap:36px; }
  .detail-photos { position:static; }
}
@media(max-width:768px) {
  .header-inner { height:60px; }
  .main-nav { display:none; }
  .hamburger-btn { display:flex; }
  .cart-panel { width:100%; }
  .product-grid { grid-template-columns:repeat(auto-fill, minmax(250px,1fr)); }
  .avis-cards-wrapper { grid-template-columns:1fr; }
  .avis-card.avis-side { display:none; }
  .form-row { grid-template-columns:1fr; }
  .hero h1 { font-size:2rem; }
}
@media(max-width:480px) {
  .contact-card { padding:22px; }
  .popup-content { padding:20px; }
}