/* ============================================================
   LifeOS · Empresas (PJ) v2.3.0 — estilos específicos
   reusa style.css (home) + financeiro.css
   ============================================================ */

/* TOGGLE Patrick / Pamella */
.pj-toggle{
  display:inline-flex;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:100px;
  padding:3px;
  gap:2px;
}
.pj-toggle-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  border:none;background:transparent;
  font-family:var(--ff,system-ui);font-size:12px;font-weight:600;
  color:var(--tx2);
  border-radius:100px;
  cursor:pointer;
  transition:all var(--d2) ease;
  letter-spacing:-0.005em;
}
.pj-toggle-btn:hover{color:var(--tx)}
.pj-toggle-dot{
  display:inline-block;
  width:7px;height:7px;border-radius:50%;
  background:currentColor;opacity:0.45;
}
.pj-toggle-btn.pat.active{background:color-mix(in srgb, var(--pat) 18%, transparent);color:var(--pat)}
.pj-toggle-btn.pat.active .pj-toggle-dot{background:var(--pat);opacity:1;box-shadow:0 0 8px color-mix(in srgb, var(--pat) 60%, transparent)}
.pj-toggle-btn.pam.active{background:color-mix(in srgb, var(--pam-deep) 18%, transparent);color:#f472b6}
.pj-toggle-btn.pam.active .pj-toggle-dot{background:#f472b6;opacity:1;box-shadow:0 0 8px color-mix(in srgb, var(--pam) 60%, transparent)}
.pj-toggle-btn.geral.active{background:color-mix(in srgb, var(--good) 16%, transparent);color:var(--good)}
.pj-toggle-btn.geral.active .pj-toggle-dot{background:var(--good);opacity:1;box-shadow:0 0 8px color-mix(in srgb, var(--good) 55%, transparent)}

/* ===== VISÃO GERAL CONSOLIDADA (TSK-054) ===== */
#pjCompanyView,#pjGeralView{display:flex;flex-direction:column;gap:14px}
.pj-vg-summary .pj-vg-totrow{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.pj-vg-tot{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel)}
.pj-vg-tot span{font-size:12px;color:var(--tx3)}
.pj-vg-tot b{font-family:var(--ff-mono);font-size:18px;color:var(--tx)}
.pj-vg-tot.pos b{color:var(--good)}
.pj-vg-tot.neg b{color:color-mix(in srgb, var(--crit) 80%, var(--tx))}
.pj-vg-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.pj-vg-card .pj-vg-card-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.pj-vg-card .pj-vg-card-head b{font-size:15px;color:var(--tx)}
.pj-vg-card.pat .pj-toggle-dot{background:var(--pat);opacity:1}
.pj-vg-card.pam .pj-toggle-dot{background:#f472b6;opacity:1}
.pj-vg-regime{margin-left:auto;font-family:var(--ff-mono);font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--tx3);border:1px solid var(--line);border-radius:var(--r-xs);padding:1px 7px}
.pj-vg-fat{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--line-2)}
.pj-vg-fat span{font-size:13px;color:var(--tx2)}
.pj-vg-fat b{font-family:var(--ff-mono);font-size:15px;color:var(--tx)}
.pj-vg-grp{margin-top:10px}
.pj-vg-grp-head{display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:var(--tx2);padding:5px 0;border-bottom:1px dashed var(--line)}
.pj-vg-grp-head b{font-family:var(--ff-mono);color:var(--tx)}
.pj-vg-line{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--tx3);padding:3px 0 3px 10px}
.pj-vg-line span:last-child{font-family:var(--ff-mono);color:var(--tx2);white-space:nowrap}
.pj-vg-grp-empty{font-size:11.5px;color:var(--tx4);padding:3px 0 3px 10px}
.pj-vg-final{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:2px solid var(--line-2)}
.pj-vg-final span{font-size:13px;font-weight:600;color:var(--tx)}
.pj-vg-final b{font-family:var(--ff-mono);font-size:18px}
.pj-vg-final.pos b{color:var(--good)}
.pj-vg-final.neg b{color:color-mix(in srgb, var(--crit) 80%, var(--tx))}
.pj-vg-final-note{font-size:10.5px;color:var(--tx4);margin-top:4px}
/* item 1: label, campo e botão na mesma linha/altura; botão com destaque */
.pj-vg-teto{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.pj-vg-teto .v-form-label{margin:0;align-self:center}
.pj-vg-teto-inp{width:160px;height:38px;font-family:var(--ff-mono)}
.pj-vg-teto-btn{height:38px}
/* switch "projeção" no header da distribuição */
.pj-vg-simsw{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--tx2);cursor:pointer;margin-left:auto}
.pj-vg-dist .sh{display:flex;align-items:center;gap:12px}
.pj-vg-dist .sh .sc{margin-left:0}
.pj-vg-steps{display:flex;flex-direction:column;gap:10px}
.pj-vg-tr{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel)}
.pj-vg-tr.done{background:color-mix(in srgb, var(--good) 7%, var(--panel));border-color:color-mix(in srgb, var(--good) 30%, var(--line))}
.pj-vg-tr-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pj-vg-tr-tx b{font-size:13px;color:var(--tx)}
.pj-vg-tr-tx span{font-size:11.5px;color:var(--tx3)}
.pj-vg-tr-amt{display:flex;flex-direction:column;align-items:flex-end;min-width:110px}
.pj-vg-tr-amt b{font-family:var(--ff-mono);font-size:15px;color:var(--tx)}
.pj-vg-tr-amt small{font-size:10px;color:var(--tx3)}
.pj-vg-tr-amt small.sim{white-space:normal;text-align:right;max-width:150px;color:var(--good);line-height:1.3;margin-top:2px}
.pj-vg-tr-btn{white-space:nowrap}
/* TSK-059: tooltip CUSTOM (não o title nativo) no botão desabilitado, aparece em cima */
.pj-vg-tr-btnwrap{position:relative;display:inline-flex}
.pj-vg-tr-btn:disabled{pointer-events:none;opacity:.5}
.pj-vg-tr-btnwrap[data-tip]::after{
  content:attr(data-tip);
  position:absolute; bottom:calc(100% + 10px); right:0;
  width:max-content; max-width:260px; white-space:normal; text-align:left;
  padding:9px 11px; border-radius:10px;
  background:var(--panel-3, #1f1f22); color:var(--tx);
  border:1px solid var(--line-2);
  box-shadow:0 10px 30px rgba(0,0,0,.5);
  font-size:11.5px; line-height:1.45; font-weight:500;
  opacity:0; transform:translateY(4px); pointer-events:none; z-index:60;
  transition:opacity var(--d1) var(--ease), transform var(--d1) var(--ease);
}
.pj-vg-tr-btnwrap[data-tip]::before{
  content:''; position:absolute; bottom:calc(100% + 4px); right:16px;
  border:6px solid transparent; border-top-color:var(--line-2);
  opacity:0; transition:opacity var(--d1) var(--ease); z-index:60;
}
.pj-vg-tr-btnwrap[data-tip]:hover::after{ opacity:1; transform:translateY(0); }
.pj-vg-tr-btnwrap[data-tip]:hover::before{ opacity:1; }
/* itens 2+3: dropdown custom de conta (campo flush, sem caixa; opções com cor+banco) */
.pj-acc-dd{position:relative;width:200px}
.pj-acc-dd.open{z-index:1000}
.pj-acc-dd-trigger{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-2);padding:7px 4px;cursor:pointer;color:var(--tx);font:inherit;font-size:13px;border-radius:0;transition:border-color var(--d1)}
.pj-acc-dd-trigger:hover{border-bottom-color:var(--tx3)}
.pj-acc-dd.open .pj-acc-dd-trigger{border-bottom-color:var(--brand)}
.pj-acc-dd-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.pj-acc-dd-lbl{flex:1;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pj-acc-dd-meta{font-size:10.5px;color:var(--tx3);white-space:nowrap;flex-shrink:0}
.pj-acc-dd-chev{width:14px;height:14px;flex-shrink:0;color:var(--tx3);transition:transform var(--d1)}
.pj-acc-dd.open .pj-acc-dd-chev{transform:rotate(180deg)}
/* painel no body (portal): position:fixed via JS, z-index altíssimo pra não cair atrás de nada */
.pj-acc-dd-panel.floating{position:fixed;z-index:99999;display:flex;flex-direction:column;max-height:280px;overflow-y:auto;background:var(--panel-2,#1c1c1e);border:1px solid var(--line-2);border-radius:var(--r-md);box-shadow:0 12px 34px rgba(0,0,0,.55)}
.pj-acc-dd-opt{display:flex;align-items:center;gap:8px;padding:10px 12px;background:transparent;border:none;cursor:pointer;color:var(--tx);font:inherit;font-size:13px;text-align:left;transition:background var(--d1)}
.pj-acc-dd-opt:hover{background:color-mix(in srgb,var(--brand) 14%,transparent)}
.pj-acc-dd-opt .pj-acc-dd-lbl{flex:1}
.pj-acc-dd.empty{font-size:12px;color:var(--tx3);padding:7px 4px}
.pj-vg-dist-tot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:2px solid var(--line-2)}
.pj-vg-dist-tot b{font-family:var(--ff-mono);font-size:16px;color:var(--good)}
.pj-vg-dist-tot small{color:var(--tx3);font-size:12px}
.pj-vg-sobra{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding:10px 12px;border-radius:var(--r-md);background:color-mix(in srgb,var(--good) 8%,var(--panel));border:1px solid color-mix(in srgb,var(--good) 25%,var(--line))}
.pj-vg-sobra span{font-size:12px;color:var(--tx2)}
.pj-vg-sobra b{font-family:var(--ff-mono);font-size:13px;color:var(--good)}
.pj-vg-dist-note{font-size:11px;color:var(--tx4);margin-top:8px;line-height:1.5}
.pj-vg-dist-note b{color:var(--tx2);font-family:var(--ff-mono)}
@media(max-width:820px){.pj-vg-cards{grid-template-columns:1fr}.pj-vg-summary .pj-vg-totrow{grid-template-columns:1fr}.pj-vg-tr{flex-wrap:wrap}.pj-acc-dd{width:100%;flex:1}}

/* HERO PJ */
.pj-hero{
  display:flex;
  flex-direction:column;
  gap:14px;
}
/* TSK-029: linha 1 = 3 cards (Faturamento, Custo c/ imposto, Custos totais).
   Antes era repeat(5) com só 3 cards → sobravam 2 colunas vazias à direita. */
.pj-hero-row1{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  align-items:stretch;
}
/* v2.31.17: linha 2 = Lucro 50% + col empilhada 50% (Conta + Cartão) */
.pj-hero-row2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:stretch;
}
.pj-hero-row2 .pj-hero-stack{
  display:flex;flex-direction:column;gap:14px;
}
/* v3.0.5: NÃO usar flex:1 nos cards do stack — estavam dividindo altura
   igualmente e cortando conteúdo do CONTAS PJ (3 linhas) pra "caber" no
   mesmo espaço do CARTÃO (1 linha). Agora cada card ocupa altura natural. */
.pj-hero-row2 .pj-hero-stack > .pj-hero-card{flex:0 0 auto}
.pj-hero-row2 .pj-hero-stack{justify-content:flex-start}
/* row2 não usa stretch — col esquerda (lucro) pode ter altura própria sem
   forçar a coluna direita a esticar e cortar conteúdo */
.pj-hero-row2{align-items:flex-start}
.pj-hero-card{
  position:relative;
  overflow:visible; /* v3.0.3: valores responsivos não cortam */
  min-height:140px;
  display:flex;flex-direction:column;
}
.pj-hero-card .fin-hero-foot,
/* v2.31.17: chips dentro do breakdown ganham gap apropriado quando wrappam linha */
.pj-hero-card .pj-hero-breakdown{
  margin-top:8px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:flex-start;
}
.pj-hero-card.pat::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit; /* herda o arredondamento do card (senão o gradiente fura o canto) */
  background:linear-gradient(135deg, color-mix(in srgb, var(--pat) 8%, transparent), transparent 60%);
  pointer-events:none;
}
.pj-hero-card.pam::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg, color-mix(in srgb, var(--pam-deep) 8%, transparent), transparent 60%);
  pointer-events:none;
}
/* v2.31.17: classes hero-main/hero-half/hero-full/hero-tall removidas — layout agora via .pj-hero-row1 e .pj-hero-row2 */

