:root{
  --bg:#0a0e14; --panel:#111824; --panel2:#0d141e; --line:#1d2a3a;
  --txt:#e6edf3; --muted:#7d8da0; --green:#00ff95; --blue:#00d4ff;
  --red:#ff3b6b; --yellow:#ffd23f; --purple:#a06bff;
  --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font-family:'Segoe UI',Inter,system-ui,Arial,sans-serif;line-height:1.5}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1180px;margin:0 auto;padding:24px 18px 80px}

header.top{display:flex;align-items:center;gap:14px;padding:18px 0;
  border-bottom:1px solid var(--line);margin-bottom:26px}
.logo{font-size:22px;font-weight:800;letter-spacing:.5px}
.logo b{color:var(--green)}
.logo .pol{color:var(--blue)}
.tagline{color:var(--muted);font-size:13px}
.spacer{flex:1}

.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:0;
  border-radius:10px;padding:10px 16px;font-weight:700;font-size:14px;
  background:var(--line);color:var(--txt);transition:.15s}
.btn:hover{filter:brightness(1.15)}
.btn.green{background:linear-gradient(135deg,#00ff95,#00c2ff);color:#04121a}
.btn.blue{background:linear-gradient(135deg,#00d4ff,#a06bff);color:#04121a}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
.btn.danger{background:transparent;border:1px solid var(--red);color:var(--red)}
.btn.sm{padding:7px 12px;font-size:12.5px;border-radius:8px}

h2.section{font-size:14px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--muted);margin:34px 0 14px}

.grid{display:grid;gap:14px}
.grid.clientes{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.grid.ints{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;transition:.15s}
.card:hover{border-color:#33506e;transform:translateY(-2px)}
.card .nome{font-size:17px;font-weight:700;margin:0 0 4px}
.card .meta{color:var(--muted);font-size:13px}
.tag{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.5px}
.tag.empresa{background:rgba(0,212,255,.15);color:var(--blue)}
.tag.politico{background:rgba(160,107,255,.18);color:var(--purple)}
.card .ger{margin-top:10px;font-size:12px;color:var(--muted)}

.int{display:flex;flex-direction:column;gap:6px;background:var(--panel2);
  border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer}
.int:hover{border-color:#33506e}
.int .ic{font-size:24px}
.int .n{font-weight:700;font-size:14px}
.int .d{color:var(--muted);font-size:12px}

/* form / modal */
.overlay{position:fixed;inset:0;background:rgba(3,7,12,.7);display:none;
  align-items:flex-start;justify-content:center;z-index:50;overflow:auto;padding:40px 16px}
.overlay.on{display:flex}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  width:100%;max-width:640px;padding:24px}
.modal h3{margin:0 0 16px}
label{display:block;font-size:12.5px;color:var(--muted);margin:12px 0 5px;font-weight:600}
input,select,textarea{width:100%;background:var(--panel2);border:1px solid var(--line);
  color:var(--txt);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit}
textarea{min-height:70px;resize:vertical}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}

/* cliente page */
.back{color:var(--muted);font-size:13px}
.profile{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin-bottom:18px}
.profile h1{margin:0 0 6px;font-size:24px}
.profile .pgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:14px;margin-top:16px}
.profile .f{font-size:13px}
.profile .f .k{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px}
.profile .f .v{margin-top:2px}

.genbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:6px 0 20px}
.genbar input{flex:1;min-width:240px}

.plano{display:grid;gap:16px}
.block{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.block h4{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--green)}
.block.pol h4{color:var(--purple)}
.block ul{margin:6px 0;padding-left:20px}
.block li{margin:4px 0}
.kv{margin:8px 0}
.kv .k{color:var(--blue);font-weight:700;font-size:13px}
.pill{display:inline-block;background:var(--panel2);border:1px solid var(--line);
  border-radius:18px;padding:4px 11px;margin:3px 4px 3px 0;font-size:12.5px}
.item{border-left:3px solid var(--green);padding:8px 0 8px 14px;margin:10px 0;background:rgba(0,255,149,.03)}
.item .t{font-weight:700}
.item .s{color:var(--muted);font-size:13px}
.muted{color:var(--muted)}
.spin{display:inline-block;width:16px;height:16px;border:2px solid #ffffff44;
  border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;vertical-align:-3px}
@keyframes sp{to{transform:rotate(360deg)}}
.hist{font-size:12.5px;color:var(--muted)}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--panel);
  border:1px solid var(--line);padding:12px 18px;border-radius:10px;display:none;z-index:80}
