/* MB Gestão Jurídica — estilos */
:root {
  --azul: #16324f;
  --azul-claro: #1f4e79;
  --azul-bg: #eef2f7;
  --fundo: #f7f8fa; /* branco gelo */
  --card: #ffffff;
  --borda: #dde3ea;
  --texto: #1a2433;
  --texto-suave: #5d6b7e;
  --label: #36465c;
  --input-bg: #ffffff;
  --thead: #f6f8fa;
  --kanban-col: #e9edf2;
  --hover: #eef2f7;
  --verde: #2e7d5b;
  --vermelho: #a83a32;
  --laranja: #a8702a;
  --amarelo: #b08a2e;
  --roxo: #5b6b8c;
  --sombra: 0 1px 2px rgba(22, 50, 79, .08);
  --raio: 8px;
}

/* tema escuro — fundo preto fosco, dados em cinza escuro */
html[data-tema="dark"] {
  --azul: #a7bdd6;
  --azul-claro: #3b6ea5;
  --azul-bg: #1c2027;
  --fundo: #0a0c0f;
  --card: #16191e;
  --borda: #262a31;
  --texto: #dadfe7;
  --texto-suave: #8a93a2;
  --label: #aab3c0;
  --input-bg: #101317;
  --thead: #111418;
  --kanban-col: #111418;
  --hover: #1c2026;
  --verde: #4a9377;
  --vermelho: #bb5d55;
  --laranja: #b58a4d;
  --roxo: #7b889e;
  --sombra: 0 1px 3px rgba(0, 0, 0, .4);
}
html[data-tema="dark"] .badge-azul { background: #1d3650; color: #b9d0e6; }
html[data-tema="dark"] .badge-verde { background: #15382b; color: #a8d5c0; }
html[data-tema="dark"] .badge-vermelho { background: #46221f; color: #e6b3ad; }
html[data-tema="dark"] .badge-laranja { background: #3e2f17; color: #dec79a; }
html[data-tema="dark"] .badge-cinza { background: #1f2a3a; color: #aebccd; }
html[data-tema="dark"] .badge-roxo { background: #25304a; color: #c2cde4; }
html[data-tema="dark"] .seg button.ativo { background: var(--azul-claro); color: #fff; }
/* no escuro, a barra lateral funde com o fundo preto fosco */
html[data-tema="dark"] .sidebar { background: #0c0e12; border-right: 1px solid var(--borda); }

/* ícones SVG (traço) */
.ico { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  background: var(--fundo); color: var(--texto); font-size: 13.5px;
  -webkit-font-smoothing: antialiased;
}
b, strong { font-weight: 600; }
::-webkit-scrollbar { width: 9px; height: 9px; }
::-webkit-scrollbar-thumb { background: var(--borda); border-radius: 99px; }
::-webkit-scrollbar-track { background: transparent; }
.hidden { display: none !important; }
a { color: var(--azul-claro); text-decoration: none; }

/* ---------- login ---------- */
.login-screen {
  position: fixed; inset: 0; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(150deg, #16324f 0%, #0e2237 55%, #0a1624 100%);
}
.login-card {
  background: #fff; border-radius: 12px; padding: 40px 36px; width: 380px;
  box-shadow: 0 25px 60px rgba(0,0,0,.35); text-align: center; color: #1a2433;
}
.login-logo {
  width: 58px; height: 58px; margin: 0 auto; border-radius: 12px; background: #16324f; color: #fff;
  display: flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 700; letter-spacing: .5px;
}
.login-card h1 { font-size: 21px; margin: 14px 0 4px; color: #16324f; }
.login-card label { color: #36465c; }
.login-card input { background: #fff; border-color: #dde3ea; color: #1a2433; }
.login-sub { color: var(--texto-suave); font-size: 13px; margin-bottom: 24px; }
.login-card form { text-align: left; display: flex; flex-direction: column; gap: 14px; }

/* ---------- layout ---------- */
.app { display: flex; height: 100vh; }
.sidebar {
  width: 220px; min-width: 220px; background: #0e1928; color: #aebccd;
  display: flex; flex-direction: column; padding: 18px 12px; border-right: 1px solid rgba(255,255,255,.05);
}
.sidebar-logo { font-size: 14.5px; font-weight: 600; color: #fff; padding: 4px 10px 20px; display: flex; align-items: center; gap: 9px; letter-spacing: .2px; }
.logo-marca {
  width: 30px; height: 30px; border-radius: 7px; background: #1f4e79; color: #fff; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center; font-size: 12.5px; font-weight: 700;
}
.sidebar nav { display: flex; flex-direction: column; gap: 1px; flex: 1; }
.sidebar nav a {
  color: #aebccd; padding: 9px 12px; border-radius: 6px; font-size: 13.5px;
  transition: background .15s; display: flex; align-items: center; gap: 10px;
  border-left: 2px solid transparent;
}
.sidebar nav a:hover { background: rgba(255,255,255,.06); color: #fff; }
.sidebar nav a.ativo { background: rgba(63, 110, 158, .22); color: #fff; font-weight: 600; border-left-color: #5d9bd5; }
.sidebar-user { border-top: 1px solid rgba(255,255,255,.12); padding: 12px 10px 0; font-size: 13px; color: #fff; }
.user-papel { color: #94a3b8; font-size: 11.5px; margin: 2px 0 8px; text-transform: capitalize; }

.conteudo { flex: 1; overflow-y: auto; padding: 24px 28px; }
.pagina-cabecalho { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; flex-wrap: wrap; gap: 10px; }
.pagina-cabecalho h1 { font-size: 19px; color: var(--azul); font-weight: 600; letter-spacing: .2px; }
.acoes { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ---------- componentes ---------- */
.card { background: var(--card); border-radius: var(--raio); box-shadow: var(--sombra); padding: 16px 18px; border: 1px solid var(--borda); }
.cards-kpi { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 14px; margin-bottom: 18px; }
.kpi { background: var(--card); border-radius: var(--raio); box-shadow: var(--sombra); padding: 14px 16px; border-left: 3px solid var(--azul-claro); border-top: 1px solid var(--borda); border-right: 1px solid var(--borda); border-bottom: 1px solid var(--borda); }
.kpi .kpi-valor { font-size: 22px; font-weight: 600; letter-spacing: .2px; }
.kpi .kpi-rotulo { color: var(--texto-suave); font-size: 11.5px; margin-top: 3px; }
.kpi.verde { border-left-color: var(--verde); }
.kpi.vermelho { border-left-color: var(--vermelho); }
.kpi.laranja { border-left-color: var(--laranja); }
.kpi.roxo { border-left-color: var(--roxo); }

.btn {
  border: 1px solid var(--borda); background: var(--card); color: var(--texto); padding: 7px 13px;
  border-radius: 7px; cursor: pointer; font-size: 12.5px; font-weight: 500; transition: filter .1s;
}
.btn:hover { filter: brightness(.96); }
.btn-primario { background: var(--azul-claro); border-color: var(--azul-claro); color: #fff; }
.btn-verde { background: var(--verde); border-color: var(--verde); color: #fff; }
.btn-vermelho { background: var(--vermelho); border-color: var(--vermelho); color: #fff; }
.btn-mini { padding: 4px 10px; font-size: 12px; }
.btn-largo { width: 100%; padding: 11px; font-size: 14px; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

label { display: flex; flex-direction: column; gap: 5px; font-size: 11.5px; font-weight: 600; color: var(--label); letter-spacing: .2px; }
input, select, textarea {
  border: 1px solid var(--borda); border-radius: 7px; padding: 8px 10px; font-size: 12.5px;
  font-family: inherit; background: var(--input-bg); color: var(--texto); width: 100%;
}
input:focus, select:focus, textarea:focus { outline: 2px solid #93c5fd; border-color: var(--azul-claro); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-grid .col-2 { grid-column: span 2; }
.form-erro { color: var(--vermelho); font-size: 13px; padding: 8px 0; }
.check { flex-direction: row; align-items: center; gap: 7px; font-weight: 500; }
.check input { width: auto; }

table.tabela { width: 100%; border-collapse: collapse; background: var(--card); border-radius: var(--raio); overflow: hidden; box-shadow: var(--sombra); border: 1px solid var(--borda); }
.tabela th { text-align: left; font-size: 10.5px; text-transform: uppercase; letter-spacing: .6px; color: var(--texto-suave); padding: 9px 12px; border-bottom: 1px solid var(--borda); background: var(--thead); font-weight: 600; }
.tabela td { padding: 9px 12px; border-bottom: 1px solid var(--borda); font-size: 12.5px; vertical-align: middle; }
.tabela tr:last-child td { border-bottom: none; }
.tabela tbody tr:hover { background: var(--hover); cursor: pointer; }
.tabela tr.sem-link:hover { background: inherit; cursor: default; }

.badge { display: inline-block; padding: 2px 8px; border-radius: 99px; font-size: 10.5px; font-weight: 600; letter-spacing: .2px; }
.badge-azul { background: #dbeafe; color: #1d4ed8; }
.badge-verde { background: #dcfce7; color: #15803d; }
.badge-vermelho { background: #fee2e2; color: #b91c1c; }
.badge-laranja { background: #ffedd5; color: #c2410c; }
.badge-cinza { background: #e2e8f0; color: #475569; }
.badge-roxo { background: #ede9fe; color: #6d28d9; }

/* ---------- modal ---------- */
.modal-fundo {
  position: fixed; inset: 0; background: rgba(15,23,42,.55); display: flex;
  align-items: flex-start; justify-content: center; z-index: 100; padding: 40px 16px; overflow-y: auto;
}
.modal {
  background: var(--card); border-radius: 14px; width: 640px; max-width: 100%;
  box-shadow: 0 25px 60px rgba(0,0,0,.3); animation: surge .15s ease-out;
}
.modal.grande { width: 900px; }
@keyframes surge { from { transform: translateY(-12px); opacity: 0; } to { transform: none; opacity: 1; } }
.modal-cabecalho { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--borda); }
.modal-cabecalho h2 { font-size: 16px; color: var(--azul); }
.modal-corpo { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.modal-rodape { padding: 14px 20px; border-top: 1px solid var(--borda); display: flex; justify-content: flex-end; gap: 8px; }
.modal-fechar { background: none; border: none; font-size: 20px; cursor: pointer; color: var(--texto-suave); }

/* ---------- toast ---------- */
#toasts { position: fixed; bottom: 20px; right: 20px; display: flex; flex-direction: column; gap: 8px; z-index: 200; }
.toast { background: #0f172a; color: #fff; padding: 12px 18px; border-radius: 10px; box-shadow: var(--sombra); font-size: 13.5px; animation: surge .2s; max-width: 420px; }
.toast.erro { background: var(--vermelho); }
.toast.sucesso { background: var(--verde); }

/* ---------- kanban ---------- */
.kanban { display: flex; gap: 14px; overflow-x: auto; align-items: flex-start; padding-bottom: 12px; }
.kanban-coluna { background: var(--kanban-col); border-radius: var(--raio); min-width: 270px; width: 270px; flex-shrink: 0; }
.kanban-coluna-titulo { padding: 11px 14px; font-weight: 700; font-size: 13px; display: flex; justify-content: space-between; border-bottom: 2px solid rgba(0,0,0,.06); }
.kanban-cartoes { padding: 10px; display: flex; flex-direction: column; gap: 8px; min-height: 60px; }
.kanban-cartao {
  background: var(--card); border-radius: 7px; padding: 9px 11px; box-shadow: var(--sombra);
  cursor: grab; font-size: 12px; border: 1px solid var(--borda); border-left: 2px solid var(--azul-claro);
}
.kanban-cartao:active { cursor: grabbing; }
.kanban-cartao .titulo { font-weight: 700; font-size: 12.5px; }
.kanban-cartao .meta { color: var(--texto-suave); font-size: 11.5px; margin-top: 4px; }
.kanban-cartoes.arrastando { outline: 2px dashed var(--azul-claro); outline-offset: -4px; border-radius: 8px; }

/* ---------- configurações: menu lateral vertical ---------- */
.config-layout { display: grid; grid-template-columns: 195px 1fr; gap: 20px; align-items: start; }
.config-menu { display: flex; flex-direction: column; gap: 2px; position: sticky; top: 10px; }
.config-menu button {
  text-align: left; background: none; border: none; padding: 8px 13px; border-radius: 7px;
  font-size: 12.5px; font-weight: 500; color: var(--texto-suave); cursor: pointer; font-family: inherit;
  border-left: 2px solid transparent;
}
.config-menu button:hover { background: var(--hover); color: var(--texto); }
.config-menu button.ativo { background: var(--azul-bg); color: var(--azul); font-weight: 600; border-left-color: var(--azul-claro); }
@media (max-width: 900px) { .config-layout { grid-template-columns: 1fr; } .config-menu { flex-direction: row; flex-wrap: wrap; position: static; } }

/* ---------- abas ---------- */
.abas { display: flex; gap: 4px; border-bottom: 2px solid var(--borda); margin-bottom: 16px; flex-wrap: wrap; }
.aba { padding: 9px 16px; cursor: pointer; font-weight: 600; font-size: 13px; color: var(--texto-suave); border-bottom: 2px solid transparent; margin-bottom: -2px; background: none; border-top: none; border-left: none; border-right: none; }
.aba.ativa { color: var(--azul-claro); border-bottom-color: var(--azul-claro); }

/* ---------- filtros ---------- */
.filtros { display: flex; gap: 8px; align-items: flex-end; flex-wrap: wrap; margin-bottom: 16px; }
.filtros label { font-size: 11px; }
.filtros input, .filtros select { width: auto; min-width: 130px; padding: 7px 10px; }
.seg { display: inline-flex; border: 1px solid var(--borda); border-radius: 8px; overflow: hidden; background: var(--card); }
.seg button { border: none; background: none; padding: 6px 12px; cursor: pointer; font-size: 12px; font-weight: 500; color: var(--texto-suave); }
.seg button.ativo { background: var(--azul-claro); color: #fff; }

/* ---------- dashboard ---------- */
.grade-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grade-2 .card h3, .card h3 { font-size: 11.5px; color: var(--texto-suave); text-transform: uppercase; letter-spacing: .7px; margin-bottom: 12px; font-weight: 600; }
.grafico-wrap { position: relative; height: 260px; }

/* ---------- intimações ---------- */
.intimacao { border-left: 4px solid var(--laranja); padding: 12px 14px; background: var(--card); border-radius: 8px; box-shadow: var(--sombra); margin-bottom: 10px; }
.intimacao.tratada { border-color: var(--verde); opacity: .75; }
.intimacao.lida { border-color: var(--azul-claro); }
.intimacao .int-topo { display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 6px; }
.intimacao .int-texto { font-size: 12.5px; color: var(--label); max-height: 80px; overflow: hidden; position: relative; }
.intimacao .int-texto.aberto { max-height: none; }

.lista-vazia { text-align: center; color: var(--texto-suave); padding: 40px; font-size: 13.5px; }
.muted { color: var(--texto-suave); font-size: 12px; }
.linha-flex { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.espaco { flex: 1; }
hr.sep { border: none; border-top: 1px solid var(--borda); margin: 14px 0; }

@media (max-width: 900px) {
  .grade-2 { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .col-2 { grid-column: span 1; }
  .sidebar { width: 64px; min-width: 64px; }
  .sidebar-logo span, .sidebar-user div { display: none; }
}

/* impressão de documentos gerados */
/* ---------- agenda (calendário mensal) ---------- */
.cal-grade { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 1px; background: var(--borda); border: 1px solid var(--borda); border-radius: var(--raio); overflow: hidden; }
.cal-dia { min-width: 0; }
.cal-cab { background: var(--thead); padding: 8px 6px; text-align: center; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--texto-suave); }
.cal-dia { background: var(--card); min-height: 110px; padding: 6px; position: relative; cursor: pointer; transition: background .1s; }
.cal-dia:hover { background: var(--hover); }
.cal-dia.fora { background: var(--thead); opacity: .55; }
.cal-dia .cal-num { font-size: 12px; font-weight: 700; color: var(--texto-suave); }
.cal-dia.hoje .cal-num { background: var(--azul-claro); color: #fff; border-radius: 99px; padding: 2px 7px; }
.cal-dia .cal-add { position: absolute; top: 4px; right: 6px; opacity: 0; font-size: 14px; font-weight: 700; color: var(--azul-claro); }
.cal-dia:hover .cal-add { opacity: 1; }
.cal-item {
  font-size: 11px; padding: 3px 6px; border-radius: 4px; margin-top: 4px; cursor: pointer;
  background: var(--azul-bg); color: var(--texto); border-left: 2px solid var(--azul-claro);
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.cal-item.atrasada { background: rgba(168, 58, 50, .12); border-left-color: var(--vermelho); }
.cal-item.concluida { opacity: .55; text-decoration: line-through; border-left-color: var(--verde); }

/* ---------- lista de processos do contato (estilo AdvBox) ---------- */
.proc-wrap { border: 1px solid var(--borda); border-radius: var(--raio); overflow: hidden; background: var(--card); }
.proc-cab, .proc-item { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) 175px 90px; gap: 12px; align-items: center; padding: 10px 14px; }
.proc-cab { font-size: 10px; text-transform: uppercase; letter-spacing: .5px; color: var(--texto-suave); font-weight: 700; background: var(--thead); border-bottom: 1px solid var(--borda); padding: 8px 14px; }
.proc-item { border-bottom: 1px solid var(--borda); cursor: pointer; position: relative; min-height: 52px; font-size: 12.5px; }
.proc-item:last-child { border-bottom: none; }
.proc-item:hover { background: var(--hover); }
.proc-item .proc-acoes {
  position: absolute; top: 50%; transform: translateY(-50%); right: 10px; display: none; gap: 4px;
  background: var(--card); border: 1px solid var(--borda); border-radius: 8px; padding: 4px 6px; box-shadow: var(--sombra);
}
.proc-item:hover .proc-acoes { display: flex; }
.badge-arquivado { background: var(--vermelho); color: #fff; font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 3px; letter-spacing: .5px; margin-right: 6px; vertical-align: middle; }

/* barra de ações do painel (compromissos) */
.barra-acoes { padding: 8px 12px; gap: 4px; }
.barra-acoes .btn-ico { width: 32px; height: 32px; }
.btn-ico-rel { position: relative; }

/* botões "flat": só ícone + texto, sem fundo */
.btn-flat {
  display: inline-flex; align-items: center; gap: 7px; background: none; border: none;
  color: var(--texto-suave); font-size: 12.5px; font-weight: 500; padding: 7px 10px;
  border-radius: 6px; cursor: pointer; font-family: inherit; white-space: nowrap;
}
.btn-flat:hover { color: var(--texto); background: var(--hover); }
.btn-flat .ico { width: 14px; height: 14px; }

/* campo de pesquisa com ícone embutido */
.campo-busca {
  display: inline-flex; align-items: center; gap: 8px; background: var(--input-bg);
  border: 1px solid var(--borda); border-radius: 99px; padding: 0 14px; height: 32px; width: 270px;
}
.campo-busca .ico { width: 13px; height: 13px; color: var(--texto-suave); flex-shrink: 0; }
.campo-busca input { border: none; background: none; padding: 0; width: 100%; font-size: 12.5px; }
.campo-busca input:focus { outline: none; }
.campo-busca:focus-within { border-color: var(--azul-claro); }

.barra-sep { width: 1px; height: 22px; background: var(--borda); margin: 0 6px; flex-shrink: 0; }

/* menu suspenso (Ordenar / Exportar) */
.menu-pop {
  position: fixed; z-index: 300; background: var(--card); border: 1px solid var(--borda);
  border-radius: 8px; box-shadow: 0 10px 30px rgba(0,0,0,.3); padding: 4px; display: flex;
  flex-direction: column; min-width: 180px;
}
.menu-pop button {
  background: none; border: none; text-align: left; padding: 8px 12px; cursor: pointer;
  color: var(--texto); font-size: 12.5px; border-radius: 5px; font-family: inherit;
}
.menu-pop button:hover { background: var(--hover); }
.notif {
  position: absolute; top: -6px; right: -6px; background: var(--vermelho); color: #fff;
  font-size: 9px; font-weight: 600; border-radius: 99px; padding: 1px 5px; line-height: 1.5; min-width: 16px; text-align: center;
}

/* linhas de compromisso do painel */
.comp-item {
  display: grid; grid-template-columns: 14px minmax(0, 2.6fr) minmax(0, 1.3fr) 110px 100px 150px;
  gap: 10px; align-items: center; padding: 10px 14px; border-bottom: 1px solid var(--borda);
  cursor: pointer; position: relative; font-size: 12.5px;
}
.comp-item:last-child { border-bottom: none; }
.comp-item:hover { background: var(--hover); }
.comp-head {
  cursor: default; font-size: 10.5px; text-transform: uppercase; letter-spacing: .6px;
  color: var(--texto-suave); font-weight: 600; padding: 8px 14px; background: var(--thead);
}
.comp-head:hover { background: var(--thead); }
.comp-head [data-ord] { cursor: pointer; }
.comp-head [data-ord]:hover { color: var(--texto); text-decoration: underline; }
.comp-parte { cursor: pointer; }
.comp-parte:hover { color: var(--texto); text-decoration: underline; }

/* coluna de ações nas tabelas (botões lado a lado, sem quebra) */
.tabela td.acoes-linha { white-space: nowrap; text-align: right; }

/* caixa de detalhe da tarefa (estilo AdvBox) */
.det-topbar {
  display: flex; align-items: center; gap: 8px; padding-bottom: 12px;
  border-bottom: 1px solid var(--borda); margin-bottom: 16px;
}
.det-grid { display: grid; grid-template-columns: minmax(0, 1fr) 240px; gap: 22px; }
.det-lateral { border-left: 1px solid var(--borda); padding-left: 18px; font-size: 13px; }
.det-linha { display: flex; gap: 12px; padding: 5px 0; align-items: baseline; }
.det-rotulo {
  width: 110px; flex-shrink: 0; font-size: 10.5px; text-transform: uppercase;
  letter-spacing: .5px; color: var(--texto-suave); font-weight: 600;
}
.det-log { margin-top: 10px; border-top: 1px solid var(--borda); padding-top: 8px; }
.avatar-ini {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 99px; background: var(--azul-claro, #7b88e0);
  color: #fff; font-size: 10px; font-weight: 700; margin-right: 2px; vertical-align: middle;
}

/* indicadores de rentabilidade na aba histórico da ficha do processo */
.grade-kpi-ficha {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 8px; margin-bottom: 14px;
}
.grade-kpi-ficha > div {
  background: var(--card); border: 1px solid var(--borda); border-radius: 9px; padding: 9px 11px;
  display: flex; flex-direction: column; gap: 2px;
}
.grade-kpi-ficha b { font-size: 15px; }
.grade-kpi-ficha span { font-size: 10.5px; color: var(--texto-suave); text-transform: uppercase; letter-spacing: .4px; }

/* teor completo da intimação dentro da caixa de tratamento */
.int-teor-box {
  background: var(--hover); border: 1px solid var(--borda); border-radius: 9px;
  padding: 12px 14px; font-size: 12.5px; line-height: 1.6; white-space: pre-wrap;
  max-height: 260px; overflow-y: auto; margin-bottom: 14px;
}

/* caixinha de conclusão rápida nas listas de tarefas (painel e atividades) */
.chk-concluir {
  width: 15px; height: 15px; accent-color: var(--verde); cursor: pointer;
  flex-shrink: 0; vertical-align: middle; margin: 0;
}
.riscada, .riscada td, .riscada .titulo, .riscada .meta, .riscada > div {
  text-decoration: line-through; opacity: .92;
}
.riscada { opacity: .6; }
.riscada .proc-acoes, .riscada .chk-concluir { text-decoration: none; }

/* botão Concluir: hover verde-claro; concluída = verde com letra branca (clicável para desmarcar) */
.btn-concluir { transition: background .12s, color .12s, border-color .12s; }
.btn-concluir:hover { background: rgba(74, 147, 119, .18); border-color: var(--verde); color: var(--verde); }
.btn-concluir.ativo { background: var(--verde); border-color: var(--verde); color: #fff; }
.btn-concluir.ativo:hover { background: var(--verde); color: #fff; opacity: .9; }

/* caixa flutuante com o teor da intimação (hover) */
.tip-flutuante {
  position: fixed; z-index: 300; max-width: 560px; max-height: 340px; overflow: hidden;
  background: var(--card); border: 1px solid var(--borda); border-radius: 10px;
  box-shadow: 0 6px 24px rgba(0, 0, 0, .25); padding: 12px 14px;
  font-size: 12px; line-height: 1.55; color: var(--texto);
  white-space: pre-wrap; pointer-events: none;
}
.comp-item .proc-acoes {
  position: absolute; right: 10px; top: 50%; transform: translateY(-50%); display: none; gap: 4px;
  background: var(--card); border: 1px solid var(--borda); border-radius: 8px; padding: 3px 5px; box-shadow: var(--sombra);
}
.comp-item:hover .proc-acoes { display: flex; }
.comp-dot { width: 8px; height: 8px; border-radius: 99px; display: inline-block; }

/* chave liga/desliga (switch) */
input.switch {
  appearance: none; -webkit-appearance: none; position: relative; width: 34px; height: 18px;
  background: var(--borda); border-radius: 99px; cursor: pointer; border: none; outline: none;
  transition: background .15s; flex-shrink: 0; vertical-align: middle; padding: 0;
}
input.switch::after {
  content: ''; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px;
  border-radius: 99px; background: #fff; transition: left .15s; box-shadow: 0 1px 2px rgba(0,0,0,.3);
}
input.switch:checked { background: var(--verde); }
input.switch:checked::after { left: 18px; }
input.switch:disabled { opacity: .5; cursor: not-allowed; }

/* avatar com iniciais e indicador de status */
.avatar {
  width: 30px; height: 30px; border-radius: 99px; background: var(--azul-claro); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600;
  flex-shrink: 0; position: relative;
}
.avatar::after {
  content: ''; position: absolute; bottom: -1px; right: -1px; width: 9px; height: 9px;
  border-radius: 99px; border: 2px solid var(--card);
}
.avatar.on::after { background: #3dba7e; }
.avatar.off::after { background: var(--texto-suave); }

/* botões só de ícone com tooltip nativo (title) */
.btn-ico {
  width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid transparent; background: none; border-radius: 6px; cursor: pointer; color: var(--texto-suave); padding: 0;
}
.btn-ico:hover { color: var(--azul-claro); background: var(--azul-bg); }
.btn-ico.perigo:hover { color: var(--vermelho); background: rgba(168, 58, 50, .1); }
.btn-ico .ico { width: 15px; height: 15px; }

/* ---------- painel lateral (ficha do processo) ---------- */
.drawer-fundo { position: fixed; inset: 0; background: rgba(8, 14, 23, .5); z-index: 150; display: flex; justify-content: flex-end; }
.drawer {
  width: 480px; max-width: 100%; height: 100%; background: var(--card); overflow-y: auto;
  padding: 18px 22px 30px; box-shadow: -14px 0 44px rgba(0,0,0,.3); animation: desliza .18s ease-out;
}
@keyframes desliza { from { transform: translateX(40px); opacity: 0; } to { transform: none; opacity: 1; } }
.ficha-toolbar { display: flex; gap: 5px; align-items: center; margin-bottom: 16px; }
.ficha-toolbar .btn-ico { border: 1px solid var(--borda); }
.ficha-toolbar .btn-ico.ativo { background: var(--azul-claro); color: #fff; border-color: var(--azul-claro); }
.ficha-titulo { font-size: 15px; font-weight: 700; letter-spacing: .3px; }
.ficha-num { color: var(--texto-suave); font-size: 12.5px; display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.drawer .form-grid { grid-template-columns: 1fr 1fr; }
.drawer .form-grid .col-2 { grid-column: span 2; }
.drawer h4 { font-size: 11.5px; text-transform: uppercase; letter-spacing: .5px; color: var(--texto-suave); margin: 18px 0 10px; border-top: 1px solid var(--borda); padding-top: 14px; }
.tl-item { display: flex; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--borda); font-size: 12.5px; }
.tl-item .tl-data { color: var(--texto-suave); white-space: nowrap; font-size: 11.5px; width: 78px; flex-shrink: 0; }

/* compat: cartão antigo */
.proc-linha { position: relative; border: 1px solid var(--borda); border-radius: var(--raio); padding: 10px 12px; margin-top: 8px; background: var(--card); }

.expansor { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 5px; border: 1px solid var(--borda); background: var(--card); cursor: pointer; font-weight: 700; color: var(--azul-claro); font-size: 14px; line-height: 1; }

@media print {
  .sidebar, .pagina-cabecalho .acoes, #toasts { display: none !important; }
}