/* v2.31.17 → v2.31.17: card de contas/cartão PJ */
.pj-acc-list{
  display:flex;flex-direction:column;gap:6px;
  margin-top:10px;
}
.pj-acc-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
  cursor:pointer;
  transition:background var(--d1), border-color var(--d1);
}
.pj-acc-row:hover{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,255,255,0.12);
}
.pj-acc-row.card-row{
  cursor:default;
  background:rgba(255,255,255,0.015);
  border-style:dashed;
}
.pj-acc-row.card-row:hover{background:rgba(255,255,255,0.02);border-color:var(--line)}
.pj-acc-row.total-row{
  cursor:default;
  margin-top:4px;
  border-top:1px solid var(--line-2);
  border-radius:0;
  background:transparent;
  padding-top:10px;
}
.pj-acc-row.total-row:hover{background:transparent;border-color:var(--line-2) transparent transparent transparent}
.pj-acc-row.total-row .pj-acc-name{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--tx2)}
.pj-acc-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.pj-acc-name{font-size:12px;font-weight:600;color:var(--tx)}
.pj-acc-sub{font-size:10px;color:var(--tx2);font-family:var(--ff-mono,monospace)}
.pj-acc-val{font-size:14px;font-weight:700;font-family:var(--ff-mono,monospace);white-space:nowrap}
.pj-acc-val.pos{color:var(--good)}
.pj-acc-val.neg{color:var(--crit)}

