/* ── RESET & VARS ──────────────────────────────────────── */
:root{
  --bg:#09090F;--surface:#0F0F1A;--surface2:#141425;--surface3:#1A1A2E;
  --border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.1);
  --text:#EEEEFF;--sub:#8888AA;--muted:#555570;
  --blue:#0093FF;--cyan:#00E2C9;--green:#00C97A;--purple:#8B5CF6;
  --red:#FF4438;--yellow:#F59E0B;--orange:#F97316;
  --tech:#0093FF;--teal:#00E2C9;--alert:#FF4438;--amber:#F59E0B;
  --grad:linear-gradient(135deg,var(--blue),var(--cyan));
  --sb-w:220px;--top-h:50px;
  --card:var(--surface);--card2:var(--surface2);--bg3:var(--surface2);
  --r:14px;--sidebar:220px;
}
body.light{
  --bg:#F0F2F8;--surface:#FFFFFF;--surface2:#F8F9FC;--surface3:#EEF0F8;
  --border:rgba(0,0,0,.07);--border2:rgba(0,0,0,.12);
  --text:#0A0A1A;--sub:#64748B;--muted:#94A3B8;
}
body.light .topbar{background:rgba(240,242,248,.95);color:var(--text);border-bottom:1px solid var(--border)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:13px;-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;display:flex;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}
.sb,.topbar,.card,.kpi{transition:background .3s,border-color .3s,color .3s}

/* ── SIDEBAR (Visual Prime) ────────────────────────────── */
.sb{width:var(--sb-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto}
.sb::-webkit-scrollbar{width:0}
.sb-brand{padding:18px 16px 14px;border-bottom:1px solid var(--border);text-align:center}
.sb-brand-logo{height:56px;width:auto;max-width:170px;object-fit:contain;display:inline-block}
.sb-logo{height:56px;width:auto;max-width:170px;object-fit:contain;display:inline-block;mix-blend-mode:screen}
.sb-brand .brand-name{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--text);background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sb-brand .tagline{font-size:9px;color:var(--muted);letter-spacing:.08em;font-weight:600;text-transform:uppercase;margin-top:4px;text-align:center;display:block;width:100%}

.nav{padding:8px 0;flex:1;overflow-y:auto}
.nav::-webkit-scrollbar{width:0}
.nav-sec{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:12px 16px 4px}
.nav-sec:first-child{margin-top:0}
.nav-item{display:flex;align-items:center;gap:8px;padding:7px 14px;margin:1px 8px;border-radius:7px;cursor:pointer;color:var(--sub);font-size:12px;font-weight:500;transition:all .15s;border:1px solid transparent}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:rgba(0,147,255,.12);color:var(--blue);font-weight:600}
.ni{width:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:.7;transition:opacity .15s}
.nav-item:hover .ni,.nav-item.active .ni{opacity:1}

