:root{
  --bg:#f4f7fb;
  --surface:#ffffff;
  --ink:#13315c;          /* marinho da logo Eunom.IA */
  --ink-2:#586074;
  --muted:#98a1b5;
  --line:#e9edf4;
  --line-2:#f0f3f9;
  --brand:#1f6fd6;        /* azul Eunom.IA */
  --brand-d:#13315c;      /* marinho p/ títulos/links fortes */
  --brand-soft:#e9f1fe;
  --accent:#29a3e0;       /* azul claro do "ia" */
  --accent-soft:#e3f5fc;
  --ok:#16a05a;       --ok-soft:#e6f6ed;
  --warn:#c07d12;     --warn-soft:#fdf3dc;
  --danger:#dd403a;   --danger-soft:#fde7e6;
  --violet:#7c3aed;   --violet-soft:#f2ebfe;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(19,49,92,.04), 0 4px 18px rgba(19,49,92,.06);
  --shadow-soft:0 1px 3px rgba(19,49,92,.05);
  --sans:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--ink-2);font-family:var(--sans);
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:var(--brand);text-decoration:none}
h1{font-size:1.55rem;color:var(--ink);font-weight:800;margin:.1rem 0 .2rem;letter-spacing:-.02em}
h2{font-size:1.05rem;color:var(--ink);font-weight:700;margin:0;letter-spacing:-.01em}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:236px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.brand{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  height:62px;box-sizing:border-box;padding:0 1rem;
  border-bottom:1px solid var(--line);
  font-size:1rem;color:var(--ink);font-weight:600;letter-spacing:-.01em;white-space:nowrap;
}
.brand b{font-weight:800}
.brand .logo{
  width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--brand),#5b8cff);
  display:grid;place-items:center;color:#fff;flex-shrink:0;
}
.sidebar nav{display:flex;flex-direction:column;gap:2px;padding:.7rem .7rem .4rem;overflow-y:auto}
.sidebar nav a{
  display:flex;align-items:center;gap:.7rem;padding:.6rem .8rem;border-radius:10px;
  color:var(--ink-2);font-weight:600;font-size:.92rem;transition:background .12s,color .12s;
}
.sidebar nav a svg{width:19px;height:19px;stroke:currentColor;flex-shrink:0;opacity:.85}
.sidebar nav a:hover{background:var(--line-2);color:var(--ink)}
.sidebar nav a.active{background:var(--brand-soft);color:var(--brand-d);box-shadow:inset 3px 0 0 var(--brand)}
.sidebar nav a.active svg{opacity:1;color:var(--brand)}
.sidebar-foot{margin-top:auto;padding:.7rem;border-top:1px solid var(--line)}
.sidebar-foot a{display:flex;align-items:center;gap:.7rem;padding:.6rem .8rem;border-radius:10px;color:var(--ink-2);font-weight:600;font-size:.92rem}
.sidebar-foot a svg{width:19px;height:19px;stroke:currentColor}
.sidebar-foot a:hover{background:var(--danger-soft);color:var(--danger)}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;gap:1rem;padding:.9rem 1.6rem;background:var(--surface);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;
}
.topbar .quick{display:flex;gap:.5rem;flex-wrap:wrap}
.topbar .esp{flex:1}
.topbar .user{display:flex;align-items:center;gap:.55rem;font-weight:700;color:var(--ink);font-size:.92rem}
.topbar .avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-soft);color:var(--brand-d);
  display:grid;place-items:center;font-weight:800;font-size:.85rem}
.content{padding:1.7rem 1.6rem;max-width:1180px;width:100%}

/* ---------- Cards de resumo ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin:1.1rem 0 1.6rem}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem 1.3rem;box-shadow:var(--shadow);transition:transform .14s,box-shadow .14s}
.card .rot{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:700}
.card .num{font-size:2.15rem;line-height:1.1;font-weight:800;color:var(--ink);margin-top:.25rem;letter-spacing:-.02em}
.card.vencido .num{color:var(--danger)}
.card.hoje .num{color:var(--violet)}
.card.alerta .num{color:var(--warn)}
.card.brand .num{color:var(--brand)}

/* painel em 2 colunas */
.painel{display:grid;grid-template-columns:1.6fr 1fr;gap:1.2rem;align-items:start}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.panel .ph{display:flex;align-items:center;gap:.6rem;padding:1.1rem 1.3rem;border-bottom:1px solid var(--line-2)}
.panel .ph .esp{flex:1}
.panel .pb{padding:.4rem 0}

