/* ============================================================
   777LOG · Painel — Design System
   Repaginação moderna: tema claro/escuro, responsivo, interativo.
   Mantém a identidade da marca (navy/azul 777LOG).
   ============================================================ */

/* ---------------- Tokens (tema claro) ---------------- */
:root{
  /* Marca */
  --navy:        #13357a;
  --navy-2:      #0f2a63;
  --brand:       #1f6fd6;
  --brand-strong:#1858bd;
  --brand-soft:  #e9f1fc;
  --accent:      #18b6a8;   /* verde-água p/ destaques secundários */

  /* Superfícies */
  --bg:          #eef2f9;
  --surface:     #ffffff;
  --surface-2:   #f5f8fd;
  --surface-3:   #eef3fb;
  --sidebar-1:   #15387f;
  --sidebar-2:   #0e2657;

  /* Texto */
  --text:        #16213a;
  --text-soft:   #41506b;
  --muted:       #6b7891;

  /* Linhas / estados */
  --border:      #e4eaf3;
  --border-2:    #d8e1ef;
  --ring:        rgba(31,111,214,.30);
  --danger:      #d64541;
  --danger-soft: #fdeceb;
  --ok:          #1f9d57;
  --ok-soft:     #e6f6ee;
  --warn:        #e08a00;
  --warn-soft:   #fdf2dd;
  --info:        #1f6fd6;

  /* Sombra / raio / movimento */
  --shadow-sm:   0 1px 2px rgba(19,53,122,.06);
  --shadow:      0 4px 16px rgba(19,53,122,.08);
  --shadow-lg:   0 12px 40px rgba(19,53,122,.16);
  --shadow-pop:  0 18px 50px rgba(10,25,60,.22);
  --radius:      14px;
  --radius-sm:   10px;
  --radius-lg:   20px;
  --ease:        cubic-bezier(.4,0,.2,1);
  --fast:        .16s var(--ease);
  --med:         .26s var(--ease);

  --sidebar-w:   258px;
  --sidebar-w-collapsed: 78px;
  --topbar-h:    64px;

  --font: "Inter","Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;

  color-scheme: light;
}

/* ---------------- Tokens (tema escuro) ---------------- */
[data-theme="dark"]{
  --navy:        #0c1730;
  --navy-2:      #0a1226;
  --brand:       #4d93f0;
  --brand-strong:#3a82e6;
  --brand-soft:  #15233f;
  --accent:      #2fd0c0;

  --bg:          #0a1120;
  --surface:     #111c30;
  --surface-2:   #16233b;
  --surface-3:   #1b2b47;
  --sidebar-1:   #0d1830;
  --sidebar-2:   #070e1d;

  --text:        #e7eefb;
  --text-soft:   #b9c6df;
  --muted:       #8595b3;

  --border:      #243352;
  --border-2:    #2c3e63;
  --ring:        rgba(77,147,240,.35);
  --danger:      #f0635e;
  --danger-soft: #3a1f24;
  --ok:          #36c074;
  --ok-soft:     #143226;
  --warn:        #f0a83a;
  --warn-soft:   #3a2e16;

  --shadow-sm:   0 1px 2px rgba(0,0,0,.4);
  --shadow:      0 6px 22px rgba(0,0,0,.45);
  --shadow-lg:   0 16px 44px rgba(0,0,0,.55);
  --shadow-pop:  0 20px 54px rgba(0,0,0,.6);

  color-scheme: dark;
}

/* ---------------- Reset / base ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{text-decoration:none;color:inherit}
button{font-family:inherit}
img,svg{display:block}

/* Acessibilidade: anel de foco visível só na navegação por teclado
   (não aparece no clique do mouse) e cor de widgets nativos na marca */
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}
:root{accent-color:var(--brand)}

/* Transição suave ao alternar tema claro/escuro
   (só em elementos que não definem `transition` próprio adiante) */
body,.topbar,.panel,.modal,.table-wrap{transition:background-color .25s,border-color .25s,color .25s}
code{
  background:var(--brand-soft);padding:1px 6px;border-radius:5px;
  font-size:.85em;color:var(--brand);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
}
::selection{background:var(--brand);color:#fff}

/* Scrollbar */
*{scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:20px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--muted);background-clip:content-box}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ---------------- Marca ---------------- */
.brand-777{font-weight:800;font-style:italic;color:var(--brand);letter-spacing:-1px}
.brand-log{font-weight:800;font-style:italic;color:var(--navy)}
.brand-sub{font-size:9px;letter-spacing:2.5px;color:var(--muted);font-weight:700;margin-top:1px}