.sb-footer{padding:12px;border-top:1px solid var(--border)}
.sb-user{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;background:var(--surface2)}
.sb-avatar{width:28px;height:28px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.sb-uname{font-size:11px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.sb-urole{font-size:9px;color:var(--muted)}
.btn-sair{background:none;border:1px solid var(--border2);border-radius:5px;cursor:pointer;color:var(--muted);font-size:9px;padding:2px 6px;font-family:inherit;font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:all .15s}
.btn-sair:hover{border-color:var(--red);color:var(--red)}

/* ── MAIN ──────────────────────────────────────────────── */
.main{margin-left:var(--sb-w);flex:1;display:flex;flex-direction:column;min-width:0}

/* ── TOPBAR (Visual Prime) ─────────────────────────────── */
.topbar{background:rgba(15,15,26,.94);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:0 22px;height:var(--top-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.tb-left{display:flex;align-items:center;gap:10px}
.pg-title{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.pg-period{font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px;background:rgba(0,147,255,.1);border:1px solid rgba(0,147,255,.2);color:var(--blue);letter-spacing:.04em}
.tb-right{display:flex;align-items:center;gap:6px}

.toggle-v{display:flex;align-items:center;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;padding:2px;gap:2px}
.tv{padding:4px 10px;border-radius:5px;font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--sub);transition:all .15s}
.tv.on{background:var(--blue);color:#09090F}

.sel{height:30px;padding:0 26px 0 10px;border:1px solid var(--border2);border-radius:7px;background:var(--surface2);font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:500;color:var(--text);cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='5'%3E%3Cpath d='M0 0l4.5 5L9 0z' fill='%238888AA'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .15s}
.sel:focus,.sel:hover{border-color:var(--blue)}
.sel option{background:var(--surface2);color:var(--text)}

.btn{height:30px;padding:0 12px;border-radius:7px;font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:600;cursor:pointer;border:1px solid var(--border2);background:var(--surface2);color:var(--sub);transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.btn:hover{border-color:var(--blue);color:var(--blue)}
.btn-p{background:var(--grad);color:#09090F;border:none;font-weight:700}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,147,255,.3);color:#09090F;border:none}
.btn-g{background:var(--surface2);color:var(--sub);border:1px solid var(--border2)}
.btn-g:hover{border-color:var(--blue);color:var(--blue)}

/* ── CONTENT ───────────────────────────────────────────── */
.content{padding:18px 22px 50px;display:flex;flex-direction:column;gap:14px}
.chips{display:flex;gap:5px;flex-wrap:wrap;min-height:20px}
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:600;background:rgba(0,147,255,.06);color:var(--blue);border:1px solid rgba(0,147,255,.1)}
.chip-x{cursor:pointer;opacity:.45;transition:opacity .1s;font-size:11px}
.chip-x:hover{opacity:1}

/* Section header */
.sh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:10px}
.sh-ey{font-size:8px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.sh-title{font-size:13px;font-weight:800;color:var(--text);letter-spacing:-.02em}
.sh-r{font-size:9px;color:var(--muted)}

/* ── KPI STRIP (Visual Prime — densidade DRE) ─────────── */
.kpi-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:8px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:11px 13px;position:relative;overflow:hidden;transition:all .2s;cursor:default;min-height:78px}
.kpi:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 4px 20px rgba(0,0,0,.3)}
.kpi::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--r) var(--r) 0 0}
.kpi.kb::before{background:linear-gradient(90deg,var(--blue),transparent)}
.kpi.kt::before{background:linear-gradient(90deg,var(--cyan),transparent)}
.kpi.kp::before{background:linear-gradient(90deg,var(--purple),transparent)}
.kpi.kg::before{background:linear-gradient(90deg,var(--green),transparent)}
.kpi.ka::before{background:linear-gradient(90deg,var(--amber),transparent)}
.kpi.kr::before{background:linear-gradient(90deg,var(--red),transparent)}
/* Forçar tamanhos compactos (estilo DRE) — !important pra sobrepor JS inline */
.kpi-lbl,.kpi .kpi-lbl{font-size:9px!important;font-weight:700!important;letter-spacing:.08em!important;text-transform:uppercase!important;color:var(--muted)!important;margin-bottom:7px!important;opacity:.85}
.kpi-val,.kpi .kpi-val{font-family:'JetBrains Mono',monospace!important;font-size:18px!important;font-weight:600!important;color:var(--text)!important;letter-spacing:-.02em!important;line-height:1.05!important;margin-bottom:4px!important}
.kpi-desc,.kpi .kpi-desc{font-size:9px!important;color:var(--sub)!important;margin-bottom:5px!important;line-height:1.3!important;font-weight:400!important}
.delta{display:inline-flex;align-items:center;gap:2px;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:500;padding:2px 6px;border-radius:5px}
.d-up{background:rgba(0,201,122,.06);color:var(--green);border:1px solid rgba(0,201,122,.1)}
.d-dn{background:rgba(255,68,56,.06);color:var(--red);border:1px solid rgba(255,68,56,.1)}
.kpi-spark{position:absolute;bottom:0;right:0;width:80px;height:36px;opacity:.15;pointer-events:none}

/* ── CARDS (Visual Prime) ─────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.card-h{padding:12px 14px 8px;display:flex;align-items:flex-start;justify-content:space-between}
.card-title{font-size:11px;font-weight:700;color:var(--text);letter-spacing:-.005em}
.card-sub{font-size:9px;color:var(--muted);margin-top:2px}
.card-body{padding:8px 14px 14px;overflow:hidden}
.card-body canvas{display:block;max-height:240px!important}
.badge{font-size:9px;font-weight:700;padding:3px 7px;border-radius:5px;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}
.bb{background:rgba(0,147,255,.06);color:var(--blue);border:1px solid rgba(0,147,255,.1)}
.bt{background:rgba(0,226,201,.05);color:var(--cyan);border:1px solid rgba(0,226,201,.1)}
.bp{background:rgba(139,92,246,.06);color:var(--purple);border:1px solid rgba(139,92,246,.1)}
.bg{background:rgba(0,201,122,.05);color:var(--green);border:1px solid rgba(0,201,122,.1)}
.ba{background:rgba(245,158,11,.05);color:var(--amber);border:1px solid rgba(245,158,11,.1)}
.br{background:rgba(255,68,56,.05);color:var(--red);border:1px solid rgba(255,68,56,.1)}

/* Animations */
@keyframes fu{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade{animation:fu .35s ease both}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* ── GRIDS ────────────────────────────────────────────── */
.g21{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.g11{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
[id^="page-"]{display:flex;flex-direction:column;gap:14px}

/* ── UF LIST (Visual Prime) ───────────────────────────── */
.uf-list{display:flex;flex-direction:column;gap:9px}
.uf-row{display:flex;align-items:center;gap:10px}
.uf-bx{width:32px;height:32px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;border:1px solid}
.uf-inf{flex:1;min-width:0}
.uf-nm{font-size:11px;font-weight:600;color:var(--text)}
.uf-rg{font-size:9px;color:var(--muted)}
.uf-bar{flex:2;display:flex;align-items:center;gap:7px}
.uf-bg{flex:1;height:3px;background:var(--border2);border-radius:2px;overflow:hidden}
.uf-fg{height:100%;border-radius:2px;transition:width .8s ease}
.uf-v{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;color:var(--text);min-width:58px;text-align:right}

/* ═══════════════════════════════════════════════════════ */
/* ── MAPA ULTRA PRIME (destaque cinematográfico) ────────── */
/* ═══════════════════════════════════════════════════════ */
.map-card{
  position:relative;
  background:radial-gradient(ellipse at top right,rgba(0,147,255,.08),transparent 60%),
             radial-gradient(ellipse at bottom left,rgba(0,226,201,.06),transparent 55%),
             var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  /* overflow visível pra estado escalado e card flutuante saírem das bordas */
  overflow:visible;
  transition:all .3s cubic-bezier(.4,0,.2,1);
}
/* Garantir que o card-body não corte */
.map-card .card-body{overflow:visible!important}
/* Borda animada gradiente girando ao redor */
.map-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:var(--r);
  padding:1px;
  background:conic-gradient(from var(--map-angle,0deg),
    var(--blue),
    var(--cyan),
    var(--purple),
    var(--blue));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  opacity:0;
  transition:opacity .4s;
  pointer-events:none;
  animation:mapBorder 8s linear infinite;
  z-index:2;
}
.map-card:hover::before{opacity:.7}
@property --map-angle{syntax:'<angle>';initial-value:0deg;inherits:false}
@keyframes mapBorder{0%{--map-angle:0deg}100%{--map-angle:360deg}}
/* Fallback pra browsers sem @property — borda estática gradient */
@supports not (background:conic-gradient(from 0deg,red,red)){
  .map-card::before{
    background:linear-gradient(135deg,var(--blue),var(--cyan),var(--purple));
    animation:none;
  }
}

/* Glow pulsante sutil */
.map-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:var(--r);
  box-shadow:0 0 0 0 rgba(0,147,255,0),
             0 8px 32px rgba(0,0,0,.2);
  pointer-events:none;
  animation:mapGlow 4s ease-in-out infinite;
  z-index:1;
}
@keyframes mapGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(0,147,255,0),0 8px 32px rgba(0,0,0,.2)}
  50%{box-shadow:0 0 32px 4px rgba(0,147,255,.15),0 12px 40px rgba(0,147,255,.12)}
}
body.light .map-card::after{
  animation:mapGlowLight 4s ease-in-out infinite;
}
@keyframes mapGlowLight{
  0%,100%{box-shadow:0 0 0 0 rgba(0,147,255,0),0 4px 20px rgba(15,23,42,.08)}
  50%{box-shadow:0 0 28px 2px rgba(0,147,255,.12),0 8px 28px rgba(0,147,255,.10)}
}

/* Header do mapa com badge premium */
.map-card .card-h{position:relative;z-index:3;padding:14px 16px 6px}
.map-card .card-title{font-size:13px;font-weight:700}
.map-card .card-title::before{
  content:"";
  display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 8px var(--cyan);
  margin-right:8px;
  animation:mapDot 1.6s ease-in-out infinite;
  vertical-align:middle;
}
@keyframes mapDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}

