:root{--bg:#0B0B0B;--card:#1A1A1A;--line:#2c2c2c;--txt:#FFFFFF;--mut:#9aa3af;--accent:#F2B233;--ok:#3ecf8e;--err:#ff6b6b}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--txt)}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 20px;background:var(--card);border-bottom:2px solid var(--accent);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-logo{height:82px;width:auto;display:block;flex:0 0 auto}
.brand-text{display:flex;flex-direction:column;min-width:0}
.brand-name{font-size:19px;font-weight:800;color:var(--txt);line-height:1.1;letter-spacing:.01em}
.brand-sub{font-size:12px;color:var(--accent);font-weight:700;margin-top:1px}
.brand-meta{font-size:11px;color:var(--mut);line-height:1.3;margin-top:3px;max-width:520px}
@media(max-width:820px){
  .brand-logo{height:56px}
  .brand-name{font-size:16px}
  .brand-meta{display:none}
  .topbar{padding:10px 14px}
}
/* --- logo no carrinho --- */
.cart-head{display:flex;align-items:center;gap:10px;margin:0 0 10px}
.cart-logo{height:34px;width:auto;display:block}
.cart-head h2{margin:0;font-size:16px}
/* --- rodapé profissional --- */
.site-footer{background:var(--card);border-top:2px solid var(--accent);margin-top:30px}
.footer-inner{max-width:1200px;margin:0 auto;padding:26px 20px;display:grid;grid-template-columns:1.2fr 1fr 1fr 1.2fr;gap:22px}
.footer-brand{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.footer-logo{height:74px;width:auto;display:block}
.footer-name{font-weight:800;font-size:16px;color:var(--txt)}
.footer-link{background:transparent;border:1px solid var(--line);color:var(--accent);padding:6px 12px;border-radius:8px;cursor:pointer;font-weight:700;font-size:12px}
.footer-link:hover{border-color:var(--accent)}
.footer-col h4{font-size:12px;color:var(--accent);margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em}
.footer-col p{margin:3px 0;font-size:13px;color:var(--mut)}
.footer-col p strong{color:var(--txt)}
.footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--mut)}
.footer-base{border-top:1px solid var(--line);text-align:center;padding:12px;font-size:12px;color:var(--mut)}
@media(max-width:820px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-inner{grid-template-columns:1fr}}
/* --- modal institucional --- */
.sobre-card{max-width:460px;text-align:center}
.sobre-logo{height:120px;width:auto;display:block;margin:6px auto 8px}
.sobre-title{margin:0;font-size:20px}
.sobre-sub{color:var(--accent);font-weight:700;margin:2px 0 14px}
.sobre-card p{font-size:14px;line-height:1.55;color:var(--txt);margin:8px 0}
.cart-toggle{display:none;background:var(--accent);border:0;color:#111;font-weight:700;padding:8px 12px;border-radius:8px}
.layout{display:grid;grid-template-columns:1fr 340px;gap:16px;padding:16px;max-width:1200px;margin:0 auto}
.controls{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
#search{padding:10px 12px;border-radius:8px;border:1px solid var(--line);background:var(--card);color:var(--txt);font-size:15px}
.cats{display:flex;gap:8px;flex-wrap:wrap}
.cats button{background:var(--card);border:1px solid var(--line);color:var(--txt);padding:6px 12px;border-radius:20px;cursor:pointer}
.cats button.active{background:var(--accent);color:#111;border-color:var(--accent);font-weight:600}
.selects{display:flex;gap:8px;flex-wrap:wrap}
.selects select{flex:1;min-width:120px;padding:8px;border-radius:8px;border:1px solid var(--line);background:var(--card);color:var(--txt)}
.count{color:var(--mut);font-size:13px;margin-bottom:8px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.product{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
.product img{width:100%;height:140px;object-fit:contain;background:#fff}
.product .info{padding:8px;display:flex;flex-direction:column;gap:4px;flex:1}
.product .title{font-size:13px;line-height:1.2;font-weight:600}
.product .meta{font-size:11px;color:var(--mut)}
.product .price{color:var(--accent);font-weight:700}
.product button{margin:8px;padding:8px;border:0;border-radius:8px;background:var(--ok);color:#0a1a12;font-weight:700;cursor:pointer}
.cart{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px;position:sticky;top:72px;height:fit-content;max-height:calc(100vh - 90px);overflow:auto}
.cart h2{margin:0 0 8px;font-size:16px}
.cart-items{display:flex;flex-direction:column;gap:8px}
.cart-items .empty{color:var(--mut);font-size:13px}
.ci{display:flex;gap:8px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:8px}
.ci .cititle{flex:1;font-size:12px}
.ci .qty{display:flex;align-items:center;gap:4px}
.ci .qty button{width:24px;height:24px;border:1px solid var(--line);background:var(--bg);color:var(--txt);border-radius:6px;cursor:pointer}
.ci .rm{background:transparent;border:0;color:var(--err);cursor:pointer;font-size:16px}
.cart-total{margin:10px 0;font-size:15px}
.checkout{display:flex;flex-direction:column;gap:8px}
.checkout input{padding:9px;border-radius:8px;border:1px solid var(--line);background:var(--bg);color:var(--txt)}
.checkout button{padding:11px;border:0;border-radius:8px;background:var(--accent);color:#111;font-weight:700;cursor:pointer}
.checkout button:disabled{opacity:.5;cursor:not-allowed}
.msg{font-size:13px;min-height:18px}
.msg.ok{color:var(--ok)} .msg.err{color:var(--err)}
.msg-nota{font-size:11px;color:var(--mut);margin:6px 0 0;text-align:center;line-height:1.4}
@media(max-width:820px){
  .layout{grid-template-columns:1fr}
  .cart-toggle{display:block}
  .cart{position:fixed;right:0;top:0;bottom:0;width:88%;max-width:360px;border-radius:0;transform:translateX(100%);transition:transform .25s;z-index:20}
  .cart.open{transform:translateX(0)}
}

/* --- Card: linha de estilo/ABV/IBU + área clicável --- */
.product-open{cursor:pointer;display:flex;flex-direction:column;flex:1}
.product-open:hover .title{color:var(--accent)}
.style-line{display:flex;flex-wrap:wrap;gap:4px 8px;align-items:center;font-size:10.5px}
.style-line .estilo{background:rgba(245,166,35,.15);color:var(--accent);border:1px solid rgba(245,166,35,.35);padding:1px 7px;border-radius:20px;font-weight:600}
.style-line .bju{color:var(--mut)}

/* --- Modal de detalhes --- */
body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(2px)}
.modal-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:14px;max-width:680px;width:100%;max-height:90vh;overflow:auto;padding:20px;z-index:1}
.modal-close{position:absolute;top:10px;right:12px;background:transparent;border:0;color:var(--mut);font-size:26px;line-height:1;cursor:pointer}
.modal-close:hover{color:var(--txt)}
.md-head{display:flex;gap:18px;flex-wrap:wrap}
.md-photo{flex:0 0 200px;max-width:200px}
.md-photo img{width:100%;height:200px;object-fit:contain;background:#fff;border-radius:10px}
.md-head-info{flex:1;min-width:220px;display:flex;flex-direction:column;gap:6px}
.md-head-info h2{margin:0;font-size:18px;line-height:1.25}
.md-brand{font-size:12px;color:var(--mut)}
.md-estilo{align-self:flex-start;background:rgba(245,166,35,.15);color:var(--accent);border:1px solid rgba(245,166,35,.35);padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600}
.md-price{color:var(--accent);font-weight:800;font-size:22px;margin-top:2px}
.md-stats{display:flex;gap:8px;margin:6px 0}
.md-stats .stat{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:6px 8px;text-align:center}
.md-stats .stat span{display:block;font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em}
.md-stats .stat strong{font-size:14px}
.md-add{margin-top:4px;padding:11px;border:0;border-radius:8px;background:var(--ok);color:#0a1a12;font-weight:700;cursor:pointer}
.md-sec{margin-top:16px;border-top:1px solid var(--line);padding-top:12px}
.md-sec h3{margin:0 0 6px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut)}
.md-sec p{margin:0;font-size:14px;line-height:1.5}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:4px 10px;font-size:12px}
@media(max-width:520px){.md-photo{flex-basis:100%;max-width:none}}

/* --- Promoções --- */
.product{position:relative}
.product.is-promo{border-color:var(--err)}
.selo-promo{position:absolute;top:8px;left:8px;z-index:2;background:var(--err);color:#fff;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:6px;letter-spacing:.02em;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.price-wrap{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px}
.price-wrap .price{color:var(--accent);font-weight:700}
.old-price{color:var(--mut);text-decoration:line-through;font-size:12px}
.economia{background:rgba(62,207,142,.15);color:var(--ok);border:1px solid rgba(62,207,142,.4);font-size:10px;font-weight:700;padding:1px 6px;border-radius:6px}
.empty-state{grid-column:1/-1;text-align:center;color:var(--mut);padding:40px 12px;font-size:15px}
/* modal */
.md-photo{position:relative}
.md-selo{top:8px;left:8px}
.md-price-wrap{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px}
.md-old-price{color:var(--mut);text-decoration:line-through;font-size:15px}
.md-economia{background:rgba(62,207,142,.15);color:var(--ok);border:1px solid rgba(62,207,142,.4);font-size:12px;font-weight:700;padding:2px 8px;border-radius:6px}
/* unidade de venda */
.venda-line{font-size:11px;color:var(--mut);font-weight:600}
.md-venda{font-size:13px;color:var(--txt);background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:3px 10px;align-self:flex-start}

/* --- Carrossel de banners --- */
.banner-carousel{position:relative;max-width:1200px;margin:16px auto 0;padding:0 16px;box-sizing:border-box}
.banner-carousel[hidden]{display:none}
.bc-track{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.35);height:200px}
.bc-slide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;visibility:hidden;transition:opacity .5s ease;background:var(--card)}
.bc-slide.active{opacity:1;visibility:visible}
/* foto real (img+overlay) por cima do gradiente; o container some inteiro (onerror)
   se o arquivo faltar, deixando só o gradiente da marca + texto */
.bc-media{position:absolute;inset:0;z-index:0}
.bc-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bc-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.45) 45%,rgba(0,0,0,.15) 100%)}
.bc-content{position:relative;z-index:3;padding:24px 28px;max-width:58%;display:flex;flex-direction:column;gap:8px}
/* faixa de PRODUTOS REAIS (imagens do cadastro) sobre o fundo, à direita */
.bc-products{position:absolute;top:0;bottom:0;right:20px;z-index:2;display:flex;align-items:flex-end;justify-content:flex-end;gap:0;max-width:48%;padding-bottom:14px;pointer-events:none}
.bc-prod{height:80%;width:auto;max-width:20%;object-fit:contain;object-position:bottom;filter:drop-shadow(0 7px 11px rgba(0,0,0,.6));margin-left:-6px}
/* telas estreitas: prioriza o texto, reduz a faixa de produtos */
@media(max-width:620px){
  .pf-hc-products,.bc-products{max-width:42%;opacity:.92}
  .pf-hc-prod{max-width:30%}
  .bc-prod{max-width:26%}
  .pf-hc-content,.bc-content{max-width:64%}
}
.bc-tipo{align-self:flex-start;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);padding:2px 10px;border-radius:20px}
.bc-title{font-size:26px;font-weight:800;line-height:1.15;text-shadow:0 1px 6px rgba(0,0,0,.45)}
.bc-sub{font-size:14px;opacity:.95;line-height:1.35;text-shadow:0 1px 5px rgba(0,0,0,.4)}
.bc-cta{align-self:flex-start;margin-top:6px;background:var(--accent);color:#111;font-weight:700;border:0;border-radius:8px;padding:9px 16px;font-size:14px;cursor:pointer}
.bc-cta:hover{filter:brightness(1.05)}
.bc-arrow{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;border:0;background:rgba(0,0,0,.45);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3}
.bc-arrow:hover{background:rgba(0,0,0,.7)}
.bc-prev{left:26px}.bc-next{right:26px}
.bc-dots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:7px;z-index:3}
.bc-dot{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer;padding:0}
.bc-dot.active{background:#fff;width:22px;border-radius:5px}
@media(max-width:820px){
  .bc-track{height:170px}
  .bc-content{max-width:88%;padding:18px 20px}
  .bc-title{font-size:20px}
  .bc-sub{font-size:13px}
  .bc-prev{left:18px}.bc-next{right:18px}
  .bc-arrow{width:32px;height:32px;font-size:19px}
}

/* --- Seção Mais Vendidos (destaques) — reusa o card .product do catálogo --- */
.destaques{max-width:1200px;margin:18px auto 0;padding:0 16px;box-sizing:border-box}
.destaques[hidden]{display:none}
.destaques-title{font-size:18px;font-weight:800;margin:0 0 12px}
.dq-secao{margin-bottom:24px}
.dq-secao:last-child{margin-bottom:0}
/* seletor de perfil */
.perfil-selector{max-width:1200px;margin:18px auto 0;padding:0 16px;box-sizing:border-box}
.perfil-titulo{font-size:18px;font-weight:800;margin:0 0 12px}
.perfil-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.perfil-card{display:flex;flex-direction:column;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 8px;cursor:pointer;color:var(--txt);transition:border-color .15s}
.perfil-card:hover{border-color:var(--accent)}
.perfil-card.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(242,178,51,.28)}
.perfil-icon{color:var(--accent);line-height:0;display:flex}
.perfil-icon svg{width:30px;height:30px}
.perfil-nome{font-size:11.5px;font-weight:600;text-align:center;line-height:1.2}
@media(max-width:820px){
  .perfil-grid{display:flex;overflow-x:auto;gap:10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .perfil-card{flex:0 0 42%;scroll-snap-align:start}
}
/* subgrupos (Compre Junto / Recomendado) */
.cj-grupo{margin-bottom:14px}
.cj-grupo:last-child{margin-bottom:0}
.cj-titulo{font-size:13px;color:var(--mut);margin:0 0 8px}
.cj-titulo strong{color:var(--accent)}
.dq-flash-secao .product{border-color:rgba(242,178,51,.5)}
.destaques-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.destaques-row .product-open{cursor:pointer}
.destaques-row .product-open:hover .title{color:var(--accent)}
.dq-ver{margin:8px;padding:8px;border:0;border-radius:8px;background:var(--accent);color:#111;font-weight:700;cursor:pointer}
.dq-ver:hover{filter:brightness(1.05)}
.product.dq-flash{outline:3px solid var(--accent);outline-offset:2px}
@media(max-width:820px){
  .destaques-row{display:flex;overflow-x:auto;gap:12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .destaques-row .product{flex:0 0 78%;scroll-snap-align:start}
}

/* --- Bloco de preço comercial DE -> POR --- */
.preco-bloco{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.pg{display:flex;flex-direction:column;line-height:1.15}
.pg-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut);font-weight:700}
.pg-de{font-size:11px;color:var(--mut);text-decoration:line-through}
.pg-por{font-size:14px;color:var(--accent);font-weight:700}
.pg--principal .pg-por{font-size:19px;font-weight:800}
.economia-badge{align-self:flex-start;background:rgba(62,207,142,.15);color:var(--ok);border:1px solid rgba(62,207,142,.4);font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;margin-top:1px}
/* no modal, preço principal ainda maior */
.md-head-info .pg--principal .pg-por{font-size:24px}
.md-head-info .economia-badge{font-size:12px;padding:3px 10px}

/* --- Carrinho detalhado (De/Por + economia + totais) --- */
.ci .cititle{display:flex;flex-direction:column;gap:2px}
.ci-head{font-size:12px;font-weight:600;line-height:1.25}
.ci-sub{font-size:11px;color:var(--mut)}
.ci-depor{font-size:11px;color:var(--txt)}
.ci-subtotal{font-size:12px}
.ci-subtotal strong{color:var(--accent)}
.ci-eco{font-size:11px;color:var(--ok);font-weight:700}
.cart-total{display:flex;flex-direction:column;gap:3px}
.ct-line{display:flex;justify-content:space-between;font-size:13px;color:var(--mut)}
.ct-line .ct-desc{color:var(--ok);font-weight:700}
.ct-final{font-size:15px;color:var(--txt);border-top:1px solid var(--line);padding-top:6px;margin-top:3px}
.ct-final strong{color:var(--accent)}

/* ===== Catálogo PF / Cliente Final ===== */
.pf-hero{max-width:1200px;margin:14px auto 0;padding:18px 16px;box-sizing:border-box}
.pf-hero h1{font-size:24px;font-weight:800;margin:0 0 6px}
.pf-hero p{margin:0;color:var(--mut);font-size:14px}
#pfGrid.grid{grid-template-columns:repeat(auto-fill,minmax(192px,1fr));gap:16px}
.pf-product{display:flex;flex-direction:column;overflow:hidden;border-radius:14px;background:var(--card);border:1px solid var(--line);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.pf-product:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.45);border-color:rgba(242,178,51,.5)}
.pf-thumb{position:relative;aspect-ratio:1/1;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}
.pf-thumb img{width:100%;height:100%;object-fit:contain;transition:transform .35s ease}
.pf-img-fallback{object-fit:contain!important;padding:22%;opacity:.32;filter:grayscale(.3);background:#fff;transform:none!important}
.pf-product:hover .pf-thumb img{transform:scale(1.06)}
.pf-info{padding:11px 13px 13px;display:flex;flex-direction:column;gap:5px;flex:1}
.pf-marca{font-size:10.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.pf-nome{font-size:14px;font-weight:700;line-height:1.25;cursor:pointer;transition:color .13s}
.pf-nome:hover{color:var(--accent)}
.pf-chips{display:flex;flex-wrap:wrap;gap:5px;margin:2px 0 1px}
.pf-chip{font-size:10px;font-weight:600;color:var(--mut);background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:2px 8px;white-space:nowrap}
.pf-chip--style{color:var(--accent);background:rgba(242,178,51,.12);border-color:rgba(242,178,51,.32)}
.pf-chip--zero{color:#7fd6ff;background:rgba(80,170,220,.12);border-color:rgba(80,170,220,.35)}
.pf-chip--gf{color:#8fe6a3;background:rgba(80,200,120,.12);border-color:rgba(80,200,120,.35)}
.pf-preco{display:flex;align-items:baseline;gap:6px;margin-top:6px;flex-wrap:wrap}
.pf-preco-val{font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-.01em}
.pf-preco-un{font-size:11.5px;color:var(--mut)}
.pf-preco-cx{font-size:11px;color:var(--mut)}
.pf-disp{font-size:11px;font-weight:700;color:var(--ok);margin-top:1px}
.pf-min-compra{font-size:11px;font-weight:600;color:var(--mut);margin-top:1px}
.pf-actions{display:flex;gap:7px;margin-top:9px}
.pf-product .pf-add{flex:1;margin:0;background:var(--accent);color:#0B0B0B;border:0;border-radius:10px;padding:10px;font-weight:800;cursor:pointer;font-size:13px;transition:filter .12s ease,transform .1s ease}
.pf-product .pf-add:hover{filter:brightness(1.06)}
.pf-product .pf-add.added{background:var(--ok);color:#06231a}
.pf-product .pf-details{flex:0 0 auto;margin:0;background:transparent;color:var(--mut);border:1px solid var(--line);border-radius:10px;padding:10px 11px;font-weight:700;cursor:pointer;font-size:12px;white-space:nowrap;transition:border-color .13s,color .13s}
.pf-product .pf-details:hover{border-color:var(--accent);color:var(--accent)}
/* botão Comprar dentro do modal segue a marca também */
.pf-md-add{width:100%;margin:0;background:var(--accent);color:#0B0B0B;border:0;border-radius:11px;padding:13px;font-weight:800;cursor:pointer;font-size:15px;transition:filter .12s ease}
.pf-md-add:hover{filter:brightness(1.06)}
/* selos no thumb */
.pf-badge{position:absolute;top:9px;left:9px;z-index:2;font-size:10.5px;font-weight:800;letter-spacing:.02em;padding:4px 9px;border-radius:20px;box-shadow:0 3px 8px rgba(0,0,0,.3)}
.pf-badge--top{background:linear-gradient(180deg,#f4cf7e,#e0a52f);color:#3a2606}
.pf-badge--new{background:#2e7d52;color:#eafff2}
.pf-badge--premium{background:#1f1f1f;color:var(--accent);border:1px solid var(--accent)}
.pf-badge--promo{left:auto;right:9px;background:var(--err);color:#fff}
/* ===== Modal / página do produto ===== */
.pf-modal{position:fixed;inset:0;z-index:1000;background:rgba(6,5,4,.74);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;padding:34px 16px;overflow:auto}
.pf-modal.open{display:flex;animation:pfFade .2s ease}
@keyframes pfFade{from{opacity:0}to{opacity:1}}
.pf-md-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;max-width:760px;width:100%;padding:22px;box-shadow:0 24px 60px rgba(0,0,0,.6);animation:pfRise .22s ease}
@keyframes pfRise{from{transform:translateY(14px);opacity:.6}to{transform:translateY(0);opacity:1}}
.pf-modal-close{position:absolute;top:12px;right:14px;background:transparent;border:0;color:var(--mut);font-size:30px;line-height:1;cursor:pointer;z-index:3}
.pf-modal-close:hover{color:var(--txt)}
.pf-md-top{display:flex;gap:22px}
.pf-md-img{position:relative;flex:0 0 280px;aspect-ratio:1/1;background:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pf-md-img img{width:100%;height:100%;object-fit:contain}
.pf-md-body{flex:1;display:flex;flex-direction:column;gap:7px;min-width:0}
.pf-md-marca{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.pf-md-nome{font-size:23px;font-weight:800;line-height:1.15;margin:0}
.pf-md-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:8px 0 4px}
.pf-md-stat{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:7px 10px;display:flex;flex-direction:column;gap:1px}
.pf-md-stat span{font-size:10.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.pf-md-stat strong{font-size:13px;color:var(--txt)}
.pf-md-add{margin-top:8px}
.pf-md-sec{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}
.pf-md-sec h4{margin:0 0 9px;font-size:13px;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}
.pf-md-desc{margin:0;font-size:14px;line-height:1.6;color:#d7d2c7}
.pf-md-rel{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pf-md-relcard{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:8px;cursor:pointer;display:flex;flex-direction:column;gap:5px;color:var(--txt);text-align:left;transition:border-color .13s,transform .13s}
.pf-md-relcard:hover{border-color:var(--accent);transform:translateY(-2px)}
.pf-md-relcard img{width:100%;aspect-ratio:1/1;object-fit:contain;background:#fff;border-radius:8px}
.pf-md-relcard span{font-size:11px;line-height:1.2;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pf-md-relcard b{font-size:12px;color:var(--accent)}
@media(max-width:560px){
  .pf-md-top{flex-direction:column}
  .pf-md-img{flex-basis:auto;width:100%;max-width:280px;margin:0 auto}
  .pf-md-rel{grid-template-columns:repeat(2,1fr)}
}
.pf-empty{color:var(--mut);font-size:13px;text-align:center;padding:14px}
.pf-citem{padding:9px 0;border-bottom:1px solid var(--line)}
.pf-citem-nome{font-size:12.5px;font-weight:600;line-height:1.25}
.pf-citem-un{color:var(--mut);font-weight:400}
.pf-citem-row{display:flex;align-items:center;gap:8px;margin-top:6px}
.pf-citem-row button{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);background:var(--card);color:var(--txt);cursor:pointer;font-size:15px;line-height:1}
.pf-citem-sub{margin-left:auto;font-weight:700;font-size:13px}
.pf-finalizar{width:100%;background:var(--accent);color:#0B0B0B;border:0;border-radius:10px;padding:12px;font-weight:800;cursor:pointer;font-size:14px;margin-top:10px}
.pf-finalizar:hover{filter:brightness(1.05)}
.pf-nota{font-size:11px;color:var(--mut);margin:8px 0 0;text-align:center}
.pf-msg{font-size:12.5px;margin-top:10px;min-height:18px;text-align:center;line-height:1.4}
.pf-msg.ok{color:var(--ok);font-weight:600}
.pf-msg.err{color:var(--err);font-weight:600}

/* PF — pedido mínimo + form */
.pf-min{margin-top:10px}
.pf-min-label{display:flex;flex-direction:column;gap:4px;font-size:11.5px;color:var(--mut)}
.pf-min-label select{background:var(--card);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px;font-size:13px}
.pf-progress{height:8px;background:var(--card);border:1px solid var(--line);border-radius:99px;overflow:hidden;margin-top:8px}
.pf-progress-bar{height:100%;width:0;background:var(--accent);transition:width .25s ease}
.pf-progress-bar.ok{background:var(--ok)}
.pf-min-msg{font-size:11.5px;margin-top:6px;color:var(--mut)}
.pf-min-msg.falta{color:var(--accent)}
.pf-min-msg.ok{color:var(--ok);font-weight:700}
.pf-form{display:flex;flex-direction:column;gap:7px;margin-top:10px}
.pf-form input{background:var(--card);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:9px;font-size:13px}
.pf-finalizar:disabled,.pf-finalizar.disabled{opacity:.45;cursor:not-allowed;filter:none}

/* ===== FASE 3 — Gate de perfil obrigatório ===== */
html.gate-lock, body.gate-lock { overflow: hidden; }
.gate{position:fixed;inset:0;z-index:9999;background:rgba(11,11,11,.92);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto}
.gate-card{width:100%;max-width:760px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px 24px;text-align:center}
.gate-logo{width:88px;height:auto;display:block;margin:0 auto 14px}
.gate-title{font-size:24px;font-weight:800;margin:0 0 6px}
.gate-sub{color:var(--mut);font-size:14px;margin:0 0 20px}
.gate-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gate-item{display:flex;flex-direction:column;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:18px 10px;cursor:pointer;color:var(--txt);transition:border-color .15s,transform .1s}
.gate-item:hover{border-color:var(--accent);transform:translateY(-2px)}
.gate-ic{color:var(--accent);line-height:0;display:flex}
.gate-ic svg{width:34px;height:34px}
.gate-nome{font-size:12.5px;font-weight:600;line-height:1.2;text-align:center}
.gate-foot{margin-top:18px;font-size:11.5px;color:var(--mut)}
@media(max-width:640px){.gate-grid{grid-template-columns:repeat(2,1fr)}.gate-title{font-size:20px}}
/* Barra "perfil escolhido" */
.perfil-escolhido{max-width:1200px;margin:16px auto 0;padding:10px 16px;box-sizing:border-box;display:flex;align-items:center;gap:8px;font-size:14px}
.pe-label{color:var(--mut)}
.pe-ic{color:var(--accent);line-height:0;display:flex}
.pe-ic svg{width:22px;height:22px}
.pe-trocar{margin-left:auto;background:transparent;border:1px solid var(--line);color:var(--accent);border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:700;cursor:pointer}
.pe-trocar:hover{border-color:var(--accent)}

/* ===== Repetir último pedido (PJ) ===== */
.repetir-pedido{max-width:1200px;margin:14px auto 0;padding:0 16px;box-sizing:border-box}
.rp-card{display:flex;gap:14px;align-items:center;flex-wrap:wrap;background:var(--card);border:1px solid var(--accent);border-radius:14px;padding:14px 16px}
.rp-main{flex:1;min-width:220px}
.rp-title{font-size:16px;font-weight:800}
.rp-meta{font-size:13px;color:var(--mut);margin-top:4px}
.rp-meta strong{color:var(--txt)}
.rp-aviso{margin-top:8px;font-size:12.5px;border-radius:8px;padding:8px 10px}
.rp-aviso--ok{background:rgba(62,207,142,.12);color:var(--ok)}
.rp-aviso--alerta{background:rgba(242,178,51,.12);color:var(--accent)}
.rp-acoes{display:flex;gap:8px;flex-wrap:wrap}
.rp-btn{border:1px solid var(--line);background:var(--bg);color:var(--txt);border-radius:9px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer}
.rp-btn:hover{border-color:var(--accent)}
.rp-btn--primary{background:var(--accent);color:#0B0B0B;border-color:var(--accent)}
.rp-btn--ghost{color:var(--mut)}
/* modal de detalhes */
.rp-modal{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;padding:18px}
.rp-modal-back{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.rp-modal-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;max-width:460px;width:100%;max-height:80vh;overflow:auto}
.rp-modal-x{position:absolute;top:10px;right:12px;background:transparent;border:0;color:var(--mut);font-size:22px;cursor:pointer}
.rp-modal-card h3{margin:0 0 4px}
.rp-modal-meta{font-size:12px;color:var(--mut);margin-bottom:12px}
.rp-tab{width:100%;border-collapse:collapse;font-size:13px}
.rp-tab td{padding:8px 6px;border-bottom:1px solid var(--line);vertical-align:top}
.rp-tab td:first-child{white-space:nowrap;color:var(--mut)}
.rp-sub{text-align:right;font-weight:700;white-space:nowrap}
.rp-cod{font-size:11px;color:var(--mut)}
.rp-modal-total{text-align:right;margin-top:12px;font-size:15px}
.rp-modal-nota{font-size:11.5px;color:var(--mut);margin-top:8px}

/* ===== Filtros secundários do catálogo (PJ) ===== */
.controls .cats, .controls .selects { display:none; } /* substituídos pela barra de filtros */
.catalogo-filtros{ width:100%; }
.flt-toggle{ display:none; }
.flt-row{ display:flex; flex-wrap:wrap; gap:10px; align-items:flex-end; }
.flt-campo{ display:flex; flex-direction:column; gap:4px; font-size:11px; color:var(--mut); text-transform:uppercase; letter-spacing:.02em }
.flt-campo select{ background:var(--card); color:var(--txt); border:1px solid var(--line); border-radius:8px; padding:8px 9px; font-size:13px; min-width:132px; text-transform:none; letter-spacing:0 }
.flt-campo select:focus{ outline:none; border-color:var(--accent) }
.flt-limpar{ background:transparent; border:1px solid var(--line); color:var(--mut); border-radius:8px; padding:8px 12px; font-size:12.5px; cursor:pointer; height:36px; align-self:flex-end }
.flt-limpar:hover{ border-color:var(--accent); color:var(--accent) }
@media(max-width:820px){
  .flt-toggle{ display:inline-block; background:var(--accent); color:#0B0B0B; border:0; border-radius:9px; padding:10px 14px; font-weight:800; font-size:13px; cursor:pointer }
  .flt-row{ display:none; margin-top:10px; width:100% }
  .catalogo-filtros.flt-open .flt-row{ display:flex }
  .flt-campo{ flex:1 1 46% }
  .flt-campo select{ width:100%; min-width:0 }
  .flt-limpar{ flex:1 1 46% }
}

/* ===== Bloco institucional (rodapé PJ/PF + modal Sobre) ===== */
.footer-institucional{max-width:1200px;margin:0 auto;padding:14px 20px 0;font-size:11.5px;line-height:1.7;color:var(--mut);text-align:center}
.footer-institucional strong{color:var(--txt)}
.footer-institucional a{color:var(--accent);text-decoration:none}
.footer-institucional a:hover{text-decoration:underline}
.sobre-institucional{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);text-align:left}
.sobre-institucional p{font-size:12.5px;line-height:1.5;color:var(--mut);margin:4px 0}
.sobre-institucional strong{color:var(--txt)}

/* mensagem "Produtos recomendados para: [Segmento]" no topo do catálogo */
.recomendado-msg{font-size:15px;font-weight:800;color:var(--txt);margin:4px 0 10px}
.recomendado-msg:empty{display:none}

/* ===== Cadastro Pessoa Física (cadastro-pf.html) ===== */
.cadastro-wrap{max-width:720px;margin:18px auto;padding:0 16px;box-sizing:border-box}
.cadastro-titulo{font-size:22px;font-weight:800;margin:0 0 6px}
.cadastro-sub{color:var(--mut);font-size:14px;margin:0 0 18px}
.cadastro-form{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cf-campo{display:flex;flex-direction:column;gap:4px;font-size:11.5px;color:var(--mut)}
.cf-campo.cf-2{grid-column:1 / -1}
.cf-campo input{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:10px;font-size:14px}
.cf-campo input:focus{outline:none;border-color:var(--accent)}
.cf-enviar{margin-top:14px;width:100%;background:var(--accent);color:#0B0B0B;border:0;border-radius:10px;padding:12px;font-weight:800;font-size:14px;cursor:pointer}
.cf-enviar:disabled{opacity:.5;cursor:not-allowed}
.cf-msg{font-size:13px;margin-top:10px;min-height:18px}
.cf-msg.ok{color:var(--ok)} .cf-msg.err{color:var(--err)}
.cf-msg a,.cf-sucesso a{color:var(--accent)}
.cf-sucesso{background:var(--card);border:1px solid var(--accent);border-radius:14px;padding:22px;text-align:center;margin-top:14px}
.cf-sucesso h2{margin:0 0 6px}
.cf-cta{display:inline-block;margin-top:10px;background:var(--accent);color:#0B0B0B;border-radius:10px;padding:11px 18px;font-weight:800;text-decoration:none}
@media(max-width:600px){.cf-grid{grid-template-columns:1fr}.cf-campo.cf-2{grid-column:auto}}
/* autocomplete hints (CEP / CNPJ) */
.cf-autocomplete-hint{font-size:.75rem;min-height:1.1em;margin-top:1px;color:var(--mut)}
.cf-autocomplete-hint.ok{color:var(--ok)}
.cf-autocomplete-hint.err{color:var(--err)}
.cf-autocomplete-hint.loading{color:var(--accent);opacity:.8}
/* select and textarea inside cf-campo */
.cf-campo select,.cf-campo textarea{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:10px;font-size:14px;width:100%;box-sizing:border-box;font-family:inherit}
.cf-campo select:focus,.cf-campo textarea:focus{outline:none;border-color:var(--accent)}
.cf-campo textarea{resize:vertical;min-height:72px}
/* PJ-form badge */
.cf-pj-badge{display:inline-block;background:var(--accent);color:#0B0B0B;font-size:11px;font-weight:800;border-radius:6px;padding:2px 8px;margin-left:6px;vertical-align:middle;letter-spacing:.5px}
/* CNPJ/CEP loading overlay */
.cf-loading-dot::after{content:' .';animation:cfDot 1s infinite}
@keyframes cfDot{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== Filtros PF (pf.html) — ISOLADOS do PJ ===== */
.pf-filtros{max-width:1200px;margin:0 auto 4px;padding:0 16px;box-sizing:border-box}
.pf-cats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.pf-cat-btn{background:var(--card);border:1px solid var(--line);color:var(--txt);padding:7px 14px;border-radius:20px;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:background .13s,color .13s,border-color .13s}
.pf-cat-btn.active{background:var(--accent);color:#111;border-color:var(--accent)}
.pf-cat-btn:hover:not(.active){border-color:var(--accent);color:var(--accent)}
.pf-filtros-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pf-flt-select{background:var(--card);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px;cursor:pointer}
.pf-flt-select:focus{outline:none;border-color:var(--accent)}
.pf-busca{flex:1;min-width:180px;background:var(--card);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px}
.pf-busca:focus{outline:none;border-color:var(--accent)}
.pf-limpar-btn{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:8px;padding:8px 12px;font-size:12.5px;cursor:pointer;white-space:nowrap}
.pf-limpar-btn:hover{border-color:var(--accent);color:var(--accent)}
.pf-promo-badge{display:inline-block;background:var(--err);color:#fff;font-size:10px;font-weight:800;border-radius:5px;padding:2px 6px;margin-left:6px;vertical-align:middle}
@media(max-width:820px){
  .pf-cats{gap:5px}
  .pf-cat-btn{padding:6px 10px;font-size:12px}
  .pf-filtros-row{gap:6px}
  .pf-flt-select{font-size:12px;padding:7px 8px}
  .pf-busca{min-width:130px}
}

/* ===== Carrossel hero PF (mobile-first; esconde-se sozinho via [hidden]) ===== */
.pf-hero-carousel{max-width:1200px;margin:14px auto 0;padding:0 16px;box-sizing:border-box;position:relative}
.pf-hero-carousel[hidden]{display:none}
.pf-hc-track{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:1920/700;box-shadow:0 10px 30px rgba(0,0,0,.45)}
.pf-hc-slide{position:absolute;inset:0;display:block;opacity:0;visibility:hidden;cursor:pointer;text-decoration:none;transition:opacity .55s ease}
.pf-hc-slide.active{opacity:1;visibility:visible}
.pf-hc-slide:focus-visible{outline:3px solid var(--accent);outline-offset:-3px}
.pf-hc-img{display:block;width:100%;height:100%;object-fit:cover}
/* gradiente de marca = fallback quando a foto não existe */
.pf-hc-s1{background:linear-gradient(120deg,#3a2a0a 0%,#7a5410 60%,#b9831f 100%)}
.pf-hc-s2{background:linear-gradient(120deg,#0e1a12 0%,#1d4a32 60%,#2e7d52 100%)}
.pf-hc-s3{background:linear-gradient(120deg,#2a1208 0%,#5e2b12 55%,#a8531f 100%)}
.pf-hc-s4{background:linear-gradient(120deg,#1a1505 0%,#5a4710 55%,#F2B233 100%)}
/* foto real (img+overlay) por cima do gradiente; o container some inteiro (onerror)
   se o arquivo faltar, deixando só o gradiente da marca + texto */
.pf-hc-media{position:absolute;inset:0;z-index:0}
.pf-hc-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pf-hc-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.45) 45%,rgba(0,0,0,.15) 100%)}
.pf-hc-content{position:relative;z-index:3;padding:22px 26px;max-width:58%;display:flex;flex-direction:column;gap:7px;color:#fff}
/* faixa de PRODUTOS REAIS (imagens do cadastro) sobre o fundo, à direita */
.pf-hc-products{position:absolute;top:0;bottom:0;right:18px;z-index:2;display:flex;align-items:flex-end;justify-content:flex-end;gap:0;max-width:48%;padding-bottom:12px;pointer-events:none}
.pf-hc-prod{height:80%;width:auto;max-width:22%;object-fit:contain;object-position:bottom;filter:drop-shadow(0 7px 11px rgba(0,0,0,.6));margin-left:-6px}
.pf-hc-tag{align-self:flex-start;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.4);padding:3px 11px;border-radius:20px}
.pf-hc-title{font-size:22px;font-weight:800;line-height:1.15;margin:0;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.pf-hc-sub{font-size:13.5px;margin:0;opacity:.96;line-height:1.35;text-shadow:0 1px 5px rgba(0,0,0,.45)}
.pf-hc-arrow{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;border:0;background:rgba(0,0,0,.42);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3}
.pf-hc-arrow:hover{background:rgba(0,0,0,.7)}
.pf-hc-prev{left:24px}.pf-hc-next{right:24px}
.pf-hc-dots{position:absolute;bottom:11px;left:0;right:0;display:flex;justify-content:center;gap:7px;z-index:3}
.pf-hc-dot{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:width .2s,background .2s}
.pf-hc-dot.active{background:#fff;width:22px;border-radius:5px}
@media(max-width:820px){
  .pf-hc-track{height:172px}
  .pf-hc-content{max-width:90%;padding:16px 18px}
  .pf-hc-title{font-size:18px}
  .pf-hc-sub{font-size:12.5px}
  .pf-hc-prev{left:14px}.pf-hc-next{right:14px}
  .pf-hc-arrow{width:30px;height:30px;font-size:18px}
}

/* ===== Área de vídeo showcase (PF e PJ; oculta via [hidden] se sem arquivo) ===== */
.beerlab-video-showcase{max-width:1200px;margin:16px auto 0;padding:0 16px;box-sizing:border-box}
.beerlab-video-showcase[hidden]{display:none}
.beerlab-video-showcase video{width:100%;max-height:340px;object-fit:cover;border-radius:16px;display:block;box-shadow:0 6px 22px rgba(0,0,0,.4);background:#000}

/* ===== Badges de contexto (discretos) ===== */
.pf-badge-consumidor,.pj-badge-b2b{display:inline-block;font-size:10.5px;font-weight:800;border-radius:6px;padding:2px 9px;margin-left:8px;vertical-align:middle;letter-spacing:.4px;text-transform:uppercase}
.pf-badge-consumidor{background:rgba(62,207,142,.16);color:var(--ok);border:1px solid rgba(62,207,142,.45)}
.pj-badge-b2b{background:rgba(242,178,51,.16);color:var(--accent);border:1px solid rgba(242,178,51,.45)}
@media(max-width:820px){.pf-badge-consumidor,.pj-badge-b2b{font-size:9.5px;padding:1px 7px;margin-left:6px}}

/* ===== Melhorias visuais seguras (cards, hover, seções, pedido mínimo) ===== */
/* Cards: sombra suave + hover no desktop (sem mexer na estrutura) */
.product{box-shadow:0 1px 4px rgba(0,0,0,.25);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
@media(hover:hover) and (min-width:821px){
  .product:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,.42);border-color:rgba(242,178,51,.45)}
}
.pf-add{transition:filter .12s ease,transform .12s ease}
.pf-add:active{transform:translateY(1px)}
/* Título do hero PF mais premium */
.pf-hero h1{letter-spacing:.005em;background:linear-gradient(90deg,#fff 0%,#ffe7b0 100%);-webkit-background-clip:text;background-clip:text}
/* Destaque do pedido mínimo PF */
.pf-min{background:rgba(242,178,51,.06);border:1px solid rgba(242,178,51,.22);border-radius:12px;padding:11px 12px}
.pf-min-msg.ok{color:var(--ok)}
.pf-min-msg.falta{color:var(--accent);font-weight:700}
/* Carrinho PF: leve realce do total */
.pf-body .cart{box-shadow:0 4px 18px rgba(0,0,0,.35)}
.pf-body .cart-total{font-weight:700}
/* Espaçamento mobile mais respirável no grid PF */
@media(max-width:520px){
  .pf-hero{padding:14px 16px 4px}
  .pf-hero h1{font-size:21px}
}

/* ===== Banners premium: cluster hero + secundários (compartilhado PF/PJ) =====
   mix-blend-mode multiply "recorta" o fundo branco das fotos do cadastro sobre o
   gradiente escuro→dourado de cada banner. Hierarquia por tamanho (hero maior). */
.bl-cluster{position:absolute;top:0;bottom:0;right:16px;z-index:2;display:flex;align-items:center;justify-content:flex-end;max-width:60%;padding:10px 0;pointer-events:none}
/* cada produto vira um "tile" premium (cartão branco arredondado + sombra) → consistente
   para qualquer foto (fundo branco ou lifestyle). Hierarquia: hero maior e à frente. */
.bl-prod{background:#fff;border-radius:11px;padding:7px;object-fit:contain;object-position:center;box-shadow:0 9px 20px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.5)}
.bl-prod--sec{height:62%;max-width:16.5%;margin-left:-14px;z-index:2;transform:scale(.96)}
.bl-prod--hero{height:94%;max-width:30%;margin-left:-8px;margin-right:-8px;z-index:5;box-shadow:0 16px 30px rgba(0,0,0,.62)}
@media(max-width:620px){
  .bl-cluster{max-width:54%;right:6px}
  .bl-prod--sec{height:48%;max-width:20%;margin-left:-10px}
  .bl-prod--hero{height:74%;max-width:34%}
}

/* Selo de confiança (estático) — Tarefa 2 Consolidação. Sem números/avaliações/certificações inventados. */
.trust-bar{max-width:1100px;margin:16px auto 6px;padding:12px 16px;box-sizing:border-box;display:flex;flex-wrap:wrap;gap:8px 0;justify-content:center;align-items:center}
.trust-item{font-size:12.5px;font-weight:500;letter-spacing:.03em;color:#cdb784;background:none;border:0;border-radius:0;padding:2px 20px;white-space:nowrap;cursor:default;position:relative}
.trust-item:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:13px;width:1px;background:rgba(205,183,132,.30)}
@media(max-width:560px){.trust-bar{gap:6px 0;padding:10px 12px}.trust-item{font-size:11px;padding:2px 11px;white-space:normal}.trust-item:not(:last-child)::after{display:none}}


/* === Fase Confiança/Conversão (2026-06-27): barra de vantagens + WhatsApp flutuante === */
.conv-bar{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;justify-content:center;padding:10px 14px;background:linear-gradient(90deg,#0c3b1e,#0a2e18);border-top:1px solid #14532d;border-bottom:1px solid #14532d;font-size:14px}
.conv-item{color:#e9f7ee}
.conv-frete{color:#7CFC9A;font-weight:700}
.conv-frete strong,.conv-min strong{color:#ffd400}
.conv-min{color:#fff;font-weight:700}
.conv-soon{color:#c9b8e8;opacity:.92}
.conv-since{color:#cfe9d6}
.wa-float{position:fixed;right:16px;bottom:16px;z-index:9999;width:54px;height:54px;border-radius:50%;background:#25D366;color:#073b1e;font-size:26px;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.wa-float:hover{filter:brightness(1.05)}
@media(max-width:560px){.conv-bar{font-size:12.5px;gap:6px 12px;padding:8px 10px}.wa-float{width:48px;height:48px;font-size:22px}}

/* cashback teaser (visual prep — F2) */
.cashback-teaser{margin:6px 0 2px;padding:8px 12px;border:1px dashed rgba(205,183,132,.45);border-radius:10px;background:rgba(205,183,132,.07);color:#cdb784;font-size:12.5px;text-align:center}
.cashback-teaser strong{color:#ffd400}

/* --- Conversão (Sprint 1): progresso até o mínimo + prazo + barra fixa mobile --- */
.pj-progress{margin:8px 0 2px}
.pj-progress[hidden]{display:none}
.pjp-track{height:8px;border-radius:6px;background:rgba(255,255,255,.10);overflow:hidden}
.pjp-fill{height:100%;background:var(--accent);border-radius:6px;transition:width .3s ease}
.pjp-msg{font-size:12px;color:var(--mut);margin-top:5px;text-align:center;line-height:1.35}
.pjp-msg.pjp-ok{color:#7bd88f;font-weight:700}
.cart-prazo{font-size:11.5px;color:var(--mut);margin:6px 0 0;text-align:center;line-height:1.4}
.seguranca-nota{font-size:11.5px;color:#bfe3c8;background:rgba(45,140,80,.10);border:1px solid rgba(45,140,80,.30);border-radius:10px;padding:8px 12px;margin:8px 0 2px;text-align:center;line-height:1.45}
.seguranca-nota strong{color:#7bd88f}
/* WhatsApp oficial: rótulo de confiança ao lado do ícone */
.wa-float{gap:0}
.wa-float .wa-float-tip{max-width:0;overflow:hidden;white-space:nowrap;opacity:0;transition:max-width .25s,opacity .25s,margin .25s;font-size:13px;font-weight:800}
.wa-float:hover .wa-float-tip,.wa-float:focus .wa-float-tip{max-width:140px;opacity:1;margin-left:8px}
.wa-float{width:auto;min-width:54px;padding:0 14px;border-radius:28px}
@media(max-width:560px){.wa-float .wa-float-tip{display:none}.wa-float{width:48px;min-width:48px;padding:0}}
.cart-sticky{display:none}
@media(max-width:820px){
  .cart-sticky{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:15;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -4px 14px rgba(0,0,0,.35)}
  .cart-sticky[hidden]{display:none}
  .csb-info{font-size:13px;color:var(--fg)}
  .csb-info strong{color:var(--accent)}
  .csb-btn{background:var(--accent);border:0;color:#111;font-weight:800;padding:11px 16px;border-radius:10px;font-size:14px;white-space:nowrap}
  .cart{padding-bottom:64px}
}
