/* index.refactor.css
   Refatorado: duplicatas mescladas, ordem ajustada para preservar overrides finais.
   Mantido comportamento original e todos os valores finais tal como no arquivo enviado.
*/

/* =========================
   Variáveis (merge das duas declarações :root, mantendo valores finais)
   ========================= */
:root{
  --primary: #1E1E2F;
  --accent: #143680;
  --neutral: #F4F4F4;
  --detail: #3E6E8C;
  --glass: rgba(255,255,255,0.06);
  --radius: 12px;
  --transition: 0.22s cubic-bezier(.2,.8,.2,1);
  --max-width: 2500px;

  /* segunda declaração mesclada */
  --page-bg: #484848;
  --small-card-bg: #575757;
  --promo-bg: var(--small-card-bg);
  --product-card-bg: #ffffff;
  --btn-black: #2c2c2c;
  --btn-wapp: #25D366;
  --muted: #424242;
  --shadow-1: 0 8px 20px rgba(16,20,28,0.06);
  --shadow-2: 0 6px 18px rgba(16,20,28,0.05);
}

/* =========================
   Reset mínimo / base
   ========================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Poppins','Inter',system-ui,Arial;
  background:var(--page-bg); /* mantido override final do arquivo */
  color:var(--primary) !important;
}

/* imagens */
img{display:block;max-width:100%;height:auto}

/* =========================
   Header
   ========================= */