/* v2.31.17: card cartão de crédito clicável (full-width) */
.pj-card-block{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:14px;
  align-items:center;
  padding:14px 16px;
  margin-top:10px;
  background:rgba(255,255,255,0.025);
  border:1px solid var(--line);
  border-radius:12px;
  cursor:pointer;
  transition:background var(--d1), border-color var(--d1), transform var(--d1);
}
.pj-card-block:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.15)}
/* v3.14.6: scale de :active removido */
.pj-card-info{display:flex;flex-direction:column;gap:3px;min-width:0}
.pj-card-name{font-size:14px;font-weight:600;color:var(--tx)}
.pj-card-sub{font-size:11px;color:var(--tx2);font-family:var(--ff-mono,monospace)}
.pj-card-val{font-size:18px;font-weight:700;font-family:var(--ff-mono,monospace);white-space:nowrap}
.pj-card-val.neg{color:var(--crit)}
.pj-card-arrow{width:16px;height:16px;color:var(--tx2)}

/* v2.31.17: badge método pagamento na lista de despesas */
/* forma do DS (.v-bdg v-bdg--mono); cor por método (credito/debito) abaixo */
.pj-pay-badge{margin-left:6px}
.pj-pay-badge.credito{background:color-mix(in srgb, var(--brand-2) 10%, transparent);border-color:color-mix(in srgb, var(--brand-2) 30%, transparent);color:color-mix(in srgb, var(--brand-2) 75%, var(--tx))}
.pj-pay-badge.debito{background:color-mix(in srgb, var(--good) 8%, transparent);border-color:color-mix(in srgb, var(--good) 30%, transparent);color:color-mix(in srgb, var(--good) 75%, var(--tx))}

