:root{
  --bg:#0a0e17; --bg2:#070a11; --panel:#0f1524; --panel2:#131b2e; --line:#1c2538;
  --text:#e2e8f2; --dim:#8492a8; --dim2:#5a6880;
  --blue:#3b82f6; --violet:#8b5cf6; --green:#22c55e; --amber:#f59e0b; --red:#ef4444; --cyan:#22d3ee;
  --sans:"Inter",system-ui,sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box} html,body{margin:0}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.5}
a{color:var(--blue);text-decoration:none}
button{font:inherit;cursor:pointer}
.mono{font-family:var(--mono)}

/* ===== shell ===== */
.shell{display:grid;grid-template-columns:228px 1fr;min-height:100vh}
@media(max-width:960px){.shell{grid-template-columns:1fr}.sidebar{display:none}}

/* ===== sidebar ===== */
.sidebar{background:var(--bg2);border-right:1px solid var(--line);display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto}
.brand{display:flex;align-items:center;gap:10px;padding:18px 16px 14px;border-bottom:1px solid var(--line)}
.brand-logo{width:34px;height:34px;border-radius:9px;background:var(--panel2);border:1px solid var(--line);
  color:var(--blue);display:flex;align-items:center;justify-content:center}
.brand b{font-size:16.5px;font-weight:800;letter-spacing:.2px}
.brand .ver{font:600 10px var(--mono);background:#1b2a4a;color:var(--blue);border-radius:10px;padding:2px 7px;margin-left:2px}
.side-sec{font:700 10px var(--sans);letter-spacing:1.6px;color:var(--dim2);padding:16px 18px 6px;text-transform:uppercase}
.side-item{display:flex;align-items:center;gap:11px;margin:1px 8px;padding:8px 11px;border-radius:8px;
  color:var(--dim);font-size:13.5px;font-weight:500;border:none;background:none;width:calc(100% - 16px);text-align:left}
.side-item:hover{background:var(--panel);color:var(--text)}
.side-item.on{background:linear-gradient(90deg,#14213f,#101a30);color:var(--text);
  box-shadow:inset 3px 0 0 var(--blue)}
.side-item .ic{width:18px;text-align:center;font-size:15px;opacity:.9}
.side-item .bdg{margin-left:auto;font:600 10px var(--mono);border-radius:9px;padding:1px 7px}
.bdg-num{background:#16203a;color:var(--blue)}
.bdg-beta{background:var(--panel2);color:var(--dim2);border:1px solid var(--line)}
.bdg-novo{background:#16203a;color:var(--blue)}
.side-user{margin-top:auto;border-top:1px solid var(--line);padding:13px 16px;display:flex;gap:10px;align-items:center}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);
  color:var(--blue);display:flex;align-items:center;justify-content:center;font:700 11.5px var(--sans)}
.side-user b{font-size:13px;display:block}
.side-user span{font-size:11px;color:var(--dim)}

/* ===== topbar ===== */
.top{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(10,14,23,.92);backdrop-filter:blur(8px);z-index:40}
.top h1{font-size:19px;margin:0;font-weight:700}
.top .sub{font-size:12px;color:var(--dim)}
.search{margin-left:auto;display:flex;align-items:center;gap:8px;background:var(--panel);
  border:1px solid var(--line);border-radius:9px;padding:7px 12px;min-width:220px;color:var(--dim2);font-size:12.5px}
.search input{background:none;border:none;outline:none;color:var(--text);font:inherit;width:100%}
.icon-btn{position:relative;width:36px;height:36px;border-radius:9px;background:var(--panel);
  border:1px solid var(--line);color:var(--dim);font-size:15px}
.icon-btn:hover{color:var(--text);border-color:var(--blue)}
.icon-btn .pip{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;
  font:700 9.5px var(--sans);border-radius:9px;padding:1px 5px}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}

/* ===== conteúdo ===== */
.content{padding:20px 24px 60px;max-width:1420px}
.grid{display:grid;gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:18px 20px}
.card h3{margin:0 0 14px;font-size:14.5px;font-weight:700}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-head h3{margin:0}
.link-sm{font-size:12px;color:var(--blue);background:none;border:none}

/* KPI strip */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:0;background:var(--panel);
  border:1px solid var(--line);border-radius:13px;overflow:hidden;margin-bottom:16px}
.kpi{padding:16px 18px;border-right:1px solid var(--line);display:flex;gap:12px;align-items:flex-start}
.kpi:last-child{border-right:none}
.kpi .kic{width:38px;height:38px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);
  color:var(--dim);display:flex;align-items:center;justify-content:center;flex:none}
.kpi small{display:block;font-size:11.5px;color:var(--dim);margin-bottom:2px}
.kpi b{font-size:16px;font-weight:700}
.kpi b em{font-style:normal;color:var(--dim);font-weight:500;font-size:13px}
.kpi .kfoot{font-size:11px;color:var(--dim2);margin-top:2px}
.kbar{height:5px;background:var(--line);border-radius:3px;margin-top:7px;overflow:hidden;width:120px}
.kbar i{display:block;height:100%;border-radius:3px}

/* tabela */
table{width:100%;border-collapse:collapse;font-size:12.5px}
th{text-align:left;font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--dim2);
  padding:7px 10px;border-bottom:1px solid var(--line);font-weight:600}
td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#111a2e}
.st{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px}
.st i{width:7px;height:7px;border-radius:50%}
.st.run{color:var(--green)} .st.run i{background:var(--green)}
.st.stop{color:var(--dim2)} .st.stop i{background:var(--dim2)}
.st.part{color:var(--amber)} .st.part i{background:var(--amber)}

/* botões */
.btn{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:8px;
  padding:7px 13px;font-size:12.5px;font-weight:600}
