/* ===== BI C6 Auto — tema dark premium ===== */
:root{
  --bg:#0d0d0f; --bg2:#141417; --panel:#191920; --panel2:#1f1f27;
  --line:#2c2c35; --line2:#3a3a45;
  --txt:#ecedf0; --muted:#8c8c98; --muted2:#6b6b78;
  --gold:#cBa85e; --gold-d:#a8893f;
  --green:#3fb950; --green-bg:#13301a;
  --red:#f0506e; --red-bg:#3a1620;
  --amber:#e3a13a; --amber-bg:#3a2c12;
  --blue:#4aa3df;
  --r:14px; --r-sm:9px;
  --sh:0 6px 22px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);color:var(--txt);
  font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;
}
#app{min-height:100%;display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:6px}

/* ---- topbar ---- */
.topbar{
  display:flex;align-items:center;gap:20px;
  padding:13px 26px;background:linear-gradient(180deg,#000 0%,#121214 100%);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;
}
.brand{display:flex;align-items:center;gap:13px;min-width:240px}
.logo{
  width:46px;height:46px;border-radius:11px;
  background:linear-gradient(145deg,#1a1a1a,#000);
  border:1px solid var(--gold-d);color:var(--gold);
  font-weight:800;font-size:19px;letter-spacing:.5px;
  display:flex;align-items:center;justify-content:center;
}
.brand-txt{display:flex;flex-direction:column;line-height:1.2}
.brand-txt strong{font-size:15px;letter-spacing:.3px}
.brand-txt span{font-size:11px;color:var(--muted)}
.topbar-mid{flex:1;display:flex;justify-content:center}
.praca-sel{
  background:var(--panel2);border:1px solid var(--gold-d);
  padding:8px 30px 8px 18px;border-radius:30px;font-size:13px;font-weight:700;
  color:var(--gold);cursor:pointer;text-align:center;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23cba85e' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
}
.praca-sel:focus{outline:none;border-color:var(--gold)}
.praca-sel option{background:var(--panel);color:var(--txt)}
.topbar-right{display:flex;align-items:center;gap:14px;min-width:240px;justify-content:flex-end}
.upd{font-size:11px;color:var(--muted);text-align:right}
.btn-role{
  background:var(--panel2);border:1px solid var(--line2);color:var(--txt);
  padding:8px 15px;border-radius:9px;font-size:12.5px;font-weight:600;
  display:flex;align-items:center;gap:7px;transition:.15s;
}
.btn-role:hover{border-color:var(--gold);color:var(--gold)}
.btn-role.admin{border-color:var(--gold);color:var(--gold);background:#221d10}

/* ---- filterbar ---- */
.filterbar{
  display:flex;align-items:center;gap:26px;flex-wrap:wrap;
  padding:12px 26px;background:var(--bg2);border-bottom:1px solid var(--line);
}
.filter-group{display:flex;align-items:center;gap:10px}
.filter-group>label{
  font-size:11px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.6px;
}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{
  background:var(--panel);border:1px solid var(--line2);color:var(--muted);
  padding:6px 13px;border-radius:30px;font-size:12px;font-weight:600;transition:.13s;
}
.chip:hover{border-color:var(--gold);color:var(--txt)}
.chip.on{background:var(--gold);border-color:var(--gold);color:#1a1505}
select{
  background:var(--panel);border:1px solid var(--line2);color:var(--txt);
  padding:7px 12px;border-radius:8px;font-size:12.5px;min-width:210px;
}
select:focus{outline:none;border-color:var(--gold)}
.btn-reset{
  background:none;border:1px solid var(--line2);color:var(--muted);
  padding:7px 13px;border-radius:8px;font-size:12px;transition:.13s;
}
.btn-reset:hover{border-color:var(--red);color:var(--red)}

/* ---- tabs ---- */
.tabs{
  display:flex;gap:4px;padding:0 26px;background:var(--bg2);
  border-bottom:1px solid var(--line);overflow-x:auto;
}
.tab{
  background:none;border:none;color:var(--muted);
  padding:13px 18px;font-size:13.5px;font-weight:600;
  border-bottom:2.5px solid transparent;white-space:nowrap;transition:.13s;
}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* ---- main / view ---- */
main{flex:1;padding:24px 26px 40px}
.section-title{
  font-size:13px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.7px;
  margin:30px 0 13px;display:flex;align-items:center;gap:10px;
}
.section-title:first-child{margin-top:0}
.section-title::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---- KPI cards ---- */
.kpi-grid{
  display:grid;gap:14px;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
}
.kpi{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:17px 18px;position:relative;overflow:hidden;
}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold)}
.kpi.good::before{background:var(--green)}
.kpi.bad::before{background:var(--red)}
.kpi.warn::before{background:var(--amber)}
.kpi-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.kpi-val{font-size:27px;font-weight:800;margin:7px 0 3px;letter-spacing:-.5px}
.kpi.good .kpi-val{color:var(--green)}
.kpi.bad .kpi-val{color:var(--red)}
.kpi.warn .kpi-val{color:var(--amber)}
.kpi-sub{font-size:11.5px;color:var(--muted)}
.kpi-sub b{color:var(--txt)}

/* ---- panels & charts ---- */
.grid{display:grid;gap:14px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.g2,.g3{grid-template-columns:1fr}}
.panel{
  background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:16px 18px;
}
.panel h4{
  font-size:13px;font-weight:700;margin-bottom:4px;
}
.panel .hint{font-size:11.5px;color:var(--muted);margin-bottom:12px}
.chart-wrap{position:relative;height:240px}
.chart-wrap.tall{height:340px}

/* ---- alerts ---- */
.alerts{display:flex;flex-direction:column;gap:9px}
.alert{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px 14px;border-radius:var(--r-sm);
  border:1px solid var(--line);background:var(--panel);font-size:13px;
}
.alert .ico{
  width:24px;height:24px;border-radius:7px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;
}
.alert.red{border-color:#5a2230;background:var(--red-bg)}
.alert.red .ico{background:var(--red);color:#2a0c14}
.alert.amber{border-color:#5a4520;background:var(--amber-bg)}
.alert.amber .ico{background:var(--amber);color:#2a1f08}
.alert.green{border-color:#235230;background:var(--green-bg)}
.alert.green .ico{background:var(--green);color:#0c2412}
.alert b{color:#fff}

/* ---- tables ---- */
.tbl-wrap{
  background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
}
.tbl-scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:12.8px}
thead th{
  background:var(--bg2);color:var(--muted);text-align:right;
  padding:11px 13px;font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;
  border-bottom:1px solid var(--line);white-space:nowrap;cursor:pointer;user-select:none;
}
thead th:first-child{text-align:left}
thead th.sorted{color:var(--gold)}
tbody td{padding:10px 13px;text-align:right;border-bottom:1px solid var(--line)}
tbody td:first-child{text-align:left;font-weight:600}
td.tl,th.tl{text-align:left!important;font-weight:400}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--panel2)}
tbody tr.total td{background:var(--bg2);font-weight:800;border-top:2px solid var(--line2)}
.num-pos{color:var(--green)}
.num-neg{color:var(--red)}
.badge{
  display:inline-block;padding:3px 9px;border-radius:20px;
  font-size:10.5px;font-weight:700;
}
.badge.ok{background:var(--green-bg);color:var(--green);border:1px solid #235230}
.badge.at{background:var(--amber-bg);color:var(--amber);border:1px solid #5a4520}
.badge.cr{background:var(--red-bg);color:var(--red);border:1px solid #5a2230}
.badge.nt{background:var(--panel2);color:var(--muted);border:1px solid var(--line2)}
.minibar{height:6px;border-radius:4px;background:var(--line);overflow:hidden;min-width:54px;display:inline-block;vertical-align:middle}
.minibar>i{display:block;height:100%}

/* ---- estrategia ---- */
.diag-box{
  background:linear-gradient(135deg,#1d1a12,#191920);
  border:1px solid var(--gold-d);border-radius:var(--r);
  padding:18px 20px;font-size:13.5px;line-height:1.6;
}
.diag-box b{color:var(--gold)}
.swot{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:840px){.swot{grid-template-columns:1fr}}
.swot-card{border-radius:var(--r);padding:16px 18px;border:1px solid var(--line)}
.swot-card h4{font-size:13px;font-weight:800;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.swot-card ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.swot-card li{font-size:12.7px;padding-left:16px;position:relative;color:var(--txt)}
.swot-card li::before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;border-radius:50%}
.swot-f{background:var(--green-bg);border-color:#235230}
.swot-f h4{color:var(--green)} .swot-f li::before{background:var(--green)}
.swot-w{background:var(--red-bg);border-color:#5a2230}
.swot-w h4{color:var(--red)} .swot-w li::before{background:var(--red)}
.swot-o{background:#1d1a12;border-color:var(--gold-d)}
.swot-o h4{color:var(--gold)} .swot-o li::before{background:var(--gold)}
.swot-t{background:var(--amber-bg);border-color:#5a4520}
.swot-t h4{color:var(--amber)} .swot-t li::before{background:var(--amber)}
.plan{display:flex;flex-direction:column;gap:10px}
.plan-item{
  display:grid;grid-template-columns:38px 1fr;gap:14px;
  background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:14px 16px;
}
.plan-n{
  width:38px;height:38px;border-radius:10px;
  background:var(--gold);color:#1a1505;font-weight:800;font-size:16px;
  display:flex;align-items:center;justify-content:center;
}
.plan-c h5{font-size:13.5px;margin-bottom:4px}
.plan-c p{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.plan-tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:6px;background:var(--panel2);border:1px solid var(--line2);color:var(--muted)}
.tag.now{background:var(--red-bg);border-color:#5a2230;color:var(--red)}
.tag.imp{background:var(--green-bg);border-color:#235230;color:var(--green)}

/* ---- footer ---- */
.footer{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  padding:14px 26px;border-top:1px solid var(--line);
  font-size:11px;color:var(--muted2);background:var(--bg2);
}

/* ---- modal ---- */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.78);
  display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;
}
.modal.hidden{display:none}
.hidden{display:none!important}
.modal-box{
  background:var(--panel);border:1px solid var(--line2);
  border-radius:var(--r);width:690px;max-width:100%;max-height:88vh;
  overflow:auto;box-shadow:var(--sh);
}
.modal-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 20px;border-bottom:1px solid var(--line);
}
.modal-head h3{font-size:15px;color:var(--gold)}
.modal-x{background:none;border:none;color:var(--muted);font-size:24px;line-height:1}
.modal-x:hover{color:var(--red)}
.modal-body{padding:20px}
.modal-body p{font-size:13px;color:var(--muted);margin-bottom:14px}
.modal-body label.fld{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:6px}
.modal-body input[type=password],.modal-body input[type=text]{
  width:100%;background:var(--bg2);border:1px solid var(--line2);
  color:var(--txt);padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;
}
.modal-body input:focus{outline:none;border-color:var(--gold)}
.dropzone{
  border:2px dashed var(--line2);border-radius:var(--r);
  padding:30px 20px;text-align:center;transition:.15s;cursor:pointer;
}
.dropzone:hover,.dropzone.drag{border-color:var(--gold);background:#1d1a12}
.dropzone .dz-ico{font-size:34px;margin-bottom:8px}
.dropzone .dz-main{font-size:13.5px;font-weight:600}
.dropzone .dz-sub{font-size:11.5px;color:var(--muted);margin-top:4px}
.btn{
  background:var(--gold);border:none;color:#1a1505;
  padding:10px 18px;border-radius:8px;font-size:13px;font-weight:700;transition:.13s;
}
.btn:hover{background:#dcb96a}
.btn.ghost{background:none;border:1px solid var(--line2);color:var(--txt)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn.danger{background:none;border:1px solid #5a2230;color:var(--red)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.admin-status{
  font-size:12.5px;padding:11px 13px;border-radius:8px;margin-top:14px;
  border:1px solid var(--line2);background:var(--bg2);
}
.admin-status.ok{border-color:#235230;background:var(--green-bg);color:var(--green)}
.admin-status.err{border-color:#5a2230;background:var(--red-bg);color:var(--red)}
.admin-note{font-size:11.5px;color:var(--muted2);margin-top:14px;line-height:1.55}
.ds-stat{
  font-size:12px;background:var(--bg2);border:1px solid var(--line2);
  border-radius:8px;padding:10px 12px;margin-bottom:14px;
  display:flex;flex-direction:column;gap:5px;color:var(--muted);
}
.ds-stat b{color:var(--gold)}
.admin-sec{
  font-size:12px;font-weight:800;color:var(--gold);text-transform:uppercase;
  letter-spacing:.6px;margin:22px 0 9px;padding-bottom:6px;border-bottom:1px solid var(--line);
}
.admin-sec:first-child{margin-top:0}
.metas-tbl{width:100%;border-collapse:collapse;font-size:11.5px}
.metas-tbl th{
  background:var(--bg2);color:var(--muted);padding:7px 5px;font-size:9.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--line);text-align:center;
}
.metas-tbl td{padding:4px 4px;border-bottom:1px solid var(--line);text-align:center}
.metas-tbl tr:last-child td{border-bottom:none}
.metas-tbl td:first-child{font-weight:700;color:var(--gold);white-space:nowrap;font-size:11px}
.metas-tbl input{
  width:100%;min-width:62px;background:var(--bg);border:1px solid var(--line2);
  color:var(--txt);padding:6px 6px;border-radius:6px;font-size:11.5px;text-align:right;
}
.metas-tbl input:focus{outline:none;border-color:var(--gold)}
.add-mes{display:flex;gap:9px;align-items:center;margin-top:13px;flex-wrap:wrap}
.add-mes input{
  background:var(--bg2);border:1px solid var(--line2);color:var(--txt);
  padding:8px 10px;border-radius:7px;font-size:12px;color-scheme:dark;
}
.adm-praca{
  display:flex;align-items:center;gap:10px;background:var(--bg2);
  border:1px solid var(--gold-d);border-radius:9px;padding:10px 13px;margin-bottom:16px;
}
.adm-praca label{font-size:11px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.5px}
.adm-praca select{
  flex:1;background:var(--panel);border:1px solid var(--line2);color:var(--gold);
  padding:8px 11px;border-radius:7px;font-size:13px;font-weight:700;
}
.adm-praca select:focus{outline:none;border-color:var(--gold)}
.up-confirm{display:flex;align-items:center;gap:10px}
.up-confirm label{font-size:12px;font-weight:700;color:var(--muted)}
.up-confirm select{
  background:var(--panel);border:1px solid var(--gold-d);color:var(--gold);
  padding:7px 11px;border-radius:7px;font-size:12.5px;font-weight:700;
}
.up-confirm select:focus{outline:none;border-color:var(--gold)}

/* ---- toast ---- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--panel2);border:1px solid var(--gold);color:var(--txt);
  padding:12px 22px;border-radius:10px;font-size:13px;font-weight:600;
  z-index:200;box-shadow:var(--sh);
}
.empty{
  text-align:center;padding:60px 20px;color:var(--muted);
}
.empty .big{font-size:40px;margin-bottom:10px}

/* ---- stat line (HHI / concentração) ---- */
.stat-line{
  display:flex;gap:20px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:12px 17px;font-size:12.5px;color:var(--muted);margin-bottom:14px;
}
.stat-line b{color:var(--txt)}
.stat-line .hot{color:var(--red)} .stat-line .gd{color:var(--green)} .stat-line .wn{color:var(--amber)}

/* ---- projeção / quadrante callout ---- */
.proj-box{
  background:linear-gradient(135deg,#1d1a12,#191920);border:1px solid var(--gold-d);
  border-radius:var(--r);padding:14px 16px;font-size:13px;line-height:1.55;margin-bottom:14px;
}
.proj-box b{color:var(--gold)}

/* ---- plano (estratégia) ---- */
.plano-status{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:6px}
.ps-ok{background:var(--green-bg);color:var(--green);border:1px solid #235230}
.ps-and{background:var(--amber-bg);color:var(--amber);border:1px solid #5a4520}
.ps-atr{background:var(--red-bg);color:var(--red);border:1px solid #5a2230}
.ps-nao{background:var(--panel2);color:var(--muted);border:1px solid var(--line2)}

/* ---- plano editor (admin) ---- */
.plano-edit{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.plano-edit-row{
  background:var(--bg2);border:1px solid var(--line2);border-radius:9px;padding:9px 10px;
  display:grid;grid-template-columns:1fr 96px 128px 30px;gap:7px;align-items:center;
}
.plano-edit-row textarea{grid-column:1/-1;resize:vertical;min-height:30px}
.plano-edit-row input,.plano-edit-row select,.plano-edit-row textarea{
  background:var(--bg);border:1px solid var(--line2);color:var(--txt);
  padding:6px 8px;border-radius:6px;font-size:11.5px;font-family:inherit;width:100%;box-sizing:border-box;
}
.plano-edit-row input:focus,.plano-edit-row select:focus,.plano-edit-row textarea:focus{outline:none;border-color:var(--gold)}
.plano-edit-row .pe-rm{
  background:none;border:1px solid #5a2230;color:var(--red);border-radius:6px;
  cursor:pointer;height:30px;font-size:15px;line-height:1;
}

/* ---- legenda de quadrante (cruzado) ---- */
.quad-leg{display:flex;flex-direction:column;gap:11px;padding-top:4px}
.quad-leg div{font-size:12.5px;color:var(--txt);line-height:1.5}
.quad-leg .badge{margin-right:4px}

/* ---- simulação Resultado × Estratégico (Estratégia) ---- */
.sim-prem{
  background:linear-gradient(135deg,#1d1a12,#191920);border:1px solid var(--gold-d);
  border-radius:9px;padding:13px 17px;font-size:12.5px;color:var(--muted);
  margin-bottom:14px;line-height:1.6;
}
.sim-prem b{color:var(--gold)}
table.sim-tbl td.estr{color:var(--gold);font-weight:700;background:rgba(203,168,94,.06)}
table.sim-tbl td.gain{color:var(--green);font-weight:800}
table.sim-tbl tr.total td{background:var(--bg2);font-weight:800;border-top:2px solid var(--line2)}
table.sim-tbl tr.total td.gain{font-size:14px}

/* ---- aba Resumo · velocímetros ---- */
.diag-banner{
  display:flex;align-items:center;gap:16px;border-radius:var(--r);
  padding:15px 20px;margin-bottom:20px;
}
.diag-banner .db-tag{
  font-size:13px;font-weight:800;letter-spacing:.5px;white-space:nowrap;
  padding:7px 14px;border-radius:7px;
}
.diag-banner .db-txt{font-size:13px;color:var(--txt);line-height:1.5}
.diag-banner.crit{background:var(--red-bg);border:1px solid #5a2230;animation:pulseRed 2.4s infinite}
.diag-banner.crit .db-tag{background:var(--red);color:#2a0c14}
.diag-banner.aten{background:var(--amber-bg);border:1px solid #5a4520}
.diag-banner.aten .db-tag{background:var(--amber);color:#2a1f08}
.diag-banner.ok{background:var(--green-bg);border:1px solid #235230}
.diag-banner.ok .db-tag{background:var(--green);color:#0c2412}
.gauge-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(188px,1fr))}
.gauge-card{text-align:center}
.gauge-title{
  font-size:11px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.6px;
}
.gauge-wrap{position:relative;height:130px;margin:10px 0 6px}
.gauge-center{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
}
.gauge-num{font-size:27px;font-weight:800;letter-spacing:-.5px}
.gauge-sub{font-size:11px;color:var(--muted)}
.gauge-dlt{font-size:10.5px;color:var(--muted2);margin-top:4px}
.dlt-up{color:var(--green);font-weight:700}
.dlt-dn{color:var(--red);font-weight:700}
.dlt-eq{color:var(--muted);font-weight:700}
.tempo-info{
  display:flex;align-items:center;gap:16px;margin-bottom:14px;padding:11px 18px;
  background:var(--bg2);border:1px solid var(--line);border-radius:9px;
  font-size:12.5px;color:var(--muted);
}
.ti-txt b{color:var(--gold);font-weight:700}
.ti-bar{flex:1;height:6px;background:var(--line);border-radius:4px;
  overflow:hidden;min-width:120px;max-width:380px}
.ti-fill{height:100%;background:var(--gold);border-radius:4px}

/* ---- central de alertas ---- */
@keyframes pulseRed{
  0%{box-shadow:0 0 0 0 rgba(240,80,110,.55)}
  70%{box-shadow:0 0 0 9px rgba(240,80,110,0)}
  100%{box-shadow:0 0 0 0 rgba(240,80,110,0)}
}
@keyframes blinkRed{ 0%,100%{opacity:1} 50%{opacity:.35} }
.alert-bell{
  background:var(--panel2);border:1px solid var(--line2);color:var(--muted);
  padding:8px 13px;border-radius:9px;font-size:12.5px;font-weight:700;
  display:flex;align-items:center;gap:7px;transition:.15s;
}
.alert-bell:hover{border-color:var(--gold);color:var(--gold)}
.alert-bell .ab-ico{font-size:13px}
.alert-bell #alertCount{
  background:var(--line2);color:var(--txt);border-radius:20px;
  padding:1px 8px;font-size:11px;min-width:20px;text-align:center;
}
.alert-bell.ativo{
  border-color:var(--red);color:var(--red);background:#2a1118;
  animation:pulseRed 1.7s infinite;
}
.alert-bell.ativo .ab-ico{animation:blinkRed 1.1s infinite}
.alert-bell.ativo #alertCount{background:var(--red);color:#2a0c14}
.tab .dot{
  position:absolute;top:7px;right:5px;width:7px;height:7px;border-radius:50%;
  background:var(--red);animation:pulseRed 1.7s infinite;
}
.ac-grp{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;margin:16px 0 9px;
}
.ac-grp:first-child{margin-top:0}
.ac-grp.crit{color:var(--red)} .ac-grp.aten{color:var(--amber)}
.ac-item{
  display:flex;gap:11px;padding:11px 13px;border-radius:9px;margin-bottom:8px;
  border:1px solid var(--line2);background:var(--panel2);
}
.ac-item.crit{border-color:#5a2230;background:var(--red-bg);animation:pulseRed 2.1s infinite}
.ac-item.aten{border-color:#5a4520;background:var(--amber-bg)}
.ac-ico{
  width:23px;height:23px;border-radius:7px;flex-shrink:0;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:13px;
}
.ac-item.crit .ac-ico{background:var(--red);color:#2a0c14;animation:blinkRed 1.1s infinite}
.ac-item.aten .ac-ico{background:var(--amber);color:#2a1f08}
.ac-txt{display:flex;flex-direction:column;gap:3px}
.ac-txt b{color:#fff;font-size:13px}
.ac-txt span{color:var(--muted);font-size:12px;line-height:1.5}
.ac-link{color:var(--gold)!important;font-size:11.5px;font-weight:700;cursor:pointer;margin-top:3px}
.ac-link:hover{text-decoration:underline}
.ac-rank{
  width:26px;height:26px;border-radius:8px;flex-shrink:0;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:13px;
  background:var(--panel);color:var(--gold);border:1px solid var(--line2);
}
.ac-item.crit .ac-rank{background:var(--red);color:#2a0c14;border-color:transparent;animation:blinkRed 1.1s infinite}
.ac-item.aten .ac-rank{background:var(--amber);color:#2a1f08;border-color:transparent}
.ac-hd{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ac-hd b{color:#fff;font-size:13px}
.ac-imp{
  display:inline-block;background:linear-gradient(180deg,#3b2e10,#2a2008);
  color:var(--gold);font-weight:800;font-size:11px;letter-spacing:.3px;
  padding:2px 8px;border-radius:999px;border:1px solid #5a4520;
}
.ac-mes{
  display:inline-block;background:linear-gradient(180deg,#0f2536,#0a1a26);
  color:var(--blue);font-weight:800;font-size:11px;letter-spacing:.3px;
  padding:2px 8px;border-radius:999px;border:1px solid #244766;
}
.plan-imp{
  display:inline-block;background:linear-gradient(180deg,#3b2e10,#2a2008);
  color:var(--gold);font-weight:800;font-size:11px;letter-spacing:.3px;
  padding:2px 8px;border-radius:999px;border:1px solid #5a4520;
  margin-left:6px;vertical-align:middle;
}
.plan-imp-mes{
  display:inline-block;background:linear-gradient(180deg,#0f2536,#0a1a26);
  color:var(--blue);font-weight:800;font-size:11px;letter-spacing:.3px;
  padding:2px 8px;border-radius:999px;border:1px solid #244766;
  margin-left:6px;vertical-align:middle;
}
/* ---- Login ---- */
.login-overlay{
  position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at top,#1a1a22 0%,#0a0a0d 70%);
}
.login-overlay.hidden{display:none}
.login-card{
  width:min(380px,90vw);background:var(--panel);border:1px solid var(--line2);
  border-radius:16px;padding:30px 32px;box-shadow:0 25px 60px rgba(0,0,0,.6);
}
.login-brand{display:flex;gap:14px;align-items:center;margin-bottom:18px}
.login-brand .logo{
  width:48px;height:48px;border-radius:11px;background:#000;color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:20px;
  border:1px solid var(--gold-d);
}
.login-brand strong{display:block;color:#fff;font-size:16px;letter-spacing:.5px}
.login-brand span{display:block;color:var(--muted);font-size:12px}
.login-msg{color:var(--muted);font-size:13px;margin-bottom:16px;line-height:1.5}
#loginInput{
  width:100%;padding:12px 14px;background:var(--bg2);border:1px solid var(--line2);
  border-radius:9px;color:var(--txt);font-size:15px;letter-spacing:1px;
  margin-bottom:12px;outline:none;transition:border .15s;
}
#loginInput:focus{border-color:var(--gold)}
#loginBtn{width:100%}
.login-err{color:var(--red);font-size:12.5px;margin-top:10px;min-height:18px;text-align:center}
.login-foot{
  margin-top:22px;padding-top:16px;border-top:1px solid var(--line);
  text-align:center;font-size:11px;letter-spacing:.6px;text-transform:uppercase;
}
.login-foot span{color:var(--muted2);display:block;margin-bottom:4px}
.login-foot strong{
  color:var(--gold);font-weight:700;font-size:12px;letter-spacing:.8px;
}

/* ---- responsivo ---- */
@media(max-width:720px){
  .topbar{flex-wrap:wrap;gap:10px;padding:10px 16px}
  .brand{min-width:0;flex:1}
  .topbar-mid{order:3;flex-basis:100%;justify-content:flex-start}
  .topbar-right{min-width:0;flex:0}
  .upd{display:none}
  .filterbar{gap:14px;padding:12px 16px}
  .filterbar .filter-group{flex-direction:column;align-items:flex-start;gap:6px}
  select{min-width:0;width:100%}
  .tabs{padding:0 16px}
  main{padding:18px 16px 36px}
  .footer{padding:14px 16px}
  .kpi-val{font-size:24px}
}
