/* ===== IdeiaBot Backups — tema escuro ===== */
:root {
  --bg: #0f1115;
  --bg-2: #161922;
  --bg-3: #1d2230;
  --linha: #262b3a;
  --txt: #e6e9f2;
  --txt-fraco: #8b91a8;
  --txt-mt-fraco: #5b6075;
  --acc: #FF6B35;
  --ok: #10b981;
  --warn: #f59e0b;
  --err: #ef4444;
  --info: #3b82f6;
  --sombra: 0 6px 24px rgba(0,0,0,.35);
  --raio: 12px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--txt);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.4;
}

input, button, select, textarea {
  font: inherit;
  color: inherit;
}

button { cursor: pointer; }

/* ===== LOGIN ===== */
.tela-login {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background:
    radial-gradient(800px 600px at 20% 10%, rgba(255,107,53,.08), transparent 60%),
    radial-gradient(700px 500px at 80% 90%, rgba(59,130,246,.06), transparent 60%),
    var(--bg);
}

.login-card {
  width: min(380px, 92vw);
  background: var(--bg-2);
  border: 1px solid var(--linha);
  border-radius: 16px;
  padding: 28px 28px 18px;
  box-shadow: var(--sombra);
}

.login-cabecalho { text-align: center; margin-bottom: 18px; }
.login-logo { font-size: 40px; }
.login-card h1 { margin: 6px 0 4px; font-size: 20px; }
.login-sub { margin: 0; color: var(--txt-fraco); font-size: 13px; }

.login-form { display: grid; gap: 12px; margin-top: 14px; }
.login-form label { display: grid; gap: 4px; }
.login-form span { font-size: 12px; color: var(--txt-fraco); }
.login-form input {
  background: var(--bg-3);
  border: 1px solid var(--linha);
  border-radius: 8px;
  padding: 10px 12px;
  outline: none;
  transition: border-color .15s;
}
.login-form input:focus { border-color: var(--acc); }

.btn-primario {
  margin-top: 6px;
  background: var(--acc);
  border: 0;
  color: #fff;
  font-weight: 600;
  padding: 11px;
  border-radius: 8px;
  transition: filter .15s;
}
.btn-primario:hover { filter: brightness(1.1); }

.erro {
  background: rgba(239, 68, 68, .12);
  color: #fecaca;
  border: 1px solid rgba(239,68,68,.3);
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 13px;
}

.login-rodape {
  margin-top: 18px;
  text-align: center;
  color: var(--txt-mt-fraco);
  font-size: 11px;
}

/* ===== DASHBOARD ===== */
.tela-dashboard { padding-bottom: 60px; }

.topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--linha);
  position: sticky; top: 0; z-index: 5;
}
.topo-esq { display: flex; align-items: center; gap: 10px; }
.topo-logo { font-size: 22px; }
.topo h1 { margin: 0; font-size: 17px; }
.topo-versao {
  font-size: 11px;
  color: var(--txt-mt-fraco);
  background: var(--bg-3);
  padding: 2px 8px;
  border-radius: 999px;
}

.topo-dir { display: flex; gap: 8px; align-items: center; }