/* v2.31.17: modal pagar fatura */
.pj-card-summary{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--line);
  border-radius:10px;
  padding:12px 14px;
  margin-bottom:14px;
  display:flex;flex-direction:column;gap:6px;
}
.pj-card-summary-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.pj-card-summary-row span{color:var(--tx2)}
.pj-card-summary-row b{font-family:var(--ff-mono,monospace);font-weight:700}
.pj-card-summary-row b.pos{color:var(--good)}
.pj-card-summary-row b.neg{color:var(--crit)}
.pj-card-summary-row.total{
  margin-top:4px;
  padding-top:8px;
  border-top:1px solid var(--line);
  font-size:14px;
}
.pj-card-summary-row.total span{color:var(--tx);font-weight:600}

.pj-warn-block{
  background:color-mix(in srgb, var(--crit) 8%, transparent);
  border:1px solid color-mix(in srgb, var(--crit) 30%, transparent);
  color:color-mix(in srgb, var(--crit) 70%, var(--tx));
  padding:10px 12px;
  border-radius:8px;
  font-size:12px;
  margin-bottom:14px;
}

.pj-card-section-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin:14px 0 8px;
}
.pj-card-section-head .pj-card-section-title{margin:0}
.pj-card-section-title{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--tx2);
  margin:14px 0 8px;
  font-weight:600;
}
.pj-card-launches{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}
.pj-card-launch-row{
  display:grid;
  grid-template-columns:60px 1fr auto;
  gap:10px;
  align-items:center;
  padding:8px 10px;
  background:rgba(255,255,255,0.02);
  border-radius:8px;
}
.pj-card-launch-row.paid-row{
  background:color-mix(in srgb, var(--good) 5%, transparent);
  border:1px solid color-mix(in srgb, var(--good) 15%, transparent);
}
.pj-card-launch-info{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}
.pj-card-launch-info b{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pj-card-launch-info small{font-size:10px;color:var(--tx2);font-family:var(--ff-mono,monospace)}
.pj-card-launch-val{font-family:var(--ff-mono,monospace);font-size:12px;font-weight:600;white-space:nowrap}

.pj-card-paid-list{margin-top:14px}
.pj-card-paid-title{
  font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--tx2);margin-bottom:6px;font-weight:600;
}

.v-btn[disabled], .v-btn[disabled]{
  opacity:.4;cursor:not-allowed;pointer-events:none;
}
/* v3.0.3 cleanup: linhas órfãs (display:flex;gap:6px;...) removidas — sem selector */

.pj-ceiling{
  margin-top:14px;
  padding-top:11px;
  border-top:1px dashed var(--line);
}
.pj-ceiling-head{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--ff-mono,monospace);font-size:10px;
  color:var(--tx2);
  margin-bottom:5px;
}
.pj-ceiling-head b{color:var(--tx);font-weight:700;font-size:11px}
.pj-ceiling-head b.warn{color:var(--warn)}
.pj-ceiling-head b.danger{color:var(--crit)}
.pj-ceiling-sub{
  font-family:var(--ff-mono,monospace);font-size:10px;
  color:var(--tx2);
  margin-top:5px;
}
/* v3.10.0 (P5.4): projeção do teto baseada em ritmo do ano */
.pj-ceiling-proj{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--ff-mono,monospace);font-size:10px;
  color:var(--tx2);
  margin-top:8px;
  padding-top:7px;
  border-top:1px dotted rgba(255,255,255,0.05);
}
.pj-ceiling-proj-lbl{flex:1;letter-spacing:0.02em;text-transform:lowercase}
.pj-ceiling-proj-val{font-weight:600;color:var(--tx);font-size:11px;letter-spacing:-0.01em}
.pj-ceiling-proj-val.warn{color:var(--warn)}
.pj-ceiling-proj-val.danger{color:var(--crit)}
.pj-ceiling-warn{
  margin-top:7px;
  padding:6px 9px;
  background:color-mix(in srgb, var(--crit) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--crit) 25%, transparent);
  border-radius:6px;
  font-family:var(--ff-mono,monospace);font-size:10px;
  color:var(--crit);
  font-weight:600;
  letter-spacing:0.01em;
}

