/* ============================================================
   CervejaBox AI HUB — Design Tokens (light/dark)
   Base: amber #FCB500 (brand) · ink #202224 · accent blue #0D99FF
   ============================================================ */
:root[data-theme="light"]{
  --amber:#FCB500;--amber-strong:#E0A000;--amber-soft:#FFF4D2;
  --ink:#202224;--blue:#0D99FF;--green:#15A06A;--red:#E0494E;
  --page:#FFFDF3;--panel:#FFFFFF;--panel2:#FFFBEC;
  --line:#EFE7D2;--line-2:#F6EFDC;
  --txt:#202224;--txt-2:#6A6457;--txt-3:#9C947F;
  --shadow:0 1px 2px rgba(32,34,36,.05),0 8px 24px -16px rgba(32,34,36,.2);
  --shadow-sm:0 1px 2px rgba(32,34,36,.05);
  --c-clube:#FCB500;--c-avulso:#2EA3FF;--c-receita:#15A06A;
  --grid:#EFE7D2;
  /* aliases legados */
  --bg:var(--page);--mut:var(--txt-3);--acc:var(--amber);--acc-2:var(--amber-strong);
  --acc-soft:var(--amber-soft);--acc2:var(--blue);--ok:var(--green);
  --warn:var(--amber-strong);--err:var(--red);--txt2:var(--txt-2);
  --radius:16px;--radius-sm:11px;
}
:root[data-theme="dark"],:root{
  --amber:#FCB500;--amber-strong:#FFC740;--amber-soft:#322811;
  --ink:#100D07;--blue:#2EA3FF;--green:#2DC489;--red:#FF6B70;
  --page:#16140F;--panel:#201D17;--panel2:#28241C;
  --line:#322D23;--line-2:#2B271E;
  --txt:#F4F0E6;--txt-2:#ADA593;--txt-3:#7C745F;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 18px 40px -22px rgba(0,0,0,.7);
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --c-clube:#FCB500;--c-avulso:#3DAEFF;--c-receita:#2DC489;
  --grid:#322D23;
  --bg:var(--page);--mut:var(--txt-3);--acc:var(--amber);--acc-2:var(--amber-strong);
  --acc-soft:var(--amber-soft);--acc2:var(--blue);--ok:var(--green);
  --warn:var(--amber-strong);--err:var(--red);--txt2:var(--txt-2);
  --radius:16px;--radius-sm:11px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
.ic{display:inline-block;vertical-align:middle;flex-shrink:0;
  stroke-linecap:round;stroke-linejoin:round}
button .ic,a .ic{pointer-events:none}
.tnum,.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
body{font-family:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--page);color:var(--txt);display:flex;min-height:100vh;
  font-size:14px;line-height:1.45;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv05";letter-spacing:.005em;
  border-top:3px solid var(--blue);
  transition:background .35s ease,color .35s ease}
/* ── SIDEBAR — floating pill rail (96px column / 64px pill) ─────────── */
#nav{width:96px;background:transparent;border-right:0;
  display:flex;flex-direction:column;align-items:center;position:sticky;top:0;
  height:100vh;padding:16px 0;gap:14px;overflow:visible;flex-shrink:0;
  z-index:100;
  transition:width .22s ease}
#nav,#nav .rail,#menu,.nav-foot,.sidebar,.sidebar-foot{overflow:visible !important}
[data-theme="dark"] #nav{background:transparent;border-right:0}

/* Brand block (apenas logotipo 44x44) */
#nav #brand,#nav .brand{display:flex;align-items:center;justify-content:center;
  gap:0;padding:0;margin:0 0 2px;width:44px;border:0;background:transparent;
  border-radius:12px;cursor:pointer;user-select:none;text-decoration:none;flex-shrink:0}
#nav #brand:hover,#nav .brand:hover{background:transparent}
#nav .brand-mark{width:44px;height:44px;border-radius:12px;object-fit:cover;
  flex-shrink:0;display:block;
  box-shadow:0 0 0 1px rgba(32,34,36,.08),0 4px 12px -4px rgba(120,80,0,.45)}
.cb-logo{
  border-radius:12px;
  object-fit:cover;
  display:block;
  box-shadow:0 0 0 1px rgba(32,34,36,.08),0 4px 12px -4px rgba(120,80,0,.45);
  flex-shrink:0;
}
[data-theme="dark"] .cb-logo{
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 4px 12px -4px rgba(252,181,0,.35);
}
/* Esconde brand-text legado caso ainda esteja no DOM */
#nav .brand-text{display:none}
#nav .nav-label{display:none}

/* Rail — pílula branca arredondada que abriga o menu */
#nav .rail{background:var(--panel);border:1px solid var(--line);
  border-radius:30px;
  box-shadow:0 12px 34px -14px rgba(32,34,36,.22);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  flex:1;padding:18px 0;width:64px;overflow:visible}
[data-theme="dark"] #nav .rail{box-shadow:0 16px 40px -18px rgba(0,0,0,.7)}

/* Menu (icon-only) */
#menu{flex:none;overflow:visible;padding:0;display:flex;flex-direction:column;
  align-items:center;gap:10px;width:auto;scrollbar-width:none}
#menu::-webkit-scrollbar{width:0;height:0;display:none}
#menu .nav-item{position:relative;display:grid;place-items:center;
  width:44px;height:44px;border-radius:50%;
  color:var(--txt-3);text-decoration:none;cursor:pointer;
  transition:background .16s,color .16s;border:1px solid transparent;
  padding:0;font-weight:500}
#menu .nav-item .ic,#menu .nav-item svg{width:21px;height:21px;flex-shrink:0;
  color:inherit;transition:color .15s}
#menu .nav-item .nav-text,#menu .nav-item .nav-title,#menu .nav-item small,
#menu .nav-item>span{display:none}
#menu .nav-item:hover{background:var(--panel-2);color:var(--txt)}
#menu .nav-item:hover svg{color:inherit}
#menu .nav-item.active{background:var(--ink);color:#fff;border-color:transparent;
  box-shadow:0 6px 16px -5px rgba(32,34,36,.55)}
#menu .nav-item.active svg{color:inherit}
[data-theme="dark"] #menu .nav-item{color:var(--txt-3)}
[data-theme="dark"] #menu .nav-item.active{background:var(--amber);color:#221802}

/* Tooltip CSS via data-tip */
#nav .nav-item::after,
.sidebar-foot .nav-item::after{content:attr(data-tip);position:absolute;
  left:calc(100% + 14px);top:50%;
  transform:translateY(-50%) translateX(-6px);
  background:var(--ink);color:#fff;font-size:12px;font-weight:600;
  white-space:nowrap;padding:6px 10px;border-radius:8px;
  opacity:0;pointer-events:none;
  transition:opacity .14s,transform .14s;z-index:1000;
  box-shadow:0 6px 18px -6px rgba(0,0,0,.4)}
[data-theme="dark"] #nav .nav-item::after{background:#000;color:#F4F0E6}
#nav .nav-item::before,
.sidebar-foot .nav-item::before{content:"";position:absolute;
  left:calc(100% + 8px);top:50%;
  transform:translateY(-50%) translateX(-6px);
  border:5px solid transparent;border-right-color:var(--ink);
  opacity:0;transition:opacity .14s,transform .14s;z-index:1000}
[data-theme="dark"] #nav .nav-item::before{border-right-color:#000}
#nav .nav-item:hover::after,#nav .nav-item:hover::before{opacity:1;
  transform:translateY(-50%) translateX(0)}
#nav .nav-item[data-tip=""]::after,#nav .nav-item:not([data-tip])::after,
#nav .nav-item[data-tip=""]::before,#nav .nav-item:not([data-tip])::before{display:none}

/* Foot — help + logout, mesma pílula visual */
.nav-foot,.sidebar-foot{display:flex;flex-direction:column;align-items:center;
  gap:4px;width:auto;padding:0;border-top:0;flex-shrink:0;background:transparent}
.nav-foot-actions{display:none}
.nav-status{display:none}
.nav-icon-btn{display:none}
.sidebar-foot .nav-item,#nav .nav-foot .nav-item{color:var(--txt-3);
  width:44px;height:44px;border-radius:50%;background:transparent;
  border:1px solid transparent}
.sidebar-foot .nav-item:hover,#nav .nav-foot .nav-item:hover{
  background:var(--panel-2);color:var(--txt)}

/* Hidden state (header toggle) */
body.nav-hidden #nav{width:0;border-right-width:0;padding:0}
body.nav-hidden #nav>*{display:none}

/* Mobile — drawer */
@media(max-width:860px){
  #nav{position:fixed;top:0;left:0;height:100vh;z-index:120;
    padding:16px 0;
    box-shadow:6px 0 24px rgba(0,0,0,.3)}
  body:not(.nav-open) #nav{width:0;padding:0}
  body:not(.nav-open) #nav>*{display:none}
  body.nav-open #nav{width:96px}
}

/* Header nav toggle button */
#navToggle{display:none;background:var(--panel2);border:1px solid var(--line);
  color:var(--mut);width:36px;height:36px;border-radius:8px;cursor:pointer;
  margin-right:14px;align-items:center;justify-content:center;
  flex-shrink:0;transition:.15s}
#navToggle:hover{border-color:var(--acc);color:var(--acc)}
body.nav-hidden #navToggle{display:flex}
.env{display:none}  /* substituído pelo nav-foot */
main{flex:1;display:flex;flex-direction:column;min-width:0}
header{display:flex;justify-content:space-between;align-items:center;
  padding:18px 28px;border-bottom:1px solid var(--line);position:sticky;top:0;
  background:var(--bg);z-index:5}
header h1{font-size:19px;font-weight:650}
header .sub{font-size:12px;color:var(--mut)}
.hd-right{display:flex;align-items:center;gap:12px}
#refresh,.hdr-icon-btn{background:var(--panel2);border:1px solid var(--line);
  color:var(--mut);width:34px;height:34px;border-radius:8px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:.15s;
  font-family:inherit}
