/* CNJ Processo Tracker – Frontend Styles (HARMONIZADO Mattos & Mattos) */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;1,500;1,600&family=Inter:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root {
  --cnj-azul:     #0d1e3a;   /* navy da marca (era var(--cnj-azul)) */
  --cnj-azul-lt:  #1f3a64;   /* navy claro p/ links/hover   */
  --cnj-ouro:     #c9a84c;   /* ouro da marca (acento)      */
  --cnj-ouro-lt:  #e0bf78;
  --cnj-verde:    #2d6a2d;
  --cnj-cinza:    #f4f1ec;   /* creme da marca (era #F4F6F9)*/
  --cnj-border:   #e3ddd2;
  --cnj-texto:    #1a2744;
  --cnj-muted:    #5c6678;
  --cnj-ativo:    #eef4ec;
  --cnj-passivo:  #f6efe1;
  --cnj-font:     'Inter', system-ui, sans-serif;
  --cnj-mono:     'IBM Plex Mono', monospace;
  --cnj-display:  'Cormorant Garamond', Georgia, serif;
}

/* ---- Container ---- */
.cnj-lista-processos,
.cnj-processo-wrapper {
  font-family: var(--cnj-font);
  color: var(--cnj-texto);
  max-width: 900px;
}

/* ---- Item da lista ---- */
.cnj-item-lista {
  background: #fff;
  border: 1px solid var(--cnj-border);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(13,30,58,.06);
  transition: box-shadow .2s;
}
.cnj-item-lista:hover { box-shadow: 0 4px 14px rgba(13,30,58,.12); }

.cnj-item-cabecalho {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  flex-wrap: wrap;
}

.cnj-item-numero {
  font-family: var(--cnj-mono);
  font-size: .95rem;
  font-weight: 500;
  color: var(--cnj-azul);
  flex: 1 1 auto;
}

.cnj-item-tribunal {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  background: var(--cnj-azul);
  color: var(--cnj-ouro-lt);
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}

.cnj-item-sync {
  font-size: .75rem;
  color: var(--cnj-muted);
  white-space: nowrap;
}

.cnj-btn-expandir,
.cnj-btn-sync-front {
  font-family: var(--cnj-font);
  font-size: .82rem;
  border: 1px solid var(--cnj-border);
  background: #fff;
  color: var(--cnj-azul-lt);
  padding: 5px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.cnj-btn-expandir:hover,
.cnj-btn-sync-front:hover {
  background: var(--cnj-azul);
  color: #fff;
  border-color: var(--cnj-azul);
}
.cnj-btn-sync-front {
  display: block;
  margin: 12px 0 4px;
  font-size: .8rem;
}

.cnj-item-detalhes {
  padding: 0 18px 18px;
  border-top: 1px solid var(--cnj-border);
  background: var(--cnj-cinza);
  animation: cnj-fade-in .2s ease;
}

@keyframes cnj-fade-in {
  from { opacity:0; transform: translateY(-4px); }
  to   { opacity:1; transform: translateY(0); }
}

/* ---- Card do processo ---- */
.cnj-processo-card {
  font-family: var(--cnj-font);
  padding-top: 14px;
}

.cnj-processo-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.cnj-numero {
  font-family: var(--cnj-mono);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--cnj-azul);
}

.cnj-badge {
  font-size: .72rem;
  font-weight: 600;
  background: var(--cnj-verde);
  color: #fff;
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: .04em;
}

/* ---- Meta grid ---- */
.cnj-processo-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.cnj-meta-item {
  background: #fff;
  border: 1px solid var(--cnj-border);
  border-radius: 8px;
  padding: 10px 14px;
}
.cnj-meta-item.cnj-meta-full { grid-column: 1 / -1; }
.cnj-meta-item label {
  display: block;
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--cnj-muted);
  margin-bottom: 4px;
}
.cnj-meta-item span {
  font-size: .88rem;
  color: var(--cnj-texto);
}

/* ---- Seção ---- */
.cnj-secao { margin-top: 18px; }
.cnj-secao h4 {
  font-family: var(--cnj-display);
  font-size: .85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cnj-azul);
  margin: 0 0 10px;
  border-bottom: 2px solid var(--cnj-ouro);
  padding-bottom: 6px;
}