.map-wrap{position:relative;min-height:280px;z-index:3;overflow:visible}

/* ─── Tooltip antigo (mantém pro fallback) ─── */
.map-tip{
  position:absolute;
  background:linear-gradient(135deg,rgba(15,15,26,.95),rgba(20,20,37,.95));
  color:#FFFFFF;
  padding:10px 14px;
  border-radius:10px;
  font-size:11px;
  pointer-events:none;
  display:none;
  z-index:200;
  white-space:nowrap;
  box-shadow:0 8px 32px rgba(0,0,0,.6),
             0 0 0 1px rgba(0,147,255,.3),
             0 0 24px rgba(0,147,255,.2);
  border:1px solid rgba(0,147,255,.4);
  backdrop-filter:blur(10px);
  font-weight:500;
  letter-spacing:.01em;
}
body.light .map-tip{
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(248,250,252,.98));
  color:var(--text);
  border:1px solid rgba(0,147,255,.3);
  box-shadow:0 8px 32px rgba(15,23,42,.15),0 0 24px rgba(0,147,255,.15);
}

/* ═══════════════════════════════════════════════════════ */
/* ── MAPA: POP-OUT 1.6x + CARD FLUTUANTE PREMIUM ──────── */
/* ═══════════════════════════════════════════════════════ */
#map-svg{width:100%;height:auto;filter:drop-shadow(0 4px 20px rgba(0,0,0,.15));overflow:visible}
#map-svg .estado{
  stroke:var(--bg);
  stroke-width:.7;
  cursor:pointer;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),
             filter .25s ease,
             stroke-width .25s,
             stroke .25s;
  transform-origin:center;
  transform-box:fill-box;
}
/* O visao.js (mouseenter) muda fill pra #00E2C9 — anulamos com !important
   pra preservar a cor original (gradient azul do mapa) */