#refresh:hover,.hdr-icon-btn:hover{border-color:var(--acc);color:var(--acc)}
.pill{font-size:18px;color:var(--mut)}.pill.ok{color:var(--ok)}.pill.err{color:var(--err)}
#content{padding:22px 28px;overflow:auto}
.grid{display:grid;gap:14px}
/* KPIs sempre em UMA linha (scroll horizontal discreto se faltar espaço) */
.kgrid{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px;
  align-items:stretch}
.kgrid>*{flex:1 1 0;min-width:158px}
.kgrid>.click{display:flex}
.kgrid .kpi{width:100%}
.kgrid .card{height:100%}
.kgrid::-webkit-scrollbar{height:7px}
.kgrid::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.c2{grid-template-columns:repeat(2,1fr)}.c3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.c2,.c3{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px}
.kpi h3{font-size:11px;color:var(--mut);font-weight:600;text-transform:uppercase;
  letter-spacing:.5px}
.kpi .big{font-size:26px;font-weight:750;margin-top:6px;letter-spacing:-.5px}
.kpi .sub{font-size:12px;color:var(--mut);margin-top:3px}
.kpi.good .big{color:var(--ok)}.kpi.bad .big{color:var(--err)}
.kpi.warn .big{color:var(--warn)}
.delta{font-size:12px;font-weight:600}.delta.up{color:var(--ok)}.delta.down{color:var(--err)}
.panel-title{font-size:13px;font-weight:650;margin-bottom:12px;display:flex;
  justify-content:space-between;align-items:center}
.panel-title .tag{font-size:10px;color:var(--mut);font-weight:500}
canvas{max-height:280px}
.note{background:var(--panel2);border:1px dashed var(--line);border-radius:10px;
  padding:12px 14px;color:var(--mut);font-size:12px;margin:14px 0}
.insight{background:linear-gradient(135deg,#1a2230,#141821);border:1px solid var(--line);
  border-left:3px solid var(--acc);border-radius:10px;padding:14px 16px;font-size:13px;
  margin-bottom:16px}
.insight b{color:var(--acc)}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
th{color:var(--mut);font-weight:600;text-transform:uppercase;font-size:10px}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr:hover td{background:var(--panel2)}
.bar-mini{height:6px;background:var(--panel2);border-radius:4px;overflow:hidden}
.bar-mini i{display:block;height:100%;background:var(--acc)}
/* mapa coroplético (tile grid Brasil) */
.mapwrap{display:grid;grid-template-columns:repeat(9,1fr);gap:5px;max-width:420px}
.uf{aspect-ratio:1;border-radius:6px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-size:10px;font-weight:700;
  background:var(--panel2);color:var(--mut);border:1px solid var(--line)}
.uf b{font-size:9px;font-weight:600;opacity:.85}
.maplegend{display:flex;gap:6px;align-items:center;font-size:11px;color:var(--mut);
  margin-top:10px}
.sw{width:14px;height:10px;border-radius:2px;display:inline-block}
.spin{display:flex;gap:8px;align-items:center;color:var(--mut);font-size:13px}
.spin:before{content:"";width:14px;height:14px;border:2px solid var(--line);
  border-top-color:var(--acc);border-radius:50%;animation:s .8s linear infinite}
@keyframes s{to{transform:rotate(360deg)}}
.chat{max-width:880px}
.msg{padding:14px 16px;border-radius:12px;margin-bottom:12px;white-space:pre-wrap}
.msg.u{background:var(--acc2);color:#fff;margin-left:60px}
.msg.a{background:var(--panel);border:1px solid var(--line)}
.msg .meta{font-size:11px;color:var(--mut);margin-top:8px}
textarea,input{font:inherit;border-radius:9px;border:1px solid var(--line);
  background:var(--panel2);color:var(--txt);padding:11px 13px;width:100%}
textarea{min-height:80px;resize:vertical}
button.pri{background:var(--acc);color:#1a1205;font-weight:650;border:0;cursor:pointer;
  padding:11px 20px;border-radius:9px;margin-top:10px}
.tag{display:inline-block;background:var(--panel2);border:1px solid var(--line);
  color:var(--acc);padding:3px 9px;border-radius:20px;font-size:11px;margin:3px}
.mb{margin-bottom:16px}

/* (legacy .fbar rules removed — replaced by new toolbar block below) */
.fresh{margin-top:8px;display:flex;gap:16px;font-size:11px;color:var(--mut);
  flex-wrap:wrap;align-items:center}
.fresh b{color:var(--txt);font-weight:600}
.fresh .dot{color:var(--ok)}
.fchip{background:rgba(245,166,35,.15);border:1px solid var(--acc);color:var(--acc);
  padding:0 10px;border-radius:18px;font-size:11px;display:flex;align-items:center;
  white-space:nowrap}

/* Modal cliente */
.modal{position:fixed;inset:0;background:rgba(8,10,15,.72);display:none;z-index:50;
  padding:24px;overflow:auto;backdrop-filter:blur(4px)}
.modal.on{display:block;animation:cfmIn .18s ease-out}
.modal-box{max-width:min(1700px,97vw);margin:0 auto;background:var(--panel);
  border:1px solid var(--line);border-radius:16px;padding:24px;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 4px 14px rgba(0,0,0,.3);
  animation:cfmBoxIn .22s cubic-bezier(.16,1,.3,1)}
/* tabelas de detalhe: tudo em 1 linha, com rolagem horizontal */
.modal-box table{width:max-content;min-width:100%}
.modal-box table td,.modal-box table th{white-space:nowrap}
.modal-box table td{max-width:420px;overflow:hidden;text-overflow:ellipsis}
.modal-h{display:flex;justify-content:space-between;align-items:center;
  margin-bottom:18px;gap:14px}
.modal-h h2{font-size:18px;font-weight:600;letter-spacing:-.2px}
.modal-h button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  width:34px;height:34px;border-radius:9px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;transition:.15s;flex-shrink:0}
.modal-h button:hover{border-color:var(--err);color:var(--err);background:var(--panel)}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:12px}
.kv div{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);
  padding:4px 0}.kv span{color:var(--mut)}
.crow{cursor:pointer}

/* Modal melhorado */
.modal-h .sub{font-size:12px;color:var(--mut);margin-top:3px}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.kv div{display:flex;flex-direction:column;border-bottom:1px solid var(--line);
  padding:5px 0;gap:2px}
.kv span{color:var(--mut);font-size:10px;text-transform:uppercase;letter-spacing:.4px}
.kv b{font-size:13px;word-break:break-word}
.prow{cursor:pointer}
.prow.sel td{background:rgba(245,166,35,.15)}
.prow:hover td{background:var(--panel2)}
.st{padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;
  background:var(--panel2);border:1px solid var(--line)}
.st-entregue{color:var(--ok);border-color:var(--ok)}
.st-enviado{color:var(--acc2);border-color:var(--acc2)}
.st-faturado,.st-aprovado{color:var(--acc)}
.st-cancelado{color:var(--err);border-color:var(--err)}
.st-emaberto,.st-preparandoenvio{color:var(--warn)}
#citAll{cursor:pointer}

.click{cursor:pointer;transition:.12s}
.click:hover{filter:brightness(1.12);outline:1px solid var(--acc)}

