:root {
    --fundo: #0f1115;
    --cartao: #1a1d24;
    --cartao-claro: #232730;
    --texto: #e6e8ec;
    --texto-fraco: #9aa0ab;
    --borda: #2c313b;
    --azul: #3b82f6;
    --verde: #22c55e;
    --vermelho: #ef4444;
    --amarelo: #f59e0b;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: var(--fundo);
    color: var(--texto);
    line-height: 1.5;
}

/* ---------- Login ---------- */
.tela-login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 1rem;
}
.caixa-login {
    width: 100%;
    max-width: 340px;
    background: var(--cartao);
    border: 1px solid var(--borda);
    border-radius: 14px;
    padding: 2rem 1.5rem;
    text-align: center;
}
.caixa-login h1 { font-size: 1.25rem; margin: 0 0 1.25rem; }
.caixa-login input,
.caixa-login button {
    width: 100%;
    padding: 0.85rem 1rem;
    border-radius: 10px;
    border: 1px solid var(--borda);
    font-size: 1rem;
    margin-bottom: 0.75rem;
}
.caixa-login input { background: var(--cartao-claro); color: var(--texto); }
.caixa-login button {
    background: var(--azul); color: #fff; border: none; font-weight: 600; cursor: pointer;
}
.aviso-erro { color: var(--vermelho); font-size: 0.9rem; margin: 0 0 0.75rem; }

/* ---------- Topo ---------- */
.topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--borda);
    position: sticky; top: 0;
    background: var(--fundo);
}
.topo h1 { font-size: 1.15rem; margin: 0; }
.contador {
    font-size: 0.75rem; color: var(--texto-fraco);
    background: var(--cartao-claro); padding: 0.15rem 0.5rem; border-radius: 999px; margin-left: 0.4rem;
}
.topo a { color: var(--texto-fraco); text-decoration: none; font-size: 0.9rem; }
.topo a:hover { color: var(--texto); }

/* ---------- Filtros ---------- */
.filtros { display: flex; gap: 0.6rem; padding: 0.9rem 1.25rem; flex-wrap: wrap; }
.filtros select {
    flex: 1; min-width: 140px;
    background: var(--cartao-claro); color: var(--texto);
    border: 1px solid var(--borda); border-radius: 8px; padding: 0.6rem 0.7rem; font-size: 0.95rem;
}

/* ---------- Lista ---------- */
.lista-erros { list-style: none; margin: 0; padding: 0 1.25rem 2rem; }
.cartao {
    background: var(--cartao); border: 1px solid var(--borda);
    border-radius: 12px; margin-bottom: 0.75rem; overflow: hidden;
}
.cartao.resolvido { opacity: 0.55; }
.cartao a { display: block; padding: 0.9rem 1rem; color: inherit; text-decoration: none; }
.linha-topo { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; }
.projeto { font-size: 0.8rem; color: var(--texto-fraco); }
.ocorrencias { margin-left: auto; font-size: 0.8rem; color: var(--texto-fraco); }
.mensagem { margin: 0 0 0.4rem; font-size: 0.95rem; word-break: break-word; }
.meta { display: flex; justify-content: space-between; font-size: 0.78rem; color: var(--texto-fraco); }
.vazio { text-align: center; color: var(--texto-fraco); padding: 3rem 1rem; }

/* ---------- Badges ---------- */
.badge {
    display: inline-block; font-size: 0.7rem; font-weight: 700;
    padding: 0.15rem 0.5rem; border-radius: 6px; text-transform: uppercase; letter-spacing: 0.02em;
    background: var(--cartao-claro); color: var(--texto-fraco);
}
.nivel-fatal, .nivel-exception, .nivel-parse, .nivel-core-error, .nivel-compile-error,
.nivel-user-error { background: rgba(239,68,68,0.15); color: #fca5a5; }
.nivel-warning, .nivel-user-warning { background: rgba(245,158,11,0.15); color: #fcd34d; }
.nivel-notice, .nivel-user-notice, .nivel-deprecated, .nivel-user-deprecated { background: rgba(59,130,246,0.15); color: #93c5fd; }

/* ---------- Detalhe ---------- */
.detalhe { padding: 1.25rem; max-width: 800px; margin: 0 auto; }
.detalhe h1 { font-size: 1.1rem; margin: 0.6rem 0 1.2rem; word-break: break-word; }
.detalhe h2 { font-size: 0.9rem; color: var(--texto-fraco); margin: 1.5rem 0 0.5rem; }
.dados { display: grid; grid-template-columns: auto 1fr; gap: 0.4rem 1rem; font-size: 0.9rem; }
.dados dt { color: var(--texto-fraco); }
.dados dd { margin: 0; word-break: break-word; }
.trace {
    background: #0a0c10; border: 1px solid var(--borda); border-radius: 10px;
    padding: 1rem; overflow-x: auto; font-size: 0.8rem; line-height: 1.6; white-space: pre-wrap; word-break: break-word;
}
.acoes { display: flex; gap: 0.6rem; margin-top: 1.5rem; flex-wrap: wrap; }
.btn {
    padding: 0.7rem 1.1rem; border-radius: 9px; border: 1px solid var(--borda);
    background: var(--cartao-claro); color: var(--texto); font-size: 0.92rem; font-weight: 600; cursor: pointer;
}
.btn-ok { background: var(--verde); border-color: var(--verde); color: #06240f; }
.btn-perigo { background: transparent; border-color: var(--vermelho); color: #fca5a5; }

@media (min-width: 640px) {
    .lista-erros { padding-left: 2rem; padding-right: 2rem; }
}
