/* ReVeste · Estilo da identidade visual. CSS próprio (sem framework/build). */

:root {
  --verde: #2e7d32;
  --verde-escuro: #1f5a24;
  --verde-claro: #bfe3c4;
  --petroleo: #0e5c6b;
  --petroleo-escuro: #0a4350;
  --fundo: #f1f7f1;
  --superficie: #ffffff;
  --borda: #d9e6d9;
  --texto: #1b2b1c;
  --texto-suave: #5a6b5a;
  --sucesso: #2e7d32;
  --alerta: #b26a00;
  --erro: #c0392b;
  --raio: 14px;
  --sombra: 0 6px 20px rgba(20, 60, 25, 0.08);
}

* { box-sizing: border-box; }

html, body { height: 100%; margin: 0; }

body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--fundo);
  color: var(--texto);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--petroleo); }

/* ---------- Botões ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: none;
  border-radius: 10px;
  padding: 11px 18px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, opacity 0.15s;
}
.btn-primario { background: var(--verde); color: #fff; width: 100%; }
.btn-primario:hover { background: var(--verde-escuro); }
.btn-secundario {
  background: transparent;
  color: var(--texto);
  border: 1px solid var(--borda);
}
.btn-secundario:hover { background: var(--fundo); }
.btn:disabled { opacity: 0.6; cursor: default; }

/* ---------- Formulários ---------- */
.campo { display: block; margin-bottom: 16px; }
.campo > span { display: block; margin-bottom: 6px; font-size: 14px; font-weight: 600; }
.campo input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--borda);
  border-radius: 10px;
  font-size: 15px;
  background: #fff;
  color: var(--texto);
}
.campo select,
.campo textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--borda);
  border-radius: 10px;
  font-size: 15px;
  background: #fff;
  color: var(--texto);
  font-family: inherit;
}
.campo input:focus,
.campo select:focus,
.campo textarea:focus {
  outline: none;
  border-color: var(--verde);
  box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.18);
}
.campo .ajuda { display: block; margin-top: 4px; font-size: 12px; color: var(--texto-suave); font-weight: 400; }
.campo .erro-campo { display: block; margin-top: 4px; font-size: 13px; color: var(--erro); }
.campo input.invalido, .campo select.invalido { border-color: var(--erro); }

/* ---------- Cabeçalho de página (título + ação) ---------- */
.pagina-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.pagina-topo h2 { margin: 0; font-size: 20px; }
.pagina-topo .sub { color: var(--texto-suave); font-size: 14px; }
.botao-acao {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--verde);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 10px 16px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  cursor: pointer;
}
.botao-acao:hover { background: var(--verde-escuro); }

/* ---------- Busca ---------- */
.barra-busca { display: flex; gap: 8px; margin-bottom: 16px; }
.barra-busca input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid var(--borda);
  border-radius: 10px;
  font-size: 15px;
}
.barra-busca input:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px rgba(46,125,50,.18); }

/* ---------- Tabela / lista ---------- */
.tabela-wrap {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  overflow: hidden;
}
table.tabela { width: 100%; border-collapse: collapse; }
table.tabela th, table.tabela td { padding: 12px 14px; text-align: left; }
table.tabela thead th {
  background: var(--fundo);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--texto-suave);
  border-bottom: 1px solid var(--borda);
}
table.tabela tbody tr { border-bottom: 1px solid var(--borda); }
table.tabela tbody tr:last-child { border-bottom: none; }
table.tabela tbody tr:hover { background: rgba(191, 227, 196, 0.18); }
.codigo-badge {
  display: inline-block;
  background: var(--verde-claro);
  color: var(--verde-escuro);
  font-weight: 700;
  font-size: 13px;
  padding: 2px 8px;
  border-radius: 6px;
  font-family: ui-monospace, monospace;
}
.link-editar { color: var(--petroleo); font-weight: 600; text-decoration: none; font-size: 14px; }
.link-editar:hover { text-decoration: underline; }

