/* ============================================================
   CAMISA PREMIUM — site-fixes.css
   Loaded LAST to resolve CSS Module class-name conflicts that
   arise from loading React .module.css files as global CSS.
   In React, classes are scoped. In PHP they are global, causing
   Header.module.css .container to pollute all page containers.
   ============================================================ */

/* ── 1. RESET: strip header styles from ALL page containers ── */
.pageWrapper .container,
.trustStrip .container,
.section .container,
.promoBanner .container,
.aboutSection .container,
.socialProofSection .container,
.heroWrapper .container {
  display: block !important;
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  border-bottom: none !important;
  color: inherit !important;
  padding: 0 24px !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* ── 2. RESTORE: header-specific container flex layout ────── */
.containerPc > .container {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: rgba(6, 9, 26, 0.92) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
  padding: 14px 40px !important;
  border-bottom: 1px solid var(--border-subtle) !important;
  color: var(--text-primary) !important;
  max-width: 100% !important;
  margin: 0 !important;
  width: 100% !important;
}

/* ── 3. Footer container also needs page-style reset ─────── */
.footerContainer .footerContent,
.footerContainer .trustBanner,
.footerContainer .footerBottom {
  box-sizing: border-box;
}

/* ── 4. Trust strip — force flex row on trust items ─────── */
.trustStrip .trustItems {
  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}

/* ── 5. Products grid — prevent overflow on mobile ───────── */
.productsGrid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

@media (min-width: 640px) {
  .productsGrid { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }
}

@media (min-width: 900px) {
  .productsGrid { grid-template-columns: repeat(3, 1fr) !important; gap: 24px !important; }
}

@media (min-width: 1200px) {
  .productsGrid { grid-template-columns: repeat(4, 1fr) !important; gap: 24px !important; }
}

/* ── 6. Product cards – full width within grid cell ─────── */
.productsGrid > a {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;  /* prevent grid blowout */
  text-decoration: none !important;
}

.product {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* ── 7. Section header — fix flex wrap on mobile ─────────── */
.sectionHeader {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 40px !important;
  flex-wrap: wrap !important;
}

.sectionHeader h2 {
  font-family: 'Outfit', sans-serif !important;
  font-size: clamp(1.4rem, 3vw, 2.2rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  margin: 0 0 4px !important;
  line-height: 1.1 !important;
}

.sectionHeader h2 span {
  color: var(--accent-cyan) !important;
}

/* ── 8. Hero wrapper — ensure background image covers full ── */
.heroWrapper {
  width: 100% !important;
  overflow: hidden !important;
}

/* ── 9. Footer grid — force proper layout ───────────────── */
.footerContent {
  display: grid !important;
  grid-template-columns: 2fr 1fr 1fr 1.5fr !important;
  gap: 32px !important;
  padding: 48px 32px !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}

.trustBanner {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 24px !important;
  padding: 0 32px 48px !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}

.trustBanner .trustItem {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  flex: 1 !important;
  min-width: 220px !important;
}

/* ── 10. Global overflow guard ───────────────────────────── */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

.pageWrapper {
  overflow-x: hidden !important;
  width: 100% !important;
}

/* ── 11. Mobile responsive ───────────────────────────────── */
@media (max-width: 768px) {
  .containerPc > .container {
    padding: 12px 16px !important;
  }

  .pageWrapper .container,
  .trustStrip .container,
  .section .container,
  .promoBanner .container {
    padding: 0 16px !important;
  }

  .footerContent {
    grid-template-columns: 1fr 1fr !important;
    padding: 32px 16px !important;
    gap: 24px !important;
  }

  .trustBanner {
    padding: 0 16px 32px !important;
  }
}

@media (max-width: 480px) {
  .productsGrid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  .footerContent {
    grid-template-columns: 1fr !important;
  }

  .trustBanner .trustItem {
    min-width: 100% !important;
  }

  .sectionHeader {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
}
/* ── 12. Desktop Search Bar Centering ───────────────────── */
@media (min-width: 901px) {
  .containerPc .container {
    position: relative !important;
  }
  .containerPc .filter {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 40% !important;
    max-width: 500px !important;
    margin: 0 !important;
    z-index: 10 !important;
  }
}