/* ============================================================
   LOGIN
   ============================================================ */
.login-body{
  min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;
  background:var(--bg);overflow:hidden;
}
/* Painel lateral ilustrativo */
.login-aside{
  position:relative;display:flex;flex-direction:column;justify-content:space-between;
  padding:56px 52px;color:#eaf2ff;overflow:hidden;
  background:linear-gradient(150deg,var(--navy) 0%,var(--brand-strong) 60%,var(--brand) 100%);
}
.login-aside::before,.login-aside::after{
  content:"";position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;
}
.login-aside::before{width:520px;height:520px;right:-180px;top:-160px;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 60%)}
.login-aside::after{width:360px;height:360px;left:-120px;bottom:-120px;
  background:radial-gradient(circle at 70% 70%,rgba(24,182,168,.5),transparent 60%)}
.login-aside .la-top{position:relative;font-size:30px;line-height:1}
.login-aside .la-top .brand-log{color:#fff}
.login-aside .la-top .brand-sub{color:rgba(255,255,255,.65)}
.login-aside .la-mid{position:relative;max-width:420px}
.login-aside .la-mid h2{font-size:30px;font-weight:800;line-height:1.2;letter-spacing:-.5px}
.login-aside .la-mid p{margin-top:14px;font-size:15px;line-height:1.6;color:rgba(255,255,255,.82)}
.login-aside .la-points{position:relative;display:flex;flex-direction:column;gap:12px;margin-top:8px}
.login-aside .la-point{display:flex;align-items:center;gap:11px;font-size:14px;color:rgba(255,255,255,.9)}
.login-aside .la-point .lp-ico{
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;
  background:rgba(255,255,255,.14);backdrop-filter:blur(6px);
}
.login-aside .la-point svg{width:18px;height:18px;stroke:#fff}
.login-aside .la-foot{position:relative;font-size:12.5px;color:rgba(255,255,255,.6)}

.login-main{display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:400px;animation:rise .5s var(--ease) both}
.login-brand-mobile{display:none;text-align:center;font-size:28px;line-height:1;margin-bottom:26px}
.login-title{font-size:25px;font-weight:800;color:var(--text);letter-spacing:-.4px}
.login-desc{font-size:14px;color:var(--muted);margin:7px 0 26px}
.login-erro{
  display:flex;align-items:center;gap:9px;background:var(--danger-soft);color:var(--danger);
  border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);
  padding:11px 13px;border-radius:var(--radius-sm);font-size:13.5px;margin-bottom:18px;
  animation:shake .4s var(--ease);
}
.login-erro svg{width:18px;height:18px;flex-shrink:0;stroke:var(--danger)}

.field{display:block;margin-bottom:16px}
.field>span{display:block;font-size:12.5px;color:var(--text-soft);margin-bottom:7px;font-weight:600}
.field-input{position:relative;display:flex;align-items:center}
.field-input>svg{position:absolute;left:13px;width:18px;height:18px;stroke:var(--muted);pointer-events:none}
.field-input input{
  width:100%;padding:13px 13px 13px 42px;border:1.5px solid var(--border-2);border-radius:var(--radius-sm);
  font-size:14.5px;background:var(--surface);color:var(--text);transition:border-color var(--fast),box-shadow var(--fast);
}
.field-input input::placeholder{color:var(--muted)}
.field-input input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--ring)}
.field-input .toggle-pass{
  position:absolute;right:8px;background:none;border:none;cursor:pointer;padding:7px;border-radius:8px;display:grid;place-items:center;
}
.field-input .toggle-pass:hover{background:var(--surface-3)}
.field-input .toggle-pass svg{width:18px;height:18px;stroke:var(--muted)}
.login-footer{text-align:center;color:var(--muted);font-size:12.5px;margin-top:22px}