.toast.on{display:block}
.empty{color:var(--muted);text-align:center;padding:40px;border:1px dashed var(--line);border-radius:var(--radius)}
.tags{margin-top:6px;font-size:12.5px;color:var(--blue);background:rgba(0,212,255,.06);
  border:1px solid var(--line);border-radius:8px;padding:7px 10px;word-break:break-word}
.copy{cursor:pointer;color:var(--green);font-weight:700;white-space:nowrap;margin-left:6px}
.copy:hover{text-decoration:underline}
.swatches{display:flex;gap:16px;flex-wrap:wrap;margin-top:6px}
.swatch{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}
.chip{display:inline-block;width:20px;height:20px;border-radius:5px;border:1px solid #ffffff33}
.cardimg{max-width:260px;border-radius:10px;margin-top:8px;border:1px solid var(--line);vertical-align:middle}
/* cockpit tabs */
.tabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:6px 0 18px;padding-bottom:0}
.tab{background:transparent;border:0;border-bottom:3px solid transparent;color:var(--muted);
  font-weight:700;font-size:14px;padding:11px 14px;cursor:pointer;border-radius:8px 8px 0 0}
.tab:hover{color:var(--txt);background:var(--panel)}
.tab.on{color:var(--green);border-bottom-color:var(--green)}
.pane{animation:fade .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.hide{display:none!important}
.profile-actions{margin-top:16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.embed{width:100%;height:78vh;border:1px solid var(--line);border-radius:12px;background:#fff}
.terr-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.lbl{color:var(--muted);font-size:12px}
.w90{width:90px}.grow{flex:1;min-width:200px}.full{width:100%;min-height:90px}
.mt10{margin-top:10px;display:block}.mt6{margin-top:6px}
.histrow{padding:8px 0;border-bottom:1px solid var(--line)}
/* Bolsa RS */
.boardhead{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.ticker{display:block;background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--muted);
  border-radius:12px;padding:14px;text-decoration:none;color:var(--txt);transition:.15s}
.ticker:hover{transform:translateY(-2px);text-decoration:none}
.ticker.up{border-left-color:var(--green)}
.ticker.down{border-left-color:var(--red)}
.ticker.flat{border-left-color:#3a4a5e}
.tickhead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.tickhead .nome{font-size:16px;font-weight:700}
.idxbox{text-align:right;white-space:nowrap}
.idx{font-size:30px;font-weight:800;line-height:1;font-family:'Segoe UI',monospace}
.var{font-size:13px;font-weight:700;margin-top:2px}
.var.up{color:var(--green)}.var.down{color:var(--red)}.var.flat{color:var(--muted)}
.spark{width:100%;height:34px;margin:10px 0 6px;display:block}
.tickfoot{display:flex;gap:6px;align-items:center;font-size:12px;color:var(--muted)}
.metriclog{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.mini{width:110px}
.cenarios{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.cen{flex:1;min-width:130px;text-align:center;border:1px solid var(--line);border-radius:12px;padding:14px 10px}
.cen .cl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.cen .cv{font-size:28px;font-weight:800;margin-top:4px}
.cen.cons{border-color:#3a4a5e}.cen.cons .cv{color:var(--muted)}
.cen.real{border-color:var(--blue)}.cen.real .cv{color:var(--blue)}
.cen.oti{border-color:var(--green)}.cen.oti .cv{color:var(--green)}
input[type=date]{color-scheme:dark}
/* Evolução & Concorrentes */
.ev-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px}
.ev-kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.ev-kpi.ev-idx{border-color:rgba(0,255,149,.25)}
.ev-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:6px}
.ev-val{font-size:26px;font-weight:800;line-height:1;margin-bottom:4px}
.cc-header{display:grid;grid-template-columns:1fr 120px 80px 70px 80px 36px;gap:8px;
  font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);
  padding:0 6px 8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.cc-row{display:grid;grid-template-columns:1fr 120px 80px 70px 80px 36px;gap:8px;
  align-items:center;padding:8px 6px;border-bottom:1px solid var(--line)}
.cc-row:last-child{border-bottom:0}
.cc-voce{background:rgba(0,255,149,.04);border-radius:8px;border-bottom:1px solid var(--line)!important}
.cc-nome{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cc-bar{background:var(--line);border-radius:4px;height:8px;overflow:hidden}
.cc-barfill{height:100%;border-radius:4px;transition:width .4s ease}
.cc-seg,.cc-eng{font-size:13px;font-weight:700;text-align:right}
/* Registro por rede */
.mnet-grid{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}
.mnet-col{display:flex;flex-direction:column;gap:6px;min-width:130px}
.mnet-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:2px}
/* Seletor de métrica no gráfico */
.ev-btns{display:flex;gap:6px;flex-wrap:wrap}
