/* ============================================================
   Dermachem Laboratory — Clone Mobile-First
   Todas as variáveis extraídas do source real do site
   ============================================================ */

/* ============================================================
   1. CSS CUSTOM PROPERTIES (variáveis reais do site)
   ============================================================ */
:root {
  --cFundo: #ffffff;
  --cBotoes: #ff1a87;
  --cBotoesTxt: #ffffff;
  --cTitulos: #3a3a3a;
  --cBarra: #ffffff;
  --cBarraTxt: #3a3a3a;
  --cCab: #ffffff;
  --cCabIcones: #3a3a3a;
  --cMenu: #ffffff;
  --cMenuTxt: #3a3a3a;
  --cPreco: #3a3a3a;
  --cPix: #f3f6f4;
  --cPixIcone: #ff1a87;
  --cBandeiraDesconto: #3a3a3a;
  --cBandeiraDescontoTxt: #ffffff;
  --cBandeiraFrete: #199a64;
  --cRodape: #ffffff;
  --cRodapeTxt: #3a3a3a;
  --cBusca: #f0f0f0;
  --cBuscaTxt: #808080;
  --cCarrinhoqtd: #ff1a87;
  --cCarrinhoqtdn: #ffffff;

  /* Aliases internos */
  --cor-principal: #ff1a87;
  --cor-principal-hover: #e50469;
  --cor-secundaria: #3a3a3a;
  --cor-texto: #3a3a3a;
  --cor-texto-suave: #666666;
  --cor-texto-claro: #999999;
  --cor-borda: #e5e5e5;
  --cor-fundo-cinza: #f5f5f5;
  --cor-estrela: #f4a308;
  --cor-sucesso: #27bf64;
  --cor-erro: #e53e3e;

  --fonte: 'Rubik', sans-serif;

  --radius: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.10);
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ANTIOVERFLOW — raiz do problema de scroll lateral */
html {
  font-size: 15px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--fonte);
  color: var(--cor-texto);
  background: var(--cFundo);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;        /* dupla proteção */
  width: 100%;
  min-width: 0;
}

/* Garante que NADA estoure a largura do viewport */
img    { max-width: 100%; width: 100%; display: block; height: auto; }
video  { max-width: 100%; }
table  { table-layout: fixed; width: 100%; }
input, select, textarea { font-family: var(--fonte); max-width: 100%; }

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; font-family: var(--fonte); border: none; background: none; }

/* Logo e ícones não devem esticar */
.cabecalho__logo img,
.rodape-logo img,
.footer-logo,
.pix-logo,
.parcelas-toggle img,
.gateway-logo,
.trusvox-logo { width: auto; max-width: 100%; }

.titulo { font-family: var(--fonte); font-weight: 700; }
.cor-principal { color: var(--cor-principal) !important; }
.cor-secundaria { color: var(--cor-secundaria) !important; }

/* ============================================================
   3. CONTAINER
   ============================================================ */
.container {
  width: 100%;
  padding: 0 16px;
  /* SEM max-width aqui — cada seção que precisar limitar define o seu */
}

/* ============================================================
   4. BOTÕES
   ============================================================ */
.botao {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px 20px;
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-weight: 600;
  font-family: var(--fonte);
  border: none;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
  -webkit-tap-highlight-color: transparent;
}
.botao:active { transform: scale(0.97); }
.botao.principal { background: var(--cBotoes); color: var(--cBotoesTxt); }
.botao.principal:active { background: var(--cor-principal-hover); }
.botao.grande { padding: 16px 14px; font-size: 18px; width: 100%; border-radius: 6px; }

/* ============================================================
   5. BARRA INICIAL (redes sociais + telefone)
      No mobile, fica compacta com apenas o telefone
   ============================================================ */
.barra-inicial {
  background: var(--cBarra);
  border-bottom: 1px solid var(--cor-borda);
  padding: 6px 0;
}
.barra-inicial__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.barra-redes { display: none; } /* Oculto no mobile */
.barra-canais {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  justify-content: space-between;
}
.barra-canais li {
  font-size: 0.72rem;
  color: var(--cBarraTxt);
}
.barra-canais a { transition: color 0.2s; }
.barra-canais a:hover { color: var(--cor-principal); }
.barra-canais i { margin-right: 3px; font-size: 0.7rem; }

/* ============================================================
   6. BARRA DE ANÚNCIO
   ============================================================ */

.barra-anuncio {
  background: #5EA3DC;
  padding: 7px 16px;
  text-align: center;
}
.anuncio-txt {
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
}
.anuncio-txt strong {
  font-weight: 700;
}

/* ============================================================
   7. CABEÇALHO MOBILE
   ============================================================ */
#cabecalho {
  background: var(--cCab);
  border-bottom: 1px solid var(--cor-borda);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--shadow-sm);
  width: 100%;          /* nunca maior que a tela */
  overflow: hidden;
}
.cabecalho__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 15px;
  gap: 8px;
  width: 100%;
  min-width: 0;
  position: relative;
}

/* Grupo esquerdo: hamburger + ícone busca */
.cabecalho__esquerda {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

/* Hamburger */
.btn-hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.btn-hamburger svg {
  width: 22px;
  height: 22px;
  fill: var(--cCabIcones);
}

/* Logo centralizado — absolutamente no centro da tela */
.cabecalho__logo {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  pointer-events: none;
}
.cabecalho__logo a {
  pointer-events: auto;
}
.cabecalho__logo img {
  height: 38px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
}

/* Busca — oculta no mobile (vira ícone) */
.cabecalho__busca { display: none; }

/* Ações — espelha a esquerda para manter logo no centro */
.cabecalho__acoes {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  flex: 1;              /* ocupa metade — espelha .cabecalho__esquerda */
}
.acao-conta, .acao-pedidos { display: none; } /* Ocultos no mobile */
.acao-carrinho {
  position: relative;
  display: flex;
  align-items: center;
  -webkit-tap-highlight-color: transparent;
}
.icone-carrinho {
  display: flex;
  align-items: center;
}
.icone-carrinho svg {
  width: 28px;
  height: 28px;
  fill: var(--cCabIcones);
}
.carrinho-qtd {
  position: absolute;
  top: -5px;
  right: -7px;
  background: var(--cCarrinhoqtd);
  color: var(--cCarrinhoqtdn);
  font-size: 0.55rem;
  font-weight: 700;
  min-width: 15px;
  height: 15px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
}

/* Ícone busca mobile */
.acao-busca {
  display: flex;
  align-items: center;
  -webkit-tap-highlight-color: transparent;
}
.acao-busca svg {
  width: 22px;
  height: 22px;
  fill: var(--cCabIcones);
}

/* ============================================================
   7. MENU MOBILE (drawer vertical)
   ============================================================ */
.menu-superior {
  display: none;
  background: var(--cMenu);
  border-bottom: 1px solid var(--cor-borda);
}
.menu-superior.aberto { display: block; }

.menu-lista { flex-direction: column; }
.menu-lista > li {
  border-bottom: 1px solid var(--cor-borda);
}
.menu-lista > li > a {
  display: block;
  padding: 13px 16px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--cMenuTxt);
  -webkit-tap-highlight-color: transparent;
}
.menu-lista > li > a:active { background: var(--cor-fundo-cinza); color: var(--cor-principal); }