/* ============================================================
   BOTÕES / CONTROLES (compartilhados)
   ============================================================ */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(180deg,var(--brand),var(--brand-strong));color:#fff;border:none;
  border-radius:var(--radius-sm);padding:13px 18px;font-size:14.5px;font-weight:700;cursor:pointer;
  box-shadow:0 6px 18px color-mix(in srgb,var(--brand) 35%,transparent);
  transition:transform var(--fast),box-shadow var(--fast),filter var(--fast);
}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 10px 26px color-mix(in srgb,var(--brand) 45%,transparent)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary svg{width:18px;height:18px;stroke:#fff}
.btn-block{width:100%}

.btn-ghost{
  display:inline-flex;align-items:center;gap:7px;background:var(--surface);color:var(--text-soft);
  border:1.5px solid var(--border-2);padding:9px 14px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:600;cursor:pointer;transition:all var(--fast);
}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand);background:var(--surface-2)}
.btn-ghost svg{width:16px;height:16px;stroke:currentColor}
.btn-ghost[hidden]{display:none}

.btn-upload{
  display:inline-flex;align-items:center;gap:7px;
  background:linear-gradient(180deg,var(--brand),var(--brand-strong));color:#fff;
  padding:9px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;
  transition:filter var(--fast),transform var(--fast);
}
.btn-upload:hover{filter:brightness(1.07)}
.btn-upload:active{transform:translateY(1px)}
.btn-upload svg{width:16px;height:16px;stroke:#fff}

.icon-btn{
  display:grid;place-items:center;width:40px;height:40px;border-radius:11px;cursor:pointer;
  background:transparent;border:1.5px solid transparent;color:var(--text-soft);transition:all var(--fast);
}
.icon-btn:hover{background:var(--surface-3);color:var(--text)}
.icon-btn svg{width:20px;height:20px;stroke:currentColor}

.search-input{
  padding:9px 13px 9px 36px;border:1.5px solid var(--border-2);border-radius:var(--radius-sm);
  font-size:13.5px;min-width:210px;background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236b7891' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat 12px center;
  color:var(--text);transition:border-color var(--fast),box-shadow var(--fast);
}
.search-input::placeholder{color:var(--muted)}
.search-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--ring)}
.search-input:disabled{opacity:.55;cursor:not-allowed}

.chip{
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;
  font-size:12.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--border-2);
  background:var(--surface);color:var(--text-soft);transition:all var(--fast);white-space:nowrap;
}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--brand) 35%,transparent)}
.chip .chip-count{font-weight:700;opacity:.7;font-size:11px}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:30px;font-size:11.5px;font-weight:700}
.badge.ok{background:var(--ok-soft);color:var(--ok)}
.badge.warn{background:var(--warn-soft);color:var(--warn)}
.badge.danger{background:var(--danger-soft);color:var(--danger)}
.badge.info{background:var(--brand-soft);color:var(--brand)}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}

/* ============================================================
   APP SHELL
   ============================================================ */
.app-body{display:flex;min-height:100vh;overflow-x:hidden}