.btn:hover{border-color:var(--blue)}
.btn.pri{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.pri:hover{background:#2f6fdd}
.btn.dgr{background:transparent;border-color:var(--red);color:var(--red)}
.btn.dgr:hover{background:var(--red);color:#fff}
.btn.sm{padding:4px 9px;font-size:11.5px}
.input{background:var(--bg2);border:1px solid var(--line);border-radius:8px;color:var(--text);
  padding:9px 11px;font:500 12.5px var(--mono);width:100%}
.input:focus{outline:none;border-color:var(--blue)}
label.fld{display:block;font-size:11.5px;color:var(--dim);margin-bottom:12px}
label.fld .input{margin-top:5px}

/* quick actions */
.qgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.qbtn{background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:14px 8px;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text);font-size:11.5px;font-weight:600}
.qbtn:hover{border-color:var(--blue);background:#152039}
.qbtn .qic{width:36px;height:36px;border-radius:9px;background:var(--bg2);border:1px solid var(--line);
  color:var(--dim);display:flex;align-items:center;justify-content:center}
.qbtn:hover .qic{color:var(--blue);border-color:var(--blue)}

/* listas kv / atividade / alertas */
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.kv:last-child{border-bottom:none}
.kv span{color:var(--dim)} .kv b{font-weight:600;font-family:var(--mono);font-size:12px}
.act{display:flex;gap:11px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.act:last-child{border-bottom:none}
.act .aic{width:30px;height:30px;border-radius:8px;background:var(--panel2);border:1px solid var(--line);
  color:var(--dim);display:flex;align-items:center;justify-content:center;flex:none}
.act p{margin:0;font-size:12.5px}
.act time{margin-left:auto;font-size:11px;color:var(--dim2);white-space:nowrap}
.alert{display:flex;gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--line);
  border-radius:10px;margin-bottom:9px;font-size:12.5px}
.alert time{margin-left:auto;font:500 10.5px var(--mono);color:var(--dim2)}

/* donut + distribuição */
.donut-wrap{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.legend{font-size:12.5px}
.legend div{display:flex;align-items:center;gap:8px;margin:5px 0}
.legend i{width:9px;height:9px;border-radius:3px}
.legend b{margin-left:auto;font-family:var(--mono);font-size:11.5px;padding-left:18px}
.distbar{display:flex;height:10px;border-radius:6px;overflow:hidden;margin:10px 0 8px}
.dist-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--dim)}
.dist-legend span{display:flex;gap:6px;align-items:center}
.dist-legend i{width:8px;height:8px;border-radius:3px}
.dist-legend b{font-family:var(--mono);font-weight:500}

/* chart */
.chart-legend{display:flex;gap:16px;font-size:12px;color:var(--dim);margin-bottom:6px}
.chart-legend span{display:flex;gap:6px;align-items:center}
.chart-legend i{width:8px;height:8px;border-radius:50%}
.selbox{background:var(--panel2);border:1px solid var(--line);color:var(--dim);border-radius:8px;
  padding:5px 10px;font-size:11.5px}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(4,7,12,.75);z-index:999;display:flex;
  align-items:center;justify-content:center;padding:22px}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px;
  width:min(720px,100%);max-height:85vh;overflow:auto}
.logbox{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:12px 14px;
  font:12px/1.6 var(--mono);color:#9fb3cf;max-height:50vh;overflow:auto;white-space:pre-wrap;word-break:break-word}
.chk{display:flex;gap:8px;align-items:center;font-size:12.5px;color:var(--dim);margin:10px 0}
.note{font-size:11.5px;color:var(--dim2)}
.danger-t{color:var(--red)}

/* placeholder v-next */
.soon{border:1px dashed var(--line);border-radius:13px;padding:44px 24px;text-align:center;color:var(--dim)}
.soon h2{color:var(--text);margin:0 0 6px;font-size:17px}
.soon .tag{display:inline-block;font:600 10px var(--mono);background:#2a1745;color:#c084fc;
  border-radius:10px;padding:3px 9px;margin-bottom:14px}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:
  radial-gradient(700px 400px at 70% 20%,#101a35 0%,var(--bg) 60%)}
.login{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:34px;width:min(390px,92vw)}
.login .brand{border:none;padding:0 0 6px}
.login .sub{color:var(--dim);font-size:12px;font-family:var(--mono);margin-bottom:22px}
.login .btn{width:100%;padding:11px;font-size:13.5px;margin-top:4px}
.login-msg{min-height:18px;color:var(--red);font-size:12px;text-align:center;margin-top:10px}

/* demo bar */
.demo-bar{position:fixed;bottom:12px;left:50%;transform:translateX(-50%);z-index:9999;
  background:var(--panel2);border:1px solid var(--violet);border-radius:30px;padding:7px 15px;
  display:flex;gap:9px;align-items:center;font:500 11px var(--mono);color:var(--dim);
  box-shadow:0 10px 34px rgba(0,0,0,.55);flex-wrap:wrap;justify-content:center;max-width:94vw}
.demo-bar b{color:#c084fc}
.demo-bar button{background:var(--line);border:none;color:var(--text);border-radius:15px;padding:4px 11px;font:inherit}
.demo-bar button:hover{background:var(--violet);color:#fff}

.side-item .ic{display:flex;align-items:center;justify-content:center;color:inherit}
.icon-btn{display:inline-flex;align-items:center;justify-content:center}
.search svg{flex:none;color:var(--dim2)}
.al-amber{color:var(--amber)} .al-red{color:var(--red)} .al-dim{color:var(--dim2)}
.alert>span{display:flex;align-items:center}
.tpl-ic{width:38px;height:38px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);
  color:var(--dim);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
footer.copy{padding:22px;text-align:center;color:var(--dim2);font-size:11.5px;border-top:1px solid var(--line);margin-top:26px}