/* ── Cliente 360: barras de status histórico ── */
.lt-bars{display:flex;flex-direction:column;gap:7px;font-size:12px}
.lt-bar{display:grid;grid-template-columns:120px 1fr 38px 78px;align-items:center;gap:8px}
.lt-bar-l{color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lt-bar-track{background:var(--panel2);border-radius:6px;height:10px;overflow:hidden}
.lt-bar-track i{display:block;height:100%;background:linear-gradient(90deg,#F5A623,#E67E22);border-radius:6px}
.lt-bar b{text-align:right}
.lt-bar-v{color:var(--mut);text-align:right;font-size:11px}

/* Cohort heatmap */
table.cohort{border-collapse:separate;border-spacing:2px;font-size:11px}
table.cohort th{position:sticky;top:0;background:var(--panel);color:var(--mut);
  font-size:10px;padding:4px 6px}
table.cohort td{padding:4px 6px;text-align:center;border-radius:3px;
  white-space:nowrap;color:var(--txt)}
table.cohort td:first-child,table.cohort th:first-child{position:sticky;left:0;
  background:var(--panel);text-align:left}

/* Cobranças classificadas pelo motor de reconciliação */
.prow.orfao td{background:rgba(255,107,107,.08)!important;
  border-left:3px solid var(--err)}
.prow.orfao td:first-child{font-weight:600;color:var(--err)}
.prow.orfao .sub{font-size:10px;color:var(--mut)}
.prow.recon-verde td{background:rgba(46,204,113,.07)!important;
  border-left:3px solid var(--ok)}
.prow.recon-verde td:first-child{color:var(--ok);font-weight:600}
.prow.recon-amarelo td{background:rgba(245,166,35,.08)!important;
  border-left:3px solid var(--acc)}
.prow.recon-amarelo td:first-child{color:var(--acc);font-weight:600}
.prow.recon-azul td{background:rgba(91,141,239,.10)!important;
  border-left:3px solid var(--acc2)}
.prow.recon-azul td:first-child{color:var(--acc2);font-weight:600}
.codelink{color:var(--acc2);cursor:pointer;text-decoration:underline}
.codelink:hover{color:var(--acc)}

/* Resumo de itens do pedido */
.resumo-itens{display:flex;gap:18px;flex-wrap:wrap;padding:8px 10px;margin-bottom:8px;
  background:var(--panel2);border:1px solid var(--line);border-radius:8px;font-size:13px}
.resumo-itens b{color:var(--acc)}

/* ── Combobox / autocomplete (Cliente / Produto / Clube) ── */
.cbx-pop{position:fixed;z-index:60;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;max-height:340px;overflow-y:auto;padding:6px;
  box-shadow:0 14px 40px rgba(0,0,0,.55),0 2px 6px rgba(0,0,0,.4);
  backdrop-filter:saturate(140%) blur(6px)}
.cbx-opt{padding:10px 12px;font-size:13px;color:var(--txt);border-radius:8px;cursor:pointer;
  white-space:normal;line-height:1.4;font-weight:500;transition:background .12s,color .12s;
  border:1px solid transparent}
.cbx-opt:hover{background:var(--panel2);border-color:var(--line)}
.cbx-opt.sel{background:rgba(245,166,35,.14);color:var(--acc);border-color:rgba(245,166,35,.3)}
.cbx-opt .cbx-sub{font-size:11.5px;color:var(--mut);margin-top:3px;line-height:1.35;
  font-weight:400;letter-spacing:.01em}
.cbx-empty{padding:14px;font-size:12.5px;color:var(--mut);text-align:center;font-style:italic}
.cbx-pop::-webkit-scrollbar{width:8px}
.cbx-pop::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.cbx-pop::-webkit-scrollbar-track{background:transparent}

/* Suggest dropdown sits above filterbar popovers (z-index 50) and modal backdrop */
.cbx-pop{z-index:70}
.cbx-opt{display:flex;flex-direction:column;gap:2px}
.cbx-opt .cbx-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:560px}

/* ── Menu do usuário (avatar + dropdown profissional) ── */
.usrmenu{position:relative}
.usravatar{display:flex;align-items:center;gap:8px;background:var(--panel2);
  border:1px solid var(--line);color:var(--txt);border-radius:999px;
  padding:5px 12px 5px 5px;cursor:pointer;font:inherit;font-size:13px;font-weight:500;
  transition:.15s}
.usravatar:hover{border-color:var(--acc);background:var(--panel)}
.usravatar-ini{display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;background:var(--acc);color:#1a1108;
  font-size:11px;font-weight:700;letter-spacing:.3px}
.usravatar-nome{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap}
.usravatar-chev{color:var(--mut);margin-left:1px;display:inline-flex;align-items:center}
.usrpop{position:absolute;top:calc(100% + 8px);right:0;background:var(--panel);
  border:1px solid var(--line);border-radius:12px;width:280px;
  box-shadow:0 18px 50px rgba(0,0,0,.55),0 4px 12px rgba(0,0,0,.35);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s;z-index:80;
  padding:6px}
.usrpop.on{opacity:1;visibility:visible;transform:translateY(0)}
.usrpop-h{padding:12px;display:flex;gap:12px;align-items:flex-start}
.usrpop-ini{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--acc);
  color:#1a1108;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;letter-spacing:.3px}
.usrpop-nome{font-size:13.5px;font-weight:600;color:var(--txt);line-height:1.3}
.usrpop-email{font-size:11.5px;color:var(--mut);margin-top:2px;
  overflow-wrap:anywhere;line-height:1.3}
.usrpop-perfil{font-size:10.5px;color:var(--acc);margin-top:6px;text-transform:uppercase;
  letter-spacing:.6px;font-weight:600;display:flex;align-items:center;gap:6px}
.usrpop-perfil .dot{width:6px;height:6px;border-radius:50%;background:var(--ok)}
.usrpop-sep{height:1px;background:var(--line);margin:4px 6px}
.usrpop-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;
  background:transparent;border:none;color:var(--txt);font:inherit;font-size:13px;
  text-align:left;cursor:pointer;border-radius:8px;transition:.12s;font-weight:500}
.usrpop-item:hover{background:var(--panel2);color:var(--err)}
.usrpop-item .ic{color:var(--mut)}
.usrpop-item:hover .ic{color:var(--err)}

/* ── Confirm modal (substitui window.confirm) ── */
.cfmodal{position:fixed;inset:0;background:rgba(8,10,15,.7);
  display:flex;align-items:center;justify-content:center;z-index:1100;
  backdrop-filter:blur(4px);animation:cfmIn .18s ease-out}
@keyframes cfmIn{from{opacity:0}to{opacity:1}}
.cfmodal-box{background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:28px;max-width:420px;width:92%;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 4px 12px rgba(0,0,0,.3);
  animation:cfmBoxIn .22s cubic-bezier(.16,1,.3,1)}
@keyframes cfmBoxIn{from{transform:scale(.94) translateY(8px);opacity:0}
  to{transform:scale(1) translateY(0);opacity:1}}
.cfmodal h2{font-size:18px;font-weight:600;color:var(--txt);margin-bottom:10px;
  letter-spacing:-.2px}
.cfmodal p{font-size:14px;color:var(--mut);line-height:1.55;margin-bottom:22px}
.cfmodal-acts{display:flex;gap:10px;justify-content:flex-end}
.cfmodal-btn{padding:11px 18px;border-radius:9px;font-size:13.5px;font-weight:600;
  cursor:pointer;border:1px solid var(--line);font-family:inherit;transition:.15s;
  background:var(--panel2);color:var(--txt);letter-spacing:.01em}
.cfmodal-btn:hover{background:var(--line)}
.cfmodal-btn.pri{background:var(--acc);color:#1a1108;border-color:var(--acc)}
.cfmodal-btn.pri:hover{background:var(--acc-2)}
.cfmodal-btn.danger{background:var(--err);color:#fff;border-color:var(--err)}
.cfmodal-btn.danger:hover{filter:brightness(1.1)}

/* ── Tabs de status operacional ── */
.optabs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.optab{background:var(--panel2);border:1px solid var(--line);color:var(--mut);
  border-radius:20px;padding:6px 13px;cursor:pointer;font-size:12px;display:flex;
  align-items:center;gap:7px;transition:.12s}
.optab:hover{border-color:var(--acc)}
.optab.on{background:rgba(245,166,35,.15);border-color:var(--acc);color:var(--acc)}
.optab .b{background:var(--bg);border-radius:10px;padding:1px 7px;font-size:11px;
  font-weight:700;color:var(--txt)}
.optab.on .b{background:var(--acc);color:#111}

/* ── Barra de paginação ── */
.opbar{display:flex;align-items:center;gap:10px;margin-top:12px;font-size:12px;
  color:var(--mut)}
.opbar button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:7px;padding:5px 11px;cursor:pointer;font-size:12px}
.opbar button:disabled{opacity:.4;cursor:default}
.opbar .sp{margin-left:auto}

/* ── Módulo Financeiro ── */
.fin-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;
  border-bottom:1px solid var(--line);padding-bottom:10px}
.fin-tab{background:transparent;border:1px solid transparent;color:var(--mut);
  border-radius:8px;padding:7px 12px;cursor:pointer;font-size:12px;white-space:nowrap}
.fin-tab:hover{color:var(--txt);background:var(--panel2)}
.fin-tab.on{background:var(--acc);color:#111;font-weight:700}
/* DRE em linhas hierárquicas */
table.dre{width:100%;border-collapse:collapse;font-size:13px}
table.dre td{padding:7px 12px;border-bottom:1px solid var(--line)}
table.dre td.v{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.dre tr.grp td{background:var(--panel2);font-weight:700;text-transform:uppercase;
  font-size:11px;letter-spacing:.5px;color:var(--acc)}
table.dre tr.tot td{font-weight:700;border-top:2px solid var(--acc);
  border-bottom:2px solid var(--acc);font-size:14px}
table.dre tr. ded td:first-child,table.dre tr.sub td:first-child{padding-left:26px;
  color:var(--mut)}
table.dre tr.sub td:first-child{padding-left:26px;color:var(--mut)}
table.dre td .pos{color:var(--ok)}
table.dre td .neg{color:var(--err)}
table.dre tr.click:hover td{background:var(--panel2)}
/* badge de qualidade do dado */
.qb{font-size:9px;padding:1px 6px;border-radius:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.3px;vertical-align:middle;margin-left:6px}
.qb-real{background:rgba(46,204,113,.18);color:var(--ok)}
.qb-est{background:rgba(245,166,35,.18);color:var(--acc)}
.qb-falta{background:rgba(255,107,107,.18);color:var(--err)}
/* botão entender racional */
.rac{background:none;border:1px solid var(--line);color:var(--mut);border-radius:50%;
  width:18px;height:18px;font-size:11px;cursor:pointer;line-height:1;padding:0;
  display:inline-flex;align-items:center;justify-content:center;margin-left:6px}
.rac:hover{border-color:var(--acc);color:var(--acc)}
/* cards de insight financeiro */
.fin-ins{display:flex;flex-direction:column;gap:10px}
.fin-card{border:1px solid var(--line);border-left-width:4px;border-radius:10px;
  padding:13px 16px;background:var(--panel)}
.fin-card.p-critica{border-left-color:var(--err)}
.fin-card.p-alta{border-left-color:#E67E22}
.fin-card.p-media{border-left-color:var(--acc)}
.fin-card.p-baixa{border-left-color:var(--mut)}
.fin-card h4{font-size:13px;margin-bottom:5px;display:flex;align-items:center;gap:8px}
.fin-card .pri{font-size:9px;padding:1px 7px;border-radius:10px;text-transform:uppercase;
  font-weight:700}
.fin-card.p-critica .pri{background:var(--err);color:#fff}
.fin-card.p-alta .pri{background:#E67E22;color:#111}
.fin-card.p-media .pri{background:var(--acc);color:#111}
.fin-card.p-baixa .pri{background:var(--panel2);color:var(--mut)}
.fin-card p{font-size:12px;color:var(--mut);margin:2px 0}
.fin-card .imp{color:var(--txt);font-weight:600}

/* ============================================================
   LOGIN — split-screen, preto + laranja, minimalista
   ============================================================ */
.lg-screen{position:fixed;inset:0;display:flex;z-index:1000;background:var(--bg);
  font-family:"Inter","-apple-system",sans-serif}
.lg-brand{flex:1.1;background:
  radial-gradient(1200px 800px at 20% 20%,rgba(245,166,35,.10),transparent 60%),
  radial-gradient(900px 600px at 80% 90%,rgba(245,166,35,.06),transparent 50%),
  linear-gradient(135deg,#1a1108 0%,#15100a 50%,#0c0a07 100%);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:56px 48px;color:#fff;position:relative;overflow:hidden}
.lg-brand::after{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.4) 100%);
  pointer-events:none}
.lg-brand-head{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.lg-brand-head h2{font-size:18px;font-weight:600;letter-spacing:-.2px;line-height:1.2}
.lg-brand-head small{color:var(--acc);font-size:10px;font-weight:600;letter-spacing:3px;
  text-transform:uppercase;display:block;margin-top:2px}
.lg-pitch{position:relative;z-index:1;max-width:440px}
.lg-pitch h1{font-size:38px;font-weight:600;line-height:1.15;letter-spacing:-1px;
  color:#fff;margin-bottom:14px}
.lg-pitch h1 span{color:var(--acc)}
.lg-pitch p{color:rgba(255,255,255,.62);font-size:15px;line-height:1.55;
  font-weight:400}
.lg-features{position:relative;z-index:1;display:flex;flex-direction:column;gap:12px;
  color:rgba(255,255,255,.55);font-size:13px;font-weight:400}
.lg-features div{display:flex;align-items:center;gap:10px}
.lg-features .dot{width:6px;height:6px;border-radius:50%;background:var(--acc);
  box-shadow:0 0 12px rgba(245,166,35,.6);flex-shrink:0}
.lg-form-wrap{flex:1;display:flex;align-items:center;justify-content:center;
  padding:48px;background:var(--bg)}
.lg-form{width:100%;max-width:380px}
.lg-form h1{font-size:28px;font-weight:600;letter-spacing:-.5px;margin-bottom:6px;
  color:var(--txt)}
.lg-form .sub{font-size:14px;color:var(--mut);margin-bottom:36px;line-height:1.5}
.lg-field{margin-bottom:18px}
.lg-label{font-size:11px;font-weight:600;color:var(--mut);text-transform:uppercase;
  letter-spacing:.8px;margin-bottom:8px;display:block}
.lg-input{width:100%;background:var(--panel);border:1px solid var(--line);
  color:var(--txt);border-radius:10px;padding:14px 16px;font-size:14px;
  font-family:inherit;font-weight:400;letter-spacing:.01em;transition:.15s;
  -webkit-appearance:none}
.lg-input:focus{outline:none;border-color:var(--acc);
  box-shadow:0 0 0 3px rgba(245,166,35,.12);background:var(--panel2)}
.lg-input::placeholder{color:#5a6376}
.lg-btn{width:100%;background:var(--acc);color:#1a1108;border:none;
  border-radius:10px;padding:14px 16px;font-size:14px;font-weight:600;cursor:pointer;
  font-family:inherit;letter-spacing:.2px;transition:.15s;margin-top:8px;
  display:flex;align-items:center;justify-content:center;gap:8px}
.lg-btn:hover{background:var(--acc-2);transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(245,166,35,.25)}
.lg-btn:active{transform:translateY(0)}
.lg-btn:disabled{opacity:.6;cursor:wait}
.lg-err{color:var(--err);font-size:12.5px;margin-top:14px;min-height:18px;
  font-weight:500;letter-spacing:.01em}
.lg-foot{margin-top:42px;font-size:11px;color:var(--mut);text-align:center;
  letter-spacing:.3px}

@media(max-width:900px){
  .lg-brand{padding:36px 28px;flex:0 0 auto;min-height:34vh}
  .lg-pitch h1{font-size:30px}
  .lg-pitch p{font-size:14px}
  .lg-features{display:none}
  .lg-form-wrap{padding:36px 24px}
}
@media(max-width:640px){
  .lg-screen{flex-direction:column}
  .lg-brand{padding:28px 22px;min-height:auto;flex:0 0 auto}
  .lg-pitch h1{font-size:22px;margin-bottom:6px}
  .lg-pitch p{font-size:13px}
  .lg-form-wrap{padding:28px 22px;flex:1}
  .lg-form h1{font-size:24px}
  .lg-form .sub{margin-bottom:24px;font-size:13.5px}
  .lg-input{padding:13px 14px;font-size:16px}  /* 16px evita zoom no iOS */
  .lg-btn{padding:14px;font-size:15px}
}

/* ============================================================
   RESPONSIVO GERAL — tablet/celular
   ============================================================ */
@media(max-width:1024px){
  #content{padding:16px 18px}
  header{padding:14px 18px}
  .kgrid>*{min-width:148px}
}
@media(max-width:768px){
  /* sidebar como drawer em mobile */
  #nav{position:fixed;top:0;left:0;height:100vh;z-index:30;
    box-shadow:6px 0 24px rgba(0,0,0,.3);padding:16px 0}
  body:not(.nav-open) #nav{width:0;padding:0}
  body:not(.nav-open) #nav>*{display:none}
  body.nav-open #nav{width:96px}
  /* overlay quando o nav está aberto */
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.55);
    z-index:25}
  /* botão ☰ sempre visível em mobile */
  #navToggle{display:flex}
  /* header compacto */
  header{padding:12px 14px}
  header h1{font-size:17px;font-weight:600}
  header .sub{font-size:11px;display:none}
  .hd-right{gap:8px}
  .hd-right .tag{padding:7px 10px;font-size:11px}
  #refresh{width:32px;height:32px;font-size:13px}
  /* conteúdo */
  #content{padding:14px}
  /* filtros */
  #filterbar{flex-wrap:wrap;gap:8px;padding:12px}
  #filterbar select,#filterbar input{font-size:14px;padding:8px 10px}
  /* KPIs compactos em 2 colunas */
  .kgrid,.kpis{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi h3,.kpi .kpi-label{font-size:9.5px}
  .kpi .big,.kpi .kpi-val{font-size:22px;margin:8px 0 5px}
  .kpi .big span,.kpi .kpi-val span{font-size:12px}
  /* grids c2/c3 → 1 coluna */
  .c2,.c3{grid-template-columns:1fr!important}
  /* tabelas com scroll horizontal natural */
  table{font-size:12.5px}
  th,td{padding:9px 10px}
  th{font-size:10px}
  /* modais quase full-screen */
  .modal-box{max-width:96vw!important;max-height:92vh;border-radius:14px;
    padding:18px!important}
  /* abas/tabs no modal: rolar horizontal */
  .tabs{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  /* charts mais baixos */
  canvas{max-height:280px!important}
}
@media(max-width:430px){  /* iPhone 14 Pro Max — porta vertical = 430px lógicos */
  header{padding:10px 12px}
  header h1{font-size:15px}
  #content{padding:10px}
  .card{padding:13px;border-radius:10px}
  .kgrid,.kpis{grid-template-columns:1fr}
  .kpi{padding:12px 13px 10px}
  .kpi .big,.kpi .kpi-val{font-size:22px}
  .insight{font-size:12.5px;padding:11px 13px;line-height:1.5}
  .panel-title{font-size:12.5px}
  /* tipografia: aumenta levemente para legibilidade no celular */
  body{font-size:14px;line-height:1.55}
  /* botões com toque generoso */
  .tag{min-height:34px;padding:7px 12px}
}

/* ============================================================
   WELCOME MODAL — boas-vindas pós-login (Lusandro Araújo)
   ============================================================ */
/* Densidade alta — cabe sem scroll em 1366×768 */
.wm-overlay{position:fixed;inset:0;background:rgba(8,10,15,.78);z-index:1100;
  display:flex;align-items:center;justify-content:center;padding:18px;
  backdrop-filter:blur(6px);animation:cfmIn .2s ease-out}
.wm-box{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  max-width:1100px;width:90vw;max-height:90vh;overflow:hidden;
  padding:22px 26px 18px;display:flex;flex-direction:column;
  position:relative;box-shadow:0 36px 90px rgba(0,0,0,.7),0 8px 22px rgba(0,0,0,.4);
  animation:cfmBoxIn .26s cubic-bezier(.16,1,.3,1)}
.wm-x{position:absolute;top:12px;right:12px;background:var(--panel2);
  border:1px solid var(--line);color:var(--mut);width:30px;height:30px;border-radius:8px;
  cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;
  transition:.15s;z-index:2}
.wm-x:hover{border-color:var(--err);color:var(--err)}
.wm-hero{display:flex;gap:16px;align-items:center;margin-bottom:16px;padding-right:36px}
.wm-hero-text{flex:1;min-width:0}
.wm-hero h1{font-size:20px;font-weight:600;letter-spacing:-.3px;color:var(--txt);
  line-height:1.2;margin-bottom:3px}
.wm-hero h1 span{color:var(--acc)}
.wm-hero p{font-size:12.5px;color:var(--mut);line-height:1.4}
.wm-hero p b{color:var(--txt);font-weight:600}
.wm-hero-tag{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:1.4px;
  font-weight:600;padding:5px 10px;background:var(--panel2);border:1px solid var(--line);
  border-radius:14px;white-space:nowrap;align-self:center}
.wm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px;
  flex:1;min-height:0}
.wm-card{background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;transition:.15s;display:flex;flex-direction:column;min-height:0}
.wm-card:hover{border-color:rgba(245,166,35,.35)}
.wm-card-h{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.wm-ico{display:inline-flex;align-items:center;color:var(--acc);
  width:22px;height:22px;justify-content:center;
  background:rgba(245,166,35,.10);border-radius:6px;flex-shrink:0}
.wm-card-h b{font-size:13px;font-weight:600;color:var(--txt);letter-spacing:-.1px;flex:1}
.wm-tag{font-size:9px;color:var(--acc);text-transform:uppercase;letter-spacing:.6px;
  font-weight:600;background:rgba(245,166,35,.12);border:1px solid rgba(245,166,35,.25);
  padding:2px 6px;border-radius:5px}
.wm-card p{font-size:12px;color:var(--mut);line-height:1.4;margin-bottom:5px}
.wm-card ul{margin:0 0 0 16px;padding:0;display:flex;flex-direction:column;gap:1px}
.wm-card li{font-size:11.5px;color:var(--txt2);line-height:1.45;letter-spacing:.01em}
.wm-card li b{color:var(--acc);font-weight:600}
.wm-warn{display:flex;gap:10px;background:rgba(255,182,72,.10);
  border:1px solid rgba(255,182,72,.30);border-radius:9px;padding:10px 14px;
  margin-bottom:12px;align-items:center}
.wm-warn-ico{display:inline-flex;color:var(--warn);flex-shrink:0;align-items:center}
.wm-warn-text{font-size:12px;color:var(--txt2);line-height:1.45;flex:1}
.wm-warn-text b{color:var(--warn);font-weight:600}
.wm-warn-text a{color:var(--acc);text-decoration:none;font-weight:600;
  border-bottom:1px dashed rgba(245,166,35,.4);transition:.15s}
.wm-warn-text a:hover{border-bottom-style:solid;border-color:var(--acc)}
.wm-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding-top:12px;border-top:1px solid var(--line)}
.wm-check{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--mut);
  cursor:pointer;user-select:none}
.wm-check input{accent-color:var(--acc);width:15px;height:15px;cursor:pointer}
.wm-check:hover{color:var(--txt)}
.wm-go{background:var(--acc);color:#1a1108;border:0;border-radius:9px;
  padding:10px 20px;font-size:13.5px;font-weight:600;cursor:pointer;letter-spacing:.2px;
  transition:.15s;font-family:inherit}
.wm-go:hover{background:var(--acc-2);transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(245,166,35,.25)}
.wm-go:active{transform:translateY(0)}

/* Telas pequenas (notebook compacto 1366×768) — compactação extra */
@media(max-height:760px){
  .wm-box{padding:18px 22px 14px}
  .wm-hero{margin-bottom:12px}
  .wm-hero h1{font-size:18px}
  .wm-card{padding:10px 12px}
  .wm-card li{font-size:11px;line-height:1.4}
}
@media(max-width:900px){
  .wm-grid{grid-template-columns:repeat(2,1fr)}
  .wm-box{width:95vw}
}
@media(max-width:640px){
  .wm-overlay{padding:0;align-items:stretch}
  .wm-box{max-height:100vh;width:100vw;border-radius:0;padding:20px 16px;overflow-y:auto}
  .wm-hero{flex-direction:column;gap:10px;padding-right:36px;align-items:flex-start;text-align:left}
  .wm-hero-tag{align-self:flex-start}
  .wm-grid{grid-template-columns:1fr;gap:8px}
  .wm-warn{flex-direction:column;align-items:flex-start}
  .wm-foot{flex-direction:column;align-items:stretch;gap:10px}
  .wm-go{width:100%;padding:12px}
}

/* ============================================================
   CRM modal — altura travada + header/tabs fixos + body com scroll
   ============================================================ */
.crm-modal-box{max-width:min(1500px,96vw);width:100%;
  height:min(720px,88vh);display:flex;flex-direction:column;
  overflow:hidden;padding:0}
.crm-modal-h{padding:20px 24px 0;background:var(--panel);
  border-bottom:1px solid var(--line);flex-shrink:0}
.crm-modal-hbox{display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:14px;gap:14px}
.crm-id{display:flex;gap:12px;align-items:flex-start;min-width:0}
.crm-id-ic{background:rgba(245,166,35,.10);color:var(--acc);
  border-radius:9px;padding:7px;display:inline-flex;flex-shrink:0}
.crm-id h2{font-size:17px;font-weight:600;letter-spacing:-.2px;line-height:1.25;
  color:var(--txt);margin:0}
.crm-id .sub{font-size:12.5px;color:var(--mut);margin-top:3px;
  overflow-wrap:anywhere;line-height:1.4}
.modal-h-x{background:var(--panel2);border:1px solid var(--line);color:var(--mut);
  width:32px;height:32px;border-radius:8px;cursor:pointer;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  transition:.15s;font-family:inherit}
.modal-h-x:hover{border-color:var(--err);color:var(--err)}
.crm-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
.crm-tabs::-webkit-scrollbar{display:none}
.crm-tab{background:transparent;border:0;color:var(--mut);font:inherit;font-size:12.5px;
  padding:12px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  border-bottom:2px solid transparent;transition:color .15s,border-color .15s;
  font-weight:500;white-space:nowrap;font-family:inherit}
.crm-tab:hover{color:var(--txt)}
.crm-tab.on{color:var(--acc);border-bottom-color:var(--acc);font-weight:600}
.crm-tab .ic{opacity:.85}
.crm-tab.on .ic{opacity:1}
.crm-body{flex:1;overflow-y:auto;padding:22px 24px;background:var(--panel);
  transition:opacity .18s ease}
.crm-body.fading{opacity:0}
.crm-section-h{margin-top:22px;margin-bottom:8px;font-size:11px;color:var(--mut);
  text-transform:uppercase;letter-spacing:.6px;font-weight:600}

/* Botão de ícone inline (ver/editar/desativar) */
.ic-btn{display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;background:var(--panel2);border:1px solid var(--line);
  color:var(--mut);border-radius:7px;cursor:pointer;transition:.15s;
  font-family:inherit}
.ic-btn:hover{border-color:var(--acc);color:var(--acc)}
.ic-btn.danger:hover{border-color:var(--err);color:var(--err)}

/* ============================================================
   CUSTOMER MODAL — header fixo + diagnóstico de recuperação
   ============================================================ */
.cust-modal-box{max-width:min(1900px,95vw);width:95vw;
  height:92vh;max-height:95vh;display:flex;flex-direction:column;
  overflow:hidden;padding:0;transition:all .2s}
.cust-modal-box.fullscreen{max-width:100vw;width:100vw;height:100vh;
  max-height:100vh;border-radius:0}
.cust-fs-btn{background:transparent;border:0;color:var(--mut);cursor:pointer;
  padding:6px 8px;border-radius:6px;display:inline-flex;align-items:center}
.cust-fs-btn:hover{background:var(--panel2);color:var(--txt)}
/* Tabs */
.cust-tabs{display:flex;gap:2px;padding:0 24px;background:var(--panel);
  border-bottom:1px solid var(--line);flex-shrink:0;overflow-x:auto}
.cust-tab{background:transparent;border:0;border-bottom:2px solid transparent;
  padding:11px 14px 10px;color:var(--mut);font:inherit;font-size:13px;
  font-weight:600;cursor:pointer;white-space:nowrap;
  display:inline-flex;align-items:center;gap:7px;transition:all .15s}
.cust-tab:hover{color:var(--txt);background:color-mix(in srgb,var(--acc) 6%,transparent)}
.cust-tab.on{color:var(--acc);border-bottom-color:var(--acc)}
.cust-tab .ct-count{background:var(--panel2);color:var(--txt-2);font-size:10.5px;
  padding:1px 6px;border-radius:9px;font-weight:700;font-variant-numeric:tabular-nums}
.cust-tab.on .ct-count{background:color-mix(in srgb,var(--acc) 18%,transparent);color:var(--acc)}
/* Audit chip reutilizável */
.audit-chip{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;
  color:var(--mut);background:var(--panel2);border:1px solid var(--line);
  padding:2px 8px;border-radius:8px;font-weight:500}
.audit-chip b{color:var(--txt-2);font-weight:700}
.cust-header{padding:18px 24px 16px;background:var(--panel);
  border-bottom:1px solid var(--line);flex-shrink:0;
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.cust-header-l{display:flex;gap:14px;align-items:flex-start;min-width:0;flex:1}
.cust-avatar{background:rgba(245,166,35,.12);color:var(--acc);
  border-radius:10px;padding:9px;display:inline-flex;flex-shrink:0}
.cust-id{min-width:0;flex:1}
.cust-id h2{font-size:19px;font-weight:600;letter-spacing:-.3px;
  line-height:1.2;color:var(--txt);margin:0}
.cust-id-meta{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:6px;
  font-size:12px;color:var(--mut)}
.cust-id-meta span{white-space:nowrap}
.cust-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.cust-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;
  font-weight:600;letter-spacing:.2px;padding:4px 9px;border-radius:14px;
  border:1px solid;text-transform:none}
.cust-badge.good{background:rgba(63,207,142,.10);border-color:rgba(63,207,142,.32);color:var(--ok)}
.cust-badge.warn{background:rgba(255,182,72,.10);border-color:rgba(255,182,72,.35);color:var(--warn)}
.cust-badge.bad{background:rgba(255,107,107,.10);border-color:rgba(255,107,107,.32);color:var(--err)}
.cust-badge.neutral{background:var(--panel2);border-color:var(--line);color:var(--mut)}

.cust-body{flex:1;overflow-y:auto;padding:18px 24px 24px;background:var(--bg)}

/* KPI row compacto */
.cust-kpi-row{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin-bottom:16px}
.cust-kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:10px 12px}
.cust-kpi-h{font-size:10px;color:var(--mut);text-transform:uppercase;
  letter-spacing:.5px;font-weight:600;margin-bottom:4px}
.cust-kpi-v{font-size:18px;font-weight:650;letter-spacing:-.3px;color:var(--txt);
  line-height:1.2}
.cust-kpi-v.small{font-size:13px;font-weight:600}
.cust-kpi-v.good{color:var(--ok)}
.cust-kpi-v.bad{color:var(--err)}
.cust-kpi-v.warn{color:var(--warn)}
@media(max-width:1100px){.cust-kpi-row{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px){.cust-kpi-row{grid-template-columns:repeat(2,1fr)}}

/* Diagnóstico — card central premium */
.cust-diag{background:linear-gradient(135deg,rgba(245,166,35,.07),rgba(91,141,239,.05));
  border:1px solid var(--line);border-left:3px solid var(--acc);
  border-radius:12px;padding:16px 18px;margin-bottom:16px}
.cust-diag-h{display:flex;align-items:center;gap:9px;color:var(--txt);
  font-size:14px;font-weight:600;margin-bottom:14px;letter-spacing:-.1px}
.cust-diag-h .ic{color:var(--acc)}
.cust-diag-class{margin-left:auto;display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:600;padding:5px 10px;border-radius:14px;
  text-transform:uppercase;letter-spacing:.4px;border:1px solid}
.cust-diag-ok{background:rgba(63,207,142,.10);border-color:rgba(63,207,142,.35);color:var(--ok)}
.cust-diag-warn{background:rgba(255,182,72,.10);border-color:rgba(255,182,72,.35);color:var(--warn)}
.cust-diag-err{background:rgba(255,107,107,.10);border-color:rgba(255,107,107,.35);color:var(--err)}
.cust-diag-acc2{background:rgba(91,141,239,.10);border-color:rgba(91,141,239,.35);color:var(--acc2)}
.cust-diag-mut{background:var(--panel2);border-color:var(--line);color:var(--mut)}
.cust-diag-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.cust-diag-grid>div:first-child{grid-row:span 2}
.cust-diag-acao{grid-column:1 / -1;border-top:1px solid var(--line);padding-top:12px}
.cust-diag-lbl{font-size:10.5px;color:var(--mut);text-transform:uppercase;
  letter-spacing:.6px;font-weight:600;margin-bottom:5px}
.cust-diag-val{font-size:13.5px;color:var(--txt);line-height:1.45;font-weight:500}
.cust-diag-meta{font-size:11.5px;color:var(--txt-3);margin-top:4px;font-weight:500}
.cust-diag-meta b{color:var(--txt-2);font-weight:700}
.cust-diag-detail{font-size:11.5px;color:var(--txt-3);margin-top:6px;padding:6px 10px;
  background:var(--panel-2);border-radius:8px;border-left:2px solid var(--amber);
  line-height:1.4;font-style:italic}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot-ok{background:var(--ok);box-shadow:0 0 8px rgba(63,207,142,.5)}
.dot-warn{background:var(--warn);box-shadow:0 0 8px rgba(255,182,72,.5)}
.dot-bad{background:var(--err);box-shadow:0 0 8px rgba(255,107,107,.5)}
.dot-acc2{background:var(--acc2);box-shadow:0 0 8px rgba(91,141,239,.5)}
@media(max-width:780px){.cust-diag-grid{grid-template-columns:1fr}.cust-diag-grid>div:first-child{grid-row:auto}.cust-diag-acao{grid-column:auto}}

/* Grid 2 colunas reutilizado */
.cust-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
@media(max-width:980px){.cust-grid-2{grid-template-columns:1fr}}

/* Timeline */
.cust-timeline{display:flex;flex-direction:column;gap:10px;max-height:340px;
  overflow-y:auto;padding-right:4px}
.cust-evt{display:flex;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--line);
  position:relative}
.cust-evt:last-child{border-bottom:0}
.cust-evt-ic{flex-shrink:0;width:26px;height:26px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--panel2);border:1px solid var(--line)}
.cust-evt-ok .cust-evt-ic{color:var(--ok);border-color:rgba(63,207,142,.4)}
.cust-evt-warn .cust-evt-ic{color:var(--warn);border-color:rgba(255,182,72,.4)}
.cust-evt-bad .cust-evt-ic{color:var(--err);border-color:rgba(255,107,107,.4)}
.cust-evt-acc2 .cust-evt-ic{color:var(--acc2);border-color:rgba(91,141,239,.4)}
.cust-evt-neutral .cust-evt-ic{color:var(--mut)}
.cust-evt-body{flex:1;min-width:0}
.cust-evt-h{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.cust-evt-h b{font-size:13px;color:var(--txt);font-weight:600}
.cust-evt-d{font-size:11.5px;color:var(--mut);white-space:nowrap;font-variant-numeric:tabular-nums}
.cust-evt-sub{font-size:12px;color:var(--mut);margin-top:2px;line-height:1.4}

/* Saúde financeira */
.cust-finance{background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:14px 16px;margin-bottom:16px}
.cust-finance-h{display:flex;align-items:center;gap:8px;font-size:13px;
  font-weight:600;color:var(--txt);margin-bottom:12px}
.cust-finance-h .ic{color:var(--acc)}
.cust-finance-status{margin-left:auto;display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:600;padding:4px 9px;border-radius:12px;
  text-transform:uppercase;letter-spacing:.4px;border:1px solid}
.cust-finance-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.cust-finance-grid>div{display:flex;flex-direction:column;gap:3px}
.cust-finance-grid span{font-size:10.5px;color:var(--mut);text-transform:uppercase;
  letter-spacing:.4px;font-weight:600}
.cust-finance-grid b{font-size:15px;font-weight:650;color:var(--txt)}
.cust-finance-grid b.good{color:var(--ok)}
.cust-finance-grid b.warn{color:var(--warn)}
.cust-finance-grid b.bad{color:var(--err)}
@media(max-width:980px){.cust-finance-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.cust-finance-grid{grid-template-columns:repeat(2,1fr)}}

/* Details expansíveis */
.cust-details{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  margin-bottom:10px}
.cust-details summary{display:flex;align-items:center;gap:8px;padding:11px 14px;
  cursor:pointer;font-size:13px;font-weight:600;color:var(--mut);
  user-select:none;list-style:none}
.cust-details summary::-webkit-details-marker{display:none}
.cust-details summary:hover{color:var(--txt)}
.cust-details summary .ic{transition:transform .2s}
.cust-details[open] summary .ic{transform:rotate(180deg)}
.cust-details[open] summary{color:var(--acc);border-bottom:1px solid var(--line)}
.cust-details > *:not(summary){padding:0 14px 14px}

/* Badge "possível mesma compra" — VTEX↔Olist↔Pagar.me */
.qb.qb-link{background:rgba(91,141,239,.12);border:1px solid rgba(91,141,239,.32);
  color:var(--acc2);font-size:9.5px;font-weight:600;letter-spacing:.3px;
  text-transform:uppercase;padding:2px 6px;border-radius:5px;
  display:inline-flex;align-items:center;gap:3px;vertical-align:middle;margin-right:6px}
.qb.qb-link .ic{color:var(--acc2)}
tr.prow.sib td{background:rgba(91,141,239,.04)}
tr.prow.sib:hover td{background:rgba(91,141,239,.10)}

/* ============================================================
   VENDAS POR CANAL — analítico tipo Power BI
   ============================================================ */
.vc-filters{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:14px;
  padding:12px 14px;background:var(--panel);border:1px solid var(--line);
  border-radius:10px}
.vc-fgroup{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.vc-flbl{font-size:10px;color:var(--mut);text-transform:uppercase;
  letter-spacing:.7px;font-weight:600;margin-right:4px}
.vc-pill{background:var(--panel2);border:1px solid var(--line);color:var(--mut);
  padding:5px 11px;border-radius:14px;cursor:pointer;font:inherit;
  font-size:11.5px;font-weight:500;transition:.15s;font-family:inherit}
.vc-pill:hover{border-color:var(--acc);color:var(--txt)}
.vc-pill.on{background:rgba(245,166,35,.15);border-color:var(--acc);color:var(--acc);font-weight:600}
.vc-kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:14px}
@media(max-width:1100px){.vc-kpi-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.vc-kpi-row{grid-template-columns:repeat(2,1fr)}}
.vc-kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:11px 13px}
.vc-kpi-lbl{font-size:10px;color:var(--mut);text-transform:uppercase;
  letter-spacing:.5px;font-weight:600;margin-bottom:5px}
.vc-kpi-val{font-size:21px;font-weight:650;letter-spacing:-.4px;color:var(--txt);line-height:1.1}
.vc-kpi.good .vc-kpi-val{color:var(--ok)}
.vc-kpi-sub{font-size:11px;color:var(--mut);margin-top:3px}
.vc-insights{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.vc-insight{display:inline-flex;align-items:center;gap:8px;
  background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.25);
  border-radius:8px;padding:7px 11px;font-size:12.5px;color:var(--txt);line-height:1.35}
.vc-insight .ic{color:var(--acc);flex-shrink:0}
tr.vc-row{cursor:pointer}
tr.vc-row:hover td{background:rgba(245,166,35,.06)}

/* ============================================================
   HEADER + TOPBAR (light/dark theme aware)
   ============================================================ */
header{display:flex;justify-content:space-between;align-items:center;
  padding:18px 28px;gap:20px;
  background:color-mix(in srgb,var(--page) 86%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20}
header h1{font-size:22px;font-weight:800;letter-spacing:-.025em;color:var(--txt)}
header .sub{color:var(--txt-2);font-size:13px;font-weight:500;margin-top:1px}
.hd-right{display:flex;align-items:center;gap:12px}

/* Theme toggle pill */
.theme-toggle{display:flex;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:3px;gap:2px}
.theme-toggle button{width:34px;height:30px;border:0;background:transparent;
  border-radius:7px;color:var(--txt-3);cursor:pointer;
  display:grid;place-items:center;transition:all .15s}
.theme-toggle button svg{width:16px;height:16px}
.theme-toggle button:hover{color:var(--txt)}
.theme-toggle button.on{background:var(--amber-soft);color:var(--amber-strong)}
[data-theme="dark"] .theme-toggle button.on{color:var(--amber)}

#refresh{background:var(--panel);border:1px solid var(--line);color:var(--txt-2);
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
#refresh:hover{color:var(--txt);border-color:var(--txt-3)}
.pill{font-size:18px;color:var(--txt-3)}
.pill.ok{color:var(--green)}.pill.err{color:var(--red)}

/* User chip (dropdown trigger no header) */
.usravatar{display:flex;align-items:center;gap:9px;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;padding:5px 11px 5px 5px;
  cursor:pointer;font-weight:600;color:var(--txt);font-family:inherit}
.usravatar:hover{border-color:var(--txt-3)}
.usravatar-ini{width:30px;height:30px;border-radius:7px;background:var(--ink);
  color:var(--amber);display:grid;place-items:center;
  font-size:11px;font-weight:800;letter-spacing:.02em}
.usravatar-nome{font-weight:600;font-size:13px}
.usravatar-chev{color:var(--txt-3);margin-left:1px;display:inline-flex;align-items:center}

#content{padding:22px 28px 40px;display:flex;flex-direction:column;gap:18px;overflow:auto}

/* ============================================================
   CARDS / KPI / BANNER (novo design)
   ============================================================ */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:20px 22px;display:flex;flex-direction:column}
/* KPI grid + card defined in the consolidated block further below (compact redesign) */

/* Banner (Visão do gestor) — destaque amber */
.insight,.banner{background:linear-gradient(100deg,var(--amber-soft),
  color-mix(in srgb,var(--amber-soft) 30%,var(--panel)));
  border:1px solid color-mix(in srgb,var(--amber) 30%,transparent);
  border-left:4px solid var(--amber);border-radius:0 var(--radius) var(--radius) 0;
  padding:16px 18px;font-size:13.5px;line-height:1.55;color:var(--txt)}
.insight b{font-weight:800;color:var(--amber-strong)}
[data-theme="dark"] .insight b{color:var(--amber)}

/* ── FILTERBAR — search + popovers (replaces legacy .fbar/.fcell/.fbtn) ─── */
#filterbar{display:none;background:transparent;border:0;
  padding:18px 28px 0;position:static;overflow:visible}
#filterbar.on{display:block}

#filterbar .toolbar{background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius,16px);box-shadow:var(--shadow-sm);
  padding:14px 16px;display:block}
#filterbar .filterbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px}

/* Search */
#filterbar .search{flex:1;min-width:240px;height:44px;
  display:flex;align-items:center;gap:11px;padding:0 8px 0 15px;
  border:1px solid var(--line);background:var(--panel-2,var(--panel2));
  border-radius:12px;color:var(--txt);cursor:text;
  transition:border-color .15s,box-shadow .15s}
#filterbar .search:focus-within{border-color:var(--blue);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 18%,transparent)}
#filterbar .search svg,#filterbar .search .ic{width:18px;height:18px;
  color:var(--txt-3);flex-shrink:0}
#filterbar .search input{flex:1;min-width:0;border:none;background:transparent;
  outline:none;font-family:inherit;font-size:14px;font-weight:500;color:var(--txt);
  padding:0;height:auto}
#filterbar .search input::placeholder{color:var(--txt-3);font-weight:500}
#filterbar .search-x{width:26px;height:26px;border:none;background:transparent;
  border-radius:7px;color:var(--txt-3);cursor:pointer;
  display:grid;place-items:center;flex-shrink:0;font-family:inherit}