/* ---- Sidebar ---- */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;position:sticky;top:0;height:100vh;z-index:60;
  background:linear-gradient(185deg,var(--sidebar-1) 0%,var(--sidebar-2) 100%);
  color:#cdd9f0;display:flex;flex-direction:column;
  transition:width var(--med),transform var(--med);
}
.sidebar-brand{
  display:flex;align-items:center;gap:12px;padding:20px 22px 18px;font-size:23px;line-height:1;
  border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap;overflow:hidden;
}
.sidebar-brand .sb-logo{
  width:40px;height:40px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--brand),var(--accent));color:#fff;font-weight:800;font-style:italic;font-size:15px;
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.sidebar-brand .sb-words{display:flex;flex-direction:column;line-height:1.05}
.sidebar-brand .sb-words .brand-777,.sidebar-brand .sb-words .brand-log{color:#fff}
.sidebar-brand .brand-sub{color:rgba(255,255,255,.5)}

.sidebar-nav{padding:14px 12px;flex:1;overflow-y:auto;overflow-x:hidden}
.nav-label{
  font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4);
  font-weight:700;padding:14px 14px 7px;white-space:nowrap;
}
.nav-item{
  position:relative;display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:11px;
  font-size:14px;font-weight:600;color:#bcccea;margin-bottom:3px;white-space:nowrap;
  transition:background var(--fast),color var(--fast);cursor:pointer;
}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:linear-gradient(90deg,var(--brand),var(--brand-strong));color:#fff;box-shadow:0 6px 18px rgba(31,111,214,.4)}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:var(--accent)}
.nav-ico{width:22px;height:22px;flex-shrink:0;display:grid;place-items:center}
.nav-ico svg{width:20px;height:20px;stroke:currentColor}
.nav-text{transition:opacity var(--fast)}
.nav-badge{margin-left:auto;background:rgba(255,255,255,.16);color:#fff;font-size:11px;font-weight:700;padding:1px 8px;border-radius:20px}
.nav-item.active .nav-badge{background:rgba(255,255,255,.25)}

.sidebar-foot{padding:14px;border-top:1px solid rgba(255,255,255,.08)}
.user-chip{display:flex;align-items:center;gap:11px;padding:8px;border-radius:11px;transition:background var(--fast)}
.user-chip .avatar{
  width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff;
  background:linear-gradient(145deg,var(--brand),var(--accent));
}
.user-chip .u-meta{min-width:0;overflow:hidden}
.user-chip .u-name{font-size:13.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .u-role{font-size:11.5px;color:rgba(255,255,255,.55);white-space:nowrap}
.logout-link{
  display:flex;align-items:center;gap:9px;margin-top:6px;padding:9px 10px;border-radius:10px;
  font-size:13px;font-weight:600;color:#9fb6df;transition:all var(--fast);
}
.logout-link:hover{background:rgba(214,69,65,.15);color:#ff9b96}
.logout-link svg{width:17px;height:17px;stroke:currentColor}

/* Sidebar colapsada (desktop) */
.app-body.collapsed .sidebar{width:var(--sidebar-w-collapsed)}
.app-body.collapsed .nav-text,
.app-body.collapsed .brand-sub,
.app-body.collapsed .sb-words,
.app-body.collapsed .nav-label,
.app-body.collapsed .nav-badge,
.app-body.collapsed .u-meta{opacity:0;width:0;overflow:hidden;pointer-events:none}
.app-body.collapsed .sidebar-brand{justify-content:center;padding:20px 0 18px}
.app-body.collapsed .nav-item{justify-content:center;padding:11px}
.app-body.collapsed .user-chip{justify-content:center;padding:8px 0}
.app-body.collapsed .logout-link{justify-content:center}
.app-body.collapsed .logout-link span{display:none}

/* ---- Conteúdo ---- */
.content{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}

.topbar{
  position:sticky;top:0;z-index:40;height:var(--topbar-h);
  background:var(--surface); /* fallback p/ navegadores sem color-mix */
  background:color-mix(in srgb,var(--surface) 82%,transparent);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 24px;display:flex;align-items:center;gap:14px;
}
.topbar-left{display:flex;align-items:center;gap:14px;min-width:0}
.topbar-title{min-width:0}
.topbar-title h1{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-title .crumb{font-size:11.5px;color:var(--muted);font-weight:600}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.topbar-info{font-size:13px;color:var(--muted);font-weight:600;padding-right:6px;white-space:nowrap}
#sidebar-toggle{display:grid}
#sidebar-open{display:none}

/* Overlay (drawer mobile) */
.scrim{
  position:fixed;inset:0;background:rgba(8,16,33,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  z-index:55;opacity:0;visibility:hidden;transition:opacity var(--med),visibility var(--med);
}
.scrim.show{opacity:1;visibility:visible}

/* ---- Views ---- */
.view{display:none;padding:24px;flex:1;flex-direction:column;min-width:0}
.view.active{display:flex;animation:viewIn .35s var(--ease) both}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---- Toolbar ---- */
.toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.toolbar-left{display:flex;flex-direction:column;gap:3px}
.toolbar-left strong{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.muted{color:var(--muted);font-size:12.5px}
.toolbar-right{display:flex;gap:9px;align-items:center;flex-wrap:wrap}

/* ============================================================
   CARDS / GRID GENÉRICO
   ============================================================ */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.section-grid{display:grid;gap:18px}

/* ---- KPIs ---- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:20px}
.kpi-card{
  position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 18px 16px;box-shadow:var(--shadow-sm);overflow:hidden;
  transition:transform var(--med),box-shadow var(--med),border-color var(--med);
  animation:rise .45s var(--ease) both;
}
.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-2)}
.kpi-card::after{content:"";position:absolute;right:-30px;top:-30px;width:110px;height:110px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--kpi,var(--brand)) 16%,transparent),transparent 70%);pointer-events:none}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi-ico{
  width:44px;height:44px;border-radius:13px;display:grid;place-items:center;flex-shrink:0;
  background:var(--surface-3);
  background:color-mix(in srgb,var(--kpi,var(--brand)) 14%,transparent);color:var(--kpi,var(--brand));
}
.kpi-ico svg{width:23px;height:23px;stroke:currentColor}
.kpi-trend{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:20px}
.kpi-trend.up{background:var(--ok-soft);color:var(--ok)}
.kpi-trend.down{background:var(--danger-soft);color:var(--danger)}
.kpi-trend.flat{background:var(--surface-3);color:var(--muted)}
.kpi-value{font-size:30px;font-weight:800;letter-spacing:-1px;color:var(--text);line-height:1}
.kpi-label{font-size:13px;color:var(--muted);font-weight:600;margin-top:6px}

/* ---- Painéis (gráficos) ---- */
.panels{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;margin-bottom:20px}
.panels.eq{grid-template-columns:1fr 1fr}
.panel{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:18px 20px;display:flex;flex-direction:column;min-width:0;
  animation:rise .5s var(--ease) both;
}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}
.panel-head h3{font-size:15px;font-weight:800;color:var(--text)}
.panel-head .ph-sub{font-size:12px;color:var(--muted);font-weight:600}
.panel-body{position:relative;flex:1;min-height:240px}
.panel-body canvas{max-width:100%}

/* lista de ranking (fallback / complemento) */
.rank-list{display:flex;flex-direction:column;gap:11px}
.rank-row{display:grid;grid-template-columns:26px 1fr auto;align-items:center;gap:11px;font-size:13px}
.rank-row .rk-pos{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--surface-3);color:var(--text-soft);font-weight:700;font-size:12px}
.rank-row .rk-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-row .rk-bar{grid-column:2;height:7px;border-radius:20px;background:var(--surface-3);overflow:hidden;margin-top:5px}
.rank-row .rk-bar>span{display:block;height:100%;border-radius:20px;background:linear-gradient(90deg,var(--brand),var(--accent));width:0;transition:width .8s var(--ease)}
.rank-row .rk-val{font-weight:700;color:var(--text-soft)}

/* ============================================================
   MAPA
   ============================================================ */
#mapa-container{position:relative;flex:1;min-height:460px;display:flex;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border)}
#mapa{flex:1;min-height:460px;background:var(--surface-2)}
.leaflet-container{font-family:var(--font)}

#mapa-dropzone{
  position:absolute;inset:0;z-index:500;
  background:var(--bg);
  background:color-mix(in srgb,var(--bg) 92%,transparent);border:2px dashed var(--brand);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;text-align:center;transition:all var(--fast);
}
#mapa-dropzone.hidden{display:none}
#mapa-dropzone.dragover{background:color-mix(in srgb,var(--brand) 14%,transparent);border-color:var(--brand-strong)}
.dz-inner{max-width:440px;padding:26px;color:var(--muted)}
.dz-ico{font-size:46px;margin-bottom:10px}
.dz-inner strong{display:block;color:var(--text);font-size:18px;margin-bottom:6px;font-weight:800}
.dz-inner span{display:block;font-size:13.5px;margin-bottom:12px}
.dz-inner small{display:block;font-size:12px;line-height:1.6}

.map-stats{
  position:absolute;left:14px;top:14px;z-index:600;display:flex;gap:10px;flex-wrap:wrap;max-width:calc(100% - 28px);
}
.map-stat{
  background:var(--surface);
  background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:12px;padding:8px 13px;box-shadow:var(--shadow-sm);
}
.map-stat .ms-val{font-size:18px;font-weight:800;color:var(--text);line-height:1}
.map-stat .ms-lab{font-size:11px;color:var(--muted);font-weight:600}

.uf-filter{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;align-items:center}
.uf-filter .uf-title{font-size:12px;font-weight:700;color:var(--muted);margin-right:2px}

.legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;font-size:12.5px;color:var(--muted)}
.legend .dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:6px;vertical-align:middle}

/* Pin */
.pin-dot span{display:block;width:15px;height:15px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.45)}
.pin-popup b{color:var(--navy);font-size:14px}
[data-theme="dark"] .pin-popup b{color:var(--brand)}
.pin-popup .kv{font-size:12.5px;line-height:1.6;margin-top:4px;max-width:270px;color:#2b3650}
.pin-popup .tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;color:#fff;margin-top:6px}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--shadow-pop)}

/* ============================================================
   TABELA (Notas)
   ============================================================ */
.table-wrap{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:auto;box-shadow:var(--shadow-sm);flex:1;max-height:calc(100vh - 340px);min-height:300px;
}
table{border-collapse:collapse;width:100%;font-size:13.5px}
thead th{
  background:var(--surface-2);color:var(--text-soft);text-align:left;padding:13px 16px;
  position:sticky;top:0;z-index:2;cursor:pointer;white-space:nowrap;font-weight:700;font-size:12px;
  letter-spacing:.3px;text-transform:uppercase;border-bottom:2px solid var(--border-2);user-select:none;
}
thead th:hover{color:var(--brand);background:var(--surface-3)}
thead th .arrow{font-size:10px;margin-left:4px;color:var(--brand)}
tbody td{padding:12px 16px;border-bottom:1px solid var(--border);white-space:nowrap;color:var(--text-soft)}
tbody tr{transition:background var(--fast)}
tbody tr:hover{background:var(--brand-soft)}
td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}
.table-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 4px 2px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.pager{display:flex;align-items:center;gap:6px}
.pager button{
  min-width:34px;height:34px;padding:0 9px;border-radius:9px;border:1.5px solid var(--border-2);
  background:var(--surface);color:var(--text-soft);font-weight:700;font-size:13px;cursor:pointer;transition:all var(--fast);
}
.pager button:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}
.pager button.active{background:var(--brand);border-color:var(--brand);color:#fff}
.pager button:disabled{opacity:.4;cursor:not-allowed}

/* ============================================================
   LEADS — Kanban
   ============================================================ */
.kanban{display:flex;gap:16px;flex:1;overflow-x:auto;padding-bottom:8px;align-items:flex-start}
.kanban-col{
  flex:1;min-width:268px;max-width:340px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 230px);transition:background var(--fast),border-color var(--fast)}