.vazio { text-align: center; padding: 40px 20px; color: var(--texto-suave); }

/* Em telas pequenas a tabela pode rolar horizontalmente */
.tabela-scroll { overflow-x: auto; }

/* ---------- Formulário em cartão ---------- */
.form-cartao {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 22px;
  max-width: 760px;
}
.form-secao-titulo {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--texto-suave);
  margin: 18px 0 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--borda);
}
.form-secao-titulo:first-child { margin-top: 0; }
.form-grade { display: grid; grid-template-columns: 1fr; gap: 0 18px; }
.form-acoes { display: flex; gap: 10px; margin-top: 20px; }
.aviso-codigo {
  background: rgba(14, 92, 107, 0.08);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--petroleo);
  margin-bottom: 16px;
}

@media (min-width: 640px) {
  .form-grade { grid-template-columns: 1fr 1fr; }
  .form-grade .col-cheia { grid-column: 1 / -1; }
}

/* ---------- Filtros (lista de peças) ---------- */
.filtros { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.filtros input[type="search"] { flex: 1 1 200px; }
.filtros input, .filtros select {
  padding: 10px 12px;
  border: 1px solid var(--borda);
  border-radius: 10px;
  font-size: 15px;
  background: #fff;
  color: var(--texto);
}
.filtros input:focus, .filtros select:focus {
  outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px rgba(46,125,50,.18);
}

/* ---------- Badge de situação da peça ---------- */
.status { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.status-disponivel { background: rgba(46,125,50,.14); color: var(--verde-escuro); }
.status-vendido { background: rgba(14,92,107,.14); color: var(--petroleo); }
.status-removido { background: rgba(192,57,43,.12); color: var(--erro); }

/* ====================================================================== */
/* ETIQUETAS (impressão de código de barras)                              */
/* ====================================================================== */
.etiquetas-pagina { max-width: 1000px; margin: 0 auto; padding: 16px; }
.etiquetas-barra {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 16px;
}
.etiquetas-grade {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.etiqueta {
  border: 1px solid var(--borda);
  border-radius: 8px;
  padding: 8px 10px;
  background: #fff;
  break-inside: avoid;
}
.etiqueta-topo { display: flex; align-items: center; justify-content: space-between; gap: 6px; margin-bottom: 4px; }
.etiqueta-logo { height: 16px; width: auto; }
.etiqueta-cat { font-size: 11px; color: var(--texto-suave); font-weight: 600; text-align: right; }
.etiqueta-barras { display: block; width: 100%; height: 42px; }
.etiqueta-rodape { display: flex; align-items: baseline; justify-content: space-between; gap: 6px; margin-top: 2px; }
.etiqueta-codigo { font-family: ui-monospace, monospace; font-size: 12px; font-weight: 700; }
.etiqueta-valor { font-size: 14px; font-weight: 800; color: var(--verde-escuro); }

@media print {
  /* Esconde tudo que não for etiqueta e ajusta para folha de adesivos. */
  .etiquetas-barra { display: none !important; }
  body { background: #fff; }
  .etiquetas-pagina { max-width: none; padding: 0; margin: 0; }
  .etiquetas-grade {
    grid-template-columns: repeat(3, 1fr);
    gap: 4mm;
  }
  .etiqueta { border: 1px solid #999; border-radius: 4px; }
  @page { margin: 8mm; }
}

/* ====================================================================== */
/* ESTOQUE                                                                */
/* ====================================================================== */
.estoque-colunas { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: start; }
.inventario-categoria {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 14px 16px;
}
.inventario-categoria h3 { margin: 0 0 10px; font-size: 15px; }
.inventario-categoria table.tabela th { background: transparent; padding: 6px 8px; }
.inventario-categoria table.tabela td { padding: 6px 8px; }

@media (min-width: 980px) {
  .estoque-colunas { grid-template-columns: 1fr 320px; }
}

/* ====================================================================== */
/* SCANNER (leitor de câmera)                                             */
/* ====================================================================== */
.scanner-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.scanner-caixa {
  width: 100%;
  max-width: 440px;
  background: #111;
  border-radius: 16px;
  overflow: hidden;
  color: #fff;
}
.scanner-cabecalho {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: #000;
}
.scanner-fechar {
  background: none;
  border: none;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
}
.scanner-video-wrap { position: relative; background: #000; aspect-ratio: 4 / 3; }
.scanner-video { width: 100%; height: 100%; object-fit: cover; display: block; }
.scanner-mira {
  position: absolute;
  inset: 22% 12%;
  border: 3px solid var(--verde-claro);
  border-radius: 12px;
  box-shadow: 0 0 0 100vmax rgba(0, 0, 0, 0.25);
  pointer-events: none;
}
.scanner-status { padding: 12px 14px; text-align: center; font-size: 14px; background: #000; }
.scanner-status.scanner-erro { color: #ffb4ab; }

/* ====================================================================== */
/* PDV (tela de venda)                                                    */
/* ====================================================================== */
.pdv { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: start; }

.pdv-add, .pdv-carrinho {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 16px 18px;
}
.pdv-add h3, .pdv-carrinho h3 { margin: 0 0 12px; font-size: 16px; }
.pdv-add-form { display: flex; gap: 8px; flex-wrap: wrap; }
.pdv-add-form input {
  flex: 1 1 200px;
  padding: 12px 14px;
  border: 1px solid var(--borda);
  border-radius: 10px;
  font-size: 16px;
}
.pdv-add-form input:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px rgba(46,125,50,.18); }
.pdv-dica { margin: 10px 0 0; font-size: 13px; color: var(--texto-suave); }

.pdv-carrinho-topo { display: flex; align-items: center; justify-content: space-between; }
.pdv-itens { list-style: none; margin: 0; padding: 0; }
.pdv-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--borda);
}
.pdv-item-info { display: flex; align-items: center; gap: 10px; min-width: 0; }
.pdv-item-desc { color: var(--texto-suave); font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pdv-item-acao { display: flex; align-items: center; gap: 12px; }
.pdv-item-valor { font-weight: 700; white-space: nowrap; }
.pdv-remover {
  background: none; border: none; color: var(--erro); cursor: pointer;
  font-size: 16px; padding: 4px 8px; border-radius: 8px;
}
.pdv-remover:hover { background: rgba(192,57,43,.1); }
.pdv-total {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 14px; padding-top: 14px; border-top: 2px solid var(--borda);
  font-size: 18px;
}
.pdv-total strong { font-size: 24px; color: var(--verde-escuro); }
.pdv-finalizar { margin-top: 14px; padding: 14px; font-size: 17px; }

@media (min-width: 860px) {
  .pdv { grid-template-columns: 1fr 1fr; }
  .pdv-add { position: sticky; top: 80px; }
}

/* ---------- Comprovante de venda ---------- */
.comprovante { max-width: 820px; }
.comprovante-cabecalho {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.comprovante-total { text-align: right; }
.comprovante-total span { display: block; font-size: 13px; color: var(--texto-suave); }
.comprovante-total strong { font-size: 26px; color: var(--verde-escuro); }
table.tabela tfoot th { background: var(--fundo); padding: 12px 14px; border-top: 2px solid var(--borda); }

/* ====================================================================== */
/* RELATÓRIOS (gráficos simples em CSS)                                   */
/* ====================================================================== */
.grafico-card {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 16px 18px;
  margin-bottom: 18px;
}
.grafico-card h3 { margin: 0 0 14px; font-size: 16px; }

/* Barra dupla (consignantes x ACACCI) */
.barra-dupla { display: flex; height: 34px; border-radius: 8px; overflow: hidden; background: var(--fundo); }
.barra-seg {
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 700; font-size: 13px; min-width: 0;
  transition: width 0.3s;
}
.barra-consign { background: var(--verde); }
.barra-acacci { background: var(--petroleo); }
.legenda { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 12px; font-size: 14px; color: var(--texto-suave); }
.ponto { display: inline-block; width: 12px; height: 12px; border-radius: 3px; vertical-align: middle; margin-right: 4px; }
.ponto-consign { background: var(--verde); }
.ponto-acacci { background: var(--petroleo); }

/* Ranking (barras horizontais) */
.ranking { display: flex; flex-direction: column; gap: 12px; }
.ranking-nome { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
.ranking-barra-wrap { display: flex; align-items: center; gap: 8px; }
.ranking-barra {
  height: 18px;
  background: linear-gradient(90deg, var(--verde), var(--petroleo));
  border-radius: 6px;
  min-width: 2px;
  transition: width 0.3s;
}
.ranking-valor { font-size: 13px; font-weight: 700; white-space: nowrap; color: var(--texto-suave); }

/* ====================================================================== */
/* ÁGUA POUPADA (diferencial do projeto)                                  */
/* ====================================================================== */
.agua-destaque {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 18px;
  padding: 18px 20px;
  border-radius: var(--raio);
  background: linear-gradient(100deg, #0e5c6b, #2e7d32);
  color: #fff;
  flex-wrap: wrap;
}
.agua-icone { font-size: 38px; line-height: 1; }
.agua-conteudo { flex: 1; min-width: 200px; }
.agua-titulo { font-size: 14px; opacity: 0.9; }
.agua-litros { font-size: 30px; font-weight: 800; line-height: 1.1; }
.agua-equivalencias { font-size: 14px; opacity: 0.95; margin-top: 4px; }
.agua-link { color: #fff; font-weight: 700; text-decoration: none; white-space: nowrap; }
.agua-link:hover { text-decoration: underline; }

/* Bloco de água nos relatórios */
.agua-relatorio { background: linear-gradient(100deg, rgba(14,92,107,.06), rgba(46,125,50,.08)); }
.agua-numero { font-size: 34px; font-weight: 800; color: var(--petroleo-escuro); }
.agua-numero span { font-size: 16px; font-weight: 600; color: var(--texto-suave); }
.agua-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 14px 0; }
.agua-eq {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: 12px;
  padding: 14px;
  text-align: center;
}
.agua-eq .n { display: block; font-size: 24px; font-weight: 800; color: var(--verde-escuro); }
.agua-eq .r { display: block; font-size: 13px; color: var(--texto-suave); margin-top: 2px; }
.agua-fonte { font-size: 13px; color: var(--texto-suave); margin: 0; font-style: italic; }

/* ---------- Alertas / mensagens ---------- */
.alerta { border-radius: 10px; padding: 10px 12px; font-size: 14px; margin-bottom: 14px; }
.alerta-erro { background: rgba(192, 57, 43, 0.1); color: var(--erro); }
.alerta-sucesso { background: rgba(46, 125, 50, 0.12); color: var(--verde-escuro); }
.alerta-info { background: rgba(14, 92, 107, 0.1); color: var(--petroleo); }

/* ====================================================================== */
/* Tela de LOGIN                                                          */
/* ====================================================================== */
.login-tela {
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
}
.login-cartao {
  width: 100%;
  max-width: 380px;
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: 20px;
  box-shadow: var(--sombra);
  padding: 32px;
}
.login-topo { text-align: center; margin-bottom: 22px; }
.login-topo img { height: 92px; width: auto; margin-bottom: 8px; }
.login-topo p { margin: 0; color: var(--texto-suave); font-size: 14px; }

/* ====================================================================== */
/* APP autenticado (menu + cabeçalho + conteúdo)                          */
/* ====================================================================== */
.app { display: flex; min-height: 100%; }

/* Menu lateral */
.menu {
  position: fixed;
  inset: 0 auto 0 0;
  width: 250px;
  background: var(--superficie);
  border-right: 1px solid var(--borda);
  box-shadow: var(--sombra);
  transform: translateX(-100%);
  transition: transform 0.2s ease;
  z-index: 40;
  display: flex;
  flex-direction: column;
}
.menu.aberto { transform: translateX(0); }
.menu-topo {
  height: 64px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-bottom: 1px solid var(--borda);
}
.menu-topo img.icone { height: 38px; width: 38px; object-fit: contain; }
.menu-marca { font-size: 22px; font-weight: 800; color: var(--verde-escuro); letter-spacing: 0.3px; }
.menu nav { padding: 12px; display: flex; flex-direction: column; gap: 4px; overflow-y: auto; }
.menu nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 600;
  color: var(--texto);
  text-decoration: none;
}
.menu nav a:hover { background: rgba(191, 227, 196, 0.4); }
.menu nav a.ativo { background: var(--verde); color: #fff; }

/* Fundo escuro ao abrir o menu no celular */
.menu-fundo {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 30;
  border: none;
  display: none;
}
.menu-fundo.visivel { display: block; }

/* Área de conteúdo */
.conteudo { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.cabecalho {
  position: sticky;
  top: 0;
  z-index: 20;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  background: var(--superficie);
  border-bottom: 1px solid var(--borda);
}
.cabecalho h1 { font-size: 18px; margin: 0; }
.cabecalho-esq { display: flex; align-items: center; gap: 12px; }
.cabecalho-dir { display: flex; align-items: center; gap: 12px; }
.usuario-info { text-align: right; line-height: 1.2; }
.usuario-info .nome { font-size: 14px; font-weight: 600; }
.usuario-info .papel { font-size: 12px; color: var(--texto-suave); text-transform: capitalize; }

.botao-menu {
  background: none;
  border: none;
  font-size: 22px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 8px;
  color: var(--texto);
}
.botao-menu:hover { background: var(--fundo); }

main.principal { flex: 1; padding: 20px 16px; }

/* Rodapé com crédito (canto inferior direito) */
.rodape {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 6px 14px;
  padding: 10px 18px 14px;
  font-size: 12px;
  color: var(--texto-suave);
}
.rodape-credito {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: 999px;
  padding: 4px 10px 4px 12px;
}
.rodape-credito img { height: 26px; width: auto; display: block; }

/* ---------- Dashboard ---------- */
.faixa-boas-vindas {
  background: linear-gradient(90deg, var(--verde), var(--petroleo));
  color: #fff;
  border-radius: var(--raio);
  padding: 22px;
  margin-bottom: 20px;
}
.faixa-boas-vindas h2 { margin: 0 0 4px; font-size: 22px; }
.faixa-boas-vindas p { margin: 0; opacity: 0.92; }

.cartoes { display: grid; grid-template-columns: 1fr; gap: 14px; }
.cartao {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 18px;
}
.cartao .icone { font-size: 24px; }
.cartao .rotulo { font-size: 13px; color: var(--texto-suave); margin-top: 6px; }
.cartao .valor { font-size: 24px; font-weight: 700; margin-top: 2px; }

/* ---------- Placeholder ---------- */
.placeholder {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  background: var(--superficie);
  border: 1px dashed var(--borda);
  border-radius: 18px;
  padding: 36px 28px;
}
.placeholder .etapa {
  display: inline-block;
  background: rgba(191, 227, 196, 0.5);
  color: var(--verde-escuro);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 12px;
}
.placeholder h2 { margin: 0 0 8px; font-size: 20px; }
.placeholder p { color: var(--texto-suave); margin: 0; }

/* ====================================================================== */
/* Telas maiores (tablet/desktop): menu fixo visível                      */
/* ====================================================================== */
@media (min-width: 768px) {
  .menu { position: static; transform: none; box-shadow: none; }
  .botao-menu { display: none; }
  .menu-fundo { display: none !important; }
  .cartoes { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px) {
  .cartoes { grid-template-columns: repeat(3, 1fr); }
}