/* LAYOUT 2 colunas (pendências + recebidos) */
.pj-row-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  /* TSK-029: ao topo — card vazio (ex: "Recebido no mês" sem itens) não estica
     mais pra 240px criando um vazio do lado do que tem conteúdo. */
  align-items:start;
}
.pj-row-2 > .sec{display:flex;flex-direction:column}
.pj-row-2 > .sec > .pj-pending-list,
.pj-row-2 > .sec > .pj-received-list{flex:1;min-height:0;overflow-y:auto;max-height:380px}

.pj-pending-list, .pj-received-list{
  display:flex;flex-direction:column;gap:6px;
}
/* TSK-029: estado vazio compacto — não inflar seções sem itens */
.pj-pending-list .v-fin-empty,
.pj-received-list .v-fin-empty,
.pj-expenses-list .v-fin-empty,
.pj-clients-list .v-fin-empty{
  padding:18px 12px;font-size:12.5px;color:var(--tx3);
}

/* INVOICE ROW (pendência ou recebimento) */
.pj-invoice-row{
  display:grid;
  grid-template-columns:1fr auto auto auto auto;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
  transition:all var(--d1) ease;
  position:relative;
  overflow:visible;
}
.pj-das-total{
  margin-top:6px;padding-top:8px !important;
  border-top:2px solid var(--line) !important;
}
.pj-das-total .pj-das-val{font-size:15px}

/* Total final em destaque (v2.31.17) */
.pj-das-final{
  margin-top:10px !important;
  padding:12px 14px !important;
  background:color-mix(in srgb, var(--info) 8%, transparent);
  border:1px solid color-mix(in srgb, var(--info) 25%, transparent) !important;
  border-radius:8px;
}
.pj-das-final .pj-das-lbl{
  font-size:11px;
  font-weight:700;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:var(--tx2);
}
.pj-das-final-val{
  font-family:var(--ff-mono);
  font-size:20px !important;
  font-weight:700;
  color:var(--brand);
  letter-spacing:-0.01em;
  font-feature-settings:"tnum";
}

.pj-year-stat{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:11px;padding:9px 11px;
  background:rgba(255,255,255,0.03);
  border-radius:8px;
  border:1px dashed var(--line);
}
.pj-year-lbl{
  font-family:var(--ff,system-ui);font-size:11px;
  color:var(--tx2);font-weight:500;
  letter-spacing:-0.005em;
}
.pj-year-val{
  font-family:var(--ff-mono,monospace);font-size:13px;
  color:var(--tx);font-weight:700;
}

.pj-inss-preset{
  font-size:10.5px !important;padding:8px 10px !important;
  width:100%;
  white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}

/* contenção dos botões edit/delete que vinham vazando */
.pj-invoice-row,
.pj-client-row,
.pj-expense-row{
  position:relative;
  overflow:visible;
}
/* Override forte do style.css global (.edit-del{position:absolute;right:7px}) */
.pj-invoice-row .edit-del,
.pj-invoice-row .edit-del2,
.pj-client-row .edit-del,
.pj-client-row .edit-del2,
.pj-expense-row .edit-del,
.pj-expense-row .edit-del2,
.pj-fixed-list .edit-del,
.pj-fixed-list .edit-del2{
  position:static !important;
  top:auto !important;right:auto !important;left:auto !important;bottom:auto !important;
  transform:none !important;
  margin:0 !important;
  inset:auto !important;
  flex-shrink:0;
  align-self:center;
  justify-self:center;
  /* v3.0.3: sincroniza com global (30x30) */
  width:30px !important;height:30px !important;
  display:inline-flex !important;
  align-items:center;justify-content:center;
  animation:none !important;
}
.pj-invoice-row .edit-del2 svg,
.pj-client-row .edit-del2 svg,
.pj-expense-row .edit-del2 svg,
.pj-fixed-list .edit-del2 svg{width:14px !important;height:14px !important}
.pj-invoice-row .edit-del,
.pj-client-row .edit-del,
.pj-expense-row .edit-del,
.pj-fixed-list .edit-del{font-size:16px !important;font-weight:600;line-height:1}
.pj-invoice-row.pending{border-left:3px solid var(--warn)}
.pj-invoice-row.received{border-left:3px solid var(--good);background:color-mix(in srgb, var(--good) 4%, transparent)}
.pj-invoice-row:hover{background:var(--panel)}
/* v2.31.17: pendência atrasada — destaque vermelho */
.pj-invoice-row.pending.late{
  border-left:3px solid var(--crit);
  background:linear-gradient(90deg, color-mix(in srgb, var(--crit) 10%, transparent) 0%, color-mix(in srgb, var(--crit) 3%, transparent) 60%, transparent 100%);
}
.pj-invoice-row.pending.late .pj-invoice-meta{color:color-mix(in srgb, var(--crit) 70%, var(--tx))}

