/* ============================================================= *
 *  Tema da Serraria — moderno claro com alternância para escuro  *
 *  Tudo controlado por variaveis; o tema escuro so redefine as   *
 *  variaveis em [data-tema="escuro"].                            *
 * ============================================================= */
:root {
  --verde: #0f8050;
  --verde-escuro: #0b5e3b;
  --verde-vivo: #16a763;
  --madeira: #97631e;

  --bg: #dfe5ee;            /* fundo cinza-azulado frio (cria contraste com os cards) */
  --card: #ffffff;
  --painel-2: #eaeff6;
  --campo: #ffffff;
  --borda: #bcc8d8;         /* bordas mais firmes/definidas */
  --texto: #0f1a25;         /* texto bem escuro = alto contraste */
  --suave: #51606f;
  --erro: #c0392b;

  --bg-verde: #d6ece0;
  --bg-madeira: #f1e4cd;
  --bg-erro: #fbe2de;
  --bg-neutro: #e2e8f1;
  --hover: #dde4ee;
  --zebra: #f1f5fa;

  --anel: rgba(15,128,80,.25);
  --sombra: 0 1px 2px rgba(15,28,42,.08), 0 10px 26px rgba(15,28,42,.12);
  --sombra-forte: 0 20px 54px rgba(15,28,42,.34);
  --raio: 12px;
  --raio-sm: 9px;
  --header: linear-gradient(135deg, #0c3a26 0%, #08231a 100%);  /* topo escuro = ar tecnologico */
  --topo-aba: rgba(255,255,255,.10);
  --topo-aba-hover: rgba(255,255,255,.20);
}

[data-tema="escuro"] {
  --verde: #5aae86;
  --verde-escuro: #8ad7b1;
  --verde-vivo: #5aae86;
  --madeira: #d59c54;

  --bg: #0f1512;
  --card: #18201b;
  --painel-2: #1e2822;
  --campo: #1f2a23;
  --borda: #2c3830;
  --texto: #e7ece8;
  --suave: #9aa69e;
  --erro: #e3675a;

  --bg-verde: rgba(90,174,134,.16);
  --bg-madeira: rgba(213,156,84,.16);
  --bg-erro: rgba(227,103,90,.18);
  --bg-neutro: #232e27;
  --hover: #243029;
  --zebra: #1b231e;

  --anel: rgba(90,174,134,.30);
  --sombra: 0 1px 2px rgba(0,0,0,.3), 0 6px 18px rgba(0,0,0,.38);
  --sombra-forte: 0 16px 48px rgba(0,0,0,.6);
  --header: linear-gradient(135deg, #20392c 0%, #15241b 100%);
  --topo-aba: rgba(255,255,255,.08);
  --topo-aba-hover: rgba(255,255,255,.16);
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Segoe UI", Roboto, system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--texto);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  transition: background-color .25s ease, color .25s ease;
}

/* ----------------------------- Login ---------------------------- */
.tela-login {
  position: fixed; inset: 0; display: flex; align-items: center; justify-content: center;
  background: var(--header); padding: 20px;
}
.caixa-login {
  background: var(--card); border-radius: 18px; padding: 36px 30px; width: 100%; max-width: 370px;
  box-shadow: var(--sombra-forte);
}
.caixa-login h1 { margin: 0; text-align: center; font-size: 32px; }
.caixa-login .sub { text-align: center; color: var(--suave); margin: 4px 0 24px; }
.login-erro { color: var(--erro); font-size: 14px; min-height: 18px; margin-bottom: 8px; }
.btn.largo { width: 100%; padding: 12px; font-size: 15px; }

/* ----------------------- Seleção de empresa ---------------------- */
.caixa-empresa { max-width: 560px; text-align: center; }
.empresa-baloes { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 8px; }
.empresa-balao {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  width: 150px; min-height: 130px; justify-content: center; cursor: pointer;
  background: var(--bg); border: 2px solid var(--borda); border-radius: 18px; padding: 18px 14px;
  color: var(--texto); transition: transform .12s, border-color .12s, box-shadow .12s;
}
.empresa-balao:hover { transform: translateY(-3px); border-color: var(--verde); box-shadow: var(--sombra-forte); }
.empresa-balao-icone { font-size: 34px; line-height: 1; }
.empresa-balao-nome { font-weight: 700; font-size: 15px; }
.empresa-balao-cnpj { font-size: 12px; color: var(--suave); }
#btn-trocar-empresa { background: rgba(255,255,255,.16); border-color: transparent; color: #fff; font-weight: 600; }
.empresas-lista { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.empresa-card {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  background: var(--bg); border: 1px solid var(--borda); border-left: 4px solid var(--verde);
  border-radius: 12px; padding: 12px 14px;
}
.empresa-card.inativa { border-left-color: var(--suave); opacity: .7; }
.empresa-card-info { display: flex; flex-direction: column; gap: 2px; }

/* ----------------------------- Topo ----------------------------- */
.topo { background: var(--header); color: #fff; box-shadow: var(--sombra); position: sticky; top: 0; z-index: 50; }
.topo-inner { max-width: 1240px; margin: 0 auto; padding: 14px 22px; }
.topo-linha { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.topo h1 { margin: 0; font-size: 22px; font-weight: 700; letter-spacing: .2px; }
.topo h1 span { font-weight: 300; opacity: .85; }
.usuario-box { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.usuario-box #usuario-nome { font-weight: 600; }
.abas { display: flex; gap: 6px; flex-wrap: wrap; }
.aba {
  background: var(--topo-aba); color: #fff; border: none; padding: 9px 16px; border-radius: 999px;
  cursor: pointer; font-size: 14px; transition: background .15s, transform .1s;
}
.aba:hover { background: var(--topo-aba-hover); }
.aba:active { transform: translateY(1px); }
.aba.ativa { background: var(--card); color: var(--verde-escuro); font-weight: 600; box-shadow: 0 3px 10px rgba(0,0,0,.18); }

/* ----------------------------- Main ----------------------------- */
main { max-width: 1240px; margin: 0 auto; padding: 26px 22px 70px; }
.painel-aba { display: none; animation: surge .22s ease; }
.painel-aba.ativa { display: block; }
@keyframes surge { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
h2 { font-size: 21px; margin: 0 0 16px; letter-spacing: .2px; }
.cabecalho-secao { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.cabecalho-secao h2 { margin: 0; }
.ajuda { color: var(--suave); margin: -6px 0 16px; font-size: 14px; }

/* ----------------------------- Cards ---------------------------- */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 16px; }
.card-resumo {
  background: var(--card); border: 1px solid var(--borda); border-left: 4px solid var(--verde);
  border-radius: var(--raio); padding: 18px 20px; box-shadow: var(--sombra);
  transition: transform .15s, box-shadow .15s;
}
.card-resumo:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(20,40,28,.10); }
.card-resumo .valor { font-size: 29px; font-weight: 700; color: var(--verde-escuro); line-height: 1.1; }
.card-resumo .rotulo { color: var(--suave); font-size: 13px; margin-top: 5px; }
.card-resumo.madeira { border-left-color: var(--madeira); }
.card-resumo.madeira .valor { color: var(--madeira); }
.card-resumo .detalhe-card { margin-top: 8px; padding-top: 7px; border-top: 1px solid var(--borda); color: var(--suave); font-size: 11px; line-height: 1.4; }
.card-resumo .acao-card-resumo { margin-top: 10px; width: 100%; }

/* ----------------------------- Botoes --------------------------- */
.btn {
  background: var(--card); border: 1px solid var(--borda); color: var(--texto); padding: 9px 16px;
  border-radius: var(--raio-sm); cursor: pointer; font: inherit; font-size: 14px;
  transition: background .15s, border-color .15s, transform .1s, box-shadow .15s;
}
.btn:hover { background: var(--hover); }
.btn:active { transform: translateY(1px); }
.btn.primario { background: linear-gradient(135deg, var(--verde-vivo), var(--verde)); color: #fff; border-color: transparent; box-shadow: 0 2px 10px var(--anel); }
.btn.primario:hover { filter: brightness(1.07); }
.btn.perigo { color: var(--erro); border-color: color-mix(in srgb, var(--erro) 35%, var(--borda)); }
.btn.perigo:hover { background: var(--bg-erro); }
.btn.pequeno { padding: 5px 11px; font-size: 13px; }

/* ----------------------------- Filtros -------------------------- */
.filtros { display: flex; gap: 10px; margin-bottom: 16px; flex-wrap: wrap; }
.filtros input, .filtros select { padding: 9px 13px; border: 1px solid var(--borda); border-radius: var(--raio-sm); font: inherit; font-size: 14px; background: var(--campo); color: var(--texto); }
.filtros input[type=search] { flex: 1; min-width: 200px; }

/* ----------------------------- Tabelas -------------------------- */
.tabela-wrap { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); overflow: auto; box-shadow: var(--sombra); }
table { width: 100%; border-collapse: collapse; font-size: 14px; }
th, td { padding: 11px 13px; text-align: left; border-bottom: 1px solid var(--borda); white-space: nowrap; }
th { background: var(--painel-2); color: var(--suave); font-weight: 600; font-size: 12.5px; text-transform: uppercase; letter-spacing: .3px; }
tbody tr { transition: background .12s; }
tbody tr:hover { background: var(--hover); }
tbody tr:last-child td { border-bottom: none; }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
.vazio { text-align: center; color: var(--suave); padding: 34px; }
.acoes-linha { display: flex; gap: 6px; }
/* Acoes ficam num wrapper flex dentro do td; a celula continua table-cell e alinha ao centro */
#tabela-toras-patio td { vertical-align: middle; }
#tabela-toras-patio td[data-col="acoes"] .acoes-linha { justify-content: flex-end; flex-wrap: wrap; }

/* --------------------------- Pacotes (cards) -------------------- */
.pacote-card { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); box-shadow: var(--sombra); margin-bottom: 16px; overflow: hidden; }
.pacote-topo { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 13px 17px; background: var(--painel-2); border-bottom: 1px solid var(--borda); flex-wrap: wrap; }
.pacote-topo .titulo { font-size: 16px; font-weight: 700; }
.pacote-topo .info { color: var(--suave); font-size: 13px; margin-top: 2px; }
.pacote-topo .totais { display: flex; gap: 16px; align-items: center; }
.pacote-topo .totais b { color: var(--verde-escuro); }
.pacote-card table { font-size: 13.5px; }
.pacote-card .acoes-pacote { display: flex; gap: 6px; }
.qualidade { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.qualidade.primeira { background: #dcefe3; color: #21633c; }
.qualidade.segunda { background: #fff0c9; color: #805c00; }
.qualidade.terceira { background: #f4ded9; color: #923c2d; }
.qualidade.nao_classificada { background: var(--bg-neutro); color: var(--suave); }
.grade-fotos { display: flex; gap: 9px; flex-wrap: wrap; margin: 8px 0 14px; }
.foto-miniatura { position: relative; width: 112px; height: 84px; border: 1px solid var(--borda); border-radius: var(--raio-sm); overflow: hidden; background: var(--painel-2); }
.foto-miniatura img { width: 100%; height: 100%; object-fit: cover; display: block; }
.foto-miniatura button { position: absolute; top: 4px; right: 4px; border: 0; border-radius: 50%; width: 24px; height: 24px; cursor: pointer; background: rgba(160,32,22,.9); color: #fff; font-weight: 700; }
.galeria-pacote { display: flex; gap: 7px; padding: 10px 16px; overflow-x: auto; border-bottom: 1px solid var(--borda); }
.galeria-pacote img { width: 110px; height: 78px; border-radius: var(--raio-sm); object-fit: cover; display: block; }
.badge { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.badge.serrada { background: #f3ece0; color: #8a5a17; }
.badge.plainada { background: #e3eef7; color: #1f5a86; }

/* ---------------------- Cards de carregamento ------------------- */
.lista-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 16px; }
.card-carregamento { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 17px; box-shadow: var(--sombra); display: flex; flex-direction: column; gap: 8px; transition: transform .15s, box-shadow .15s; }
.card-carregamento:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(20,40,28,.10); }
.card-carregamento h3 { margin: 0; font-size: 17px; }
.card-carregamento .meta { color: var(--suave); font-size: 13px; line-height: 1.6; }
.card-carregamento .nums { display: flex; gap: 16px; margin-top: 4px; }
.card-carregamento .nums b { display: block; font-size: 18px; color: var(--verde-escuro); }
.card-carregamento .nums span { font-size: 12px; color: var(--suave); }
.card-carregamento .rodape { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.selo { display: inline-block; padding: 3px 11px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.selo.aberto { background: var(--bg-verde); color: var(--verde-escuro); }
.selo.finalizado { background: var(--bg-neutro); color: var(--suave); }

/* ----------------------------- Modais --------------------------- */
.modal-fundo { display: none; position: fixed; inset: 0; background: rgba(10,20,14,.5); backdrop-filter: blur(2px); z-index: 100; padding: 20px; overflow-y: auto; }
.modal-fundo.aberto { display: flex; align-items: flex-start; justify-content: center; }
.modal { background: var(--card); border: 1px solid var(--borda); border-radius: 16px; padding: 24px; width: 100%; max-width: 560px; margin: 40px auto; box-shadow: var(--sombra-forte); animation: surge .2s ease; }
.modal-grande { max-width: 1000px; }
.modal h3 { margin: 0 0 16px; font-size: 19px; }
.grade { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; color: var(--suave); margin-bottom: 12px; }
label.inline { flex-direction: row; align-items: center; gap: 8px; }
input, select, textarea { padding: 10px 12px; border: 1px solid var(--borda); border-radius: var(--raio-sm); font: inherit; color: var(--texto); background: var(--campo); transition: border-color .15s, box-shadow .15s; }
textarea { width: 100%; resize: vertical; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--anel); }
.acoes-modal { display: flex; justify-content: flex-end; gap: 10px; margin-top: 8px; }
.previa { background: var(--bg-verde); border: 1px dashed var(--verde); border-radius: var(--raio-sm); padding: 11px 13px; font-size: 14px; color: var(--verde-escuro); margin: 12px 0; }
.previa:empty { display: none; }

/* ----------------------- Tabela de itens (modal) ---------------- */
.itens-cabecalho { display: flex; justify-content: space-between; align-items: center; margin: 6px 0 8px; }
.tabela-itens td, .tabela-itens th { padding: 6px 7px; }
.tabela-itens input, .tabela-itens select { padding: 7px 8px; font-size: 13px; width: 100%; min-width: 70px; margin: 0; }
.tabela-itens select { min-width: 120px; }
.tabela-itens .col-calc { color: var(--verde-escuro); font-variant-numeric: tabular-nums; text-align: right; white-space: nowrap; }
.tabela-itens label { margin: 0; }

/* --------------------------- Permissoes ------------------------- */
fieldset { border: 1px solid var(--borda); border-radius: var(--raio-sm); padding: 14px; margin: 0 0 14px; }
legend { font-size: 13px; color: var(--suave); padding: 0 6px; font-weight: 600; }

/* --------------------- Cadastro de tora de patio ---------------- */
.bloco-medidas { margin: 0 0 12px; }
.m3-calc { background: var(--bg-neutro); color: var(--madeira, #245539); font-weight: 700; cursor: default; }
.grade-plaqueta { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: end; }
.tabela-sugestoes { width: 100%; border-collapse: collapse; margin-top: 8px; font-size: 13px; }
.tabela-sugestoes th, .tabela-sugestoes td { border-bottom: 1px solid var(--borda); padding: 5px 7px; text-align: left; }
.tabela-sugestoes th.num, .tabela-sugestoes td.num { text-align: right; }
.tabela-sugestoes tr.melhor td { background: rgba(47, 111, 78, 0.10); }
.tabela-sugestoes small { color: var(--suave); }
.erro-texto { color: var(--perigo, #c0392b); }
.permissoes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; }
.permissoes-grid label { flex-direction: row; align-items: center; gap: 7px; margin: 0; color: var(--texto); font-size: 14px; }
.chips { display: flex; flex-wrap: wrap; gap: 4px; }
.chip { background: var(--bg-neutro); color: var(--suave); border-radius: 999px; padding: 2px 9px; font-size: 11px; }

/* ------------------- Menu de colunas (toras no patio) ----------- */
.menu-colunas { position: relative; }
.menu-colunas > summary { list-style: none; cursor: pointer; display: inline-flex; align-items: center; }
.menu-colunas > summary::-webkit-details-marker { display: none; }
.menu-colunas[open] > summary { background: var(--verde); border-color: var(--verde); color: #fff; }
.menu-colunas-corpo {
  position: absolute; z-index: 60; right: 0; margin-top: 6px; min-width: 210px;
  background: var(--campo); border: 1px solid var(--borda); border-radius: var(--raio-sm);
  padding: 10px 12px; box-shadow: 0 8px 22px rgba(0, 0, 0, 0.22);
}
.menu-colunas-corpo label {
  display: flex; flex-direction: row; align-items: center; gap: 8px;
  margin: 5px 0; font-size: 13px; color: var(--texto); cursor: pointer;
}

/* --------- Disponibilidade SISFLORA (madeira bruta/acabada) ------ */
.card-resumo.alerta { border-left-color: var(--perigo, #c0392b); }
.card-resumo.alerta .valor { color: var(--perigo, #c0392b); }
.bloco-disp { margin: 4px 0 14px; }
.bloco-disp > summary {
  cursor: pointer; font-size: 13px; font-weight: 600; color: var(--suave);
  padding: 6px 0; list-style: revert;
}
.tabela-disp { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 6px; }
.tabela-disp th, .tabela-disp td { border-bottom: 1px solid var(--borda); padding: 6px 8px; text-align: left; }
.tabela-disp th.num, .tabela-disp td.num { text-align: right; white-space: nowrap; }
.tabela-disp tr.linha-excede td { background: rgba(192, 57, 43, 0.08); }
.tag-disp { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.tag-disp.ok { background: var(--bg-verde); color: var(--verde-escuro); }
.tag-disp.excede { background: rgba(192, 57, 43, 0.14); color: var(--perigo, #c0392b); }

/* ------------------------ Detalhe carregamento ------------------ */
.detalhe-cabecalho { border-bottom: 2px solid var(--verde); padding-bottom: 12px; margin-bottom: 14px; }
.detalhe-cabecalho h2 { margin: 0 0 6px; }
.detalhe-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 8px 18px; font-size: 14px; }
.detalhe-grid div span { color: var(--suave); font-size: 12px; display: block; }
.totais-box { display: flex; gap: 22px; background: var(--bg-verde); border-radius: var(--raio-sm); padding: 14px 18px; margin: 14px 0; flex-wrap: wrap; }
.totais-box b { display: block; font-size: 20px; color: var(--verde-escuro); }
.totais-box span { font-size: 12px; color: var(--suave); }
.add-pacote-box { display: flex; gap: 8px; margin: 12px 0; flex-wrap: wrap; align-items: center; }
.add-pacote-box select { flex: 1; min-width: 220px; padding: 10px 12px; border: 1px solid var(--borda); border-radius: var(--raio-sm); background: var(--campo); color: var(--texto); }
.grid-resumos { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.grid-resumos h4 { margin: 14px 0 6px; }

/* ---------- Navegacao interna: estoque, projetos e configuracoes */
.contexto-ajuda { margin: -8px 0 14px; }
.subabas-contexto { display: flex; gap: 8px; margin: 0 0 18px; border-bottom: 1px solid var(--borda); padding-bottom: 8px; }
.subabas-contexto .btn.ativa { background: var(--verde); border-color: var(--verde); color: #fff; }
.cabecalho-secao > .subabas-contexto { flex: 1; margin-bottom: 0; }
.subpainel-contexto { display: none; }
.subpainel-contexto.ativo { display: block; }
.subpainel-contexto h3 { margin: 0; font-size: 18px; }

/* ------------------------- Saldo de toras ----------------------- */
.grid-projetos-toras { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 16px; }
.projeto-painel { border: 1px solid var(--borda); border-left: 5px solid var(--madeira); background: var(--card); border-radius: var(--raio); padding: 16px; box-shadow: var(--sombra); cursor: pointer; transition: transform .15s, box-shadow .15s; }
.projeto-painel:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(20,40,28,.12); }
.projeto-painel h4 { margin: 0 0 4px; color: var(--verde-escuro); font-size: 16px; }
.projeto-painel .meta { color: var(--suave); font-size: 12px; }
.projeto-painel .numeros { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; margin-top: 12px; }
.projeto-painel .numeros div { background: var(--painel-2); border-radius: var(--raio-sm); padding: 8px 10px; }
.projeto-painel .numeros b { display: block; color: var(--madeira); font-size: 17px; }
.projeto-painel .numeros span { color: var(--suave); font-size: 11px; }
.grid-uts-projeto { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; margin: 8px 0 14px; }
.ut-projeto { border: 1px solid var(--borda); border-radius: var(--raio-sm); padding: 9px 11px; background: var(--painel-2); cursor: pointer; text-align: left; color: var(--texto); }
.ut-projeto.ativa { background: var(--bg-verde); border-color: var(--verde); }
.ut-projeto b { display: block; color: var(--verde-escuro); }
.ut-projeto span { color: var(--suave); font-size: 11px; }
.paginacao { display: flex; justify-content: center; align-items: center; gap: 12px; margin-top: 12px; }
.importar-xlsx { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.importar-xlsx input { max-width: 300px; }
.grade-importacoes { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin: 18px 0; }
.importacao-card { display: flex; flex-direction: column; min-width: 0; padding: 18px; border: 1px solid var(--borda); border-radius: var(--raio); background: var(--card); box-shadow: var(--sombra); }
.importacao-titulo { display: flex; gap: 12px; align-items: flex-start; min-height: 72px; }
.importacao-titulo h4 { margin: 1px 0 5px; color: var(--texto); font-size: 16px; }
.importacao-titulo p { margin: 0; color: var(--suave); font-size: 12px; line-height: 1.45; }
.importacao-passo { display: grid; place-items: center; flex: 0 0 30px; width: 30px; height: 30px; border-radius: 50%; background: var(--verde); color: #fff; font-weight: 700; }
.campo-arquivo { margin: 12px 0; color: var(--texto); font-weight: 600; }
.campo-arquivo input[type="file"] { width: 100%; max-width: none; padding: 6px; font-weight: 400; color: var(--suave); }
.campo-arquivo input[type="file"]::file-selector-button { margin-right: 10px; padding: 8px 12px; border: 0; border-radius: 6px; background: var(--bg-verde); color: var(--verde-escuro); font: inherit; font-weight: 700; cursor: pointer; }
.opcao-sincronizacao { flex-direction: row; align-items: flex-start; gap: 9px; margin: 0 0 12px; padding: 10px; border-radius: var(--raio-sm); background: var(--painel-2); color: var(--texto); }
.opcao-sincronizacao input { margin-top: 2px; }
.opcao-sincronizacao span { display: flex; flex-direction: column; gap: 2px; }
.opcao-sincronizacao small { color: var(--suave); line-height: 1.35; }
.importacao-rodape { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 8px; }
.importacao-rodape > span { color: var(--suave); font-size: 12px; }
.importacao-rodape .btn { white-space: nowrap; }
@media (max-width: 800px) {
  .grade-importacoes { grid-template-columns: 1fr; }
  .importacao-titulo { min-height: 0; }
  .importacao-rodape { align-items: stretch; flex-direction: column; }
}
.situacao-tora { display: inline-block; padding: 2px 9px; border-radius: 999px; background: var(--bg-neutro); color: var(--suave); font-size: 12px; }
.situacao-tora.disponivel { background: #dcefe3; color: #21633c; font-weight: 700; }
.historico-importacoes { margin-top: 14px; color: var(--suave); font-size: 13px; }
.historico-importacoes h4 { margin: 0 0 5px; color: var(--texto); }

/* ----------------------------- Relatorio ------------------------ */
.area-relatorio { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 24px; box-shadow: var(--sombra); }
.area-relatorio h3 { margin-top: 0; }
.area-relatorio h4 { margin: 22px 0 8px; }
.linha-total td { font-weight: 700; background: var(--bg-verde); border-top: 2px solid var(--verde); }

/* ----------------------------- Toast ---------------------------- */
.toast { position: fixed; bottom: 26px; left: 50%; transform: translateX(-50%) translateY(20px); background: #222d26; color: #fff; padding: 13px 24px; border-radius: var(--raio-sm); font-size: 14px; box-shadow: var(--sombra-forte); opacity: 0; pointer-events: none; transition: all .25s; z-index: 200; max-width: 90%; }
.toast.mostrar { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.erro { background: var(--erro); }

@media (max-width: 640px) { .grade, .permissoes-grid { grid-template-columns: 1fr; } }

/* ----------------------------- Impressao ------------------------ */
@media print {
  :root, [data-tema="escuro"] {
    --bg: #fff; --card: #fff; --painel-2: #fff; --campo: #fff; --texto: #000; --suave: #555;
    --borda: #ccc; --bg-verde: #eef5f0; --bg-neutro: #eee; --hover: #fff; --zebra: #fff;
    --verde: #2f6f4e; --verde-escuro: #245539; --madeira: #a9742f;
  }
  .topo, .filtros, .cabecalho-secao .btn, .nao-imprimir, .acoes-linha, .acoes-modal, .acoes-pacote { display: none !important; }
  body { background: #fff; }
  .modal-fundo { display: none !important; }
  .modal { box-shadow: none; max-width: 100%; margin: 0; padding: 0; border: none; }
  .area-relatorio, .tabela-wrap { box-shadow: none; border: none; }
  main { padding: 0; }
  table { font-size: 12px; }

  body.impressao-estoque .painel-aba { display: none !important; }
  body.impressao-estoque #relatorios { display: block !important; }

  body.impressao-carregamento #app { display: none !important; }
  body.impressao-carregamento #modal-detalhe-carregamento {
    display: block !important;
    position: static;
    background: #fff;
    padding: 0;
  }
}
