*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root { --bg:#fff; --bg2:#f8f8f6; --border:#f0f0ee; --border2:#e8e8e5; --txt:#111; --txt2:#555; --txt3:#999; --radius:16px; }
body { font-family: 'DM Sans', sans-serif; background: var(--bg2); min-height: 100vh; }
.vitrine { max-width: 430px; margin: 0 auto; background: var(--bg); min-height: 100vh; position: relative; }

/* HEADER */
.header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.92); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--border); padding: 14px 18px; }
.header-top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.logo-wrap { flex: 1; min-width: 0; display: flex; align-items: center; overflow: hidden; }
.logo-wrap.alignLeft { justify-content: flex-start; }
.logo-wrap.alignCenter { justify-content: center; }
.logo-wrap.alignRight { justify-content: flex-end; }
.logo-img { height: 38px; max-width: 130px; object-fit: contain; border-radius: 6px; }
.logo-txt { letter-spacing: -0.5px; line-height: 1.1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* BUSCA */
.search-wrap { position: relative; }
.search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--txt3); pointer-events: none; }
.search-input { width: 100%; padding: 10px 16px 10px 40px; background: var(--bg2); border: none; border-radius: 12px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--txt); outline: none; transition: background .2s; }
.search-input:focus { background: #eeeeeb; }
.search-input::placeholder { color: var(--txt3); }

/* CATEGORIAS */
.cats { display: flex; gap: 8px; padding: 14px 18px; overflow-x: auto; scrollbar-width: none; }
.cats::-webkit-scrollbar { display: none; }
.cat-pill { padding: 8px 18px; border-radius: 100px; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; border: 1.5px solid var(--border2); background: var(--bg); color: var(--txt2); cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: all .2s; }
.cat-pill:hover:not(.ativo) { border-color: #bbb; }

/* SUBTITULO */
.produtos-header { padding: 4px 18px 14px; display: flex; justify-content: space-between; align-items: center; }
.produtos-titulo { font-size: 17px; font-weight: 600; color: var(--txt); }
.produtos-count { font-size: 12px; color: var(--txt3); margin-top: 2px; }

/* GRID */
.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 18px 100px; }
.card { background: var(--bg); border-radius: var(--radius); border: 1px solid var(--border); overflow: hidden; transition: transform .2s, box-shadow .2s; }
.card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.07); }

.card-img { aspect-ratio: 1; overflow: hidden; background: var(--bg2); position: relative; display: flex; align-items: center; justify-content: center; color: #d0d0cc; }
.card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card:hover .card-img img { transform: scale(1.04); }
.card-tag { position: absolute; top: 8px; left: 8px; background: var(--dest); color: #fff; font-size: 10px; font-weight: 700; padding: 4px 8px; border-radius: 6px; letter-spacing: .3px; }

.card-body { padding: 10px 10px 12px; }
.card-nome { font-size: 12px; font-weight: 500; color: #222; line-height: 1.4; margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-precos { display: flex; gap: 5px; align-items: baseline; margin-bottom: 10px; flex-wrap: wrap; }
.preco-atual { font-size: 14px; font-weight: 700; color: var(--txt); }
.preco-antigo { font-size: 11px; color: #bbb; text-decoration: line-through; }
.preco-none { font-size: 11px; color: var(--txt3); font-style: italic; }

.card-btn { width: 100%; padding: 9px 0; color: #fff; border: none; border-radius: 10px; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 600; cursor: pointer; transition: opacity .2s; letter-spacing: .2px; display: flex; align-items: center; justify-content: center; gap: 5px; }
.card-btn:hover { opacity: .85; }
.card-btn svg { flex-shrink: 0; }

.empty { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: var(--txt3); font-size: 14px; }

/* WHATSAPP FLUTUANTE */
.wpp-btn { position: fixed; bottom: 24px; right: max(18px, calc(50% - 215px + 18px)); width: 52px; height: 52px; border-radius: 50%; background: #25D366; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(37,211,102,.4); z-index: 200; transition: transform .2s; }
.wpp-btn:hover { transform: scale(1.08); }

/* SLIDES */
.vt-slides { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--bg2); }
.vt-slides-track { display: flex; height: 100%; transition: transform .5s cubic-bezier(.32,.72,0,1); will-change: transform; }
.vt-slide { flex: 0 0 100%; height: 100%; position: relative; }
.vt-slide img, .vt-slide video { width: 100%; height: 100%; object-fit: cover; display: block; }
.vt-slides-dots {
  position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 2;
  background: rgba(0,0,0,.25); padding: 6px 10px; border-radius: 100px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.vt-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.6); border: none; cursor: pointer; padding: 0; transition: all .25s ease; }
.vt-dot-active { background: #fff; width: 22px; border-radius: 4px; }

/* BUSCA FORA DO HEADER */
.vt-busca-wrap { padding: 16px 0 4px; }
.vt-busca-wrap .cats { padding: 0 18px 12px; }
.vt-busca-wrap .search-wrap { padding: 0 18px; }
.header { padding: 14px 18px 10px; }
.header-top { margin-bottom: 0; }
