/* public/css/base.css */
/* Variáveis, reset e componentes comuns a todas as páginas */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --azul-escuro:   #0f1f3d;
  --azul-medio:    #1a3a6e;
  --azul-claro:    #2563eb;
  --azul-suave:    #dbeafe;
  --branco:        #ffffff;
  --cinza-100:     #f5f7fb;
  --cinza-200:     #e2e8f0;
  --cinza-300:     #cbd5e1;
  --cinza-400:     #94a3b8;
  --cinza-600:     #475569;
  --preto-texto:   #0f172a;
  --verde:         #16a34a;
  --amarelo:       #d97706;
  --laranja:       #f97316;
  --vermelho:      #dc2626;
  --vermelho-suave:#fee2e2;

  --fundo:         radial-gradient(circle at top left, rgba(37,99,235,.10), transparent 32%), var(--cinza-100);
  --superficie:    var(--branco);
  --borda:         var(--cinza-200);
  --titulo-cor:    var(--azul-escuro);
  --texto-suave:   var(--cinza-600);
  --cabecalho-bg:  linear-gradient(135deg, #081427, #0f1f3d 58%, #123b73);

  --fonte-texto: 'IBM Plex Sans', sans-serif;
  --fonte-mono:  'IBM Plex Mono', monospace;

  --raio:    14px;
  --raio-sm: 9px;
  --sombra:  0 10px 30px rgba(15, 23, 42, .08);
  --sombra-md: 0 16px 50px rgba(15, 23, 42, .14);
}

