/* Prysmo Refatorado — design system fiel (tokens extraídos do app real) */
:root{
  --azul:#2B5E9B; --azul-10:rgba(43,94,155,.10); --azul-d:#1c3f6b; --navy:#002040; --navy2:#3B3E66;
  --bg:#FAFAFA; --branco:#fff; --linha:#e8eaee; --linha2:#eaecef;
  --ink:#1b1b1b; --muted:#7a7f87; --muted2:#9aa0a8;
  --verde:#2e9e5b; --verde-bg:#e7f6ec; --vermelho:#d24b4b; --vermelho-bg:#fdeaea;
  --amarelo:#c98a14; --amarelo-bg:#fdf3e2; --roxo:#6b4fb3; --roxo-bg:#efeafb; --cinza-bg:#eef1f4;
  --coral:#c5563d; --coral-bg:#fde9e4;
  --rail-w:43px; --top-h:58px; --radius:8px; --shadow:0 1px 3px rgba(20,30,45,.06),0 1px 2px rgba(20,30,45,.04);
  --rail-ink:rgba(0,0,0,.54);
  /* aliases compat (telas antigas) */
  --b:#2B5E9B; --line:#e8eaee; --ink:#1b1b1b;
}
/* compat: botão fantasma antigo */
.ghost{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1px solid var(--azul);background:#fff;color:var(--azul);cursor:pointer;text-decoration:none}
.ghost:hover{background:var(--azul-10);text-decoration:none}
button{font:inherit}
h1{font-size:20px;font-weight:600} h3{font-weight:600}
*{box-sizing:border-box}
html,body{margin:0}
body{font:13px/1.5 Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--azul);text-decoration:none} a:hover{text-decoration:underline}

/* ---------- shell (rail BRANCO + ícones-linha cinza, fiel ao atual) ---------- */
.rail{position:fixed;top:0;left:0;bottom:0;width:var(--rail-w);background:#fff;
  border-right:1px solid var(--linha);
  display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;z-index:30}
.rail .logo{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin-bottom:8px}
.rail .logo:hover{text-decoration:none}
.rail a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;
  color:var(--rail-ink);transition:.15s}
.rail a svg{display:block}
.rail a:hover{background:var(--azul-10);color:var(--azul);text-decoration:none}
.rail a.on{background:var(--azul-10);color:var(--azul)}
.topbar{position:fixed;top:0;left:var(--rail-w);right:0;height:var(--top-h);background:var(--branco);
  display:flex;align-items:center;gap:14px;padding:0 22px;border-bottom:1px solid var(--linha);
  box-shadow:0 2px 10px rgba(234,236,239,.7);z-index:20}
.topbar .brand{font-weight:700;color:var(--azul);font-size:17px;letter-spacing:-.3px}
.topbar .crumb{color:var(--muted);font-size:13px}
.topbar .crumb b{color:var(--ink);font-weight:600}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:10px;color:var(--muted)}
[x-cloak]{display:none!important}
.country,.userbox{position:relative}
/* seletor de cliente global "Ver como" (topbar) */
.vercomo{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--linha);
  border-radius:20px;padding:3px 8px 3px 10px;cursor:pointer}
.vercomo:hover{border-color:#cfd5dd}
.vercomo .vc-eye{font-size:14px;line-height:1}
.vercomo select{border:0;background:transparent;font:inherit;font-size:13px;color:var(--ink);
  cursor:pointer;outline:none;max-width:200px}
.vercomo-locked{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--muted);
  padding:5px 10px;border:1px solid var(--linha);border-radius:20px;background:var(--bg)}
.vercomo-locked b{color:var(--azul);font-weight:600}
.country-btn,.user-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--linha);
  border-radius:20px;padding:5px 10px;color:var(--ink);cursor:pointer;font:inherit}
