/* ===================== Tokens ===================== */
:root {
  /* dourado da marca (mantive os nomes --verde p/ não quebrar nada) */
  --verde: #b8902f;
  --verde-esc: #9a7826;
  --verde-claro: #f4ecd7;
  --ouro: #b8902f;
  --ouro-esc: #9a7826;
  --grafite: #26262a;
  --grafite-esc: #19191c;
  --rosa: #26262a;
  --rosa-esc: #19191c;
  --ink: #2b2b2b;
  --muted: #7c8079;
  --bg: #ffffff;
  --cinza: #f4f5f3;
  --linha: #e8e8e4;
  --amarelo: #f4b400;
  --radius: 12px;
  --shadow: 0 10px 30px -18px rgba(0,0,0,.35);
  --max: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: "Poppins", system-ui, sans-serif; line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4 { margin: 0; line-height: 1.15; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ===================== Botões ===================== */
.btn-verde {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--verde); color: #fff; border: 0; cursor: pointer;
  font: inherit; font-weight: 600; padding: 12px 22px; border-radius: 8px;
  transition: background .15s ease, transform .15s ease;
}
.btn-verde:hover { background: var(--verde-esc); }
.btn-verde.grande { padding: 14px 28px; font-size: 16px; }
.btn-verde.mini { padding: 8px 16px; font-size: 13px; border-radius: 999px; }
.btn-branco { display: inline-block; background: #fff; color: var(--rosa); font-weight: 700;
  padding: 12px 26px; border-radius: 999px; }

/* ===================== Promo bar ===================== */
.promo-bar {
  background: var(--rosa); color: #fff; text-align: center;
  font-size: 13px; padding: 8px 16px; letter-spacing: .01em;
}
.promo-bar strong { font-weight: 700; }

/* ===================== Header ===================== */
.header { position: sticky; top: 0; z-index: 40; background: #fff; border-bottom: 1px solid var(--linha); }
.header-in {
  max-width: var(--max); margin: 0 auto; display: flex; align-items: center; gap: 24px;
  padding: 14px clamp(14px, 4vw, 32px);
}
.logo { display: flex; align-items: center; gap: 9px; }
.logo-mark {
  width: 34px; height: 34px; display: grid; place-items: center;
  background: var(--verde); color: #fff; border-radius: 9px; font-size: 18px;
}
.logo-text { font-weight: 500; font-size: 19px; letter-spacing: .02em; color: var(--ink); }
.logo-text strong { font-weight: 800; color: var(--verde); }
.logo-text.claro, .logo-text.claro strong { color: #fff; }

.busca { flex: 1; max-width: 520px; display: flex; border: 1.5px solid var(--linha); border-radius: 999px; overflow: hidden; }
.busca input { flex: 1; border: 0; padding: 11px 18px; font: inherit; font-size: 14px; outline: none; }
.busca button { border: 0; background: var(--verde); color: #fff; padding: 0 18px; cursor: pointer; font-size: 15px; }

.header-acoes { display: flex; align-items: center; gap: 18px; margin-left: auto; }
.icone {
  display: inline-flex; flex-direction: column; align-items: center; gap: 2px;
  background: none; border: 0; cursor: pointer; font: inherit; font-size: 18px; color: var(--ink); position: relative;
}
.icone span { font-size: 11px; color: var(--muted); }
.contador {
  position: absolute; top: -6px; right: -8px; min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--rosa); color: #fff; border-radius: 999px; font-size: 11px; font-weight: 700;
  font-style: normal; display: grid; place-items: center;
}

.menu {
  max-width: var(--max); margin: 0 auto; display: flex; gap: 26px; flex-wrap: wrap;
  padding: 0 clamp(14px, 4vw, 32px) 12px; font-size: 14px; font-weight: 500;
}
.menu a { color: #555; padding: 4px 0; }
.menu a:hover { color: var(--verde); }
.menu .destaque-menu { color: var(--rosa); font-weight: 700; }

/* ===================== Faixa de categorias ===================== */
.cat-strip {
  max-width: var(--max); margin: 0 auto; display: flex; gap: 10px; overflow-x: auto;
  padding: 14px clamp(14px, 4vw, 32px); border-bottom: 1px solid var(--linha);
  scrollbar-width: none;
}
.cat-strip::-webkit-scrollbar { display: none; }
.cat-chip {
  display: flex; flex-direction: column; align-items: center; gap: 6px; min-width: 76px; cursor: pointer;
}
.cat-chip .bolha {
  width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center;
  font-size: 22px; color: #fff;
}
.cat-chip span { font-size: 11.5px; color: #555; text-align: center; white-space: nowrap; }

/* ===================== Hero ===================== */
.hero {
  position: relative; max-width: var(--max); margin: 18px auto; border-radius: 18px; overflow: hidden;
  min-height: 320px; display: flex; align-items: center;
  padding: clamp(20px, 4vw, 48px);
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(130% 130% at 78% 12%, #4a4640 0%, #2c2a27 55%, #1a1916 100%);
}
.hero-bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 80% at 85% 80%, rgba(184,144,47,.28), transparent 60%),
    repeating-linear-gradient(95deg, rgba(255,255,255,.04) 0 14px, rgba(0,0,0,.06) 14px 28px);
}
.hero-card {
  position: relative; z-index: 1; background: rgba(255,255,255,.94); border-radius: 14px;
  padding: 28px 30px; max-width: 380px; box-shadow: var(--shadow);
}
.hero-eyebrow { display: block; font-size: 14px; color: var(--muted); font-weight: 500; }
.hero-off {
  display: inline-block; background: var(--verde); color: #fff; font-weight: 800;
  font-size: 30px; padding: 6px 16px; border-radius: 10px; margin: 8px 0 12px;
}
.hero-desc { font-size: 14px; color: #555; margin: 0 0 18px; }

/* ===================== Seções ===================== */
.secao { max-width: var(--max); margin: 0 auto; padding: 44px clamp(14px, 4vw, 32px); }
.faixa-clara { max-width: none; background: var(--cinza); }
.faixa-clara > * { max-width: var(--max); margin-left: auto; margin-right: auto; }
.secao-cabeca { margin-bottom: 26px; }
.secao-cabeca.centro { text-align: center; }
.secao-cabeca h2 { font-size: clamp(22px, 3vw, 30px); font-weight: 700; }
.secao-cabeca p { color: var(--muted); font-size: 14px; margin: 8px 0 0; }
.secao-cabeca.linha { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.secao-cabeca.linha h2 { font-size: clamp(20px, 2.6vw, 26px); }

/* ===================== Carrossel + cards ===================== */
.carrossel-wrap { position: relative; }
.trilho {
  display: grid; grid-auto-flow: column; grid-auto-columns: minmax(230px, 1fr);
  gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 4px; scrollbar-width: none;
}
.trilho::-webkit-scrollbar { display: none; }
@media (min-width: 920px) {
  .trilho { grid-auto-columns: calc((100% - 54px) / 4); }
}
.seta {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--linha);
  background: #fff; color: var(--verde); font-size: 22px; line-height: 1; cursor: pointer;
  box-shadow: var(--shadow); display: grid; place-items: center;
}
.seta.esq { left: -10px; }
.seta.dir { right: -10px; }
.seta:hover { background: var(--verde); color: #fff; }

.produto {
  scroll-snap-align: start; background: #fff; border: 1px solid var(--linha); border-radius: var(--radius);
  display: flex; flex-direction: column; overflow: hidden; position: relative;
  transition: box-shadow .18s ease, transform .18s ease;
}
.produto:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.prod-foto { aspect-ratio: 1 / 1; position: relative; }
.prod-foto .ph { width: 100%; height: 100%; display: grid; place-items: center; text-align: center;
  color: #fff; font-weight: 600; font-size: 13px; padding: 16px; }
.selos { position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 5px; z-index: 2; }
.selo { font-size: 10.5px; font-weight: 700; color: #fff; padding: 3px 8px; border-radius: 5px; letter-spacing: .02em; }
.selo.oferta { background: var(--rosa); }
.selo.site { background: #2b6cb0; }
.selo.premium { background: var(--ink); }
.selo.frete { background: var(--verde); }
.desc-off { position: absolute; top: 10px; right: 10px; background: var(--rosa); color: #fff;
  font-size: 11px; font-weight: 700; padding: 3px 7px; border-radius: 6px; z-index: 2; }

.prod-corpo { padding: 12px 13px 14px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.rating { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--muted); }
.estrelas { color: var(--verde); letter-spacing: 1px; font-size: 13px; }
.prod-nome { font-size: 13.5px; font-weight: 500; color: #333; min-height: 38px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.swatches { display: flex; gap: 5px; }
.swatch { width: 16px; height: 16px; border-radius: 4px; border: 1px solid rgba(0,0,0,.1); }

.preco-bloco { margin-top: 2px; }
.preco-de { font-size: 12px; color: #aaa; text-decoration: line-through; }
.preco-apartir { font-size: 11px; color: var(--muted); }
.preco-now { font-size: 21px; font-weight: 800; color: var(--ink); }
.preco-now small { font-size: 12px; font-weight: 600; color: var(--verde); }
.preco-parc { font-size: 11px; color: var(--muted); }

.comprar {
  margin-top: auto; width: 100%; background: var(--verde); color: #fff; border: 0;
  padding: 11px; border-radius: 8px; font: inherit; font-weight: 600; font-size: 14px;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .15s ease;
}
.comprar:hover { background: var(--verde-esc); }

/* ===================== Banner rosa ===================== */
.banner-rosa { background: var(--cinza); padding: 8px 0 44px; }
.banner-rosa-in {
  max-width: var(--max); margin: 0 auto; background: var(--rosa); color: #fff; border-radius: 18px;
  display: grid; grid-template-columns: 220px 1fr; align-items: center; gap: 24px;
  padding: 26px clamp(20px, 4vw, 44px); margin-inline: clamp(14px, 4vw, 32px);
}
.banner-foto { font-size: 80px; text-align: center; }
.banner-txt h3 { font-size: clamp(22px, 3vw, 30px); margin-bottom: 8px; }
.banner-txt p { opacity: .92; margin: 0 0 16px; max-width: 50ch; }

/* ===================== Faça você mesmo ===================== */
.faca { display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px; align-items: center; }
.faca-texto h2 { font-size: clamp(24px, 3vw, 34px); margin-bottom: 10px; }
.faca-texto p { color: var(--muted); }
.passos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.passo { background: var(--cinza); border-radius: 14px; padding: 18px; text-align: center; position: relative; }
.passo-num {
  position: absolute; top: 12px; left: 12px; width: 24px; height: 24px; border-radius: 50%;
  background: var(--rosa); color: #fff; font-size: 13px; font-weight: 700; display: grid; place-items: center;
}
.passo-img { font-size: 46px; margin: 8px 0 10px; }
.passo b { font-size: 13px; }

/* ===================== Avaliações ===================== */
.avals { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.aval { background: #fff; border: 1px solid var(--linha); border-radius: 12px; padding: 18px; }
.aval .estrelas { font-size: 15px; margin-bottom: 8px; }
.aval p { font-size: 13px; color: #555; margin: 0 0 14px; }
.aval .quem { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; }
.aval .av { width: 30px; height: 30px; border-radius: 50%; background: var(--verde-claro); display: grid; place-items: center; color: var(--verde-esc); font-weight: 700; }

/* ===================== Quem tá usando ===================== */
.galeria { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.foto-uso { aspect-ratio: 3 / 4; border-radius: 14px; position: relative; overflow: hidden; display: grid; place-items: end start; padding: 12px; }
.foto-uso span { background: rgba(0,0,0,.5); color: #fff; font-size: 12px; padding: 3px 9px; border-radius: 999px; }

/* ===================== Navegue por categoria ===================== */
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cat-card { aspect-ratio: 5 / 4; border-radius: 14px; position: relative; overflow: hidden; display: grid; place-items: center; cursor: pointer; }
.cat-card span { background: #fff; color: var(--ink); font-weight: 600; font-size: 14px; padding: 8px 18px; border-radius: 999px; box-shadow: var(--shadow); }
.cat-card:hover { transform: translateY(-3px); transition: transform .15s ease; }

/* ===================== Rodapé ===================== */
.rodape { background: #1f241d; color: #cfd3ca; margin-top: 40px; }
.news {
  max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr auto; gap: 20px;
  align-items: center; padding: 30px clamp(14px, 4vw, 32px); border-bottom: 1px solid rgba(255,255,255,.1);
}
.news h3 { color: #fff; font-size: 20px; }
.news p { font-size: 13px; margin: 6px 0 0; }
.news-form { display: flex; gap: 8px; }
.news-form input { border: 0; border-radius: 8px; padding: 12px 14px; font: inherit; min-width: 240px; }

.rodape-cols {
  max-width: var(--max); margin: 0 auto; display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr); gap: 24px;
  padding: 36px clamp(14px, 4vw, 32px);
}
.rodape-cols h4 { color: #fff; font-size: 14px; margin-bottom: 12px; }
.rodape-cols a { display: block; font-size: 13px; padding: 4px 0; color: #b8bcb2; }
.rodape-cols a:hover { color: #fff; }
.rodape-sobre { font-size: 13px; margin-top: 10px; max-width: 32ch; }
.rodape-base {
  text-align: center; font-size: 12px; color: #8b9085;
  padding: 16px; border-top: 1px solid rgba(255,255,255,.1);
}

/* ===================== Sacola (drawer) ===================== */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.42); opacity: 0; visibility: hidden;
  transition: opacity .25s ease, visibility .25s; z-index: 60; }
.overlay.ativo { opacity: 1; visibility: visible; }
.sacola { position: fixed; top: 0; right: 0; z-index: 70; width: min(420px, 100%); height: 100dvh;
  background: #fff; display: flex; flex-direction: column; transform: translateX(100%);
  transition: transform .28s cubic-bezier(.22,.61,.36,1); box-shadow: -20px 0 50px -30px rgba(0,0,0,.5); }
.sacola.ativo { transform: translateX(0); }
.sacola-topo { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--linha); }
.sacola-topo h3 { font-size: 18px; }
.fechar { background: none; border: 0; font-size: 26px; cursor: pointer; color: var(--muted); line-height: 1; }
.sacola-itens { flex: 1; overflow-y: auto; padding: 6px 20px; }
.item { display: grid; grid-template-columns: 52px 1fr auto; gap: 12px; align-items: center; padding: 13px 0; border-bottom: 1px solid var(--linha); }
.item-foto { width: 52px; height: 52px; border-radius: 8px; overflow: hidden; }
.item-foto .ph { width: 100%; height: 100%; display: grid; place-items: center; font-size: 9px; color: #fff; padding: 4px; text-align: center; }
.item-nome { font-weight: 600; font-size: 13px; }
.item-preco { color: var(--muted); font-size: 12px; }
.qtd { display: inline-flex; align-items: center; gap: 8px; margin-top: 6px; }
.qtd button { width: 24px; height: 24px; border-radius: 6px; border: 1px solid var(--linha); background: #fff; cursor: pointer; font-size: 15px; }
.qtd span { min-width: 18px; text-align: center; font-size: 13px; }
.remover { background: none; border: 0; color: var(--muted); font-size: 11px; cursor: pointer; text-decoration: underline; }
.sacola-vazia { padding: 40px 20px; text-align: center; color: var(--muted); }
.link { background: none; border: 0; color: var(--verde); font: inherit; font-weight: 600; cursor: pointer; text-decoration: underline; }

.sacola-pe { border-top: 1px solid var(--linha); padding: 16px 20px 20px; background: var(--cinza); }
.frete label { font-size: 13px; font-weight: 600; color: var(--muted); display: block; margin-bottom: 8px; }
.frete-linha { display: flex; gap: 8px; }
.frete-linha input { flex: 1; padding: 11px 12px; border: 1px solid var(--linha); border-radius: 9px; font: inherit; font-size: 14px; background: #fff; }
.frete-linha button { background: var(--ink); color: #fff; border: 0; padding: 0 16px; border-radius: 9px; font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; }
.frete-status { font-size: 13px; color: var(--muted); margin-top: 8px; }
.frete-status.erro { color: #c0291f; }
.frete-opcoes { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.opcao { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--linha); border-radius: 9px; cursor: pointer; font-size: 13px; background: #fff; }
.opcao:hover { border-color: var(--verde); }
.opcao input { accent-color: var(--verde); }
.opcao .nome { font-weight: 600; }
.opcao .prazo { color: var(--muted); }
.opcao .preco { margin-left: auto; font-weight: 700; color: var(--verde-esc); }
.totais { margin: 16px 0 12px; display: flex; flex-direction: column; gap: 6px; }
.totais .linha { display: flex; justify-content: space-between; font-size: 14px; color: var(--muted); }
.totais .total { color: var(--ink); font-weight: 700; font-size: 18px; padding-top: 8px; border-top: 1px solid var(--linha); }
.pagar { width: 100%; background: var(--verde); color: #fff; border: 0; padding: 14px; border-radius: 10px; font: inherit; font-weight: 700; font-size: 16px; cursor: pointer; }
.pagar:hover:not(:disabled) { background: var(--verde-esc); }
.pagar:disabled { background: #b7bbb4; cursor: not-allowed; }
.aviso-pagamento { text-align: center; font-size: 12px; color: var(--muted); margin: 10px 0 0; }

/* ===================== Popup ===================== */
.popup { position: fixed; inset: 0; background: rgba(0,0,0,.5); display: none; place-items: center; z-index: 80; padding: 20px; }
.popup.ativo { display: grid; }
.popup-card { background: #fff; border-radius: 16px; max-width: 380px; width: 100%; padding: 30px 26px; text-align: center; position: relative; }
.popup-x { position: absolute; top: 12px; right: 14px; background: none; border: 0; font-size: 22px; cursor: pointer; color: var(--muted); }
.popup-tag { display: inline-block; background: var(--verde-claro); color: var(--verde-esc); font-size: 12px; font-weight: 700; padding: 4px 12px; border-radius: 999px; }
.popup-card h3 { font-size: 22px; margin: 12px 0 6px; }
.popup-card p { color: var(--muted); font-size: 14px; margin: 0 0 16px; }
.popup-form { display: flex; flex-direction: column; gap: 10px; }
.popup-form input { border: 1px solid var(--linha); border-radius: 9px; padding: 12px; font: inherit; }

/* ===================== WhatsApp flutuante ===================== */
.whats { position: fixed; right: 18px; bottom: 18px; z-index: 55; width: 56px; height: 56px;
  background: #25d366; color: #fff; border-radius: 50%; display: grid; place-items: center;
  font-size: 26px; box-shadow: var(--shadow); }
.whats:hover { transform: scale(1.06); transition: transform .15s ease; }

/* ===================== Responsivo ===================== */
@media (max-width: 920px) {
  .avals, .galeria, .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .rodape-cols { grid-template-columns: 1fr 1fr; }
  .faca { grid-template-columns: 1fr; }
  .banner-rosa-in { grid-template-columns: 1fr; text-align: center; }
  .banner-foto { display: none; }
  .news { grid-template-columns: 1fr; }
  .news-form input { min-width: 0; flex: 1; }
}
@media (max-width: 620px) {
  .busca { display: none; }
  .menu { gap: 16px; font-size: 13px; }
  .secao-cabeca.linha { flex-direction: row; }
  .trilho { grid-auto-columns: 72%; }
}
@media (prefers-reduced-motion: reduce) { * { transition: none !important; scroll-behavior: auto !important; } }
:focus-visible { outline: 2px solid var(--verde); outline-offset: 2px; border-radius: 4px; }

/* ===== Seletor de variação (produto variável) ===== */
.var-label { font-size: 11px; color: var(--muted); font-weight: 600; display: block; margin-bottom: 2px; }
.sel-var {
  width: 100%; padding: 8px 10px; border: 1px solid var(--linha); border-radius: 8px;
  font: inherit; font-size: 13px; background: #fff; cursor: pointer; color: var(--ink);
}
.sel-var:focus { outline: 2px solid var(--verde-claro); border-color: var(--verde); }

/* ============================================================
   AJUSTES DOURADO + NOVO LAYOUT (4 produtos)
   ============================================================ */

/* Texto escuro sobre botões dourados (melhor contraste) */
.btn-verde, .comprar, .pagar, .busca button { color: #1f1c14; }
.btn-verde:hover, .comprar:hover, .pagar:hover:not(:disabled) { color: #1f1c14; }
.hero-off { color: #1f1c14; }
.logo-mark { color: #1f1c14; }
.contador { background: var(--ouro); color: #1f1c14; }
.selo.oferta { background: var(--ouro); color: #1f1c14; }
.btn-branco { color: var(--ouro-esc); }
.promo-bar strong { color: #f0d68a; }

/* Promo bar e banner ficam grafite (premium) */
.promo-bar { letter-spacing: .02em; }

/* ---------- Grid de produtos (substitui os carrosséis) ---------- */
.grade {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(14px, 2vw, 22px);
}
.grade .produto { scroll-snap-align: unset; }
@media (max-width: 920px) { .grade { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .grade { grid-template-columns: 1fr; } }

/* destaque sutil no card do produto variável */
.produto[data-variavel] { box-shadow: 0 0 0 1.5px var(--ouro) inset; }

/* ---------- Diferenciais ---------- */
.dif-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.dif {
  background: #fff; border: 1px solid var(--linha); border-radius: 14px;
  padding: 24px 18px; text-align: center;
}
.dif .ic {
  width: 54px; height: 54px; margin: 0 auto 12px; border-radius: 50%;
  display: grid; place-items: center; font-size: 26px;
  background: var(--ouro-claro);
}
.dif b { display: block; font-size: 15px; margin-bottom: 6px; }
.dif p { font-size: 13px; color: var(--muted); margin: 0; }
@media (max-width: 920px) { .dif-grid { grid-template-columns: repeat(2, 1fr); } }

/* banner em grafite com borda dourada */
.banner-rosa-in { border: 1px solid rgba(184,144,47,.4); }

/* ============================================================
   DOIS BOTÕES NO CARD + MODAL + CONTATO (modernização)
   ============================================================ */

/* ---- Dois botões no card ---- */
.card-acoes { display: flex; gap: 8px; margin-top: auto; }
.btn-ver {
  flex: 1; background: #fff; color: var(--ouro-esc); border: 1.5px solid var(--ouro);
  border-radius: 9px; padding: 10px; font: inherit; font-weight: 600; font-size: 13px;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s ease, color .15s ease;
}
.btn-ver:hover { background: var(--ouro-claro); }
.btn-add {
  flex: 1; background: var(--ouro); color: #1f1c14; border: 0;
  border-radius: 9px; padding: 10px; font: inherit; font-weight: 700; font-size: 13px;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s ease, transform .15s ease;
}
.btn-add:hover { background: var(--ouro-esc); }
.btn-add.largo, .btn-ver.largo { width: 100%; flex: none; padding: 13px; font-size: 15px; }
.btn-ver.grande { display: inline-flex; flex: none; padding: 13px 26px; font-size: 15px; }

/* card um pouco mais moderno */
.produto { border-radius: 16px; }
.prod-foto { background: var(--cinza); }

/* ---- Modal de produto ---- */
.modal { position: fixed; inset: 0; background: rgba(20,18,14,.55); display: none; place-items: center; z-index: 90; padding: 18px; }
.modal.ativo { display: grid; }
.modal-card { background: #fff; border-radius: 18px; max-width: 760px; width: 100%; max-height: 92vh; overflow: auto; position: relative; box-shadow: var(--shadow); }
.modal-x { position: absolute; top: 12px; right: 14px; background: #fff; border: 1px solid var(--linha); width: 36px; height: 36px; border-radius: 50%; font-size: 20px; line-height: 1; cursor: pointer; z-index: 2; }
.modal-grid { display: grid; grid-template-columns: 1fr 1fr; }
.modal-foto { background: var(--cinza); display: grid; place-items: center; }
.modal-foto img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1 / 1; }
.modal-info { padding: 28px 30px; display: flex; flex-direction: column; gap: 10px; }
.modal-info h3 { font-size: 23px; }
.modal-preco { display: flex; align-items: baseline; gap: 10px; }
.modal-preco .preco-now { font-size: 27px; font-weight: 800; }
.modal-preco .preco-de { font-size: 15px; }
.modal-desc { color: #555; font-size: 14px; line-height: 1.65; }
.modal-specs { display: flex; flex-direction: column; gap: 7px; margin: 4px 0 10px; }
.spec { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; border-bottom: 1px dashed var(--linha); padding-bottom: 7px; }
.spec b { color: var(--ink); font-weight: 600; }
.spec span { color: var(--muted); text-align: right; }
.modal .sel-var { margin-bottom: 6px; }
.modal .var-label { margin-top: 4px; }
@media (max-width: 680px) { .modal-grid { grid-template-columns: 1fr; } .modal-foto img { aspect-ratio: 16 / 10; } }

/* ---- Seção de contato ---- */
.contato-sec { padding-top: 20px; }
.contato-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
.contato-info h2 { font-size: clamp(24px, 3vw, 34px); margin: 10px 0 12px; }
.contato-info > p { color: var(--muted); margin: 0 0 18px; }
.contato-itens { list-style: none; padding: 0; margin: 0 0 22px; display: flex; flex-direction: column; gap: 11px; }
.contato-itens li { display: flex; align-items: center; gap: 11px; font-size: 14px; }
.contato-itens span { width: 32px; height: 32px; display: grid; place-items: center; background: var(--ouro-claro); border-radius: 50%; }
.form-contato { background: #fff; border: 1px solid var(--linha); border-radius: 16px; padding: 26px; box-shadow: var(--shadow); }
.form-contato h3 { font-size: 18px; margin-bottom: 14px; }
.campo { margin-bottom: 13px; }
.campo label { display: block; font-size: 12px; font-weight: 600; color: var(--muted); margin-bottom: 5px; }
.campo input, .campo textarea { width: 100%; border: 1px solid var(--linha); border-radius: 9px; padding: 11px 12px; font: inherit; font-size: 14px; background: var(--cinza); color: var(--ink); }
.campo input:focus, .campo textarea:focus { outline: 2px solid var(--ouro-claro); border-color: var(--ouro); background: #fff; }
.campo textarea { resize: vertical; }
.form-msg { font-size: 13px; margin: 10px 0 0; min-height: 18px; }
.form-msg.ok { color: #2e7d32; }
.form-msg.erro { color: #c0291f; }
@media (max-width: 820px) { .contato-grid { grid-template-columns: 1fr; } }

/* ============================================================
   PÁGINA DE PRODUTO (PDP) — estilo do anexo, enxuto
   ============================================================ */
.pdp { background: var(--bg); }
.pdp[hidden] { display: none; }
.pdp-wrap { max-width: var(--max); margin: 0 auto; padding: 18px clamp(14px, 4vw, 32px) 60px; }

.pdp-voltar { background: none; border: 0; color: var(--ouro-esc); font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; padding: 6px 0; }
.pdp-voltar:hover { text-decoration: underline; }
.breadcrumb { font-size: 12px; color: var(--muted); margin: 4px 0 18px; }
.breadcrumb b { color: var(--ink); }

.pdp-top { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 4vw, 48px); align-items: start; }

/* galeria */
.pdp-foto { background: var(--cinza); border-radius: 16px; overflow: hidden; aspect-ratio: 1 / 1; display: grid; place-items: center; }
.pdp-foto img { width: 100%; height: 100%; object-fit: cover; }
.pdp-thumbs { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.pdp-thumb { width: 60px; height: 60px; border-radius: 10px; overflow: hidden; border: 2px solid var(--linha); cursor: pointer; background: var(--cinza); padding: 0; }
.pdp-thumb img { width: 100%; height: 100%; object-fit: cover; }
.pdp-thumb.ativo { border-color: var(--ouro); }

/* painel de compra */
.pdp-selos { display: flex; gap: 8px; margin-bottom: 10px; }
.pdp-compra h1 { font-size: clamp(24px, 3vw, 34px); line-height: 1.1; margin-bottom: 10px; }
.pdp-meta { display: flex; align-items: center; gap: 14px; font-size: 13px; color: var(--muted); margin-bottom: 16px; }
.pdp-meta .rating { display: inline-flex; gap: 5px; align-items: center; }
.pdp-meta .sku { padding-left: 14px; border-left: 1px solid var(--linha); }

.pdp-preco { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.pdp-preco .preco-now { font-size: 32px; font-weight: 800; }
.pdp-preco .preco-de { font-size: 16px; }
.pdp-preco .desc-off { position: static; }

.pdp-compra .var-label { font-size: 13px; margin-bottom: 6px; }
.pdp-compra .sel-var { max-width: 320px; padding: 12px; font-size: 15px; margin-bottom: 18px; }

.pdp-qtd { display: flex; align-items: center; justify-content: space-between; max-width: 320px; margin-bottom: 14px; font-size: 14px; font-weight: 600; }
.stepper { display: inline-flex; align-items: center; border: 1px solid var(--linha); border-radius: 10px; overflow: hidden; }
.stepper button { width: 40px; height: 40px; border: 0; background: #fff; font-size: 20px; cursor: pointer; color: var(--ink); }
.stepper button:hover { background: var(--cinza); }
.stepper span { min-width: 44px; text-align: center; font-size: 16px; font-weight: 700; }

.pdp-total { display: flex; align-items: center; justify-content: space-between; max-width: 320px; margin-bottom: 16px; padding-top: 14px; border-top: 1px solid var(--linha); }
.pdp-total strong { font-size: 22px; }

.pdp-compra .btn-add.largo { max-width: 320px; padding: 15px; font-size: 16px; }

.pdp-frete { display: flex; gap: 8px; max-width: 320px; margin-top: 14px; }
.pdp-frete input { flex: 1; border: 1px solid var(--linha); border-radius: 10px; padding: 11px 12px; font: inherit; font-size: 14px; background: var(--cinza); }
.pdp-frete button { background: var(--ink); color: #fff; border: 0; border-radius: 10px; padding: 0 18px; font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; }
.pdp-frete-res { max-width: 320px; margin-top: 10px; font-size: 13px; color: var(--muted); display: flex; flex-direction: column; gap: 6px; }
.pdp-frete-res .opt { display: flex; justify-content: space-between; background: var(--cinza); border-radius: 8px; padding: 8px 10px; }
.pdp-frete-res .opt b { color: var(--ouro-esc); }

/* benefícios */
.pdp-benef { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 36px 0; }
.benef { background: #fff; border: 1px solid var(--linha); border-radius: 12px; padding: 16px; text-align: center; }
.benef span { font-size: 26px; display: block; margin-bottom: 6px; }
.benef b { font-size: 13px; font-weight: 600; }

/* descrição */
.pdp-desc { border-top: 1px solid var(--linha); padding-top: 26px; }
.pdp-desc h2 { font-size: 20px; margin-bottom: 12px; }
.pdp-desc p { color: #555; font-size: 14.5px; line-height: 1.7; margin: 0 0 16px; max-width: 760px; }
.pdp-desc .modal-specs { max-width: 560px; }

/* relacionados */
.pdp-rel { margin-top: 44px; }
.pdp-rel h2 { font-size: 20px; margin-bottom: 18px; }

@media (max-width: 820px) {
  .pdp-top { grid-template-columns: 1fr; }
  .pdp-benef { grid-template-columns: repeat(2, 1fr); }
  .pdp-compra .sel-var, .pdp-qtd, .pdp-total, .pdp-compra .btn-add.largo, .pdp-frete, .pdp-frete-res { max-width: none; }
}

/* ===== Descrição formatada (subtítulos, listas) ===== */
.pdp-desc h4 { font-size: 15px; margin: 18px 0 8px; color: var(--ink); }
.pdp-desc ul { margin: 0 0 14px; padding-left: 20px; color: #555; font-size: 14.5px; }
.pdp-desc li { margin-bottom: 5px; }
.pdp-desc .nao-inflamavel { display: inline-block; margin-top: 10px; font-weight: 700; color: var(--ouro-esc); font-size: 13px; letter-spacing: .03em; background: var(--ouro-claro); padding: 5px 12px; border-radius: 8px; }

/* ============================================================
   CHECKOUT (dados do cliente + endereço)
   ============================================================ */
.checkout[hidden] { display: none; }
.ck-titulo { font-size: clamp(24px, 3vw, 32px); margin: 6px 0 22px; }
.ck-grid { display: grid; grid-template-columns: 1fr 380px; gap: 30px; align-items: start; }
.ck-form h2 { font-size: 17px; margin: 22px 0 12px; }
.ck-form h2:first-child { margin-top: 0; }
.ck-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ck-form .btn-add.largo { margin-top: 20px; }
.ck-aviso { font-size: 12px; color: var(--muted); text-align: center; margin: 12px 0 0; }

.ck-resumo { background: #fff; border: 1px solid var(--linha); border-radius: 16px; padding: 24px; box-shadow: var(--shadow); position: sticky; top: 90px; }
.ck-resumo h2 { font-size: 17px; margin-bottom: 14px; }
.ck-item { display: flex; justify-content: space-between; gap: 10px; font-size: 13px; padding: 9px 0; border-bottom: 1px solid var(--linha); color: #444; }
.ck-tot { display: flex; justify-content: space-between; font-size: 14px; color: var(--muted); margin-top: 10px; }
.ck-tot.total { color: var(--ink); font-weight: 700; font-size: 19px; border-top: 1px solid var(--linha); padding-top: 12px; margin-top: 12px; }

@media (max-width: 820px) {
  .ck-grid { grid-template-columns: 1fr; }
  .ck-resumo { position: static; order: -1; }
}