.kanban-col.drag-over{background:var(--brand-soft);border-color:var(--brand);border-style:dashed}
.kc-head{display:flex;align-items:center;gap:9px;padding:14px 15px 11px;position:sticky;top:0}
.kc-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.kc-title{font-size:13.5px;font-weight:800;color:var(--text)}
.kc-count{margin-left:auto;background:var(--surface-3);color:var(--text-soft);font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:20px}
.kc-body{padding:4px 11px 11px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;flex:1;min-height:60px}
.kc-empty{font-size:12.5px;color:var(--muted);text-align:center;padding:22px 8px;border:1.5px dashed var(--border-2);border-radius:11px}

.lead-card{
  background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--lc,var(--brand));
  border-radius:11px;padding:12px 13px;cursor:grab;box-shadow:var(--shadow-sm);
  transition:transform var(--fast),box-shadow var(--fast),opacity var(--fast);animation:rise .3s var(--ease) both;
}
.lead-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.lead-card:active{cursor:grabbing}
.lead-card.dragging{opacity:.5;transform:rotate(1.5deg) scale(.98)}
.lead-card .lc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.lead-card .lc-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.3}
.lead-card .lc-menu{opacity:0;background:none;border:none;cursor:pointer;color:var(--muted);padding:2px;border-radius:6px;transition:opacity var(--fast),background var(--fast),color var(--fast);flex-shrink:0}
.lead-card:hover .lc-menu{opacity:1}
.lead-card .lc-menu:hover{background:var(--surface-3);color:var(--text)}
.lead-card .lc-menu svg{width:17px;height:17px;stroke:currentColor}
.lead-card .lc-meta{display:flex;flex-direction:column;gap:5px;margin-top:9px;font-size:12.5px;color:var(--muted)}
.lead-card .lc-meta .lc-line{display:flex;align-items:center;gap:7px}
.lead-card .lc-meta svg{width:14px;height:14px;stroke:currentColor;flex-shrink:0}
.lead-card .lc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:11px;gap:8px}
.lead-card .lc-value{font-size:13.5px;font-weight:800;color:var(--ok)}
.lead-card .lc-tag{font-size:10.5px;font-weight:700;color:var(--muted);background:var(--surface-3);padding:2px 8px;border-radius:20px}