.pj-invoice-info{min-width:0}
.pj-invoice-title{
  font-family:var(--ff,system-ui);font-size:13px;font-weight:600;
  color:var(--tx);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  letter-spacing:-0.01em;
}
.pj-invoice-meta{
  font-family:var(--ff-mono,monospace);font-size:10.5px;
  color:var(--tx2);
  margin-top:2px;
}
.pj-invoice-val{
  font-family:var(--ff-mono,monospace);font-weight:700;font-size:13px;
  color:var(--tx);
}
.pj-invoice-val.pos{color:color-mix(in srgb, var(--good) 75%, var(--tx))}

/* v4.0.12 — migrados pro DS:
   .pj-confirm-btn        → .v-btn v-btn-sec v-btn--good v-btn--sm
   .pj-confirm-btn.revert → .v-btn v-btn-gho v-btn--danger v-btn--sm
   .pj-add-invoice-btn    → .v-add (botão adicionar tracejado do showcase) */

/* KIND BADGES (FIXO/PARCELADO/AVULSO/INATIVO) — a FORMA vem do DS
   (.v-bdg v-bdg--mono no markup); aqui só as cores de domínio por tipo
   (o DS não tem variante semântica pra "tipo de lançamento"). */
.pj-kind-badge.fixo{background:color-mix(in srgb, var(--info) 16%, transparent);color:color-mix(in srgb, var(--brand) 70%, var(--tx))}
.pj-kind-badge.parc{background:color-mix(in srgb, var(--brand-2) 16%, transparent);color:color-mix(in srgb, var(--brand-2) 60%, var(--tx))}
.pj-kind-badge.avulso{background:color-mix(in srgb, var(--amber) 16%, transparent);color:color-mix(in srgb, var(--warn) 80%, var(--tx))}
.pj-kind-badge.inactive{background:color-mix(in srgb, var(--tx2) 16%, transparent);color:var(--tx)}

/* CLIENTES */
.pj-clients-list{display:flex;flex-direction:column;gap:6px}
.pj-client-row{
  display:grid;
  grid-template-columns:1fr auto auto auto;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
}
.pj-client-row.inactive{opacity:0.55}
.pj-client-row:hover{background:var(--panel)}
.pj-client-info{min-width:0}
.pj-client-name{
  font-family:var(--ff,system-ui);font-size:13px;font-weight:600;
  color:var(--tx);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  letter-spacing:-0.01em;
}
.pj-client-meta{
  font-family:var(--ff-mono,monospace);font-size:10.5px;
  color:var(--tx2);
  margin-top:2px;
}
.pj-client-action{padding:5px 10px;font-size:11px}

/* ROW 3: despesas + DAS */
.pj-row-3{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:start;
}
.pj-expenses-list{display:flex;flex-direction:column;gap:5px}
.pj-expense-row{
  display:grid;
  grid-template-columns:1fr auto auto auto;
  align-items:center;
  gap:12px;
  padding:11px 13px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
  transition:border-color var(--d1,.15s) ease, background-color var(--d1,.15s) ease;
}
.pj-expense-row:hover{ border-color:var(--line-2); background:var(--panel); }
.pj-expense-info{min-width:0;display:flex;flex-direction:column;gap:3px}
.pj-expense-info b{
  display:flex;align-items:center;gap:7px;flex-wrap:wrap;
  font-family:var(--ff,system-ui);font-size:13px;font-weight:600;
  color:var(--tx);
  letter-spacing:-0.01em;
}
.pj-expense-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.pj-expense-info small{
  font-family:var(--ff-mono,monospace);font-size:11px;
  color:var(--tx3);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.pj-expense-val{
  font-family:var(--ff-mono,monospace);font-weight:700;font-size:13.5px;
  color:color-mix(in srgb, var(--crit) 72%, var(--tx));
  white-space:nowrap;
}

/* DAS */
.pj-das-card{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
  padding:14px 16px;
}
.pj-das-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:7px 0;
  border-bottom:1px dashed var(--line);
}
.pj-das-row:last-of-type{border-bottom:none}
.pj-das-lbl{
  font-family:var(--ff,system-ui);font-size:11.5px;
  color:var(--tx2);font-weight:500;
}
.pj-das-val{
  font-family:var(--ff,system-ui);font-size:12.5px;
  color:var(--tx);font-weight:700;
}
.pj-das-val.mono{font-family:var(--ff-mono,monospace);font-size:14px}


.pj-das-btn{width:100%;justify-content:center;margin-bottom:10px}