#filterbar .search-x svg{width:14px;height:14px}
#filterbar .search-x:hover{background:color-mix(in srgb,var(--txt-3) 18%,transparent);
  color:var(--txt)}
#filterbar .search-x[hidden]{display:none}

/* Segmented popover triggers */
#filterbar .seg{height:44px;display:inline-flex;align-items:center;gap:9px;
  padding:0 14px;border:1px solid var(--line);
  background:var(--panel-2,var(--panel2));border-radius:12px;
  font-size:13.5px;font-weight:600;color:var(--txt);cursor:pointer;
  font-family:inherit;transition:border-color .15s;white-space:nowrap}
#filterbar .seg:hover{border-color:var(--txt-3)}
#filterbar .seg svg,#filterbar .seg .ic{width:16px;height:16px;
  color:var(--txt-3);flex-shrink:0}
#filterbar .seg .chev{margin-left:1px}
#filterbar .seg.has-filters{border-color:var(--blue);color:var(--blue)}
#filterbar .seg.has-filters svg{color:var(--blue)}

/* Spacer */
#filterbar .fb-spacer{flex:1;min-width:0}
@media(max-width:760px){#filterbar .fb-spacer{display:none}}

/* Aplicar (primary btn) */
#filterbar .btn{height:44px;border-radius:12px;padding:0 18px;
  font-weight:700;font-size:13.5px;border:1px solid var(--line);
  background:var(--panel);color:var(--txt);cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  font-family:inherit;transition:all .15s}