/* ============================================================
   MODAL
   ============================================================ */
.modal-scrim{
  position:fixed;inset:0;background:rgba(8,16,33,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  z-index:200;display:grid;place-items:center;padding:18px;opacity:0;visibility:hidden;transition:opacity var(--med),visibility var(--med);
}
.modal-scrim.show{opacity:1;visibility:visible}
.modal{
  width:100%;max-width:480px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-pop);transform:translateY(16px) scale(.98);transition:transform var(--med);max-height:92vh;overflow:auto;
}
.modal-scrim.show .modal{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 0}
.modal-head h3{font-size:18px;font-weight:800;color:var(--text)}
.modal-body{padding:18px 22px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:0 22px 22px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1 / -1}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field label{font-size:12.5px;font-weight:600;color:var(--text-soft)}
.form-field input,.form-field select,.form-field textarea{
  padding:11px 12px;border:1.5px solid var(--border-2);border-radius:var(--radius-sm);font-size:14px;
  background:var(--surface);color:var(--text);font-family:inherit;transition:border-color var(--fast),box-shadow var(--fast);
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--ring)}
.form-field textarea{resize:vertical;min-height:74px}

/* ---- Estado vazio ---- */
.empty-state{margin:auto;text-align:center;color:var(--muted);padding:56px 20px;max-width:440px}
.empty-ico{font-size:50px;margin-bottom:12px}
.empty-state h2{color:var(--text);margin-bottom:8px;font-size:22px;font-weight:800}
.empty-state p{font-size:14px;line-height:1.6}