/* ============================================================
   8. BARRA DE BUSCA EXPANDÍVEL (mobile)
   ============================================================ */
.busca-mobile {
  display: none;
  background: var(--cor-fundo-cinza);
  padding: 10px 16px;
  border-bottom: 1px solid var(--cor-borda);
}
.busca-mobile.aberta { display: block; }
.busca-mobile form {
  display: flex;
  background: var(--cFundo);
  border: 1px solid var(--cor-borda);
  border-radius: 50px;
  overflow: hidden;
}
.busca-mobile input {
  flex: 1;
  padding: 9px 14px;
  border: none;
  outline: none;
  font-size: 0.875rem;
  background: transparent;
}
.busca-mobile button {
  padding: 0 14px;
  color: var(--cBuscaTxt);
  font-size: 0.85rem;
}

/* ============================================================
   9. BREADCRUMB
   ============================================================ */
.breadcrumb-nav {
  background: var(--cor-fundo-cinza);
  border-bottom: 1px solid var(--cor-borda);
  padding: 8px 0;
}
.breadcrumb-lista {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  color: var(--cor-texto-claro);
}
.breadcrumb-lista li:not(:last-child)::after {
  content: '›';
  margin-left: 4px;
  color: var(--cor-texto-claro);
}
/* No mobile, esconde itens intermediários do breadcrumb */
.breadcrumb-lista li:not(:first-child):not(:last-child) { display: none; }
.breadcrumb-lista li:not(:last-child):first-child::after { content: '›'; margin-left: 4px; }
.breadcrumb-lista a { color: var(--cor-principal); }
.breadcrumb-lista [aria-current="page"] {
  color: var(--cor-texto);
  font-size: 0.7rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 200px;
}

/* ============================================================
   10. PÁGINA PRODUTO — Layout mobile (tudo em coluna)
   ============================================================ */
.pagina-produto { padding-bottom: 40px; /* espaço para botão fixo */ }

/* Grid: coluna única no mobile */
.produto-grid {
  display: flex;
  flex-direction: column;
}

/* ============================================================
   11. GALERIA DE IMAGENS (mobile)
   ============================================================ */
.produto-imagens {
  display: flex;
  flex-direction: column;
  width: 100%;
  overflow: hidden;     /* sem overflow para fora */
}

/* Imagem principal — 100% da largura disponível */
.conteiner-imagem {
  position: relative;
  background: #fff;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: clip;
  text-align: center;
}
.conteiner-imagem #imagemProduto {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 0.15s, transform 0.15s;
  display: block;
  cursor: zoom-in;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  vertical-align: bottom;
}