#filterbar .btn svg,#filterbar .btn .ic{width:15px;height:15px}
#filterbar .btn:hover{border-color:var(--txt-3)}
#filterbar .btn.primary{background:var(--amber);border-color:var(--amber);
  color:#2A1F06;
  box-shadow:0 1px 0 rgba(0,0,0,.04),0 4px 14px -4px rgba(252,181,0,.5)}
#filterbar .btn.primary:hover{background:var(--amber-strong)}

/* Icon-only round buttons (clear + refresh) */
#filterbar .icon-btn{width:44px;height:44px;border-radius:12px;
  background:var(--panel-2,var(--panel2));border:1px solid var(--line);
  color:var(--txt-2);display:grid;place-items:center;cursor:pointer;
  font-family:inherit;transition:all .15s}
#filterbar .icon-btn:hover{color:var(--txt);border-color:var(--txt-3)}
#filterbar .icon-btn svg,#filterbar .icon-btn .ic{width:18px;height:18px}

@media(max-width:860px){
  #filterbar{padding:12px 16px 0}
  #filterbar .search{flex:1 1 100%}
}

/* ── SOURCES BAR — condensed inline (replaces legacy .sources) ─── */
.sources-bar{display:flex;flex-wrap:wrap;align-items:center;
  gap:4px 0;padding:8px 4px 0;margin:0;
  font-size:12.5px;color:var(--txt-2);font-weight:500}
