/* =============================================
   RV SPORT STORE — PREMIUM CSS v2
   Melhorias: cards, header, footer, tipografia,
   filtros, badges, mobile, trust signals.
   ============================================= */

:root {
  --black:    #07090C;
  --dark:     #0E1118;
  --card:     #141922;
  --card2:    #1A2030;
  --border:   rgba(255,255,255,0.07);
  --border2:  rgba(255,255,255,0.13);
  --accent:   #E4FF00;
  --accent2:  #FF3E3E;
  --accent3:  #00D9F0;
  --green:    #00E676;
  --white:    #F0F2F8;
  --muted:    #7A8499;
  --muted2:   #4A5568;
  --radius:   14px;
  --radius-sm:9px;
  --radius-xs:6px;
  --shadow:   0 8px 32px rgba(0,0,0,.55);
  --shadow-lg:0 20px 60px rgba(0,0,0,.75);
  --shadow-card: 0 2px 16px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.04);
  --shadow-hover: 0 20px 56px rgba(0,0,0,.65), 0 0 0 1px rgba(228,255,0,.12);
  --tr:       .22s cubic-bezier(.4,0,.2,1);
  --max:      1400px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 15px; -webkit-font-smoothing: antialiased; }
body {
  background: var(--black);
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  line-height: 1.65;
  overflow-x: hidden;
}
/* === PERFORMANCE: BASE IMG RULES === */
img {
  display: block;
  max-width: 100%;
  height: auto;           /* evita CLS quando width/height estão definidos */
  color: transparent;     /* esconde alt text durante carregamento */
}

/* Placeholder de carregamento para todas as imagens lazy */
img[loading="lazy"] {
  background: linear-gradient(135deg, #1a1f2e 0%, #0d1018 100%);
}

/* Imagens que carregam com eager não precisam do placeholder */
img[loading="eager"] {
  background: transparent;
}

/* Garante que imagens de produto não causem layout shift */
.prod-img-front,
.prod-img-back {
  width: 100%;
  height: 100%;
}

/* Otimização de renderização para carrosséis */
.prod-carousel,
.team-badges-carousel {
  contain: layout style;                /* isola layout do resto da página */
  will-change: scroll-position;
}

/* content-visibility para seções abaixo da dobra (GPU offload) */
.section:not(:first-child),
.cat-grid,
.craques-mini-grid,
.testimonials-grid {
  content-visibility: auto;
  contain-intrinsic-size: 0 400px;     /* estimativa de altura para evitar re-layout */
}

/* Força aceleração de GPU apenas onde há animação real */
.prod-img-front,
.prod-img-back,
.cat-card img,
.hero-card img,
.big-slide-img {
  will-change: transform;
  transform: translateZ(0);            /* promove para camada composta */
}

/* Objeto de ajuste padrão para todas as imagens de produto */
.prod-img-wrap img,
.gallery-main img,
.cat-card img,
.craque-mini-img img,
.craque-card-imgs img,
.jogador-img-card img,
.hero-card img {
  object-fit: cover;
}
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }

/* =============================================
   TYPOGRAPHY
   ============================================= */
.font-display { font-family: 'Bebas Neue', sans-serif; letter-spacing: .04em; }
.font-title   { font-family: 'Oswald', sans-serif; }
h1,h2,h3,h4 { font-family: 'Oswald', sans-serif; line-height: 1.2; }

/* =============================================
   ANNOUNCE BAR
   ============================================= */
.announce-bar {
  background: linear-gradient(90deg, #bdd600 0%, var(--accent) 50%, #bdd600 100%);
  color: #07090C;
  height: 38px;
  overflow: hidden;
  display: flex;
  align-items: center;
  position: relative;
}
.announce-bar::before,
.announce-bar::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 6px; height: 6px;
  background: var(--black);
  border-radius: 50%;
  opacity: .3;
  z-index: 2;
  animation: announce-blink 2s ease-in-out infinite;
}
.announce-bar::before { left: 14px; }
.announce-bar::after  { right: 14px; animation-delay: 1s; }
@keyframes announce-blink { 0%,100%{opacity:.3} 50%{opacity:.7} }
.announce-track {
  display: flex;
  white-space: nowrap;
  animation: marquee 34s linear infinite;
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .1em;
}
.announce-track span { padding: 0 30px; }
.announce-track .sep { padding: 0; opacity: .3; font-weight: 300; }
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* =============================================
   HEADER
   ============================================= */
.header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(7,9,12,.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .3s ease;
}
.header-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
  height: 70px;
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Logo */
.logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 30px;
  letter-spacing: .05em;
  display: flex;
  align-items: baseline;
  gap: 3px;
  flex-shrink: 0;
  cursor: pointer;
}
.logo-rv    { color: var(--accent); }
.logo-sport { color: var(--white); }
.logo em {
  font-family: 'DM Sans', sans-serif;
  font-style: normal;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted2);
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-left: 5px;
  align-self: center;
  border: 1px solid rgba(255,255,255,.1);
  padding: 2px 6px;
  border-radius: 4px;
}

/* Nav */
.nav {
  display: flex;
  align-items: center;
  gap: 1px;
  margin-left: 12px;
}
.nav-link {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 7px 13px;
  border-radius: 8px;
  color: rgba(240,242,248,.75);
  transition: color .2s ease, background .2s ease;
  white-space: nowrap;
  position: relative;
}
.nav-link:hover { color: var(--white); background: rgba(255,255,255,.07); }
.nav-link.active {
  color: var(--accent);
  background: rgba(228,255,0,.06);
  border-bottom: 2px solid var(--accent);
  border-radius: 0;
  padding-bottom: 5px;
}

/* Dropdown (legacy) */
.nav-dropdown { position: relative; }
.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: var(--card2);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 8px;
  min-width: 220px;
  display: none;
  box-shadow: var(--shadow-lg);
  z-index: 300;
  padding-top: 14px;
}
.dropdown-menu::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0; right: 0;
  height: 12px;
}
.nav-dropdown:hover .dropdown-menu { display: block; }
.nav-dropdown.open .dropdown-menu  { display: block; }
.dropdown-menu a {
  display: block;
  padding: 11px 14px;
  border-radius: 8px;
  font-size: 14px;
  color: var(--muted);
  transition: var(--tr);
  cursor: pointer;
}
.dropdown-menu a:hover { color: var(--white); background: rgba(255,255,255,.07); }

/* Header Actions */
.header-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.btn-icon {
  width: 42px; height: 42px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  color: rgba(240,242,248,.7);
  transition: var(--tr);
  position: relative;
}
.btn-icon:hover {
  background: rgba(255,255,255,.1);
  border-color: var(--border2);
  color: var(--white);
}
.btn-icon:active { transform: scale(.93); }
.cart-badge {
  position: absolute;
  top: -6px; right: -6px;
  background: var(--accent);
  color: var(--black);
  font-size: 10px;
  font-weight: 900;
  width: 20px; height: 20px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--black);
}
.btn-whatsapp {
  display: flex; align-items: center; gap: 7px;
  background: #25D366;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 9px 18px;
  border-radius: 10px;
  transition: var(--tr);
  white-space: nowrap;
  position: relative;
  overflow: visible;
}
.btn-whatsapp::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 13px;
  border: 2px solid rgba(37,211,102,.5);
  animation: wpp-ping 2.8s ease-out infinite;
  pointer-events: none;
}
@keyframes wpp-ping {
  0%   { transform: scale(1);    opacity: .65; }
  65%  { transform: scale(1.15); opacity: 0;   }
  100% { transform: scale(1.15); opacity: 0;   }
}
.btn-whatsapp:hover { background: #1dba58; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(37,211,102,.35); }
.btn-whatsapp:hover::after { animation: none; opacity: 0; }
.hamburger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--white); border-radius: 2px; transition: var(--tr); }

/* Search Bar */
.search-bar {
  background: var(--dark);
  border-top: 1px solid var(--border);
  padding: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
}
.search-bar.open { max-height: 420px; padding: 18px 0; }
.search-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  border-bottom: 1.5px solid var(--border2);
}
.search-inner svg { color: var(--muted); flex-shrink: 0; }
.search-inner input {
  flex: 1;
  background: none;
  border: none;
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-size: 20px;
  outline: none;
  letter-spacing: .01em;
}
.search-inner input::placeholder { color: var(--muted2); }
.search-close { color: var(--muted); font-size: 20px; padding: 4px 8px; }
.search-close:hover { color: var(--white); }
.search-results {
  max-width: var(--max);
  margin: 14px auto 0;
  padding: 0 28px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}

/* =============================================
   PAGES
   ============================================= */
#main { min-height: 60vh; }