/* ============================================================
   TOASTS
   ============================================================ */
.toast-wrap{position:fixed;right:18px;bottom:18px;z-index:300;display:flex;flex-direction:column;gap:10px;max-width:340px}
.toast{
  display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--border);
  border-left:4px solid var(--brand);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow-pop);
  font-size:13.5px;color:var(--text);animation:toastIn .3s var(--ease) both;
}
.toast.ok{border-left-color:var(--ok)}
.toast.err{border-left-color:var(--danger)}
.toast.leaving{animation:toastOut .25s var(--ease) forwards}
.toast svg{width:19px;height:19px;flex-shrink:0}
.toast.ok svg{stroke:var(--ok)}
.toast.err svg{stroke:var(--danger)}
.toast.info svg{stroke:var(--brand)}

/* ---- Spinner / skeleton ---- */
.spinner{width:34px;height:34px;border:3px solid var(--border-2);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;margin:30px auto}
.loading-row{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--muted);font-size:13.5px;padding:24px}

/* ============================================================
   ANIMAÇÕES
   ============================================================ */
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes viewInOnly{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media(max-width:1100px){
  .panels,.panels.eq{grid-template-columns:1fr}
}

@media(max-width:860px){
  /* Sidebar vira drawer off-canvas */
  .sidebar{
    position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);
    box-shadow:var(--shadow-pop);width:min(84vw,300px);
  }
  .app-body.drawer-open .sidebar{transform:none}
  .app-body.collapsed .sidebar{width:min(84vw,300px)} /* ignora colapso no mobile */
  .app-body.collapsed .nav-text,.app-body.collapsed .sb-words,
  .app-body.collapsed .brand-sub,.app-body.collapsed .nav-label,
  .app-body.collapsed .nav-badge,.app-body.collapsed .u-meta{opacity:1;width:auto;pointer-events:auto}
  .app-body.collapsed .nav-item{justify-content:flex-start;padding:11px 14px}
  .app-body.collapsed .sidebar-brand{justify-content:flex-start;padding:20px 22px 18px}

  #sidebar-toggle{display:none}
  #sidebar-open{display:grid}
  .view{padding:18px 16px}
  .topbar{padding:0 16px}
  .kpi-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
  .kpi-value{font-size:25px}
  .table-wrap{max-height:none}
  .search-input{min-width:0;flex:1}
  .toolbar-right{width:100%}
  .toolbar-right .search-input{order:-1}
}

@media(max-width:560px){
  .topbar-info{display:none}
  .form-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .panel-body{min-height:220px}
  .kanban-col{min-width:240px}
  .map-stat{padding:6px 10px}
  .map-stat .ms-val{font-size:15px}
}
