/* edespiao — tema light (padrão) + dark (padrão Velaplast). */
:root {
  --bg: #f4f6fa; --panel: #ffffff; --line: #e3e6eb; --text: #1d2330;
  --muted: #6b7280; --accent: #4f8cff; --accent-soft: #eaf0ff;
}
body.dark {
  --bg: #0f1115; --panel: #161a22; --line: #232a36; --text: #e7ebf0;
  --muted: #8892a6; --accent: #4f8cff; --accent-soft: #1f2a45;
}
/* cores por estado (fixas — legíveis nos dois temas) */
.verde   { background: #16a34a; } .amarelo { background: #ca8a04; }
.vermelho{ background: #dc2626; } .laranja { background: #ea580c; }
.cinza   { background: #6b7280; } .geralc  { background: #1f2937; }

* { box-sizing: border-box; }
body { font-family: system-ui, "Segoe UI", sans-serif; margin: 0; background: var(--bg); color: var(--text); }

/* ── Navbar ── */
header { background: var(--panel); border-bottom: 1px solid var(--line); padding: 10px 20px; }
header h1 { margin: 0 0 8px; font-size: 20px; display: flex; align-items: center; gap: 3px; letter-spacing: .5px; }
header h1 .logo { height: 26px; width: auto; flex: none; }
.sync-bar { display: flex; gap: 12px; align-items: center; }
.sync-bar .spacer { flex: 1; }
.sync-bar button, .sync-bar a.btn, #theme-toggle {
  padding: 6px 12px; border-radius: 6px; border: 1px solid var(--line);
  background: transparent; color: var(--text); cursor: pointer; font-size: 13px; text-decoration: none; }
#btn-forcar { background: var(--accent); color: #fff; border-color: var(--accent); }
.sync-bar a.btn:hover, #theme-toggle:hover { background: var(--accent-soft); border-color: var(--accent); }
.status { font-size: 13px; color: var(--muted); }

/* ── Cartões ── */
.cartoes { display: flex; gap: 12px; flex-wrap: wrap; padding: 16px 20px; }
.cartao { border: none; border-radius: 10px; padding: 12px 18px; cursor: pointer; color: #fff;
  display: flex; flex-direction: column; min-width: 120px; opacity: .92; }
.cartao.ativo { outline: 3px solid var(--text); opacity: 1; }
.cartao .num { font-size: 26px; font-weight: 700; } .cartao .lbl { font-size: 12px; }

/* ── Filtros ── */
.filtros { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; padding: 0 20px 12px; }
.filtros input, .filtros button { padding: 7px 10px; border-radius: 6px; border: 1px solid var(--line); background: var(--panel); color: var(--text); }
.filtros input[type=search] { width: 300px; max-width: 100%; }
#btn-filtrar { background: var(--accent); color: #fff; border-color: var(--accent); cursor: pointer; }
#btn-limpar-datas { cursor: pointer; }
.filtros label { font-size: 13px; color: var(--muted); }

/* ── Tabela ── */
table { width: calc(100% - 40px); margin: 0 20px 40px; border-collapse: collapse; background: var(--panel); font-size: 13px; color: var(--text); }
th, td { padding: 8px 10px; border-bottom: 1px solid var(--line); text-align: left; }
th { background: var(--bg); position: sticky; top: 0; white-space: nowrap; }
.chave { font-family: ui-monospace, monospace; font-size: 11px; }
/* badge de estado: quadrado de cantos arredondados, só ele é colorido */
.badge { display: inline-block; padding: 3px 10px; border-radius: 6px; color: #fff; font-size: 12px; white-space: nowrap; }
/* alerta com ponto (dot) colorido */
.btn-alerta { background: transparent; border: none; color: var(--text); cursor: pointer; font-size: 12px; display: inline-flex; align-items: center; gap: 6px; }
.btn-alerta .dot { width: 9px; height: 9px; border-radius: 50%; background: #d9534f; display: inline-block; flex: none; }

/* ── Filtro de estado no cabeçalho (estilo Excel) ── */
.th-estado { display: inline-flex; align-items: center; gap: 6px; }
.th-filtro { background: transparent; border: 1px solid var(--line); border-radius: 4px; color: var(--text); cursor: pointer; padding: 0 5px; font-size: 11px; }
.th-filtro.ativo { border-color: var(--accent); color: var(--accent); }
.popover { position: absolute; z-index: 30; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 6px 24px rgba(0,0,0,.25); padding: 8px; min-width: 200px; }
.popover[hidden] { display: none; }
.popover label { display: flex; align-items: center; gap: 8px; padding: 5px 6px; font-size: 13px; cursor: pointer; font-weight: normal; }
.popover .acoes { display: flex; gap: 8px; border-top: 1px solid var(--line); margin-top: 6px; padding-top: 8px; }
.popover .acoes button { flex: 1; padding: 5px; border-radius: 5px; border: 1px solid var(--line); background: transparent; color: var(--text); cursor: pointer; font-size: 12px; }

/* ── Modal de divergências ── */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; z-index: 50; }
.modal-overlay[hidden] { display: none; }
.modal-box { background: var(--panel); color: var(--text); border-radius: 10px; width: min(820px, 95vw); max-height: 80vh; overflow: auto; box-shadow: 0 10px 40px rgba(0,0,0,.3); }
.modal-head { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.modal-head button { border: none; background: none; font-size: 18px; cursor: pointer; color: var(--muted); }
.danfe-acoes { display: inline-flex; gap: 10px; align-items: center; }
#danfe-reconhecer { font-size: 13px; background: #16a34a; color: #fff; border-radius: 6px; padding: 6px 12px; }
#danfe-cancelar-rec { font-size: 13px; background: #b45309; color: #fff; border-radius: 6px; padding: 6px 12px; }
.modal-sub { padding: 10px 18px 0; font-size: 13px; color: var(--muted); }
.modal-tabela { width: 100%; border-collapse: collapse; margin: 10px 0 16px; }
.modal-tabela th, .modal-tabela td { padding: 8px 14px; border-bottom: 1px solid var(--line); text-align: left; font-size: 13px; vertical-align: top; }
.modal-tabela th { background: var(--bg); }
.modal-tabela th:first-child, .modal-tabela td:first-child { white-space: nowrap; }
.modal-tabela td:nth-child(2), .modal-tabela td:nth-child(3) { font-family: ui-monospace, monospace; font-size: 12px; word-break: break-all; }
.modal-tabela td:nth-child(2) { color: #1d4ed8; } .modal-tabela td:nth-child(3) { color: #b45309; }
body.dark .modal-tabela td:nth-child(2) { color: #7aa2ff; } body.dark .modal-tabela td:nth-child(3) { color: #e7a23c; }
/* Modal DANFE */
.modal-box.danfe { width: min(960px, 96vw); }
.danfe-cab { padding: 12px 18px; font-size: 13px; line-height: 1.7; border-bottom: 1px solid var(--line); }
#danfe-itens td, #danfe-itens th { font-family: inherit; font-size: 13px; color: var(--text); word-break: normal; }
#tabela tbody tr:hover { background: var(--accent-soft); cursor: default; }

/* ── Config (página) ── */
.config-wrap { max-width: 720px; margin: 20px; }
.config-ajuda { background: var(--panel); border-left: 4px solid var(--accent); padding: 10px 14px; font-size: 14px; border-radius: 4px; color: var(--text); }
.bloco { background: var(--panel); padding: 18px 20px; border-radius: 8px; margin-bottom: 16px; }
.bloco h2 { margin: 0 0 6px; font-size: 17px; } .bloco h3 { margin: 16px 0 4px; font-size: 14px; }
.campo { display: flex; flex-direction: column; margin-bottom: 14px; }
.campo label { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.campo input, .campo select { padding: 8px 10px; border: 1px solid var(--line); border-radius: 6px; font-size: 14px; background: var(--bg); color: var(--text); }
.campo .dica { font-size: 12px; color: var(--muted); margin-top: 3px; }
.bloco-acoes { display: flex; gap: 12px; align-items: center; margin-top: 16px; }
.bloco-acoes button { padding: 8px 16px; border: none; border-radius: 6px; cursor: pointer; background: #16a34a; color: #fff; }
.bloco-acoes #btn-testar { background: var(--accent); }
.status-bloco { font-size: 13px; color: var(--text); }
.check { display: block; padding: 6px 0; font-size: 14px; cursor: pointer; }
.check input { margin-right: 8px; }
.lista-modelos { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 2px 14px; max-height: 220px; overflow-y: auto; border: 1px solid var(--line); padding: 8px; border-radius: 6px; }
.lista-modelos .qt { color: var(--muted); font-size: 12px; }
.resultado-teste { margin: 16px 0 0; }
.teste-linha { background: var(--bg); padding: 10px 14px; border-radius: 6px; margin-bottom: 8px; font-size: 14px; border-left: 4px solid var(--line); }
.teste-linha.ok { border-left-color: #16a34a; } .teste-linha.erro { border-left-color: #dc2626; }
.link-voltar { color: var(--accent); text-decoration: none; }