.site-header{
  border-radius: 30px;
  position:fixed !important;
  min-width: 90% !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  top:0;
  z-index:80;
  background:linear-gradient(90deg,var(--primary),rgb(30, 30, 47));
  color:#000;
  padding:16px 20px;
  box-shadow:0 6px 20px rgba(16,20,30,0.06);
}
.header-inner{
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.brand{display:flex;align-items:center;gap:12px;cursor: pointer;}
.logo{
  width:48px;height:48px;border-radius:10px;
  display:grid;place-items:center;font-weight:800;color:var(--primary);
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
}
.brand .title{font-weight:700;color:white}
nav.main-nav{display:flex;gap:16px;align-items:center}
nav.main-nav a{
  color:#fff;text-decoration:none;padding:8px 10px;border-radius:8px;font-weight:600;
}
nav.main-nav a:hover{
  background:rgba(255,255,255,0.04);
  transform:translateY(-2px);
  transition:var(--transition);
}

/* smooth scroll fallback for browsers that support it */
html { scroll-behavior: smooth; }

/* active link styles for navbar */
nav.main-nav a.active{
  transform:translateY(-4px);
  position:relative;
  color: #fff;
  font-weight:800;
}
nav.main-nav a.active::after{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -8px;
  height: 3px;
  width: 40%;
  background: linear-gradient(90deg,var(--accent),var(--detail));
  border-radius: 6px;
  box-shadow: 0 6px 14px rgba(243,167,18,0.12);
  transition: width .25s ease;
}
nav.main-nav a:hover::after{ width: 60%; }



/* =========================
   Containers / Grid geral
   ========================= */
.container{margin:0;padding:0}
.market-grid{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:20px;
  align-items:start;
  margin:30px;
}
.products-column{min-width:0}
.promo-column{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:12px;
  /* later overridden by flex-based patch block - mantido abaixo */
}

/* =========================
   HERO (unificado / últimos valores preservados)
   - Observação: havia múltiplas declarações; mantenho a configuração final
   ========================= */
.hero{
  display:grid;
  grid-template-columns: 1fr 420px; /* mantido o último override do arquivo */
  gap:28px;
  align-items:stretch;
  margin:20px 0 22px 0;
}

/* versões locais do hero (left/right/cards/templates) */
.hero-left{
  background-image:url('assets/hero-room.png');
    background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position:relative;
  min-height:380px;
  border-radius:12px;
  overflow:hidden;
  padding:18px;
}
.hero-template{position:absolute;inset:0;padding:18px;pointer-events:none}

.hero-card{
  background:linear-gradient(180deg,#ffffff,var(--neutral));
  border-radius:var(--radius);
  padding:28px;
  box-shadow:0 14px 30px rgba(18,20,28,0.06);
}
.hero-card.small{padding:18px}

.hero-info{
  padding: 20px;
  background-color: #ffffff41;
  position:relative;
  z-index:2;
  max-width:1020px;
  transition:opacity .28s ease, transform .28s ease;
}
.hero-info p{
  padding: 20px;
  font-weight: bold;
  font-size:1.05rem;
  line-height:1.5;
  color:#424242;
  margin-top:12px;
  margin-bottom:20px;
}
.hero-info.hidden{
  opacity:0;transform:translateX(-12px);pointer-events:none;
}

/* mini-catalog / smallcard / swatches (unificadas) */
.mini-catalog{
  background:white;
  border-radius:var(--radius);
  padding:14px;
  box-shadow:0 12px 30px rgba(16,20,28,0.06);
  z-index:3;
  transition:transform .35s cubic-bezier(.2,.9,.2,1), opacity .28s ease;
  display:flex;
  flex-direction:column;
  transform:translateX(20px);
  opacity:0;
}
.mini-catalog[aria-hidden="false"]{transform:translateX(0);opacity:1}

/* smallcard (visível por padrão) */
.smallcard{
  position:relative;
  z-index:2;
  background:linear-gradient(180deg,#fff,#fcfcfc);
  border-radius:10px;
  padding:10px 12px;
  box-shadow:0 6px 18px rgba(16,20,30,0.05);
  transition:opacity .28s ease, transform .28s ease;
}

/* quando testar (modo testing) - mantém comportamento original */
.hero.testing .smallcard{opacity:0;transform:translateY(-6px);pointer-events:none}
.hero.testing .hero-info{opacity:0;transform:translateX(-12px);pointer-events:none}
.hero.testing .mini-catalog{transform:translateX(0);opacity:1}

/* swatches (unificado: versão do hero + versão de produto) */
.swatches{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  /* algumas declarações de estado inicial variavam; mantive comportamento expansível */
  opacity:1;
  max-height:600px;
  overflow:hidden;
  pointer-events:auto;
  transition:opacity .35s ease, max-height .35s ease, transform .35s cubic-bezier(.2,.9,.2,1);
  transform:translateY(0);
}
.swatches.hidden{
  opacity:0;max-height:0;pointer-events:none;transform:translateY(6px);
}

.swatch{
  width:44px;height:44px;border-radius:8px;cursor:pointer;
  border:2px solid rgba(0,0,0,0.06);
  box-shadow:0 6px 16px rgba(16,20,30,0.04);
}
.swatch.active{outline:3px solid rgba(0,0,0,0.06);transform:scale(1.05)}

/* SVG transitions (mantido) */
#roomSvg #wall-left,
#roomSvg #wall-right{transition:fill .35s ease, opacity .25s ease}

/* hero-side / hero-right specifics */
.hero-side{display:flex;flex-direction:column;gap:12px}
.hero-right{display:flex;align-items:center;justify-content:center;min-height:320px}

/* color-fan (imagem + botão central) */
.color-fan{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;box-shadow:0 14px 30px rgba(18,20,28,0.06)}
.color-fan img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;user-select:none}
.color-fan-btn{
  text-decoration:none;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:0;
  padding:24px 46px;width:100%;font-size:2.05rem;font-weight:700;cursor:pointer;box-shadow:0 10px 22px rgba(18,20,28,0.12);
  background-color:#181818;color:#fff;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;z-index:3;display:flex;justify-content:flex-end;
}
.color-fan-btn:hover,.color-fan-btn:focus{transform:translate(-50%,-50%) scale(1.03);box-shadow:0 16px 30px rgba(18,20,28,0.16);outline:none}
.color-fan-btn:focus-visible{outline:3px solid rgba(243,167,18,0.18);outline-offset:4px}

/* =========================
   Produtos / Grid (unificado)
   ========================= */
#produtos{margin:30px}
.products-header{display:flex;gap:12px;align-items:end;justify-content:space-between;margin:18px 0}
.searchbar{display:flex;gap:8px;align-items:center;background:white;padding:8px;border-radius:12px;box-shadow:0 6px 18px rgba(18,20,28,0.04)}
.searchbar input{border:0;outline:none;font-size:.95rem}

.filters{display:flex;gap:8px;align-items:center}
.select,.input{padding:8px 10px;border-radius:10px;border:1px solid #e6e6e6;background:white}

/* products-grid: usei a versão final (auto-fit) para responsividade */
.products-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin-top:12px;
  flex:1 1 auto;
  min-height:0;
}

/* product card (unificado; mantive as últimas sombras e hover) */
.product{
  background:var(--product-card-bg);
  border-radius:12px;
  padding:12px;
  box-shadow:var(--shadow-2);
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:stretch;
  transition:transform .18s ease, box-shadow .18s ease;
  overflow:hidden;
}
.product:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(16,20,28,0.08)}

/* thumb / imagem */
.product .thumb{
  width:100%;
  aspect-ratio:16/12;
  border-radius:10px;
  overflow:hidden;
  background:linear-gradient(180deg,#f6f6f6,#ffffff);
  display:flex;align-items:center;justify-content:center;
}
.product .thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* swatches dentro do produto (versão mais compacta) */
.product .swatches{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.product .swatch{
  width:34px;height:34px;border-radius:8px;border:2px solid rgba(0, 0, 0, 0.815);
  box-shadow:0 6px 16px rgba(30, 16, 16, 0.04);cursor:pointer;flex-shrink:0;
}
.product .swatch.active{border:2px solid rgb(21, 35, 71);}

/* botões de ação */
.btn{background:var(--accent);color:#ffffff;border:0;padding:10px 14px;border-radius:10px;font-weight:700;text-decoration:none;cursor:pointer}
.btn:hover{transform:translateY(-4px);transition:var(--transition)}
.btn.ghost{background-color: #00000042;color:rgb(255, 255, 255);border:1.5px solid rgba(255, 255, 255, 0.822); font-weight: 900;}
.btn.ghost:hover{color: #000; background:rgba(255, 255, 255, 0.041);transform:translateY(-2px);transition:var(--transition);border: 1.5px solid #000}
.btn--test{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;padding:10px 12px;border-radius:10px;background:var(--btn-black);;
  color:#fff;border:none;cursor:pointer;font-weight:600;width:100%;transition:transform .12s ease;
}
.btn--test:active{transform:translateY(1px)}
.btn--zap{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;padding:10px 12px;border-radius:10px;background:var(--btn-wapp);
  color:#fff;border:none;cursor:pointer;font-weight:700;text-decoration:none;width:100%;
}
.btn--zap svg{width:18px;height:18px;display:block}

/* títulos, preço e meta */
.product strong{font-size:1rem;color:#111;display:block;line-height:1.2}
.product .meta{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.product .price{font-weight:700;color:#111}
.product .installment{font-size:.9rem;color:var(--muted)}

/* badges */
.badge{background:rgba(0,0,0,0.06);padding:6px 8px;border-radius:8px;font-weight:600;font-size:.95rem}

/* promoção em produto */
.product.promo{outline:3px solid rgba(243,167,18,0.12);position:relative}
.product.promo .promo-badge{
  position:absolute;top:12px;right:12px;background:var(--accent);color:var(--primary);padding:6px 8px;border-radius:8px;font-weight:800;font-size:.85rem;
}

/* =========================
   Promo / Promo-grid / Promo-sidebar (unificado)
   ========================= */
.promo{margin-top:30px;margin-bottom:30px;display:grid;gap:14px}
.promo .banner{
  background:linear-gradient(90deg,var(--primary),rgba(30,30,47,0.92));
  color:white;border-radius:12px;padding:22px;
}
.promo .small-card{background:white;border-radius:12px;padding:18px;box-shadow:0 8px 20px rgba(18,20,28,0.04)}

.promo-grid{margin:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.promo-card{
  background:white;border-radius:12px;overflow:hidden;box-shadow:0 10px 28px rgba(16,20,28,0.06);
  display:flex;flex-direction:column;transition:transform var(--transition), box-shadow var(--transition);
}
.promo-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(16,20,28,0.10)}
.promo-img{display:flex;justify-content:center;align-items:center;width:120px;height:120px;background-size:cover;background-position:center}
.promo-body{padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.promo-title{font-weight:700;font-size:.98rem;color:var(--primary);margin:0}
.promo-sub{color:#6b6b6b;font-size:.9rem;margin:0}
.price-row{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-top:6px}
.price-old{text-decoration:line-through;color:#9b9b9b;font-weight:600;font-size:.95rem}
.price-new{color:#111;font-weight:800;font-size:1.05rem}
.badge-sale{background:var(--accent);color:#fff;padding:6px 8px;border-radius:8px;font-weight:800;font-size:.85rem}
.promo-actions{display:flex;gap:8px;margin-top:8px}
.promo-actions .btn.ghost{background:transparent;border:1px solid #e6e6e6;color:var(--primary)}

/* promo sidebar (inside promo-column) - visual dark column treatment preserved */
.promo-column{
  /* make entire promo column have same header gradient (patch preserved) */
  background:linear-gradient(90deg,var(--primary),rgba(54, 54, 83, 0.92));
  color:#fff;border-radius:12px;padding:18px;box-shadow:0 12px 30px rgba(0,0,0,0.18);
  flex:0 0 360px;max-width:360px;box-sizing:border-box;
}
.promo-column .promo-banner{background:transparent;color:inherit;padding:0;margin:0 0 8px 0}
.promo-sidebar{display:grid;gap:12px;margin-top:6px}
.promo-sidebar .promo-card{
  background:rgba(255,255,255,0.08);color:#fff;border-radius:10px;padding:12px;display:flex;gap:12px;align-items:center;
  box-shadow:0 8px 22px rgba(0,0,0,0.32);border:1px solid rgba(255,255,255,0.04);
}
.promo-sidebar .promo-card .promo-img{width:76px;height:76px;border-radius:8px;background-size:cover;background-position:center;box-shadow:0 6px 18px rgba(0,0,0,0.4);border:1px solid rgba(255,255,255,0.06)}
.promo-sidebar .promo-card .promo-body,
.promo-sidebar .promo-card .promo-title,
.promo-sidebar .promo-card .promo-sub{color:#fff}
.promo-sidebar .promo-card .price-old{color:rgba(255,255,255,0.6);text-decoration:line-through}
.promo-sidebar .promo-card .price-new{color:#fff;font-weight:800}
.promo-sidebar .promo-card .btn{background:rgba(255,255,255,0.12);color:#fff;border:1px solid rgba(255,255,255,0.08)}
.promo-sidebar .promo-card .btn--zap{background:#25D366;color:#fff;border:none}

/* =========================
   Footer / socials / review
   ========================= */
footer{
  background:rgba(30,30,47,0.92);
  color:white;margin-top:20px;margin-bottom:30px;padding:20px;border-radius:12px;box-shadow:var(--shadow-1);
  display:flex;gap:20px;flex-wrap:wrap;
}
footer>.ft-col:nth-child(3){display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end}
footer>.ft-col:nth-child(2){border-left:1px solid rgba(255,255,255,0.1);border-right:1px solid rgba(255,255,255,0.1)}
footer>.ft-col:nth-child(3) p{width:80%;margin-bottom:20px}
footer>.ft-col:nth-child(3) h4{margin-bottom:7px}
.ft-title-social{text-align:center}
.ft-col{flex:1;min-width:200px}
.ft-col button{
  background:var(--accent);color:var(--primary);border:0;padding:10px 14px;border-radius:10px;font-weight:700;cursor:pointer;margin-bottom:8px;
}
.ft-col button:hover{transform:translateY(-4px);transition:var(--transition)}
.socials{text-align:center;display:flex;gap:8px;justify-content:center}
.socials a{
  display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1.5px solid rgba(16,24,40,0.301);text-decoration:none;color:inherit;
}
.review{display:flex;flex-direction:column;gap:8px}
.review a{
  background:#fff8ed;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,170,38,0.12);text-decoration:none;color:#a45b00;font-weight:600;
}

/* socials cards (unificado) */
.socials{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;margin-top:8px}
.social-link{
  display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;text-decoration:none;color:inherit;
  border:1px solid rgba(16,24,40,0.04);min-width:92px;transition:transform 160ms cubic-bezier(.2,.8,.2,1),box-shadow 160ms;
}
.social-name{font-weight:600;font-size:.95rem;line-height:1;text-align:center}
.social-link svg{display:block;width:28px;height:28px}
.social-link:hover,.social-link:focus{transform:translateY(-4px);box-shadow:0 8px 20px rgba(16,20,28,0.06);border-color:rgba(16,24,40,0.08);outline:none}

/* =========================
   MARKET GRID patches & flex-based adjustments (mantidos)
   ========================= */
/* final patch: tornar .market-grid um flex wrapper conforme seu patch original */
.market-section .market-grid,
.market-grid{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:20px !important;
  align-items:flex-start !important;
  width:calc(100% - 60px);
  margin:30px auto !important;
  box-sizing:border-box;
}
.market-grid .products-column,
.products-column{flex:1 1 0%;min-width:0}
.market-grid .promo-column,
.promo-column{flex:0 0 360px;max-width:360px;box-sizing:border-box;position:relative}

/* stretch vertical behavior preserved */
.market-section .market-grid,
.market-grid{align-items:stretch !important}
.products-column,.promo-column{display:flex;flex-direction:column;height:100%;align-items:stretch}
.products-column > section#produtos{display:flex;flex-direction:column;gap:16px;flex:1 1 auto;min-height:0}
.products-grid{flex:1 1 auto;min-height:0}
.promo-column .promo-sidebar{flex:1 1 auto;min-height:0;overflow:auto;padding-right:6px}

/* =========================
   Paginator (setas + pontos)
   ========================= */
.paginator{display:inline-flex;align-items:center;gap:12px;justify-content:center;user-select:none}
.pager-arrow{
  background:transparent;border:0;font-weight:900;font-size:1.85rem;padding:6px 10px;border-radius:8px;cursor:pointer;color: #a0a0a0;
}
.pager-arrow:disabled{opacity:0.4;cursor:default}
.pager-dots{display:inline-flex;gap:10px;align-items:center;padding:4px 8px}
.pager-dot{
  width:14px;height:14px;border-radius:50%;border:2px solid #000;background:rgba(255,255,255,0.65);padding:0;margin:0;cursor:pointer;box-sizing:border-box;
  transition:transform .12s ease,background .18s ease,box-shadow .12s ease;display:inline-block;
}
.pager-dot:hover,.pager-dot:focus{transform:scale(1.06);outline:none;box-shadow:0 4px 10px rgba(0,0,0,0.12)}
.pager-dot.active{background:rgba(243,167,18,0.92);border-color:rgba(243,167,18,0.92);box-shadow:0 6px 14px rgba(243,167,18,0.12)}
.visually-hidden{
  position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px;
}

/* =========================
   Site-map / map container
   ========================= */
.site-map{
  width:100%;
  padding:18px 12px 36px;
  background:rgba(30,30,47,0.92);
  display:flex;flex-direction:column;gap:12px;align-items:center;box-sizing:border-box;padding-top:50px;
}
.map-inner{
  width:100%;max-width:1200px;height:360px;border-radius:12px;overflow:hidden;box-shadow:0 12px 30px rgba(18,20,28,0.06);
  background:#f4f4f4;filter:grayscale(10%),brightness(55%);
}
.site-map iframe{width:100%;height:100%;border:0;display:block}
.map-actions{width:100%;max-width:1200px;display:flex;gap:12px;align-items:center;justify-content:space-between;padding:0 6px;box-sizing:border-box}
.map-address{font-size:14px;color:#969696}

/* =========================
   Helpers / small utilities
   ========================= */
.muted{color:#bbbbbb}
#produtos-title{color:white;margin-top: 5px;}
.badge{color:var(--primary);padding:6px 8px;border-radius:999px;font-weight:700}
.kpi{display:flex;gap:12px;align-items:center;background:linear-gradient(180deg,#ffffff,var(--neutral));padding:12px 18px;border-radius:var(--radius);box-shadow:0 8px 20px rgba(18,20,28,0.04);margin: 0 auto;height: 30%;}
.kpi .num{font-weight:700;font-size:1.2rem}

/* =========================
   Responsividade (media queries unificadas)
   ========================= */
@media (max-width:1000px){
  .hero{grid-template-columns:1fr}
  .promo{grid-template-columns:1fr}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .promo-grid{grid-template-columns:repeat(2,1fr)}
  .market-grid{display:block !important;width:auto !important;margin:18px}
  .promo-column > .promo-sidebar{position:relative;top:auto}
  .promo-column{padding:14px;border-radius:10px}
}

@media (max-width:980px){
  .hero{grid-template-columns:1fr}
  .hero-right{min-height:260px;margin-top:18px}
}

@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .mini-catalog{order:2;margin-top:12px;width:100%;position:relative;transform:none;opacity:1}
  .map-inner{height:260px}
  .map-actions{flex-direction:column;align-items:flex-start;gap:8px}
}

@media (max-width:600px){
  .products-grid{grid-template-columns:1fr}
  nav.main-nav{display:none}
  .header-inner{gap:8px}
  .promo-grid{grid-template-columns:1fr}
  .product .thumb{height:auto}
}

@media (max-width:480px){
  .product{padding:10px}
  .product .swatch{width:30px;height:30px}
  .btn--test,.btn--zap{padding:10px;font-size:.95rem}
  .socials{gap:8px}
  .social-link{padding:6px 10px;min-width:76px}
  .social-link svg{width:24px;height:24px}
  .pager-dot{width:12px;height:12px;border-width:1.6px}
  .pager-dots{gap:8px}
}
/* esconder comportamento de catálogo interativo (opcional) */

/* =========================
   Ajustes: hamburger + z-index para evitar sumir a navbar
   ========================= */
.site-header{ z-index: 99999 !important; }

/* botão hamburger (visível apenas em <=999px) */
.hamburger-button{
  display:none;
  background:transparent;
  border:0;
  color:#fff;
  font-size:1.25rem;
  padding:8px 10px;
  border-radius:8px;
  cursor:pointer;
  align-items:center;
  justify-content:center;
}

/* painél mobile (off-canvas) - ocupa 1/3 da viewport width */
.mobile-nav-panel{
  position:fixed;
  top:0;
  right:-100%;
  height:100vh;
  width:clamp(23.333vw, 56.666vw, 83.333vw);          /* 1/3 da largura do viewport */
  max-width:420px;
  background:linear-gradient(180deg, rgba(20,20,30,0.98), rgba(28,28,40,0.98));
  color:#fff;
  box-shadow: -12px 0 40px rgba(0,0,0,0.45);
  transition: right .28s ease;
  z-index: 999999;
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap:0;
  overflow:auto;
}

/* quando aberto */
.mobile-nav-panel.open{ right:0; }

/* links em coluna com border separando */
.mobile-nav-panel nav{
  display:flex;
  flex-direction:column;
  gap:0;
  margin:6px 0;
}
.mobile-nav-panel nav a{
  display:block;
  padding:18px 14px;
  text-decoration:none;
  color:inherit;
  font-weight:700;
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition: background .12s ease;
}
.mobile-nav-panel nav a:hover{ background: rgba(255,255,255,0.03); }

/* backdrop para fechar o painel */
.mobile-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  z-index: 999990;
  opacity:0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.mobile-backdrop.open{ opacity:1; pointer-events:auto; }

/* pequena aparência do ícone */
.hamburger-icon{ font-size:1.3rem; line-height:1; }

/* Responsividade: quando viewport <= 999px, escondemos nav desktop e right-actions */
@media (max-width:999px){
  nav.main-nav{ display:none !important; }
  .header-inner > div:last-child{ display:none !important; } /* esconde os botões do lado direito */
  .hamburger-button{ display:inline-flex !important; }
}



/* CONTROL: promotions tab only visible on mobile (<=999px) */
nav.main-nav a[href="#promocoes"], nav.main-nav a.promocoes-link {
  display: none !important;
}

/* Make promo visible only on small screens, and ensure hamburger shows */
@media (max-width:999px){
  nav.main-nav{ display:none !important; }
  .header-inner > div:last-child{ display:none !important; } /* esconde os botões do lado direito */
  .hamburger-button{ display:inline-flex !important; }
  nav.main-nav a[href="#promocoes"], nav.main-nav a.promocoes-link {
    display: inline-flex !important;
  }
}
.google-btn {
  display: inline-block;
  background-color: #4285F4; /* azul Google */
  color: white;
  padding: 10px 20px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: bold;
  transition: background 0.2s;
}

.google-btn:hover {
  background-color: #3367D6;
}
/* ---------- Patch: promo acima dos produtos + clamp responsivo (<=1200px) ---------- */
@media (max-width:1200px) {
  /* torne o layout vertical e garanta largura adequada */
  .market-grid {
    flex-direction: column;
    gap: clamp(12px, 2vw, 24px);
    width: calc(100% - 40px);
    margin: 18px auto;
    align-items: stretch;
  }

  /* promo vira linha completa e aparece acima */
  .promo-column {
    order: -1;                /* mostra promo antes dos produtos */
    flex: 0 0 auto;
    min-width: 100%;
    max-width: none;
    box-sizing: border-box;
    padding: clamp(12px, 2vw, 20px);
    border-radius: 12px;
    /* manter visual (gradient já vem do CSS base) */
    background-clip: padding-box;
  }

  /* transformamos a área de cards de promo em row rolável */
  .promo-sidebar {
    display: flex;
    flex-direction: row;
    gap: clamp(10px, 1.5vw, 18px);
    overflow-x: auto;
    padding: 8px 6px;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    align-items: stretch;
  }
  .promo-sidebar::-webkit-scrollbar { height: 10px; }
  .promo-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 8px; }

  /* cada promo-card vira um item em linha com largura responsiva usando clamp */
  .promo-sidebar .promo-card {
    flex: 0 0 auto;
    width: clamp(220px, 36%, 320px);  /* mínimo 220, ideal 36% da viewport, máximo 320 */
    scroll-snap-align: center;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-sizing: border-box;
  }

  /* garantir que a coluna de produtos ocupe 100% da largura */
  .products-column {
    order: 0;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  /* ajustar grid dos produtos para usar clamp no min do minmax */
  .products-grid{
    grid-template-columns: repeat(auto-fit, minmax(clamp(180px, 22vw, 300px), 1fr));
    gap: clamp(10px, 1.6vw, 20px);
  }

  /* botões e CTAs responsivos (ex.: tamanho dos botões do color-fan) */
  .color-fan-btn {
    font-size: clamp(16px, 2.2vw, 28px);
    padding: clamp(10px, 1.8vw, 28px) clamp(18px, 3vw, 40px);
  }
}

@media (max-width: 999px) {
  .color-fan-btn{
    align-items: center;
  height:clamp(10px, 120px, 300px);
  font-size: clamp(18px, 28px, 40px);
}
.Observação{
  display: flex;
  font-size: clamp(14px, 18px, 22px) !important;
  width: 90% !important;
  margin: 0 !important;
  position: relative !important;  
  left: 50% !important;
  transform: translateX(-50%) !important;
  flex-direction: column;
  text-align: center;
}
}
@media (max-width: 730px) {
  .color-fan-btn{
    align-items: center;
  height:clamp(50px, 100px, 200px);
  font-size: clamp(18px, 28px, 40px);
}
}
@media (max-width: 680px) {
footer{
font-size: clamp(12px, 16px, 20px) !important;
}
footer >.ft-col:nth-child(3) {
  align-items: start !important;
  }
.promo-card{
  width: clamp(20%, 50%, 100%) !important; 
  height: clamp(80%, 90%, 100%) !important;
}
}
@media (max-width: 600px) {
  .color-fan-btn{
    height:clamp(40px, 80px, 140px);
 font-size:clamp(15px, 25px, 35px);
}
.Observação{
  font-size: clamp(9px, 14px, 19px) !important;
}
}
@media (max-width: 460px) {
footer >.ft-col:nth-child(2){
  display: flex !important;
  flex-direction: row !important;
  padding: 10px;
  width: 100% !important;
  flex: none !important;
  border-left: none !important;
  border-right: none !important;
  border-top: 1.5px solid rgba(255,255,255,0.1) !important;
  border-bottom: 1.5px solid rgba(255,255,255,0.1) !important;
  padding-left: 0 !important;
}
.ft-title-social{
  display: none !important;
}
a.social-link{
  padding: 0 !important;
  padding-right: 10px !important;
}
}
@media (max-width: 450px) {
  .color-fan-btn{
 height:clamp(25px, 55px, 135px);
  font-size:clamp(15px, 20px, 30px);
}
@media (max-width: 339px){
  .color-fan-btn{
    height:clamp(20px, 50px, 130px);
    font-size:clamp(13px, 18px, 22px);
  }
}
}
@media (max-width: 530px) {
  .products-header{
    display: flex;
    gap: 12px;            /* espaço entre itens */
    overflow-x: auto;
    flex-wrap: nowrap;    /* força uma linha só */
    -webkit-overflow-scrolling: touch;
    padding-bottom: 15px;  /* evita cortar sombras/bordas do conteúdo */
  }

  .products-header > * {
    flex: 0 0 auto;       /* itens não encolhem, mantêm tamanho próprio */
  }
}

.products-header::-webkit-scrollbar { height: 8px; }
.products-header::-webkit-scrollbar-thumb { border-radius: 999px; background: rgba(224, 224, 224, 0.2); }
/* RESPONSIVIDADE: regras para width <= 750px */
@media (max-width: 750px) {
  :root{
    /* controles globais — ajuste se quiser */
    --hero-min-w: 280px;
    --hero-max-w: 100%;
    --hero-w-vw: 88vw;
  }

  /* container geral do hero */
  .hero-info {
    width: clamp(var(--hero-min-w), var(--hero-w-vw), var(--hero-max-w)) !important;
    min-width: unset !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: clamp(12px, 4vw, 28px) !important;
    gap: clamp(8px, 2.5vw, 20px) !important;
    min-height: clamp(200px, 35vh, 420px) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
  }

  /* título principal */
  #hero-title {
    text-align: center !important;
    align-items: center !important;
    font-size: clamp(18px, 5.2vw, 28px) !important;
    font-weight: 600 !important; /* não é possível usar vw dentro do clamp() para font-weight; usar número fixo */
    line-height: clamp(1.05, 1.08, 1.2) !important;
    margin: 0 0 clamp(8px, 2vw, 14px) 0 !important;
    padding-left: 0 !important; /* evita overflow em telas pequenas — ajuste se preferir */
    word-break: break-word !important;
  }

  /* parágrafo do hero */
  .hero-info p {
    font-size: clamp(12px, 3.6vw, 16px) !important;
    font-weight: 400 !important;
    margin: 0 0 clamp(10px, 2.5vw, 16px) 0 !important;
    color: #333 !important;
    max-width: 100% !important;
  }

  /* container dos CTAs: transforma em coluna em mobile */
  .hero-cta {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: clamp(8px, 2.6vw, 18px) !important;
    width: 100% !important;
    padding-left: 0 !important;
  }

  /* KPI (números) */
  .kpi {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: clamp(8px, 2.5vw, 12px) !important;
    margin: 0 0 clamp(6px, 1.6vw, 10px) 0 !important;
  }

  .kpi .num {
    font-size: clamp(18px, 5.6vw, 28px) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    display: inline-block !important;
  }

  .kpi .muted {
    font-size: clamp(11px, 3.2vw, 13px) !important;
    color: rgb(48,48,48) !important;
    opacity: 0.95 !important;
    display: inline-block !important;
  }

  /* botões — full width, espacamento e tipografia responsiva */
  .btn {
    width: 100% !important;
    display: inline-flex !important;
    justify-content: start !important;
    align-items: center !important;
    padding: clamp(8px, 2.8vw, 12px) clamp(12px, 4vw, 18px) !important;
    font-size: clamp(13px, 3.6vw, 16px) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border-radius: clamp(6px, 2.2vw, 10px) !important;
    box-sizing: border-box !important;
    gap: clamp(8px, 2.5vw, 12px) !important;
    margin: 0 !important;
  }

  #heroInfo .btn.ghost {
    border: 1px solid rgba(0,0,0,0.08) !important;
  }

  .hero-cta .btn + .btn {
    margin-top: clamp(6px, 2vw, 12px) !important;
  }

  /* pequenas garantias para evitar overflow horizonal */
  .hero-info, .hero-info * {
    max-width: 100% !important;
  }

  /* ajustes finos em casos extremos (telinhas muito estreitas) */
  @media (max-width: 420px) {
    #hero-title { font-size: clamp(16px, 6.5vw, 20px) !important; }
    .kpi .num { font-size: clamp(16px, 7vw, 20px) !important; }
    .hero-info { padding: clamp(10px, 6vw, 16px) !important; }
  }
}


/* GRID / LAYOUT */
.kpi-grid{
  display: flex;
  gap: clamp(10px, 2.2vw, 18px);
  align-items: center;
  flex-wrap: wrap;
}

/* cada card (link) */
.kpi-card{
  display: inline-flex;
  gap: 12px;
  align-items: center;
  text-decoration: none;
  padding: clamp(6px, 1.1vw, 10px);
  border-radius: 12px;
  min-width: 160px;
  flex: 1 1 200px;
  background: transparent;
  color: inherit;
  transition: transform .12s ease, box-shadow .12s ease;
}

/* foco acessível */
.kpi-card:focus-visible{
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, white);
  transform: translateY(-2px);
}

/* círculo do ícone (pequeno, com cor principal) */
.kpi-icon-circle{
  width: clamp(36px, 6vw, 48px);
  height: clamp(36px, 6vw, 48px);
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: var(--accent);
  box-shadow: 0 2px 6px rgba(0,0,0,0.06);
}

/* imagem interna */
.kpi-img{
  width: 58%;
  height: 58%;
  object-fit: contain;
  display: block;
  /* filtro recomendado se sua imagem for ícone escuro (transforma em branco sobre o fundo accent).
     Se seu asset já for branco/transparente, remova essa linha. */
  filter: brightness(0) invert(1);
}

/* texto - usar MESMA fonte/estilo para ambas as frases */
.kpi-text{
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--text);
}

/* sem diferenciação de font/title/subtitle — tudo igual */
.kpi-line{
  font-size: clamp(14px, 2.3vw, 17px);
  line-height: 1.05;
  font-weight: 700; /* ajuste para o peso que sua tipografia usa no site */
  color: var(--text);
}

/* hover pequeno */
.kpi-card:hover{
  transform: translateY(-3px);
}

/* mobile: ocupar toda largura disponível */
@media (max-width: 580px){
  .kpi-grid{
    gap: 10px;
  }
  .kpi-card{
    width: 100%;
    justify-content: flex-start;
  }
  .kpi-line{
    font-size: 14px;
  }
}
