:root{
  --bg:#0c0f12; --card:#141a1f; --card2:#0e1419; --bd:#222b33;
  --tx:#e6ebf0; --tx2:#9aa7b2; --azul:#2ba8e0; --azul-esc:#1f7fb0;
  --verde:#3fd07a; --verm:#e05656; --amar:#e0b030;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--tx);font-family:'Segoe UI',Arial,sans-serif;font-size:15px}
a{color:var(--azul)}
b{color:#fff}

/* ---- topo ---- */
.topo{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#0a0d10;border-bottom:1px solid var(--bd);position:sticky;top:0;z-index:5}
.topo-logo,.login-logo{font-weight:800;font-size:20px;letter-spacing:1px}
.logo-a{color:var(--azul)}
.logo-sub{color:var(--tx2);font-weight:600;font-size:.7em;letter-spacing:2px}
.logo-img{max-height:64px;width:auto;display:block;margin:0 auto}
.logo-img-topo{height:32px;width:auto;vertical-align:middle}
.topo-user{font-size:.9em;color:var(--tx2)}
.badge{padding:2px 8px;border-radius:10px;font-size:.78em;font-weight:bold}
.badge-accula{background:#13384d;color:var(--azul)}
.badge-cli{background:#2a2f17;color:var(--amar)}

.wrap{max-width:1080px;margin:0 auto;padding:18px}
.sec{font-size:1.05em;color:var(--azul);margin:22px 0 10px;font-weight:700}
.sec-sub{color:var(--tx2);font-weight:400;font-size:.85em}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px}
.kpis-sm{grid-template-columns:repeat(auto-fit,minmax(95px,1fr))}
.kpi{background:var(--card);border:1px solid var(--bd);border-radius:10px;padding:12px 14px}
.kpi-v{font-size:1.7em;font-weight:bold;line-height:1.1}
.kpi-l{font-size:.8em;color:var(--tx2);margin-top:2px}

/* ---- grid de máquinas ---- */
.grid-maq{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}
.maq{display:block;background:var(--card);border:1px solid var(--bd);border-radius:12px;padding:14px;text-decoration:none;color:var(--tx);transition:.15s}
.maq:hover{border-color:var(--azul);transform:translateY(-1px)}
.maq.off{opacity:.62}
.maq.alarme{border-color:#5a2a2a}
.maq-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.maq-nome{font-weight:bold}
.maq-sub{font-size:.8em;color:var(--tx2);margin-bottom:8px}
.maq-linha{display:flex;justify-content:space-between;font-size:.9em;margin-bottom:6px}
.maq-metr{display:flex;gap:12px;font-size:.85em;color:var(--tx2);flex-wrap:wrap}
.maq-visto{font-size:.75em;color:#6b7681;margin-top:8px}
.tag-alarme{color:var(--verm);font-weight:bold}

.dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.dot-on{background:var(--verde);box-shadow:0 0 6px var(--verde)}
.dot-off{background:#555}

/* ---- detalhe ---- */
.maq-cab{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.maq-cab h1{font-size:1.4em;margin:0}
.maq-cab-sub{font-size:.82em;color:var(--tx2);width:100%}
.card-graf{background:var(--card2);border:1px solid var(--bd);border-radius:10px;padding:10px;overflow:auto}
#graf{width:100%;max-width:920px;height:200px}
.duas-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:720px){.duas-col{grid-template-columns:1fr}}
.card-ev{background:var(--card2);border:1px solid var(--bd);border-radius:10px;padding:10px;font-family:Consolas,monospace;font-size:.85em;max-height:230px;overflow:auto}
.ev{padding:3px 0;border-bottom:1px solid #1c242b}
.ev-t{color:#6b7681;margin-right:8px}
.ev-vazio,.vazio,.ev-vazio{color:var(--tx2);padding:12px 0}
.vazio{text-align:center;padding:30px;background:var(--card);border:1px dashed var(--bd);border-radius:10px}

/* ---- login ---- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--card);border:1px solid var(--bd);border-radius:14px;padding:28px;width:330px;display:flex;flex-direction:column}
.login-logo{font-size:26px;text-align:center;margin-bottom:4px}
.login-tit{text-align:center;color:var(--tx2);font-size:.85em;margin-bottom:18px}
.login-card label{font-size:.82em;color:var(--tx2);margin:8px 0 4px}
.login-card input{background:var(--card2);border:1px solid var(--bd);border-radius:8px;padding:10px;color:var(--tx);font-size:1em}
.login-card button{margin-top:18px;background:var(--azul);border:0;border-radius:8px;padding:11px;color:#06222f;font-weight:bold;font-size:1em;cursor:pointer}
.login-card button:hover{background:#4cbef0}
.login-erro{background:#3a1c1c;border:1px solid #5a2a2a;color:#f1a9a9;border-radius:8px;padding:8px;font-size:.85em;margin-bottom:10px;text-align:center}
.login-rod{text-align:center;color:#6b7681;font-size:.75em;margin-top:16px}