.pj-das-info{
  font-family:var(--ff-mono,monospace);font-size:10.5px;line-height:1.5;
  color:var(--tx2);
  padding:9px 11px;
  background:rgba(255,255,255,0.02);
  border-radius:7px;
}

/* MODAL CLIENTE: kind picker */
.pj-kind-picker{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
  margin-top:4px;
}
.pj-kind-tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:14px 8px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:10px;
  cursor:pointer;
  transition:all var(--d2) ease;
}
.pj-kind-tile b{
  font-family:var(--ff,system-ui);font-size:11px;font-weight:700;
  color:var(--tx);
  letter-spacing:0.04em;
}
.pj-kind-tile small{
  font-family:var(--ff-mono,monospace);font-size:9.5px;
  color:var(--tx2);
}
.pj-kind-tile:hover{
  background:var(--panel);
  border-color:color-mix(in srgb, var(--info) 40%, transparent);
}
.pj-kind-tile.active{
  background:color-mix(in srgb, var(--info) 10%, transparent);
  border-color:color-mix(in srgb, var(--info) 55%, transparent);
  box-shadow:0 0 0 2px color-mix(in srgb, var(--info) 12%, transparent);
}

.pj-cond-fields{margin-top:6px}

/* CHECKBOX customizado */
.pj-checkbox{
  display:inline-flex;align-items:center;gap:8px;
  cursor:pointer;
  font-family:var(--ff,system-ui);font-size:12.5px;
  color:var(--tx);font-weight:500;
}
.pj-checkbox input[type="checkbox"]{
  width:16px;height:16px;
  accent-color:var(--brand);
  cursor:pointer;
}

/* ============ RESPONSIVE ============ */
/* v3.0.3: valores grandes (R$ 9.750,00) não cabiam em 5 cols com sidebar 240px.
   Trigger pra reduzir colunas adiantado + valor responsivo via clamp. */
.pj-hero-card .fin-hero-val{
  font-size:clamp(20px, 2.5vw, 34px) !important;
  letter-spacing:-0.02em;
  line-height:1.05;
}
.pj-hero-card{overflow:visible !important} /* permite valor não ser cortado */

@media (max-width:1100px){
  .pj-hero-row1{grid-template-columns:repeat(2, 1fr)}
  .pj-hero-row2{grid-template-columns:1fr}
  .pj-row-2, .pj-row-3{grid-template-columns:1fr}
}
@media (max-width:760px){
  .pj-toggle-btn{padding:5px 10px;font-size:11px}
  .pj-hero-row1{grid-template-columns:1fr}
  .pj-invoice-row{grid-template-columns:1fr auto;gap:8px;padding:10px}
  .pj-invoice-row .pj-confirm-btn,
  .pj-invoice-row .edit-del2,
  .pj-invoice-row .edit-del{grid-column:span 2;justify-self:end}
  .pj-client-row{grid-template-columns:1fr auto}
  .pj-client-row .pj-client-action,
  .pj-client-row .edit-del2,
  .pj-client-row .edit-del{grid-column:span 2;justify-self:end}
  .pj-kind-picker{grid-template-columns:1fr}
}

/* ============ CUSTOS FIXOS PJ (recorrentes) ============ */
.pj-fixed-sec{padding:14px 16px}
.pj-fixed-sec .sh{margin-bottom:10px}
.pj-fixed-list{display:flex;flex-direction:column;gap:6px}
.pj-fixed-row{
  display:grid;grid-template-columns:1fr auto auto auto;gap:10px;
  align-items:center;padding:9px 12px;
  background:var(--panel-2);
  border:1px solid var(--line);border-radius:8px;
}
.pj-fixed-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.pj-fixed-info b{font-size:13px;font-weight:600;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pj-fixed-info small{font-size:11px;color:var(--tx2);font-family:var(--ff-mono)}
.pj-fixed-val{font-family:var(--ff-mono);font-weight:700;color:var(--tx);font-size:13px;font-feature-settings:"tnum"}

/* segmented control no modal de despesa */
.pj-seg{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:rgba(0,0,0,0.25);
  border:1px solid var(--line);border-radius:10px;padding:4px;
  position:relative;
}
.pj-seg-3{grid-template-columns:1fr 1fr 1fr}
.pj-seg-btn{
  padding:10px 8px;border:none;background:transparent;
  font-size:11px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--tx2);cursor:pointer;border-radius:7px;
  transition:all var(--d2) ease;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.pj-seg-btn:hover{color:var(--tx)}
.pj-seg-btn.active{
  background:linear-gradient(135deg, color-mix(in srgb, var(--info) 18%, transparent), color-mix(in srgb, var(--info) 8%, transparent));
  color:#fff;
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--info) 45%, transparent), 0 2px 8px color-mix(in srgb, var(--info) 15%, transparent);
}
.pj-seg-btn svg{width:14px;height:14px;flex-shrink:0}
.pam .pj-seg-btn.active,
.pj-seg.pam-theme .pj-seg-btn.active{
  background:linear-gradient(135deg, color-mix(in srgb, var(--pam-deep) 18%, transparent), color-mix(in srgb, var(--pam-deep) 8%, transparent));
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--pam-deep) 45%, transparent), 0 2px 8px color-mix(in srgb, var(--pam-deep) 15%, transparent);
}