/* =============================================
   HERO
   ============================================= */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--dark);
}
.hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 65% 50%, rgba(228,255,0,.08) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 10% 80%, rgba(0,217,240,.05) 0%, transparent 60%),
    linear-gradient(145deg, #07090C 0%, #0C1018 60%, #090E12 100%);
}
.hero-lines {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 64px 64px;
}
.hero-diagonal {
  position: absolute;
  top: -120px; right: 28%;
  width: 2px; height: 140%;
  background: linear-gradient(to bottom, transparent 0%, rgba(228,255,0,.16) 40%, rgba(228,255,0,.07) 70%, transparent 100%);
  transform: rotate(-12deg);
  transform-origin: top center;
  pointer-events: none;
}
.hero-diagonal::after {
  content: '';
  position: absolute;
  top: 0; left: -40px;
  width: 1px; height: 100%;
  background: linear-gradient(to bottom, transparent 0%, rgba(0,217,240,.08) 50%, transparent 100%);
}
.hero-corner-accent {
  position: absolute;
  bottom: 0; left: 0;
  width: 400px; height: 3px;
  background: linear-gradient(to right, var(--accent), transparent);
  opacity: .35;
}
.hero-content {
  position: relative;
  max-width: var(--max);
  margin: 0 auto;
  padding: 80px 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  width: 100%;
}
.hero-text { z-index: 2; }
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(228,255,0,.09);
  border: 1px solid rgba(228,255,0,.22);
  color: var(--accent);
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .13em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 22px;
}
.hero-eyebrow::before { content: ''; width: 6px; height: 6px; background: var(--accent); border-radius: 50%; animation: blink 1.5s ease infinite; }
@keyframes blink { 0%,100% { opacity:1; } 50% { opacity:.25; } }
.hero-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(60px, 7vw, 104px);
  line-height: .92;
  letter-spacing: .02em;
  margin-bottom: 22px;
}
.hero-title .accent {
  color: var(--accent);
  position: relative;
  display: inline-block;
}
.hero-title .accent::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 100%; height: 3px;
  background: linear-gradient(to right, var(--accent), rgba(228,255,0,.15));
  border-radius: 2px;
}
.hero-sub {
  font-size: 17px;
  color: #8a9ab8;
  max-width: 460px;
  margin-bottom: 38px;
  line-height: 1.78;
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, #cee800 0%, var(--accent) 55%, #eeff40 100%);
  color: var(--black);
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 14px 30px;
  border-radius: 10px;
  transition: var(--tr);
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(228,255,0,.18);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #d4f000 0%, #f0ff22 100%);
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 14px 36px rgba(228,255,0,.42), 0 4px 12px rgba(0,0,0,.3);
}
.btn-primary:active { transform: translateY(-1px) scale(.99); }
.btn-secondary {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.05);
  border: 1.5px solid rgba(255,255,255,.15);
  color: var(--white);
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 14px 28px;
  border-radius: 10px;
  transition: var(--tr);
  cursor: pointer;
}
.btn-secondary:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.25);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.3);
}
.btn-secondary:active { transform: scale(.98); }
.hero-stats {
  display: flex;
  gap: 36px;
  margin-top: 44px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.stat-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 44px;
  color: var(--accent);
  line-height: 1;
  text-shadow: 0 0 28px rgba(228,255,0,.22);
}
.stat-lbl { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .1em; margin-top: 5px; font-weight: 600; }

/* Hero Images */
.hero-imgs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  position: relative;
}
.hero-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: var(--tr);
}
.hero-card:hover { transform: translateY(-5px); border-color: rgba(228,255,0,.2); box-shadow: var(--shadow); }
.hero-card:nth-child(2) { margin-top: 32px; }
.hero-card img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: contain;
  object-position: top;
  background: linear-gradient(to bottom, #1a2030, #0e1420);
  transition: transform .4s ease;
}
.hero-card:hover img { transform: scale(1.05); }
.hero-card-label {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 28px 14px 14px;
  background: linear-gradient(to top, rgba(0,0,0,.88), transparent);
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* =============================================
   SECTION WRAPPER
   ============================================= */
.section {
  max-width: var(--max);
  margin: 0 auto;
  padding: 88px 28px;
}
.section-sm { padding: 40px 28px; }
.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 44px;
  gap: 16px;
}
.section-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(36px, 4vw, 58px);
  letter-spacing: .04em;
  line-height: 1;
}
.section-title span { color: var(--accent); }
.section-sub { color: var(--muted); font-size: 15px; margin-top: 8px; }
.see-all {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
  border-bottom: 1px solid transparent;
  transition: var(--tr);
  cursor: pointer;
  padding-bottom: 2px;
}
.see-all:hover { border-color: var(--accent); }

/* =============================================
   CATEGORIES GRID
   ============================================= */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px 60px;
}
.cat-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: transform .28s cubic-bezier(.4,0,.2,1), box-shadow .28s ease, border-color .22s ease;
  aspect-ratio: 3/4;
}
.cat-card:first-child { grid-column: span 2; aspect-ratio: auto; min-height: 280px; }
.cat-card:hover {
  transform: translateY(-6px);
  border-color: rgba(228,255,0,.22);
  box-shadow: 0 18px 44px rgba(0,0,0,.55), 0 0 0 1px rgba(228,255,0,.09);
}
.cat-card img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .45s ease; }
.cat-card:hover img { transform: scale(1.07); }
.cat-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.25) 55%, transparent 100%);
  transition: var(--tr);
}
.cat-card:hover .cat-overlay { background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.45) 65%, rgba(0,0,0,.08) 100%); }
.cat-info {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 22px 16px 16px;
}
.cat-name {
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.cat-count { font-size: 12px; color: rgba(255,255,255,.55); margin-top: 4px; font-weight: 500; }
.cat-arrow {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px;
  background: var(--accent);
  color: var(--black);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700;
  opacity: 0;
  transition: var(--tr);
  transform: translateY(6px);
}
.cat-card:hover .cat-arrow { opacity: 1; transform: translateY(0); }

/* =============================================
   PRODUCTS GRID & CAROUSEL
   ============================================= */
.products-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
}
.section-title-bold {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(30px, 3.5vw, 50px);
  letter-spacing: .05em;
  line-height: 1;
  color: var(--white);
}
.section-title-bold span { color: var(--accent); }

/* Horizontal carousel */
.prod-carousel-wrap {
  position: relative;
  overflow: visible;
}
.prod-carousel {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  overflow-y: visible;
  -ms-overflow-style: none;
  scrollbar-width: none;
  padding-bottom: 4px;
  cursor: grab;
}
.prod-carousel:active { cursor: grabbing; }
.prod-carousel::-webkit-scrollbar { display: none; }
.carousel-item {
  flex: 0 0 230px;
}
.carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: rgba(7,9,12,.9);
  border: 1px solid var(--border2);
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: var(--tr);
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 18px rgba(0,0,0,.55);
}
.carousel-arrow:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--black);
  transform: translateY(-50%) scale(1.12);
  box-shadow: 0 6px 22px rgba(228,255,0,.35);
}
.carousel-prev { left: -18px; }
.carousel-next { right: -18px; }

/* =============================================
   PRODUCT CARD
   ============================================= */
.product-card {
  background: var(--card);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s cubic-bezier(.4,0,.2,1), border-color .3s ease;
  position: relative;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-card);
}
.product-card:hover {
  transform: translateY(-7px);
  border-color: rgba(228,255,0,.2);
  box-shadow: var(--shadow-hover);
}
.prod-img-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #fff;
  flex-shrink: 0;
}
.prod-img-front,
.prod-img-back {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: opacity .4s ease, transform .48s ease;
  will-change: opacity, transform;
}
.prod-img-front { opacity: 1;  transform: scale(1);    z-index: 1; }
.prod-img-back  { opacity: 0;  transform: scale(1.05); z-index: 2; }
/* Flip CSS ativo só quando costas foi carregada com sucesso */
.product-card:not(.no-back):hover .prod-img-front { opacity: 0;  transform: scale(1.05); }
.product-card:not(.no-back):hover .prod-img-back  { opacity: 1;  transform: scale(1);    }
/* Sem costas: zoom suave na frente */
.product-card.no-back:hover .prod-img-front { transform: scale(1.04); }

