/* ===================================================================
   SPICEX — Responsive partagé (chargé après les <style> inline)
   =================================================================== */

/* ---------- Hamburger (injecté par responsive-nav.js) ---------- */
.nav-burger {
  display: none;
  position: absolute;
  left: 16px;
  top: 9px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 60;
  padding: 6px;
}
.nav-burger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--navy, #2C1A0E);
  margin: 5px 0;
  border-radius: 2px;
  transition: transform 0.25s, opacity 0.25s;
}
body.nav-open .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-burger span:nth-child(2) { opacity: 0; }
body.nav-open .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ====================== TABLETTE (≤ 1024px) ====================== */
@media (max-width: 1024px) {
  .products-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 18px !important; }
  .cat-layout { grid-template-columns: 200px 1fr !important; gap: 24px !important; }
  .cat-hero { height: 380px !important; }
  .cat-hero-content h1 { font-size: 52px !important; }
}

/* ====================== MOBILE (≤ 768px) ====================== */
@media (max-width: 768px) {

  /* --- Topbar --- */
  .topbar-inner { flex-direction: column; gap: 4px; text-align: center; font-size: 10px; }
  .topbar-left a, .topbar-right a { margin-right: 10px; }

  /* --- Header haut : logo centré, recherche cachée, actions compactes --- */
  .header-top-row {
    grid-template-columns: 1fr auto 1fr !important;
    gap: 8px !important;
    padding: 0 12px !important;
    min-height: 64px !important;
  }
  .search-box { display: none !important; }
  .header-logo-cell { width: auto !important; justify-self: center; }
  .header-logo {
    width: 84px !important; height: 84px !important;
    top: -6px !important; border-width: 3px !important;
  }
  .header-actions { gap: 2px !important; }
  .btn-icon { font-size: 0 !important; padding: 4px !important; }
  .btn-icon svg { width: 20px !important; height: 20px !important; }
  .btn-icon span:not(.cart-bubble span) { display: none; }
  .cart-bubble span { font-size: 9px !important; }
  .lang-switcher { display: flex; }
  .lang-btn { font-size: 10px !important; padding: 2px 5px !important; }

  /* --- Barre de nav : devient menu déroulant via hamburger --- */
  .header-nav-row { padding-top: 0 !important; position: relative; min-height: 44px; }
  .nav-burger { display: block; }
  .main-nav-lpv {
    flex-direction: column !important;
    align-items: stretch !important;
    height: auto !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    padding: 0 !important;
  }
  body.nav-open .main-nav-lpv { max-height: 90vh; overflow-y: auto; padding: 44px 0 16px !important; }
  .nav-left, .nav-right { flex-direction: column !important; align-items: stretch !important; width: 100%; gap: 0 !important; }
  .logo-spacer { display: none !important; }
  .main-nav-lpv a {
    font-size: 18px !important;
    padding: 12px 20px !important;
    border-bottom: 1px solid #e8e4dc;
    text-align: left;
  }
  /* Mega-menus désactivés en mobile (trop larges) */
  .mega-menu { display: none !important; }

  /* --- Hero --- */
  .cat-hero { height: 260px !important; }
  .cat-hero-bg img { height: 260px !important; width: auto !important; max-width: none !important; }
  .cat-hero-content { padding: 0 20px !important; }
  .cat-hero-content h1 { font-size: 38px !important; }
  .cat-hero-tag { font-size: 10px !important; }
  .cat-hero-content p { font-size: 12px !important; }

  /* --- Bandeau intro : colonne --- */
  .cat-intro-inner { flex-direction: column !important; gap: 18px !important; }
  .cat-intro-badges { justify-content: center; gap: 12px !important; }
  .badge { font-size: 11px !important; }
  .cat-intro-text { text-align: center; font-size: 12px !important; }

  /* --- Layout catégorie : sidebar repliée en haut --- */
  .cat-layout {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    padding: 24px 14px !important;
  }
  .sidebar { position: static !important; top: auto !important; }

  /* --- Grille produits : 2 colonnes compactes --- */
  .products-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .product-name { font-size: 14px !important; }
  .product-desc { font-size: 11px !important; }
  .product-price { font-size: 16px !important; }
  .btn-add { font-size: 11px !important; padding: 6px 10px !important; }

  /* --- Pin-up bannières décoratives : masquées (débordent) --- */
  .cat-banner-pinup { display: none !important; }

  /* --- Footer --- */
  .footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; text-align: center; }
}

/* ====================== PETIT MOBILE (≤ 480px) ====================== */
@media (max-width: 480px) {
  .products-grid { grid-template-columns: 1fr !important; }
  .cat-hero-content h1 { font-size: 32px !important; }
  .cat-intro-badges { grid-template-columns: repeat(2, 1fr); display: grid; }
}