/* badges de tipo na lista de despesas */
.pj-kind-badge.avulsa{
  background:color-mix(in srgb, var(--tx2) 18%, transparent);color:var(--tx);border:1px solid color-mix(in srgb, var(--tx2) 30%, transparent);
}
.pj-kind-badge.parcela{
  background:color-mix(in srgb, var(--brand-2) 18%, transparent);color:color-mix(in srgb, var(--brand-2) 60%, var(--tx));border:1px solid color-mix(in srgb, var(--brand-2) 35%, transparent);
}
.pj-kind-badge.recorrente{
  background:color-mix(in srgb, var(--good) 16%, transparent);color:color-mix(in srgb, var(--good) 75%, var(--tx));border:1px solid color-mix(in srgb, var(--good) 32%, transparent);
}

/* erro inline no modal */
.pj-modal-error{
  margin:8px 0 -4px;
  padding:9px 12px;
  background:color-mix(in srgb, var(--crit) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--crit) 35%, transparent);
  border-radius:8px;
  color:color-mix(in srgb, var(--crit) 70%, var(--tx));
  font-size:12px;line-height:1.4;
  display:none;
}
.pj-modal-error.active{display:block}

@media (max-width:760px){
  .pj-fixed-row{grid-template-columns:1fr auto;gap:8px}
  .pj-fixed-row .edit-del2,
  .pj-fixed-row .edit-del{grid-column:span 2;justify-self:end}
}

/* Somatório destacado no header de seções (v2.31.17) */
.sec-total{
  font-family:var(--ff-mono);
  font-size:14px;
  font-weight:700;
  color:var(--crit);
  letter-spacing:-0.01em;
  font-feature-settings:"tnum";
  margin-left:auto;
  margin-right:8px;
}

/* v2.31.17: extrato no modal de conta PJ */
.pj-stmt{
  display:flex;flex-direction:column;gap:4px;
  max-height:280px;overflow-y:auto;
  background:rgba(0,0,0,.18);
  border:1px solid var(--line);
  border-radius:10px;padding:8px;
}
.pj-stmt-empty{
  text-align:center;color:var(--tx2);
  padding:18px 12px;font-size:12px;
}
.pj-stmt-row{
  display:grid;grid-template-columns:50px 1fr auto;gap:10px;
  align-items:center;
  padding:8px 10px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.04);
  border-radius:8px;
  font-size:12px;
}
.pj-stmt-date{
  font-family:'Inter',var(--ff-mono),monospace;
  font-size:11px;color:var(--tx2);
}
.pj-stmt-label{color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pj-stmt-amount{font-family:'Inter',var(--ff-mono),monospace;font-weight:600;font-size:12px}
.pj-stmt-amount.pos{color:color-mix(in srgb, var(--good) 75%, var(--tx))}
.pj-stmt-amount.neg{color:color-mix(in srgb, var(--crit) 70%, var(--tx))}

/* ============ PENDÊNCIAS A PAGAR (TSK-035) ============ */
.pj-pend-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; align-items:start; }
.pj-pend-group{ border:1px solid var(--line); border-radius:var(--r-md); padding:12px 14px; background:var(--bg); display:flex; flex-direction:column; }
.pj-pend-ghead{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; margin-bottom:8px; }
.pj-pend-gtitle{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--tx3); }
.pj-pend-gtot{ font-family:var(--ff-mono); font-size:13px; font-weight:700; font-variant-numeric:tabular-nums; color:var(--tx); }
.pj-pend-row{ display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:8px; padding:7px 0; border-bottom:1px solid var(--line); font-size:12.5px; }
.pj-pend-row:last-of-type{ border-bottom:none; }
.pj-pend-row.paid .pj-pend-name, .pj-pend-row.paid .pj-pend-val{ opacity:.5; }
.pj-pend-name{ min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--tx); }
.pj-pend-val{ font-family:var(--ff-mono); font-variant-numeric:tabular-nums; color:var(--tx); }
.pj-pend-btn{ white-space:nowrap; }
.pj-pend-empty{ font-size:12px; color:var(--tx3); padding:8px 0; }
.pj-pend-more{ font-size:11px; color:var(--tx3); padding:6px 0; }
.pj-pend-note{ margin-top:auto; padding-top:8px; font-size:10.5px; color:var(--tx4); line-height:1.4; }
@media (max-width:1100px){ .pj-pend-grid{ grid-template-columns:1fr; } }
.pj-pend-fullbtn{ width:100%; justify-content:center; margin-top:8px; }
