/* Ecossistema Muvuka — Estilos */


:root {
  /* Dark mode palette */
  --bg:#0E0E0E;--bg2:#161616;--bg3:#1E1E1E;--bg4:#252525;
  --border:#2A2A2A;--border2:#333;
  --text:#F0F0F0;--text2:#A0A0A0;--text3:#666;

  /* Green accent (neon) */
  --g900:#041a00;--g800:#0a3d05;--g600:#166b0e;--g400:#22C55E;--g200:#4ade80;--g100:#86efac;--g50:#1a3d24;
  --g700:#19a34a;

  /* Teal */
  --t800:#052a1f;--t600:#0d5c42;--t400:#10b981;--t50:#0d2e22;

  /* Amber/Orange */
  --a800:#3d1f00;--a400:#f59e0b;--a200:#fbbf24;--a50:#2d1f05;

  /* Purple */
  --p800:#1a1040;--p400:#8b5cf6;--p50:#1e1535;

  /* Red */
  --r400:#ef4444;--r50:#2d0f0f;

  /* Blue */
  --b400:#3b82f6;--b50:#0f1f3d;--b800:#1e3a7a;

  --sidebar:220px;
  --font:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex}

/* ── SIDEBAR ── */
#sidebar{width:var(--sidebar);min-height:100vh;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100}
.logo-wrap{padding:18px 16px 14px;border-bottom:1px solid var(--border)}
.logo-icon{width:32px;height:32px;background:var(--g400);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;vertical-align:middle}
.logo-icon svg{width:18px;height:18px;fill:#fff}
.logo-name{font-size:14px;font-weight:600;color:var(--g400);vertical-align:middle}
.logo-sub{font-size:10px;color:var(--text3);margin-top:3px;padding-left:42px}
nav{flex:1;padding:10px 0}
.nav-section{font-size:9px;font-weight:600;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;padding:10px 16px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:12.5px;color:var(--text2);cursor:pointer;border-left:3px solid transparent;transition:all .15s;text-decoration:none}
.nav-item:hover{background:var(--bg3);color:var(--g400)}
.nav-item.active{background:var(--g50);color:var(--g400);font-weight:600;border-left-color:var(--g400)}
.nav-icon{width:15px;height:15px;flex-shrink:0;opacity:.7}
.nav-item.active .nav-icon{opacity:1}
.sidebar-footer{padding:14px 16px;border-top:1px solid var(--border);font-size:10px;color:var(--text3)}

/* ── MAIN ── */
#main{margin-left:var(--sidebar);flex:1;padding:28px 32px;min-height:100vh}
.view{display:none}
.view.active{display:block}
.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.view-title{font-size:20px;font-weight:700;color:var(--g400)}
.view-sub{font-size:13px;color:var(--text2);margin-top:2px}

/* ── METRICS ── */
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.metric-card{background:var(--bg3);border-radius:12px;padding:16px 20px;border:1px solid var(--border)}
.metric-val{font-size:26px;font-weight:700;color:var(--g400)}
.metric-label{font-size:11px;color:var(--text2);margin-top:3px}
.metric-sub{font-size:10px;color:var(--text3);margin-top:2px}

/* ── CHARTS ROW ── */
.charts-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:20px}
.chart-card{background:var(--bg3);border-radius:12px;padding:18px;border:1px solid var(--border)}
.chart-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:14px}
.bar-item{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.bar-label{font-size:11px;color:var(--text2);width:110px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:10px;background:var(--bg4);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;transition:width .6s ease}
.bar-count{font-size:10px;color:var(--text3);width:28px;text-align:right}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
.bg{background:#1a3d24;color:var(--g400)}
.bt{background:#0d2e22;color:var(--t400)}
.ba{background:#2d1f05;color:var(--a400)}
.bp{background:#1e1535;color:var(--p400)}
.br{background:#2d0f0f;color:var(--r400)}
.bb{background:#0f1f3d;color:var(--b400)}
.bz{background:var(--bg4);color:var(--text2)}

/* ── TABLE ── */
.table-wrap{background:var(--bg3);border-radius:12px;border:1px solid var(--border);overflow:hidden}
.table-toolbar{display:flex;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.search-input{flex:1;min-width:160px;padding:7px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--bg4);color:var(--text);outline:none;font-family:var(--font)}
.search-input:focus{border-color:var(--g400)}
.filter-select{padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:var(--bg4);color:var(--text);outline:none;cursor:pointer;font-family:var(--font)}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:2px solid var(--border)}
th{padding:10px 14px;text-align:left;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
td{padding:9px 14px;border-bottom:1px solid #f8f8f4;font-size:12.5px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafaf8}
.org-name{font-weight:600;color:#1a1a18;font-size:13px}
.org-sub{font-size:10px;color:#aaa;margin-top:1px}
.flag-pill{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:700}
.flag-1{background:#27500A;color:#fff}
.flag-2{background:var(--g400);color:#fff}
.flag-3{background:var(--g100);color:var(--g800)}
.flag-4{background:#f0f0ec;color:#888}
.flag-5{background:#f0f0ec;color:#aaa}
.flag-x{background:#fee;color:var(--r400)}
.flag-other{background:#f0f0ec;color:#888}

/* ── PESSOAS CARDS ── */
.pessoas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.pessoa-card{background:#fff;border-radius:12px;border:1px solid #eeeee8;overflow:hidden;cursor:pointer;transition:border-color .15s}
.pessoa-card:hover{border-color:var(--g200)}
.pessoa-card-head{padding:14px 16px;display:flex;align-items:center;gap:12px}
.pessoa-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.pessoa-name{font-size:13px;font-weight:600;color:#1a1a18}
.pessoa-role{font-size:11px;color:#888;margin-top:1px}
.pessoa-org{font-size:11px;color:var(--g600);margin-top:2px}
.pessoa-card-body{padding:0 16px 14px;display:none}
.pessoa-card-body.open{display:block}
.pessoa-bio{font-size:12px;color:#555;line-height:1.6;margin-bottom:10px}
.pessoa-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}
.pessoa-links{display:flex;gap:10px}
.pessoa-links a{font-size:11px;color:var(--g600);text-decoration:none}
.pessoa-links a:hover{text-decoration:underline}
.tier-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px}
.tier-1{background:var(--g800);color:#fff}
.tier-2{background:var(--g400);color:#fff}
.tier-3{background:var(--g50);color:var(--g800)}
.tier-4{background:#f0f0ec;color:#888}

/* ── VAGAS CARDS ── */
.vagas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.vaga-card{background:#fff;border-radius:12px;border:1px solid #eeeee8;overflow:hidden}
.vaga-card-accent{height:4px;background:linear-gradient(90deg,var(--g400),var(--t400))}
.vaga-card-body{padding:16px}
.vaga-org{font-size:13px;font-weight:700;color:var(--g800);margin-bottom:4px}
.vaga-tier{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#888;margin-bottom:10px}
.vaga-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--g50);color:var(--g800);border-radius:8px;font-size:12px;font-weight:600;text-decoration:none;margin-right:8px;transition:background .15s}
.vaga-link:hover{background:var(--g100)}
.vaga-link.consult{background:var(--a50);color:var(--a800)}
.vaga-link.consult:hover{background:#f5d9a0}

/* ── PLATAFORMAS ── */
.plat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.plat-card{background:#fff;border-radius:12px;border:1px solid #eeeee8;padding:16px}
.plat-name{font-size:13px;font-weight:600;color:#1a1a18;margin-bottom:6px}
.plat-link{display:inline-block;font-size:12px;color:var(--g600);text-decoration:none;word-break:break-all}
.plat-link:hover{text-decoration:underline}
.plat-flag{margin-bottom:8px}

/* ── PIPELINE ── */
.pipeline-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.pipeline-col{background:#f8f8f4;border-radius:12px;padding:14px}
.pipeline-col-head{font-size:12px;font-weight:600;color:#555;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}
.pipeline-card{background:#fff;border-radius:8px;border:1px solid #eeeee8;padding:12px;margin-bottom:8px}
.pipeline-title{font-size:12px;font-weight:600;color:#1a1a18;margin-bottom:3px}
.pipeline-org{font-size:11px;color:#888;margin-bottom:8px}
.pipeline-val{font-size:11px;font-weight:600;color:var(--g600)}

/* ── MUVUKA RADAR ── */
.radar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.radar-card{background:#fff;border-radius:12px;border:1px solid #eeeee8;padding:16px}
.radar-org{font-size:13px;font-weight:700;color:#1a1a18;margin-bottom:6px}
.radar-stars{margin-bottom:8px}
.radar-star{font-size:14px}
.radar-star.on{color:var(--g400)}
.radar-star.off{color:#e0e0d8}
.radar-rationale{font-size:11px;color:#666;line-height:1.6}

/* ── LOADING / ERROR ── */
.loading{display:flex;align-items:center;justify-content:center;height:300px;flex-direction:column;gap:14px}
.spinner{width:32px;height:32px;border:3px solid var(--g100);border-top-color:var(--g400);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:13px;color:#888}
.error-box{background:var(--r50);border:1px solid #fca5a5;border-radius:12px;padding:20px 24px;margin:20px 0}
.error-title{font-size:14px;font-weight:700;color:var(--r400);margin-bottom:6px}
.error-text{font-size:13px;color:#666;line-height:1.6}
.error-steps{margin-top:10px;padding-left:16px;font-size:12px;color:#666;line-height:2}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none;font-family:var(--font)}
.btn-green{background:var(--g400);color:#fff}
.btn-green:hover{background:var(--g600)}
.btn-outline{background:#fff;color:var(--g800);border:1px solid var(--g200)}
.btn-outline:hover{background:var(--g50)}
.info-banner{background:var(--b50);border:1px solid #bfdbfe;border-radius:10px;padding:12px 16px;font-size:12px;color:var(--b800);margin-bottom:16px;display:flex;gap:8px;align-items:flex-start}
.tag-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.stat-row{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  #sidebar{transform:translateX(-100%);transition:transform .2s}
  #sidebar.open{transform:translateX(0)}
  #main{margin-left:0;padding:16px}
  .metrics-grid{grid-template-columns:repeat(2,1fr)}
  .charts-row{grid-template-columns:1fr}
  .pipeline-cols{grid-template-columns:1fr 1fr}
}

/* ── MISC ── */
.sep{height:1px;background:#f0f0ec;margin:16px 0}
.empty-state{text-align:center;padding:40px;color:#aaa;font-size:13px}
a{color:inherit}
/* ── MOBILE RESPONSIVE ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
  #sidebar { display: none; }
  #main { margin-left: 0; padding: 16px 14px 80px; }
  .metrics-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .charts-row { grid-template-columns: 1fr; }
  .metric-val { font-size: 22px; }
  .view-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .view-title { font-size: 17px; }
  th, td { font-size: 11px; padding: 7px 8px; }
  .table-toolbar { gap: 6px; }
  .search-input { font-size: 13px; }
  #ai-wrap { height: calc(100vh - 180px); }
  .ai-bubble { font-size: 13px; }
  .dir-grid { grid-template-columns: 1fr !important; }
  .crono-task { grid-template-columns: 28px 1fr; }
  .crono-task-resp, .crono-task-date { display: none; }
  .flag-grid { grid-template-columns: 1fr 1fr; }
}

/* ── BOTTOM NAV (mobile only) ───────────────────────────────────────────── */
#bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  z-index: 200;
  padding: 0;
  padding-bottom: env(safe-area-inset-bottom);
}
#bottom-nav .bn-scroll {
  display: flex;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 6px 4px 2px;
  gap: 2px;
}
#bottom-nav .bn-scroll::-webkit-scrollbar { display: none; }
.bn-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 6px 10px;
  cursor: pointer;
  border-radius: 10px;
  min-width: 56px;
  flex-shrink: 0;
  transition: background .15s;
  border: none;
  background: transparent;
  font-family: var(--font);
  color: var(--text2);
}
.bn-item:hover { background: var(--bg3); }
.bn-item.active { background: #1a3d24; }
.bn-item svg { width: 20px; height: 20px; color: #aaa; stroke: currentColor; }
.bn-item.active svg { color: var(--g600); }
.bn-label {
  font-size: 9px;
  font-weight: 500;
  color: var(--text3);
  white-space: nowrap;
}
.bn-item.active .bn-label { color: var(--g400); font-weight: 600; }

/* Show bottom nav only on mobile */
@media (max-width: 900px) {
  #bottom-nav { display: block; }
  #main { padding-bottom: 85px; }
}




#ai-wrap{display:flex;flex-direction:column;height:calc(100vh - 120px);gap:0}
#ai-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:4px 0 16px;scroll-behavior:smooth}
.ai-msg{display:flex;gap:10px;max-width:820px;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.ai-msg.user{flex-direction:row-reverse;align-self:flex-end}
.ai-msg.assistant{align-self:flex-start}
.ai-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;margin-top:2px}
.ai-msg.user .ai-avatar{background:var(--g400);color:#fff}
.ai-msg.assistant .ai-avatar{background:var(--g50);color:var(--g800);border:1px solid var(--g100)}
.ai-bubble{padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.6;max-width:680px;word-break:break-word}
.ai-msg.user .ai-bubble{background:var(--g800);color:#fff;border-bottom-right-radius:4px}
.ai-msg.assistant .ai-bubble{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}
.ai-bubble pre{background:#f4f5f0;border-radius:8px;padding:10px;font-size:11px;overflow-x:auto;margin:8px 0;white-space:pre-wrap}
.ai-bubble code{font-family:monospace;background:#f0f0ec;padding:1px 5px;border-radius:4px;font-size:12px}
.ai-bubble p{margin-bottom:8px}.ai-bubble p:last-child{margin-bottom:0}
.ai-bubble ul,ol{padding-left:18px;margin:6px 0}
.ai-bubble li{margin-bottom:3px}
.ai-bubble strong{font-weight:600}
.ai-typing{display:flex;align-items:center;gap:4px;padding:10px 14px}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--text3);animation:bounce .9s infinite}
.ai-dot:nth-child(2){animation-delay:.15s}.ai-dot:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-7px)}}

/* attachments preview */
#ai-attachments{display:flex;flex-wrap:wrap;gap:6px;padding:6px 0;min-height:0}
.ai-att-chip{display:flex;align-items:center;gap:6px;padding:5px 10px;background:#fff;border:1px solid #e0e0d8;border-radius:99px;font-size:11px;color:#555}
.ai-att-chip .att-rm{cursor:pointer;color:#aaa;font-size:14px;line-height:1;margin-left:2px}
.ai-att-chip .att-rm:hover{color:var(--r400)}
.ai-att-img{width:18px;height:18px;border-radius:3px;object-fit:cover}

/* input bar */
#ai-inputbar{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 4px 16px rgba(0,0,0,.3)}
#ai-inputbar.drag{border-color:var(--g400);background:var(--g50)}
#ai-textarea{width:100%;min-height:42px;max-height:160px;resize:none;border:none;outline:none;font-family:var(--font);font-size:13px;color:var(--text);line-height:1.5;background:transparent}
#ai-textarea::placeholder{color:#bbb}
#ai-bar-bottom{display:flex;align-items:center;gap:8px}
.ai-attach-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;cursor:pointer;color:#888;border-radius:8px;transition:all .15s}
.ai-attach-btn:hover{background:#f4f5f0;color:var(--g800)}
.ai-attach-btn svg{width:17px;height:17px}
.ai-url-input{flex:1;padding:5px 10px;border:1px solid #e8e8e4;border-radius:8px;font-size:12px;outline:none;color:#444;background:#fafaf8;display:none}
.ai-url-input.show{display:block}
#ai-send{margin-left:auto;display:flex;align-items:center;gap:6px;padding:7px 16px;background:var(--g800);color:#fff;border:none;border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}
#ai-send:hover{background:var(--g600)}
#ai-send:disabled{background:#ccc;cursor:not-allowed}
#ai-send svg{width:14px;height:14px}

/* model badge + clear */
.ai-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ai-model-badge{font-size:10px;font-weight:600;color:var(--g600);background:var(--g50);padding:3px 10px;border-radius:99px;border:1px solid var(--g100)}
.ai-clear-btn{font-size:11px;color:#aaa;cursor:pointer;margin-left:auto;padding:3px 8px;border-radius:6px;border:none;background:transparent;font-family:var(--font)}
.ai-clear-btn:hover{color:var(--r400);background:var(--r50)}

/* suggestions */
.ai-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.ai-sug{padding:6px 12px;background:#fff;border:1px solid #e0e0d8;border-radius:99px;font-size:11px;color:#555;cursor:pointer;transition:all .15s;white-space:nowrap}
.ai-sug:hover{border-color:var(--g400);color:var(--g800);background:var(--g50)}



    .dir-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
    .dir-card{background:var(--bg3);border-radius:12px;border:1px solid var(--border);padding:20px}
    .dir-card.full{grid-column:1/-1}
    .dir-card h3{font-size:12px;font-weight:700;color:var(--g800);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;display:flex;align-items:center;gap:8px}
    .dir-card h3 span{font-size:16px}
    .dir-section{margin-bottom:20px}
    .dir-section:last-child{margin-bottom:0}
    .dir-label{font-size:10px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}
    .dir-field-list{display:flex;flex-direction:column;gap:5px}
    .dir-field{display:flex;gap:10px;font-size:12px;align-items:flex-start}
    .dir-field-name{font-weight:600;color:var(--text);min-width:130px;flex-shrink:0}
    .dir-field-desc{color:var(--text2);line-height:1.4}
    .dir-field-req{font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;flex-shrink:0;margin-top:1px}
    .req{background:#fce4d6;color:#c00000}
    .opt{background:#f0f0ec;color:#888}
    .dir-rule{display:flex;gap:10px;padding:10px 12px;border-radius:8px;background:var(--bg4);margin-bottom:6px;font-size:12px;align-items:flex-start}
    .dir-rule-icon{font-size:15px;flex-shrink:0;margin-top:1px}
    .dir-rule-text{color:#444;line-height:1.5}
    .dir-rule-text strong{color:#222}
    .dir-example{background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:12px;font-size:11px;color:var(--g800);font-family:monospace;line-height:1.7;margin-top:8px}
    .dir-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;margin:2px;background:#1a3d24;color:var(--g400)}
    .dir-divider{border:none;border-top:1px solid #f0f0ec;margin:16px 0}
  


    .crono-grid{display:flex;flex-direction:column;gap:16px}
    .crono-fase{background:var(--bg3);border-radius:12px;border:1px solid var(--border);overflow:hidden}
    .crono-fase-header{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
    .crono-fase-num{font-size:10px;font-weight:700;color:#fff;background:var(--g600);border-radius:6px;padding:3px 8px;flex-shrink:0}
    .crono-fase-title{font-size:13px;font-weight:600;color:var(--text);flex:1}
    .crono-fase-date{font-size:11px;color:#aaa;flex-shrink:0;margin-right:8px}
    .crono-tasks{padding:4px 0}
    .crono-task{display:grid;grid-template-columns:32px 1fr 90px 100px;align-items:start;gap:8px;padding:9px 18px;border-bottom:1px solid var(--border);font-size:12px}
    .crono-task:last-child{border-bottom:none}
    .crono-task-num{color:#ccc;font-size:10px;font-weight:600;padding-top:2px}
    .crono-task-title{font-weight:600;color:var(--text);margin-bottom:2px;font-size:12px}
    .crono-task-desc{color:var(--text3);font-size:11px;line-height:1.4}
    .crono-task-resp{color:#999;font-size:11px;text-align:center;padding-top:2px}
    .crono-task-date{font-size:11px;text-align:right;color:#777;padding-top:2px}
    .st-done{background:#e2f0d9;color:#375623;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
    .st-prog{background:#fff2cc;color:#7d6608;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
    .st-sched{background:#dce6f1;color:#2e4482;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
    .st-todo{background:#f0f0ec;color:#888;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
    .st-backlog{background:#f4e6ff;color:#5c2d91;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
    .st-urgent{background:#fce4d6;color:#c00000;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700;white-space:nowrap;animation:blink 1.5s infinite}
    @keyframes blink{0%,100%{opacity:1}50%{opacity:.5}}
    .crono-flag-legend{background:var(--bg3);border-radius:12px;border:1px solid var(--border);padding:18px;margin-bottom:20px}
    .crono-flag-legend h3{font-size:11px;font-weight:600;color:#888;margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
    .flag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
    .flag-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;background:var(--bg4)}
    .flag-badge{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
    .flag-name{font-size:11px;font-weight:600;color:var(--text)}
    .flag-desc{font-size:10px;color:var(--text3);line-height:1.4;margin-top:1px}
  


    /* ── FILTROS ── */
    .campo-filters { background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:14px;display:flex;flex-direction:column;gap:10px; }
    .campo-filters-row { display:flex;flex-wrap:wrap;gap:8px;align-items:center; }
    .cf-search { flex:1;min-width:160px;padding:7px 12px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:var(--bg4);color:var(--text);outline:none;font-family:var(--font); }
    .cf-search:focus { border-color:var(--g400); }
    .cf-select { padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;background:var(--bg4);color:var(--text);outline:none;cursor:pointer;font-family:var(--font); }
    .cf-flags { display:flex;gap:4px;flex-wrap:wrap; }
    .cf-flag-btn { padding:4px 10px;border-radius:99px;border:1px solid var(--border);font-size:11px;font-weight:600;cursor:pointer;background:var(--bg4);color:var(--text2);transition:all .15s;font-family:var(--font); }
    .cf-flag-btn.on { border-color:var(--g400);background:var(--g50);color:var(--g800); }
    .cf-clear { padding:6px 12px;border:none;background:transparent;color:#aaa;font-size:11px;cursor:pointer;font-family:var(--font); }
    .cf-clear:hover { color:var(--r400); }
    .cf-count-badge { font-size:11px;color:var(--g400);font-weight:600;background:#1a3d24;padding:3px 10px;border-radius:99px;white-space:nowrap; }

    /* ── INDICADORES ── */
    .campo-ind { display:block;margin-bottom:14px; }
    .campo-ind-card { background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px; }
    .campo-ind-card h4 { font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px; }
    .ind-bar { display:flex;align-items:center;gap:7px;margin-bottom:6px;font-size:11px; }
    .ind-bar-label { width:90px;flex-shrink:0;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .ind-bar-track { flex:1;height:9px;background:var(--bg4);border-radius:5px;overflow:hidden; }
    .ind-bar-fill { height:100%;border-radius:5px;transition:width .5s ease; }
    .ind-bar-val { width:28px;text-align:right;color:var(--text3); }
    @media(max-width:768px){ .campo-ind{grid-template-columns:1fr;} }

    /* ── LISTA DE ORGS ── */
    .campo-list-wrap { background:var(--bg3);border:1px solid var(--border);border-radius:12px;overflow:hidden; }
    .campo-list-header { display:grid;grid-template-columns:48px 1fr 90px 60px 90px 1fr 100px;gap:6px;padding:8px 14px;background:var(--bg4);border-bottom:2px solid var(--border);font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em; }
    .campo-list-row { display:grid;grid-template-columns:48px 1fr 90px 60px 90px 1fr 100px;gap:6px;padding:9px 14px;border-bottom:1px solid var(--border);align-items:center;cursor:pointer;transition:background .1s; }
    .campo-list-row:hover { background:var(--bg4); }
    .campo-list-row:last-child { border-bottom:none; }
    .org-name-cell { font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .org-n1-cell { font-size:11px;color:var(--text2); }
    .org-uf-cell { font-size:11px;color:#888;text-align:center; }
    .org-bioma-cell { font-size:10px;color:#639922;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .org-tags-cell { font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .campo-load-more { padding:12px;text-align:center;border-top:1px solid var(--border); }
    .btn-load-more { padding:8px 24px;border:1px solid var(--g200);border-radius:99px;background:#fff;color:var(--g700);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font); }
    .btn-load-more:hover { background:var(--g50); }
    @media(max-width:768px){
      .campo-list-header,.campo-list-row { grid-template-columns:40px 1fr 70px; }
      .campo-list-header span:nth-child(n+4),.campo-list-row span:nth-child(n+4) { display:none; }
    }

    /* ── ORG POPUP (Monday-style) ── */
    #org-popup { display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:2000;align-items:flex-end;justify-content:center;padding:0; }
    #org-popup.open { display:flex; }
    @media(min-width:600px){ #org-popup { align-items:center;padding:20px; } }
    .org-popup-box { background:var(--bg2);width:100%;max-width:560px;max-height:88vh;overflow-y:auto;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .2s ease; }
    @media(min-width:600px){ .org-popup-box { border-radius:16px; } }
    @keyframes slideUp { from{transform:translateY(40px);opacity:0} to{transform:none;opacity:1} }
    .org-popup-header { display:flex;justify-content:space-between;align-items:flex-start;padding:18px 18px 12px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1; }
    .org-popup-title { font-size:16px;font-weight:700;color:var(--g400);flex:1;padding-right:12px;line-height:1.3; }
    .org-popup-close { width:28px;height:28px;border:none;background:var(--bg4);border-radius:50%;cursor:pointer;font-size:16px;color:var(--text2);flex-shrink:0;display:flex;align-items:center;justify-content:center; }
    .org-popup-body { padding:16px 18px;display:flex;flex-direction:column;gap:14px; }
    .org-popup-section { display:flex;flex-direction:column;gap:6px; }
    .org-popup-section-title { font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.09em; }
    .org-popup-pills { display:flex;flex-wrap:wrap;gap:5px; }
    .org-popup-field { display:flex;gap:10px;font-size:12px;align-items:flex-start; }
    .org-popup-field-label { font-size:10px;font-weight:600;color:var(--text3);width:80px;flex-shrink:0;padding-top:1px; }
    .org-popup-field-val { color:var(--text);line-height:1.5;flex:1; }
    .org-tag { padding:3px 9px;border-radius:99px;background:var(--bg4);color:var(--text2);font-size:10px; }
    .org-popup-link { display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:8px;border:1px solid #e0e0d8;font-size:12px;font-weight:600;color:var(--b400);text-decoration:none;transition:all .15s; }
    .org-popup-link:hover { background:var(--b50); }
  


    .capt-metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 14px; }
    .capt-metric { background:var(--bg3);border-radius:12px;border:1px solid var(--border);padding:14px 16px; }
    .capt-metric-val { font-size: 20px; font-weight: 700; color: var(--g400); }
    .capt-metric-label { font-size: 10px; color: #888; margin-top: 2px; }
    .capt-metric-sub { font-size: 10px; color: #aaa; margin-top: 1px; }
    .capt-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
    .capt-card { background:var(--bg3);border-radius:12px;border:1px solid var(--border);padding:16px; }
    .capt-card h4 { font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing:.06em; margin-bottom: 12px; }
    .funil-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
    .funil-label { font-size: 11px; color: #555; width: 110px; flex-shrink: 0; }
    .funil-bar-wrap { flex: 1; height: 12px; background: var(--bg4); border-radius: 6px; overflow: hidden; }
    .funil-bar { height: 100%; border-radius: 6px; transition: width .6s ease; }
    .funil-val { font-size: 11px; color: #888; width: 80px; text-align: right; }
    .prop-table { width: 100%; border-collapse: collapse; font-size: 11px; }
    .prop-table th { padding: 8px 10px; text-align: left; font-size: 10px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing:.05em; border-bottom: 2px solid var(--border); }
    .prop-table td { padding: 9px 10px; border-bottom: 1px solid var(--border); color: var(--text); }
    .prop-table tr:hover td { background: var(--bg4); }
    .status-pill { padding: 2px 8px; border-radius: 99px; font-size: 10px; font-weight: 600; white-space: nowrap; }
    .sp-rascunho { background:var(--bg4);color:var(--text2); }
    .sp-enviada { background:#dce6f1;color:#2e4482; }
    .sp-negociacao { background:#fff2cc;color:#7d6608; }
    .sp-aprovada { background:#e2f0d9;color:#375623; }
    .sp-recusada { background:#fce4d6;color:#c00000; }
    .sp-arquivada { background:#f0f0ec;color:#aaa; }
    .conv-box { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
    .conv-item { text-align:center;padding:14px 10px;background:var(--bg4);border-radius:10px; }
    .conv-val { font-size:22px;font-weight:700;color:var(--g800); }
    .conv-label { font-size:10px;color:#888;margin-top:3px; }
    @media(max-width:768px){ .capt-metrics{grid-template-columns:1fr 1fr;} .capt-row{grid-template-columns:1fr;} }

    /* ── MODAL NOVA PROPOSTA ── */
    #modal-proposta { display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;align-items:center;justify-content:center;padding:16px; }
    #modal-proposta.open { display:flex; }
    .modal-box { background:var(--bg2);border-radius:16px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column; }
    .modal-header { display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1; }
    .modal-title { font-size:15px;font-weight:700;color:var(--g400); }
    .modal-close { width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:var(--bg4);border-radius:50%;cursor:pointer;font-size:16px;color:var(--text2); }
    .modal-body { padding:18px 20px;display:flex;flex-direction:column;gap:14px; }
    .form-row { display:grid;grid-template-columns:1fr 1fr;gap:12px; }
    .form-group { display:flex;flex-direction:column;gap:5px; }
    .form-label { font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em; }
    .form-input { padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);outline:none;background:var(--bg4);color:var(--text); }
    .form-input:focus { border-color:var(--g400); }
    .form-select { padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);outline:none;background:var(--bg4);color:var(--text);cursor:pointer; }
    .form-divider { font-size:11px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.07em;padding:4px 0;border-bottom:1px solid #f0f0ec; }
    .chat-area { border:1px solid var(--border);border-radius:10px;overflow:hidden; }
    .chat-msgs { min-height:60px;max-height:140px;overflow-y:auto;padding:10px 12px;font-size:12px;color:var(--text2);background:var(--bg4); }
    .chat-input-row { display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border);background:var(--bg3);align-items:flex-end; }
    .chat-textarea { flex:1;border:none;outline:none;font-size:12px;font-family:var(--font);resize:none;min-height:32px;max-height:80px;background:transparent;color:var(--text); }
    .chat-attach { display:flex;gap:4px; }
    .chat-btn-sm { width:28px;height:28px;border:none;background:transparent;cursor:pointer;color:#888;border-radius:6px;display:flex;align-items:center;justify-content:center; }
    .chat-btn-sm:hover { background:#f0f0ec;color:var(--g800); }
    .chat-att-chips { display:flex;flex-wrap:wrap;gap:4px;padding:4px 10px;min-height:0; }
    .modal-footer { padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;position:sticky;bottom:0;background:var(--bg2); }
    .btn-secondary { padding:8px 16px;border:1px solid var(--border);border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;background:var(--bg4);font-family:var(--font);color:var(--text2); }
    .btn-primary { padding:8px 20px;border:none;border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;background:var(--g800);color:#fff;font-family:var(--font); }
    @media(max-width:768px){ .form-row{grid-template-columns:1fr;} }
  


    #map-wrap { display: flex; gap: 14px; height: calc(100vh - 180px); min-height: 500px; }
    #map-sidebar { width: 260px; flex-shrink: 0; display: flex; flex-direction: column; gap: 10px; overflow-y: auto; }
    #te-map { flex: 1; border-radius: 12px; overflow: hidden; border: 1px solid var(--border); z-index: 0; }
    .te-filter-box { background: var(--bg3); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; }
    .te-filter-title { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 10px; }
    .te-type-btn { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-radius: 8px; cursor: pointer; font-size: 12px; color: var(--text2); transition: background .15s; margin-bottom: 2px; }
    .te-type-btn:hover { background: var(--bg4); }
    .te-type-btn.active { background: var(--bg4); color: var(--text); font-weight: 600; }
    .te-type-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
    .te-type-count { margin-left: auto; font-size: 10px; color: var(--text3); background: var(--bg4); padding: 1px 6px; border-radius: 99px; }
    .te-search { padding: 7px 10px; border: 1px solid var(--border); border-radius: 8px; font-size: 12px; background: var(--bg4); color: var(--text); outline: none; width: 100%; font-family: var(--font); }
    .te-org-list { background: var(--bg3); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; flex: 1; overflow-y: auto; }
    .te-org-title { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 8px; }
    .te-org-item { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--border); font-size: 11px; color: var(--text2); cursor: pointer; }
    .te-org-item:hover { color: var(--g400); }
    .te-org-item:last-child { border-bottom: none; }
    .te-org-flag { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 4px; background: var(--bg4); color: var(--text3); flex-shrink: 0; }
    .te-org-empty { font-size: 12px; color: var(--text3); padding: 12px 0; text-align: center; }

    /* Leaflet overrides for dark mode */
    .leaflet-container { background: #0a0e1a !important; }
    .leaflet-tile { filter: brightness(0.7) invert(1) contrast(3) hue-rotate(200deg) saturate(0.3) brightness(0.7); }
    .leaflet-popup-content-wrapper { background: var(--bg2); color: var(--text); border: 1px solid var(--border); border-radius: 10px; box-shadow: 0 8px 32px rgba(0,0,0,.5); }
    .leaflet-popup-tip { background: var(--bg2); }
    .leaflet-popup-content { margin: 12px 16px; font-family: var(--font); }
    .leaflet-control-zoom a { background: var(--bg3) !important; color: var(--text) !important; border-color: var(--border) !important; }
    .leaflet-control-zoom a:hover { background: var(--bg4) !important; }
    .leaflet-bar { border: 1px solid var(--border) !important; }
    .popup-te-name { font-size: 14px; font-weight: 700; color: var(--g400); margin-bottom: 4px; }
    .popup-te-type { font-size: 10px; color: var(--text3); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 10px; }
    .popup-org-item { display: flex; align-items: center; gap: 6px; font-size: 11px; padding: 4px 0; border-bottom: 1px solid var(--border); color: var(--text2); }
    .popup-org-item:last-child { border-bottom: none; }
    .popup-no-orgs { font-size: 12px; color: var(--text3); padding: 4px 0; }
    @media (max-width: 768px) {
      #map-wrap { flex-direction: column; height: auto; }
      #map-sidebar { width: 100%; max-height: 200px; flex-direction: row; overflow-x: auto; }
      #te-map { height: 340px; }
      .te-org-list { display: none; }
    }
  