.galeria-seta {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: rgba(255,255,255,0.85);
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  transition: background 0.15s, opacity 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.galeria-seta:hover { background: #fff; }
.galeria-seta svg { width: 18px; height: 18px; color: #333; }
.galeria-seta--prev { left: 8px; }
.galeria-seta--next { right: 8px; }
.galeria-seta[disabled] { opacity: 0.25; pointer-events: none; }

/* Thumbnails — scroll INTERNO, não vaza para fora */
.thumbs-vertical {
  order: 2;
  width: 100%;
  overflow: hidden;     /* contém o scroll filho */
}
.produto-thumbs {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  list-style: none;
  margin: 0;
  background: var(--cFundo);
}

.thumb {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ccc;
  border: none;
  padding: 0;
  flex-shrink: 0;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.thumb:hover { background: #aaa; }
.thumb--ativo {
  background: var(--cor-principal);
  transform: scale(1.3);
}

/* ============================================================
   11b. PRODUTO SHARE
   ============================================================ */
.produto-share {
  order: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 16px 6px;
  background: var(--cFundo);
}

.produto-share__row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.produto-share__label {
  font-size: 13px;
  color: #444;
  white-space: nowrap;
  font-weight: 600;
}

.produto-share__icons {
  display: flex;
  align-items: center;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.produto-share__link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: opacity 0.2s;
}
.produto-share__link:hover { opacity: 0.7; }

.produto-share__link svg {
  width: 14px;
  height: 14px;
  fill: #B9B9B9;
  transition: fill 0.2s;
}
.produto-share__link:hover svg { fill: #888; }

.produto-share__desejos {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  color: #555;
  padding: 2px 0;
  white-space: nowrap;
  transition: color 0.2s;
}
.produto-share__desejos:hover { color: #e53e3e; }

.produto-share__desejos svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: #888;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: fill 0.2s, stroke 0.2s;
}
.produto-share__desejos:hover svg {
  fill: #e53e3e;
  stroke: #e53e3e;
}
.produto-share__desejos.ativo svg {
  fill: #e53e3e;
  stroke: #e53e3e;
}

/* ============================================================
   12. INFORMAÇÕES DO PRODUTO (mobile)
   ============================================================ */
.produto-info {
  display: flex;
  flex-direction: column;
  padding: 6px 16px 0;
  gap: 14px;
}

/* Info principal */
.info-principal-produto {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
}

.marca-produto {
  font-size: 14px;
  font-family: 'Rubik', sans-serif;
  color: #949494;
}
.marca-produto a {
  color: #949494;
  text-decoration: none;
}
.marca-produto a:hover { text-decoration: underline; }

.nome-produto {
  font-size: 18px;
  font-weight: 700;
  color: var(--cor-texto);
  line-height: 1.35;
}

.codigo-produto {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--cor-texto-suave);
}

/* Mini avaliação */
.produto-avaliacao-mini {
  display: flex;
  align-items: center;
  gap: 4px;
}
.avaliacao-link {
  display: flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
}
.ts-shelf-rate {
  display: flex;
  gap: 2px;
}
.ts-shelf-rate svg {
  width: 17px;
  height: 17px;
  fill: #ffb500;
}
.ts-shelf-rate-count {
  font-size: 13px;
  color: #888;
  margin-left: 4px;
  font-weight: 400;
}

/* ============================================================
   13. PREÇOS (mobile)
   ============================================================ */
.precos-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
}
.precos-wrap .desconto-a-vista,
.precos-wrap .parcelamento-full {
  width: 100%;
  text-align: left;
}
.precos-wrap .mais-formas {
  justify-content: center;
}
.precos-wrap .comprar {
  width: 100%;
}

.preco-produto {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 12px 16px 16px;
  border-top: 1px solid #e8e8e8;
  border-bottom: 1px solid #e8e8e8;
  width: 100%;
}

/* Linha dupla: riscado + promocional */
.preco-linha-dupla {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.preco-venda {
  font-size: 13px;
  color: #999;
  text-decoration: line-through;
  font-weight: 400;
  margin-bottom: -4px;
}
.preco-promocional {
  font-size: 27px;
  font-weight: 700;
  line-height: 1;
  color: #3a3a3a;
}

.preco-parcela {
  font-size: 15px;
  color: var(--cor-texto-suave);
  margin-top: -4px;
}
.preco-parcela strong { color: var(--cor-texto); font-weight: 600; }

/* Bloco pix avista */
.desconto-a-vista {
  background: var(--cPix);
  border-radius: var(--radius);
  padding: 8px 12px;
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 8px;
}
.pp-avista {
  display: flex;
  align-items: center;
  gap: 10px;
}
.listagem-avista-1 svg {
  width: 17px;
  height: 17px;
  fill: var(--cor-principal);
  flex-shrink: 0;
  display: block;
}
.listagem-avista-2 {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 15px;
  color: #888;
}
.avista-strong {
  font-weight: 700;
  color: var(--cor-principal);
}
.avista-resto {
  color: #888;
}

/* Accordion mais formas */
#wrapParcelas {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s ease;
}

.mais-formas svg {
  transition: transform 0.3s ease;
}
.mais-formas.aberto svg {
  transform: rotate(180deg);
}

.parcelas-produto.padrao { font-size: 0.8rem; }
.accordion { list-style: none; padding: 0; margin: 0; }
.accordion-group {
  border: 1px solid var(--cor-borda);
  overflow: hidden;
  margin-top: 6px;
  border-radius: var(--radius);
}
.accordion-heading .accordion-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px;
  background: var(--cor-fundo-cinza);
  text-decoration: none;
  cursor: pointer;
  width: 100%;
  box-sizing: border-box;
}
.accordion-heading img { height: 22px; width: auto; }
.text-parcelas { font-size: 0.75rem; color: var(--cor-texto-suave); }
.pull-right { margin-left: auto; }
.accordion-body.collapse.in { display: block; }
.accordion-inner {
  display: flex;
  gap: 4px;
  padding: 8px 10px;
  border-top: 1px solid var(--cor-borda);
}
.accordion-inner ul { list-style: none; padding: 0; margin: 0; flex: 1; display: flex; flex-direction: column; gap: 2px; }
.accordion-inner li { font-size: 0.78rem; color: var(--cor-texto-suave); }
.accordion-inner b { color: var(--cor-texto); font-weight: 700; margin-right: 2px; }

.accordion-group--pix .accordion-toggle { background: #fff; }
.pix-parcela-valor { color: var(--cor-texto); font-size: 0.9rem; }
.img-parcelas-proxy-pagali-v2-pix { height: 22px; width: auto; }
.pix-logo { height: 20px; width: auto; }

/* Mais formas de pagamento */
.parcelamento-full { margin-top: 2px; }
.mais-formas {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--cor-texto-suave);
  text-decoration: underline;
  cursor: pointer;
  padding: 4px 0;
}
.mais-formas svg { fill: var(--cor-texto-suave); flex-shrink: 0; }
.mais-formas:hover { color: var(--cor-texto); }
.mais-formas:hover svg { fill: var(--cor-texto); }

.parcelas-lista-full {
  list-style: none;
  padding: 8px 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.8rem;
  color: var(--cor-texto-suave);
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius);
  padding: 8px 12px;
}
.parcelas-lista-full b { color: var(--cor-principal); margin-right: 4px; }
.parcelas-lista-full span { color: var(--cor-sucesso); font-size: 0.75rem; margin-left: 4px; }

.pix-linha-full {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border: 1px solid var(--cor-borda);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
}
.pix-logo { height: 20px; width: auto; }
.pix-linha-full b { color: var(--cor-principal); font-size: 0.95rem; }

/* ============================================================
   14. CALCULADORA DE FRETE (mobile)
   ============================================================ */
.cep {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  text-align: left;
  background: var(--cor-fundo-cinza);
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.cep form {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
}
.cep-label {
  font-size: 14px;
  font-weight: 600;
  color: rgb(32, 31, 31);
  font-family: var(--fonte);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
}
.cep-label i { color: var(--cor-principal); font-size: 13px; }
.cep-link-nao-sei {
  font-size: 0.75rem;
  color: var(--cor-texto-suave);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  transition: color 0.15s;
}
.cep-link-nao-sei:hover { color: var(--cor-principal); }
.form-inline { width: 100%; }
.input-append.input-prepend {
  display: flex;
  width: 100%;
  border: 1px solid #ccc;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
}
.input-cep {
  flex: 1;
  padding: 10px 14px;
  border: none;
  font-size: 14px;
  outline: none;
  background: transparent;
  font-family: var(--fonte);
  color: #aaa;
  -webkit-appearance: none;
}
.input-cep:focus { color: rgb(32, 31, 31); }
.botao-cep {
  padding: 10px 18px;
  background: transparent;
  border: none;
  border-left: 1px solid #ccc;
  color: #3a3a3a !important;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--fonte);
  white-space: nowrap;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.botao-cep:hover { color: #3a3a3a !important; opacity: 0.7; }
.cep-resultado {
  margin-top: 12px;
  width: 100%;
  animation: cepFadeIn 0.3s ease;
}
@keyframes cepFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cep-resultado--error { font-size: 0.8rem; color: var(--cor-erro); line-height: 1.6; }
.cep-opcoes { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--cor-borda); width: 100%; }
.cep-opcoes li { display: flex; flex-direction: column; gap: 2px; padding: 10px 0; border-bottom: 1px solid var(--cor-borda); }
.cep-linha-topo { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; width: 100%; }
.cep-opcoes .nome { color: #3a3a3a; font-weight: 600; font-size: 0.87rem; line-height: 1.3; }
.cep-opcoes .prazo { color: var(--cor-texto-suave); font-size: 0.78rem; font-weight: 400; line-height: 1.3; text-align: left; }
.cep-opcoes .valor { font-weight: 700; color: #3a3a3a; white-space: nowrap; flex-shrink: 0; font-size: 0.87rem; }
.cep-opcoes .valor.gratis { color: var(--cor-principal); }
.aviso-disponibilidade { font-size: 0.72rem; color: var(--cor-texto-claro); margin-top: 8px; line-height: 1.4; }

/* Endereço do CEP */
.cep-endereco {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: var(--cor-texto-suave);
  padding: 8px 0 6px;
  border-bottom: 1px solid var(--cor-borda);
  margin-bottom: 2px;
}
.cep-endereco i { color: var(--cor-principal); font-size: 0.85rem; flex-shrink: 0; }

/* Loading — texto + dots */
.cep-loading {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--cor-texto-suave);
  padding: 10px 0;
}
.cep-dots { display: flex; gap: 4px; }
.cep-dots span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cor-principal);
  animation: cepPulse 1s infinite ease-in-out;
}
.cep-dots span:nth-child(2) { animation-delay: 0.2s; }
.cep-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes cepPulse {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40% { transform: scale(1); opacity: 1; }
}

/* Spinner no botão durante loading */
.cep-spinner {
  display: inline-block;
  width: 14px; height: 14px;
  border: 2px solid rgba(58,58,58,0.2);
  border-top-color: #3a3a3a;
  border-radius: 50%;
  animation: cepSpin 0.7s linear infinite;
  vertical-align: middle;
}
@keyframes cepSpin { to { transform: rotate(360deg); } }

/* ============================================================
   15. QUANTIDADE E BOTÃO COMPRAR (mobile — botão fixo no rodapé)
   ============================================================ */

/* Controle inline de quantidade */
.comprar {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 14px;
}

/* Selos de confiança */
.selos-confianca {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px 0;
  align-items: center;
  text-align: center;
  width: 100%;
}
.selo-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  width: 100%;
}
.selo-icone {
  flex-shrink: 0;
  color: #aaa;
  margin-top: 1px;
}
.selo-titulo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: #3a3a3a;
  line-height: 1.3;
}
.selo-desc {
  font-size: 12px;
  color: #888;
  line-height: 1.4;
  margin-top: 2px;
}
.qtde-adicionar-carrinho {
  display: flex;
  align-items: center;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: default;
  flex-shrink: 0;
}
.botao-quantidade {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 44px;
  background: var(--cor-fundo-cinza);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.botao-quantidade svg {
  width: 12px;
  height: 12px;
  fill: var(--cor-texto);
  pointer-events: none;
}
.botao-quantidade:active { background: var(--cor-principal); }
.botao-quantidade:active svg { fill: #fff; }
.qtde-carrinho-title {
  font-size: 0.78rem;
  color: var(--cor-texto-suave);
  padding: 0 6px;
  white-space: nowrap;
  border-left: 1px solid var(--cor-borda);
  border-right: 1px solid var(--cor-borda);
  height: 100%;
  display: flex;
  align-items: center;
}
.qtde-carrinho {
  width: 36px;
  height: 44px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--cor-borda);
  border-right: 1px solid var(--cor-borda);
  font-size: 0.9rem;
  font-weight: 600;
  outline: none;
  -moz-appearance: textfield;
  background: var(--cFundo);
}
.qtde-carrinho::-webkit-outer-spin-button,
.qtde-carrinho::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Botão principal — fixo no rodapé da tela */
.barra-compra-fixa {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 90;
  background: var(--cFundo);
  border-top: 1px solid var(--cor-borda);
  padding: 10px 16px;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.08);
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;          /* ocupa exatamente a largura da tela */
  overflow: hidden;
}
.barra-compra-fixa .botao.principal.grande {
  flex: 1;
  font-size: 1rem;
  padding: 13px;
  border-radius: var(--radius-md);
  width: auto;
}
.barra-compra-fixa .preco-fixo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--cor-texto);
  white-space: nowrap;
}