.sources-bar .sync{display:inline-flex;align-items:center;gap:8px;
  font-weight:700;color:var(--txt);padding-right:14px}
.sources-bar .pulse{position:relative;width:8px;height:8px;border-radius:50%;
  background:var(--green)}
.sources-bar .pulse::after{content:"";position:absolute;inset:-4px;
  border-radius:50%;background:var(--green);opacity:.25;
  animation:ping 2.4s ease-out infinite}
.sources-bar .srcs{display:flex;flex-wrap:wrap;align-items:center}
.sources-bar .src-item{display:inline-flex;align-items:center;gap:6px;
  padding:0 13px;border-left:1px solid var(--line);color:var(--txt-2)}
.sources-bar .src-item:first-child{border-left:0;padding-left:0}
.sources-bar .src-item b{color:var(--txt);font-weight:700}
.sources-bar .src-item em{font-style:normal;color:var(--txt-3);font-weight:500}

/* Mantém a chave @keyframes ping caso ela tenha sido usada antes */
@keyframes ping{0%{transform:scale(.6);opacity:.35}80%,100%{transform:scale(1.9);opacity:0}}

/* Compat: força a versão antiga (.sources com .src/.lead) a usar o novo layout
   se aparecer dentro do filterbar */
#filterbar .sources{display:none}