/* Heart button */
.prod-wish-btn {
  position: absolute;
  top: 9px; right: 9px;
  z-index: 3;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,.94);
  border: none;
  display: flex; align-items: center; justify-content: center;
  color: #aaa;
  cursor: pointer;
  transition: var(--tr);
  box-shadow: 0 2px 10px rgba(0,0,0,.18);
}
.prod-wish-btn:hover { color: #e53935; transform: scale(1.12); }
.prod-wish-btn svg { width: 15px; height: 15px; }

/* Discount badge */
.prod-disc-badge {
  position: absolute;
  top: 9px; left: 9px;
  z-index: 3;
  background: #e53935;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  padding: 3px 9px;
  border-radius: 5px;
}

/* Small badges */
.prod-badges {
  position: absolute; top: 38px; left: 9px;
  display: flex; flex-direction: column; gap: 4px;
  z-index: 2;
}
.badge {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 5px;
  white-space: nowrap;
  width: fit-content;
}
.badge-novo    { background: var(--accent3); color: var(--black); }
.badge-oferta  { background: var(--accent2); color: #fff; }
.badge-especial{ background: linear-gradient(135deg, #FFD700, #FF8C00); color: var(--black); }
.badge-jogador { background: var(--accent); color: var(--black); }
.badge-retro   { background: linear-gradient(135deg, #c0a060, #8b6914); color: #fff; }
.badge-pct     { background: rgba(0,230,118,.14); color: var(--green); border: 1px solid rgba(0,230,118,.24); }

/* Product info */
.prod-info {
  padding: 13px 13px 15px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex: 1;
}
.prod-name {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: #dce2ef;
  line-height: 1.42;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  letter-spacing: .01em;
}
.prod-promo-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: linear-gradient(135deg, #6a00cc, #4a0090);
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 5px;
  width: fit-content;
  box-shadow: 0 2px 10px rgba(100,0,200,.35);
}
.prod-promo-badge svg { width: 10px; height: 10px; flex-shrink: 0; }
.prod-pricing { display: flex; flex-direction: column; gap: 1px; }
.prod-price-row { display: flex; align-items: baseline; gap: 8px; }
.prod-price {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--white);
  line-height: 1;
  letter-spacing: .02em;
}
.prod-old {
  font-size: 12px;
  color: var(--muted2);
  text-decoration: line-through;
}
.prod-installment { font-size: 11px; color: var(--muted); }

/* COMPRAR button */
/* === CARD ACTIONS — dois botões lado a lado === */
.card-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: auto;
  width: 100%;
}

/* Botão CARRINHO — verde, ícone + texto */
.btn-add-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: linear-gradient(135deg, #00c853 0%, #00a844 100%);
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 11px 8px;
  border-radius: 9px;
  border: none;
  cursor: pointer;
  transition: var(--tr);
  box-shadow: 0 4px 14px rgba(0,180,74,.22);
  white-space: nowrap;
}
.btn-add-cart:hover {
  background: linear-gradient(135deg, #00e676 0%, #00c853 100%);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,230,118,.38);
}
.btn-add-cart:active { transform: scale(.97); }
.btn-add-cart svg { width: 14px; height: 14px; flex-shrink: 0; }

/* Botão VER PRODUTO — outline accent */
.btn-ver-produto {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--accent);
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 11px 8px;
  border-radius: 9px;
  border: 1.5px solid var(--accent);
  cursor: pointer;
  transition: var(--tr);
  white-space: nowrap;
}
.btn-ver-produto:hover {
  background: var(--accent);
  color: var(--black);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(228,255,0,.25);
}
.btn-ver-produto:active { transform: scale(.97); }

/* Compatibilidade — mantém .btn-comprar para uso eventual em outros contextos */
.btn-comprar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  background: linear-gradient(135deg, #00c853 0%, #00a844 100%);
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 11px 12px;
  border-radius: 9px;
  border: none;
  cursor: pointer;
  transition: var(--tr);
  margin-top: auto;
  box-shadow: 0 4px 14px rgba(0,180,74,.22);
}
.btn-comprar:hover {
  background: linear-gradient(135deg, #00e676 0%, #00c853 100%);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,230,118,.38);
}
.btn-comprar:active { transform: scale(.97); }
.btn-comprar svg { width: 14px; height: 14px; }

/* Stock indicator */
.prod-stock {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--muted);
}
.prod-stock-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #00b84a;
  flex-shrink: 0;
  box-shadow: 0 0 5px rgba(0,184,74,.5);
}

.prod-country {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2px;
}

/* =============================================
   TEAM BADGES STRIP
   ============================================= */
.team-badges-section {
  background: var(--dark);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 20px 0;
  overflow: hidden;
}
.team-badges-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.team-badges-label {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted2);
}
.team-badges-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.team-badges-carousel {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  flex: 1;
  cursor: grab;
}
.team-badges-carousel:active { cursor: grabbing; }
.team-badges-carousel::-webkit-scrollbar { display: none; }
.team-badge-item {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: var(--tr);
  min-width: 82px;
}
.team-badge-item:hover {
  border-color: var(--accent);
  background: rgba(228,255,0,.07);
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 8px 22px rgba(0,0,0,.38), 0 0 0 1px rgba(228,255,0,.11);
}
.team-badge-logo {
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
}
.team-badge-logo img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.6));
  transition: transform .22s ease;
}
.team-badge-item:hover .team-badge-logo img { transform: scale(1.15); }
.team-badge-name {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
  white-space: nowrap;
}
.team-badge-item:hover .team-badge-name { color: var(--accent); }

/* =============================================
   FILTER BAR
   ============================================= */
/* =============================================
   FILTROS — SISTEMA PREMIUM v3
   ============================================= */
.filter-wrap {
  background: rgba(10,13,19,.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  position: sticky;
  top: 70px;
  z-index: 100;
}
.filter-bar {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 24px;
}
.filter-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.filter-row:last-child { border-bottom: none; }
.filter-group {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.filter-group-label {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted2);
  white-space: nowrap;
  flex-shrink: 0;
}
.filter-chips {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  padding: 4px 0;
  flex: 1;
}
.filter-chips::-webkit-scrollbar { display: none; }

/* CHIP BASE */
.chip {
  flex-shrink: 0;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 8px 16px;
  min-height: 36px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.45);
  background: transparent;
  cursor: pointer;
  transition: all .18s cubic-bezier(.4,0,.2,1);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

/* CHIP HOVER */
.chip:hover {
  border-color: rgba(228,255,0,.4);
  color: var(--white);
  background: rgba(228,255,0,.06);
  transform: translateY(-1px);
}

/* CHIP ACTIVE — forte, inconfundível */
.chip.active {
  background: var(--accent);
  color: #07090C;
  border-color: var(--accent);
  font-weight: 800;
  box-shadow: 0 0 0 0 rgba(228,255,0,0), 0 4px 16px rgba(228,255,0,.32);
  transform: translateY(0);
}
.chip.active:hover { background: #f0ff20; }

/* CHIP PRESS */
.chip:active { transform: scale(.95); }

/* SORT WRAPPER */
.filter-sort { flex-shrink: 0; }
.sort-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,.05);
  border: 1.5px solid rgba(255,255,255,.08);
  border-radius: 10px;
  padding: 0 12px 0 10px;
  height: 36px;
  cursor: pointer;
  transition: all .18s ease;
}
.sort-wrapper:hover {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
}
.sort-wrapper svg:first-child { color: var(--muted); flex-shrink: 0; }
.sort-arrow { color: var(--muted); flex-shrink: 0; pointer-events: none; }
.sort-select {
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 100%;
  cursor: pointer;
  border: none;
  background: none;
  appearance: none;
  -webkit-appearance: none;
}
.sort-label {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
  pointer-events: none;
}

/* =============================================
   PRODUCT PAGE
   ============================================= */
.breadcrumb {
  max-width: var(--max);
  margin: 0 auto;
  padding: 22px 28px 0;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--muted2);
}
.breadcrumb a { transition: var(--tr); }
.breadcrumb a:hover { color: var(--white); }
.breadcrumb span { color: var(--muted2); }
.breadcrumb .current { color: var(--muted); }

.product-detail {
  max-width: var(--max);
  margin: 0 auto;
  padding: 36px 28px 88px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

/* Gallery */
.gallery { position: sticky; top: 92px; }
.gallery-main {
  background: #fff;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 1/1;
  position: relative;
  cursor: zoom-in;
  margin-bottom: 12px;
  box-shadow: 0 6px 28px rgba(0,0,0,.45);
}
.gallery-main img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .4s ease;
}
.gallery-main:hover img { transform: scale(1.04); }
.gallery-thumbs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--card2) transparent;
}
.gallery-thumbs::-webkit-scrollbar { height: 4px; }
.gallery-thumbs::-webkit-scrollbar-track { background: transparent; }
.gallery-thumbs::-webkit-scrollbar-thumb { background: var(--card2); border-radius: 2px; }
.gallery-thumb {
  width: 82px; height: 82px;
  flex-shrink: 0;
  background: #fff;
  border: 2px solid rgba(255,255,255,.06);
  border-radius: 9px;
  overflow: hidden;
  cursor: pointer;
  transition: var(--tr);
}
.gallery-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .3s ease;
}
.gallery-thumb:hover { border-color: var(--border2); }
.gallery-thumb:hover img { transform: scale(1.08); }
.gallery-thumb.active { border-color: var(--accent); border-width: 2.5px; }

/* Product Info Panel */
.prod-detail-country {
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 9px;
  display: flex; align-items: center; gap: 8px;
}
.prod-detail-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(32px, 4vw, 54px);
  letter-spacing: .04em;
  line-height: .97;
  margin-bottom: 18px;
}
.prod-detail-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 22px; }
.prod-detail-price {
  margin-bottom: 26px;
  padding: 20px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
.prod-detail-price::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--accent), transparent);
  opacity: .6;
}
.price-main {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 54px;
  color: var(--accent);
  line-height: 1;
  letter-spacing: .02em;
}
.price-old { font-size: 14px; color: var(--muted2); text-decoration: line-through; margin-bottom: 4px; }
.price-discount { font-size: 13px; color: var(--green); font-weight: 700; }
.price-installment { font-size: 14px; color: var(--muted); margin-top: 8px; }

/* Sizes */
.option-label {
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}
.sizes-grid { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 26px; }
.size-btn {
  min-width: 52px; height: 48px;
  padding: 0 14px;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  color: var(--white);
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--tr);
  display: flex; align-items: center; justify-content: center;
}
.size-btn:hover { border-color: rgba(255,255,255,.22); background: var(--card2); transform: translateY(-1px); }
.size-btn.active {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(228,255,0,.07);
  box-shadow: 0 0 0 1px rgba(228,255,0,.14) inset;
}
.size-btn:active { transform: scale(.95); }