.country-btn:hover,.user-btn:hover{border-color:#cfd5dd}
.country-btn .flag,.country-menu .flag{font-size:15px}
.country-btn .cc{font-size:13px}
.user-btn .uname{font-size:13px;font-weight:500;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.country-menu{position:absolute;right:0;top:38px;background:#fff;border:1px solid var(--linha);border-radius:8px;
  box-shadow:var(--shadow);min-width:180px;display:flex;flex-direction:column;padding:4px;z-index:40}
.country-menu a{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;color:var(--ink)}
.country-menu a:hover{background:var(--bg);text-decoration:none}
.country-menu a.on{color:var(--azul);font-weight:500}
.main{margin-left:var(--rail-w);padding-top:var(--top-h)}
.content{max-width:1180px;margin:0 auto;padding:22px}

/* ---------- header de página ---------- */
.page-head{display:flex;align-items:center;gap:12px;margin:4px 0 16px}
.page-head h1{font-size:20px;font-weight:600;margin:0}
.page-head .count{color:var(--muted);font-size:13px}
.page-head .actions{margin-left:auto;display:flex;gap:8px;align-items:center}

/* ---------- botões ---------- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);
  border:1px solid var(--linha);background:#fff;color:var(--ink);font:inherit;cursor:pointer;white-space:nowrap}
.btn:hover{border-color:#cfd5dd;text-decoration:none}
.btn-primary{background:var(--azul);border-color:var(--azul);color:#fff} .btn-primary:hover{background:var(--azul-d);border-color:var(--azul-d)}
.btn-ghost{background:#fff;color:var(--azul);border-color:var(--azul)}
.btn-export{background:var(--verde);border-color:var(--verde);color:#fff} .btn-export:hover{background:#268a4e;border-color:#268a4e}
.btn-sm{padding:5px 10px;font-size:12px}
.feed-notif{display:inline-flex;align-items:center;gap:8px;font-size:13px}

/* ---------- tabs pill ---------- */
.tabs{display:inline-flex;background:#eef1f4;border-radius:10px;padding:3px;gap:2px;margin-bottom:14px}
.tabs a{padding:7px 16px;border-radius:8px;color:var(--muted);font-weight:500} .tabs a:hover{text-decoration:none;color:var(--ink)}
.tabs a.on{background:#fff;color:var(--azul);box-shadow:var(--shadow)}

/* ---------- chips de filtro/módulo ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.chip{padding:7px 14px;border-radius:20px;background:var(--azul-10);color:var(--azul);font-weight:500;cursor:pointer;border:none;font:inherit}
.chip.on{background:var(--azul);color:#fff}
.chip-x{display:inline-flex;align-items:center;gap:6px;background:#eef1f4;color:var(--ink);border-radius:16px;padding:4px 10px;font-size:12px}
.chip-mod{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border-radius:20px;border:1px solid var(--linha);background:#fff;color:var(--ink);font-weight:500;font-size:13px;cursor:pointer}
.chip-mod:hover{border-color:var(--azul);color:var(--azul);text-decoration:none}
.chip-mod .chip-rm{color:var(--muted2);flex:0 0 auto}
.chip-mod:hover .chip-rm{color:var(--azul)}
.chip-mod.on{background:var(--azul-10);border-color:var(--azul);color:var(--azul)}
.chip-mod.on .chip-rm{color:var(--azul)}

/* ---------- cards ---------- */
.card{background:#fff;border:1px solid var(--linha);border-radius:var(--radius);padding:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.card h3{margin:0 0 10px;font-size:14px;font-weight:600}
.feed-card{border-left:3px solid var(--azul)}
.feed-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.prop-ref a{font-size:14px}
.prop-box{margin-top:10px;border:1px solid var(--linha);border-radius:8px;padding:12px 14px;background:#fcfcfd}
.prop-line{font-size:13px;margin:4px 0;line-height:1.5}
.prop-line b{color:var(--ink)}
.feed-foot{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:10px;border-top:1px solid var(--linha2);font-size:12px}

/* ---------- badges / tags ---------- */
.badge{display:inline-block;padding:2px 9px;border-radius:12px;font-size:11px;font-weight:500;background:var(--cinza-bg);color:#566}
.badge.green{background:var(--verde-bg);color:var(--verde)} .badge.red{background:var(--vermelho-bg);color:var(--vermelho)}
.badge.blue{background:#e7f0fb;color:var(--azul)} .badge.amber{background:var(--amarelo-bg);color:var(--amarelo)}
.badge.purple{background:var(--roxo-bg);color:var(--roxo)}
.badge.beta{background:#f0a92b;color:#fff;font-weight:600}
.badge.dark{background:#2b2f33;color:#fff}
.badge.badge-ico{background:#fff;border:1px solid var(--linha);color:#566;border-radius:6px}
.tag{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11px;margin:1px;background:#eef1f4;color:#4a5560}
.tag.t0{background:#dbe8f7;color:#1c3f6b}.tag.t1{background:var(--verde-bg);color:var(--verde)}.tag.t2{background:var(--roxo-bg);color:var(--roxo)}
.tag.t3{background:var(--amarelo-bg);color:var(--amarelo)}.tag.t4{background:var(--vermelho-bg);color:var(--vermelho)}
.tag.coral{background:var(--coral-bg);color:var(--coral)}
/* chips de TAG do grid de stakeholders: fills saturados (pill colorido + ✕), fiel ao PROD */
.tag-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;font-size:12px;
  font-weight:500;margin:2px 3px 2px 0;line-height:1.2;border:1px solid transparent}
.tag-chip a{display:inline-flex;align-items:center;line-height:0;opacity:.8}
.tag-chip a:hover{opacity:1;text-decoration:none}
.tag-chip.c0{background:#dbe8f7;color:#1c3f6b;border-color:#c2d8f0}
.tag-chip.c1{background:#dcf2e4;color:#1f8049;border-color:#bfe6cd}
.tag-chip.c2{background:#ece2fb;color:#5a3aa3;border-color:#dccdf5}
.tag-chip.c3{background:#fbeccd;color:#9c6a0c;border-color:#f4ddae}
.tag-chip.c4{background:#fcdcdc;color:#c23636;border-color:#f6c4c4}
.verif{display:inline-flex;vertical-align:middle;margin-left:4px}
.class-temas summary::-webkit-details-marker{display:none}
/* chip de TIPO de evento: mais peso/contraste p/ não ler como neutro ao lado dos badges */
.feed-head .tag{font-weight:600}
.tags-cell{display:inline}
.tag-add{display:inline-flex;position:relative;vertical-align:middle}
.tag-plus{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;
  border:1px solid var(--linha);border-radius:7px;background:#fff;color:var(--muted);font-weight:600;
  font-size:15px;line-height:1;cursor:pointer;margin:2px 0}
.tag-plus:hover{border-color:var(--azul);color:var(--azul)}
.tag-add .kebab-menu{left:0;right:auto;top:24px;min-width:170px}
table.leg-table td{vertical-align:top}
table.leg-table .sub{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- avatar ---------- */
.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:#dfe5ec;display:inline-flex;
  align-items:center;justify-content:center;color:#8a94a0;font-weight:600;flex:0 0 auto}

/* ---------- tabela ---------- */
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;color:var(--muted);font-weight:500;font-size:12px;padding:10px 12px;border-bottom:1px solid var(--linha)}
tbody td{padding:11px 12px;border-bottom:1px solid var(--linha);vertical-align:middle}
tbody tr:hover{background:#fafcff}
.cell-person{display:flex;align-items:center;gap:11px}
.cell-person .nm{font-weight:600;color:var(--ink)} .cell-person .sub{color:var(--muted);font-size:12px}

/* ---------- inputs / filtros ---------- */
input,select,textarea{padding:8px 11px;border:1px solid var(--linha);border-radius:var(--radius);font:inherit;background:#fff}
input:focus,select:focus{outline:none;border-color:var(--azul)}
.search{position:relative;flex:1}
.search input{width:100%;padding-left:34px}
.search::before{content:"🔍";position:absolute;left:11px;top:8px;opacity:.5;font-size:12px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.applied{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:12px;margin-bottom:12px}

/* ---------- KPIs / grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.kpi{background:#fff;border:1px solid var(--linha);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.kpi b{display:block;font-size:26px;color:var(--azul);font-weight:700;line-height:1.1}
.kpi span{color:var(--muted);font-size:12px}
.muted{color:var(--muted)} .ok{color:var(--verde)}
.feed-people{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.ppl{display:inline-flex;align-items:center;gap:5px;font-size:12px}
.kebab summary::-webkit-details-marker{display:none}
.kebab summary{color:var(--muted);font-size:18px;padding:2px 6px;border-radius:6px}
.kebab[open] summary{background:var(--azul-10);color:var(--azul)}
.kebab-menu{position:absolute;right:8px;top:30px;background:#fff;border:1px solid var(--linha);border-radius:8px;box-shadow:var(--shadow);z-index:10;min-width:150px;display:flex;flex-direction:column}
.kebab-menu a{padding:8px 12px;color:var(--ink)}.kebab-menu a:hover{background:var(--bg);text-decoration:none}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
@media(max-width:760px){.content{padding:14px}.rail{display:none}.topbar{left:0}.main{margin-left:0}}

/* ---------- login (identidade PROD: navy full-screen + arte poligonal) ---------- */
.login-page{min-height:100vh;margin:0;background:#1b2a4a;color:#fff;overflow:hidden}
.login-art{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.login-wrap{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:48px 24px 90px}
.login-card{width:100%;max-width:380px;text-align:center}
.login-brand{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:30px}
.login-logo{width:54px;height:36px}
.login-word{font-weight:600;color:#fff;font-size:30px;letter-spacing:.5px;line-height:1}
.login-by{font-size:9px;letter-spacing:3px;color:#aeb8cc;font-weight:600}
.login-title{font-size:16px;font-weight:600;text-align:center;margin:0 0 22px;color:#fff}
.login-sub{display:none}
.login-alert{background:rgba(210,75,75,.18);color:#ffc9c9;border:1px solid rgba(210,75,75,.4);
  border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:16px;text-align:center}
.login-form{display:flex;flex-direction:column;gap:14px}
.login-field{display:flex;flex-direction:column;gap:6px;position:relative}
.login-field>span{display:none}
.login-field input{padding:13px 15px;border:1px solid rgba(255,255,255,.25);border-radius:8px;
  font-size:14px;background:rgba(255,255,255,.06);color:#fff;width:100%}
.login-field input::placeholder{color:#aeb8cc}
.login-field input:focus{border-color:#3fae8e;box-shadow:0 0 0 3px rgba(63,174,142,.25);outline:none}
.login-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;
  cursor:pointer;color:#aeb8cc;padding:4px;display:flex;align-items:center}
.login-eye:hover{color:#fff}
.login-btn{justify-content:center;padding:12px;font-size:13px;font-weight:600;letter-spacing:.5px;
  margin-top:6px;background:#fff;color:#1b2a4a;border:none;border-radius:8px;text-transform:uppercase}
.login-btn:hover{background:#eef2f8}
.login-forgot{display:block;margin-top:14px;font-size:13px;color:#aeb8cc;text-decoration:underline}
.login-forgot:hover{color:#fff}
.login-foot{position:fixed;left:0;right:0;bottom:18px;z-index:1;text-align:center;
  color:#aeb8cc;font-size:12px;line-height:1.7}
.login-foot .secure{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:#cdd5e3}

/* ---------- prysmo.ia (rail oculto, saudação grande, prompt cards) ---------- */
body.ia-mode .rail{display:none}
body.ia-mode .topbar{left:0}
body.ia-mode .main{margin-left:0}
body.ia-mode .content{max-width:1280px}
.ia-layout{display:flex;gap:16px;align-items:stretch}
.ia-prompts{flex:0 0 320px;align-self:flex-start}
.ia-main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:calc(100vh - var(--top-h) - 60px)}
.pts{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.prompt-card{display:flex;flex-direction:column;gap:3px;text-align:left;width:100%;background:#fff;
  border:1px solid var(--linha);border-radius:10px;padding:14px 16px;cursor:pointer;font:inherit;transition:.15s}
.prompt-card:hover{border-color:var(--azul);background:var(--azul-10)}
.prompt-card b{font-size:13px;color:var(--ink)}
.prompt-card span{font-size:12px;color:var(--muted)}
.ia-chat{flex:1;min-height:340px;overflow:auto;padding:8px 2px;display:flex;flex-direction:column}
.ia-greet{margin:auto;text-align:center;max-width:520px;padding:24px}
.ia-greet h2{font-size:30px;font-weight:700;line-height:1.25;margin:0 0 14px;color:var(--ink)}
.ia-greet p{color:var(--muted);font-size:14px;line-height:1.6;margin:0}
.ia-bar{margin:8px 0 0}
.ia-chat .msg{margin:8px 0;padding:10px 13px;border-radius:12px;max-width:80%}
.ia-chat .msg.u{background:var(--azul);color:#fff;margin-left:auto}
.ia-chat .msg.a{background:#eef1f4;color:var(--ink)}
/* topbar do modo IA (fiel ao PROD) */
.topbar.ia-topbar{padding:0 18px}
.ia-back{display:inline-flex;align-items:center;gap:5px;color:var(--ink);font-size:14px;font-weight:500}
.ia-back:hover{text-decoration:none;color:var(--azul)}
.topbar.ia-topbar .right{margin-left:auto;display:flex;align-items:center;gap:8px}
.ia-wordmark{font-weight:700;color:var(--azul);font-size:16px;letter-spacing:-.3px}
/* painel Prompts colapsável */
.ia-prompts-head{display:flex;align-items:center;justify-content:space-between}
.ia-collapse{background:#fff;border:1px solid var(--linha);border-radius:7px;width:28px;height:28px;
  display:inline-flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer}
.ia-collapse:hover{border-color:var(--azul);color:var(--azul)}
.ia-prompts.collapsed{flex:0 0 48px;padding:10px 8px}
/* barra superior do chat: chip "Novo chat ✕" + botão "+" quadrado azul */
.ia-chatbar{display:flex;align-items:center;gap:8px}
.ia-newchip{display:inline-flex;align-items:center;gap:7px;background:var(--azul-10);color:var(--azul);
  border-radius:16px;padding:5px 12px;font-size:13px;font-weight:500}
.ia-newchip a{color:var(--azul);font-weight:700;line-height:1}
.ia-add{width:32px;height:32px;border-radius:8px;background:var(--azul);color:#fff;border:none;
  font-size:20px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.ia-add:hover{background:var(--azul-d)}
/* botão enviar = ícone avião (sem texto) */
.ia-send{width:38px;height:38px;border-radius:8px;background:var(--azul);color:#fff;border:none;
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.ia-send:hover{background:var(--azul-d)}
@media(max-width:860px){.ia-layout{flex-direction:column}.ia-prompts{flex:1}}

/* ---------- iOS toggle (reusável: agenda Favoritos, feed Validado, grid Perfis verificados) ---------- */
.ios-toggle{display:inline-flex;align-items:center;width:38px;height:22px;border-radius:11px;background:#cfd5dd;
  padding:2px;transition:.18s;cursor:pointer;flex:0 0 auto;vertical-align:middle}
.ios-toggle:hover{text-decoration:none}
.ios-toggle .knob{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.25);transition:.18s}
.ios-toggle.on{background:var(--azul)}
.ios-toggle.on .knob{transform:translateX(16px)}
.ios-toggle.disabled{opacity:.9;cursor:default}
.fav-toggle{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--ink)}
/* iOS switch funcional (checkbox real escondido + visual) */
.ios-switch-label{display:inline-flex;align-items:center;gap:9px;font-weight:500;color:var(--ink);cursor:pointer}
.ios-switch-input{position:absolute;opacity:0;width:0;height:0}
.ios-switch{display:inline-flex;align-items:center;width:38px;height:22px;border-radius:11px;background:#cfd5dd;padding:2px;transition:.18s}
.ios-switch .knob{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.25);transition:.18s}
.ios-switch-input:checked + .ios-switch{background:var(--azul)}
.ios-switch-input:checked + .ios-switch .knob{transform:translateX(16px)}
.ios-switch-input:focus-visible + .ios-switch{box-shadow:0 0 0 3px var(--azul-10)}

/* ---------- tabs em botões outline (com ícone) ---------- */
.tabs.tabs-outline{background:none;border-radius:0;padding:0;gap:8px}
.tabs.tabs-outline a,.btn-tab{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:8px;
  border:1px solid var(--linha);background:#fff;color:var(--ink);font-weight:500}
.tabs.tabs-outline a:hover{border-color:#cfd5dd;color:var(--ink);text-decoration:none}
.tabs.tabs-outline a.on{border-color:var(--azul);background:var(--azul-10);color:var(--azul);box-shadow:none}
.tabs.tabs-outline a svg{flex:0 0 auto}
.btn-tab{cursor:pointer}
.btn-tab.on{border-color:var(--azul);background:var(--azul-10);color:var(--azul)}
.btn-tab svg{flex:0 0 auto}

/* ---------- agenda: escopo + dia + accordion por órgão ---------- */
.agenda-scope{display:flex;align-items:center;gap:12px;padding:14px 16px;position:relative;overflow:hidden;background:#f5f6f8}
.agenda-scope b{font-size:14px}
.agenda-scope-bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--amarelo)}
.agenda-day{color:var(--muted);font-size:15px;font-weight:500;margin:6px 2px 12px}
.org-accordion{padding:0;overflow:hidden}
.org-accordion>summary{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;cursor:pointer;list-style:none;background:#f7f8fa}
.org-accordion>summary::-webkit-details-marker{display:none}
.org-accordion>summary:hover{background:#f1f3f6}
.org-accordion .org-name{font-weight:600;color:var(--ink)}
.org-accordion .org-count{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;white-space:nowrap}
.org-accordion .chev{transition:transform .18s}
.org-accordion[open] .chev{transform:rotate(180deg)}
.org-accordion .org-body{padding:4px 18px 10px}
.agenda-item{padding:12px 0;border-top:1px solid var(--linha2)}
.agenda-item:first-child{border-top:none}

/* ---------- feed: card de proposição 2 colunas Autores | Relator ---------- */
.feed-people-2col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:10px;
  border:1px solid var(--linha);border-radius:8px;padding:14px 16px;background:#fcfcfd}
.feed-col-label{font-size:12px;color:var(--muted);margin-bottom:8px;font-weight:500}
.feed-col .ppl{display:flex;align-items:flex-start;gap:9px;margin-bottom:8px}
.feed-col .ppl:last-child{margin-bottom:0}
.feed-col .ppl .nm{font-weight:600;color:var(--ink);font-size:13px}
.feed-col .ppl .meta{display:block;color:var(--muted);font-size:11px;line-height:1.4;margin-top:1px}
.feed-validado{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.btn-addtags{margin-top:10px;padding:6px 12px;font-size:12px;color:var(--ink);background:#fff;border:1px solid var(--linha)}
.btn-addtags:hover{border-color:var(--azul);color:var(--azul)}
@media(max-width:620px){.feed-people-2col{grid-template-columns:1fr}}

/* ---------- grid stakeholders: status bolinha+label ---------- */
.status-dot{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink)}
.status-dot::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--muted);flex:0 0 auto}
.status-dot.done::before{background:var(--azul)}
.status-dot.review::before{background:var(--verde)}
/* ---------- matriz: colunas Posição/Impacto alinhadas + larguras ---------- */
.matriz-tbl .col-pos,.matriz-tbl .col-imp{width:130px;text-align:right;white-space:nowrap}
.matriz-tbl thead th.col-pos,.matriz-tbl thead th.col-imp{text-align:right}
.matriz-tbl tbody td:first-child{color:var(--ink);line-height:1.45}
.matriz-tbl .badge{font-size:11px}

/* ---------- convergência: KPI cards flat dentro do card (sem aninhar borda) + células coloridas ---------- */
.conv-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;flex:1}
.conv-kpis .kpi{box-shadow:none;cursor:pointer;transition:.15s}
.conv-kpis .kpi:hover{border-color:var(--azul);background:var(--azul-10)}
.conv-tbl td.pos{font-weight:500}
.conv-tbl td.pos.fav{color:var(--verde)} .conv-tbl td.pos.con{color:var(--vermelho)}
.conv-tbl .col-res{width:140px}
.conv-tbl thead th{white-space:nowrap}

.posic-link{font-weight:600;color:var(--azul);text-decoration:underline}
.ev-title{color:var(--azul);text-decoration:underline}
.ev-title:hover{color:var(--azul-d)}

/* ---------- Mapa de Conexões (canvas interativo) ---------- */
.cx-card{padding:14px}
.cx-legend{display:flex;flex-wrap:wrap;gap:12px;margin-left:auto;align-items:center}
.cx-lg{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink);cursor:pointer;user-select:none}
.cx-lg:hover{color:var(--azul)}
.cx-lg.off{opacity:.4;text-decoration:line-through}
.cx-lg i{width:18px;height:0;border-top:3px solid #999;display:inline-block;border-radius:2px}
.cx-lg i.dash{border-top-style:dashed}
.cx-stage{position:relative;width:100%;height:72vh;min-height:520px;border:1px solid var(--linha);
  border-radius:8px;background:#fbfbfc;overflow:hidden}
#cy{position:absolute;inset:0;width:100%;height:100%}
.cx-counter{position:absolute;top:10px;right:12px;background:#fff;border:1px solid var(--linha);
  border-radius:8px;padding:6px 12px;font-size:12px;color:var(--muted);box-shadow:var(--shadow);z-index:5}
.cx-counter b{color:var(--ink)}
.cx-controls{position:absolute;bottom:14px;left:14px;right:auto;display:flex;flex-direction:column;gap:6px;z-index:9}
.cx-ctl{width:34px;height:34px;border:1px solid var(--linha);background:#fff;border-radius:8px;cursor:pointer;
  font-size:18px;line-height:1;color:var(--ink);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.cx-ctl:hover{border-color:var(--azul);color:var(--azul)}
/* painel de detalhe + filtros (drawers) */
.cx-detail,.cx-filters{position:absolute;top:0;right:0;bottom:0;width:300px;background:#fff;
  border-left:1px solid var(--linha);box-shadow:-2px 0 12px rgba(20,30,45,.08);z-index:8;
  padding:18px 18px 14px;overflow:auto;display:flex;flex-direction:column;gap:12px}
.cx-detail[hidden],.cx-filters[hidden]{display:none}
.cx-detail-x{position:absolute;top:12px;right:12px;border:none;background:none;font-size:16px;
  color:var(--muted);cursor:pointer;line-height:1}
.cx-detail-x:hover{color:var(--ink)}
.cx-detail-head{display:flex;gap:12px;align-items:center;margin-top:6px}
.cx-detail-photo{width:56px;height:56px;border-radius:50%;background:#e8eaee center/cover no-repeat;flex:0 0 auto;border:2px solid #fff;box-shadow:var(--shadow)}
.cx-d-name{font-weight:600;font-size:14px;line-height:1.3}
.cx-d-sub{font-size:12px}
.cx-d-conn-title{font-weight:600;font-size:12px;margin-bottom:6px}
.cx-d-chips{display:flex;flex-wrap:wrap;gap:6px}
.cx-chip{color:#fff;font-size:11px;font-weight:500;padding:3px 9px;border-radius:12px}
.cx-d-desc{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.5;border-top:1px solid var(--linha2);padding-top:8px}
.cx-filters-head{display:flex;align-items:center;justify-content:space-between}
.cx-fgroup{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--linha2);padding-top:10px}
.cx-fglabel{font-weight:600;font-size:12px;color:var(--muted);margin-bottom:2px}
.cx-fgroup label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.cx-fgroup input[type=checkbox]{width:auto}
.cx-fbtns{display:flex;gap:8px;margin-top:auto;justify-content:flex-end;flex-wrap:wrap;align-items:center}
.cx-fgroup select,.cx-fgroup input[type=text],.cx-fgroup #f-nome{width:100%}
.cx-fgroup select:disabled{color:var(--muted2);background:#f6f7f9}
/* modo Pessoas / Instituições */
.cx-fmode{display:flex;gap:6px;border:1px solid var(--linha);border-radius:8px;padding:3px;background:#eef1f4}
.cx-mode{flex:1;padding:7px 10px;border:none;background:none;border-radius:6px;color:var(--muted);font:inherit;font-weight:500;cursor:pointer}
.cx-mode.on{background:#fff;color:var(--azul);box-shadow:var(--shadow)}
/* toggle Lista/Mapa (no header) */
.cx-view-toggle{display:inline-flex;background:#eef1f4;border-radius:8px;padding:3px;gap:2px}
.cx-view-toggle .btn{border:none;background:none;box-shadow:none;color:var(--muted);padding:5px 12px}
.cx-view-toggle .btn:hover{color:var(--ink)}
.cx-view-toggle .btn.on{background:#fff;color:var(--azul);box-shadow:var(--shadow)}
/* toolbar lateral vertical (à esquerda do canvas) */
.cx-toolbar{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;gap:4px;z-index:7;
  background:#fff;border:1px solid var(--linha);border-radius:8px;padding:4px;box-shadow:var(--shadow)}
.cx-tb{width:30px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;
  font-size:16px;line-height:1;color:var(--muted);display:flex;align-items:center;justify-content:center}
.cx-tb:hover{background:var(--azul-10);color:var(--azul)}
.cx-tb.off{color:var(--vermelho)}
/* tabela Lista (alternativa ao Mapa) */
.cx-list{position:absolute;inset:0;background:#fff;overflow:auto;padding:12px 16px;z-index:6}
.cx-list[hidden]{display:none}
.cx-list table{width:100%}
/* modo Lista: oculta controles de canvas (toolbar/zoom/contador) que flutuam sobre a tabela */
.cx-stage.list-mode .cx-toolbar,
.cx-stage.list-mode .cx-controls,
.cx-stage.list-mode .cx-counter{display:none}