#map-svg .estado.popout{
  /* Hack: fill: inherit não funciona pra SVG attribute, mas conseguimos
     forçar via CSS variable/inline. A solução é que aplicarEfeitosEstado
     já faz brightness+saturate sobre o fill atual, então mesmo se o
     visao.js trocar pra ciano, o glow vai ser na cor que SETAMOS no JS
     (que é calculada via data-fat, não via fill) */
}

#map-svg .estado:hover,
#map-svg .estado.popout{
  transform:scale(1.6);
  filter:brightness(1.3) saturate(1.4)
         drop-shadow(0 8px 22px rgba(0,0,0,.45));
  /* stroke e drop-shadows extras são aplicados via JS com a cor real */
}
/* Quando um estado está em popout, escurecer MAIS os outros pra dar destaque */
#map-svg.has-popout .estado:not(.popout){
  filter:brightness(.4) saturate(.35);
  opacity:.4;
}
/* O estado em destaque vai pra frente (z-order via SVG) — usamos JS pra reordenar */
#map-svg .estado.popout{
  pointer-events:auto;
}

/* ─── CARD FLUTUANTE PREMIUM (mini) ─── */
.uf-pop{
  position:absolute;
  display:none;
  z-index:300;
  min-width:130px;
  max-width:140px;
  padding:0;
  background:linear-gradient(135deg,rgba(15,15,26,.97),rgba(28,28,48,.97));
  border:1px solid rgba(0,147,255,.35);
  border-radius:9px;
  box-shadow:0 12px 32px rgba(0,0,0,.65),
             0 0 0 1px rgba(0,226,201,.12),
             0 0 24px rgba(0,147,255,.2);
  backdrop-filter:blur(16px);
  pointer-events:none;
  overflow:hidden;
  opacity:0;
  transform:scale(.92) translateY(8px);
  transition:opacity .25s ease,transform .35s cubic-bezier(.34,1.56,.64,1);
}
body.light .uf-pop{
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(245,247,252,.98));
  border:1px solid rgba(0,147,255,.3);
  box-shadow:0 12px 32px rgba(15,23,42,.18),
             0 0 0 1px rgba(0,147,255,.08),
             0 0 24px rgba(0,147,255,.18);
}
.uf-pop.show{
  display:block;
  opacity:1;
  transform:scale(1) translateY(0);
}

