:root{
  --bg:#0f0f0f; --surface:#1a1a1a; --card:#222; --border:#2e2e2e;
  --primary:#e63946; --primary2:#c1121f; --text:#f1f1f1; --muted:#888;
  --green:#2ecc71; --yellow:#f39c12; --blue:#3498db;
}
*{box-sizing:border-box}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:"Segoe UI",system-ui,-apple-system,sans-serif; font-size:15px; line-height:1.5;
}
a{color:var(--primary); text-decoration:none}
a:hover{text-decoration:underline}

header.topo{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px; background:var(--surface); border-bottom:1px solid var(--border);
}
header.topo .marca{font-weight:700; font-size:18px}
header.topo .marca b{color:var(--primary)}
header.topo nav a{margin-left:18px; color:var(--text); font-size:14px}
header.topo nav a.sair{color:var(--muted)}
.empresa-tag{color:var(--muted); font-size:13px; margin-left:14px}

.container{max-width:980px; margin:0 auto; padding:26px 22px}
.estreito{max-width:420px}

h1{font-size:22px; margin:0 0 4px}
h2{font-size:16px; color:var(--primary); margin:26px 0 10px; border-bottom:1px solid var(--border); padding-bottom:6px}
.sub{color:var(--muted); font-size:13px; margin:0 0 18px}

.card{background:var(--card); border:1px solid var(--border); border-radius:10px; padding:20px; margin-bottom:16px}

label{display:block; font-size:13px; color:var(--muted); margin:12px 0 4px}
input,select{
  width:100%; padding:10px 12px; background:var(--surface); color:var(--text);
  border:1px solid var(--border); border-radius:7px; font-size:14px; outline:none;
}
input:focus,select:focus{border-color:var(--primary)}

.btn{
  display:inline-block; background:var(--primary); color:#fff; border:none; border-radius:7px;
  padding:11px 20px; font-size:14px; font-weight:600; cursor:pointer;
}
.btn:hover{background:var(--primary2); text-decoration:none}
.btn.bloco{width:100%; padding:13px}
.btn.cinza{background:#333}
.btn.cinza:hover{background:#444}
.btn.peq{padding:6px 12px; font-size:12px}

.flash{padding:11px 14px; border-radius:7px; margin-bottom:16px; font-size:14px}
.flash.ok{background:rgba(46,204,113,.12); color:var(--green); border:1px solid rgba(46,204,113,.3)}
.flash.err{background:rgba(230,57,70,.12); color:var(--primary); border:1px solid rgba(230,57,70,.35)}

table{width:100%; border-collapse:collapse; font-size:13px; margin-top:8px}
th,td{text-align:left; padding:9px 10px; border-bottom:1px solid var(--border)}
th{color:var(--primary); font-weight:600}
td .pill{font-size:11px; padding:2px 8px; border-radius:20px}
.pill.admin{background:rgba(243,156,18,.15); color:var(--yellow)}
.pill.on{background:rgba(46,204,113,.15); color:var(--green)}
.pill.off{background:rgba(136,136,136,.15); color:var(--muted)}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.grid2 .full{grid-column:1/-1}
.inline-form{display:inline}
.acoes{display:flex; gap:6px; align-items:center}
.acoes input[type=text]{width:120px; padding:6px 8px; font-size:12px}
.dica{color:var(--muted); font-size:12px; margin-top:6px}
.logo-centro{text-align:center; margin-bottom:22px}
.logo-centro .marca{font-size:24px; font-weight:700}
.logo-centro .marca b{color:var(--primary)}

/* ── Histórico / comparação ── */
.barra-linha{display:flex; align-items:center; gap:12px; margin:8px 0}
.barra-ref{width:110px; font-size:13px; color:var(--text); flex-shrink:0}
.barra-trilho{flex:1; background:var(--surface); border-radius:6px; height:22px; overflow:hidden; border:1px solid var(--border)}
.barra-fill{height:100%; background:linear-gradient(90deg,var(--primary2),var(--primary)); border-radius:6px}
.barra-val{width:120px; text-align:right; font-size:13px; color:var(--muted); flex-shrink:0}
.delta{font-size:11px; font-weight:600; margin-left:6px; white-space:nowrap}
.delta.up{color:var(--green)}
.delta.down{color:var(--primary)}
.muted-data{color:var(--muted); font-size:11px}

/* ── Dashboard ── */
.kpi-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:8px}
.kpi{background:var(--card); border:1px solid var(--border); border-radius:10px; padding:16px}
.kpi .lbl{color:var(--muted); font-size:12px}
.kpi .val{font-size:22px; font-weight:700; margin:4px 0}
.kpi .sub{color:var(--muted); font-size:11px}
.v-blue{color:var(--blue)} .v-green{color:var(--green)} .v-yellow{color:var(--yellow)}
.v-red{color:var(--primary)} .v-text{color:var(--text)}
.mini-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:16px 0}
.mini h3{color:var(--primary); font-size:14px; margin:0 0 8px}
.mini .row{display:flex; justify-content:space-between; padding:3px 0; font-size:13px; border:none}
.acoes-dash{display:flex; gap:10px; margin-top:8px}
@media (max-width:760px){
  .kpi-grid, .mini-grid{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
}

/* ── Workspace (barra lateral / abas) ── */
.container.amplo{max-width:1180px}
.ws{display:flex; gap:22px; align-items:flex-start}
.ws-side{width:190px; flex-shrink:0}
.ws-side a{display:block; padding:11px 14px; border-radius:8px; color:var(--text);
  font-size:14px; margin-bottom:4px; border:1px solid transparent}
.ws-side a:hover{background:var(--surface); text-decoration:none}
.ws-side a.ativo{background:var(--primary); color:#fff; font-weight:600}
.ws-csv{margin-top:18px; padding:12px; background:var(--surface);
  border:1px solid var(--border); border-radius:8px; font-size:12px; color:var(--muted); word-break:break-all}
.ws-csv a{display:block; margin-top:8px; font-size:13px}
.ws-main{flex:1; min-width:0}
@media (max-width:760px){
  .ws{flex-direction:column}
  .ws-side{width:100%; display:flex; flex-wrap:wrap; gap:6px}
  .ws-side a{margin:0; flex:1; text-align:center; min-width:120px}
  .ws-csv{width:100%}
}