/* ---- Partes ---- */
.cnj-partes { display: flex; flex-direction: column; gap: 7px; }
.cnj-parte {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1px solid var(--cnj-border);
  border-radius: 7px;
  padding: 8px 13px;
  font-size: .87rem;
}
.cnj-polo {
  font-size: .7rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .05em;
  min-width: 44px;
  text-align: center;
}
.cnj-polo-ativo  { background: var(--cnj-ativo);   color: var(--cnj-azul-lt); }
.cnj-polo-passivo{ background: var(--cnj-passivo);  color: #B25B00; }
.cnj-polo-terce  { background: #F0FFF4; color: var(--cnj-verde); }
.cnj-parte-nome  { flex:1; font-weight: 500; }
.cnj-parte-tipo  { font-size: .75rem; color: var(--cnj-muted); }

/* ---- Timeline ---- */
.cnj-timeline {
  position: relative;
  padding-left: 28px;
}
.cnj-timeline::before {
  content: '';
  position: absolute;
  left: 7px; top: 0; bottom: 0;
  width: 2px;
  background: var(--cnj-border);
}

.cnj-mov-item {
  position: relative;
  margin-bottom: 14px;
  padding-bottom: 4px;
}
.cnj-mov-item.cnj-mov-push .cnj-mov-dot {
  background: #f59e0b;
  box-shadow: 0 0 0 2px var(--cnj-border);
}
.cnj-mov-item.cnj-mov-push .cnj-mov-content {
  border-left: 3px solid #f59e0b;
  background: #fffbeb;
}
.cnj-push-badge {
  font-size: .75rem;
  margin-left: 4px;
  vertical-align: middle;
  opacity: .8;
}
.cnj-mov-dot {
  position: absolute;
  left: -24px;
  top: 5px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--cnj-azul-lt);
  border: 2px solid #fff;
  box-shadow: 0 0 0 2px var(--cnj-border);
}
.cnj-mov-content {
  background: #fff;
  border: 1px solid var(--cnj-border);
  border-radius: 8px;
  padding: 9px 13px;
}
.cnj-mov-data {
  font-family: var(--cnj-mono);
  font-size: .75rem;
  color: var(--cnj-muted);
  margin-bottom: 4px;
}
.cnj-mov-nome {
  font-size: .88rem;
  font-weight: 600;
  color: var(--cnj-texto);
}
.cnj-mov-compl {
  font-size: .82rem;
  color: var(--cnj-muted);
  margin-top: 3px;
}
.cnj-mov-mais {
  font-size: .8rem;
  color: var(--cnj-muted);
  font-style: italic;
  padding-left: 4px;
}

.cnj-sem-processos,
.cnj-erro { color: var(--cnj-muted); font-style: italic; }

/* ---- Loading ---- */
.cnj-spin-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .85rem;
  color: var(--cnj-muted);
  padding: 8px 0;
}

/* ── Modal de edição de vínculos e partes ───────────────────────── */
.cnj-vedit-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.55);
    z-index: 99999; display: flex; align-items: center; justify-content: center;
}
.cnj-vedit-box {
    background: #fff; border-radius: 12px; padding: 24px;
    width: 90%; max-width: 680px; max-height: 80vh;
    display: flex; flex-direction: column; gap: 0; box-shadow: 0 8px 40px rgba(0,0,0,.18);
}
.cnj-vedit-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 12px; font-size: .95rem;
}
.cnj-vedit-fechar {
    background: none; border: none; font-size: 1.1rem;
    cursor: pointer; color: var(--cnj-muted); padding: 0 4px;
}
.cnj-vedit-lista {
    overflow-y: auto; flex: 1; max-height: 50vh;
    border: 1px solid var(--cnj-border); border-radius: 7px; padding: 8px;
}
.cnj-vedit-row {
    display: flex; align-items: center; gap: 8px; padding: 6px 4px;
    font-size: .82rem; cursor: pointer; border-radius: 5px;
    border-bottom: 1px solid var(--cnj-border);
}
.cnj-vedit-row:hover { background: var(--cnj-cinza); }
.cnj-vedit-num { font-family: monospace; font-weight: 700; color: var(--cnj-azul); }
.cnj-vedit-trib { color: var(--cnj-muted); font-size: .76rem; }
.cnj-vedit-cls { color: var(--cnj-muted); font-size: .74rem; flex: 1; text-align: right; }
.cnj-vedit-footer {
    display: flex; gap: 8px; margin-top: 14px; padding-top: 12px;
    border-top: 1px solid var(--cnj-border);
}
/* Botão editar vínculos */
.cnj-vin-btn-editar {
    margin-left: 8px; font-size: .7rem; padding: 2px 8px;
    border: 1px solid var(--cnj-border); border-radius: 4px;
    background: var(--cnj-cinza); color: var(--cnj-texto); cursor: pointer;
    vertical-align: middle;
}
.cnj-vin-btn-editar:hover { background: var(--cnj-border); }

