/* ============================================
   ÁREA DO CLIENTE — BAIETA ADVOCACIA
   ============================================ */
:root {
  --acb-verde: #2D5016;
  --acb-verde-soft: #e8f0e0;
  --acb-verde-accent: #5a9930;
  --acb-cinza: #1a1a1a;
  --acb-cinza-texto: #444;
  --acb-borda: #e0e0d8;
  --acb-fundo: #f5f5f3;
  --acb-branco: #ffffff;
  --acb-fonte: 'DM Sans', system-ui, sans-serif;
  --acb-titulo: 'Playfair Display', Georgia, serif;
}

.acb-wrap { max-width: 1400px; margin: 0 auto; padding: 32px 24px 80px; font-family: var(--acb-fonte); color: var(--acb-cinza); }

/* LOGIN */
.acb-login-card { max-width: 440px; margin: 40px auto; background: var(--acb-branco); border: 1px solid var(--acb-borda); border-radius: 12px; padding: 48px 40px; }
.acb-login-logo { display: flex; flex-direction: column; gap: 2px; margin-bottom: 28px; padding-bottom: 20px; border-bottom: 1px solid var(--acb-borda); }
.acb-logo-name { font-family: var(--acb-titulo); font-size: 20px; font-weight: 600; color: var(--acb-cinza); }
.acb-logo-sub { font-size: 12px; color: #888; }
.acb-login-card h2 { font-family: var(--acb-titulo); font-size: 24px; font-weight: 500; margin: 0 0 8px; }
.acb-login-desc { font-size: 14px; color: #666; margin-bottom: 28px; }
.acb-field { margin-bottom: 16px; }
.acb-field label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 6px; }
.acb-field input { width: 100%; padding: 11px 14px; border: 1px solid var(--acb-borda); border-radius: 6px; font-family: var(--acb-fonte); font-size: 14px; outline: none; box-sizing: border-box; transition: border-color 0.2s; }
.acb-field input:focus { border-color: var(--acb-verde-accent); }
.acb-btn-primary { width: 100%; background: var(--acb-verde); color: #fff; border: none; padding: 13px; border-radius: 6px; font-size: 15px; font-weight: 500; cursor: pointer; font-family: var(--acb-fonte); margin-top: 8px; transition: background 0.2s; }
.acb-btn-primary:hover { background: #3d6b1e; }
.acb-erro { background: #fef2f2; border: 1px solid #fca5a5; color: #dc2626; padding: 12px 16px; border-radius: 6px; font-size: 14px; margin-bottom: 16px; }
.acb-login-footer { margin-top: 24px; font-size: 13px; color: #888; text-align: center; }
.acb-login-footer a { color: var(--acb-verde); }

/* DASHBOARD — CABEÇALHO */
.acb-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 32px; padding-bottom: 24px; border-bottom: 2px solid var(--acb-borda); }
.acb-eyebrow { font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--acb-verde-accent); margin: 0 0 6px; }
.acb-nome-credor { font-family: var(--acb-titulo); font-size: 28px; font-weight: 500; margin: 0 0 4px; }
.acb-cnpj { font-size: 13px; color: #888; margin: 0; }
.acb-btn-sair { background: none; border: 1px solid var(--acb-borda); color: var(--acb-cinza-texto); padding: 8px 18px; border-radius: 6px; font-size: 13px; cursor: pointer; font-family: var(--acb-fonte); transition: all 0.2s; }
.acb-btn-sair:hover { background: var(--acb-fundo); }

/* RESUMO */
.acb-resumo-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 36px; }
.acb-resumo-card { background: var(--acb-branco); border: 1px solid var(--acb-borda); border-radius: 8px; padding: 20px; display: flex; flex-direction: column; gap: 6px; }
.acb-resumo-card--destaque { border-color: var(--acb-verde); background: var(--acb-verde-soft); }
.acb-resumo-label { font-size: 12px; color: #888; font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; }
.acb-resumo-valor { font-size: 22px; font-weight: 600; color: var(--acb-cinza); }

/* TÍTULO DE SEÇÃO */
.acb-section-title { font-family: var(--acb-titulo); font-size: 20px; margin-bottom: 16px; color: var(--acb-cinza); }

/* CARD DO DEVEDOR */
.acb-devedor-card { background: var(--acb-branco); border: 1px solid var(--acb-borda); border-radius: 10px; margin-bottom: 12px; overflow: hidden; }
.acb-devedor-header { display: flex; justify-content: space-between; align-items: center; padding: 20px 24px; cursor: pointer; gap: 16px; transition: background 0.15s; }
.acb-devedor-header:hover { background: var(--acb-fundo); }
.acb-devedor-nome { display: block; font-size: 15px; font-weight: 500; color: var(--acb-cinza); margin-bottom: 4px; }
.acb-devedor-fantasia { display: block; font-size: 13px; color: #888; margin-bottom: 4px; }
.acb-devedor-meta { font-size: 13px; color: #999; display: flex; gap: 6px; flex-wrap: wrap; }
.acb-devedor-resumo { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.acb-devedor-valor { text-align: right; }
.acb-devedor-valor span { display: block; font-size: 15px; font-weight: 600; color: var(--acb-cinza); }
.acb-devedor-valor small { font-size: 12px; color: #999; }
.acb-toggle-icon { font-size: 12px; color: #999; transition: transform 0.3s; }
.acb-devedor-header.open .acb-toggle-icon { transform: rotate(180deg); }

/* CORPO EXPANSÍVEL */
.acb-devedor-body { padding: 0 24px 24px; border-top: 1px solid var(--acb-borda); }
.acb-subsection { margin-top: 20px; }
.acb-subsection-title { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--acb-verde-accent); margin-bottom: 12px; }

/* DADOS CADASTRAIS */
.acb-dados-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.acb-dado { background: var(--acb-fundo); border-radius: 6px; padding: 12px 14px; }
.acb-dado--full { grid-column: 1 / -1; }
.acb-dado-label { display: block; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: #999; margin-bottom: 4px; }
.acb-dado span:last-child { font-size: 13px; color: var(--acb-cinza-texto); }

/* TIMELINE */
.acb-timeline { display: flex; flex-direction: column; gap: 0; padding-left: 16px; border-left: 2px solid var(--acb-borda); margin-left: 6px; }
.acb-timeline-item { display: flex; gap: 14px; align-items: flex-start; padding: 12px 0; position: relative; }
.acb-tl-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; margin-left: -22px; margin-top: 3px; border: 2px solid #fff; }
.acb-tl-dot--done   { background: var(--acb-verde); box-shadow: 0 0 0 2px var(--acb-verde-soft); }
.acb-tl-dot--active { background: var(--acb-verde-accent); box-shadow: 0 0 0 3px var(--acb-verde-soft); animation: pulse-dot 2s infinite; }
.acb-tl-dot { background: #ddd; }
@keyframes pulse-dot { 0%,100%{box-shadow:0 0 0 3px rgba(90,153,48,.2)} 50%{box-shadow:0 0 0 5px rgba(90,153,48,.35)} }
.acb-tl-content strong { display: block; font-size: 14px; color: var(--acb-cinza); margin-bottom: 2px; }
.acb-tl-content span { font-size: 13px; color: #888; }

/* TABELA PRINCIPAL (GRID EXPANSÍVEL) */
.acb-wrap { max-width: 100% !important; padding: 32px 24px 80px !important; }
.acb-table-card { background: var(--acb-branco); border: 1px solid var(--acb-borda); border-radius: 10px; overflow: hidden; width: 100%; }
.acb-table-wrap { overflow-x: auto; }

.acb-grid-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.acb-grid-table thead th { background: var(--acb-fundo); padding: 11px 14px; text-align: left; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: #888; border-bottom: 2px solid var(--acb-borda); white-space: nowrap; }
.acb-grid-table tbody .acb-row-main td { padding: 13px 14px; border-bottom: 1px solid #e0e0d8; vertical-align: middle; cursor: pointer; transition: background 0.15s; }
.acb-grid-table tbody .acb-row-main:hover td { background: var(--acb-fundo); }
.acb-grid-table tbody .acb-row-main.acb-row-open td { background: var(--acb-verde-soft); border-bottom: none; }
.acb-grid-table tfoot .acb-row-total td { padding: 12px 14px; background: var(--acb-verde-soft); border-top: 2px solid var(--acb-verde); font-size: 13px; }

.acb-expand-cell { width: 36px; text-align: center; }
.acb-expand-icon { font-size: 10px; color: var(--acb-verde); transition: transform 0.2s; display: inline-block; }
.acb-subtexto { display: block; font-size: 11px; color: #aaa; font-weight: 400; margin-top: 2px; }
.acb-mono { font-family: 'Courier New', monospace; font-size: 12px; }
.text-center { text-align: center !important; }
.text-right  { text-align: right !important; }

/* LINHA DE DETALHE */
.acb-row-detail { background: #fafaf8; }
.acb-detail-cell { padding: 0 !important; border-bottom: 2px solid var(--acb-verde) !important; }
.acb-detail-inner { padding: 20px 24px 24px; }

/* ABAS */
.acb-tabs { display: flex; gap: 4px; margin-bottom: 16px; border-bottom: 1px solid var(--acb-borda); }
.acb-tab { background: none; border: none; padding: 8px 16px; font-size: 13px; font-weight: 500; color: #888; cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; font-family: var(--acb-fonte); transition: all 0.2s; }
.acb-tab:hover { color: var(--acb-cinza); }
.acb-tab.active { color: var(--acb-verde); border-bottom-color: var(--acb-verde); }

/* SUB-TABELA */
.acb-sub-table-wrap { overflow-x: auto; }
.acb-sub-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.acb-sub-table thead th { background: var(--acb-branco); padding: 8px 12px; text-align: left; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: #aaa; border-bottom: 1px solid var(--acb-borda); white-space: nowrap; }
.acb-sub-table tbody td { padding: 9px 12px; border-bottom: 1px solid #f5f5f0; vertical-align: middle; }
.acb-sub-table tbody tr:last-child td { border-bottom: none; }
.acb-sub-table tfoot td { padding: 9px 12px; background: var(--acb-verde-soft); border-top: 1px solid #c2d9a8; font-size: 12px; }
.acb-vazio-sub { color: #bbb; font-size: 13px; padding: 20px 0; text-align: center; }

/* TABELAS LEGADO */
.acb-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.acb-table th { background: var(--acb-fundo); padding: 10px 12px; text-align: left; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: #888; border-bottom: 1px solid var(--acb-borda); white-space: nowrap; }
.acb-table td { padding: 10px 12px; border-bottom: 1px solid #f0f0ec; vertical-align: middle; }
.acb-table tfoot td { background: var(--acb-verde-soft); border-top: 2px solid var(--acb-verde); border-bottom: none; }
.acb-table code { font-size: 12px; background: var(--acb-fundo); padding: 2px 6px; border-radius: 4px; }

/* BADGES */
.acb-status { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.06em; }
.acb-status--ativa    { background: #dcfce7; color: #16a34a; }
.acb-status--baixada  { background: #f0f0f0; color: #888; }
.acb-status--pendente { background: #fef9c3; color: #ca8a04; }
.acb-badge { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.05em; }
.acb-badge--pendente  { background: #fef9c3; color: #ca8a04; }
.acb-badge--notificado { background: #dbeafe; color: #2563eb; }
.acb-badge--quitado   { background: #dcfce7; color: #16a34a; }
.acb-badge--validado  { background: #dcfce7; color: #16a34a; }

/* OBSERVAÇÕES */
.acb-obs { margin-top: 16px; padding: 12px 16px; background: #fffbeb; border-left: 3px solid #fbbf24; border-radius: 0 6px 6px 0; font-size: 13px; color: var(--acb-cinza-texto); }

/* FOOTER */
.acb-footer-info { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--acb-borda); font-size: 13px; color: #888; text-align: center; }
.acb-footer-info a { color: var(--acb-verde); }
.acb-vazio { color: #999; font-size: 14px; padding: 24px 0; }

/* RESPONSIVO */
@media (max-width: 700px) {
  .acb-resumo-grid { grid-template-columns: 1fr 1fr; }
  .acb-dados-grid  { grid-template-columns: 1fr; }
  .acb-devedor-header { flex-direction: column; align-items: flex-start; }
  .acb-devedor-resumo { width: 100%; justify-content: space-between; }
  .acb-login-card { padding: 32px 24px; }
}
@media (max-width: 480px) {
  .acb-resumo-grid { grid-template-columns: 1fr; }
  .acb-header { flex-direction: column; gap: 16px; }
}

/* FORÇAR LARGURA TOTAL — override do tema */
.page-hero + section .container,
.acb-wrap,
body .acb-wrap {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
}

.acb-grid-table {
  min-width: 900px;
}

.acb-resumo-grid {
  max-width: 1400px;
}

/* Garantir scroll horizontal na tabela */
.acb-table-card {
  overflow-x: auto !important;
}

/* TOOLBAR */
.acb-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; gap: 16px; flex-wrap: wrap; }
.acb-toolbar-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.acb-busca-input { padding: 8px 14px; border: 1px solid var(--acb-borda); border-radius: 6px; font-family: var(--acb-fonte); font-size: 13px; outline: none; width: 240px; transition: border-color 0.2s; }
.acb-busca-input:focus { border-color: var(--acb-verde-accent); }
.acb-btn-exportar { background: var(--acb-verde); color: #fff; border: none; padding: 8px 18px; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: var(--acb-fonte); transition: background 0.2s; white-space: nowrap; }
.acb-btn-exportar:hover { background: var(--acb-verde-medio); }
.acb-btn-exportar:disabled { background: #aaa; cursor: not-allowed; }

/* ORDENAÇÃO */
.acb-th-sort { cursor: pointer; user-select: none; white-space: nowrap; }
.acb-th-sort:hover { color: var(--acb-verde); }
.acb-sort-icon { font-size: 10px; margin-left: 4px; color: #bbb; }