/* ── POPOVERS (período / filtros) ───────────────────── */
.pop-wrap{position:relative}
.pop-wrap .seg .badge{min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:var(--blue);color:#fff;
  font-size:11px;font-weight:800;
  display:inline-grid;place-items:center;font-variant-numeric:tabular-nums}
.pop-wrap .seg .badge[hidden]{display:none}

.popover{position:absolute;top:calc(100% + 8px);left:auto;right:0;z-index:60;
  width:320px;max-width:min(360px,calc(100vw - 48px));min-width:0;
  background:var(--panel);border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 18px 44px -16px rgba(32,34,36,.4);
  padding:16px;display:flex;flex-direction:column;gap:12px;
  max-height:calc(100vh - 120px);overflow-x:hidden;overflow-y:auto;
  animation:popIn .14s ease}
[data-theme="dark"] .popover{box-shadow:0 22px 50px -18px rgba(0,0,0,.8)}
.popover.wide{width:340px;max-width:min(380px,calc(100vw - 48px))}
.popover.align-left{left:0;right:auto}
.popover.align-right{left:auto;right:0}
.popover[hidden]{display:none}
.pop-field input,.pop-field select,.pop-field input[type=date]{width:100%;min-width:0}
.pop-field input[type=date]{padding:0 8px}
@keyframes popIn{from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}}

/* Narrow-viewport fallback: stack De/Até vertically before mobile sheet kicks in */
@media (max-width: 380px){
  .popover .pop-row{grid-template-columns:1fr}
  .popover{width:auto} /* mobile-sheet already handles this but be explicit */
}

/* Popover responsive — bottom sheet up to 900px (covers wrapped filterbar) */
@media(max-width:900px){
  .popover,.popover.wide{
    position:fixed;left:8px;right:8px;bottom:8px;top:auto;
    transform:none;width:auto;max-width:none;
    max-height:calc(100vh - 80px);overflow-y:auto;
    border-radius:20px;z-index:80;
    padding:18px 16px calc(18px + env(safe-area-inset-bottom));
    box-shadow:0 -18px 50px -10px rgba(0,0,0,.45);
    animation:popSheetIn .22s cubic-bezier(.16,1,.3,1)}
  [data-theme="dark"] .popover,
  [data-theme="dark"] .popover.wide{
    box-shadow:0 -22px 60px -14px rgba(0,0,0,.75)}
  .popover .pop-row{grid-template-columns:1fr}
  body:has(#filterbar .popover:not([hidden]))::after{
    content:"";position:fixed;inset:0;
    background:rgba(0,0,0,.4);z-index:55;
    animation:popFadeIn .18s ease;pointer-events:none}
}
/* iOS Safari URL-bar safe dvh fallback for bottom sheet */
@supports(height:1dvh){
  @media(max-width:900px){
    .popover,.popover.wide{max-height:calc(100dvh - 120px)}
  }
}
/* Borderline desktop range 901-1100px: anchor popovers to .filterbar edges
   to prevent left-edge clipping when the toolbar nearly wraps */
@media (min-width: 901px) and (max-width: 1100px){
  .pop-wrap{position:static}
  .filterbar{position:relative}
  .popover{left:16px;right:auto}
  .popover.wide{left:auto;right:16px}
}
@keyframes popSheetIn{from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}}
@keyframes popFadeIn{from{opacity:0}to{opacity:1}}

