:root{
  --bg:#eef0f4; --card:#ffffff; --line:#e2e6ee; --line2:#eef1f6;
  --txt:#1b2330; --dim:#69748a; --dim2:#97a0b2;
  --red:#c8102e; --red-soft:#fcebed; --red2:#e23046;
  --green:#0f8a43; --green-soft:#e7f6ec;
  --blue:#2563eb;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;font-size:16px}
body{padding-top:144px;padding-bottom:70px}
b{color:#000}
input,button{font-family:inherit}

/* TOPO */
#topo{position:fixed;top:0;left:0;right:0;z-index:30;background:#fff;border-bottom:1px solid var(--line);padding:9px 12px 10px;box-shadow:0 2px 12px rgba(20,30,50,.07)}
.marca{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.marca .nome{font-size:16px;font-weight:800}
.marca .nome b{color:var(--red)}
.marca-acoes{display:flex;gap:7px;align-items:center}
.sync{font-size:11px;color:var(--dim);background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:5px 11px;font-weight:600}
.sync.ok{color:var(--green);border-color:#bfe6cd;background:var(--green-soft)}
.ic-btn{font-size:15px;background:var(--bg);border:1px solid var(--line);border-radius:20px;width:32px;height:30px;line-height:1}
/* campo de stand com ícone */
.campo-stand{display:flex;align-items:center;gap:8px;background:var(--bg);border:1.5px solid var(--line);border-radius:11px;padding:0 12px;margin-bottom:8px}
.campo-stand .ic{font-size:15px;opacity:.7}
.campo-stand input{flex:1;background:none;border:0;color:var(--txt);font-size:15px;padding:11px 0;outline:none;font-weight:600}
.campo-stand input::placeholder{color:var(--dim2);font-weight:400}
.campo-stand:focus-within{border-color:var(--red);background:#fff}
/* barra de descontos compacta */
.descontos-bar{display:flex;align-items:center;gap:8px}
.descontos-bar .dl{font-size:11px;color:var(--dim);font-weight:600;flex:1}
.desc-mini{display:flex;align-items:center;gap:5px;background:var(--bg);border:1.5px solid var(--line);border-radius:9px;padding:0 9px}
.desc-mini input{width:34px;background:none;border:0;color:var(--txt);font-size:16px;font-family:var(--mono);font-weight:700;padding:7px 0;outline:none;text-align:center}
.desc-mini span{color:var(--dim);font-size:11px;font-weight:600}
.desc-mini:focus-within{border-color:var(--red);background:#fff}
/* campos genéricos (usados em calc/config) */
.campo{display:flex;align-items:center;background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:0 10px}
.campo input{width:100%;background:none;border:0;color:var(--txt);font-size:18px;font-family:var(--mono);padding:8px 0;outline:none}
.campo input::placeholder{color:var(--dim2)}
.campo span{color:var(--dim);font-size:15px}
.campo:focus-within{border-color:var(--red)}

/* VIEWS */
.view{display:none;padding:12px}
.view.ativa{display:block}
.titulo{font-size:18px;margin:2px 2px 12px;font-weight:700}
.sub-dim{color:var(--dim);font-size:13px}

/* BUSCA */
#q{width:100%;background:#fff;border:1.5px solid var(--line);border-radius:12px;color:var(--txt);font-size:17px;padding:13px 14px;outline:none;margin-bottom:8px}
#q:focus{border-color:var(--red)}
.chips{display:flex;gap:7px;overflow-x:auto;padding:3px 0 9px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;background:#fff;border:1.5px solid var(--line);color:var(--dim);padding:7px 13px;border-radius:20px;font-size:13px;white-space:nowrap;font-weight:500}
.chip.on{background:var(--red);border-color:var(--red);color:#fff;font-weight:700}
.chips.grupo .chip.on{background:var(--txt);border-color:var(--txt)}

/* LISTAS */
.lista{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 13px;display:flex;justify-content:space-between;gap:10px;align-items:center}
.item:active{border-color:var(--red);background:var(--red-soft)}
.item .nome{font-size:15px;line-height:1.25;font-weight:600}
.item .meta{font-size:12px;color:var(--dim);margin-top:3px}
.item .meta .ean{font-family:var(--mono);color:var(--dim2)}
.item .dir{text-align:right;flex:0 0 auto}
.item .custo{font-family:var(--mono);font-size:15px;font-weight:700}
.item .est{font-size:11px;color:var(--dim);margin-top:2px}
.est.neg{color:var(--red);font-weight:700}
.est.zero{color:var(--red2)}
.vazio{color:var(--dim);text-align:center;padding:38px 20px;font-size:14px}

/* CARD */
.voltar{background:none;border:0;color:var(--red);font-size:16px;padding:6px 2px;margin-bottom:4px;font-weight:600}
.card-nome{font-size:20px;font-weight:800;line-height:1.22;margin-bottom:3px}
.card-sub{color:var(--dim);font-size:12.5px;margin-bottom:6px;line-height:1.5}
.card-sub .ean{font-family:var(--mono)}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.kpi .rot{font-size:10.5px;color:var(--dim);text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.kpi .val{font-size:20px;font-family:var(--mono);margin-top:3px;font-weight:700}
.kpi .sub{font-size:11px;color:var(--dim);margin-top:2px}
.kpi{cursor:pointer;transition:border-color .15s}
.kpi:active{border-color:var(--red)}
.kpi .rot .exp{float:right;color:var(--dim2);transition:transform .2s;display:inline-block}
.kpi.aberto{grid-column:1 / -1;border-color:var(--red)}
.kpi.aberto .rot .exp{transform:rotate(90deg);color:var(--red)}
.kpi-det{display:none;margin-top:9px;padding-top:9px;border-top:1px solid var(--line2);font-size:12.5px;color:var(--dim);line-height:1.7}
.kpi-det b{color:var(--txt)}
.kpi.aberto .kpi-det{display:block}
.tag{display:inline-block;font-size:10.5px;padding:2px 8px;border-radius:20px;font-weight:700}
.tag.verde{background:var(--green-soft);color:var(--green)}
.tag.amarelo{background:#fef3e2;color:#b25e09}
.tag.vermelho{background:var(--red-soft);color:var(--red)}
.tag.cinza{background:#eef1f6;color:var(--dim)}
.tag.hos{background:#e8f0fe;color:var(--blue)}
.tag.base{background:#eef1f6;color:var(--dim)}
.tag.etico{background:#f0e8fb;color:#6b34c9}
.tag.generico{background:var(--green-soft);color:var(--green)}
.tag.similar{background:#e8f0fe;color:var(--blue)}

/* bloco genérico do card */
.bloco{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px;margin-bottom:12px}
.bloco h3{margin:0 0 10px;font-size:13px;color:var(--dim);text-transform:uppercase;letter-spacing:.5px;font-weight:700}

/* CALCULADORA */
.calc-row{display:flex;gap:10px;margin-bottom:11px}
.calc-row label{flex:1;font-size:11px;color:var(--dim);display:flex;flex-direction:column;gap:4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.calc-row .campo input{font-size:21px}
.resultado{text-align:center;padding:13px;border-radius:12px;border:1.5px solid var(--line);margin-bottom:11px}
.resultado.bom{background:var(--green-soft);border-color:#9fd9b3}
.resultado.ruim{background:var(--red-soft);border-color:#f0b6bf}
.resultado .liq{font-size:32px;font-family:var(--mono);font-weight:800}
.resultado.bom .liq{color:var(--green)}
.resultado.ruim .liq{color:var(--red)}
.resultado .vs{font-size:12.5px;color:var(--dim);margin-top:3px}
.resultado .eco{font-weight:800;margin-top:3px}
.resultado.bom .eco{color:var(--green)}
.resultado.ruim .eco{color:var(--red)}
.btn-comprar{width:100%;background:var(--green);color:#fff;border:0;border-radius:12px;font-size:18px;font-weight:800;padding:15px;margin-top:2px}
.btn-comprar:active{filter:brightness(.92)}
.btn-comprar:disabled{background:#cfd6e2;color:#fff}
.total-compra{margin-top:11px;padding-top:11px;border-top:1px dashed rgba(0,0,0,.12)}
.total-compra>div{display:flex;justify-content:space-between;align-items:center;font-size:14px;margin-top:3px}
.total-compra>div span{color:var(--dim);font-size:12.5px}
.total-compra b{font-family:var(--mono);font-size:19px}
.total-compra .ok b{color:var(--green);font-size:14px}
.total-compra .no b{color:var(--red);font-size:14px}
.alerta-parado{background:#fef3e2;border:1.5px solid #f3c98a;color:#92500a;border-radius:12px;padding:12px 14px;font-size:13.5px;line-height:1.45;margin-bottom:12px}
.alerta-parado b{color:#7a4308}
.alerta-fracao{background:#e8f0fe;border:1.5px solid #aac6f5;color:#1d4eb8;border-radius:12px;padding:12px 14px;font-size:13.5px;line-height:1.45;margin-bottom:12px}
.alerta-fracao b{color:#173a8a}
.tag.fr{background:#e8f0fe;color:#1d4eb8}
/* ficha completa */
.ficha{display:flex;flex-direction:column}
.ficha .fr{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px solid var(--line2);font-size:13px}
.ficha .fr:last-child{border-bottom:0}
.ficha .fr span{color:var(--dim);flex:0 0 auto}
.ficha .fr b{text-align:right;word-break:break-word}
/* pill de preço com seta (mais barato/mais caro) */
.preco-pill{display:inline-block;padding:3px 9px;border-radius:8px;font-family:var(--mono);font-weight:800}
.preco-pill.bom{background:var(--green-soft);color:var(--green)}
.preco-pill.ruim{background:var(--red-soft);color:var(--red)}
.sim .r .ec{font-size:10.5px;color:var(--green);font-weight:700;margin-top:2px}

/* badge no botão do topo */
.ic-btn{position:relative}
.ic-btn em{position:absolute;top:-5px;right:-5px;background:var(--red);color:#fff;font-style:normal;font-size:9px;min-width:15px;height:15px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 3px;font-weight:700}
.ic-btn em.on{display:flex}

/* CHAT */
.chat-msgs{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;min-height:50vh}
.msg{max-width:84%;padding:9px 12px;border-radius:14px;font-size:14px;line-height:1.35;position:relative}
.msg .quem{font-size:11px;font-weight:800;margin-bottom:2px}
.msg .hora{font-size:10px;color:var(--dim2);margin-top:3px;text-align:right}
.msg.eu{align-self:flex-end;background:var(--red);color:#fff;border-bottom-right-radius:4px}
.msg.eu .quem,.msg.eu .hora{color:rgba(255,255,255,.8)}
.msg.outro{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px}
.msg .prodchip{display:block;margin-top:6px;background:rgba(0,0,0,.06);border-radius:9px;padding:8px 10px;font-size:12.5px}
.msg.eu .prodchip{background:rgba(255,255,255,.18)}
.msg .prodchip .pn{font-weight:700}
.msg .prodchip .qs{font-family:var(--mono)}
.msg .prodchip button{margin-top:6px;background:var(--green);color:#fff;border:0;border-radius:8px;padding:7px 10px;font-size:12px;font-weight:700;width:100%}
.chat-compose{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));display:flex;gap:6px;align-items:center;z-index:35}
.chat-compose select{flex:0 0 auto;width:62px;border:1.5px solid var(--line);border-radius:10px;padding:8px 4px;font-size:11px;outline:none}
.chat-compose input#chat-texto{flex:1;min-width:0;border:1.5px solid var(--line);border-radius:20px;padding:11px 14px;font-size:15px;outline:none}
.chat-compose input#chat-texto:focus{border-color:var(--red)}
.chat-compose button{flex:0 0 auto;width:42px;height:42px;background:var(--red);color:#fff;border:0;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;padding:0}
/* esconde a barra de abas quando o chat está aberto (ele abre pelo topo) */
body.chat-aberto #tabs{display:none}
#view-chat{padding-bottom:80px}
.cc-ic{background:var(--bg)!important;color:var(--txt)!important;width:38px!important;font-size:18px}
.cc-ic.gravando{background:var(--red)!important;color:#fff!important;animation:pisca 1s infinite}
@keyframes pisca{50%{opacity:.5}}
.midia-img{max-width:200px;max-height:200px;border-radius:10px;margin-top:6px;display:block}
.midia-audio{margin-top:6px;width:210px;height:38px}
.midia-doc{display:inline-block;margin-top:6px;background:rgba(0,0,0,.06);border-radius:9px;padding:8px 11px;font-size:13px;text-decoration:none;color:inherit}
.msg.eu .midia-doc{background:rgba(255,255,255,.2)}
.chat-anexo{background:var(--green-soft);border:1px solid #bfe6cd;border-radius:10px;padding:8px 11px;margin-bottom:8px;font-size:13px;display:flex;justify-content:space-between;align-items:center}
.chat-anexo b{color:var(--green)}
.chat-anexo .x{background:none;border:0;color:var(--red);font-size:16px}
#view-chat{padding-bottom:60px}
.btn-time{width:100%;background:#fff;border:1.5px solid var(--red);color:var(--red);border-radius:12px;font-size:15px;font-weight:700;padding:13px;margin-bottom:12px}
.btn-time:active{background:var(--red-soft)}

/* alerta flutuante (mensagem nova) */
.alerta-pop{position:fixed;top:12px;left:50%;transform:translateX(-50%) translateY(-120%);z-index:120;background:var(--red);color:#fff;border-radius:14px;padding:12px 16px;box-shadow:0 12px 30px rgba(200,16,46,.5);max-width:92vw;font-size:14px;transition:transform .35s cubic-bezier(.2,.9,.2,1);cursor:pointer}
.alerta-pop.show{transform:translateX(-50%) translateY(0)}
.alerta-pop b{display:block;font-size:12px;opacity:.9;margin-bottom:2px}

/* quem adicionou no carrinho */
.c-item .por{font-size:11px;color:var(--dim);font-weight:600}
.c-item .por b{color:var(--red)}
.st-row{display:flex;gap:8px;margin-bottom:11px;align-items:center}
.st-btn{background:#fff;border:1.5px solid var(--line);color:var(--dim);border-radius:9px;padding:9px 14px;font-size:13px;font-weight:700}
.st-btn.on{background:var(--txt);border-color:var(--txt);color:#fff}
.st-pct{flex:1}.st-pct input{font-size:16px}

/* DASHBOARD */
.dash-kpis{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.dash-kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.dash-kpi.hero{grid-column:1/-1;background:linear-gradient(135deg,var(--red),var(--red2));border:0;color:#fff;box-shadow:0 8px 24px rgba(200,16,46,.3)}
.dash-kpi .rot{font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:600;opacity:.85}
.dash-kpi .num{font-size:24px;font-family:var(--mono);font-weight:800;margin-top:3px}
.dash-kpi.hero .num{font-size:30px}
.dash-kpi .sub{font-size:11px;opacity:.8;margin-top:2px}
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{font-size:13px}
.bar-row .bl{display:flex;justify-content:space-between;margin-bottom:3px}
.bar-row .bl b{font-family:var(--mono)}
.bar-track{height:9px;background:var(--line2);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--red2),var(--red));transition:width .5s}
.bar-fill.g{background:linear-gradient(90deg,#27c06a,var(--green))}

/* CONFIG */
.cfg-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.cfg-row label{flex:0 0 130px;font-size:13px;color:var(--dim);font-weight:600}
.cfg-row .campo{flex:1}
.cfg-add{display:flex;gap:7px;align-items:center}
.cfg-add input{border:1.5px solid var(--line);border-radius:9px;padding:10px;font-size:14px;flex:1}
#cfg-fab-lista .item{padding:9px 12px}
#cfg-fab-lista .rm{color:var(--red);background:none;border:0;font-size:13px;font-weight:600}

/* MOVIMENTO compra/venda */
.mov{overflow-x:auto;scrollbar-width:none}
.mov::-webkit-scrollbar{display:none}
.mov table{border-collapse:collapse;width:100%;min-width:100%}
.mov th,.mov td{padding:7px 6px;text-align:center;font-size:12.5px;font-family:var(--mono);white-space:nowrap}
.mov th{color:var(--dim);font-size:10.5px;font-weight:700;text-transform:uppercase;font-family:inherit}
.mov td.rot{text-align:left;font-family:inherit;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.mov tr.compra td{color:var(--green)} .mov tr.compra td.rot{color:var(--green)}
.mov tr.venda td{color:var(--red)} .mov tr.venda td.rot{color:var(--red)}
.mov tr.compra{background:var(--green-soft)}
.mov tr.venda{background:var(--red-soft)}

/* HISTÓRICO (últimas compras) */
.hist{display:flex;flex-direction:column;gap:0}
.hist .h{display:flex;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid var(--line2);font-size:13px}
.hist .h:last-child{border-bottom:0}
.hist .h .d{font-family:var(--mono);color:var(--dim);min-width:78px}
.hist .h .c{font-family:var(--mono);font-weight:700}
.hist .h .f{color:var(--dim);font-size:11.5px;flex:1;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* SIMILARES */
.sim{display:flex;justify-content:space-between;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line2)}
.sim:last-child{border-bottom:0}
.sim:active{background:var(--red-soft)}
.sim .n{font-size:13.5px;font-weight:600;line-height:1.2}
.sim .m{font-size:11px;color:var(--dim);margin-top:2px}
.sim .m .ean{font-family:var(--mono)}
.sim .r{text-align:right;flex:0 0 auto}
.sim .r .cu{font-family:var(--mono);font-weight:700;font-size:14px}
.sim .r .ec{font-size:10.5px;color:var(--green);font-weight:700}

/* filtros com botões (repor/feira/listas) */
.filtro-chips{display:flex;gap:7px;overflow-x:auto;padding:4px 0 10px;scrollbar-width:none}
.filtro-chips::-webkit-scrollbar{display:none}
.fchip{flex:0 0 auto;background:#fff;border:1.5px solid var(--line);color:var(--dim);padding:8px 14px;border-radius:20px;font-size:13px;font-weight:600;white-space:nowrap}
.fchip.on{background:var(--red);border-color:var(--red);color:#fff}

/* REPOR */
.repo-head{display:flex;gap:8px;margin-bottom:12px}
.repo-head .bloco{flex:1;text-align:center;margin:0;padding:11px}
.repo-head .rot{font-size:10.5px;color:var(--dim);text-transform:uppercase;font-weight:600}
.repo-head .num{font-size:19px;font-family:var(--mono);margin-top:3px;font-weight:700}
.urg{font-size:10px;padding:2px 7px;border-radius:5px;font-weight:800;text-transform:uppercase}
.urg.ruptura{background:var(--red);color:#fff}
.urg.critico{background:#fbe3b0;color:#92500a}
.urg.baixo{background:#eef1f6;color:var(--dim)}

/* linha de campos com rótulo (upload feira, config) */
.linha-topo{display:flex;gap:8px}
.linha-topo label{flex:1;font-size:10px;color:var(--dim);display:flex;flex-direction:column;gap:3px;text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.campo.stand input{font-family:inherit;font-size:15px}

/* FEIRA upload */
.upload{background:#fff;border:1px dashed var(--line);border-radius:14px;padding:14px;margin-bottom:12px}
.upload .campo{margin-bottom:9px;border-style:solid}
.upload input[type=file]{width:100%;font-size:13px;color:var(--dim);padding:6px 0}
.btn{width:100%;background:var(--red);color:#fff;border:0;border-radius:11px;font-size:16px;font-weight:700;padding:13px}
.btn:active{filter:brightness(.92)}
.btn.ghost{background:#fff;color:var(--txt);border:1.5px solid var(--line)}
.btn.sm{padding:9px;font-size:13px}
.feira-item .top{display:flex;justify-content:space-between;gap:8px;width:100%}
.feira-item{flex-direction:column;align-items:stretch;gap:7px}
.feira-liq{font-family:var(--mono);font-weight:800;font-size:15px}
.feira-liq.bom{color:var(--green)} .feira-liq.ruim{color:var(--red)}
.feira-acao{display:flex;gap:8px;align-items:center}
.feira-acao input{width:64px;text-align:center;border:1.5px solid var(--line);border-radius:8px;padding:7px;font-family:var(--mono);font-size:15px}
.feira-acao .mini{flex:1;background:var(--green);color:#fff;border:0;border-radius:8px;padding:9px;font-weight:700;font-size:13px}
.feira-acao .mini:disabled{background:#cfd6e2}

/* CARRINHO */
.totais{display:flex;gap:8px;margin-bottom:12px}
.totais .b{flex:1;background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px;text-align:center}
.totais .rot{font-size:10.5px;color:var(--dim);text-transform:uppercase;font-weight:600}
.totais .num{font-size:20px;font-family:var(--mono);margin-top:3px;font-weight:700}
.totais .num.eco{color:var(--green)}
.grp-forn{font-size:12px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.4px;margin:14px 2px 6px}
.c-item{flex-direction:column;align-items:stretch;gap:8px}
.c-item .top{display:flex;justify-content:space-between;gap:8px}
.c-item .ctrl{display:flex;align-items:center;gap:10px}
.c-item .ctrl button.pm{width:38px;height:38px;border-radius:9px;border:1.5px solid var(--line);background:#fff;color:var(--txt);font-size:20px}
.c-item .qtd{font-family:var(--mono);font-size:18px;min-width:42px;text-align:center;font-weight:700}
.c-item .rm{width:auto;height:auto;margin-left:auto;color:var(--red);background:none;border:0;font-size:13px;white-space:nowrap}
.c-item .tot{font-family:var(--mono);font-size:16px;font-weight:700}
.export-bar{display:flex;gap:10px;margin-top:18px}
.btn-ghost{flex:1;text-align:center;text-decoration:none;color:var(--txt);background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:14px;font-size:15px;font-weight:600}

/* TABS */
#tabs{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;background:#fff;border-top:1px solid var(--line);overflow-x:auto;scrollbar-width:none}
#tabs::-webkit-scrollbar{display:none}
#tabs button{flex:1 0 auto;min-width:64px;background:none;border:0;color:var(--dim2);font-size:10.5px;padding:8px 4px 10px;display:flex;flex-direction:column;align-items:center;gap:3px;position:relative;font-weight:600}
#tabs button span{font-size:20px}
#tabs button.ativa{color:var(--red)}
#badge{position:absolute;top:4px;right:50%;margin-right:-24px;background:var(--red);color:#fff;font-size:10px;font-style:normal;min-width:17px;height:17px;border-radius:9px;display:none;align-items:center;justify-content:center;padding:0 4px;font-weight:700}
#badge.on{display:flex}

.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;padding:11px 20px;border-radius:24px;font-weight:700;z-index:50;opacity:0;transition:opacity .2s;pointer-events:none;box-shadow:0 6px 18px rgba(20,30,50,.2)}
.toast.show{opacity:1}
.toast.err{background:var(--red)}
.carregando{color:var(--dim);text-align:center;padding:30px;font-size:14px}

/* busca + scanner */
.busca-linha{display:flex;gap:8px;margin-bottom:8px}
.busca-linha #q{flex:1;margin-bottom:0}
.ic-scan{flex:0 0 auto;width:52px;background:var(--red);color:#fff;border:0;border-radius:12px;font-size:22px}
.ordenar{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ordenar span{font-size:12px;color:var(--dim);font-weight:600}
.ordenar select{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:9px 10px;font-size:14px;background:#fff;color:var(--txt)}
#scan-overlay{position:fixed;inset:0;z-index:90;background:#000;display:none;flex-direction:column}
#scan-overlay.on{display:flex}
.scan-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;color:#fff;font-size:15px;font-weight:600}
.scan-head button{background:rgba(255,255,255,.15);color:#fff;border:0;width:34px;height:34px;border-radius:50%;font-size:16px}
#scan-video{flex:1;width:100%;object-fit:cover}
.scan-mira{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:74%;height:130px;border:3px solid var(--red2);border-radius:14px;box-shadow:0 0 0 2000px rgba(0,0,0,.45)}
.scan-msg{position:absolute;bottom:40px;left:0;right:0;text-align:center;color:#fff;font-size:14px;padding:0 20px}

/* LOGIN */
#login{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 0%, #2a0610, #0b0e14 70%);overflow:hidden}
.login-bg{position:absolute;inset:-45%;background:
  radial-gradient(circle at 28% 32%, rgba(200,16,46,.65), transparent 42%),
  radial-gradient(circle at 72% 64%, rgba(226,48,70,.5), transparent 44%),
  radial-gradient(circle at 50% 92%, rgba(120,8,28,.55), transparent 50%);
  animation:gira 18s linear infinite;filter:blur(26px)}
@keyframes gira{to{transform:rotate(360deg)}}
.login-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:38px 38px;mask:radial-gradient(ellipse at center,#000 30%,transparent 75%);animation:desliza 22s linear infinite}
@keyframes desliza{to{background-position:0 -380px}}
.parts{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.parts i{position:absolute;bottom:-20px;width:6px;height:6px;border-radius:50%;background:rgba(255,90,110,.7);
  box-shadow:0 0 10px 2px rgba(226,48,70,.6);animation:flutua linear infinite}
.parts i:nth-child(1){left:8%;animation-duration:9s;animation-delay:0s}
.parts i:nth-child(2){left:18%;animation-duration:12s;animation-delay:1s;width:4px;height:4px}
.parts i:nth-child(3){left:28%;animation-duration:10s;animation-delay:3s}
.parts i:nth-child(4){left:38%;animation-duration:14s;animation-delay:2s;width:5px;height:5px}
.parts i:nth-child(5){left:48%;animation-duration:8s;animation-delay:4s}
.parts i:nth-child(6){left:58%;animation-duration:13s;animation-delay:1.5s;width:3px;height:3px}
.parts i:nth-child(7){left:66%;animation-duration:11s;animation-delay:5s}
.parts i:nth-child(8){left:74%;animation-duration:9.5s;animation-delay:2.5s;width:5px;height:5px}
.parts i:nth-child(9){left:82%;animation-duration:15s;animation-delay:0.5s}
.parts i:nth-child(10){left:90%;animation-duration:10.5s;animation-delay:3.5s;width:4px;height:4px}
.parts i:nth-child(11){left:14%;animation-duration:16s;animation-delay:6s;width:3px;height:3px}
.parts i:nth-child(12){left:60%;animation-duration:12.5s;animation-delay:7s}
@keyframes flutua{to{transform:translateY(-105vh) translateX(18px);opacity:0}}
.login-card{position:relative;z-index:2;width:min(87vw,370px);background:rgba(22,26,36,.55);
  border:1px solid rgba(255,255,255,.14);border-radius:24px;padding:34px 26px 28px;backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 30px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.12), 0 0 0 1px rgba(226,48,70,.12);
  text-align:center;animation:sobe .55s cubic-bezier(.2,.85,.2,1)}
@keyframes sobe{from{opacity:0;transform:translateY(26px) scale(.96)}to{opacity:1;transform:none}}
.login-logo{position:relative;font-size:48px;display:inline-flex;align-items:center;justify-content:center;width:92px;height:92px;margin-bottom:4px}
.login-logo .ring{position:absolute;inset:6px;border-radius:50%;border:2px solid transparent;
  background:conic-gradient(from 0deg,var(--red2),transparent 35%,transparent 65%,var(--red2)) border-box;
  -webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  animation:roda 3s linear infinite}
@keyframes roda{to{transform:rotate(360deg)}}
.login-logo::after{content:'';position:absolute;inset:14px;border-radius:50%;background:radial-gradient(rgba(226,48,70,.4),transparent 70%);animation:pulsa 2.2s ease-in-out infinite}
@keyframes pulsa{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:1}}
.login-card h1{color:#fff;font-size:25px;margin:6px 0 3px;font-weight:800;letter-spacing:.3px}
.login-card h1 b{background:linear-gradient(90deg,#ff6072,#c8102e);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.login-sub{color:rgba(255,255,255,.62);font-size:12.5px;margin:0 0 24px}
.login-card input{width:100%;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.16);
  border-radius:13px;color:#fff;font-size:16px;padding:15px;margin-bottom:11px;outline:none;transition:.18s}
.login-card input::placeholder{color:rgba(255,255,255,.45)}
.login-card input:focus{border-color:var(--red2);background:rgba(255,255,255,.12);box-shadow:0 0 0 3px rgba(226,48,70,.18)}
.login-card button{position:relative;overflow:hidden;width:100%;background:linear-gradient(135deg,#e23046,#c8102e);color:#fff;border:0;
  border-radius:13px;font-size:17px;font-weight:800;padding:16px;margin-top:5px;cursor:pointer;
  box-shadow:0 10px 30px rgba(200,16,46,.45)}
.login-card button span{position:relative;z-index:2}
.login-card button::before{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);animation:brilho 3s ease-in-out infinite}
@keyframes brilho{0%{left:-120%}55%,100%{left:130%}}
.login-card button:active{transform:translateY(1px)}
.login-erro{color:#ff8a95;font-size:13px;margin-top:10px;min-height:16px;font-weight:600}
.login-tag{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1);font-size:11.5px;color:#ffd2d8;font-weight:700;letter-spacing:.3px}
.login-rodape{position:absolute;bottom:16px;z-index:2;color:rgba(255,255,255,.42);font-size:10.5px;text-align:center;line-height:1.7;width:100%;padding:0 20px}
.login-rodape b{color:rgba(255,255,255,.72)}
.login-rodape div:first-child{font-size:11.5px}

/* ===== PC: coluna centralizada estilo celular (no fim, pra vencer as regras base) ===== */
@media (min-width:600px){
  html{background:#dfe3ea}
  body{max-width:560px;margin:0 auto;background:var(--bg);box-shadow:0 0 50px rgba(20,30,50,.18);min-height:100vh}
  #topo{left:50% !important;right:auto !important;transform:translateX(-50%);width:560px;max-width:100vw}
  #tabs{left:50% !important;right:auto !important;transform:translateX(-50%);width:560px;max-width:100vw}
  .chat-compose{left:50% !important;right:auto !important;transform:translateX(-50%);width:560px;max-width:100vw}
  #login .login-bg,#login .login-grid,#login .parts{max-width:100vw}
  #scan-overlay{left:50%;transform:translateX(-50%);width:560px;max-width:100vw}
}

/* ===================== TEMA ESCURO ===================== */
body.tema-escuro{
  --bg:#0d1017; --card:#171d29; --line:#283143; --line2:#1e2531;
  --txt:#e8edf6; --dim:#94a0b4; --dim2:#65718a;
  --red-soft:#2c1218; --green-soft:#10271b;
}
body.tema-escuro b{color:#fff}
body.tema-escuro #topo,body.tema-escuro #tabs,body.tema-escuro .chat-compose{background:#121826;border-color:var(--line)}
body.tema-escuro .item,body.tema-escuro .bloco,body.tema-escuro .kpi,body.tema-escuro .dash-kpi,
body.tema-escuro .totais .b,body.tema-escuro .repo-head .bloco,body.tema-escuro #q,body.tema-escuro .chip,
body.tema-escuro .fchip,body.tema-escuro .campo,body.tema-escuro .campo-stand,body.tema-escuro .desc-mini,
body.tema-escuro .sync,body.tema-escuro .ic-btn,body.tema-escuro .upload,body.tema-escuro .ordenar select,
body.tema-escuro .cfg-add input,body.tema-escuro .chat-compose input,body.tema-escuro .chat-compose select,
body.tema-escuro .feira-acao input,body.tema-escuro .msg.outro,body.tema-escuro .btn.ghost,
body.tema-escuro .btn-ghost,body.tema-escuro #scan-overlay{background:var(--card);color:var(--txt)}
body.tema-escuro input,body.tema-escuro select,body.tema-escuro textarea{color:var(--txt)}
body.tema-escuro .chip.on,body.tema-escuro .fchip.on{background:var(--red);color:#fff}
body.tema-escuro .chips.grupo .chip.on{background:#e8edf6;color:#121826}
body.tema-escuro .dash-kpi.hero,body.tema-escuro .btn,body.tema-escuro .btn-comprar,
body.tema-escuro .chat-compose button:not(.cc-ic),body.tema-escuro .feira-acao .mini,
body.tema-escuro .ic-scan{color:#fff}
body.tema-escuro .resultado.bom,body.tema-escuro .total-compra .ok b{filter:brightness(1.1)}
body.tema-escuro .login-card input{background:rgba(255,255,255,.07)}

/* cores de destaque (config) */
.cores{display:flex;gap:8px}
.cores .cor{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer}
.cores .cor.on{border-color:var(--txt)}
/* acentos */
body[data-cor=azul]{--red:#2563eb;--red2:#3b82f6;--red-soft:#e8f0fe}
body[data-cor=verde]{--red:#0f8a43;--red2:#16a34a;--red-soft:#e7f6ec}
body[data-cor=roxo]{--red:#7c3aed;--red2:#8b5cf6;--red-soft:#f0e8fb}
body[data-cor=laranja]{--red:#ea580c;--red2:#f97316;--red-soft:#fff0e6}

/* ===================== DASHBOARD PRO ===================== */
.dash-hero{background:linear-gradient(135deg,var(--red),var(--red2));color:#fff;border-radius:18px;padding:18px;margin-bottom:12px;box-shadow:0 12px 30px rgba(200,16,46,.28)}
.dash-hero.verde{background:linear-gradient(135deg,#0f8a43,#16a34a);box-shadow:0 12px 30px rgba(15,138,67,.28)}
.dh-rot{font-size:12px;opacity:.9;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.dh-num{font-size:34px;font-family:var(--mono);font-weight:800;margin:4px 0 2px;line-height:1}
.dh-sub{font-size:12px;opacity:.92;margin-top:4px}
.dh-gauge{height:8px;background:rgba(255,255,255,.25);border-radius:6px;margin:10px 0 5px;overflow:hidden}
.dh-gfill{height:100%;background:#fff;border-radius:6px}
.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.dcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 8px;text-align:center}
.dcard:active{border-color:var(--red)}
.dcard .di{font-size:22px}
.dcard .dn{font-size:16px;font-weight:800;font-family:var(--mono);margin-top:3px}
.dcard .dl{font-size:10.5px;color:var(--dim);margin-top:2px;font-weight:600}
/* gráfico de barras compra×venda */
.tend{display:flex;justify-content:space-around;align-items:flex-end;height:130px;gap:8px;padding-top:8px}
.tcol{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}
.tbars{flex:1;display:flex;align-items:flex-end;gap:3px;width:100%;justify-content:center}
.tb{width:38%;border-radius:4px 4px 0 0;min-height:2px}
.tb.c{background:linear-gradient(180deg,#16a34a,#0f8a43)}
.tb.v{background:linear-gradient(180deg,#e23046,#c8102e)}
.tm{font-size:10px;color:var(--dim);margin-top:5px;font-family:var(--mono)}
.tend-leg{text-align:center;font-size:11px;margin-top:8px;font-weight:700}
.tend-leg .lc{color:var(--green)} .tend-leg .lv{color:var(--red);margin-left:10px}

/* arrasta-pra-rolar (grab cursor no PC) */
.chips,.filtro-chips,#tabs,.mov,.cores,.tend{cursor:grab}
.chips.arrastando,.filtro-chips.arrastando,#tabs.arrastando,.mov.arrastando,.tend.arrastando{cursor:grabbing;scroll-behavior:auto}
.arrastando *{pointer-events:none}

/* caixas de filtro (categoria/fabricante) */
.filtro-box{display:flex;gap:8px;margin-bottom:10px}
.fbox{flex:1;min-width:0;background:var(--card);border:1.5px solid var(--line);border-radius:11px;padding:9px 12px;text-align:left;display:flex;align-items:center;gap:6px;color:var(--txt)}
.fbox .fl{font-size:10.5px;color:var(--dim);text-transform:uppercase;font-weight:700;letter-spacing:.3px;flex:0 0 auto}
.fbox b{flex:1;min-width:0;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fbox .fseta{color:var(--dim);flex:0 0 auto}
.fbox.ativo{border-color:var(--red)}
.fbox.ativo b{color:var(--red)}
/* bottom sheet do picker */
#picker-overlay{position:fixed;inset:0;z-index:80;background:rgba(10,14,22,.45);display:none;align-items:flex-end}
#picker-overlay.on{display:flex}
.picker-sheet{background:var(--bg);width:100%;max-height:78vh;border-radius:18px 18px 0 0;padding:14px 14px calc(14px + env(safe-area-inset-bottom));display:flex;flex-direction:column;animation:sheetUp .25s cubic-bezier(.2,.85,.2,1)}
@media (min-width:600px){.picker-sheet{max-width:560px;margin:0 auto;border-radius:18px;margin-bottom:8vh}#picker-overlay{align-items:center}}
@keyframes sheetUp{from{transform:translateY(40px);opacity:.4}to{transform:none;opacity:1}}
.picker-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.picker-head b{font-size:17px}
.picker-head button{background:var(--card);border:1px solid var(--line);width:32px;height:32px;border-radius:50%;font-size:15px;color:var(--txt)}
#picker-q{width:100%;background:var(--card);border:1.5px solid var(--line);border-radius:11px;color:var(--txt);font-size:16px;padding:12px;outline:none;margin-bottom:10px}
#picker-q:focus{border-color:var(--red)}
#picker-list{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
#picker-list li{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:13px 14px;display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:15px;font-weight:600}
#picker-list li:active{border-color:var(--red);background:var(--red-soft)}
#picker-list li.sel{border-color:var(--red);color:var(--red)}
#picker-list li .c{font-size:12px;color:var(--dim);font-weight:600;font-family:var(--mono)}

/* 🚂 trem do cashback */
.trem-box{background:linear-gradient(135deg,#0f8a43,#16a34a);color:#fff;border-radius:16px;padding:14px;margin-bottom:12px;box-shadow:0 10px 26px rgba(15,138,67,.3)}
.trem-top{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600}
.trem-top b{font-size:22px;font-family:var(--mono)}
.trilho{position:relative;height:14px;background:rgba(255,255,255,.22);border-radius:8px;margin:16px 0 6px}
.trilho-fill{height:100%;background:linear-gradient(90deg,#ffe082,#ffc107);border-radius:8px;transition:width .7s cubic-bezier(.2,.8,.2,1)}
.loco{position:absolute;top:-10px;transform:translateX(-50%);font-size:22px;transition:left .7s cubic-bezier(.2,.8,.2,1);filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}
.vagoes{display:flex;gap:2px;justify-content:center;font-size:17px;margin-top:6px}
.vagoes .vag{transition:.4s;filter:grayscale(1);opacity:.4}
.vagoes .vag.on{filter:none;opacity:1;animation:vagPop .4s}
@keyframes vagPop{0%{transform:scale(.6)}60%{transform:scale(1.25)}100%{transform:scale(1)}}
.trem-meta{font-size:12.5px;text-align:center;margin-top:9px;opacity:.96;line-height:1.4}
.trem-meta b{font-weight:800}
.cupons-ganhos{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:10px}
.cupom{background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.35);border-radius:20px;padding:4px 11px;font-size:11.5px;font-weight:700}
/* alerta de cupom conquistado */
.cupom-pop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:130;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(8,12,20,.55);opacity:0;pointer-events:none;transition:opacity .25s;text-align:center;padding:30px}
.cupom-pop.show{opacity:1;pointer-events:auto}
.cupom-pop .cp-emoji{font-size:70px;animation:bounce 1s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.cupom-pop .cp-t{color:#fff;font-size:24px;font-weight:800;margin-top:10px}
.cupom-pop .cp-m{color:rgba(255,255,255,.85);font-size:15px;margin-top:6px;max-width:300px}

/* pedido HOS: preço editável */
.feira-acao .pd-preco{border-color:var(--red)}
.pd-tot{font-family:var(--mono);font-weight:700;font-size:13px;flex:1;text-align:right}
.pd-tot.dim{color:var(--dim);font-weight:600;font-family:inherit;font-size:12px}

/* chat: cabeçalho próprio fixo + esconde o topo de descontos */
body.chat-aberto{padding-top:0}
body.chat-aberto #topo{display:none}
.chat-header{position:sticky;top:0;z-index:20;background:var(--card);border-bottom:1px solid var(--line);margin:-12px -12px 10px;padding:10px 12px calc(10px + env(safe-area-inset-top));display:flex;align-items:center;gap:10px}
.chat-header #chat-voltar{background:var(--bg);border:1px solid var(--line);color:var(--red);font-size:15px;font-weight:700;border-radius:20px;padding:8px 14px;flex:0 0 auto}
.chat-header .ch-tit{font-size:16px;font-weight:800}
.chat-header .ch-tit .sub-dim{font-weight:400;font-size:12px}

/* botões de apagar + linha de resumo */
.resumo-linha{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:4px 2px 10px}
.btn-apagar{background:var(--red-soft);color:var(--red);border:1px solid #f0b6bf;border-radius:10px;padding:8px 12px;font-size:12.5px;font-weight:700;flex:0 0 auto}
.btn-apagar:active{filter:brightness(.95)}

/* trem: cashback atual + cupons de sorteio */
.cb-now{font-size:13px;font-weight:700;margin-top:4px;opacity:.97}
.cb-now b{font-size:15px}
.cupom-sorteio{font-size:12px;text-align:center;margin-top:9px;background:rgba(255,255,255,.18);border-radius:10px;padding:7px 10px}
.cupom-sorteio b{font-weight:800}

/* ===== trem do cashback v2 (mais foda) ===== */
.trem-box{position:relative;overflow:hidden}
.trem-top{display:flex;justify-content:space-between;align-items:flex-start;font-weight:600}
.tt-rot{font-size:11.5px;opacity:.9}
.tt-num{font-size:26px;font-family:var(--mono);font-weight:800;line-height:1.05}
.cb-badge{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);border-radius:12px;padding:6px 12px;text-align:right}
.cbb-rot{font-size:10px;opacity:.9;font-weight:700}
.cbb-num{font-size:18px;font-family:var(--mono);font-weight:800;color:#fff;text-shadow:0 0 12px rgba(255,224,130,.8)}
/* estações (faixas de cashback) */
.estacoes{display:flex;justify-content:space-between;margin:14px 2px 2px;gap:2px}
.estacao{flex:1;text-align:center;opacity:.5;transition:.4s}
.estacao.ok{opacity:1}
.estacao .est-dot{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.25);margin:0 auto;font-size:12px;display:flex;align-items:center;justify-content:center;font-weight:800;border:2px solid rgba(255,255,255,.4)}
.estacao.ok .est-dot{background:#ffc107;color:#0a4022;border-color:#fff;box-shadow:0 0 10px rgba(255,193,7,.9)}
.estacao.atual .est-dot{animation:pulseDot 1.2s infinite}
@keyframes pulseDot{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
.estacao .est-cb{font-size:12px;font-weight:800;margin-top:3px;font-family:var(--mono)}
.estacao .est-meta{font-size:9.5px;opacity:.8}
/* trilho + locomotiva animada */
.trilho{position:relative;height:12px;background:rgba(255,255,255,.22);border-radius:8px;margin:8px 0 4px}
.trilho-fill{height:100%;background:linear-gradient(90deg,#ffe082,#ffc107);border-radius:8px;transition:width .8s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 12px rgba(255,193,7,.6)}
.loco{position:absolute;top:-11px;transform:translateX(-50%);transition:left .8s cubic-bezier(.2,.8,.2,1)}
.loco-emoji{font-size:24px;display:inline-block;animation:chug .5s infinite;filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}
@keyframes chug{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-2px) rotate(2deg)}}
.fumaca{position:absolute;left:-12px;top:-6px;font-size:12px;opacity:.7;animation:fuma 1.4s infinite}
@keyframes fuma{0%{opacity:0;transform:translate(0,0) scale(.6)}40%{opacity:.7}100%{opacity:0;transform:translate(-10px,-12px) scale(1.2)}}
.trem-meta{font-size:13px;text-align:center;margin-top:10px;font-weight:600}
.trem-meta b{font-weight:800;color:#fff;text-shadow:0 0 10px rgba(255,224,130,.7)}
/* cupom de sorteio */
.cupom-sorteio{background:rgba(255,255,255,.16);border-radius:12px;padding:10px 12px;margin-top:11px;text-align:center}
.cs-top{font-size:16px;font-weight:700}.cs-top b{font-size:20px}
.cs-sub{font-size:11px;opacity:.92;margin-top:2px}
.cs-bar{height:6px;background:rgba(255,255,255,.25);border-radius:4px;margin-top:8px;overflow:hidden}
.cs-fill{height:100%;background:#fff;border-radius:4px;transition:width .6s}

/* estoque negativo no pré-pedido */
.est-neg{color:var(--red)}

/* ===== item do pré-pedido (nosso custo · custo ofertado · total) ===== */
.ped-item{flex-direction:column;align-items:stretch;gap:8px}
.pi-nome{font-size:15px;font-weight:700;line-height:1.25}
.pi-meta{font-size:11.5px;color:var(--dim)}
.pi-meta .ean{font-family:var(--mono)}
.pi-edit{display:flex;gap:8px;align-items:flex-end}
.pi-bloco{display:flex;flex-direction:column;gap:3px}
.pi-bloco label{font-size:10px;color:var(--dim);font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.pi-bloco.ref{flex:0 0 auto}
.pi-bloco.ref .pi-val{font-family:var(--mono);font-size:14px;color:var(--dim);padding:9px 0}
.pi-bloco.oferta{flex:1}
.pi-bloco.qtd{flex:0 0 78px}
.pi-input{display:flex;align-items:center;background:#fff;border:2px solid var(--line);border-radius:10px;padding:0 9px}
.pi-bloco.oferta .pi-input{border-color:var(--green)}
.pi-input span{color:var(--dim);font-size:14px;font-weight:700}
.pi-input input{width:100%;background:none;border:0;outline:none;font-family:var(--mono);font-weight:800;padding:9px 4px}
.pi-bloco.oferta .pi-input input{font-size:20px;color:var(--green)}
.pi-bloco.qtd .pi-input input{font-size:17px;text-align:center}
.pi-input:focus-within{border-color:var(--red)}
.pi-total{display:flex;justify-content:space-between;align-items:center;background:var(--green-soft);border-radius:9px;padding:8px 12px;margin-top:2px}
.pi-total span{font-size:12px;color:var(--green);font-weight:600}
.pi-total b{font-family:var(--mono);font-size:18px;color:var(--green);font-weight:800}
.pi-total.dim{background:#f3f4f7}.pi-total.dim span,.pi-total.dim b{color:var(--dim)}

/* botão adicionar/remover do pré-pedido na feira */
.feira-acao .mini.no-ped{background:var(--green)}
.feira-acao .mini{white-space:nowrap}

/* meta da feira (meio milhão) destacada no trem */
.meta-geral{background:rgba(0,0,0,.18);border-radius:12px;padding:11px 13px;margin-top:10px}
.mg-top{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;opacity:.95}
.mg-top b{font-size:16px;font-family:var(--mono)}
.mg-bar{position:relative;height:18px;background:rgba(255,255,255,.2);border-radius:9px;margin:7px 0 5px;overflow:hidden}
.mg-fill{height:100%;background:linear-gradient(90deg,#ffe082,#ffc107);border-radius:9px;transition:width .8s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 12px rgba(255,193,7,.7)}
.mg-pct{position:absolute;top:0;left:0;right:0;text-align:center;line-height:18px;font-size:11px;font-weight:800;color:#0a3d1f;text-shadow:0 0 3px rgba(255,255,255,.5)}
.mg-sub{font-size:11px;opacity:.92}.mg-sub b{font-weight:800}

/* link "sou representante" no login */
.login-rep{display:block;text-align:center;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);font-size:13px;font-weight:600;text-decoration:none}
.login-rep:active{color:#ff8a95}

/* QR do representante na feira */
.qr-rep{margin-bottom:12px}
.qr-rep #btn-qr{width:100%;background:var(--card);border:1.5px dashed var(--red);color:var(--red);border-radius:12px;padding:12px;font-size:14px;font-weight:700}
#qr-box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin-top:8px;text-align:center}
#qr-box p{font-size:12.5px;color:var(--dim);margin:0 0 10px}
#qr-img{width:220px;max-width:80%;border-radius:10px;background:#fff;padding:8px}
.qr-acoes{display:flex;gap:8px;margin-top:12px}
.qr-acoes .btn{flex:1;text-decoration:none;display:block;text-align:center}

/* selects do upload da feira (ST / aplicado) */
.up-sel{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:9px;font-size:14px;background:#fff;color:var(--txt);margin-top:3px}
body.tema-escuro .up-sel{background:var(--card);color:var(--txt)}

/* pill azul = preço igual ao nosso custo */
.preco-pill.azul{background:#e8f0fe;color:#1d4eb8}
body.tema-escuro .preco-pill.azul{background:#16243a;color:#7fb0ff}
/* alertas de análise no pré-pedido */
.pi-alerta{font-size:11.5px;border-radius:9px;padding:7px 10px;margin-top:6px;line-height:1.35}
.pi-alerta.caro{background:var(--red-soft);color:var(--red)}
.pi-alerta.parado{background:#fef3e2;color:#92500a}
.pi-alerta b{font-weight:800}

/* overlay de busca de produto no chat (reusa estilo do picker) */
#prodbusca-overlay{position:fixed;inset:0;z-index:90;background:rgba(10,14,22,.45);display:none;align-items:flex-end}
#prodbusca-overlay.on{display:flex}
@media (min-width:600px){#prodbusca-overlay{align-items:center}}
#pb-q{width:100%;background:var(--card);border:1.5px solid var(--line);border-radius:11px;color:var(--txt);font-size:16px;padding:12px;outline:none;margin-bottom:10px}
#pb-q:focus{border-color:var(--red)}
#pb-list{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
#pb-list li{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:14px}
#pb-list li:active{border-color:var(--red);background:var(--red-soft)}
#pb-list li b{font-size:14px}
#pb-list li .c{font-size:11.5px;color:var(--dim)}

/* seletor de pré-pedido (adicionar produto) */
#pedchooser-overlay{position:fixed;inset:0;z-index:90;background:rgba(10,14,22,.45);display:none;align-items:flex-end}
#pedchooser-overlay.on{display:flex}
@media (min-width:600px){#pedchooser-overlay{align-items:center}}
#pedchooser-overlay .campo.stand{gap:8px}
#pedchooser-overlay #pc-novo{flex:1}
#pc-list{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
#pc-list li{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:12px 13px;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600}
#pc-list li:active{border-color:var(--red);background:var(--red-soft)}
#pc-list li .c{font-size:11.5px;color:var(--dim);font-weight:400}

/* trem REALIZADO (pedido feito) — verde, no Painel */
.trem-box.feito{background:linear-gradient(135deg,#0f8a43,#0a6e35)}
.trem-box.feito .mg-fill{background:linear-gradient(90deg,#d6ffe0,#7CFFB0);box-shadow:0 0 12px rgba(120,255,150,.7)}
.trem-box.feito .mg-pct{color:#06351c}
/* resumo "minha compra" compacto no topo da Feira */
.feira-meta-bar{display:flex;justify-content:space-between;align-items:center;gap:10px;background:linear-gradient(135deg,#c8102e,#9b0f24);color:#fff;border-radius:12px;padding:10px 13px;margin-bottom:10px}
.feira-meta-bar .fm-l{font-size:11px;opacity:.9;font-weight:600}
.feira-meta-bar .fm-n{font-size:18px;font-weight:800;font-family:var(--mono)}
.feira-meta-bar .fm-cb{text-align:right}
.feira-meta-bar .fm-cb .fm-l{opacity:.85}

/* registrar compra (só valor) */
#reg-overlay{position:fixed;inset:0;z-index:90;background:rgba(10,14,22,.45);display:none;align-items:flex-end}
#reg-overlay.on{display:flex}
@media (min-width:600px){#reg-overlay{align-items:center}}
.reg-form label{display:block;font-size:11px;color:var(--dim);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-bottom:10px}
.reg-form label input{display:block;width:100%;margin-top:4px;border:1.5px solid var(--line);border-radius:10px;padding:11px;font-size:16px;background:var(--card);color:var(--txt);text-transform:none;font-weight:400;letter-spacing:0}
.reg-form label input:focus{border-color:var(--red);outline:none}
.reg-2col{display:flex;gap:10px}.reg-2col label{flex:1}
.reg-form .toggle{display:flex;gap:8px;margin-top:4px}
.reg-form .toggle button{flex:1;background:var(--bg);border:1.5px solid var(--line);color:var(--txt);border-radius:10px;padding:11px;font-size:14px;font-weight:700}
.reg-form .toggle button.on{background:var(--red);border-color:var(--red);color:#fff}
.reg-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line2)}
.reg-item:last-child{border-bottom:0}
.reg-item .c{font-size:11.5px;color:var(--dim);margin-top:2px}
.reg-item .reg-val{font-family:var(--mono);font-size:15px;color:var(--green)}
.reg-del{background:none;border:0;font-size:15px;margin-left:8px}

/* arquivos recebidos (download) */
#arquivos-box{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.arq-item{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 12px}
.arq-item b{font-size:14px}
.arq-item .c{font-size:11px;color:var(--dim);margin-top:2px;word-break:break-word}
#btn-arquivos{width:100%;background:var(--card);border:1.5px dashed var(--dim);color:var(--txt);border-radius:12px;padding:12px;font-size:14px;font-weight:700}

/* filtro com 3 caixas (grupo/classif/fabricante) */
.filtro-box.tres{display:flex;gap:6px}
.filtro-box.tres .fbox{flex:1;min-width:0;padding:8px 9px}
.filtro-box.tres .fbox .fl{font-size:9.5px}
.filtro-box.tres .fbox b{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