/* CTA */
.prod-ctas { display: flex; gap: 12px; margin-bottom: 26px; }
.btn-buy {
  flex: 1;
  background: var(--accent);
  color: var(--black);
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 18px 24px;
  border-radius: 10px;
  cursor: pointer;
  border: none;
  transition: var(--tr);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  box-shadow: 0 4px 20px rgba(228,255,0,.25);
}
.btn-buy svg { width: 20px; height: 20px; }
.btn-buy:hover { background: #d4ee00; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(228,255,0,.4); }
.btn-buy:active { transform: scale(.97); }
.btn-wpp-buy {
  background: #25D366;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  padding: 17px 20px;
  border-radius: 10px;
  cursor: pointer;
  border: none;
  transition: var(--tr);
  display: flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.btn-wpp-buy:hover { background: #1dba58; transform: translateY(-1px); box-shadow: 0 7px 20px rgba(37,211,102,.35); }
.btn-wpp-buy:active { transform: scale(.97); }

/* Benefits inline */
.prod-benefits {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 26px;
}
.prod-benefit-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 9px;
  font-size: 13px;
  color: var(--muted);
}
.prod-benefit-item .icon { font-size: 18px; }

/* Tabs */
.prod-tabs { margin-top: 32px; }
.tab-btns { display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 24px; }
.tab-btn {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 12px 20px;
  color: var(--muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  transition: var(--tr);
}
.tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }
.tab-panel p { color: var(--muted); line-height: 1.85; margin-bottom: 16px; }
.tab-panel table { width: 100%; border-collapse: collapse; font-size: 14px; }
.tab-panel table th,
.tab-panel table td { padding: 12px 16px; text-align: left; border: 1px solid var(--border); }
.tab-panel table th { background: var(--card2); font-family: 'Oswald', sans-serif; font-weight: 600; color: var(--muted); }

/* =============================================
   BENEFITS BAR
   ============================================= */
.benefits-bar {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.benefits-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.benefit-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 30px 24px;
  border-right: 1px solid var(--border);
  transition: var(--tr);
}
.benefit-item:last-child { border-right: none; }
.benefit-item:hover { background: rgba(255,255,255,.025); }
.benefit-icon { font-size: 28px; flex-shrink: 0; }
.benefit-title {
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .02em;
  margin-bottom: 4px;
}
.benefit-desc { font-size: 12px; color: var(--muted); line-height: 1.55; }

/* =============================================
   TESTIMONIALS
   ============================================= */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.testimonial-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 26px;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
}
.testimonial-card::before {
  content: '"';
  position: absolute;
  top: -12px; right: 20px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 100px;
  color: var(--accent);
  opacity: .05;
  line-height: 1;
  pointer-events: none;
}
.testimonial-card:hover {
  border-color: rgba(228,255,0,.18);
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(0,0,0,.35);
}
.stars { color: #FFD700; font-size: 15px; margin-bottom: 12px; letter-spacing: 2px; }
.testimonial-text { color: #8090aa; font-size: 14px; line-height: 1.8; margin-bottom: 18px; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.author-avatar {
  width: 42px; height: 42px;
  background: linear-gradient(135deg, var(--accent), var(--accent3));
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  color: var(--black);
  font-weight: 700;
  flex-shrink: 0;
}
.author-name { font-weight: 600; font-size: 14px; }
.author-loc { font-size: 12px; color: var(--muted2); }

/* =============================================
   CART DRAWER
   ============================================= */
.cart-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 300;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.cart-overlay.open { opacity: 1; pointer-events: all; }
.cart-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 420px;
  max-width: 100vw;
  background: var(--dark);
  border-left: 1px solid var(--border);
  z-index: 400;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
}
.cart-drawer.open { transform: translateX(0); }
.cart-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 24px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cart-header h3 { font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 600; }
.cart-close {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.05);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 18px;
  cursor: pointer; transition: var(--tr);
  border: 1px solid var(--border);
}
.cart-close:hover { color: var(--white); background: rgba(255,255,255,.1); }
.cart-items { flex: 1; overflow-y: auto; padding: 16px 24px; }
.cart-empty { text-align: center; padding: 60px 0; color: var(--muted); }
.cart-empty-icon { font-size: 60px; margin-bottom: 16px; }
.cart-empty h4 { font-family: 'Oswald', sans-serif; font-size: 20px; margin-bottom: 8px; }

.cart-item {
  display: flex; gap: 14px; align-items: start;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}
.cart-item-img {
  width: 80px; height: 80px; flex-shrink: 0;
  background: #fff;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 9px;
  overflow: hidden;
}
.cart-item-img img { width: 100%; height: 100%; object-fit: contain; }
.cart-item-info { flex: 1; }
.cart-item-name { font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600; text-transform: uppercase; line-height: 1.3; margin-bottom: 4px; }
.cart-item-size { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.cart-item-price { font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 700; color: var(--accent); }
.cart-item-qty {
  display: flex; align-items: center; gap: 0;
  margin-top: 9px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  width: fit-content;
}
.qty-btn {
  width: 32px; height: 32px;
  background: var(--card);
  color: var(--white);
  font-size: 18px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--tr);
  border: none; border-radius: 0;
  font-family: inherit;
}
.qty-btn:hover { background: var(--card2); }
.qty-num { width: 36px; text-align: center; font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600; }
.cart-item-remove {
  color: var(--muted2); font-size: 18px; cursor: pointer; transition: var(--tr);
  padding: 4px; flex-shrink: 0;
  background: none; border: none;
}
.cart-item-remove:hover { color: var(--accent2); }

.cart-footer { padding: 20px 24px; border-top: 1px solid var(--border); flex-shrink: 0; }
.cart-summary { margin-bottom: 16px; }
.cart-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 9px; font-size: 14px; color: var(--muted); }
.cart-row.total { font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 700; color: var(--white); border-top: 1px solid var(--border); padding-top: 13px; margin-top: 13px; }
.cart-row.total .price { color: var(--accent); }
.btn-checkout {
  width: 100%;
  background: var(--accent);
  color: var(--black);
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 16px;
  border-radius: 10px;
  cursor: pointer;
  border: none;
  transition: var(--tr);
  margin-bottom: 10px;
}
.btn-checkout:hover { background: #ccee00; box-shadow: 0 8px 24px rgba(228,255,0,.28); }
.btn-continue {
  width: 100%;
  background: none;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 12px;
  border-radius: 10px;
  cursor: pointer;
  transition: var(--tr);
}
.btn-continue:hover { color: var(--white); border-color: var(--border2); }

/* =============================================
   CHECKOUT PAGE
   ============================================= */
.checkout-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 28px 88px;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 40px;
  align-items: start;
}
.checkout-form h2 { font-family: 'Oswald', sans-serif; font-size: 28px; margin-bottom: 24px; }
.form-section { margin-bottom: 32px; }
.form-section h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.form-row.full { grid-template-columns: 1fr; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--muted2); }
.form-group input,
.form-group select {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 12px 14px;
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  outline: none;
  transition: var(--tr);
}
.form-group input:focus,
.form-group select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(228,255,0,.08); }
.form-group input::placeholder { color: var(--muted2); }
.form-group select option { background: var(--dark); }

.checkout-summary {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 26px;
  position: sticky;
  top: 92px;
}
.checkout-summary h3 { font-family: 'Oswald', sans-serif; font-size: 18px; margin-bottom: 20px; border-bottom: 1px solid var(--border); padding-bottom: 14px; }
.summary-items { margin-bottom: 20px; }
.summary-item { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; font-size: 13px; color: var(--muted); }
.summary-item img { width: 50px; height: 50px; object-fit: contain; background: #fff; border-radius: 7px; }
.summary-item-name { flex: 1; font-size: 12px; line-height: 1.4; }
.summary-item-price { font-family: 'Oswald', sans-serif; font-size: 15px; color: var(--white); font-weight: 600; white-space: nowrap; }
.summary-divider { border: none; border-top: 1px solid var(--border); margin: 16px 0; }
.summary-row { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 8px; color: var(--muted); }
.summary-total { display: flex; justify-content: space-between; font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 700; color: var(--white); margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }
.summary-total span:last-child { color: var(--accent); }

/* =============================================
   ABOUT PAGE
   ============================================= */
.about-hero {
  background: var(--dark);
  padding: 88px 28px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.about-hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(60px, 8vw, 120px); letter-spacing: .04em; margin-bottom: 18px; }
.about-hero h1 span { color: var(--accent); }
.about-hero p { font-size: 18px; color: var(--muted); max-width: 600px; margin: 0 auto; line-height: 1.75; }
.about-content { max-width: 900px; margin: 0 auto; padding: 80px 28px; }
.about-content p { color: var(--muted); font-size: 16px; line-height: 1.85; margin-bottom: 24px; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 64px 0; }
.value-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 34px 24px; text-align: center; transition: var(--tr); }
.value-card:hover { border-color: rgba(228,255,0,.18); transform: translateY(-4px); box-shadow: 0 12px 36px rgba(0,0,0,.35); }
.value-icon { font-size: 40px; margin-bottom: 16px; }
.value-title { font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 12px; }
.value-desc { font-size: 14px; color: var(--muted); line-height: 1.75; }