/* lista estilo "tarefas" do painel */
.task{display:flex;gap:.8rem;padding:.85rem 1.2rem;border-bottom:1px solid var(--line-2)}
.task:last-child{border-bottom:none}
.task .dot{width:9px;height:9px;border-radius:50%;margin-top:.45rem;flex-shrink:0;background:var(--muted)}
.task.vencido .dot{background:var(--danger)} .task.hoje .dot{background:var(--violet)}
.task.alerta .dot{background:var(--warn)} .task.ok .dot{background:var(--ok)}
.task .corpo{flex:1;min-width:0}
.task .tit{color:var(--brand-d);font-weight:700;font-size:.95rem}
.task .sub{color:var(--ink-2);font-size:.86rem}
.task .meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;flex-wrap:wrap}
.task .data{color:var(--ink);font-weight:700;font-size:.82rem;white-space:nowrap}

/* mini barras */
.bars{padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.85rem}
.bar-row{display:grid;grid-template-columns:96px 1fr 30px;align-items:center;gap:.6rem}
.bar-row .lbl{font-size:.82rem;font-weight:600;color:var(--ink-2)}
.bar-row .track{background:var(--line-2);border-radius:999px;height:10px;overflow:hidden}
.bar-row .fill{height:100%;border-radius:999px}
.bar-row .val{font-size:.85rem;font-weight:800;color:var(--ink);text-align:right}
.fill.vencido{background:var(--danger)} .fill.hoje{background:var(--violet)}
.fill.alerta{background:var(--warn)} .fill.brand{background:var(--brand)}

/* ---------- Tabelas ---------- */
.tablewrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:auto}
table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{text-align:left;padding:.8rem 1rem;border-bottom:1px solid var(--line-2);vertical-align:top}
th{background:#f7f9fd;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;
  font-weight:700;position:sticky;top:0}
td{color:var(--ink-2)}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#f6f9ff}
td.acoes{white-space:nowrap;text-align:right}
.mono{font-family:inherit;font-size:inherit;color:var(--ink)}
td strong,.tit-link{color:var(--brand-d);font-weight:700}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.73rem;
  font-weight:800;letter-spacing:.2px;white-space:nowrap;text-transform:uppercase}
