/*app\portals\loja\static\forn.css*/

/* Paleta preto + dourado */
:root{
  --bg:#0b0b0b; --panel:#121212; --bd:#2b2b2b;
  --gold:#e4c95c; --muted:#aaa; --text:#eee;
}

html,body{ background:var(--bg); color:var(--text); font-family:system-ui,Segoe UI,Roboto,Arial; }
a{ color:var(--gold); }

/* Layout geral */
.shell{ display:grid; grid-template-columns:260px 1fr; min-height:100dvh; }
.sidebar{
  border-right:1px solid var(--bd); background:#0e0e0e; padding:16px; position:sticky; top:0; height:100dvh;
}
.brand{ display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.brand img{ width:28px; height:28px }
.brand h1{ font-size:18px; margin:0; color:var(--gold) }
.nav a{
  display:block; padding:10px 12px; margin:6px 0; border-radius:10px; color:#ddd; text-decoration:none;
}
.nav a.active, .nav a:hover{ background:var(--panel); border:1px solid var(--bd); }
.main{ padding:18px; }

/* Componentes */
.box{ background:#121212; border:1px solid #232323; border-radius:12px; padding:16px; margin:12px 0; position:relative; }
.muted{ color:var(--muted); }
.btn{
  display:inline-block; background:var(--gold); color:#000; font-weight:700;
  padding:10px 14px; border:none; border-radius:10px; cursor:pointer;
}
.btn[disabled]{ opacity:.6; cursor:not-allowed }
input:not([type="checkbox"]):not([type="radio"]), select{
  width:100%; background:#161616; border:1px solid var(--bd); border-radius:8px; padding:9px 10px; color:#eee;
}

/* Cards de demanda */
.card{ max-width: 1140px; margin: 10px auto; }
.card{ border:1px solid var(--bd); border-radius:12px; background:#111; margin:10px 0; overflow:hidden; }
.cardHead{ display: grid; grid-template-columns: 1fr 220px; gap:16px; padding:12px 12px; align-items:center }
.cardHead .left{ display: flex; align-items: center;gap: 12px;}
.cardHead:hover{ background:#131313; cursor:pointer; }
.card img.principal{ width:120px; height:80px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); }
.carInfo b{ color:#fff }
.carInfo .muted{ display:block; }
.carInfo .small{ font-size:13px; margin-top:3px }
.k{ color:#d0d0d0; font-weight:700 }
.cardRight{ text-align:right; }
.timer{ font-variant-numeric: tabular-nums; }

/* Área expandida */
.expand{ border-top:1px solid var(--bd); padding:12px; display:none; }
.thumbRow{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.thumbRow img{ width:76px; height:60px; object-fit:cover; border:1px solid var(--bd); border-radius:8px; cursor:pointer; }
.bigPreview{ max-width:100%; border:1px solid var(--bd); border-radius:8px; margin-bottom:10px; }

.tbl{ width:100%; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.tbl th, .tbl td{ padding:8px 10px; border-bottom:1px solid var(--bd); }
.tbl .input, .tbl select{ margin-right:8px }   /* um espacinho entre caixas */
input.upper{ text-transform: uppercase; }
.tbl thead th{ color:var(--gold); text-align:left; border-bottom:1px solid #404040; }
.txr{ text-align:right }
.actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }

/* Larguras constantes para as colunas (desktop) */
.tbl colgroup col.c1{ width: 36%; }      /* peça/código */
.tbl colgroup col.c2{ width: 6%;  }       /* qtd */
.tbl colgroup col.c3{ width: 16%; }      /* marca */
.tbl colgroup col.c4{ width: 12%; }      /* cond */
.tbl colgroup col.c5{ width: 12%; }      /* preço */
.tbl colgroup col.c6{ width: 14%; }      /* obs */
.tbl colgroup col.c7{ width: 128px; }      /* ações */

.tbl td, .tbl th{ vertical-align:middle; padding:10px 12px; }
.tbl td .input:not([type="checkbox"]):not([type="radio"]), .tbl td select{ width:100%; margin:0; }
.tbl td.actions .icon.linked{ border-color:#1b6c1b; box-shadow:0 0 0 1px #1b6c1b inset; }

/* Login */
.loginWrap{ max-width:920px; margin:40px auto; display:grid; grid-template-columns:1fr 1fr; background:#0f0f0f; border:1px solid var(--bd); border-radius:14px; overflow:hidden }
.loginLeft{ padding:22px }
.loginRight{ background:#1a1a1a; min-height:360px }
.loginTitle{ color:var(--gold); margin:0 0 12px 0; }
.row{ display:flex; gap:12px; flex-wrap:wrap; }
.col{ flex:1 1 240px }

/* badges / estados */
.badge { display:inline-block; padding:2px 8px; border-radius:999px; font-weight:700; font-size:12px }
.badge.gold { background:var(--gold); color:#000 }
.badge.warn { background:#b58900; color:#000 }
.badge.danger { background:#b00020; color:#fff }
.badge.instock{ background:#114b11; color:#9cf09c; border:1px solid #1b6c1b }

/* botões variantes */
.btn.secondary{ background:#222; color:#ddd; border:1px solid var(--bd) }
.btn.ghost{ background:transparent; color:#ddd; border:1px solid var(--bd) }

/* estados do timer */
.timer.warn{ color:#f4d03f }
.timer.danger{ color:#ff6b6b }
.input.upper{ text-transform: uppercase; }

/* barra de totais */
.totalBar{
  display:flex; justify-content:flex-end; gap:16px; align-items:center;
  padding:10px; margin-top:8px; border-top:1px solid var(--bd);
}
.totalBar b{ color:#fff }

/* lightbox */
.lb {
  position:fixed; inset:0; background:rgba(0,0,0,.85);
  display:none; align-items:center; justify-content:center; z-index:9999;
  overflow:auto;        /* permite rolar quando estiver muito grande */
}
.lb img{
  max-width:90vw; max-height:90vh;
  border-radius:10px; border:1px solid #333;
  transition: transform .2s ease;
  transform-origin:center;
  cursor: zoom-in;
}
.lb.show{ display:flex }
.lb.zoom img{
  max-width:none; max-height:none;   /* libera o tamanho natural */
  transform: scale(2.2);             /* amplia mais */
  cursor: zoom-out;
}

/* mensagens (se ainda não tiver) */
.msg{ border:1px solid var(--bd); background:#151515; padding:10px 12px; border-radius:8px }
.msg.ok{ border-color:#2e7d32; background:#102a12; color:#b2ffb2 }
.msg.warn{ border-color:#b58900; background:#2a2206; color:#ffd36b }
.msg.error{ border-color:#b00020; background:#2a0e12; color:#ffb3b3 }

/* estados de validação */
.input.invalid, select.invalid, textarea.invalid{
  border-color:#b00020 !important;
  box-shadow:0 0 0 1px #b00020 inset;
}

/* --- Modal (vidro claro) --- */
.modal{
  position:fixed; inset:0; z-index:2000;
  display:flex; align-items:center; justify-content:center;
  padding:24px;

  /* mais escuro e mais blur para "não ver nada" atrás */
  background:rgba(0,0,0,.78);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}
.modal-box{
  width:min(980px, 96vw);
  background: linear-gradient(180deg, rgba(255,255,255,.15), rgba(255,255,255,.08));
  border:1px solid rgba(255,255,255,.20);
  border-radius:16px;
  box-shadow:0 18px 60px rgba(0,0,0,.45);
  color:#fff;
  padding:18px;
}
.modal-box h3{ margin:0 0 10px; color:var(--gold); }

/* espaçamentos do formulário dentro do modal */
.modal-box .row{ display:flex; gap:12px; flex-wrap:wrap; margin:10px 0; }
.modal-box .col{ flex:1 1 240px; min-width:220px }
.modal-box label{ display:block; font-size:.92rem; margin:0 0 6px; color:#ddd }
.modal-box .input, .modal-box select{
  background: rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.25);
}
.modal-box .right{ display:flex; gap:10px; justify-content:flex-end; margin-top:12px; }

/* === Form em página (caixa .box) === */
.box.box-form{
  max-width: 1100px;        /* limita a largura e centraliza */
  margin: 16px auto;
  padding: 16px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.12);
  box-sizing: border-box;
}

.box.box-form .hdr{ margin-bottom: 8px; }

/* grid responsivo de campos */
.box.box-form form .row{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;                 /* espaço horizontal/vertical entre campos */
  align-items: start;
  margin: 12px 0;
}

/* impede que o conteúdo “estoure” a coluna */
.box.box-form form .col{ min-width: 0; }

/* rótulos e inputs */
.box.box-form form label{
  display: block;
  font-size: .92rem;
  color: #ddd;
  margin: 0 0 6px;
}

.box.box-form form .input,
.box.box-form form select,
.box.box-form form textarea{
  width: 100%;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  box-sizing: border-box;     /* evita somar padding à largura */
}

/* placeholders mais visíveis no dark */
.box.box-form form input::placeholder,
.box.box-form form textarea::placeholder{ color: #9aa0a6; }

/* linha dos botões */
.box.box-form form .right{
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 14px;
}

/* previne qualquer overflow horizontal no formulário */
.box.box-form form{ overflow: hidden; }

/* ajuste fino (mobile) */
@media (max-width: 700px){
  .box.box-form{ margin: 8px auto; padding: 12px; }
  .box.box-form form .row{ gap: 10px; margin: 10px 0; }
}

/* === Fix contraste do <select> (dropdown) no tema escuro — só no form novo === */
.box.box-form select{
  color:#fff;                            /* texto quando FECHADO */
  background: rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.22);
}

/* texto quando ABERTO (lista de opções) */
.box.box-form select option{
  color:#111 !important;                 /* letras escuras */
  background:#fff !important;            /* fundo branco */
}

/* opção selecionada/destaque */
.box.box-form select option:checked{
  background:#e9ecef !important;
  color:#111 !important;
}

/* estado desabilitado (ex.: “Selecione a marca”) */
.box.box-form select:disabled,
.box.box-form select option[disabled]{
  color:#999 !important;
  background:#f6f6f6 !important;
}

/* ===== Fotos no form (.box.box-form) ===== */
.box.box-form .dz{
  width:100%;
  min-height:70px;
  border:1.5px dashed rgba(255,255,255,.35);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  text-align:center;
  padding:12px;
  cursor:pointer;
  background: rgba(255,255,255,.06);
  transition:.2s;
  color:#e7e7e7;
}
.box.box-form .dz:hover{ background: rgba(255,255,255,.08); }
.box.box-form .dz.on{ border-color:#ffd166; background: rgba(255,209,102,.12); }

.box.box-form .thumbs{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap:10px;
  margin-top:10px;
}
.box.box-form .th{
  position:relative;
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;
  overflow:hidden;
  background: rgba(0,0,0,.25);
  min-height: 90px;
}
.box.box-form .th img{
  display:block; width:100%; height:110px; object-fit:cover;
}
.box.box-form .th .cap{
  position:absolute; left:0; right:0; bottom:0;
  background: rgba(0,0,0,.5);
  color:#fff; font-size:.75rem; padding:2px 6px;
}
.box.box-form .th .rm{
  position:absolute; top:8px; right:8px;
  width:28px; height:28px;                /* tamanho fixo */
  border-radius:50%;
  border:0; cursor:pointer;
  background:#ff4757; color:#fff;
  display:inline-flex;                    /* CENTRALIZA o ícone */
  align-items:center; justify-content:center;
  padding:0; line-height:1;               /* evita “saltar” com fontes diferentes */
  box-shadow:0 2px 6px rgba(0,0,0,.25);
}
.box.box-form .th .rm svg{ width:14px; height:14px; display:block; }
.box.box-form .th:hover .rm{ transform:scale(1.05); }


/* === Layout específico da linha de veículo === */
.box.box-form form .row.row-veic{
  grid-template-columns: 1.1fr 1.7fr 0.55fr 0.55fr 0.25fr; /* marca | modelo (maior) | anos (menores) | botão + (estreito) */
  align-items: end;
}
.box.box-form form .row.row-veic .col-model .input:not([type="checkbox"]):not([type="radio"]){ min-width: 260px; }
.box.box-form form .row.row-veic .col-ano .input{ min-width: 120px; }
.box.box-form form .row.row-veic .col-add{ display:flex; flex-direction:column; justify-content:flex-end; }

/* botão + compacto */
.btn.plus{
  width: 44px; padding: 0; height: 40px; line-height: 40px;
  font-size: 24px; font-weight: 800; text-align: center;
}

/* Caixa da lista de veículos adicionados */
.veicBox{
  background: #f3f3f3; color:#000;
  border-radius: 10px; padding: 6px 8px;
  border: 1px solid #e0e0e0;
}
.veicBox .vempty{
  color:#333; font-size:.92rem; padding:6px 2px;
}
.veicBox .vrow{
  display:flex; align-items:center; gap:10px;
  padding: 8px 2px;
  border-top: 1px solid #e1e1e1;   /* só linhas horizontais */
}
.veicBox .vrow:first-child{ border-top: none; }
.veicBox .vtxt{ flex:1 1 auto; font-weight:600; }
.veicBox .vdel{
  width: 28px; height: 28px; line-height: 28px; text-align:center;
  border-radius: 999px; border: 0; cursor: pointer;
  background: #d9534f; color:#fff; font-weight:700;
}

/* responsivo */
@media (max-width: 900px){
  .box.box-form form .row.row-veic{
    grid-template-columns: 1fr 1fr; /* quebra em duas colunas no mobile */
  }
  .box.box-form form .row.row-veic .col-add{ grid-column: 1 / -1; }
}

/* === Veículos compatíveis: tabela simples com linhas horizontais === */
.veicBox{
  background: #f3f3f3; color:#000;
  border-radius: 10px; padding: 6px 8px;
  border: 1px solid #e0e0e0;
}

.veicBox .vtable{ width:100%; }

.veicBox .vhead{
  display: grid;
  grid-template-columns: 1fr 1.6fr 0.6fr 0.3fr; /* Marca | Modelo | Anos | Ações */
  gap: 8px;
  padding: 8px 4px;
  font-weight: 700;
  border-bottom: 1px solid #e1e1e1;
}

.veicBox .vhead .vh.act{ text-align: right; }

.veicBox .vrow{
  display: grid;
  grid-template-columns: 1fr 1.6fr 0.6fr 0.3fr; /* mesmas larguras do head */
  gap: 8px;
  align-items: center;
  padding: 8px 4px;
  border-top: 1px solid #e1e1e1; /* só linhas horizontais */
}

.veicBox .vc.anos{ text-align: left; } /* pode ser center se preferir */
.veicBox .vc.act{ text-align: right; }

.veicBox .vdel{
  border: 0;
  background: transparent;
  color: #d9534f;               /* lixeira vermelha */
  cursor: pointer;
  padding: 2px 4px;
  line-height: 1;
}
.veicBox .vdel:hover{ color:#b52b27; }

/* estado vazio */
.veicBox .vempty{
  color:#333; font-size:.92rem; padding:6px 2px;
}

/* responsivo */
@media (max-width: 900px){
  .veicBox .vhead,
  .veicBox .vrow{
    grid-template-columns: 1.1fr 1.4fr 0.6fr 0.3fr; /* leve ajuste no mobile */
  }
}

.box.box-form .invalid{
  border-color: #ff6b6b !important;
  box-shadow: 0 0 0 1px rgba(255,107,107,.3) inset;
}

/* === Cards do "Meu estoque" === */
#stockCards{ display:flex; flex-direction:column; gap:0 } /* linha dourada cuida da separação */

.stockCard{
  display:grid;
  grid-template-columns: 140px 1fr auto;
  gap:14px;
  align-items:center;
  padding:14px;
  background:#111;
  border:1px solid var(--bd);
  border-radius:12px;
  margin:0 0 14px 0;
  position:relative;
}

/* linha dourada embaixo de cada card */
.stockCard::after{
  content:"";
  position:absolute;
  left:14px; right:14px; bottom:-7px;
  border-bottom:2px solid var(--gold);
  border-radius:999px;
}

.stockLeft{ display:flex; align-items:center; justify-content:center; }
.stockImg{
  width:120px; height:90px; object-fit:cover;
  border-radius:10px; border:1px solid var(--bd);
  background:#0f0f0f;
}
.stockImg.noimg{ display:flex; align-items:center; justify-content:center; font-size:12px; color:#888 }

.stockMid{ min-width:0 }
.stockTitle{
  font-weight:700; color:#fff; margin-bottom:6px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.stockMeta{
  display:flex; gap:16px; flex-wrap:wrap; font-size:13px; color:#cfcfcf; margin-bottom:6px;
}
.stockMeta .k{ color:#d0d0d0; font-weight:700 }

.stockPriceRow{
  display:flex; gap:16px; align-items:center; flex-wrap:wrap;
}
.stockPriceRow .price{ font-variant-numeric: tabular-nums; }

.stockRight{ display:flex; flex-direction:column; gap:8px; }
.stockRight .btn{ width:140px }

/* responsivo */
@media (max-width: 820px){
  .stockCard{ grid-template-columns: 120px 1fr; }
  .stockRight{ grid-column: 1 / -1; flex-direction:row; justify-content:flex-end; }
  .stockRight .btn{ width:auto }
}

/* ações do topo da tela de estoque */
.stock-actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
/* Campo de busca precisa encolher para caber com os botões */
.stock-actions #qEst{ width:auto; flex:1 1 520px; min-width:320px; }
/* Mantém filtros na linha de baixo */
.stock-actions .filters{ display:flex; gap:6px; flex-basis:100%; }
.btn.gold{
  background: var(--gold);
  color:#000; border:1px solid #a38207;
  font-weight:700;
}
.btn.small{ padding:6px 12px; font-size:13px; height:36px; }
.btn.ghost.active{ border-color:var(--gold); color:var(--gold) }

/* cards (adicionados anteriormente) */
#stockCards{ display:flex; flex-direction:column; gap:0 }
.stockCard{
  display:grid; grid-template-columns: 140px 1fr auto; gap:14px; align-items:center;
  padding:14px; background:#111; border:1px solid var(--bd); border-radius:12px; margin:0 0 14px 0;
  position:relative;
}
.stockCard::after{
  content:""; position:absolute; left:14px; right:14px; bottom:-7px;
  border-bottom:2px solid var(--gold); border-radius:999px;
}
.stockLeft{ display:flex; align-items:center; justify-content:center; }
.stockImg{ width:120px; height:90px; object-fit:cover; border-radius:10px; border:1px solid var(--bd); background:#0f0f0f; cursor:pointer }
.stockImg.noimg{ display:flex; align-items:center; justify-content:center; font-size:12px; color:#888; cursor:default }
.stockMid{ min-width:0 }
.stockTitle{ font-weight:700; color:#fff; margin-bottom:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.stockMeta{ display:flex; gap:16px; flex-wrap:wrap; font-size:13px; color:#cfcfcf; margin-bottom:6px; }
.stockMeta .k{ color:#d0d0d0; font-weight:700 }
.stockPriceRow{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.stockPriceRow .price{ font-variant-numeric: tabular-nums; }
.stockRight{ display:flex; flex-direction:column; gap:8px; }
.stockRight .btn{ width:140px }
@media (max-width: 820px){
  .stockCard{ grid-template-columns: 120px 1fr; }
  .stockRight{ grid-column: 1 / -1; flex-direction:row; justify-content:flex-end; }
  .stockRight .btn{ width:auto }
}

/* thumbs dentro do modal de fotos */
.modal .thumbs{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:8px }
.modal .thumbs .th{ width:120px; position:relative }
.modal .thumbs .th img{ width:120px; height:90px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); cursor:pointer }
.modal .thumbs .th .cap{ position:absolute; left:6px; bottom:6px; background:rgba(0,0,0,.6); color:#fff; font-size:11px; padding:2px 6px; border-radius:6px }

/* dropzone do modal de fotos */
.dz-modal{
  margin: 8px 0;
  padding: 18px;
  border: 1px dashed var(--bd);
  border-radius: 10px;
  text-align: center;
  cursor: pointer;
  user-select: none;
}
.dz-modal.on{
  border-color: var(--gold);
  background: rgba(196,155,16,.08);
}
#prevModal .th{
  position: relative;
  width: 120px;
}
#prevModal .th img{
  width: 120px; height: 90px; object-fit: cover;
  border-radius: 8px; border: 1px solid var(--bd);
}
#prevModal .th .rm{
  position: absolute; top: -6px; right: -6px;
  width: 22px; height: 22px; border-radius: 50%;
  border: 0; background: #222; color: #fff; cursor: pointer;
  line-height: 22px; display: inline-flex; align-items: center; justify-content: center;
}

/* ofuscar cards INATIVOS quando estiver no filtro "Todos" */
.stockCard.inactive{
  opacity: .55;
  filter: grayscale(25%);
}
.stockCard.inactive .badge{ opacity: 1 } /* mantém legível a etiqueta */

/* === Busca (balcão) - grid de cards === */
.searchRow{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.cardsGrid{
  display:grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap:12px;
}
.cardProd{
  position:relative; border:1px solid var(--bd); background: var(--panel);
  border-radius: 12px; overflow:hidden; cursor:pointer; transition: transform .08s ease, background .15s ease;
}
.cardProd:hover{ transform: translateY(-2px); background:#141414; }
.cardProd .imgWrap{ width:100%; aspect-ratio:4/3; background:#0f0f0f; display:flex; align-items:center; justify-content:center; }
.cardProd .imgWrap img{ width:100%; height:100%; object-fit:contain; }
.cardProd .noimg{ height:100%; width:100%; display:flex; align-items:center; justify-content:center; color:#888; }
.cardProd .info{ padding:10px 12px 12px; }
.cardProd .info .marca{ font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; }
/* Condição no card: mesma estilização da marca, alinhada à direita */
.cardProd .info .topRow{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.cardProd .info .cond{ font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; }
.cardProd .info .titulo{ font-size:14px; font-weight:600; margin:4px 0 6px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; line-clamp:2; }
.cardProd .info .preco{ font-size:16px; font-weight:700; color:#fff; }

/* tarja diagonal 'estoque' */
.cardProd .ribbon{
  position:absolute; top:10px; left:-44px; transform: rotate(-45deg);
  background:#16a34a; color:#fff; font-weight:700; font-size:11px;
  padding:4px 50px; text-transform:uppercase; letter-spacing:.5px; opacity:.95; pointer-events:none;
}

.metaRow{ margin-top:6px; color:var(--muted); }
.pager{ display:flex; gap:6px; align-items:center; justify-content:center; margin:12px 0 0; }
.pager .pagerBtn{ background:#1a1a1a; border:1px solid var(--bd); padding:6px 10px; border-radius:8px; cursor:pointer; }
.pager .pagerBtn.active{ background:var(--gold); color:#000; border-color:var(--gold); }
.pager .pagerBtn.disabled{ opacity:.5; cursor:not-allowed }

/* detalhe */
.detailBox{ margin-top:16px; }
.detail{
  display:grid; grid-template-columns: minmax(280px, 420px) 1fr; gap:16px; border:1px solid var(--bd); border-radius:12px; padding:12px; background:#101010;
}
.detail .bigPrev{ width:100%; max-height:360px; object-fit:contain; border-radius:8px; border:1px solid var(--bd); background:#0f0f0f; }
.thumbRow{ display:flex; gap:8px; margin-top:8px; flex-wrap:wrap; }
.thumb{ width:60px; height:60px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); background:#0f0f0f; cursor:pointer; }
.detail .kv{ margin:4px 0; color:#ddd; }
.detail .desc{ margin-top:10px; color:#ccc; white-space:pre-wrap; }

/* Cabeçalho do modal (título + fechar) */
.modal-box .modalHdr{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom: 8px;
}
.modal-box .modalHdr h3{ margin:0; color:var(--gold); text-transform: uppercase; letter-spacing: .5px; }

/* Garante que o grid de detalhes se comporte bem dentro do modal */
.modal-box .detail{
  grid-template-columns: minmax(280px, 460px) 1fr;
}
@media (max-width: 860px){
  .modal-box .detail .detailRight{ min-width:0; }
  .modal-box .detail{
    grid-template-columns: 1fr;
  }
  .modal-box .detail .left{ order: 1; }
  .modal-box .detail .right{ order: 2; }
}

/* grade chave/valor dentro do detalhe (alinhado) */
.kvgrid{
  display:grid;
  grid-template-columns: max-content 1fr;
  column-gap: 12px;
  row-gap: 6px;
  margin: 8px 0 6px;
}
.kvgrid .k{ color:var(--muted); font-weight:700; }
.kvgrid .v{ color:#fff; }

.sectionTitle{
  margin-top: 10px;
  color: var(--gold);
  font-weight: 700;
}
.sectionText{
  color:#ddd;
  margin-top: 4px;
}
.sectionText.prewrap{
  white-space: pre-wrap;   /* mantém quebras de linha do texto vindo do BD */
}

/* ====== Fix modal detail ====== */
.detail{ align-items:start; }                 /* evita esticar verticalmente */
.detail .right{ min-width:0; }                /* ***ESSENCIAL***: permite o texto quebrar normalmente no grid */

/* Título do detalhe: quebra natural em até 2 linhas (sem empilhar letras) */
.detail .detailRight .ttl{
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.15;
  color: var(--gold);

  /* quebra saudável */
  white-space: normal;
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: auto;

  /* se quiser truncar em 2 linhas sem bug do -webkit-box, use max-height */
  max-height: calc(1.15em * 2);
  overflow: hidden;
}

/* Grade chave/valor já criada — só garantimos que os valores quebrem bem */
.kvgrid .v{
  white-space: normal;
  overflow-wrap: break-word;
}

/* Texto de seções (descrição/aplicações) */
.sectionText{ color:#ddd; margin-top:4px; white-space: normal; }
.sectionText.prewrap{ white-space: pre-wrap; }  /* mantém quebras se vierem do BD */

/* ===== Detalhe do card: layout horizontal enxuto ===== */
.modal-box .detail{
  display: grid;
  grid-template-columns: minmax(300px, 420px) 1fr;  /* imagem | conteúdo */
  gap: 16px;
  align-items: start;
}
.modal-box .detail .right{ min-width: 0; }         /* evita “apertar” texto */

/* Título (uma ou duas linhas, horizontal) */
.modal-box .detail .ttl{
  margin: 0 0 10px;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.2;
  color: var(--gold);
  white-space: normal; word-break: normal; overflow-wrap: break-word; hyphens: auto;
}

/* Foto grande e thumbs */
.bigPrev{ width:100%; max-height:380px; object-fit:contain; border-radius:8px; border:1px solid var(--bd); background:#0f0f0f; }
.thumbRow{ display:flex; gap:8px; margin-top:8px; flex-wrap:wrap; }
.thumb{ width:64px; height:64px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); background:#0f0f0f; cursor:pointer }

/* Linha de características (chips) */
.facts{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 8px 0 10px;
}
.fact{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 10px;
  padding: 8px 10px;
  min-width: 0;
}
.fact .k{ display:block; font-size:12px; color:var(--muted); font-weight:700; letter-spacing:.3px; text-transform:uppercase; }
.fact .v{ display:block; color:#fff; font-weight:700; margin-top:2px; white-space:normal; overflow-wrap:break-word; }
.fact.preco .v{ font-size:20px; font-variant-numeric: tabular-nums; }

/* Seções */
.sectionTitle{ margin-top: 8px; color: var(--gold); font-weight: 800; }
.sectionText{ margin-top: 6px; color:#ddd; white-space: normal; }
.sectionText.prewrap{ white-space: pre-wrap; }  /* preserva quebras vindas do BD */

/* Tabela de veículos compatíveis */
.compatTbl{ width:100%; border-collapse:separate; border-spacing:0; margin-top:6px; table-layout:fixed; }
.compatTbl th, .compatTbl td{ padding:8px 10px; border-bottom:1px solid var(--bd); text-align:left; }
.compatTbl thead th{ color:var(--gold); font-weight:700; }
.compatTbl td{ color:#eee; word-wrap:anywhere; }

/* === FIX: conflito com .modal-box .right (flex) dentro do detalhe === */
.modal-box .detail .detailRight{
  display:block;     /* cancela o flex herdado */
  min-width:0;       /* permite o texto quebrar normalmente */
  margin-top:0;      /* não queremos margem ali */
  gap:0;             /* só por garantia */
}

/* ========= CARDS DA BUSCA (tema branco elegante) ========= */
.cardsGrid .cardProd{
  background:#fff;
  border:1px solid #e6e6e6;
  overflow: hidden;
  border-radius:12px;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
  color:#0f172a;
  transition: transform .08s ease, box-shadow .15s ease;
}
.cardsGrid .cardProd:hover{
  transform: translateY(-3px);
  box-shadow:0 8px 28px rgba(0,0,0,.08);
}

/* imagem com fundo claro */
.cardsGrid .cardProd .imgWrap{
  background:#f5f7fa;           /* cinza claro */
  border-bottom:1px solid #eef0f3;
}
.cardsGrid .cardProd .noimg{ color:#94a3b8; }

/* tipografia no branco */
.cardsGrid .cardProd .info .marca{ color:#64748b; }    /* cinza médio */
.cardsGrid .cardProd .info .titulo{ color:#0f172a; }
.cardsGrid .cardProd .info .preco{ color:#0f172a; }
.cardsGrid .cardProd .info .cond{ color:#64748b; }

/* ========= MOLDURA DOURADA (itens do fornecedor: classe .mine) ========= */
/* Moldura dourada com cantos ARREDONDADOS */
.cardsGrid .cardProd.mine{
  border: 2px solid transparent;           /* “canal” da moldura */
  border-radius: 12px;                        /* garante o raio */
  background:
    linear-gradient(#fff, #fff) padding-box,  /* fundo branco do card */
    linear-gradient(120deg, #fff29d, #f1c40f, #b8860b) border-box; /* moldura */
  box-shadow:
    0 0 0 1px rgba(0,0,0,.02) inset,
    0 10px 26px rgba(184,134,11,.12);
}

/* opcional: tarja “estoque” no mesmo tom dourado */
.cardsGrid .cardProd.mine .ribbon{
  background: linear-gradient(135deg, #f7e27a, #caa016);
  color:#111;
}

/* ===== Popup claro (mesmo look dos cards brancos) ===== */
.modal-box.light{
  background:#fff;
  color:#0f172a;
  border:1px solid #e6e6e6;
  border-radius:16px;
  box-shadow:0 24px 80px rgba(0,0,0,.35);
}
.modal-box.light .modalHdr h3{ color:#0f172a; }
.modal-box.light .btn.ghost{ color:#0f172a; border-color:#e2e8f0; }

/* Moldura dourada no popup quando for peça do fornecedor (.mine) */
.modal-box.light.mine{
  border:1.5px solid transparent;
  border-radius:16px;
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(120deg, #fff29d, #f1c40f, #b8860b) border-box;
}

/* Área de detalhes no claro */
.modal-box.light .detail{
  background:#fff;
  border:1px solid #eef0f3;
}
.modal-box.light .bigPrev{ background:#f5f7fa; border-color:#eef0f3; }
.modal-box.light .thumb{ background:#f5f7fa; border-color:#eef0f3; }

/* Título um pouco menor para caber melhor */
.modal-box.light .detail .ttl{
  font-size:20px;
  color:#0f172a;
}

/* ===== Chips (características) menores ===== */
.modal-box .facts{
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); /* antes 180px */
  gap:8px;                 /* antes 10px */
  margin:6px 0 8px;        /* menos altura */
}
.modal-box .fact{
  padding:6px 8px;         /* antes 8px 10px */
  border-radius:8px;       /* menorzinho */
}
.modal-box .fact .k{ font-size:11px; }
.modal-box .fact .v{ font-size:14px; }
.modal-box .fact.preco .v{ font-size:18px; }  /* antes 20px */

/* Texto das seções no claro */
.modal-box.light .sectionTitle{ color:#0f172a; }
.modal-box.light .sectionText{ color:#334155; }

/* Tabela de compatibilidade no claro */
.modal-box.light .compatTbl th{ color:#0f172a; }
.modal-box.light .compatTbl td{ color:#0f172a; }

/* ===== Popup claro: chips maiores e com cores escuras ===== */

/* tamanhos e espaçamento “confortáveis” */
.modal-box.light .facts{
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 8px 0 10px;
}
.modal-box.light .fact{
  padding: 8px 12px;              /* ↑ um pouco maior */
  border-radius: 10px;
  background: #f8fafc;            /* fundo claro */
  border: 1px solid #e6eaf0;      /* borda sutil */
}

/* rotulo e valor com contraste escuro (corrige o “branco invisível”) */
.modal-box.light .fact .k{
  font-size: 12px;
  color: #64748b;                  /* cinza médio */
  letter-spacing: .3px;
  text-transform: uppercase;
  font-weight: 700;
}
.modal-box.light .fact .v{
  font-size: 16px;                 /* ↑ maior que antes */
  color: #0f172a;                  /* escuro */
  font-weight: 700;
  margin-top: 2px;
  white-space: normal;
  overflow-wrap: break-word;
}
.modal-box.light .fact.preco .v{
  font-size: 20px;                 /* preço destacado */
  font-variant-numeric: tabular-nums;
}

/* Botão "Limpar" minimalista */
.btn.clean{
  background: transparent;
  border: 1px solid var(--bd);
  color: var(--muted);
}
.btn.clean:hover{
  background: rgba(255,255,255,.06);
  color:#ddd;
}

/* se estiver usando o modal claro e quiser manter o "clean" claro lá dentro */
.modal-box.light .btn.clean{
  border-color:#e2e8f0;
  color:#475569;
}
.modal-box.light .btn.clean:hover{
  background:#f1f5f9;
  color:#0f172a;
}

/* ==== Submenu (Marketplaces) ==== */
.nav .nav-group { margin: 6px 0; }
.nav .has-sub { position: relative; padding-right: 26px; }
.nav .has-sub::after{
  content: '▸'; position:absolute; right:10px; top:50%; transform:translateY(-50%);
  opacity:.8;
}
.nav .nav-group.open .has-sub::after{ content:'▾'; }

.subnav{ display:none; margin:6px 0 0 8px; border-left:1px solid var(--bd); padding-left:8px; }
.nav .nav-group.open .subnav{ display:block; }
.subnav a{
  display:block; padding:8px 10px; margin:4px 0; border-radius:8px; color:#ddd; text-decoration:none;
  font-size:.95rem;
}
.subnav a.active, .subnav a:hover{ background:var(--panel); border:1px solid var(--bd); }

/* ==== Pills ==== */
.pill{ display:inline-block; padding:4px 8px; border-radius:999px; font-size:.85rem; font-weight:700 }
.pill.ok{ background:#143015; border:1px solid #2e7d32; color:#b2ffb2 }
.pill.warn{ background:#2a2206; border:1px solid #b58900; color:#ffd36b }
.pill.bad{ background:#2a0e12; border:1px solid #b00020; color:#ffb3b3 }

/* grid básico de formulário */
.formRow{ display:flex; gap:12px; flex-wrap:wrap; margin:10px 0 }
.formCol{ flex:1 1 260px; min-width:240px }

/* Perfil ML */
.box { background:#121212; border:1px solid #232323; border-radius:12px; padding:16px; margin:12px 0; }
.box h3 { margin:0 0 12px; font-size:16px; color:#eaeaea; }
.box-muted { opacity:.6; }
.grid.cols-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.grid label { display:flex; flex-direction:column; gap:6px; }
.grid input[type="text"], .grid input[type="number"] { background:#0d0d0d; border:1px solid #2a2a2a; color:#eaeaea; padding:10px; border-radius:8px; }

/* Preferências (Market > Perfil): checkboxes em coluna, texto à esquerda, caixa à direita */
.checkList{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.checkRow{
  display:flex;
  align-items:center;
  justify-content:space-between;  /* texto à esquerda, checkbox encostado à direita */
  gap:12px;
  padding:10px 12px;
  border:1px solid var(--bd);
  border-radius:10px;
  background:#101010;
}
.checkRow span{ color:#ddd; }
.checkRow input[type="checkbox"]{
  width:20px;
  height:20px;
  accent-color: var(--gold);      /* cor do tema no checkbox (navegadores modernos) */
}

/* ===== Overrides para a lista de preferências (checkbox + texto na mesma linha) ===== */

/* o <label> desta linha deve ser em ROW, não em coluna */
label.checkRow{
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--bd);
  border-radius: 10px;
  background: #101010;
}

/* o texto ocupa o espaço flexível */
label.checkRow > span{
  flex: 1;
  color: #ddd;
}

/* checkbox pequeno, sem largura 100% */
label.checkRow input[type="checkbox"]{
  width: 20px !important;
  min-width: 20px !important;
  height: 20px;
  margin: 0;
  flex: 0 0 20px;
  display: inline-block;   /* garante inline */
  accent-color: var(--gold);
}

/* a lista dos 3 checkboxes fica empilhada verticalmente */
.checkList{
  display: flex;
  flex-direction: column;
  gap: 10px;
  grid-column: 1 / -1;   /* ocupa a linha inteira do grid do form */
}

.btn.danger{
  background:#3a1a1a;       /* vermelho bem escuro */
  color:#ffd9d9;
  border:1px solid #6a2a2a;
}
.btn.danger:hover:not([disabled]){ filter:brightness(1.06); }

/* já existe, mas reforçamos o estado apagado */
.btn[disabled]{ opacity:.55; cursor:not-allowed }

/* Grid 2 colunas que não vaza e permite encolher conteúdo longo */
.grid.cols-2{
  display:grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);  /* <- chave: minmax(0, 1fr) */
  gap:12px;
}

/* Os rótulos/inputs dentro do grid podem encolher dentro da coluna */
.grid.cols-2 > label{ min-width:0; }
.grid.cols-2 input[type="text"],
.grid.cols-2 input[type="number"],
.grid.cols-2 select{
  min-width:0;               /* <- permite encolher */
  width:100%;
  box-sizing:border-box;
}

/* Para campos de texto muito longos (ex.: link do perfil) */
.grid.cols-2 input[type="text"]{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;     /* mostra "…" no fim */
}

/* === Anúncios ML === */
.an-bar { display:flex; gap:8px; flex-wrap:wrap; }
.an-bar .pill{
  border:1px solid var(--bd); background:#1a1a1a; color:#ddd; padding:8px 12px; border-radius:999px; cursor:pointer;
}
.an-bar .pill.on{ background:var(--gold); color:#000; border-color:transparent; }

.an-list { display:flex; flex-direction:column; gap:10px; }
.an-card {
  display:grid; grid-template-columns: 120px 1fr auto;
  gap:12px; align-items:center;
  border:1px solid var(--bd); border-radius:12px; background:#111; padding:10px;
}
.an-left img{ width:120px; height:80px; object-fit:cover; border-radius:8px; border:1px solid var(--bd); }
.an-left .noimg{ width:120px; height:80px; display:grid; place-items:center; border:1px dashed var(--bd); border-radius:8px; color:#888; }

.an-title a{ color:#fff; text-decoration:none; font-weight:700; }
.an-title a:hover{ text-decoration:underline; }
.an-meta { display:flex; gap:8px; align-items:center; margin:4px 0; flex-wrap:wrap; }
.an-stats { display:flex; gap:16px; align-items:center; }
.an-stats b{ color:#fff; font-size:1.05rem }

.badge.ghost{ border:1px solid var(--bd); background:transparent; color:#ddd }

/* === Anúncios ML — ajustes de respiro e novas linhas === */
.an-card {
  /* aumenta “respiro” vertical */
  padding: 14px;                   /* era 10px */
  gap: 14px;                       /* era 12px */
  min-height: 120px;               /* garante altura confortável */
}

.an-left img, .an-left .noimg{
  width: 140px;                    /* era 120px */
  height: 96px;                    /* era 80px */
}

.an-title { margin-bottom: 4px; }

.an-meta { margin: 6px 0; }        /* 2px a mais entre título e meta */

.an-stats, .an-priceRow {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 4px;
}

.an-stats .kv, .an-priceRow .kv {
  display: inline-flex;
  gap: 6px;
  align-items: baseline;
  font-variant-numeric: tabular-nums;
}

.an-stats .k, .an-priceRow .k { color: var(--muted); font-weight: 700; }
.an-stats .v, .an-priceRow .v { color: #fff; }

.badge.t-light { background: #1e1e1e; color:#bbb; border:1px solid var(--bd) }

/* === Anúncios ML • Refresh visual === */
.an-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:2px;
}

/* Destaque do preço */
.price-pill{
  display:inline-flex;
  align-items:baseline;
  gap:8px;
  padding:4px 10px;
  border-radius:10px;
  background:#151515;
  border:1px solid var(--bd);
}
.price-pill .label{ color:#ccc; font-weight:700; }
.price-pill .value{ color:var(--gold); font-size:20px; font-weight:800; }

/* Badges de status e tipo */
.badge{ padding:3px 8px; border-radius:999px; font-size:12px; font-weight:700; border:1px solid transparent; }

.badge.status-ativo   { background:#123a1f; color:#95f2b1; border-color:#1f6a36; }  /* verde */
.badge.status-pausado { background:#3a1212; color:#ff9a9a; border-color:#6a1f1f; }  /* vermelho */

.badge.tipo-premium   { background:#3a330a; color:#ffd84d; border-color:#6a5b1f; }  /* amarelo (premium) */
.badge.tipo-classico  { background:#3a250a; color:#ffbd4d; border-color:#6a441f; }  /* laranja amarelado (clássico) */

/* === Anúncios ML • Layout sólido e sem sobreposição === */

/* Barra de filtros no topo */
.an-toolbar{
  display:flex;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;      /* quebra para a linha de baixo quando faltar espaço */
}

/* Card em grid: [thumb] [conteúdo] [botão] */
/* === Anúncios ML • card compacto e centralizado === */
/* Layout em 3 colunas: [thumb] [conteúdo] [botão] */
.an-card{
  display:grid;
  grid-template-columns: 150px 1fr auto;   /* menor e sem distorção */
  gap:10px 14px;                           /* [linha, coluna] */
  padding:12px 14px;                       /* mesmo espaço em cima e embaixo */
  border:1px solid var(--bd);
  border-radius:12px;
  background:#111;
  align-items:center;                      /* centraliza verticalmente tudo */
}

/* colunas */
.an-left{ grid-column:1; }
.an-mid{  grid-column:2; display:flex; flex-direction:column; gap:6px; min-width:0; }
.an-right{grid-column:3;}

/* imagem menor e estável (sem esticar) */
.an-left img, .an-left .noimg{
  width:150px;
  height:100px;        /* proporção ~3:2 */
  object-fit:cover;
  border-radius:8px;
  border:1px solid var(--bd);
}

/* título em MAIÚSCULAS */
.an-title a{
  font-size:15px;
  font-weight:800;
  line-height:1.25;
  color:#fff;
  text-transform:uppercase;
}

/* linha do preço (sem moldura) */
.price-line{ font-size:17px; font-weight:800; }
.price-line .label{ color:#ccc; margin-right:6px; font-weight:700; }
.price-line .value{ color:var(--gold); }

/* Preços em duas colunas (Clássico | Premium), com valor abaixo do rótulo */
.price-duo{ display:flex; gap:16px; align-items:flex-start; margin: 6px 0; flex-wrap:wrap; }
.an-card .fact .k{ display:block; font-size:12px; color:var(--muted); font-weight:700; letter-spacing:.3px; text-transform:uppercase; }
.an-card .fact .v{ display:block; font-weight:800; margin-top:2px; white-space:normal; overflow-wrap:break-word; }
.an-card .fact.preco .v{ font-size:20px; font-variant-numeric: tabular-nums; color: var(--gold); }

/* estatísticas em linha, com respiro enxuto */
.an-stats{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.an-stats .kv{ display:inline-flex; gap:6px; }
.an-stats .k{ color:var(--muted); font-weight:700; }

/* cores dos badges de status/tipo já existentes no tema */
.badge.instock{ background:#114b11; color:#9cf09c; border:1px solid #1b6c1b } /* Ativo */
.badge.warn{ background:#3a1212; color:#ff9a9a; border-color:#6a1f1f }       /* Pausado (vermelho discreto) */
.badge.gold{ background:var(--gold); color:#000 }                             /* Premium */

/* Badges (cores pedidas) */
.badge{ padding:3px 8px; border-radius:999px; font-size:12px; font-weight:700; border:1px solid transparent; }
.badge.status-ativo   { background:#123a1f; color:#95f2b1; border-color:#1f6a36; }  /* verde */
.badge.status-pausado { background:#3a1212; color:#ff9a9a; border-color:#6a1f1f; }  /* vermelho */
.badge.tipo-premium   { background:#3a330a; color:#ffd84d; border-color:#6a5b1f; }  /* amarelo */
.badge.tipo-classico  { background:#3a250a; color:#ffbd4d; border-color:#6a441f; }  /* laranja amarelado */

/* Responsivo simples: em telas estreitas, botão cai para baixo da imagem */
@media (max-width: 900px){
  .an-card{ grid-template-columns: 180px 1fr; }
  .an-right{ grid-column:1 / -1; grid-row:auto; justify-self:end; }
  .an-left img, .an-left .noimg{ width:180px; height:126px; }
}

/* Barra de busca + botões lado a lado */
.an-searchbar{
  display:flex;
  gap:8px;
  align-items:center;
}
.an-searchbar input[type="text"]{
  flex:1;                    /* o input cresce e os botões encostam nele */
  min-width:240px;
}

/* === Formulário de Anúncio (detalhes) === */
.an-form .row { margin-bottom: 10px; }
.an-form .grid { display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 900px){ .an-form .grid { grid-template-columns: 1fr; } }

/* === FAB (botão flutuante) azul === */
.fab{
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 1500;
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 800;
  border: 0;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}
.btn.primary, .fab.primary{
  background: #3b82f6;              /* azul */
  color: #fff;
  border: 1px solid #2563eb;
}
.fab.primary:hover{
  filter: brightness(1.05);
  transform: translateY(-1px);
}

/* X vermelho no topo direito do popup */
.modal-box .xClose{
  position:absolute; top:10px; right:12px;
  width:30px; height:30px; padding:0;
  border:0; border-radius:6px;
  background:#b00020; color:#fff; font-weight:900;
  line-height:30px; text-align:center; cursor:pointer;
}
.modal-box .xClose:hover{ filter:brightness(1.1); }

/* Cards brancos já existem (.cardsGrid .cardProd) — reforço a imagem sem corte */
.cardsGrid .cardProd .imgWrap img{ object-fit: contain; }

/* “chips”/pílulas para condição e ES */
.pill.es {
  background:#0b3d91;    /* azul escuro */
  color:#e8f0ff;
  border:1px solid #0b3d91;
}
.pill.cond {
  background:#f1f5f9;
  color:#0f172a;
  border:1px solid #e2e8f0;
}

/* ===== Popup "Criar anúncio" — cards na HORIZONTAL (1 por linha) ===== */
#stockPicker .cardsGrid{
  display: flex;
  flex-direction: column;   /* um card por linha */
  gap: 10px;
}

#stockPicker .cardsGrid .cardProd{
  display: grid;
  grid-template-columns: 110px 1fr auto; /* imagem | textos | botão */
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: #fff;               /* card branco, como no restante */
  color: #0f172a;
  border: 1px solid #e6e6e6;
  border-radius: 12px;
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
}

#stockPicker .cardsGrid .cardProd .imgWrap{
  width: 110px;
  height: 90px;
  display: flex; align-items: center; justify-content: center;
  background: #f5f7fa;
  border: 1px solid #eef0f3;
  border-radius: 10px;
  overflow: hidden;
}
#stockPicker .cardsGrid .cardProd .imgWrap img{
  width: 100%; height: 100%; object-fit: contain; /* SEM corte */
}

#stockPicker .cardsGrid .cardProd .info{ display:flex; flex-direction:column; gap:4px; }
#stockPicker .cardsGrid .cardProd .info .marca{
  font-size: 12px; color: #64748b; letter-spacing: .3px; text-transform: uppercase;
}
#stockPicker .cardsGrid .cardProd .info .titulo{
  color: #0f172a; font-weight: 700; line-height: 1.25;
}

/* área do botão à direita */
#stockPicker .cardsGrid .cardProd .right{ display:flex; justify-content:flex-end; }

/* pílulas para condição e ES (caso ainda não existam no seu CSS) */
#stockPicker .pill.es{
  background:#0b3d91; color:#e8f0ff; border:1px solid #0b3d91; border-radius:999px; padding:2px 8px; font-weight:700; font-size:12px;
}
#stockPicker .pill.cond{
  background:#f1f5f9; color:#0f172a; border:1px solid #e2e8f0; border-radius:999px; padding:2px 8px; font-weight:700; font-size:12px;
}

/* ===== Formulário ML (linhas horizontais) ===== */
.form-hz{ display:flex; flex-direction:column; gap:10px; }
.form-hz .row-hz{
  display:grid;
  grid-template-columns: 240px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px dashed var(--bd);
}
.form-hz .row-hz:last-child{ border-bottom:0; }
.form-hz .row-hz .label{
  font-weight:700; color:#334155; text-transform: none;
}
.form-hz .row-hz .right{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; }
.form-hz .row-hz .right .input,
.form-hz .row-hz .right select,
.form-hz .row-hz .right textarea{ min-width: 280px; }

.form-hz #ttlCount{ margin-left:6px; font-weight:700; }

.form-actions{
  display:flex; justify-content:flex-end; gap:8px; padding-top:8px;
}

/* grid de imagens */
.imgGrid{ display:flex; gap:10px; flex-wrap:wrap; }
.imgGrid .imgCell{
  width:96px; height:96px; border:1px solid var(--bd); border-radius:10px; overflow:hidden; background:#0b0b0b;
}
.imgGrid .imgCell img{ width:100%; height:100%; object-fit:contain; background:#111; }

/* dicas pequenas */
.hint{ width:100%; font-size:12px; color:#6b7280; }
.small{ font-size:12px; color:#6b7280; }

/* Detalhes ML: descrição mais alta */
#fAn #iDesc{ min-height: 320px; }

/* Ajustes leves para os novos campos */
.box-form .row .col label + .input { min-height: 38px; }

.cpk-hidden { display: none; }
.cpk-modal { position: fixed; inset: 0; z-index: 1000; }
.cpk-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.4); }
.cpk-dialog { position: relative; margin: 5vh auto; width: 680px; max-width: calc(100vw - 32px);
  background: #fff; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,.25); padding: 16px 16px 12px; }
.cpk-header { display: flex; align-items: center; gap: 8px; }
.cpk-header h3 { margin: 0; font-size: 18px; }
.cpk-x { margin-left: auto; border: 0; background: transparent; font-size: 24px; line-height: 1; cursor: pointer; }
.cpk-breadcrumb { margin: 8px 0 12px; font-size: 12px; color: #666; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cpk-row { display: grid; gap: 6px; }
.cpk-select { width: 100%; padding: 6px; font-size: 14px; }
.cpk-footer { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.cpk-btn { border: 1px solid #ccc; background: #f7f7f7; padding: 8px 12px; border-radius: 8px; cursor: pointer; }
.cpk-btn:disabled { opacity: .5; cursor: not-allowed; }
.cpk-primary { background: #0d6efd; color: #fff; border-color: #0d6efd; }
.cpk-spacer { flex: 1; }
.cpk-hint { margin-top: 8px; font-size: 12px; color: #777; }

/* CatPicker */
.cpk-hidden { display: none; }
#catPickerModal .modal-box { max-width: 820px; }
#cpkSelect { 
  background: rgba(0,0,0,.35);
  color:#fff;
  border:1px solid var(--bd);
  border-radius:8px;
  padding:6px;
}
#cpkBreadcrumb { color:#bbb; }
#cpkHint { color:#000000; }

/* CatPicker: título + “breadcrumb” */
#catPickerModal .cpk-title { margin:0 0 6px; font-weight:700; }
#catPickerModal .cpk-breadcrumb { display:flex; gap:6px; flex-wrap:wrap; margin:6px 0 8px; }
#catPickerModal .cpk-breadcrumb .crumb {
  background: rgba(255,255,255,.08); padding:4px 8px; border-radius:10px; font-size:.92rem;
}

/* 2 colunas com setas entre elas */
#catPickerModal .cpk-columns {
  display:grid; grid-template-columns: 1fr 48px 1fr; gap:10px; align-items:stretch;
}
#catPickerModal select.input { height:240px; }
#catPickerModal .cpk-arrows { display:flex; flex-direction:column; gap:8px; align-items:center; justify-content:center; }
#catPickerModal .cpk-arrows .cpkArrow { width:40px; height:40px; border-radius:999px; font-weight:700; line-height:40px; }
#catPickerModal .cat-error { color:#ff8a8a; display:none; margin-bottom:8px; }

/* esconde a lista antiga, se existir */
#catPickerModal .cat-list { display:none !important; }

/* === NCM/CEST picker — texto preto e fundo claro (sem afetar o resto) === */
#cbCat,
#cbSub,
#cbDesc{
  background:#2a2a2a !important;
  color:#f8f6f6 !important;
  border-color: var(--bd);
}

/* garante as opções do dropdown no mesmo tema claro */
#cbCat option,
#cbSub option,
#cbDesc option{
  background:#fff !important;
  color:#111 !important;
}

/* CatPicker layout */
.cpk-grid{display:grid;grid-template-columns:1fr 64px 1fr;gap:12px;margin-top:8px}
.cpk-left,.cpk-right{background:var(--bg2);border:1px solid var(--bd);border-radius:10px;padding:10px}
.cpk-left select{width:100%;height:100%;min-height:280px}
.cpk-arrows{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.cpkArrow{min-width:44px}

.cpk-breadcrumb{margin:8px 0 12px;font-size:12px;color:#f8f4f4;display:flex;gap:6px;flex-wrap:wrap}
.cpk-breadcrumb .chip{background:var(--bg2);border:1px solid var(--bd);border-radius:999px;padding:4px 10px}

.cpk-right ul{list-style:none;margin:0;padding:6px 8px;max-height:280px;overflow:auto}
.cpk-right li{padding:6px 8px;border-radius:8px;background:var(--bg);border:1px dashed var(--bd);margin-bottom:8px}
.cpk-right li.muted{opacity:.7;text-align:center;border-style:dotted}

/* X vermelho (igual aos outros popups) */
.modal-box .xClose{
  position:absolute; top:10px; right:10px;
  width:28px; height:28px; border-radius:50%;
  border:0; background:#b00020; color:#fff; font-weight:800;
  display:inline-flex; align-items:center; justify-content:center;
  line-height:1; cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.25);
}

/* setas arredondadas com ícone */
.cpkArrow{
  width:44px; height:44px; border-radius:999px;
  background:var(--gold); color:#000; border:0; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
}
.cpkArrow svg{ width:22px; height:22px; display:block; }

/* trilha do topo (texto simples com ">") */
#cpkPath{
  color:#fff;            /* branco */
  min-height: 24px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#cpkPath.empty{ color:#9aa0a6; }

/* hint em branco (ex.: "Categoria final selecionada: ...") */
#cpkHint{ color:#fff; }

/* CatPicker */
.cpk-hidden{ display:none; }
.cpk .cpk-grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:12px;
  margin-top:8px;
}
.cpk-select{
  width:100%;
  height:340px; /* coerente com 14 linhas */
  background: var(--bg2, #212121);
  border:1px solid var(--bd, #3a3a3a);
  border-radius:8px;
  padding:8px;
  color: #eee;
}
.cpk-arrows{ display:flex; flex-direction:column; gap:10px; align-items:center; justify-content:center; }
.btn.circle{
  width:44px; height:44px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:20px; line-height:1;
}
.cpk-picked{
  list-style:none; margin:0; padding:8px;
  background: var(--bg2, #212121);
  border:1px solid var(--bd, #3a3a3a);
  border-radius:8px;
  height:340px; overflow:auto;
}
.cpk-picked li{ padding:6px 8px; border-bottom:1px dashed var(--bd,#3a3a3a); }
.cpk-picked li:last-child{ border-bottom:none; }
.cpk-path{
  min-height:20px;
  color:#d9d9d9;
  margin-top:6px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* CatPicker – posiciona o X no canto superior direito do POP-UP */
#catPickerModal .modal-box { 
  position: relative;              /* referência para o absolute abaixo */
}

#catPickerModal .xClose{
  position: absolute !important;   /* vence qualquer regra antiga com fixed */
  top: 10px;
  right: 10px;
  z-index: 5;
  width: 32px; height: 32px;       /* mantém o botão redondo bonitinho */
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}

/* --- Padrão portal: UX de inputs/botões/foco --- */
*{ box-sizing: border-box; }

.label{ display:block; font-weight:600; color:#ddd; margin:8px 0 6px; }

/* inputs e selects com foco dourado */
input:not([type="checkbox"]):not([type="radio"]), select, textarea{
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input:not([type="checkbox"]):not([type="radio"]):focus,
select:focus, textarea:focus{
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(228,201,92,.20);
  background:#181818;
}

/* botão: hover/active/acessibilidade */
.btn{ transition: filter .12s ease, transform .04s ease; }
.btn:hover{ filter: brightness(1.06); }
.btn:active{ transform: translateY(1px); }

/* card padrão do portal */
.card{
  background: #111; border:1px solid var(--bd);
  border-radius:12px; padding:16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}

/* cartão de login compacto */
.login-card{ max-width:480px; margin:6vh auto; padding:24px; }

/* ===== Capa da peça ===== */
.thumbWrap{
  position: relative;
  border: 2px solid transparent;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
}
.thumbWrap.is-capa{
  border-color: #f2c200;            /* amarelo */
  box-shadow: 0 0 0 2px rgba(242,194,0,.28);
}
.thumbWrap .capaTag{
  position: absolute;
  left: 8px;
  bottom: 8px;
  font-size: 12px;
  font-weight: 600;
  padding: 2px 8px;
  background: #ffd84d;
  color: #3b2f00;
  border-radius: 4px;
  letter-spacing: .2px;
  display: none;
}
.thumbWrap.is-capa .capaTag{ display: inline-block; }

/* === MODAL: centralização + rolagem interna (não travar conteúdo) === */
.modal{
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;             /* respiro nas bordas para a caixa */
  background: rgba(0,0,0,.55);
  z-index: 1000;
}
.modal .modal-box{
  /* ocupa a maior parte da viewport, mas com rolagem interna */
  max-height: calc(100vh - 48px);
  overflow: auto;
}

/* Em telas menores, a caixa acompanha a largura */
@media (max-width: 900px){
  .modal .modal-box{ width: calc(100vw - 24px); }
}

/* Quando o modal estiver aberto, travamos o BODY para não “puxar” o fundo */
body.modal-open{ overflow: hidden; }

/* === CatPicker: layout e rolagem seguros === */
#catPickerModal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(0,0,0,.55);
  z-index: 1000;
}
#catPickerModal.cpk-hidden { display: none; }

#catPickerModal .modal-box {
  max-height: calc(100vh - 48px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* mantém o fundo travado quando qualquer modal estiver aberto */
body.modal-open { overflow: hidden; }

/* ==== Ações do card (layout) ==== */
.cardProd .actions,
.card-actions{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  padding:10px;
}

/* ==== Botão dourado 3D (Adicionar) ==== */
.btn-add{
  flex:1 1 auto;
  height:42px;
  border-radius:12px;
  font-weight:800;
  letter-spacing:.2px;
  border:1px solid #b88a05;
  background: linear-gradient(180deg, #ffe083, #f1c232 65%, #e0b019);
  color:#0f172a;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    0 1px 0 rgba(0,0,0,.05);
  transition: filter .15s ease, transform .05s ease;
}
.btn-add:hover{ filter:brightness(1.03); }
.btn-add:active{ transform: translateY(1px); }
.btn-add:focus-visible{
  outline: 2px solid #0f172a;
  outline-offset: 2px;
}

/* ==== Botão quadrado claro com ícone (Compartilhar) ==== */
.btn-light{
  background:#f1f5f9;
  color:#0f172a;
  border:1px solid #e2e8f0;
  border-radius:.65rem;
  padding:.5rem .9rem;
  transition: filter .15s ease, background .15s ease;
}
.btn-light:hover{ background:#eef2f7; filter:brightness(1.01); }

.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:12px;
  padding:0;
  line-height:1;
}

/* Tira o efeito de “pular” do SVG e garante cor herdada */
.icon-btn svg{ display:block; }

/* (Opcional) ligeiro ajuste quando dentro das ações do card */
.cardProd .actions .btn-light.icon-btn{ margin-left:6px; }

/* Acessibilidade: foco visível também no share */
.icon-btn:focus-visible{
  outline:2px solid #0f172a;
  outline-offset:2px;
}

/* ES abaixo do nome — igual marca/cond no card branco */
.cardsGrid .cardProd .esCode{
  font-size:12px;
  color:#64748b;               /* mesmo tom da marca/condição */
  text-transform:uppercase;
  letter-spacing:.4px;
  margin-top:2px;
}

/* Se sobrar algum .pill.es antigo em cards da busca, neutraliza */
.cardsGrid .cardProd .pill.es{
  background:transparent;
  border:0;
  padding:0;
  color:#64748b;
}

/* Carrinho > Detalhe: botão "Remover" com borda vermelha */
#itensWrap .btn.clean[data-rem]{
  border-color:#b00020;     /* vermelho */
  color:#b00020;            /* texto vermelho */
  background:#fff;          /* fundo branco (como já estava) */
}
#itensWrap .btn.clean[data-rem]:hover{
  background:#fff;
  filter:brightness(1.03);
}

/* Botão “Voltar ao carrinho” — grande e alinhado à direita do topo da box */
#btnVoltarCarrinho.backCartBtn{
  position:absolute;              /* ancora no topo da .box */
  top:14px;
  right:14px;
  height:40px;
  padding:0 14px;
  font-weight:800;
  border-radius:10px;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
}

/* Tarja de confirmação — grande e central na tela */
.toast{
  position:fixed;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%) scale(.98);
  width:clamp(280px, 60vw, 720px);
  text-align:center;

  background:rgba(16,24,16,.96);
  color:#b2ffb2;
  border:1px solid #2e7d32;
  border-radius:14px;
  box-shadow:0 18px 48px rgba(0,0,0,.35);

  padding:18px 24px;
  font-weight:800;
  font-size:20px;
  letter-spacing:.2px;

  z-index:4000;
  opacity:0;
  animation:toastIn .22s ease-out forwards;
  pointer-events:none;
}
.toast.ok{ background:rgba(16,24,16,.92); color:#b2ffb2; border-color:#2e7d32; }
.toast.out{ animation:toastOut .35s ease-in forwards; }

@keyframes toastIn{
  from{ opacity:0; transform:translate(-50%, -50%) scale(.98); }
  to  { opacity:1; transform:translate(-50%, -50%) scale(1); }
}
@keyframes toastOut{
  from{ opacity:1; transform:translate(-50%, -50%) scale(1); }
  to  { opacity:0; transform:translate(-50%, -50%) scale(.98); }
}

/* ===== Carrinho: cards horizontais com número gigante à esquerda ===== */
.cartHdr{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:10px;
}
.cartHdr h2{ color:var(--gold); margin:0; }

/* botões de filtro Abertos/Enviado */
.cartFilters{ display:flex; gap:8px; }
.cartFilters .btn.small{ padding:6px 12px; height:34px; }
.cartFilters .btn.ghost.small.active,
.cartFilters .btn.ghost.small[aria-selected="true"]{
  background:var(--gold); color:#000; border-color:var(--gold);
}

/* lista e card */
.cartList{ display:flex; flex-direction:column; gap:10px; }
.cartCard{
  display:grid;
  grid-template-columns: 170px 1fr 120px;   /* [#ID] | [dados] | [ações] */
  align-items:center;                       /* centraliza verticalmente o ID grandão */
  gap:16px;
  padding:14px;
  background:#111;
  border:1px solid var(--bd);
  border-radius:12px;
  position:relative;
}

/* número do orçamento – grande, amarelo e centrado */
.cartLeft{ display:flex; align-items:center; justify-content:center; }
.cartBadge{
  color:var(--gold);
  font-weight:900;
  font-size:clamp(18px, 5.6vw, 62px);
  line-height:0.92;               /* compacto para caber “alto” */
  letter-spacing:.6px;
  user-select:none;
}

/* miolo: nome / telefone / criado em (empilhados) */
.cartMid{ min-width:0; }
.cartTitle{
  color:#fff;
  font-weight:800;
  font-size:16px;
  margin:0 0 4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.cartMeta{ color:#ddd; font-size:14px; margin:2px 0; }
.cartMeta .k{ color:var(--muted); font-weight:700; margin-right:6px; }

/* ações: Abrir / Excluir um abaixo do outro à direita */
.cartRight{
  display:flex; flex-direction:column;
  gap:8px; align-items:flex-end; justify-self:end;
}
.cartRight .btn.small{
  height:36px; padding:6px 12px; font-weight:800;
}

/* responsivo: estreita um pouco a coluna do número e joga ações para baixo */
@media (max-width: 860px){
  .cartCard{ grid-template-columns: 140px 1fr; }
  .cartRight{ grid-column:1 / -1; flex-direction:row; justify-content:flex-end; }
}

/* ====== CONFIGURAÇÕES (perfil + senha + logo) ====== */
.configBox{ max-width: 980px; margin: 16px auto; }
.configHdr{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.configHdr h2{ color:var(--gold); margin:0; }

.configGrid{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 14px;
}
@media (max-width: 900px){ .configGrid{ grid-template-columns: 1fr; } }

.cardPanel{
  background:#111; border:1px solid var(--bd); border-radius:12px; padding:14px;
}

.cardPanel h3{ margin:0 0 10px; color:#eaeaea; }
.formRowX{ display:grid; grid-template-columns: repeat(12, 1fr); gap:10px; margin:8px 0; }
.formRowX > .col-12{ grid-column: span 12; }
.formRowX > .col-8 { grid-column: span 8; }
.formRowX > .col-6 { grid-column: span 6; }
.formRowX > .col-5 { grid-column: span 5; }
.formRowX > .col-4 { grid-column: span 4; }
.formRowX > .col-3 { grid-column: span 3; }
.formRowX > .col-2 { grid-column: span 2; }

.configLogo{
  display:flex; gap:12px; align-items:center;
}
.configLogo .logoPrev{
  width: 160px; height: 90px; border:1px solid var(--bd); border-radius:10px;
  background:#0f0f0f center/contain no-repeat;
}
.configLogo .btn{ white-space:nowrap; }

.inputNote{ font-size:12px; color:#9aa0a6; margin-top:4px; }

.btn.warn{ background:#b58900; color:#000; border:1px solid #8c6c00; }