.pop-title{font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--txt-3)}

.preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.preset{height:36px;border-radius:9px;border:1px solid var(--line);
  background:var(--panel-2,var(--panel2));color:var(--txt);
  font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;
  transition:all .14s}
.preset:hover{border-color:var(--txt-3)}
.preset.is-active{background:var(--amber-soft);
  border-color:color-mix(in srgb,var(--amber) 45%,transparent);
  color:var(--amber-strong)}
[data-theme="dark"] .preset.is-active{color:var(--amber)}

.pop-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:0}
.pop-field{display:flex;flex-direction:column;gap:5px;min-width:0}
.pop-field span{font-size:11px;font-weight:700;letter-spacing:.04em;
  color:var(--txt-2)}
.pop-field input,.pop-field select{height:38px;border:1px solid var(--line);
  background:var(--panel-2,var(--panel2));border-radius:9px;padding:0 10px;
  color:var(--txt);font-family:inherit;font-size:13px;font-weight:500;
  outline:none;width:100%;min-width:0}
.pop-field input:focus,.pop-field select:focus{border-color:var(--blue)}
.pop-field select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239C947F' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
  background-size:16px;padding-right:30px}
[data-theme="dark"] .pop-field input[type=date]{color-scheme:dark}

.pop-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:2px}
.btn.sm{height:34px;padding:0 14px;font-size:12.5px;border-radius:9px}

/* Loading / refresh feedback */
.refreshing svg{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.kpis.loading,.grid-2.loading,.kgrid.loading,.grid.loading{opacity:.45;
  transition:opacity .2s;pointer-events:none}

/* ============================================================
   Tabelas refinadas (light theme)
   ============================================================ */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--txt-3);padding:0 0 12px;
  border-bottom:1px solid var(--line)}
td{padding:13px 0;border-bottom:1px solid var(--line-2);font-weight:600;color:var(--txt)}
tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr:hover td{background:transparent}

/* ============================================================
   Mobile responsivo
   ============================================================ */
@media(max-width:860px){
  body{display:flex}
  #nav{position:fixed;top:0;left:0;height:100vh;z-index:30;
    box-shadow:6px 0 24px rgba(0,0,0,.3);padding:16px 0}
  body:not(.nav-open) #nav{width:0;padding:0}
  body:not(.nav-open) #nav>*{display:none}
  body.nav-open #nav{width:96px}
  #navToggle{display:flex}
  header{padding:14px 18px}
  header h1{font-size:18px}
  #content{padding:14px}
}

/* ── WELCOME / GREETING ─────────────────────────────── */
#greeting{padding:6px 28px 0;display:none}
#greeting.on{display:block}
/* Suporta tanto .greet legado quanto a nova .welcome — CSS unificado. */
.welcome,.greet{margin:2px 0 0;padding:8px 0 4px}
.welcome-title,.greet h2{font-size:34px;font-weight:800;letter-spacing:-.035em;
  line-height:1.05;color:var(--txt);margin:0}
.welcome-title .u-name,.greet h2 span{color:var(--blue)}
.welcome-sub,.greet p{font-size:15px;color:var(--txt-2);font-weight:500;
  margin-top:6px}

/* ============================================================
   KPI CARDS — COMPACT REDESIGN
   Auto-fit grid so partial rows never leave dead columns.
   Tighter padding, smaller value/icon, no forced min-height.
   ============================================================ */
.kgrid,.kpis{display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;
  flex-wrap:nowrap;overflow-x:visible}
.kgrid > *,.kpis > *{min-width:0;flex:initial}
@media(max-width:1180px){
  .kgrid,.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
}
@media(max-width:640px){
  .kgrid,.kpis{grid-template-columns:repeat(2,1fr)}
}

.kpi,.card.kpi{background:var(--panel);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-sm);padding:13px 15px 11px;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:box-shadow .2s,transform .2s,border-color .2s}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px);
  border-color:color-mix(in srgb,var(--amber) 40%,var(--line))}

/* Label — current markup uses .kpi h3; alias .kpi-label / .kpi-top */
.kpi h3,.kpi .kpi-label,.kpi .kpi-top{
  font-size:10px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--txt-2);margin:0;
  padding-right:32px}

/* Value — current markup uses .kpi .big; alias .kpi-val */
.kpi .big,.kpi .kpi-val{
  font-size:26px;font-weight:800;letter-spacing:-.03em;line-height:1;
  margin:10px 0 6px;color:var(--txt);font-variant-numeric:tabular-nums}
.kpi .big span,.kpi .kpi-val span{
  font-size:14px;font-weight:700;letter-spacing:0;
  margin-left:2px;color:var(--txt-2)}

.kpi.good .big,.kpi.good .kpi-val{color:var(--green)}
.kpi.bad .big,.kpi.bad .kpi-val{color:var(--red)}
.kpi.warn .big,.kpi.warn .kpi-val{color:var(--amber-strong)}
[data-theme="dark"] .kpi.warn .big,
[data-theme="dark"] .kpi.warn .kpi-val{color:var(--amber)}

/* Footer / note — current markup uses .kpi .sub; alias .kpi-note / .kpi-foot */
.kpi .sub,.kpi .kpi-note,.kpi .kpi-foot{
  font-size:11px;color:var(--txt-3);font-weight:500;margin-top:auto;
  display:flex;align-items:center;gap:6px;justify-content:space-between}

/* Icon top-right (smaller box, same placement) */
.kpi-ic{position:absolute;top:12px;right:12px;width:26px;height:26px;
  border-radius:8px;display:grid;place-items:center;
  background:var(--panel2);color:var(--txt-3)}
.kpi-ic svg,.kpi-ic .ic{width:14px;height:14px}

/* Delta chip */
.kpi .delta{display:inline-flex;align-items:center;gap:3px;font-size:11px;
  font-weight:700;padding:2px 7px;border-radius:6px}
.kpi .delta.up{color:var(--green);background:color-mix(in srgb,var(--green) 12%,transparent)}
.kpi .delta.down{color:var(--red);background:color-mix(in srgb,var(--red) 12%,transparent)}

/* Link "ver detalhe →" */
.kpi .link,.kpi .kpi-link{font-size:11px;font-weight:700;
  color:var(--amber-strong);text-decoration:none;
  display:inline-flex;align-items:center;gap:3px;cursor:pointer}
[data-theme="dark"] .kpi .link,
[data-theme="dark"] .kpi .kpi-link{color:var(--amber)}

/* Defensive — prevent cards introducing isolation that traps nav tooltip */
.card,.kpi,.banner,.insight,#filterbar .toolbar{isolation:auto}

/* KPI FEATURED (gradient amber, slightly more lift, still compact) */
.kpi.featured{background:linear-gradient(105deg,#F2A600 0%,#FCB500 46%,#FFCB33 100%);
  border-color:#E6A400;color:#2A1F06;
  padding:14px 16px 12px;
  box-shadow:0 6px 18px -12px rgba(226,164,0,.55)}
.kpi.featured:hover{border-color:#E6A400;
  box-shadow:0 10px 28px -14px rgba(226,164,0,.7)}
.kpi.featured h3,.kpi.featured .kpi-label{color:#5A4206}
.kpi.featured .big,.kpi.featured .big.good,.kpi.featured .kpi-val{color:#1E1602}
.kpi.featured .big span,.kpi.featured .kpi-val span{color:#4A3705}
.kpi.featured .kpi-ic{background:rgba(32,22,2,.13);color:#4A3705}
.kpi.featured .sub,.kpi.featured .kpi-note,.kpi.featured .kpi-foot{color:#5A4206}
.kpi.featured .link,.kpi.featured .kpi-link{color:#2A1F06}
.kpi.featured .delta.up{color:#1E5233;background:rgba(255,255,255,.5)}

/* ============================================================
   USER CHIP HEADER (avatar com letras + nome + chevron)
   ============================================================ */
.usravatar{display:flex;align-items:center;gap:9px;background:var(--panel);
  border:1px solid var(--line);border-radius:11px;padding:5px 12px 5px 5px;
  cursor:pointer;font-weight:600;color:var(--txt);font-family:inherit;height:38px}
.usravatar:hover{border-color:var(--txt-3)}
.usravatar-ini{width:30px;height:30px;border-radius:8px;background:var(--ink);
  color:var(--amber);display:grid;place-items:center;
  font-size:11.5px;font-weight:800;letter-spacing:.02em}
.usravatar-nome{font-weight:600;font-size:13px}
.usravatar-chev{color:var(--txt-3);margin-left:1px;display:inline-flex;align-items:center}

#refresh,.hdr-icon-btn{background:var(--panel);border:1px solid var(--line);
  color:var(--txt-2);width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:all .15s;
  font-family:inherit}
#refresh:hover,.hdr-icon-btn:hover{color:var(--txt);border-color:var(--txt-3)}

/* ── TOAST ──────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;
  font-size:13px;font-weight:600;
  padding:12px 20px;border-radius:11px;
  box-shadow:0 14px 40px -12px rgba(0,0,0,.5);
  opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;z-index:200;
  display:flex;align-items:center;gap:9px;font-family:inherit}
[data-theme="dark"] .toast{background:#000;color:var(--amber);
  border:1px solid var(--line)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg,.toast .ic{width:16px;height:16px;color:var(--green)}

/* ============================================================
   Mobile responsive
   ============================================================ */
@media(max-width:860px){
  body{padding-left:0}
}
@media(max-width:640px){
  #nav{position:fixed;top:0;left:0;height:100vh;z-index:30;
    box-shadow:6px 0 24px rgba(0,0,0,.3);padding:16px 0}
  body:not(.nav-open) #nav{width:0;padding:0}
  body:not(.nav-open) #nav>*{display:none}
  body.nav-open #nav{width:96px}
  #navToggle{display:flex}
  #greeting{padding:6px 16px 0}
  .greet h2,.welcome-title{font-size:24px}
  #content{padding:14px}
}