.badge.ok{background:var(--ok-soft);color:var(--ok)}
.badge.alerta{background:var(--warn-soft);color:var(--warn)}
.badge.vencido{background:var(--danger-soft);color:var(--danger)}
.badge.hoje{background:var(--violet-soft);color:var(--violet)}
.badge.neutro{background:var(--line-2);color:var(--muted)}
.badge.pend{background:var(--warn-soft);color:var(--warn);border:1px dashed #e3c07a}

/* ---------- Botões / forms ---------- */
.btn{display:inline-flex;align-items:center;gap:.4rem;background:var(--brand);color:#fff;border:none;
  border-radius:10px;padding:.58rem 1.05rem;cursor:pointer;font-family:var(--sans);font-weight:700;
  font-size:.88rem;transition:background .12s,transform .04s,box-shadow .12s;box-shadow:0 1px 2px rgba(31,111,214,.18)}
.btn:hover{background:var(--brand-d);box-shadow:0 2px 8px rgba(31,111,214,.22)} .btn:active{transform:translateY(1px)}
.btn.sm{padding:.4rem .75rem;font-size:.82rem;border-radius:9px;box-shadow:none}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--line-2)}
.btn.accent{background:var(--brand)}
.btn.danger{background:#fff;color:var(--danger);border:1px solid #f1cfcd;box-shadow:none}
.btn.danger:hover{background:var(--danger-soft)}
.barra{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin:0 0 1.1rem}
.barra .esp{flex:1}

label{display:block;font-size:.78rem;color:var(--ink-2);font-weight:700;margin:.6rem 0 .2rem}
input,select,textarea{width:100%;padding:.55rem .65rem;border:1px solid var(--line);border-radius:10px;
  background:#fff;font:inherit;font-size:.9rem;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-soft)}
textarea{min-height:76px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.2rem .9rem}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.2rem .9rem}

/* ---------- Modal ---------- */
dialog{border:none;border-radius:18px;padding:1.6rem;max-width:640px;width:92%;
  background:var(--surface);box-shadow:0 24px 70px rgba(24,34,58,.28)}
dialog::backdrop{background:rgba(24,34,58,.4);backdrop-filter:blur(2px)}
dialog h2{margin-bottom:.8rem}

/* ---------- Flash ---------- */
.flash{padding:.75rem 1rem;border-radius:11px;margin-bottom:1rem;font-size:.9rem;font-weight:600;
  display:flex;align-items:center;gap:.5rem}
.flash.ok{background:var(--ok-soft);color:var(--ok)}
.flash.erro{background:var(--danger-soft);color:var(--danger)}

/* ---------- Login ---------- */
.login-screen{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(1200px 600px at 50% -10%,#dfe9ff,transparent),var(--bg)}
.login-wrap{width:380px;max-width:92vw;background:var(--surface);border:1px solid var(--line);
  border-radius:20px;padding:2.2rem 2rem;box-shadow:var(--shadow)}
.login-wrap .brand{justify-content:center;padding:0 0 1.2rem}
.login-wrap h1{text-align:center;font-size:1.2rem;margin-bottom:1rem}

.muted{color:var(--muted);font-size:.86rem}
.empty{padding:2.2rem 1.2rem;text-align:center;color:var(--muted)}
.aviso{background:var(--warn-soft);border:1px solid #f0d79a;border-radius:12px;padding:.8rem 1rem;
  font-size:.86rem;color:#8a6212;margin:1rem 0}
code{background:var(--line-2);padding:.12rem .4rem;border-radius:6px;font-size:.85rem;color:var(--ink)}

/* ---------- Responsivo ---------- */
@media(max-width:860px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--line)}
  .sidebar nav{flex-direction:row;overflow-x:auto;padding:.4rem .6rem}
  .sidebar nav a span{display:none}
  .sidebar-foot{border-top:none}
  .painel{grid-template-columns:1fr}
  .grid2,.grid3{grid-template-columns:1fr}
}

/* ===== Cartões do painel centralizados + clicáveis ===== */
.card.center{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:104px}
.card.center .rot{order:1} .card.center .num{order:2;margin-top:.35rem}
a.card{text-decoration:none;transition:transform .08s,box-shadow .12s}
a.card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(24,34,58,.10)}

/* ===== Faixa de alerta ===== */
.alert-banner{display:flex;align-items:center;gap:.7rem;background:var(--danger-soft);
  border:1px solid #f1cfcd;color:var(--danger);border-radius:12px;padding:.8rem 1.1rem;margin-bottom:1.2rem;font-weight:600}
.alert-banner.warn{background:var(--warn-soft);border-color:#f0d79a;color:#8a6212}
.alert-banner a{margin-left:auto;font-weight:700}

/* ===== Grid de painéis do dashboard ===== */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:start;margin-top:1.2rem}
.dash-grid .full{grid-column:1 / -1}
@media(max-width:860px){.dash-grid{grid-template-columns:1fr}}

/* ===== Abas ===== */
.tabs{display:flex;gap:.3rem;border-bottom:1px solid var(--line);margin:0 0 1.2rem}
.tabs a{padding:.6rem 1rem;font-weight:700;color:var(--ink-2);border-bottom:2px solid transparent;font-size:.92rem}
.tabs a:hover{color:var(--ink)}
.tabs a.active{color:var(--brand-d);border-bottom-color:var(--brand)}
.tabs .badge{margin-left:.35rem}

/* ===== Timeline (histórico) ===== */
.timeline{list-style:none;margin:0;padding:.4rem 0}
.timeline li{position:relative;padding:.55rem 0 .55rem 1.4rem;border-bottom:1px solid var(--line-2)}
.timeline li:last-child{border-bottom:none}
.timeline li::before{content:"";position:absolute;left:2px;top:.95rem;width:8px;height:8px;border-radius:50%;background:var(--brand)}
.timeline .tdata{font-size:.8rem;color:var(--muted);font-weight:700}
.timeline .tgrau{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}

/* ===== Detalhe (cabeçalho de processo) ===== */
.ficha-head{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.3rem 1.4rem;margin-bottom:1.2rem}
.ficha-head h1{margin:.2rem 0}
.ficha-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;margin-top:.6rem;font-size:.9rem}
.ficha-meta b{color:var(--ink)}
.kv{display:grid;grid-template-columns:180px 1fr;gap:.55rem 1rem;font-size:.85rem;line-height:1.5}
.kv dt{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.3px;padding-top:.04rem}
.kv dd{margin:0;color:var(--ink);font-weight:500;font-size:.85rem}
.kv dd.mono, .kv dd .mono{font-size:inherit}

/* publicação detalhe 2 colunas */
.pub-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1.2rem;align-items:start}
.pub-grid>.col-dir{display:flex;flex-direction:column}
@media(max-width:860px){.pub-grid{grid-template-columns:1fr}}
.teor{white-space:pre-wrap;font-size:.9rem;color:var(--ink-2);background:#fafbfe;border:1px solid var(--line-2);
  border-radius:10px;padding:.9rem;max-height:340px;overflow:auto}