.agendamento {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg-3);
  border: 1px solid var(--linha);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--txt-fraco);
}
.agendamento b { color: var(--txt); font-weight: 600; }
.agendamento.pausado {
  background: rgba(245,158,11,.12);
  border-color: rgba(245,158,11,.35);
  color: #fcd34d;
}
.agendamento.pausado b { color: #fcd34d; }
.ag-icone { font-size: 14px; }

@media (max-width: 1100px) {
  .agendamento { display: none; }
}
.topo-dir input[type="search"] {
  background: var(--bg-3);
  border: 1px solid var(--linha);
  border-radius: 8px;
  padding: 7px 10px;
  width: 220px;
  outline: none;
}
.topo-dir input:focus { border-color: var(--acc); }

.btn-secundario {
  background: var(--bg-3);
  border: 1px solid var(--linha);
  color: var(--txt);
  border-radius: 8px;
  padding: 7px 12px;
  transition: background .15s, border-color .15s;
}
.btn-secundario:hover { background: var(--linha); border-color: #353b50; }

/* Resumo */
.resumo {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 12px;
  padding: 18px 22px 6px;
}
.resumo-item {
  background: var(--bg-2);
  border: 1px solid var(--linha);
  border-radius: var(--raio);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.resumo-item .lbl { font-size: 12px; color: var(--txt-fraco); }
.resumo-item .val { font-size: 22px; font-weight: 700; }
.resumo-item.ok .val { color: var(--ok); }
.resumo-item.warn .val { color: var(--warn); }
.resumo-item.err .val { color: var(--err); }
.resumo-item.destaque {
  background: linear-gradient(135deg, rgba(255,107,53,.18), rgba(255,107,53,.06));
  border-color: rgba(255,107,53,.35);
}
.resumo-item.destaque .val { color: var(--acc); }

@media (max-width: 1200px) {
  .resumo { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 800px) {
  .resumo { grid-template-columns: repeat(2, 1fr); }
  .topo-dir input { width: 140px; }
}

.conteudo { padding: 14px 22px; display: grid; gap: 22px; }

.carregando {
  padding: 40px;
  text-align: center;
  color: var(--txt-fraco);
}

/* Grupo / Categoria */
.grupo h2 {
  margin: 0 0 10px;
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--txt-fraco);
  display: flex; align-items: center; gap: 8px;
}
.grupo h2 .ponto {
  width: 10px; height: 10px; border-radius: 50%;
}
.grupo h2 .cont {
  margin-left: auto;
  font-size: 11px;
  font-weight: 600;
  background: var(--bg-3);
  color: var(--txt-fraco);
  padding: 2px 8px;
  border-radius: 999px;
}

.grade {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.grupo-vazio {
  grid-column: 1 / -1;
  text-align: center;
  padding: 20px;
  color: var(--txt-mt-fraco);
  font-size: 13px;
  font-style: italic;
}

/* Card de banco */
.card {
  background: var(--bg-2);
  border: 1px solid var(--linha);
  border-left: 4px solid var(--acc);
  border-radius: var(--raio);
  padding: 14px 16px;
  display: grid;
  gap: 8px;
  transition: transform .12s, border-color .12s, background .12s;
  cursor: pointer;
}
.card:hover { transform: translateY(-2px); background: #1a1e29; }

.card-cab {
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.card-cab-acoes { display: flex; align-items: center; gap: 8px; }

.btn-snapshot {
  background: transparent;
  border: 1px solid var(--linha);
  color: var(--info);
  width: 26px; height: 26px;
  border-radius: 6px;
  display: grid; place-items: center;
  font-size: 12px;
  transition: background .12s, border-color .12s;
}
.btn-snapshot:hover {
  background: rgba(59,130,246,.15);
  border-color: var(--info);
}
.btn-snapshot:disabled { cursor: wait; opacity: .7; }
.btn-snapshot.rodando { animation: pulsar 1.2s ease-in-out infinite; }
@keyframes pulsar {
  0%, 100% { opacity: 1; }
  50% { opacity: .55; }
}

.btn-toggle-skip {
  background: transparent;
  border: 1px solid var(--linha);
  color: var(--txt-fraco);
  width: 26px; height: 26px;
  border-radius: 6px;
  display: grid; place-items: center;
  font-size: 12px;
  transition: background .12s, border-color .12s, color .12s;
}
.btn-toggle-skip:hover {
  background: var(--bg-3);
  border-color: var(--acc);
  color: var(--txt);
}

.card.card-skip {
  opacity: .55;
  border-left-color: var(--txt-mt-fraco) !important;
}
.card.card-skip:hover { opacity: 0.85; }

.tag.skip {
  background: rgba(107, 114, 128, .18);
  color: #cbd5e1;
  border-color: rgba(107,114,128,.4);
}
.card-nome {
  font-weight: 600;
  font-size: 15px;
  word-break: break-all;
}
.card-status {
  width: 12px; height: 12px; border-radius: 50%;
  flex-shrink: 0;
}
.card-status.ok   { background: var(--ok);   box-shadow: 0 0 8px var(--ok); }
.card-status.warn { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.card-status.err  { background: var(--err);  box-shadow: 0 0 8px var(--err); }
.card-status.none { background: var(--txt-mt-fraco); }

.card-linha {
  display: flex; justify-content: space-between;
  font-size: 12px; color: var(--txt-fraco);
}
.card-linha b { color: var(--txt); font-weight: 600; }

.card-paths {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--linha);
  display: grid; gap: 3px;
}
.path-linha {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px;
  color: var(--txt-fraco);
  overflow: hidden;
}
.path-icon { flex-shrink: 0; font-size: 10px; }
.path-linha code {
  background: var(--bg-3);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10.5px;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1; min-width: 0;
}

.card-rodape {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 4px;
}
.tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--bg-3);
  color: var(--txt-fraco);
  border: 1px solid var(--linha);
}
.tag.ok { background: rgba(16,185,129,.12); color: #6ee7b7; border-color: rgba(16,185,129,.3); }
.tag.warn { background: rgba(245,158,11,.12); color: #fcd34d; border-color: rgba(245,158,11,.3); }
.tag.err { background: rgba(239,68,68,.12); color: #fca5a5; border-color: rgba(239,68,68,.3); }
.tag.info { background: rgba(59,130,246,.12); color: #93c5fd; border-color: rgba(59,130,246,.3); }

/* Modal */
.modal {
  position: fixed; inset: 0;
  display: grid;
  place-items: center;
  z-index: 20;
}
.modal[hidden] { display: none !important; }

/* Modal de confirmação */
.caixa-confirm { width: min(440px, 92vw); }
.modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid var(--linha);
}
.confirm-msg {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--txt);
  white-space: pre-wrap;
}
.confirm-msg b { color: var(--txt); }
.confirm-msg code {
  background: var(--bg-3);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: ui-monospace, monospace;
  font-size: 12.5px;
}

.confirm-input-bloco { margin-top: 14px; }
.confirm-input-label {
  display: block;
  font-size: 12px;
  color: var(--txt-fraco);
  margin-bottom: 6px;
}
.confirm-input {
  width: 100%;
  background: var(--bg-3);
  border: 1px solid var(--linha);
  border-radius: 8px;
  padding: 9px 12px;
  outline: none;
  font-family: ui-monospace, monospace;
  transition: border-color .15s;
}
.confirm-input:focus { border-color: var(--acc); }
.confirm-erro {
  margin-top: 6px;
  font-size: 12px;
  color: #fca5a5;
}

.btn-primario-modal {
  background: var(--acc);
  border: 0;
  color: #fff;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 8px;
  transition: filter .15s;
}
.btn-primario-modal:hover { filter: brightness(1.1); }
.btn-primario-modal.perigo {
  background: #dc2626;
}
.btn-primario-modal.perigo:hover { background: #ef4444; }
.modal-fundo {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.55);
}
.modal-caixa {
  position: relative;
  background: var(--bg-2);
  border: 1px solid var(--linha);
  border-radius: 14px;
  width: min(640px, 92vw);
  max-height: 80vh;
  display: flex; flex-direction: column;
  box-shadow: var(--sombra);
}
.modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--linha);
}
.modal-header h2 { margin: 0; font-size: 16px; }
.btn-icone {
  background: transparent; border: 0; color: var(--txt-fraco);
  font-size: 18px; padding: 4px 8px; border-radius: 6px;
}
.btn-icone:hover { background: var(--bg-3); color: var(--txt); }

.modal-corpo {
  padding: 14px 18px;
  overflow: auto;
}
.modal-corpo table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.modal-corpo th, .modal-corpo td {
  text-align: left;
  padding: 8px 6px;
  border-bottom: 1px solid var(--linha);
}
.modal-corpo th { color: var(--txt-fraco); font-weight: 600; font-size: 11px; }
.modal-corpo .empty {
  text-align: center; padding: 30px; color: var(--txt-fraco);
}

.modal-corpo .bloco-h {
  margin: 16px 0 8px;
  font-size: 12px;
  letter-spacing: .05em;
  color: var(--txt-fraco);
  text-transform: none;
  font-weight: 600;
}
.modal-corpo .bloco-h:first-child { margin-top: 0; }

.tabela-paths code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11.5px;
  background: var(--bg-3);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--txt);
  word-break: break-all;
}
.tabela-paths td { vertical-align: top; padding: 6px; }
.tabela-paths tr.vol td { color: var(--info); }

.info-vazio {
  color: var(--txt-mt-fraco);
  font-size: 12px;
  margin: 6px 0 0;
  font-style: italic;
}

.btn-restaurar {
  background: rgba(239, 68, 68, .12);
  color: #fca5a5;
  border: 1px solid rgba(239, 68, 68, .35);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11.5px;
  font-weight: 600;
  transition: background .12s, color .12s;
}
.btn-restaurar:hover {
  background: rgba(239, 68, 68, .25);
  color: #fff;
}

.restore-status {
  padding: 10px 12px;
  border-radius: 8px;
  margin-bottom: 12px;
  font-size: 13px;
  background: var(--bg-3);
  border: 1px solid var(--linha);
}
.restore-status code {
  background: rgba(255,255,255,.06);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: ui-monospace, monospace;
}
.restore-status.sucesso {
  background: rgba(16,185,129,.12);
  border-color: rgba(16,185,129,.35);
  color: #6ee7b7;
}
.restore-status.erro {
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.35);
  color: #fca5a5;
}