/* Disponibilidade e SKU */
.disponibilidade-produto {
  font-size: 0.78rem;
  color: var(--cor-texto-suave);
}
.disponibilidade-produto .disponivel { color: var(--cor-sucesso); font-weight: 600; }
.produto-sku { font-size: 0.7rem; color: var(--cor-texto-claro); }

/* ============================================================
   16. COMPRE JUNTO (mobile — tudo empilhado)
   ============================================================ */
.produto-comprejunto {
  background: var(--cor-fundo-cinza);
  border-top: 8px solid #eeeeee;
  padding: 16px 0;
}

/* ============================================================
   17. ABAS — Descrição / Avaliações / Perguntas (mobile)
   ============================================================ */
.produto-descricao-section {
  border-top: 8px solid #eeeeee;
  padding-bottom: 24px;
}
.abas__nav {
  display: flex;
  border-bottom: 1px solid var(--cor-borda);
  overflow-x: auto;
  scrollbar-width: none;
  position: sticky;
  top: 64px; /* altura do header mobile */
  z-index: 10;
  background: var(--cFundo);
}
.abas__nav::-webkit-scrollbar { display: none; }

.aba-btn {
  padding: 12px 16px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--cor-texto-suave);
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.aba-btn--ativo { color: var(--cor-principal); border-bottom-color: var(--cor-principal); font-weight: 600; }

.aba-painel { display: none; padding: 0; margin: 0; }
.aba-painel--ativo { display: block; animation: fadeIn 0.2s ease; }
#aba-descricao { margin-top: -8px; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   DESCRIÇÃO PREMIUM
   ============================================================ */

/* Hero */
.desc-hero {
  background: #1a1a1a;
  color: #fff;
  padding: 36px 24px;
  text-align: center;
  margin: 0 -16px;
}
.desc-hero a { color: inherit !important; text-decoration: none; }
.desc-hero__texto strong { color: #fff; font-weight: 600; }
.desc-hero__badge {
  display: inline-block;
  background: rgba(255,26,135,0.15);
  border: 1px solid rgba(255,26,135,0.3);
  color: var(--cor-principal);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 16px;
}
.desc-hero__sub {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #666;
  margin-bottom: 10px;
}
.desc-hero__titulo {
  font-size: 38px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 16px;
  color: #fff;
}
.desc-hero__divider {
  width: 40px;
  height: 2px;
  background: var(--cor-principal);
  margin: 0 auto 16px;
  border-radius: 2px;
}
.desc-hero__texto {
  font-size: 14px;
  line-height: 1.8;
  color: #e0e0e0;
  max-width: 360px;
  margin: 0 auto;
  font-weight: 300;
}

/* Métricas */
.desc-metricas {
  display: flex;
  border-bottom: 1px solid var(--cor-borda);
}
.desc-metrica {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 8px;
  border-right: 1px solid var(--cor-borda);
  text-align: center;
}
.desc-metrica:last-child { border-right: none; }
.desc-metrica__num {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--cor-principal);
  line-height: 1;
  margin-bottom: 4px;
}
.desc-metrica__label {
  font-size: 0.68rem;
  color: var(--cor-texto-suave);
  font-weight: 500;
  line-height: 1.3;
}

/* Blocos gerais */
.desc-bloco {
  padding: 24px 16px;
  margin: 0 -16px;
  border-bottom: 1px solid var(--cor-borda);
  background: #fff;
}
.desc-bloco:last-child { border-bottom: none; }
.desc-bloco--cinza {
  background: #fce8f3;
}

.desc-titulo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 22px;
  font-weight: 700;
  color: var(--cor-texto);
  margin-bottom: 16px;
}
.desc-titulo__barra {
  display: inline-block;
  width: 5px;
  height: 28px;
  border-radius: 3px;
  background: linear-gradient(to bottom, var(--cor-principal), rgba(255,26,135,0.3));
  flex-shrink: 0;
}
.desc-texto {
  font-size: 15px;
  color: var(--cor-texto-suave);
  line-height: 1.8;
}
.desc-texto strong { color: var(--cor-texto); font-weight: 700; }
.desc-sobre { display: flex; flex-direction: column; gap: 16px; }
.desc-sobre__destaque {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: linear-gradient(135deg, rgba(255,26,135,0.06) 0%, rgba(255,26,135,0.02) 100%);
  border-left: 3px solid var(--cor-principal);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 14px 16px;
}
.desc-sobre__destaque i {
  color: var(--cor-principal);
  font-size: 1rem;
  margin-top: 2px;
  flex-shrink: 0;
}
.desc-sobre__destaque p {
  font-size: 0.85rem;
  font-style: italic;
  color: var(--cor-texto);
  line-height: 1.6;
  margin: 0;
  font-weight: 500;
}