/* ── Modal edição de partes (cnj-partes-overlay) ─────────────────── */
.cnj-parte-bloco-edit { transition: box-shadow .15s; }
.cnj-parte-bloco-edit:focus-within {
    box-shadow: 0 0 0 2px rgba(13,30,58,.15);
}
.cnj-parte-bloco-rm:hover { background: #FEF2F2 !important; }
.cnj-pe-add-adv:hover { background: var(--cnj-cinza) !important; }
.cnj-btn-salvar-partes:hover { background: var(--cnj-azul-lt) !important; }
.cnj-btn-salvar-partes:disabled { opacity: .65; cursor: not-allowed !important; }

/* ====================================================================
   Módulo: Notas Internas (cnj-pane-notas)
   ==================================================================== */

/* --- Wrapper geral --- */
.cnj-notas-wrap {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    height: 100%;
    box-sizing: border-box;
}

/* --- Formulário de nova nota --- */
.cnj-notas-form {
    background: var(--cnj-cinza);
    border: 1px solid var(--cnj-border);
    border-radius: 10px;
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.cnj-notas-form-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.cnj-nota-tipo {
    flex: 1;
    padding: 6px 8px;
    border: 1px solid var(--cnj-border);
    border-radius: 6px;
    font-size: .83rem;
    color: var(--cnj-texto);
    background: #fff;
}
.cnj-nota-arquivo-label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 1px solid var(--cnj-border);
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    font-size: 1rem;
    flex-shrink: 0;
    transition: background .15s;
}
.cnj-nota-arquivo-label:hover { background: var(--cnj-passivo); border-color: var(--cnj-ouro); }
.cnj-nota-texto {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--cnj-border);
    border-radius: 6px;
    font-size: .84rem;
    font-family: inherit;
    resize: vertical;
    color: var(--cnj-texto);
    box-sizing: border-box;
    line-height: 1.5;
}
.cnj-nota-texto:focus { outline: none; border-color: var(--cnj-azul); box-shadow: 0 0 0 2px rgba(13,30,58,.1); }
.cnj-nota-arquivo-preview {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 8px;
    background: var(--cnj-passivo);
    border: 1px solid var(--cnj-ouro-lt);
    border-radius: 5px;
    font-size: .78rem;
    color: var(--cnj-azul);
}
.cnj-nota-preview-nome { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cnj-nota-preview-rm {
    background: none; border: none; cursor: pointer;
    color: var(--cnj-muted); font-size: .8rem; padding: 0 2px; flex-shrink: 0;
}
.cnj-notas-form-footer {
    display: flex;
    align-items: center;
    gap: 10px;
}
.cnj-nota-salvar {
    padding: 7px 18px;
    background: var(--cnj-ouro);
    color: var(--cnj-azul);
    border: none;
    border-radius: 6px;
    font-size: .83rem;
    font-weight: 700;
    letter-spacing: .01em;
    cursor: pointer;
    transition: background .15s;
}
.cnj-nota-salvar:hover  { background: var(--cnj-ouro-lt); }
.cnj-nota-salvar:disabled { opacity: .6; cursor: not-allowed; }
.cnj-notas-status { font-size: .76rem; }

/* --- Lista de notas --- */
.cnj-notas-lista {
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow-y: auto;
    max-height: 42vh;
    padding-right: 2px;
}
.cnj-notas-vazio {
    text-align: center;
    color: var(--cnj-muted);
    font-size: .83rem;
    padding: 24px 0;
    font-style: italic;
}

/* --- Item de nota --- */
.cnj-nota-item {
    background: #fff;
    border: 1px solid var(--cnj-border);
    border-radius: 8px;
    padding: 12px 14px;
    transition: box-shadow .15s;
}
.cnj-nota-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.cnj-nota-item-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}
.cnj-nota-tipo-badge {
    font-size: .7rem;
    font-weight: 700;
    color: #fff;
    padding: 2px 8px;
    border-radius: 20px;
    letter-spacing: .02em;
    white-space: nowrap;
}
.cnj-nota-autor {
    font-size: .75rem;
    font-weight: 600;
    color: var(--cnj-texto);
}
.cnj-nota-data {
    font-size: .72rem;
    color: var(--cnj-muted);
    margin-left: auto;
}
.cnj-nota-excluir {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--cnj-border);
    font-size: .75rem;
    padding: 0 2px;
    transition: color .15s;
    opacity: 0;
    flex-shrink: 0;
}
.cnj-nota-item:hover .cnj-nota-excluir { opacity: 1; }
.cnj-nota-excluir:hover { color: #DC2626 !important; }
.cnj-nota-corpo {
    font-size: .84rem;
    color: var(--cnj-texto);
    line-height: 1.55;
    word-break: break-word;
}
.cnj-nota-anexo { margin-top: 8px; }
.cnj-nota-anexo-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .76rem;
    color: var(--cnj-azul);
    text-decoration: none;
    padding: 3px 8px;
    background: var(--cnj-passivo);
    border: 1px solid var(--cnj-ouro-lt);
    border-radius: 4px;
    transition: background .15s;
}
.cnj-nota-anexo-link:hover { background: #efe6d4; }