/* =============================================
   CONTACT PAGE
   ============================================= */
.contact-wrap { max-width: 1000px; margin: 0 auto; padding: 60px 28px 88px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; }
.contact-info h2 { font-family: 'Bebas Neue', sans-serif; font-size: 56px; letter-spacing: .04em; margin-bottom: 16px; }
.contact-info h2 span { color: var(--accent); }
.contact-info p { color: var(--muted); font-size: 15px; line-height: 1.75; margin-bottom: 32px; }
.contact-items { display: flex; flex-direction: column; gap: 14px; }
.contact-item { display: flex; align-items: center; gap: 14px; padding: 16px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); transition: var(--tr); }
.contact-item:hover { border-color: var(--border2); transform: translateX(4px); }
.contact-item-icon { font-size: 22px; }
.contact-item-text { font-size: 14px; color: var(--muted); }
.contact-item-text strong { display: block; color: var(--white); font-size: 15px; margin-bottom: 2px; }
.contact-form-wrap h3 { font-family: 'Oswald', sans-serif; font-size: 24px; text-transform: uppercase; margin-bottom: 24px; }
.btn-submit { width: 100%; }

/* =============================================
   LEGAL PAGES
   ============================================= */
.legal-wrap { max-width: 800px; margin: 0 auto; padding: 60px 28px 88px; }
.legal-wrap h1 { font-family: 'Oswald', sans-serif; font-size: 40px; text-transform: uppercase; margin-bottom: 8px; }
.legal-wrap .updated { font-size: 13px; color: var(--muted2); margin-bottom: 40px; }
.legal-wrap h2 { font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 600; text-transform: uppercase; margin: 32px 0 12px; color: var(--white); }
.legal-wrap p { color: var(--muted); font-size: 14px; line-height: 1.85; margin-bottom: 16px; }
.legal-wrap ul { padding-left: 20px; }
.legal-wrap ul li { color: var(--muted); font-size: 14px; line-height: 1.85; margin-bottom: 8px; list-style: disc; }

/* =============================================
   FOOTER — Premium
   ============================================= */