/* Ingredientes ativos */
.desc-ativos {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.desc-ativo {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(135deg, #fafafa 0%, #fff 100%);
  border: 1px solid #d8c0cc;
  border-radius: var(--radius-md);
  padding: 18px 16px;
}
.desc-ativo__topo {
  display: flex;
  align-items: center;
  gap: 12px;
}
.desc-ativo__icone {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(158,61,92,0.12);
  color: #9e3d5c;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}
.desc-ativo__icone--vitc {
  background: rgba(158,61,92,0.12);
  color: #9e3d5c;
}
.desc-ativo__icone--ha {
  background: rgba(93,111,168,0.12);
  color: #5d6fa8;
}
.desc-ativo--vitc .desc-ativo__barra-fill {
  background: linear-gradient(to right, #9e3d5c, rgba(158,61,92,0.5));
}
.desc-ativo--vitc .desc-ativo__eficacia-pct {
  color: #9e3d5c;
}
.desc-ativo--ha .desc-ativo__barra-fill {
  background: linear-gradient(to right, #5d6fa8, rgba(93,111,168,0.5));
}
.desc-ativo--ha .desc-ativo__eficacia-pct {
  color: #5d6fa8;
}
.desc-ativo__topo strong {
  font-size: 1rem;
  font-weight: 700;
  color: var(--cor-texto);
}
.desc-ativo__desc {
  font-size: 0.85rem;
  color: var(--cor-texto-suave);
  line-height: 1.6;
  margin: 0;
}
.desc-ativo__eficacia {
  display: flex;
  align-items: center;
  gap: 8px;
}
.desc-ativo__eficacia-label {
  font-size: 0.7rem;
  color: var(--cor-texto-suave);
  font-weight: 500;
  white-space: nowrap;
}
.desc-ativo__eficacia-pct {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--cor-principal);
  white-space: nowrap;
}
.desc-ativo__barra {
  flex: 1;
  height: 5px;
  background: #eee;
  border-radius: 10px;
  overflow: hidden;
}
.desc-ativo__barra-fill {
  height: 100%;
  background: linear-gradient(to right, var(--cor-principal), rgba(255,26,135,0.5));
  border-radius: 10px;
  transition: width 1s ease;
}
.desc-ativo__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.desc-ativo__tags span {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 50px;
}
/* Vitamina C — rosê profundo */
.desc-ativo__tags--vitc span {
  background: rgba(158,61,92,0.07);
  color: #9e3d5c;
  border: 1px solid rgba(158,61,92,0.2);
}
/* Ácido Hialurônico — índigo empoeirado */
.desc-ativo__tags--ha span {
  background: rgba(93,111,168,0.07);
  color: #5d6fa8;
  border: 1px solid rgba(93,111,168,0.2);
}
.desc-ativo__mais {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  color: var(--cor-principal);
  font-size: 0.75rem;
}
.desc-ativo__mais span {
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,26,135,0.3));
}
.desc-ativo__mais span:last-child {
  background: linear-gradient(to left, transparent, rgba(255,26,135,0.3));
}

/* Benefícios */
.desc-beneficios {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.desc-beneficio {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
  padding: 24px 20px;
  background: #fafafa;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
}
.desc-beneficio__topo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.desc-beneficio__icone {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: rgba(255,26,135,0.08);
  color: var(--cor-principal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.desc-beneficio__titulo {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--cor-texto);
  line-height: 1.3;
}
.desc-beneficio__desc {
  font-size: 0.82rem;
  color: #888;
  line-height: 1.6;
  margin: 0;
}
.desc-beneficio__resultado {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--cor-principal);
  background: rgba(255,26,135,0.07);
  border: 1px solid rgba(255,26,135,0.18);
  border-radius: 50px;
  padding: 3px 10px;
}

/* Variantes de cor — benefícios */
.desc-beneficio--rosa {
  background: linear-gradient(160deg, rgba(255,26,135,0.22) 0%, #ffffff 75%);
  border-color: rgba(255,26,135,0.15);
}
.desc-beneficio--rosa .desc-beneficio__icone {
  background: rgba(255,26,135,0.08);
  color: var(--cor-principal);
}
.desc-beneficio--rosa .desc-beneficio__resultado {
  color: var(--cor-principal);
  background: rgba(255,26,135,0.07);
  border-color: rgba(255,26,135,0.18);
}

.desc-beneficio--verde {
  background: linear-gradient(160deg, rgba(42,157,111,0.22) 0%, #ffffff 75%);
  border-color: rgba(42,157,111,0.18);
}
.desc-beneficio--verde .desc-beneficio__icone {
  background: rgba(42,157,111,0.08);
  color: #2a9d6f;
}
.desc-beneficio--verde .desc-beneficio__resultado {
  color: #2a9d6f;
  background: rgba(42,157,111,0.07);
  border-color: rgba(42,157,111,0.2);
}

.desc-beneficio--violeta {
  background: linear-gradient(160deg, rgba(123,94,168,0.22) 0%, #ffffff 75%);
  border-color: rgba(123,94,168,0.18);
}
.desc-beneficio--violeta .desc-beneficio__icone {
  background: rgba(123,94,168,0.08);
  color: #7b5ea8;
}
.desc-beneficio--violeta .desc-beneficio__resultado {
  color: #7b5ea8;
  background: rgba(123,94,168,0.07);
  border-color: rgba(123,94,168,0.2);
}

/* Rotina de uso */
.desc-rotina {
  display: flex;
  flex-direction: column;
}
.desc-passo {
  display: flex;
  gap: 16px;
}
.desc-passo__lado {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}
.desc-passo__circulo {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,26,135,0.08);
  color: var(--cor-principal);
  border: 1.5px solid rgba(255,26,135,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.desc-passo__linha {
  width: 2px;
  flex: 1;
  min-height: 20px;
  background: linear-gradient(to bottom, rgba(255,26,135,0.25), rgba(255,26,135,0.05));
  margin: 4px 0;
}
.desc-passo__info {
  padding-bottom: 20px;
  flex: 1;
}
.desc-passo--ultimo .desc-passo__info {
  padding-bottom: 0;
}
.desc-passo__info strong {
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--cor-texto);
  margin-top: 2px;
}
.desc-passo__badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 600;
  border-radius: 50px;
  padding: 2px 9px;
  margin: 5px 0 6px;
}
.desc-passo__badge--diario {
  color: var(--cor-principal);
  background: rgba(255,26,135,0.07);
  border: 1px solid rgba(255,26,135,0.18);
}
.desc-passo__badge--manha-noite {
  color: #2a9d6f;
  background: rgba(42,157,111,0.07);
  border: 1px solid rgba(42,157,111,0.2);
}
.desc-passo__badge--semanal {
  color: #7b5ea8;
  background: rgba(123,94,168,0.07);
  border: 1px solid rgba(123,94,168,0.2);
}
.desc-passo__badge--final {
  color: #5d6fa8;
  background: rgba(93,111,168,0.07);
  border: 1px solid rgba(93,111,168,0.2);
}
.desc-passo__info p {
  font-size: 0.8rem;
  color: #888;
  line-height: 1.5;
  margin: 0;
}

/* Variantes de cor — círculo por tipo de passo */
.desc-passo--diario .desc-passo__circulo {
  background: rgba(255,26,135,0.08);
  color: var(--cor-principal);
  border-color: rgba(255,26,135,0.2);
}
.desc-passo--diario .desc-passo__linha {
  background: linear-gradient(to bottom, rgba(255,26,135,0.25), rgba(255,26,135,0.05));
}
.desc-passo--manha-noite .desc-passo__circulo {
  background: rgba(42,157,111,0.08);
  color: #2a9d6f;
  border-color: rgba(42,157,111,0.2);
}
.desc-passo--manha-noite .desc-passo__linha {
  background: linear-gradient(to bottom, rgba(42,157,111,0.25), rgba(42,157,111,0.05));
}
.desc-passo--semanal .desc-passo__circulo {
  background: rgba(123,94,168,0.08);
  color: #7b5ea8;
  border-color: rgba(123,94,168,0.2);
}
.desc-passo--semanal .desc-passo__linha {
  background: linear-gradient(to bottom, rgba(123,94,168,0.25), rgba(123,94,168,0.05));
}
.desc-passo--final .desc-passo__circulo {
  background: rgba(93,111,168,0.08);
  color: #5d6fa8;
  border-color: rgba(93,111,168,0.2);
}

/* Tipos de pele */
.desc-tipos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.desc-tipo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  background: #fafafa;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
  padding: 14px 14px;
}
.desc-tipo__icone {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,26,135,0.08);
  color: var(--cor-principal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
}
.desc-tipo strong {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--cor-texto);
}
.desc-tipo span {
  font-size: 0.74rem;
  color: #888;
  line-height: 1.4;
}

/* Variantes de cor — tipos de pele */
.desc-tipo--rosa {
  background: linear-gradient(160deg, rgba(255,26,135,0.22) 0%, #ffffff 75%);
  border-color: rgba(255,26,135,0.15);
}
.desc-tipo--rosa .desc-tipo__icone {
  background: rgba(255,26,135,0.1);
  color: var(--cor-principal);
}

.desc-tipo--teal {
  background: linear-gradient(160deg, rgba(14,143,160,0.22) 0%, #ffffff 75%);
  border-color: rgba(14,143,160,0.15);
}
.desc-tipo--teal .desc-tipo__icone {
  background: rgba(14,143,160,0.1);
  color: #0e8fa0;
}

.desc-tipo--ambar {
  background: linear-gradient(160deg, rgba(193,122,42,0.22) 0%, #ffffff 75%);
  border-color: rgba(193,122,42,0.15);
}
.desc-tipo--ambar .desc-tipo__icone {
  background: rgba(193,122,42,0.1);
  color: #c17a2a;
}

.desc-tipo--indigo {
  background: linear-gradient(160deg, rgba(93,111,168,0.22) 0%, #ffffff 75%);
  border-color: rgba(93,111,168,0.15);
}
.desc-tipo--indigo .desc-tipo__icone {
  background: rgba(93,111,168,0.1);
  color: #5d6fa8;
}

.desc-tipo--violeta {
  background: linear-gradient(160deg, rgba(123,94,168,0.22) 0%, #ffffff 75%);
  border-color: rgba(123,94,168,0.15);
}
.desc-tipo--violeta .desc-tipo__icone {
  background: rgba(123,94,168,0.1);
  color: #7b5ea8;
}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-secao {
  background: #f7f7f7;
  padding: 36px 16px;
  border-top: 8px solid #eeeeee;
}
.reviews-cabecalho {
  text-align: center;
  margin-bottom: 24px;
}
.reviews-badge {
  display: inline-block;
  background: rgba(255,26,135,0.1);
  color: var(--cor-principal);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 50px;
  margin-bottom: 10px;
  letter-spacing: 0.04em;
}
.reviews-titulo {
  font-size: 1.333rem;
  font-weight: 700;
  color: var(--cor-texto);
  margin-bottom: 10px;
  line-height: 1.3;
}
.reviews-titulo span { color: var(--cor-principal); }
.reviews-estrelas { display: flex; justify-content: center; gap: 3px; margin-bottom: 6px; }
.reviews-nota { font-size: 0.933rem; color: var(--cor-texto-suave); }
.reviews-nota strong { color: var(--cor-texto); }

/* Grade de fotos */
.reviews-fotos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 24px;
}
.reviews-foto {
  position: relative;
  aspect-ratio: 1;
  border-radius: 8px;
  overflow: hidden;
  background: #e5e5e5;
}
.reviews-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.reviews-foto__check {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Cards */
.reviews-lista {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 28px;
}
.review-card {
  display: flex;
  gap: 12px;
  background: #fff;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
  padding: 14px;
}
.review-card__foto {
  width: 52px;
  height: 52px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  background: #eee;
}
.review-card__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.review-card__corpo { flex: 1; min-width: 0; }
.review-card__topo {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.review-card__nome {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--cor-texto);
}
.review-card__verificado {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 0.68rem;
  font-weight: 600;
  color: #27bf64;
  background: rgba(39,191,100,0.1);
  padding: 2px 7px;
  border-radius: 50px;
}
.review-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.review-card__estrelas { color: #f4a308; font-size: 0.65rem; display: flex; gap: 1px; }
.review-card__cidade {
  font-size: 0.68rem;
  color: var(--cor-texto-suave);
  display: flex;
  align-items: center;
  gap: 3px;
}
.review-card__texto {
  font-size: 0.82rem;
  color: var(--cor-texto);
  line-height: 1.55;
  margin: 0;
}

/* Rodapé */
.reviews-rodape { text-align: center; }
.reviews-selos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-bottom: 12px;
}
.reviews-selo {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 50px;
}
.reviews-selo--verde { color: #27bf64; background: rgba(39,191,100,0.1); }
.reviews-selo--amarelo { color: #b8860b; background: rgba(244,163,8,0.1); }
.reviews-selo--azul { color: #5d6fa8; background: rgba(93,111,168,0.1); }
.reviews-rodape__texto { font-size: 0.78rem; color: var(--cor-texto-suave); }
.reviews-rodape__texto strong { color: var(--cor-texto); }

/* Tabela técnica */
.desc-tabela {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.desc-tabela tr { border-bottom: 1px solid var(--cor-borda); }
.desc-tabela tr:last-child { border-bottom: none; }
.desc-tabela td {
  padding: 10px 6px;
  line-height: 1.4;
}
.desc-tabela td:first-child {
  color: var(--cor-texto-suave);
  width: 45%;
  font-weight: 500;
}
.desc-tabela td:last-child {
  color: var(--cor-texto);
  font-weight: 600;
}

/* ============================================================
   18. AVALIAÇÕES (mobile)
   ============================================================ */
.avaliacoes-resumo { display: flex; gap: 16px; align-items: flex-start; margin-bottom: 14px; }
.nota-geral { display: flex; flex-direction: column; align-items: center; gap: 4px; min-width: 70px; }
.nota-numero { font-size: 2.5rem; font-weight: 700; line-height: 1; color: var(--cor-texto); }
.nota-total { font-size: 0.7rem; color: var(--cor-texto-claro); }
.estrelas { display: flex; gap: 2px; color: var(--cor-estrela); }
.estrelas--pequenas { font-size: 0.8rem; }

.barras-nota { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.barra-linha { display: flex; align-items: center; gap: 6px; font-size: 0.72rem; color: var(--cor-texto-suave); }
.barra-trilha { flex: 1; height: 7px; background: var(--cor-borda); border-radius: 50px; overflow: hidden; }
.barra-fill { height: 100%; background: var(--cor-estrela); border-radius: 50px; }

.recomendam {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.78rem; color: var(--cor-texto-suave); margin-bottom: 4px;
}
.recomendam i { color: var(--cor-sucesso); }
.verificado-trusvox { font-size: 0.7rem; color: var(--cor-texto-claro); display: flex; align-items: center; gap: 6px; margin-bottom: 14px; }
.trusvox-logo { height: 14px; }

.avaliacoes-ordenar {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; color: var(--cor-texto-suave); margin-bottom: 14px;
}
.avaliacoes-ordenar select {
  padding: 5px 8px; border: 1px solid var(--cor-borda);
  border-radius: var(--radius); font-size: 0.78rem; outline: none;
  background: var(--cFundo); font-family: var(--fonte);
}

.avaliacoes-lista { display: flex; flex-direction: column; gap: 10px; }

.avaliacao-card {
  background: #fafafa;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.avaliacao-cabecalho { display: flex; align-items: center; gap: 10px; }
.avaliacao-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--cor-principal); color: #fff;
  font-size: 0.72rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.avaliacao-meta { flex: 1; display: flex; flex-direction: column; gap: 1px; }
.avaliacao-autor { font-size: 0.82rem; font-weight: 600; }
.avaliacao-verificada { font-size: 0.68rem; color: var(--cor-sucesso); }
.avaliacao-data { font-size: 0.68rem; color: var(--cor-texto-claro); }
.avaliacao-texto { font-size: 0.82rem; color: var(--cor-texto-suave); line-height: 1.55; }
.btn-util {
  font-size: 0.72rem; color: var(--cor-texto-claro);
  display: flex; align-items: center; gap: 4px; width: fit-content;
  -webkit-tap-highlight-color: transparent;
}
.btn-util:active { color: var(--cor-principal); }

.botao-carregar-mais {
  display: block; margin: 16px auto 0;
  padding: 10px 24px;
  background: transparent;
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius);
  font-size: 0.82rem; color: var(--cor-texto-suave);
  font-family: var(--fonte);
  -webkit-tap-highlight-color: transparent;
}

/* Perguntas */
.perguntas-secao p { font-size: 0.875rem; color: var(--cor-texto-suave); margin-bottom: 14px; }
.pergunta-form { display: flex; flex-direction: column; gap: 10px; }
.pergunta-input {
  padding: 10px; border: 1px solid var(--cor-borda);
  border-radius: var(--radius); font-size: 0.875rem;
  resize: none; outline: none; font-family: var(--fonte);
}
.pergunta-input:focus { border-color: var(--cor-principal); }
.pergunta-form .botao { width: 100%; padding: 12px; }

/* ============================================================
   19. APROVEITE E COMPRE TAMBÉM — Swiper (mobile)
   ============================================================ */
.produto-aproveite {
  border-top: 8px solid #eeeeee;
  padding: 20px 0;
  background: var(--cor-fundo-cinza);
}
.produto-aproveite .titulo-secao { padding: 0 16px; margin-bottom: 14px; font-size: 0.95rem; }

/* Swiper contido — sem overflow lateral */
.produto-aproveite { overflow: hidden; }  /* pai bloqueia o overflow do swiper */
.aproveite-swiper {
  padding: 0 16px 8px !important;
  overflow: hidden !important;            /* nunca deixa slides saírem do container */
  width: 100% !important;
}
.swiper-wrapper { align-items: stretch; }

/* Botões de nav — ocultos no mobile (swipe nativo) */
.swiper-button-prev.aproveite-prev,
.swiper-button-next.aproveite-next {
  display: none;
}

/* Cards de produto */
.listagem-item.produto-card {
  background: var(--cFundo);
  border: 1px solid var(--cor-borda);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  -webkit-tap-highlight-color: transparent;
}
.produto-card__img-link {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--cor-fundo-cinza);
}
.produto-card__img-link img { width: 100%; height: 100%; object-fit: cover; }
.produto-card__info { padding: 10px; flex: 1; display: flex; flex-direction: column; gap: 3px; }
.produto-card__nome { font-size: 0.78rem; font-weight: 500; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.produto-card__nome a { color: var(--cor-texto); }
.produto-card__precos { display: flex; align-items: center; gap: 6px; margin-top: 4px; }
.preco-de { font-size: 0.68rem; color: var(--cor-texto-claro); }
.bandeira-desconto { background: var(--cBandeiraDesconto); color: var(--cBandeiraDescontoTxt); font-size: 0.6rem; font-weight: 700; padding: 1px 5px; border-radius: 50px; }
.preco-por { font-size: 1rem; font-weight: 700; color: var(--cor-texto); }
.preco-pix-card { font-size: 0.68rem; color: var(--cor-sucesso); }
.produto-card__btn {
  margin: 0 10px 10px;
  padding: 9px;
  font-size: 0.8rem;
  border-radius: var(--radius);
  width: calc(100% - 20px);
}

/* ============================================================
   20. NEWSLETTER (mobile)
   ============================================================ */
.newsletter-secao {
  background: var(--cor-principal);
  padding: 24px 0;
  border-top: 8px solid #eeeeee;
}
.newsletter-inner { display: flex; flex-direction: column; gap: 14px; }
.newsletter-titulo { font-size: 1rem; color: #fff; margin-bottom: 4px; }
.newsletter-sub { font-size: 0.8rem; color: rgba(255,255,255,0.85); }
.newsletter-form { display: flex; gap: 8px; }
.newsletter-form input {
  flex: 1; padding: 10px 12px;
  border: none; border-radius: var(--radius);
  font-size: 0.875rem; outline: none; font-family: var(--fonte);
}
.newsletter-form .botao.principal {
  background: #222;
  white-space: nowrap;
  font-size: 0.875rem;
  padding: 10px 16px;
}

/* ============================================================
   21. RODAPÉ (mobile — acordeão ou lista simples)
   ============================================================ */
#rodape { background: var(--cRodape); border-top: 8px solid #eeeeee; }

.institucional { padding: 24px 0; }
.rodape-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rodape-col { border-bottom: 1px solid var(--cor-borda); }
.rodape-col--sobre {
  border: none;
  padding: 0 16px 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.rodape-logo img { height: 40px; width: auto; }
.rodape-descricao { font-size: 0.78rem; color: var(--cor-texto-suave); line-height: 1.6; }
.rodape-redes { display: flex; gap: 12px; }
.rodape-redes a {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--cor-borda);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; color: var(--cor-texto-suave);
  -webkit-tap-highlight-color: transparent;
}

/* Seções colapsáveis do rodapé */
.rodape-col-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  width: 100%;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.rodape-titulo {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--cor-texto);
}
.rodape-chevron { font-size: 0.7rem; color: var(--cor-texto-claro); transition: transform 0.2s; }
.rodape-col.aberto .rodape-chevron { transform: rotate(180deg); }

.links-rodape ul {
  display: none;
  flex-direction: column;
  padding: 0 16px 14px;
  gap: 10px;
}
.rodape-col.aberto .links-rodape ul { display: flex; }
.links-rodape a { font-size: 0.82rem; color: var(--cor-texto-suave); }

.rodape-contato {
  display: none;
  flex-direction: column;
  gap: 10px;
  padding: 0 16px 14px;
}
.rodape-col.aberto .rodape-contato { display: flex; }
.rodape-contato li { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: var(--cor-texto-suave); }
.rodape-contato i { color: var(--cor-principal); font-size: 0.8rem; }

/* Rodapé bottom */
.rodape-bottom {
  border-top: 1px solid var(--cor-borda);
  padding: 14px 0;
  background: var(--cor-fundo-cinza);
}
.rodape-bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.gateways-rodape {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}
.gateways-rodape .gateway-logo { height: 20px; width: auto; }
.gateway-txt {
  font-size: 0.65rem; font-weight: 600;
  color: var(--cor-texto-suave);
  background: var(--cFundo);
  border: 1px solid var(--cor-borda);
  padding: 2px 7px; border-radius: var(--radius);
}
.rodape-copy { font-size: 0.7rem; color: var(--cor-texto-claro); text-align: center; }
.rodape-seguranca { font-size: 0.72rem; color: var(--cor-texto-suave); display: flex; align-items: center; gap: 4px; }
.rodape-seguranca i { color: var(--cor-sucesso); }

/* ============================================================
   22. BOTÃO FLUTUANTE REVENDEDOR (mobile)
   ============================================================ */
.btn-revendedor-fixo {
  position: fixed;
  bottom: 78px; /* acima da barra de compra fixa */
  right: 14px;
  background: var(--cor-sucesso);
  color: #fff;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  z-index: 80;
  -webkit-tap-highlight-color: transparent;
}
.btn-revendedor-fixo span { display: none; } /* Oculto no mobile */

/* ============================================================
   23. RESPONSIVO — Telas maiores (≥ 480px)
       Mantém mobile como base, apenas ajustes leves
   ============================================================ */
/* ============================================================
   Ajustes progressivos — nunca quebram o mobile base
   ============================================================ */
@media (min-width: 480px) {
  .barra-redes { display: flex; }
  .barra-canais { width: auto; }
}

@media (min-width: 768px) {
  .container { max-width: 960px; margin: 0 auto; }
  .acao-conta, .acao-pedidos { display: flex; }
  .acao-busca { display: none; }
  .cabecalho__busca { display: block; order: -1; }
  .busca-mobile { display: none !important; }
  .menu-superior { display: block; }
  .menu-lista { flex-direction: row; }
  .menu-lista > li { border: none; }
  .menu-lista > li > a { padding: 10px 14px; border-bottom: 2px solid transparent; margin-bottom: -1px; }
  .menu-lista > li > a:hover { color: var(--cor-principal); border-bottom-color: var(--cor-principal); }
  .barra-redes { display: flex; }
  /* Produto lado a lado no tablet */
  .produto-grid { flex-direction: row; gap: 32px; }
  .produto-imagens { width: 52%; }
  .produto-info { flex: 1; }
  .conteiner-imagem { aspect-ratio: 3/4; }
  /* Esconde barra fixa e mostra botão normal */
  .barra-compra-fixa { display: none; }
  .pagina-produto { padding-bottom: 32px; }
  /* Swiper com botões */
  .swiper-button-prev.aproveite-prev,
  .swiper-button-next.aproveite-next {
    display: flex; color: var(--cor-principal);
    background: var(--cFundo); border: 1px solid var(--cor-borda);
    border-radius: 50%; width: 36px; height: 36px;
  }
  .swiper-button-prev.aproveite-prev::after,
  .swiper-button-next.aproveite-next::after { font-size: 0.8rem; font-weight: 700; }
  /* Rodapé grid horizontal */
  .rodape-grid { flex-direction: row; flex-wrap: wrap; }
  .rodape-col { border: none; flex: 1; min-width: 150px; padding: 0 12px; }
  .rodape-col-toggle .rodape-chevron { display: none; }
  .links-rodape ul { display: flex !important; padding: 0; }
  .rodape-contato { display: flex !important; padding: 0; }
  .rodape-bottom-inner { flex-direction: row; justify-content: space-between; }
  .btn-revendedor-fixo { width: auto; height: auto; border-radius: var(--radius-md); padding: 10px 16px; bottom: 24px; }
  .btn-revendedor-fixo span { display: inline; }
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: rgba(32, 31, 31, 0.88) !important;
  isolation: isolate;
  animation: lightboxFadeIn 0.25s ease;
}
.lightbox[hidden] { display: none !important; }
.lightbox__zoom-wrap {
  animation: lightboxSlideUp 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes lightboxFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes lightboxSlideUp {
  from { opacity: 0; transform: translateY(-60px) scale(0.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes lightboxFadeOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}
.lightbox__conteudo {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.lightbox__zoom-wrap {
  background: #fff;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox__img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}
.lightbox__fechar {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(255,255,255,0.2);
  border: none;
  border-radius: 50%;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
}
.lightbox__fechar svg { width: 18px; height: 18px; color: #fff; }
.lightbox__fechar:hover { background: rgba(255,255,255,0.35); }

.lightbox__contador {
  position: absolute;
  top: 20px;
  left: 16px;
  color: #fff;
  font-size: 0.85rem;
  z-index: 2;
}
.lightbox__seta {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.12);
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
  transition: background 0.15s;
}
.lightbox__seta:hover { background: rgba(255,255,255,0.25); }
.lightbox__seta svg { width: 20px; height: 20px; color: #fff; }
.lightbox__seta--prev { left: 8px; }
.lightbox__seta--next { right: 8px; }
.lightbox__seta[disabled] { opacity: 0.15; pointer-events: none; }

/* ===== RODAPÉ BASE ===== */
.row-fluid {
  width: 100%;
  background: #f5f5f5;
  padding: 12px 0;
  border-top: 1px solid #e0e0e0;
}

/* ===== CONTAINER INTERNO ===== */
.inside {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  flex-wrap: wrap;
  text-align: center;
}

/* ===== TEXTO DA EMPRESA ===== */
.rodape-dados p {
  margin: 0;
  font-size: 12px;
  color: #7a7a7a;
  line-height: 1.3;
  font-family: Arial, sans-serif;
}

/* ===== BLOCO DAS MARCAS ===== */
.rodape-marcas {
  display: flex;
  align-items: flex-start;
  gap: 20px;
}

/* ===== CADA ITEM (DESENVOLVIMENTO / PLATAFORMA) ===== */
.rodape-marca {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-decoration: none;
}

/* ===== TEXTO "DESENVOLVIMENTO" / "PLATAFORMA" ===== */
.rodape-marca span {
  font-size: 11px;
  color: #8c8c8c;
  margin-bottom: 4px;
}

/* ===== LOGOS ===== */
.rodape-marca img {
  max-height: 26px;
  width: auto;
  opacity: 0.85;
  transition: all 0.2s ease;
}

/* ===== EFEITO HOVER (sutil, profissional) ===== */
.rodape-marca img:hover {
  opacity: 1;
  transform: scale(1.03);
}

/* ===== RESPONSIVO ===== */
@media (max-width: 768px) {
  .inside {
    flex-direction: column;
    gap: 12px;
  }

  .rodape-marcas {
    justify-content: center;
  }

  .rodape-marca {
    align-items: center;
  }

  .rodape-marca span {
    text-align: center;
  }
}

.barra-compra-fixa {
  transform: translateY(100%);
  transition: transform 0.3s ease;
}

.barra-compra-fixa.ativa {
  transform: translateY(0);
}