/* Faixa colorida superior (gradient azul → ciano) */
.uf-pop-bar{
  height:2px;
  background:linear-gradient(90deg,var(--blue),var(--cyan));
}

/* Header do card — bem compacto */
.uf-pop-h{
  display:flex;
  align-items:center;
  gap:6px;
  padding:7px 9px 6px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
body.light .uf-pop-h{border-bottom:1px solid rgba(15,23,42,.05)}

.uf-pop-flag{
  width:32px;
  height:24px;
  border-radius:4px;
  overflow:hidden;
  flex-shrink:0;
  position:relative;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  box-shadow:0 2px 8px rgba(0,147,255,.35),
             0 0 0 1px rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'JetBrains Mono',monospace;
  color:#FFFFFF;
  font-weight:700;
  font-size:9.5px;
  letter-spacing:-.02em;
}
.uf-pop-flag img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
/* Quando carrega imagem, esconder o texto fallback */
.uf-pop-flag.has-img .uf-pop-flag-fallback{display:none}

.uf-pop-name{
  flex:1;
  min-width:0;
}
.uf-pop-uf{
  font-size:7px;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:0;
  opacity:.85;
}
.uf-pop-st{
  font-size:9.5px;
  font-weight:500;
  color:#FFFFFF;
  letter-spacing:-.005em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.15;
}
body.light .uf-pop-st{color:var(--text)}

/* Body com KPIs — bem compacto */
.uf-pop-body{padding:7px 9px 8px}

.uf-pop-lbl{
  font-size:7px;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
body.light .uf-pop-lbl{color:var(--muted)}

.uf-pop-val{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  font-weight:500;
  color:#FFFFFF;
  letter-spacing:-.01em;
}
body.light .uf-pop-val{color:var(--text)}

.uf-pop-val.big{
  font-size:14px;
  font-weight:600;
  background:linear-gradient(90deg,var(--cyan),var(--blue));
  -webkit-background-clip:text;
          background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Barra de progresso (% do total) — compacta */
.uf-pop-prog{
  margin-top:3px;
  height:2.5px;
  background:rgba(255,255,255,.07);
  border-radius:2px;
  overflow:hidden;
}
body.light .uf-pop-prog{background:rgba(15,23,42,.05)}
.uf-pop-prog-fill{
  height:100%;
  background:linear-gradient(90deg,var(--blue),var(--cyan));
  border-radius:2px;
  box-shadow:0 0 5px rgba(0,226,201,.5);
  transition:width .5s cubic-bezier(.34,1.56,.64,1);
}

/* Versão fallback simples se browser não suportar conic-gradient */
.map-card-simple{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
}

/* ── INSIGHTS (estilo DRE — fundo + borda colorida) ──── */
.ins-list{display:flex;flex-direction:column;gap:8px}
.ins{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);transition:transform .12s}
.ins:hover{transform:translateX(4px)}
.ins.alerta,.ins.alert{background:rgba(255,68,56,.05);border-color:rgba(255,68,56,.25)}
.ins.atencao,.ins.warn{background:rgba(245,158,11,.05);border-color:rgba(245,158,11,.25)}
.ins.positivo,.ins.ok{background:rgba(0,201,122,.05);border-color:rgba(0,201,122,.25)}
.ins.info{background:rgba(0,147,255,.05);border-color:rgba(0,147,255,.25)}
.ins-ico{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;margin-top:1px}
.ins.alerta .ins-ico,.ins.alert .ins-ico{background:rgba(255,68,56,.1);color:var(--red)}
.ins.atencao .ins-ico,.ins.warn .ins-ico{background:rgba(245,158,11,.1);color:var(--amber)}
.ins.positivo .ins-ico,.ins.ok .ins-ico{background:rgba(0,201,122,.1);color:var(--green)}
.ins.info .ins-ico{background:rgba(0,147,255,.1);color:var(--blue)}
.ins-tp{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:2px;opacity:.95}
.ins.alerta .ins-tp,.ins.alert .ins-tp{color:var(--red)}
.ins.atencao .ins-tp,.ins.warn .ins-tp{color:var(--amber)}
.ins.positivo .ins-tp,.ins.ok .ins-tp{color:var(--green)}
.ins.info .ins-tp{color:var(--blue)}
.ins-ti{font-size:12px;font-weight:600;color:var(--text);margin-bottom:2px}
.ins-tx{font-size:11px;color:var(--sub);line-height:1.5}

/* ── YoY CARDS (Compactos — estilo DRE) ──────────────── */
.yoy-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:11px 13px;position:relative;overflow:hidden}
.yoy-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),transparent);border-radius:var(--r) var(--r) 0 0}
.yoy-lbl,.yoy-card .yoy-lbl{font-size:9px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:var(--muted)!important;margin-bottom:6px!important}
/* O ano (2024, 2025, 2026) gigante — força menor */
.yoy-card .yoy-yr-big,.yoy-card>div:nth-child(1){font-size:11px!important;color:var(--muted)!important;font-weight:600!important;letter-spacing:.05em!important}
/* Valor principal (R$15.2K) — força menor */
.yoy-card .yoy-main,.yoy-card .yoy-value{font-family:'JetBrains Mono',monospace!important;font-size:20px!important;font-weight:600!important;letter-spacing:-.02em!important;line-height:1.1!important;color:var(--text)!important;margin:4px 0 6px!important}
.yoy-row{display:flex;align-items:center;padding:5px 0;border-bottom:1px solid var(--border)}
.yoy-row:last-child{border-bottom:none}
.yoy-yr{font-size:10px!important;font-weight:600!important;color:var(--sub)!important;min-width:42px}
.yoy-bar{flex:1;height:3px;background:var(--border2);border-radius:2px;margin:0 10px;overflow:hidden}
.yoy-fill{height:100%;border-radius:2px;transition:width .8s}
.yoy-val{font-family:'JetBrains Mono',monospace!important;font-size:11px!important;font-weight:500!important;color:var(--text)!important;min-width:60px;text-align:right}
.yoy-card .yoy-delta{font-family:'JetBrains Mono',monospace!important;font-size:10px!important;font-weight:600!important}