.sug-box{background:var(--brand-soft);border:1px solid #cfe0ff;border-radius:12px;padding:1rem;margin-top:1rem}

/* dropdown simples */
.drop{position:relative;display:inline-block}
.drop-menu{display:none;position:absolute;right:0;top:110%;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 12px 40px rgba(24,34,58,.18);min-width:230px;z-index:20;padding:.35rem}
.drop-menu a{display:block;padding:.55rem .7rem;border-radius:8px;color:var(--ink);font-weight:600;font-size:.9rem}
.drop-menu a:hover{background:var(--brand-soft);color:var(--brand-d)}
.drop.open .drop-menu{display:block}

.link-cli{color:var(--brand-d);font-weight:700;cursor:pointer}
.link-cli:hover{text-decoration:underline}

/* Linha clicável (pendência 9) */
tr.linha-clic{cursor:pointer}
tr.linha-clic:hover td{background:#f8faff}

/* Responsividade: tabelas viram cartões no celular (pendência 7) */
@media(max-width:680px){
  .tablewrap{border:none;box-shadow:none;background:transparent}
  table, thead, tbody, th, td, tr{display:block}
  thead{display:none}
  tr{background:var(--surface);border:1px solid var(--line);border-radius:12px;
     margin-bottom:.7rem;padding:.5rem .2rem;box-shadow:var(--shadow)}
  td{border:none;padding:.35rem .9rem}
  td.acoes{text-align:left;padding-top:.5rem}
  .cards{grid-template-columns:1fr 1fr}
}

/* Status do processo (pendência F) */
.badge.warn-b{background:var(--warn-soft,#fef3da);color:#8a6212}
.badge.info-b{background:#e6effe;color:#1f5bb5}

/* Cartão de contador selecionado (pendência N) */
a.card.sel{outline:2px solid var(--brand);outline-offset:1px;box-shadow:0 4px 16px rgba(37,99,235,.18)}

/* Logo Eunom.IA na sidebar */
.brand{padding:.4rem .2rem}
.brand-logo{width:140px;max-width:100%;height:auto;display:block}

/* Campo travado (cliente vindo do processo) - pendência S */
input.travado{background:#eef1f6;color:#667;cursor:not-allowed}

/* Abas de atividades na ficha (Abertas|Concluídas) - pendência P */
.tabbtn{background:none;border:none;cursor:pointer;font:inherit;color:var(--ink-3,#8a93a6);
  padding:.3rem .6rem;border-radius:8px;font-weight:600;font-size:.85rem}
.tabbtn.active{color:var(--brand);background:#eef3ff}
a.task.linha-ativ{text-decoration:none;color:inherit;cursor:pointer}
a.task.linha-ativ:hover{background:#f6f9ff}

/* Checkbox com label (monitoramento) */
label.chk{display:flex;align-items:center;gap:.45rem;font-weight:500;color:var(--ink-2);cursor:pointer;font-size:.9rem}
label.chk input{width:auto;margin:0}

/* ===== Calendário (Dia/Semana/Mês) ===== */
.cal-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin:.6rem 0}
.cal-views{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.cal-views button{border:0;background:#fff;padding:.4rem .8rem;cursor:pointer;font:inherit;color:var(--ink-2)}
.cal-views button.active{background:var(--brand);color:#fff}
.cal-nav{display:inline-flex;gap:.3rem;align-items:center}
.cal-titulo{font-weight:700;font-size:1.05rem;color:var(--ink);min-width:180px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;width:100%}
.cal-dow{background:#f7f9fc;padding:.4rem;text-align:center;font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;min-width:0}
.cal-cel{background:#fff;min-height:96px;padding:.3rem;display:flex;flex-direction:column;gap:.2rem;min-width:0;overflow:hidden}
.cal-cel.fora{background:#fafbfc}
.cal-cel .dia-num{font-size:.82rem;color:var(--ink-2);font-weight:600;align-self:flex-end}
.cal-cel.hoje{background:var(--brand-soft)}
.cal-cel.hoje .dia-num{background:var(--brand);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.cal-ev{font-size:.72rem;padding:.12rem .35rem;border-radius:5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid;max-width:100%;box-sizing:border-box}
.cal-ev.prazo{background:#fee2e2;border-color:#ef4444;color:#991b1b}
.cal-ev.tarefa{background:#fef9c3;border-color:#eab308;color:#854d0e}
.cal-ev.audiencia{background:#dbeafe;border-color:#3b82f6;color:#1e40af}
.cal-ev.done{opacity:.55;text-decoration:line-through}
.cal-ev.cancel{opacity:.55;text-decoration:line-through;background:#fee2e2;border-color:#ef4444;color:#991b1b}
.cal-mais{font-size:.7rem;color:var(--muted);cursor:pointer;padding:.1rem .35rem}
/* semana/dia: lista por dia */
.cal-lista-dia{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cal-dia-bloco{display:grid;grid-template-columns:120px 1fr;border-bottom:1px solid var(--line)}
.cal-dia-bloco:last-child{border-bottom:0}
.cal-dia-rotulo{background:#f7f9fc;padding:.6rem;font-size:.82rem;font-weight:600;color:var(--ink-2)}
.cal-dia-rotulo.hoje{background:var(--brand-soft);color:var(--brand-d)}
.cal-dia-eventos{padding:.5rem;display:flex;flex-direction:column;gap:.35rem}
.cal-dia-eventos .cal-ev{white-space:normal;font-size:.82rem;padding:.35rem .6rem}
.cal-vazio-dia{color:var(--muted);font-size:.82rem;padding:.3rem}
@media(max-width:640px){.cal-cel{min-height:64px}.cal-ev{font-size:.65rem}}

/* ===== Cards de grau (Recursos e desdobramentos) ===== */
.grau-card{border:1px solid var(--line);border-radius:10px;margin-bottom:.6rem;overflow:hidden;background:#fff}
.grau-card-head{display:flex;align-items:center;gap:.5rem;padding:.7rem .9rem;cursor:pointer;position:relative}
.grau-card-head:hover{background:#f7f9fc}
.grau-icone{font-size:1rem}
.grau-titulo{font-weight:600;color:var(--ink);font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}
.grau-chevron{color:var(--muted);font-size:.9rem;width:1rem;text-align:center}
.grau-menu{position:relative}
.grau-menu-btn{border:0;background:transparent;font-size:1.1rem;cursor:pointer;color:var(--ink-2);padding:.1rem .4rem;border-radius:6px}
.grau-menu-btn:hover{background:var(--line)}
.grau-menu-pop{display:none;position:absolute;right:0;top:1.8rem;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:30;min-width:190px;padding:.3rem}
.grau-menu-pop button,.grau-menu-pop a{display:block;width:100%;text-align:left;border:0;background:transparent;padding:.5rem .7rem;font:inherit;color:var(--ink);cursor:pointer;border-radius:7px;text-decoration:none}
.grau-menu-pop button:hover,.grau-menu-pop a:hover{background:var(--brand-soft)}
.grau-menu-pop a.perigo{color:var(--danger)}
.grau-card-body{padding:.3rem .9rem .8rem;border-top:1px solid var(--line)}
.grau-cab{display:grid;grid-template-columns:1fr 1fr;gap:.2rem .8rem;font-size:.86rem;padding:.5rem 0}
.grau-cab .muted{font-size:.82rem}
@media(max-width:640px){.grau-cab{grid-template-columns:1fr}.grau-titulo{max-width:50%}}

/* Badges por tipo de compromisso (lista da Agenda) */
.badge.tp-prazo{background:#fee2e2;color:#991b1b}
.badge.tp-tarefa{background:#fef9c3;color:#854d0e}
.badge.tp-audiencia{background:#dbeafe;color:#1e40af}

/* Título do processo (nome) sempre em caixa alta */
.proc-titulo{ text-transform:uppercase; }

/* Badge e evento (cor verde) */
.badge.tp-evento{background:#dcfce7;color:#166534}
.cal-ev.evento{background:#dcfce7;border-color:#16a34a;color:#166534}

/* Busca global na topbar */
.busca-global{position:relative;flex:1;max-width:480px}
.busca-global input{
  width:100%;padding:.5rem .9rem;border:1px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:.92rem;background:var(--bg);color:var(--ink);
}
.busca-global input:focus{outline:none;border-color:var(--brand);background:var(--surface)}
.busca-pop{
  position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.13);
  z-index:50;max-height:380px;overflow-y:auto;padding:.3rem;
}
.busca-item{
  display:flex;align-items:center;gap:.55rem;padding:.5rem .6rem;border-radius:8px;
  text-decoration:none;color:var(--ink);
}
.busca-item:hover{background:var(--brand-soft)}
.busca-tag{
  font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  background:var(--line-2);color:var(--muted);padding:.12rem .4rem;border-radius:5px;flex-shrink:0;
}
.busca-tit{font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.busca-sub{color:var(--muted);font-size:.82rem;flex-shrink:0}
.busca-vazio{padding:.7rem .8rem;color:var(--muted);font-size:.9rem}

/* ---- Alinha a linha do cabeçalho: logo (sidebar) e topbar na MESMA altura ---- */
.brand, .topbar{ height:62px; box-sizing:border-box; }
.topbar{ padding-top:0; padding-bottom:0; }