footer {
  background: var(--dark);
  border-top: 1px solid var(--border);
  margin-top: 80px;
}
.footer-top {
  max-width: var(--max);
  margin: 0 auto;
  padding: 64px 28px 44px;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
}
.footer-logo { margin-bottom: 18px; }
.footer-logo .logo { font-size: 34px; }
.footer-tagline { font-size: 14px; color: var(--muted); line-height: 1.75; max-width: 280px; margin-bottom: 22px; }
.footer-social { display: flex; gap: 10px; }
.social-btn {
  width: 38px; height: 38px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted);
  font-size: 16px;
  transition: var(--tr);
  cursor: pointer;
  text-decoration: none;
}
.social-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(228,255,0,.07);
  transform: translateY(-2px) scale(1.1);
  box-shadow: 0 5px 16px rgba(0,0,0,.4);
}
.social-btn[title="Instagram"]:hover { border-color: #E1306C; color: #E1306C; background: rgba(225,48,108,.06); }
.social-btn[title="Facebook"]:hover  { border-color: #1877F2; color: #1877F2; background: rgba(24,119,242,.06); }
.social-btn[title="TikTok"]:hover    { border-color: #ff0050; color: #ff0050; background: rgba(255,0,80,.06); }
.social-btn svg { display: block; }

.footer-col h4 {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  margin-bottom: 18px;
  color: var(--white);
}
.footer-col ul { display: flex; flex-direction: column; gap: 11px; }
.footer-col ul li a {
  font-size: 14px;
  color: var(--muted);
  transition: all .2s ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.footer-col ul li a:hover { color: var(--accent); transform: translateX(4px); }

.footer-bottom {
  border-top: 1px solid var(--border);
  padding: 22px 28px;
  max-width: var(--max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-bottom p { font-size: 13px; color: var(--muted2); }
.payment-icons { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.payment-icon {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  font-family: 'Oswald', sans-serif;
  letter-spacing: .06em;
}

/* =============================================
   MOBILE NAV
   ============================================= */
.mobile-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 500;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.mobile-overlay.open { opacity: 1; pointer-events: all; }
.mobile-nav {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: 270px;
  max-width: 80vw;
  background: var(--dark);
  border-right: 1px solid var(--border);
  z-index: 600;
  display: flex; flex-direction: column;
  transform: translateX(-100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
}
.mobile-nav.open { transform: translateX(0); }
.mobile-nav-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px;
  border-bottom: 1px solid var(--border);
}
.mobile-nav-header button { font-size: 22px; color: var(--muted); background: none; border: none; cursor: pointer; }
.mobile-links { padding: 20px; flex: 1; }
.mobile-links a {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 17px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
  transition: var(--tr);
}
.mobile-links a:last-child { border-bottom: none; }
.mobile-links a:hover, .mobile-links a.active { color: var(--white); }
.mobile-links a.promo-link { color: var(--accent2); }
.mobile-whatsapp {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: #25D366;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 16px 20px;
  margin: 20px;
  border-radius: 12px;
  transition: var(--tr);
  text-decoration: none;
}
.mobile-whatsapp:hover { background: #1dba58; }

/* =============================================
   TOAST
   ============================================= */
.toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(110px);
  background: var(--card2);
  border: 1px solid var(--border2);
  border-radius: 12px;
  padding: 14px 26px;
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: .04em;
  color: var(--white);
  z-index: 1000;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
  white-space: nowrap;
  box-shadow: var(--shadow-lg);
}
.toast.show { transform: translateX(-50%) translateY(0); }
.toast.success { border-color: rgba(0,230,118,.28); }
.toast.success::before { content: '✅ '; }

/* =============================================
   OFFERS STRIP
   ============================================= */
.offers-section {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.offers-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  align-items: stretch;
}
.offer-promo { padding: 52px 44px; border-right: 1px solid var(--border); }
.offer-tag {
  display: inline-block;
  background: var(--accent2);
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 5px;
  margin-bottom: 16px;
}
.offer-promo h3 { font-family: 'Bebas Neue', sans-serif; font-size: 52px; letter-spacing: .04em; line-height: 1; margin-bottom: 12px; }
.offer-promo h3 span { color: var(--accent); }
.offer-promo p { font-size: 15px; color: var(--muted); margin-bottom: 24px; }
.offer-products-list { padding: 32px 40px; }
.offer-products-list h4 { font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-bottom: 20px; }
.offer-items { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.offer-item {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: var(--tr);
}
.offer-item:hover { border-color: var(--accent); transform: translateY(-3px); }
.offer-item img { width: 100%; aspect-ratio: 1; object-fit: contain; background: #fff; }
.offer-item-info { padding: 8px 10px; }
.offer-item-name { font-size: 11px; color: var(--muted); line-height: 1.3; }
.offer-item-price { font-family: 'Oswald', sans-serif; font-size: 15px; color: var(--accent); font-weight: 700; }

/* =============================================
   PAGE TITLE BAR
   ============================================= */
.page-title-bar {
  background: var(--dark);
  border-bottom: 1px solid var(--border);
  padding: 44px 28px;
}
.page-title-inner { max-width: var(--max); margin: 0 auto; }
.page-title-bar h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(40px, 5vw, 72px); letter-spacing: .04em; line-height: 1; }
.page-title-bar h1 span { color: var(--accent); }
.page-title-bar p { color: var(--muted); margin-top: 8px; font-size: 15px; }

/* =============================================
   LOAD MORE
   ============================================= */
.load-more-wrap { text-align: center; margin-top: 52px; }
.btn-load-more {
  background: none;
  border: 1.5px solid var(--border2);
  color: var(--white);
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 14px 44px;
  border-radius: 10px;
  cursor: pointer;
  transition: var(--tr);
}
.btn-load-more:hover { border-color: var(--accent); color: var(--accent); background: rgba(228,255,0,.04); }

/* =============================================
   RELATED PRODUCTS
   ============================================= */
.related-section {
  background: var(--dark);
  border-top: 1px solid var(--border);
  padding: 64px 0;
}
.related-inner { max-width: var(--max); margin: 0 auto; padding: 0 28px; }

/* =============================================
   MEGA MENU
   ============================================= */
.nav-mega-wrap { position: relative; }
.mega-menu {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--card2);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 22px;
  display: none;
  grid-template-columns: repeat(3, 160px);
  gap: 0;
  box-shadow: 0 24px 64px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.04);
  z-index: 300;
  min-width: 500px;
}
.mega-menu::before {
  content: '';
  position: absolute;
  top: -8px; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid var(--border2);
}
.nav-mega-wrap.open .mega-menu,
.nav-mega-wrap:hover .mega-menu { display: grid; }
.mega-col {
  padding: 0 16px;
  border-right: 1px solid var(--border);
}
.mega-col:last-child { border-right: none; }
.mega-col-title {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
  padding-bottom: 7px;
  border-bottom: 1px solid var(--border);
}
.mega-col a {
  display: block;
  padding: 7px 0;
  font-size: 13px;
  color: var(--muted);
  transition: var(--tr);
  border-radius: 4px;
  cursor: pointer;
}
.mega-col a:hover { color: var(--white); padding-left: 5px; }

/* Nav special links */
.nav-promo, .nav-jogador, .nav-craques, .nav-retro, .nav-rastreio {
  color: var(--white) !important;
  font-weight: 500 !important;
}
.nav-promo:hover, .nav-jogador:hover, .nav-craques:hover, .nav-retro:hover, .nav-rastreio:hover {
  background: rgba(255,255,255,.07) !important;
}

/* =============================================
   MOBILE SECTION TITLES
   ============================================= */
.mobile-section-title {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 14px 0 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.mobile-sub {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 10px 0 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  color: var(--muted);
  transition: var(--tr);
  cursor: pointer;
  text-decoration: none;
}
.mobile-sub:hover { color: var(--white); }
.mobile-ver-todos { color: var(--accent) !important; font-size: 13px !important; }
.mobile-jogador { color: #5bc8ff !important; }
.mobile-craques { color: #FFD700 !important; }

/* =============================================
   PROMO PAGUE 2 LEVE 3
   ============================================= */
.promo-2-3-banner {
  border-radius: 9px;
  padding: 11px 14px;
  font-size: 13px;
  margin-bottom: 14px;
  line-height: 1.5;
  text-align: center;
}
.promo-2-3-banner.hint {
  background: rgba(228,255,0,.05);
  border: 1px solid rgba(228,255,0,.14);
  color: var(--muted);
}
.promo-2-3-banner.progress {
  background: rgba(255,150,0,.07);
  border: 1px solid rgba(255,150,0,.22);
  color: #ffaa44;
}
.promo-2-3-banner.active {
  background: rgba(0,230,118,.09);
  border: 1px solid rgba(0,230,118,.28);
  color: var(--green);
}

/* =============================================
   VERSAO JOGADOR BANNER
   ============================================= */
.jogador-banner {
  background: linear-gradient(135deg, #091526 0%, #0c1f3c 50%, #07101a 100%);
  border-top: 1px solid rgba(91,200,255,.14);
  border-bottom: 1px solid rgba(91,200,255,.14);
  cursor: pointer;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
}
.jogador-banner::before {
  content: '';
  position: absolute;
  top: -80px; right: 20%;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(91,200,255,.06), transparent 70%);
  pointer-events: none;
}
.jogador-banner:hover { filter: brightness(1.07); }
.jogador-banner-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 56px 28px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}
.jogador-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #5bc8ff;
  margin-bottom: 10px;
}
.jogador-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(44px, 5vw, 72px);
  letter-spacing: .04em;
  line-height: 1;
  color: var(--white);
  margin-bottom: 16px;
}
.jogador-title span { color: #5bc8ff; }
.jogador-desc { font-size: 15px; color: var(--muted); max-width: 440px; line-height: 1.75; margin-bottom: 26px; }
.jogador-banner-imgs { display: flex; gap: 12px; }
.jogador-img-card {
  width: 110px;
  background: rgba(91,200,255,.04);
  border: 1px solid rgba(91,200,255,.1);
  border-radius: var(--radius);
  overflow: hidden;
  flex-shrink: 0;
}
.jogador-img-card:nth-child(2) { margin-top: 22px; }
.jogador-img-card img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: contain;
  object-position: top;
  background: linear-gradient(to bottom, #1a2a3e, #0e1a2c);
  transition: transform .4s ease;
}
.jogador-banner:hover .jogador-img-card img { transform: scale(1.05); }

/* =============================================
   CRAQUES
   ============================================= */
.craques-mini-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
.craque-mini {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: var(--tr);
}
.craque-mini:hover { transform: translateY(-5px); border-color: rgba(255,215,0,.22); box-shadow: 0 10px 28px rgba(0,0,0,.45); }
.craque-mini-img { aspect-ratio: 3/4; background: linear-gradient(160deg, #1d2438, #0e1420); overflow: hidden; }
.craque-mini-img img { width: 100%; height: 100%; object-fit: contain; object-position: top; transition: transform .4s ease; padding: 4px 0 0; }
.craque-mini:hover .craque-mini-img img { transform: scale(1.07); }
.craque-mini-info { padding: 10px 10px 12px; text-align: center; }
.craque-mini-emoji { font-size: 18px; margin-bottom: 4px; }
.craque-mini-name { font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--white); margin-bottom: 2px; }
.craque-mini-flag { font-size: 14px; }

.craques-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.craque-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; cursor: pointer; transition: var(--tr); }
.craque-card:hover { transform: translateY(-5px); border-color: rgba(255,215,0,.2); box-shadow: 0 14px 44px rgba(0,0,0,.55); }
.craque-card-imgs { display: grid; grid-template-columns: repeat(3, 1fr); aspect-ratio: 3/1; background: linear-gradient(160deg, #1d2438, #0e1420); overflow: hidden; }
.craque-card-imgs img { width: 100%; height: 100%; object-fit: contain; object-position: top; transition: transform .4s ease; }
.craque-card:hover .craque-card-imgs img { transform: scale(1.05); }
.craque-card-info { padding: 22px; text-align: center; }
.craque-emoji { font-size: 28px; margin-bottom: 6px; }
.craque-flag  { font-size: 22px; margin-bottom: 8px; }
.craque-name  { font-family: 'Bebas Neue', sans-serif; font-size: 28px; letter-spacing: .04em; color: var(--white); margin-bottom: 4px; }
.craque-count { font-size: 13px; color: var(--muted); margin-bottom: 4px; }

/* =============================================
   RASTREIO PAGE
   ============================================= */
.rastreio-wrap { max-width: 900px; margin: 0 auto; padding: 52px 28px 88px; display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: start; }
.rastreio-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 38px 32px; text-align: center; }
.rastreio-icon { font-size: 48px; margin-bottom: 16px; }
.rastreio-card h2 { font-family: 'Bebas Neue', sans-serif; font-size: 32px; letter-spacing: .04em; margin-bottom: 10px; }
.rastreio-card p { font-size: 14px; color: var(--muted); line-height: 1.75; margin-bottom: 24px; }
.rastreio-input {
  width: 100%;
  background: var(--dark);
  border: 1.5px solid var(--border2);
  border-radius: 10px;
  padding: 14px 16px;
  color: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  outline: none;
  transition: var(--tr);
  text-align: center;
}
.rastreio-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(228,255,0,.08); }
.rastreio-input::placeholder { color: var(--muted2); }
.rastreio-divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; color: var(--muted2); font-size: 13px; }
.rastreio-divider::before, .rastreio-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.btn-whatsapp-full {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%;
  background: #25D366;
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 14px 20px;
  border-radius: 10px;
  transition: var(--tr);
  text-decoration: none;
}
.btn-whatsapp-full:hover { background: #1dba58; transform: translateY(-2px); box-shadow: 0 7px 22px rgba(37,211,102,.3); }
.rastreio-info h3 { font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 24px; }
.rastreio-steps { display: flex; flex-direction: column; gap: 14px; }
.rastreio-step { display: flex; align-items: flex-start; gap: 16px; padding: 16px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); transition: var(--tr); }
.rastreio-step:hover { border-color: var(--border2); }
.rstep-num { width: 32px; height: 32px; background: var(--accent); color: var(--black); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Bebas Neue', sans-serif; font-size: 18px; flex-shrink: 0; }
.rstep-title { font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.rstep-desc { font-size: 13px; color: var(--muted); line-height: 1.65; }

/* =============================================
   BIG PROMO SLIDER
   ============================================= */
.big-promo-slider { position: relative; overflow: hidden; background: var(--black); border-bottom: 1px solid var(--border); user-select: none; }
.big-slider-track { position: relative; }
.big-slide { display: none; position: relative; width: 100%; cursor: pointer; }
.big-slide.active { display: block; animation: bigSlideIn .45s cubic-bezier(.4,0,.2,1); }
@keyframes bigSlideIn { from { opacity: 0; } to { opacity: 1; } }
.big-slide-img { display: block; width: 100%; height: auto; aspect-ratio: 1400 / 500; object-fit: cover; object-position: center; transition: transform .5s ease; }
.big-slide:hover .big-slide-img { transform: scale(1.016); }
.big-slide-placeholder { width: 100%; aspect-ratio: 1400 / 500; background: #0a0e14; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; border: 2px dashed rgba(255,255,255,.08); cursor: pointer; transition: var(--tr); }
.big-slide-placeholder:hover { border-color: rgba(255,255,255,.18); background: #0d1018; }
.big-slide-counter { position: absolute; bottom: 58px; left: 28px; font-family: 'Bebas Neue', sans-serif; font-size: 13px; letter-spacing: .14em; color: rgba(255,255,255,.45); z-index: 5; pointer-events: none; }
.big-slider-arrow { position: absolute; top: calc(50% - 30px); transform: translateY(-50%); z-index: 10; width: 48px; height: 48px; border-radius: 50%; background: rgba(7,9,12,.75); border: 1px solid rgba(255,255,255,.14); color: var(--white); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: var(--tr); backdrop-filter: blur(10px); }
.big-slider-arrow:hover { background: rgba(228,255,0,.16); border-color: rgba(228,255,0,.45); color: var(--accent); }
.big-slider-prev { left: 20px; }
.big-slider-next { right: 20px; }
.big-slider-footer { position: absolute; bottom: 0; left: 0; right: 0; z-index: 10; background: linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 100%); padding: 0 28px; }
.big-slider-dots { max-width: var(--max); margin: 0 auto; display: flex; gap: 4px; padding: 0 68px; }
.big-slider-dot { flex: 1; background: none; border: none; cursor: pointer; padding: 12px 6px 14px; display: flex; flex-direction: column; gap: 5px; align-items: flex-start; transition: var(--tr); min-width: 0; }
.big-dot-label { font-family: 'Oswald', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.38); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; width: 100%; transition: var(--tr); }
.big-slider-dot.active .big-dot-label { color: rgba(255,255,255,.88); }
.big-dot-bar { width: 100%; height: 2px; background: rgba(255,255,255,.14); border-radius: 1px; overflow: hidden; }
.big-dot-fill { height: 100%; width: 0%; background: var(--accent); border-radius: 1px; }
.big-dot-fill.filling { animation: dotFill 6s linear forwards; }
@keyframes dotFill { from { width: 0%; } to { width: 100%; } }

/* ─── TOP SELLER badge ─── */
.prod-topseller-badge { position: absolute; top: 38px; left: 9px; z-index: 3; background: linear-gradient(135deg, #FFD700, #FF8C00); color: #1a0800; font-family: 'Oswald', sans-serif; font-size: 9px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; box-shadow: 0 2px 8px rgba(255,180,0,.4); }

/* =============================================
   ICON CSS
   ============================================= */
.benefit-icon svg,
.benefit-icon {
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
  width: 46px; height: 46px;
  background: rgba(228,255,0,.07);
  border-radius: 11px;
}
.prod-benefit-item .icon svg,
.prod-benefit-item .icon { color: var(--accent); display: flex; align-items: center; }
.value-icon {
  display: flex; align-items: center; justify-content: center;
  width: 58px; height: 58px;
  background: rgba(228,255,0,.07);
  border-radius: 14px;
  margin: 0 auto 18px;
  color: var(--accent);
}
.contact-item-icon { display: flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 10px; background: var(--card2); color: var(--accent); flex-shrink: 0; }
.contact-item-icon svg { color: inherit; }
.rastreio-icon { display: flex; align-items: center; justify-content: center; width: 80px; height: 80px; border-radius: 50%; background: rgba(228,255,0,.06); border: 1px solid rgba(228,255,0,.14); margin: 0 auto 22px; color: var(--accent); }
.cart-empty-icon { display: flex; align-items: center; justify-content: center; margin: 0 auto 22px; color: var(--muted2); }

/* Social buttons */
.social-btn { width: 38px; height: 38px; background: var(--card); border: 1px solid var(--border); border-radius: 9px; display: flex; align-items: center; justify-content: center; color: var(--muted); transition: var(--tr); cursor: pointer; text-decoration: none; }
.social-btn:hover { border-color: var(--accent); color: var(--accent); background: rgba(228,255,0,.07); transform: translateY(-2px) scale(1.1); box-shadow: 0 5px 16px rgba(0,0,0,.4); }
.social-btn[title="Instagram"]:hover { border-color: #E1306C; color: #E1306C; background: rgba(225,48,108,.06); }
.social-btn[title="Facebook"]:hover  { border-color: #1877F2; color: #1877F2; background: rgba(24,119,242,.06); }
.social-btn[title="TikTok"]:hover    { border-color: #ff0050; color: #ff0050; background: rgba(255,0,80,.06); }
.social-btn svg { display: block; }

/* =============================================
   SCROLLBAR
   ============================================= */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--dark); }
::-webkit-scrollbar-thumb { background: var(--card2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--muted2); }

/* Animations */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-up { animation: fadeInUp .5s ease forwards; }

/* =============================================
   SCROLL REVEAL
   ============================================= */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .08s; }
.reveal-delay-2 { transition-delay: .17s; }
.reveal-delay-3 { transition-delay: .26s; }

/* =============================================
   COUNTDOWN COPA 2026
   ============================================= */
.countdown-section { background: var(--black); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 52px 28px; text-align: center; position: relative; overflow: hidden; }
.countdown-section::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 100% at 50% 50%, rgba(228,255,0,.04), transparent); pointer-events: none; }
.countdown-eyebrow { font-family: 'Oswald', sans-serif; font-size: 12px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; display: flex; align-items: center; justify-content: center; gap: 12px; }
.countdown-eyebrow::before, .countdown-eyebrow::after { content: ''; width: 40px; height: 1px; background: linear-gradient(to right, transparent, var(--accent)); }
.countdown-eyebrow::after { background: linear-gradient(to left, transparent, var(--accent)); }
.countdown-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(32px, 4vw, 52px); letter-spacing: .04em; color: var(--white); margin-bottom: 36px; line-height: 1; }
.countdown-title span { color: var(--accent); }
.countdown-digits { display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap; }
.countdown-unit { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.countdown-num { font-family: 'Bebas Neue', sans-serif; font-size: clamp(52px, 7vw, 90px); line-height: 1; color: var(--accent); background: var(--card); border: 1px solid rgba(228,255,0,.18); border-radius: var(--radius); min-width: 112px; padding: 14px 18px; letter-spacing: .04em; position: relative; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.4); }
.countdown-num::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(228,255,0,.04), transparent); pointer-events: none; }
.countdown-lbl { font-family: 'Oswald', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.countdown-sep { font-family: 'Bebas Neue', sans-serif; font-size: 62px; color: var(--muted2); line-height: 1; margin-bottom: 26px; animation: blink 1s ease infinite; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1200px) {
  .products-grid { grid-template-columns: repeat(3, 1fr); }
  .benefits-inner { grid-template-columns: repeat(2, 1fr); }
  .benefit-item:nth-child(2) { border-right: none; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 36px; }
  .craques-mini-grid { grid-template-columns: repeat(3, 1fr); }
  .mega-menu { min-width: 420px; }
}

@media (max-width: 1024px) {
  .cat-grid { grid-template-columns: repeat(3, 1fr); }
  .cat-card:first-child { grid-column: span 3; }
  .hero-content { grid-template-columns: 1fr; gap: 40px; }
  .hero-imgs { display: none; }
  .hero { min-height: auto; }
  .hero-content { padding: 60px 28px; }
  .jogador-banner-inner { grid-template-columns: 1fr; }
  .jogador-banner-imgs { display: none; }
  .craques-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .nav { display: none; }
  .btn-whatsapp { display: none; }
  .hamburger { display: flex; }
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-card:first-child { grid-column: span 2; }
  .benefits-inner { grid-template-columns: 1fr 1fr; }
  .hero-title { font-size: 56px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 28px; }
  .product-detail { grid-template-columns: 1fr; gap: 36px; }
  .gallery { position: static; }
  .offers-inner { grid-template-columns: 1fr; }
  .offer-promo { border-right: none; border-bottom: 1px solid var(--border); }
  .checkout-wrap { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .values-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .craques-mini-grid { grid-template-columns: repeat(2, 1fr); }
  .craques-grid { grid-template-columns: 1fr; }
  .rastreio-wrap { grid-template-columns: 1fr; }
  .countdown-digits { gap: 8px; }
  .countdown-num { min-width: 80px; font-size: 52px; }
  .big-slide-img, .big-slide-placeholder { aspect-ratio: 4 / 3; height: auto; }
  .big-dot-label { display: none; }
  .big-slider-dots { padding: 0 52px; justify-content: center; gap: 8px; }
  .big-slider-dot { flex: 0 0 44px; }
  .big-dot-bar { height: 3px; }
  .big-slider-arrow { width: 38px; height: 38px; }
  .big-slider-prev { left: 10px; }
  .big-slider-next { right: 10px; }
  .big-slide-counter { display: none; }
  .btn-comprar { padding: 13px 12px; font-size: 14px; }
  .card-actions { gap: 6px; }
  .btn-add-cart { padding: 10px 6px; font-size: 11px; }
  .btn-ver-produto { padding: 10px 6px; font-size: 11px; }
  .gallery-thumb { width: 72px; height: 72px; }
  .size-btn { min-width: 48px; height: 48px; font-size: 15px; }
  .cart-badge { width: 22px; height: 22px; font-size: 11px; }
  .section-title-bold { font-size: clamp(26px, 7vw, 36px); }
  .benefit-item { padding: 22px 16px; }
  .benefit-title { font-size: 14px; }
  .benefit-desc { font-size: 11px; }
  .team-badge-item { padding: 8px 10px; min-width: 64px; }
  .team-badge-logo { width: 38px; height: 38px; }
  .team-badge-name { font-size: 9px; }
  .team-badges-inner { padding: 0 16px; }
  .team-badge-logo { width: 40px; height: 40px; }
}

@media (max-width: 480px) {
  .header-inner { padding: 0 16px; height: 62px; }
  .announce-bar { font-size: 11px; }
  .products-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .prod-info { padding: 10px 10px 12px; }
  .prod-name { font-size: 13px; }
  .prod-price { font-size: 19px; }
  .cat-grid { grid-template-columns: 1fr 1fr; padding: 0 16px 40px; }
  .cat-card:first-child { grid-column: span 2; }
  .section { padding: 48px 16px; }
  .footer-top { grid-template-columns: 1fr; padding: 44px 16px 32px; }
  .footer-bottom { padding: 18px 16px; flex-direction: column; align-items: flex-start; gap: 12px; }
  .craques-mini-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .countdown-sep { font-size: 36px; margin-bottom: 18px; }
  .countdown-num { min-width: 64px; font-size: 40px; padding: 8px 10px; }
  .filter-wrap { top: 62px; }
  .filter-bar { padding: 0 16px; }
  .filter-row { padding: 10px 0; gap: 10px; }
  .filter-group-label { display: none; }
  .chip { font-size: 11px; padding: 7px 14px; min-height: 34px; }
  .sort-wrapper { height: 34px; }
  .sort-label { font-size: 11px; }
}

/* =============================================
   CORREÇÕES & MELHORIAS PREMIUM v3
   ============================================= */

/* --- FALLBACK DE IMAGEM --- */
.img-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #12161f 0%, #1a2030 100%);
  z-index: 1;
  color: var(--muted2);
}
.img-fallback-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 16px;
  text-align: center;
}
.img-fallback-text {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 32px;
  letter-spacing: .08em;
  color: rgba(255,255,255,.12);
  line-height: 1;
}
.img-fallback-sub {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  color: rgba(255,255,255,.2);
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* --- PRODUTO SEM IMAGEM: placeholder elegante --- */
.prod-img-wrap {
  background: linear-gradient(145deg, #12161f, #1a2030);
}

/* --- CARD: sombra de entrada mais premium --- */
.product-card {
  will-change: transform;
  contain: layout style;
}

/* --- CARD: brilho no hover --- */
.product-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(228,255,0,.04) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
  z-index: 10;
}
.product-card:hover::after { opacity: 1; }

/* --- NOME DO PRODUTO: mais legível --- */
.prod-name {
  font-weight: 600;
}

/* .btn-comprar: ver definição original acima */

/* .btn-primary: ver definição original acima */

/* --- SECTION TITLE: sublinhado dourado --- */
.section-header .section-title::after,
.section-header .section-title-bold::after {
  content: '';
  display: block;
  width: 36px;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
  margin-top: 8px;
}

/* --- CATEGORIA: hover premium --- */
.cat-card {
  transition: transform .32s cubic-bezier(.4,0,.2,1), box-shadow .32s ease;
}
.cat-card:hover {
  transform: translateY(-6px) scale(1.015);
  box-shadow: 0 24px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(228,255,0,.12);
}

/* --- FOOTER: linha dourada no topo --- */
footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(228,255,0,.35) 50%, transparent 100%);
}
footer { position: relative; overflow: hidden; }

/* --- COUNTDOWN: sombra interna nos números --- */
.countdown-num {
  box-shadow: 0 4px 20px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.06);
}

/* --- DEPOIMENTOS: aspas decorativas --- */
.testimonial-card {
  position: relative;
  overflow: hidden;
}
.testimonial-card::before {
  content: '"';
  position: absolute;
  top: -8px;
  right: 14px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 72px;
  color: rgba(228,255,0,.05);
  line-height: 1;
  pointer-events: none;
}

/* --- BADGE DESCONTO: pulse sutil --- */
@keyframes pulse-disc {
  0%, 100% { box-shadow: 0 0 0 0 rgba(229,57,53,0); }
  50%       { box-shadow: 0 0 0 4px rgba(229,57,53,.18); }
}
.prod-disc-badge {
  animation: pulse-disc 3s ease-in-out infinite;
}

/* chips: ver definição principal acima */

/* --- GALERIA DO PRODUTO: borda sutil --- */
.gallery-main::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius);
  pointer-events: none;
  z-index: 2;
}
.gallery-main { position: relative; border-radius: var(--radius); overflow: hidden; }

/* --- MOBILE: targets de toque maiores --- */
@media (max-width: 768px) {
  .size-btn { min-width: 52px; height: 52px; font-size: 15px; }
  .btn-buy { padding: 18px; font-size: 16px; }
  .btn-wpp-buy { padding: 18px; }
  /* Carrossel mobile: setas fora do card, padding vertical para scale */
  .prod-carousel-wrap { padding: 12px 0 44px; }
  .carousel-item { flex: 0 0 46vw; max-width: 210px; }
  .carousel-arrow {
    top: auto;
    bottom: 0;
    transform: none;
    width: 36px; height: 36px;
    background: var(--card2);
    border-color: var(--border);
  }
  .carousel-arrow:hover { transform: none; }
  .carousel-prev { left: calc(50% - 44px); }
  .carousel-next { right: calc(50% - 44px); }
}

@media (max-width: 480px) {
  .carousel-item { flex: 0 0 44vw; max-width: 190px; }
}

/* --- FOCO VISÍVEL: acessibilidade --- */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* --- SELEÇÃO DE TEXTO --- */
::selection {
  background: rgba(228,255,0,.22);
  color: var(--white);
}

/* --- SCROLLBAR CUSTOM: webkit --- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--dark); }
::-webkit-scrollbar-thumb { background: var(--card2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border2); }

/* Desativa flip hover quando imagem de costas não existe */
.product-card.no-back .prod-img-front,
.product-card.no-back:hover .prod-img-front {
  opacity: 1 !important;
  transform: scale(1) !important;
  z-index: 2;
}
.product-card.no-back:hover .prod-img-front {
  transform: scale(1.04) !important;
}
.product-card.no-back .prod-img-back,
.product-card.no-back:hover .prod-img-back {
  opacity: 0 !important;
  visibility: hidden !important;
  z-index: 1;
}

/* --- TIMES DO CORAÇÃO: botão de nav discreto --- */
.team-nav-btn {
  flex-shrink: 0;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: var(--card2);
  border: 1px solid var(--border);
  color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: var(--tr);
}
.team-nav-btn:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--black);
}