/* ── TABELAS (Visual Prime) ───────────────────────────── */
.tbl{width:100%;border-collapse:collapse;font-size:11px}
.tbl thead th{padding:8px 12px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:transparent;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}
.tbl tbody td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:rgba(255,255,255,.015)}
.tbl-scroll{max-height:280px;overflow-y:auto}
.tbl-scroll::-webkit-scrollbar{width:3px}
.tbl-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px}

.pill{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500}
.pu{background:rgba(0,201,122,.06);color:var(--green);border:1px solid rgba(0,201,122,.1)}
.pd{background:rgba(255,68,56,.06);color:var(--red);border:1px solid rgba(255,68,56,.1)}
.pn{background:rgba(136,136,170,.05);color:var(--sub);border:1px solid var(--border)}

.rn{width:22px;height:22px;border-radius:6px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rn1{background:rgba(245,158,11,.12);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.rn2{background:rgba(136,136,170,.12);color:#A0A0C0;border:1px solid rgba(136,136,170,.2)}
.rn3{background:rgba(180,120,80,.12);color:#C8956C;border:1px solid rgba(180,120,80,.2)}
.rnn{background:var(--surface2);color:var(--sub)}

.ftag{display:inline-block;padding:2px 7px;border-radius:5px;font-size:9px;font-weight:700;background:rgba(0,147,255,.06);color:var(--blue);border:1px solid rgba(0,147,255,.1)}
.mbar{display:flex;align-items:center;gap:6px}
.mb{width:56px;height:3px;background:var(--border2);border-radius:2px;overflow:hidden;flex-shrink:0}
.mbf{height:100%;border-radius:2px;background:var(--grad)}

/* ── MATRIZ CMC ───────────────────────────────────────── */
.mx-table{width:100%;border-collapse:collapse;font-size:11px}
.mx-table thead th{padding:8px 10px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--surface);border-bottom:1px solid var(--border);white-space:nowrap;text-align:right;position:sticky;top:0;z-index:1}
.mx-table thead th:first-child{text-align:left}
.mx-table thead th:not(:first-child){text-align:right}
.mx-table tbody td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;text-align:right;font-family:'JetBrains Mono',monospace;font-size:10px}
.mx-table tbody td:not(:first-child){text-align:right;min-width:72px}
.mx-table tbody tr:last-child td{border-bottom:none}
.mx-table tbody tr:hover td{background:rgba(255,255,255,.015)}
.mx-fam{background:rgba(255,255,255,.015);cursor:pointer}
.mx-fam td:first-child{font-weight:700;color:var(--text)}
.mx-fam td:not(:first-child){font-weight:600;color:var(--text)}
.mx-prod td:first-child{padding-left:24px;color:var(--sub);font-family:'Plus Jakarta Sans',sans-serif;font-size:11px}
.mx-total td{background:rgba(0,147,255,.04);font-weight:700;color:var(--blue)!important}
.mx-btn{background:none;border:none;color:var(--sub);cursor:pointer;font-size:10px;margin-right:6px;padding:0;transition:transform .2s}
.mx-open .mx-btn{transform:rotate(90deg)}
.cell-ok{color:#4DBD8E!important}
.cell-warn{color:#D6655B!important}
.cell-mid{color:#D69E5C!important}

/* ── LOGIN ────────────────────────────────────────────── */
#glip-login{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:99999;font-family:'Plus Jakarta Sans',sans-serif}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 44px 40px;width:100%;max-width:400px;box-shadow:0 24px 80px rgba(0,0,0,.6);position:relative;overflow:hidden}
.login-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);border-radius:20px 20px 0 0}
.login-title{font-size:18px;font-weight:800;color:var(--text);text-align:center;margin-bottom:4px;letter-spacing:-.02em}
.login-sub{font-size:12px;color:var(--sub);text-align:center;margin-bottom:28px}
.login-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sub);margin-bottom:8px}
.login-input-wrap{position:relative;margin-bottom:20px}
.login-input{width:100%;height:44px;padding:0 44px 0 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--text);outline:none;transition:border-color .15s;box-sizing:border-box}
.login-input:focus{border-color:var(--blue)}
.login-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--muted);font-size:14px;background:none;border:none;padding:4px;transition:color .15s}
.login-eye:hover{color:var(--text)}
.login-btn{width:100%;height:44px;background:var(--grad);border:none;border-radius:10px;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;color:#09090F;cursor:pointer;transition:transform .15s,box-shadow .15s}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,147,255,.4)}
.login-erro{background:rgba(255,68,56,.1);border:1px solid rgba(255,68,56,.2);border-radius:8px;padding:10px 14px;font-size:11px;color:var(--red);margin-bottom:16px;display:none;text-align:center}
.login-footer{text-align:center;margin-top:24px;font-size:10px;color:var(--muted)}