body.tema-escuro {
  --azul-escuro:   #101d34;
  --azul-medio:    #1d4ed8;
  --azul-claro:    #60a5fa;
  --azul-suave:    #172554;
  --branco:        #111827;
  --cinza-100:     #070d1a;
  --cinza-200:     #1f2937;
  --cinza-300:     #334155;
  --cinza-400:     #94a3b8;
  --cinza-600:     #cbd5e1;
  --preto-texto:   #f8fafc;
  --verde:         #22c55e;
  --amarelo:       #facc15;
  --laranja:       #fb923c;
  --vermelho:      #f87171;
  --vermelho-suave:#3b1116;

  --fundo:         radial-gradient(circle at top left, rgba(96,165,250,.14), transparent 34%), #070d1a;
  --superficie:    #111827;
  --borda:         #1f2937;
  --titulo-cor:    #e5e7eb;
  --texto-suave:   #94a3b8;
  --cabecalho-bg:  linear-gradient(135deg, #020617, #0f172a 55%, #172554);
  --sombra:        0 10px 30px rgba(0, 0, 0, .26);
  --sombra-md:     0 18px 55px rgba(0, 0, 0, .38);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; }

body {
  overflow-x: hidden;
  font-family: var(--fonte-texto);
  background: var(--fundo);
  color: var(--preto-texto);
  line-height: 1.5;
  min-height: 100vh;
  transition: background .2s ease, color .2s ease;
}

/* ── Botões ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  padding: .58rem 1.05rem;
  border: 1px solid transparent;
  border-radius: var(--raio-sm);
  font-family: var(--fonte-texto);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform .12s ease, background .15s ease, color .15s ease, border-color .15s ease, opacity .15s ease;
}
.btn:hover:not(:disabled) { transform: translateY(-1px); }
.btn:disabled { opacity: .55; cursor: not-allowed; }
.btn-primario  { background: var(--azul-claro); color: #fff; box-shadow: 0 8px 20px rgba(37,99,235,.20); }
.btn-primario:hover:not(:disabled) { background: var(--azul-medio); }
.btn-secundario { background: rgba(148,163,184,.15); color: var(--cinza-600); border-color: var(--borda); }
.btn-secundario:hover:not(:disabled) { background: rgba(148,163,184,.25); color: var(--preto-texto); }
.btn-perigo    { background: var(--vermelho); color: #fff; }
.btn-sm { padding: .38rem .75rem; font-size: .78rem; }

/* ── Inputs ── */
.campo {
  display: flex;
  flex-direction: column;
  gap: .3rem;
}
.campo label {
  font-size: .73rem;
  font-weight: 700;
  color: var(--texto-suave);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.campo input,
.campo select {
  padding: .62rem .78rem;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-sm);
  font-family: var(--fonte-texto);
  font-size: .9rem;
  color: var(--preto-texto);
  background: var(--superficie);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
  width: 100%;
}
.campo input::placeholder { color: var(--cinza-400); }
.campo input:focus,
.campo select:focus {
  outline: none;
  border-color: var(--azul-claro);
  box-shadow: 0 0 0 4px rgba(37,99,235,.12);
}
.campo-ajuda {
  color: var(--cinza-400);
  font-size: .72rem;
  line-height: 1.25;
}

/* ── Mensagens de feedback ── */
.mensagem {
  padding: .7rem .95rem;
  border-radius: var(--raio-sm);
  font-size: .875rem;
  display: none;
}
.mensagem.visivel { display: block; }
.mensagem.erro    { background: var(--vermelho-suave); color: var(--vermelho); }
.mensagem.sucesso { background: rgba(34,197,94,.15); color: var(--verde); }
.mensagem.aviso   { background: rgba(250,204,21,.18); color: #a16207; }

/* ── Badges ── */
.nivel-badge,
.modulo-badge {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .18rem .55rem;
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 700;
  font-family: var(--fonte-mono);
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
}
.nivel-info     { background: #dbeafe; color: #1d4ed8; }
.nivel-aviso    { background: #fef9c3; color: #92400e; }
.nivel-erro     { background: #ffedd5; color: #9a3412; }
.nivel-critico  { background: #1a0000; color: #fca5a5; }
body.tema-escuro .nivel-info    { background: rgba(96,165,250,.18); color: #93c5fd; }
body.tema-escuro .nivel-aviso   { background: rgba(250,204,21,.16); color: #fde68a; }
body.tema-escuro .nivel-erro    { background: rgba(251,146,60,.16); color: #fdba74; }
body.tema-escuro .nivel-critico { background: rgba(248,113,113,.16); color: #fca5a5; }

.modulo-badge { background: rgba(37,99,235,.10); color: var(--azul-claro); }
.modulo-whatsapp { background: rgba(34,197,94,.14); color: #16a34a; }
.modulo-mercadolivre { background: rgba(250,204,21,.20); color: #a16207; }
.modulo-scanntech { background: rgba(14,165,233,.14); color: #0284c7; }
.modulo-email { background: rgba(168,85,247,.14); color: #7e22ce; }
.modulo-sem_modulo { background: rgba(148,163,184,.18); color: var(--cinza-600); }
body.tema-escuro .modulo-whatsapp { color: #86efac; }
body.tema-escuro .modulo-mercadolivre { color: #fde68a; }
body.tema-escuro .modulo-scanntech { color: #7dd3fc; }
body.tema-escuro .modulo-email { color: #d8b4fe; }

/* ── Cabeçalho das telas internas ── */
.cabecalho {
  background: var(--cabecalho-bg);
  color: #fff;
  padding: 0 1.5rem;
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: var(--sombra-md);
  position: sticky;
  top: 0;
  z-index: 20;
}
.cabecalho-logo {
  font-family: var(--fonte-mono);
  font-size: .98rem;
  font-weight: 600;
  letter-spacing: .06em;
  color: #fff;
  text-decoration: none;
}
.cabecalho-logo span { color: #93c5fd; }
.cabecalho-info {
  display: flex;
  align-items: center;
  gap: .75rem;
  font-size: .82rem;
  color: #cbd5e1;
}
.cabecalho-papel {
  background: rgba(255,255,255,.13);
  color: #fff;
  padding: .24rem .62rem;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.btn-sair,
.btn-tema {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.18);
  color: #dbeafe;
  padding: .38rem .7rem;
  border-radius: var(--raio-sm);
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s ease;
}
.btn-tema:hover { border-color: #93c5fd; color: #fff; }
.btn-sair:hover { border-color: var(--vermelho); color: #fecaca; }

/* ── Layout principal ── */
.pagina {
  max-width: 1280px;
  margin: 0 auto;
  padding: 1.5rem;
}

/* ── Tabela de logs ── */
.tabela-container {
  background: var(--superficie);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  box-shadow: var(--sombra);
  overflow-x: auto;
}
.tabela-logs {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}
.tabela-logs thead th {
  background: rgba(15, 31, 61, .96);
  color: #fff;
  padding: .78rem 1rem;
  text-align: left;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
}
body.tema-escuro .tabela-logs thead th { background: #0b1220; }
.tabela-logs tbody tr {
  border-bottom: 1px solid var(--borda);
  transition: background .12s ease;
}
.tabela-logs tbody tr:hover { background: rgba(37,99,235,.045); }
body.tema-escuro .tabela-logs tbody tr:hover { background: rgba(96,165,250,.08); }
.tabela-logs tbody td {
  padding: .78rem 1rem;
  vertical-align: top;
  color: var(--texto-suave);
}
.tabela-logs tbody td.mensagem-col {
  max-width: 380px;
  color: var(--preto-texto);
  font-size: .84rem;
  word-break: break-word;
}
.tabela-logs tbody td.mono,
.mono {
  font-family: var(--fonte-mono);
  font-size: .78rem;
}
.link-log {
  color: var(--azul-claro);
  text-decoration: none;
  font-weight: 700;
}
.link-log:hover { text-decoration: underline; }

/* ── Paginação ── */
.paginacao {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1rem;
  background: var(--superficie);
  border-top: 1px solid var(--borda);
  font-size: .8rem;
  color: var(--texto-suave);
}
.paginacao-controles { display: flex; gap: .45rem; }

/* ── Estado vazio ── */
.estado-vazio {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--cinza-400);
}
.estado-vazio.pequeno { padding: 1.2rem .75rem; font-size: .85rem; }
.estado-vazio p { margin-top: .5rem; font-size: .85rem; }

/* ── Loading spinner ── */
.spinner {
  display: inline-block;
  width: 18px; height: 18px;
  border: 2.5px solid var(--cinza-200);
  border-top-color: var(--azul-claro);
  border-radius: 50%;
  animation: girar .6s linear infinite;
}
@keyframes girar { to { transform: rotate(360deg); } }

/* ── Utilitários ── */
.texto-alerta { color: var(--laranja) !important; font-weight: 700; }

/* ── Responsividade ── */
@media (max-width: 760px) {
  .cabecalho { padding: .75rem 1rem; align-items: flex-start; flex-direction: column; gap: .55rem; }
  .cabecalho-info { flex-wrap: wrap; }
  .pagina { padding: 1rem; }
  .tabela-logs thead th:nth-child(n+5),
  .tabela-logs tbody td:nth-child(n+5) { display: none; }
}