/* =============================================
   🚀 PERFORMANCE OPTIMIZATIONS — Image Loading
   ============================================= */

/* === BLUR-UP / SKELETON LOADING === */
/* Animação de skeleton enquanto imagens lazy carregam */
@keyframes imgSkeleton {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

.prod-img-wrap {
  background: linear-gradient(90deg,
    #141820 25%,
    #1e2433 50%,
    #141820 75%
  );
  background-size: 800px 100%;
  animation: imgSkeleton 1.4s ease-in-out infinite;
  /* Para quando a imagem carrega */
}

/* Remove skeleton quando a imagem está visível */
.prod-img-wrap:has(img.loaded),
.prod-img-wrap:has(.img-fallback) {
  animation: none;
  background: var(--card);
}

/* Fade-in suave nas imagens ao carregar */
.prod-img-front,
.cat-card img,
.craque-mini-img img,
.craque-card-imgs img,
.hero-card img {
  opacity: 0;
  transition: opacity .35s ease, transform .4s ease;
}

.prod-img-front.img-loaded,
.cat-card img.img-loaded,
.craque-mini-img img.img-loaded,
.craque-card-imgs img.img-loaded,
.hero-card img.img-loaded {
  opacity: 1;
}

/* Imgs eager (hero/LCP) sem fade — aparecem imediatamente */
img[loading="eager"] {
  opacity: 1 !important;
  transition: none !important;
}

/* === GALLERY PRINCIPAL — evitar CLS === */
.gallery-main {
  aspect-ratio: 1 / 1;
  background: linear-gradient(135deg, #1a1f2e, #0d1018);
  overflow: hidden;
  position: relative;
}

.gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

/* === BANNER SLIDER — previne CLS === */
.big-promo-slider {
  contain: layout style paint;
}

.big-slide {
  contain: layout style paint;
}

/* === CATEGORY CARDS — previne CLS === */
.cat-card {
  contain: layout style;
}

/* === FONT DISPLAY — evita FOIT === */
@font-face {
  font-display: swap; /* garante texto visível enquanto fonte carrega */
}

/* === CRITICAL RENDERING PATH === */
/* Esconde conteúdo abaixo da dobra até JS carregar (evita FOUC) */
.reveal {
  will-change: opacity, transform;
}

/* === PRINT — não carregar imagens desnecessárias === */
@media print {
  .big-promo-slider,
  .announce-bar,
  .cart-drawer,
  .mobile-nav,
  .toast { display: none !important; }
}

/* === REDUCED MOTION — respeitar preferência do usuário === */
@media (prefers-reduced-motion: reduce) {
  img[loading="lazy"],
  .prod-img-front,
  .cat-card img,
  .craque-mini-img img,
  .hero-card img {
    transition: none !important;
    animation: none !important;
    opacity: 1 !important;
  }

  .prod-carousel,
  .team-badges-carousel {
    scroll-behavior: auto;
  }

  @keyframes imgSkeleton {
    0%, 100% { background-position: 0 0; }
  }
}
