/* ============================================================================
   theme.css — Design System do Módulo Financeiro J.Monte
   Tokens (light/dark) + componentes base + responsividade do shell e do CAP.
   Carregado DEPOIS do <style> legado do index.html: o que está aqui vence.
   Identidade: navy #15294d + vermelho #c62828.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500;600&display=swap');

/* ----------------------------- 1. TOKENS ---------------------------------- */
:root{
  /* marca */
  --brand-900:#15294d; --brand-800:#1d3660; --brand-700:#27497f;
  --brand-600:#224178; --brand-500:#2b5cb8; --brand-100:#d4dff0; --brand-50:#eef3fb;
  --accent:#c62828; --accent-bg:#fdecec;
  /* rampa de cinzas */
  --gray-50:#f8f9fb; --gray-100:#f1f3f7; --gray-200:#e3e7ee; --gray-300:#cdd4e0;
  --gray-400:#aab2c0; --gray-500:#7b8794; --gray-600:#5a6678; --gray-700:#3e4a5e;
  --gray-800:#27303f; --gray-900:#1a212c;
  /* superfícies */
  --surface:#ffffff; --surface-2:#f6f8fb; --surface-sunken:#eef0f3;
  --border:#e3e7ee; --border-strong:#c9d1de;
  /* semânticas */
  --success:#2e9e5b; --success-bg:#e6f6ec; --success-fg:#1d7a43;
  --warning:#e0a106; --warning-bg:#fff7e6; --warning-fg:#8a6100;
  --danger:#c62828;  --danger-bg:#fdecec;  --danger-fg:#a91f1f;
  --info:#2f6fed;    --info-bg:#eaf1ff;    --info-fg:#27497f;
  /* texto */
  --text:#1f2d3d; --text-muted:#7b8794; --text-subtle:#aab2c0; --text-on-brand:#ffffff;
  /* tipografia */
  --fs-xs:12px; --fs-sm:13px; --fs-base:14px; --fs-md:15px;
  --fs-lg:17px; --fs-xl:20px; --fs-2xl:24px; --fs-3xl:30px;
  /* espaçamento (escala 4px) */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-5:20px; --sp-6:24px; --sp-7:28px; --sp-8:32px;
  /* raio */
  --r-sm:8px; --r-md:10px; --r-lg:13px; --r-xl:22px; --r-full:999px;
  /* sombras */
  --sh-1:0 1px 2px rgba(21,41,77,.04),0 2px 6px rgba(21,41,77,.05);
  --sh-2:0 1px 3px rgba(21,41,77,.05),0 8px 20px rgba(21,41,77,.07);
  --sh-3:0 4px 10px rgba(21,41,77,.06),0 20px 44px rgba(21,41,77,.13);
  --sh-4:0 6px 16px rgba(21,41,77,.10),0 24px 48px rgba(21,41,77,.16);
  /* movimento */
  --ease:cubic-bezier(.2,.7,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1); --ease-soft:cubic-bezier(.33,1,.68,1);
  --t-fast:120ms; --t:180ms; --t-slow:260ms;
  --font-sans:'IBM Plex Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',monospace;
  /* aliases p/ o CSS legado (index.html e telas) — apontam para os tokens */
  --nav:var(--brand-900); --navactive:var(--brand-700); --navhover:#1f3a66;
  --red:var(--danger); --bg:var(--surface-sunken); --card:var(--surface);
  --line:var(--border); --ink:var(--text); --muted:var(--text-muted);
  --blue:var(--brand-500); --green:var(--success); --amber:var(--warning);
  /* shell */
  --bnav-h:60px;
  color-scheme:light;
}

[data-theme="dark"]{
  --brand-100:#1c2e52; --brand-50:#182645;
  --accent-bg:#3a1d1f;
  --gray-50:#161b24; --gray-100:#1c2230; --gray-200:#262e40; --gray-300:#36405a;
  --gray-400:#566180; --gray-500:#8b96ad; --gray-600:#aeb8cc; --gray-700:#cbd3e3;
  --gray-800:#e2e7f1; --gray-900:#f2f5fa;
  --surface:#1a2130; --surface-2:#212a3c; --surface-sunken:#10151f;
  --border:#2a3347; --border-strong:#3b4760;
  --success:#3fb56e; --success-bg:#16301f; --success-fg:#6dd397;
  --warning:#e8b53a; --warning-bg:#332a10; --warning-fg:#ecc873;
  --danger:#e25555;  --danger-bg:#371b1d;  --danger-fg:#f08a8a;
  --info:#5b8ef5;    --info-bg:#182645;    --info-fg:#9dbcfa;
  --text:#e8ecf4; --text-muted:#8b96ad; --text-subtle:#566180;
  --navhover:#22386a;
  --sh-1:0 1px 2px rgba(0,0,0,.4);
  --sh-2:0 4px 10px rgba(0,0,0,.45);
  --sh-3:0 12px 28px rgba(0,0,0,.55);
  --sh-4:0 24px 60px rgba(0,0,0,.65);
  color-scheme:dark;
}

/* ----------------------------- 2. BASE ------------------------------------ */
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);font-size:var(--fs-base);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--brand-100);color:var(--text)}

/* foco visível em TODOS os interativos */
:focus{outline:none}
:focus-visible{outline:2px solid var(--brand-500);outline-offset:2px;border-radius:var(--r-sm)}
.side nav a:focus-visible,.bnav a:focus-visible{outline-offset:-2px}

/* ----------------------------- 3. BOTÕES ----------------------------------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:var(--brand-500);color:var(--text-on-brand);border:1px solid transparent;
  border-radius:var(--r-md);padding:10px 16px;font-size:var(--fs-base);font-weight:600;
  cursor:pointer;line-height:1.2;width:auto;
  box-shadow:0 1px 2px rgba(21,41,77,.32),inset 0 1px 0 rgba(255,255,255,.16);
  transition:background var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),
             transform var(--t-fast) var(--ease),opacity var(--t-fast) var(--ease);
}
.btn:hover{filter:none;background:var(--brand-600);box-shadow:0 3px 10px rgba(21,41,77,.34),inset 0 1px 0 rgba(255,255,255,.16)}
.btn:active{transform:translateY(1px)}
.btn.sm{padding:7px 12px;font-size:var(--fs-sm)}
.btn.lg{padding:12px 20px;font-size:var(--fs-md)}
.btn.ghost,.btn.secondary{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:var(--sh-1)}
.btn.ghost:hover,.btn.secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}
.btn.danger{background:var(--danger);color:#fff;box-shadow:0 1px 2px rgba(163,31,31,.30),inset 0 1px 0 rgba(255,255,255,.14)}
.btn.danger:hover{background:var(--danger-fg)}
.btn.ghost.danger,.btn.dgr{background:var(--surface);color:var(--danger);border-color:var(--border);box-shadow:var(--sh-1)}
.btn.ghost.danger:hover,.btn.dgr:hover{background:var(--danger-bg);border-color:var(--danger)}
.btn[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none}
/* estado loading: spinner inline, texto esmaecido, clique bloqueado */
.btn.is-loading{pointer-events:none;color:transparent!important}
.btn.is-loading::after{
  content:'';position:absolute;width:16px;height:16px;left:calc(50% - 8px);top:calc(50% - 8px);
  border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;
  animation:btn-spin .7s linear infinite;
}
.btn.ghost.is-loading::after,.btn.secondary.is-loading::after{
  border-color:var(--gray-300);border-top-color:var(--brand-500);
}
@keyframes btn-spin{to{transform:rotate(360deg)}}

/* ----------------------------- 4. INPUTS ----------------------------------- */
.ft input,.ft select,.field input,.ed-ctrl select,.ed-ctrl input,
.rp-trigger,.rp-in,.pp-in,.mv-controls input[type=search],.mv-controls select,
.mv-toolbar select,.mv-toolbar input[type=date]{
  background:var(--surface);color:var(--text);border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);
}
.ft input:hover,.ft select:hover,.rp-trigger:hover,.pp-in:hover{border-color:var(--border-strong)}
.ft input:focus,.ft select:focus,.field input:focus,.rp-in:focus,.pp-in:focus,
.ed-ctrl select:focus,.ed-ctrl input:focus{
  outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100);
}
.ft input.error,.ft select.error,input.error{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-bg)}
.ft input[disabled],.ft select[disabled]{background:var(--surface-2);color:var(--text-subtle);cursor:not-allowed}
.ft label{font-weight:500;color:var(--text-muted)}
input::placeholder{color:var(--text-subtle)}
input,select,textarea,button{font-family:inherit}

/* ----------------------------- 5. CARDS / KPI ------------------------------ */
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-1);
  transition:box-shadow var(--t) var(--ease),transform var(--t) var(--ease);
}
.card:hover{box-shadow:var(--sh-2)}
.card.click:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.kpi .lbl{font-size:var(--fs-xs);font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--text-muted)}
.kpi .val{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.3px;margin-top:var(--sp-2);font-variant-numeric:tabular-nums}
.kpi .sub{font-size:var(--fs-xs);color:var(--text-subtle);margin-top:var(--sp-1)}

/* ----------------------------- 6. PILLS DE STATUS -------------------------- */
/* cor SEMPRE pareada com ícone (acessibilidade: status nunca só por cor) */
.status{
  display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  padding:2px 9px;border-radius:var(--r-full);white-space:nowrap;line-height:1.6;
}
.status::before{font-size:9px;line-height:1}
.status.st-aberto{background:var(--danger-bg);color:var(--danger-fg)}
.status.st-aberto::before{content:'●'}
.status.st-liquidado{background:var(--success-bg);color:var(--success-fg)}
.status.st-liquidado::before{content:'✓';font-size:11px;font-weight:800}
.status.st-baixado{background:var(--gray-100);color:var(--text-muted)}
.status.st-baixado::before{content:'⊘';font-size:11px}
.status.st-areceber{background:var(--warning-bg);color:var(--warning-fg)}
.status.st-areceber::before{content:'●'}
.status.st-parcial{background:var(--warning-bg);color:var(--warning-fg)}
.status.st-parcial::before{content:'◐';font-size:11px;font-weight:800}
/* boleto-caixa via remessa (cad. caixa-boleto): aguardando arquivo de remessa × confirmado na remessa */
.status.st-aguarda{background:var(--warning-bg);color:var(--warning-fg)}
.status.st-aguarda::before{content:'◷';font-size:11px;font-weight:800}
.status.st-confirma{background:var(--info-bg);color:var(--info-fg)}
.status.st-confirma::before{content:'⇄';font-size:11px;font-weight:800}
.pill{background:var(--gray-100);color:var(--text-muted)}

/* ----------------------------- 7. TABELAS ---------------------------------- */
table{background:var(--surface);border-color:var(--border);box-shadow:var(--sh-1)}
th{background:var(--surface-2);color:var(--text-muted);border-color:var(--border)}
td{border-color:var(--border)}
th.th-sort:hover{background:var(--gray-100)}
/* grade de títulos: densidade confortável no desktop, zebra sutil, header fixo */
.cap-table td,.cap-table th{padding:7px 2.5px;font-size:12.5px;line-height:1.35}
.cap-table th{font-size:10.5px;position:sticky;top:0;z-index:5;box-shadow:0 1px 0 var(--border)}
.cap-table tbody tr{transition:background var(--t-fast) var(--ease)}
.cap-table tbody tr:nth-child(even){background:var(--gray-50)}
.cap-table tbody tr:hover{background:var(--brand-50)}
.cap-table tbody tr.sel-row{background:var(--brand-100)!important}
.cap-table tbody tr.row-flash{animation:row-flash 1.2s var(--ease)}
@keyframes row-flash{0%{background:var(--success-bg)}100%{background:transparent}}
.cap-table .btn.sm{padding:4px 10px;font-size:11px;min-height:26px}
.cap-scroll{border-radius:var(--r-lg);max-height:calc(100vh - 280px);overflow:auto}
.cap-scroll table{border-radius:var(--r-lg)}
/* DRE: realce suave da linha no hover (!important vence os fundos inline das linhas de grupo/análise) */
.dre-tbl tbody tr{transition:background .12s var(--ease)}
.dre-tbl tbody tr:hover{background:var(--brand-100)!important}
.dre-tbl tbody tr:hover td:first-child{background:var(--brand-100)!important}
/* nome de linha com legenda (fórmula/soma): sem sublinhado; navy no hover + tooltip flutuante instantâneo */
.dre-leg{cursor:help;outline:none;border-radius:4px;transition:color .12s var(--ease)}
.dre-leg:hover,.dre-leg:focus-visible{color:var(--info-fg)}
.dre-tip{position:fixed;z-index:2200;display:none;max-width:380px;background:var(--surface);color:var(--text-muted);
  border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-2);padding:9px 11px;
  font-size:12px;line-height:1.55;pointer-events:none;font-variant-numeric:tabular-nums}
.dre-tip .dre-tip-h{font-weight:700;color:var(--info-fg);margin-bottom:4px;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px}
.dre-tip .dre-tip-b{white-space:normal;color:var(--text)}

/* ---- Dropdown de escolha única (dropdown.js): ✓ no item + cabeçalho de grupo ---- */
.ms.ds{position:relative}
.ds-opt{padding-left:6px}
.ds-ck{flex:none;width:15px;text-align:center;color:var(--brand-500);font-weight:700;visibility:hidden}
.ds-opt.on .ds-ck{visibility:visible}
.ds-opt.on{font-weight:600;color:var(--text)}
.ds-grp{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-subtle);padding:8px 8px 3px}
.ds-grp:first-child{padding-top:2px}

/* ----------------------------- 8. TOOLBAR / CHIPS --------------------------- */
.toolbar{box-shadow:var(--sh-1);border-radius:var(--r-lg)}
/* Cabeçalho das telas de títulos (Pagar/Receber): descrição à esquerda + busca rápida à direita.
   Tira a busca da toolbar (some uma faixa inteira) e a mantém fora do sheet de filtros do mobile. */
.cap-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);margin:0 0 var(--sp-3)}
.cap-head .page-d{margin:0}
.cap-busca{flex:0 0 auto;width:360px;max-width:42%;position:relative}
.cap-busca input{
  width:100%;padding:8px 12px 8px 34px;border:1px solid var(--line);border-radius:var(--r-md);
  font-size:var(--fs-sm);background-color:var(--card);color:var(--ink);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:11px center;background-size:15px;
}
.cap-busca input:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}
.chips{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin:0 0 var(--sp-3)}
.chips:empty{display:none}
.chip{
  display:inline-flex;align-items:center;gap:6px;background:var(--brand-50);
  border:1px solid var(--brand-100);color:var(--info-fg);font-size:var(--fs-xs);
  font-weight:600;padding:4px 6px 4px 10px;border-radius:var(--r-full);
}
[data-theme="dark"] .chip{color:var(--info-fg)}
.chip b{font-weight:700}
.chip .chip-x{
  display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;
  border:none;border-radius:50%;background:transparent;color:inherit;cursor:pointer;
  font-size:12px;line-height:1;padding:0;
}
.chip .chip-x:hover{background:var(--brand-100)}

/* totalizador do CAP — destaque de verdade, não textinho */
.tot-bar{
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-1);padding:10px 16px;margin-bottom:var(--sp-4);
}
.tot-bar .tot-qtd,.ab-tot .tot-qtd{font-size:var(--fs-sm);color:var(--text-muted)}
.tot-bar .tot-qtd b,.ab-tot .tot-qtd b{color:var(--text);font-size:var(--fs-md)}
.tot-bar .tot-vals{display:flex;gap:var(--sp-6);flex-wrap:wrap}
.ab-tot .tot-vals{display:flex;gap:var(--sp-4);flex-wrap:wrap}
.tot-bar .tot-item,.ab-tot .tot-item{display:flex;flex-direction:column}
.tot-bar .tot-item small,.ab-tot .tot-item small{font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--text-subtle)}
.tot-bar .tot-item b{font-size:var(--fs-lg);font-variant-numeric:tabular-nums;letter-spacing:-.2px}
.ab-tot .tot-item b{font-size:var(--fs-md);font-variant-numeric:tabular-nums;letter-spacing:-.2px}
/* compacta os totais dentro da faixa (~75% da altura): rótulo+valor na MESMA linha */
.ab-tot .tot-qtd b{font-size:var(--fs-sm)}
.ab-tot .tot-item{flex-direction:row;align-items:baseline;gap:5px;line-height:1.1}
.ab-tot .tot-item small{font-size:9px;line-height:1.1}
.ab-tot .tot-item b{font-size:var(--fs-sm);line-height:1.1}
/* chips de filtro mais baixos dentro da faixa */
.actionbar .chip{padding:1px 5px 1px 8px;font-size:11px}
.actionbar .chip .chip-x{width:15px;height:15px;font-size:11px}

/* faixa fixa unificada (CAP/CAR): totais + chips de filtro SEMPRE visíveis;
   ao selecionar linhas, surgem ali também o total dos selecionados + os botões
   de ação — no mesmo lugar, sem esconder os totais nem empurrar a tabela */
.actionbar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:5px var(--sp-3);flex-wrap:wrap;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-1);padding:5px 12px;margin-bottom:var(--sp-3);min-height:33px;
}
.actionbar .ab-info{display:flex;align-items:center;gap:5px var(--sp-5);flex-wrap:wrap;min-width:0}
.actionbar .ab-tot{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap}
.actionbar .chips{margin:0}
.actionbar .ab-hint{font-size:var(--fs-sm);color:var(--text-subtle)}
.actionbar .ab-bulk{display:none}
.actionbar.selecting .ab-bulk{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap;margin-left:auto}
.ab-bulk .ab-sel{font-size:12px;font-weight:700;white-space:nowrap;color:var(--brand-700);
  background:var(--brand-50);border:1px solid var(--brand-100);border-radius:var(--r-full);padding:2px 10px}
.ab-bulk .ab-btns{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.ab-bulk .ab-btns .btn{padding:3px 9px;font-size:11px;min-height:24px}

/* barra de ações em lote (desktop ancorada no fluxo; mobile vira fixa — ver §13) */
.bulk-bar{
  display:flex;justify-content:space-between;align-items:center;gap:var(--sp-3);
  background:var(--gray-800);color:#fff;padding:10px 14px;border-radius:var(--r-lg);
  margin-bottom:var(--sp-4);box-shadow:var(--sh-2);
  animation:bulk-in var(--t) var(--ease);
}
[data-theme="dark"] .bulk-bar{background:var(--brand-700)}
@keyframes bulk-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.bulk-bar .btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.bulk-bar .btn.ghost:hover{background:rgba(255,255,255,.12)}

/* ----------------------------- 9. TOASTS ----------------------------------- */
#toasts{
  position:fixed;top:16px;right:16px;z-index:12000;display:flex;flex-direction:column;
  gap:var(--sp-2);max-width:380px;pointer-events:none;
}
.toast{
  display:flex;align-items:flex-start;gap:10px;background:var(--surface);color:var(--text);
  border:1px solid var(--border);border-left:4px solid var(--info);border-radius:var(--r-md);
  box-shadow:var(--sh-3);padding:12px 14px;font-size:var(--fs-sm);line-height:1.45;
  pointer-events:auto;animation:toast-in var(--t-slow) var(--ease);white-space:pre-line;
}
.toast.out{opacity:0;transform:translateX(12px);transition:opacity var(--t) var(--ease),transform var(--t) var(--ease)}
@keyframes toast-in{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.toast .tic{flex:none;font-size:15px;line-height:1.3}
.toast.ok{border-left-color:var(--success)}.toast.ok .tic{color:var(--success)}
.toast.err{border-left-color:var(--danger)}.toast.err .tic{color:var(--danger)}
.toast.warn{border-left-color:var(--warning)}.toast.warn .tic{color:var(--warning)}
.toast .tmsg{flex:1;word-break:break-word}
.toast .tx{flex:none;border:none;background:none;color:var(--text-subtle);cursor:pointer;font-size:14px;padding:0 2px}
.toast .tx:hover{color:var(--text)}
/* toast de progresso (lote) */
.toast .tprog{display:block;height:4px;background:var(--gray-100);border-radius:var(--r-full);margin-top:8px;overflow:hidden}
.toast .tprog i{display:block;height:100%;width:0;background:var(--brand-500);border-radius:var(--r-full);transition:width var(--t) var(--ease)}

/* ----------------------------- 10. MODAL / BOTTOM SHEET --------------------- */
.ui-ov{
  position:fixed;inset:0;background:rgba(10,18,35,.5);z-index:10000;
  display:flex;align-items:center;justify-content:center;padding:var(--sp-6);overflow:auto;
  animation:ov-in var(--t) var(--ease);
}
[data-theme="dark"] .ui-ov{background:rgba(0,0,0,.6)}
@keyframes ov-in{from{opacity:0}to{opacity:1}}
.ui-modal{
  background:var(--surface);color:var(--text);border-radius:var(--r-lg);width:100%;
  max-width:560px;box-shadow:var(--sh-4);display:flex;flex-direction:column;
  max-height:calc(100vh - 48px);animation:modal-in var(--t-slow) var(--ease);
}
.ui-modal.wide{max-width:760px}
/* Modal de título (CAP/CAR): um pouco mais largo p/ a barra de abas + botão "Renegociar" caberem
   na MESMA linha (sem o botão quebrar p/ uma 2ª linha). No mobile o reset abaixo devolve full-width. */
.ui-modal.modal-titulo{max-width:900px}
@keyframes modal-in{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}
.ui-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border)}
.ui-head h3{margin:0;font-size:var(--fs-lg);font-weight:700}
.ui-x{
  flex:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border:none;background:transparent;border-radius:var(--r-md);color:var(--text-muted);
  font-size:16px;cursor:pointer;
}
.ui-x:hover{background:var(--gray-100);color:var(--text)}
.ui-body{padding:var(--sp-5);overflow:auto;-webkit-overflow-scrolling:touch}
.ui-foot{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border)}
.ui-grab{display:none}
.ui-modal .page-d{color:var(--text-muted)}
/* tabela de Renegociações: padding enxuto p/ caber no modal sem rolagem lateral;
   nome do fornecedor trunca com … em vez de alargar a tabela */
.rh-table{width:100%;font-size:13px;border-collapse:collapse}
.rh-table th,.rh-table td{padding:5px 8px;border-bottom:1px solid var(--border)}
.rh-table th{background:transparent}
.rh-table .rh-forn{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Linha de rateio (Loja · Centro de Custo · Plano de Contas · Valor · remover): grid que ENCOLHE
   (min-width:0 nos campos) — sem isso os <select> não reduzem abaixo do conteúdo e o modal ganha
   scroll lateral. Em telas estreitas quebra em 2 colunas. Usada em CAP e CAR. */
.rat-linha{display:grid;grid-template-columns:1fr 1fr 1fr 96px 26px;gap:6px;align-items:center;margin-bottom:8px}
.rat-linha>select,.rat-linha>input{min-width:0;width:100%;padding:7px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--text)}
.rat-linha>input{text-align:right}
.rat-linha .ui-x{justify-self:center;color:var(--danger)}
/* cabeçalho de colunas do rateio (alinhado ao mesmo grid das linhas) */
.rat-head{margin-bottom:4px}
.rat-head>span{font-size:12px;font-weight:500;color:var(--text-muted);padding:0 2px}
@media (max-width:767px){.rat-linha{grid-template-columns:1fr 1fr}.rat-linha .ui-x{justify-self:end}.rat-head{display:none}}

/* ----------------------------- 11. SKELETON / EMPTY ------------------------- */
.skel{position:relative;overflow:hidden;background:var(--gray-100);border-radius:var(--r-sm)}
.skel::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  animation:skel 1.3s infinite;
}
[data-theme="dark"] .skel::after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent)}
@keyframes skel{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.skel-rows{display:flex;flex-direction:column;gap:10px;padding:var(--sp-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg)}
.skel-row{height:30px}
.skel-card{height:96px;border-radius:var(--r-lg)}
.empty{background:var(--surface);border-color:var(--border);border-radius:var(--r-lg)}

/* ----------------------------- 12. SHELL (desktop) -------------------------- */
.top{position:sticky;top:0;z-index:40}
.theme-toggle{
  width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface);
  cursor:pointer;font-size:15px;transition:background var(--t-fast) var(--ease);
}
.theme-toggle:hover{background:var(--surface-2)}
.side nav a{transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}
/* bottom-nav: invisível fora do mobile */
.bnav{display:none}
.fab-filtros,.msel-btn{display:none}

/* ----------------------------- 13. RESPONSIVO ------------------------------- */
/* TABLET (768–1023px): sidebar colapsa para ícones, conteúdo fluido */
@media (max-width:1023px) and (min-width:768px){
  #app .side{width:64px}
  #app .main{margin-left:64px}
  #app .side .brand{justify-content:center;padding:16px 0}
  #app .side .brand .mark,#app .side .brand b,#app .side .lbl,
  #app .side .user,#app .side .grp,#app .side .foot{display:none}
  #app .side nav a{justify-content:center;padding:12px 0;gap:0;border-left-width:0}
  #app .side nav a.active{border-left-width:3px}
  .mv-bar{left:64px}
  .content{padding:var(--sp-5)}
  .grid.g4,.grid.g5{grid-template-columns:repeat(2,1fr)}
}

/* MOBILE (<768px) */
@media (max-width:767px){
  /* shell: sidebar some, bottom-nav entra.
     Inclui os seletores .collapsed porque #app.collapsed .main (1,2,0) é mais específico
     que #app .main (1,1,0) — sem isto, a margem de 64px da sidebar recolhida sobra no mobile. */
  #app .side,#app.collapsed .side{display:none}
  #app .main,#app.collapsed .main{margin-left:0;min-width:0;max-width:100vw}
  body{padding-bottom:0}
  .content{padding:var(--sp-4) var(--sp-3) calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 76px)}
  .top{padding:10px var(--sp-3);gap:8px}
  .top .right{display:none}            /* tema e sair vivem no sheet "Mais" */
  .top .crumb{font-size:0}             /* esconde o "Financeiro"; fica só o título da tela */
  .top .crumb b{font-size:var(--fs-md);margin-top:0;white-space:nowrap;max-width:38vw;overflow:hidden;text-overflow:ellipsis}
  .top .top-left{gap:10px;min-width:0;flex:1;justify-content:space-between}
  .top .page-actions{flex:none;gap:6px}
  .top .page-actions .btn{white-space:nowrap;min-height:38px}
  /* no celular os botões de ação (Calendário/Selecionar/Novo) viram ícones quadrados → não estouram a barra */
  .top .page-actions .pa-lbl{display:none}
  .top .page-actions .pa-ico{padding:0;width:38px;min-width:38px;justify-content:center}
  .grid.g5,.grid.g4,.grid.g3,.grid.g2{grid-template-columns:1fr 1fr}
  .mv-bar{left:0;bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px))}

  .bnav{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:9000;
    background:var(--surface);border-top:1px solid var(--border);
    height:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px));
    padding-bottom:env(safe-area-inset-bottom,0px);
    box-shadow:0 -4px 18px rgba(20,40,80,.10);
  }
  [data-theme="dark"] .bnav{box-shadow:0 -4px 18px rgba(0,0,0,.45)}
  .bnav a{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    color:var(--text-muted);text-decoration:none;font-size:10px;font-weight:600;cursor:pointer;
    min-height:44px;border-top:2px solid transparent;letter-spacing:.2px;
  }
  .bnav a .bic{font-size:19px;line-height:1.1}
  .bnav a.active{color:var(--brand-500);border-top-color:var(--brand-500)}
  [data-theme="dark"] .bnav a.active{color:var(--info-fg);border-top-color:var(--info-fg)}

  /* sheet "Mais": grade de atalhos */
  .more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-2)}
  .more-it{
    display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 6px;
    border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2);
    cursor:pointer;font-size:var(--fs-xs);font-weight:600;color:var(--text);text-align:center;
    min-height:44px;
  }
  .more-it:active{background:var(--brand-50)}
  .more-it .mic{font-size:22px}
  .more-it.active{border-color:var(--brand-500);background:var(--brand-50)}

  /* modal vira bottom sheet */
  .ui-ov{align-items:flex-end;padding:0}
  .ui-modal,.ui-modal.wide{
    max-width:none;border-radius:var(--r-xl) var(--r-xl) 0 0;
    max-height:92dvh;animation:sheet-in var(--t-slow) var(--ease);
    padding-bottom:env(safe-area-inset-bottom,0px);
  }
  @keyframes sheet-in{from{transform:translateY(40%)}to{transform:none}}
  .ui-modal.drag-out{transition:transform var(--t) var(--ease)}
  .ui-grab{display:block;padding:10px 0 2px;cursor:grab;touch-action:none}
  .ui-grab::before{content:'';display:block;width:44px;height:5px;border-radius:var(--r-full);background:var(--gray-300);margin:0 auto}
  .ui-foot{padding-bottom:max(var(--sp-4),env(safe-area-inset-bottom,0px))}
  .ui-foot .btn{min-height:46px;flex:1}
  /* formulários dentro de sheets: campos encolhem p/ caber no grid de 2 colunas */
  .ui-body{overflow-x:hidden}
  .ui-body .ft{min-width:0}
  .ui-body .ft input,.ui-body .ft select,.ui-body .rp-trigger,.ui-body .pp-in{min-width:0;width:100%;max-width:none}
  .ui-body .grid.g3{grid-template-columns:1fr 1fr}

  /* alvos de toque ≥44px */
  .btn.sm{min-height:40px;padding:9px 14px}
  .ft input,.ft select,.rp-trigger,.pp-in{min-height:44px;font-size:16px} /* 16px evita zoom do iOS */
  .ms-opt,.pp-item{min-height:40px;display:flex;align-items:center}
  .rp-day{padding:10px 0}
  input[type=checkbox]{width:20px;height:20px}

  /* toasts acima da bottom-nav */
  #toasts{top:auto;left:12px;right:12px;bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 12px);max-width:none}
  @keyframes toast-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

  /* CAP/CAR: no mobile a busca rápida empilha sob a descrição e ocupa a largura toda */
  .cap-head{flex-direction:column;align-items:stretch;gap:var(--sp-2)}
  .cap-busca{width:100%;max-width:none}
  /* CAP: toolbar de filtros sai do fluxo (vai para o sheet) */
  .tela-titulos .toolbar{display:none}
  .filtros-sheet-body .toolbar{
    display:flex!important;flex-direction:column;align-items:stretch;border:none;
    box-shadow:none;padding:0;margin:0;background:transparent;
  }
  .filtros-sheet-body .toolbar .ft{width:100%}
  .filtros-sheet-body .ft-datas{flex-direction:column;align-items:stretch;width:100%}   /* 4 datas empilham no sheet */
  .filtros-sheet-body .toolbar .ft select,.filtros-sheet-body .toolbar .ft .pp-in,
  .filtros-sheet-body .toolbar .ft .rp-trigger{width:100%;max-width:none}
  .filtros-sheet-body .toolbar .ft[style*="margin-left"]{margin-left:0!important}
  .filtros-sheet-body .rp-panel,.filtros-sheet-body .dp-panel{position:fixed;left:8px;right:8px;top:auto;bottom:90px;max-height:60dvh;overflow:auto}
  .filtros-sheet-body .rp-cals{flex-direction:column}
  .filtros-sheet-body .rp-body{flex-direction:column}
  .filtros-sheet-body .rp-presets{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--border);padding:0 0 8px;min-width:0}

  /* botão Filtrar flutuante */
  .fab-filtros{
    display:flex;position:fixed;right:14px;bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 14px);
    z-index:8900;align-items:center;gap:8px;background:var(--brand-900);color:#fff;border:none;
    border-radius:var(--r-full);padding:13px 20px;font-size:var(--fs-base);font-weight:700;
    box-shadow:var(--sh-3);cursor:pointer;min-height:48px;
  }
  .fab-filtros .fab-n{
    background:var(--accent);border-radius:var(--r-full);font-size:11px;min-width:20px;height:20px;
    display:inline-flex;align-items:center;justify-content:center;padding:0 6px;font-weight:700;
  }
  .fab-filtros .fab-n:empty{display:none}

  /* tabela → cards */
  .tela-titulos .cap-scroll,.tela-titulos .pager-box{display:none}
  .content{overflow-x:clip}
  .tot-bar{position:sticky;top:54px;z-index:30;padding:8px 12px;gap:2px 8px}
  .tot-bar .tot-vals{width:100%;justify-content:space-between;gap:var(--sp-3)}
  .tot-bar .tot-item b{font-size:var(--fs-base)}

  /* no mobile a faixa unificada se desfaz: totais/chips ficam grudados no topo
     e os botões de ação voltam a ser uma barra fixa acima da bottom-nav (alcance do polegar) */
  .actionbar{display:block;position:static;background:transparent;border:none;box-shadow:none;padding:0;margin:0;min-height:0}
  .actionbar .ab-info{display:flex;position:sticky;top:54px;z-index:30;
    background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
    box-shadow:var(--sh-1);padding:8px 12px;gap:6px 12px}
  .actionbar.selecting .ab-info{display:flex}            /* no mobile NÃO esconde os totais ao selecionar */
  .actionbar .ab-tot .tot-vals{width:100%;justify-content:space-between;gap:var(--sp-3)}

  /* barra de lote fixa acima da bottom-nav */
  .actionbar.selecting .ab-bulk{
    position:fixed;left:8px;right:8px;z-index:8950;
    bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 8px);
    flex-direction:column;align-items:stretch;gap:6px;margin:0;
    background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
    box-shadow:var(--sh-2);padding:10px 12px;
  }
  .ab-bulk .ab-btns{flex-wrap:wrap;gap:6px;justify-content:stretch}
  .ab-bulk .ab-btns .btn{flex:1;min-height:42px}
}

/* ------------------- PALETA DE BUSCA GLOBAL (Cmd+K) ------------------------ */
kbd{
  display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:1px 5px;
  border:1px solid var(--border);border-bottom-width:2px;border-radius:5px;background:var(--surface-2);
  color:var(--text-muted);font:600 10px/1.5 inherit;font-family:inherit;
}
/* botão de busca do topbar */
.busca-btn{
  display:inline-flex;align-items:center;gap:9px;min-width:210px;padding:8px 14px;
  border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-2);
  color:var(--text-muted);font-size:var(--fs-sm);cursor:pointer;
  transition:border-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);
}
.busca-btn:hover{border-color:var(--border-strong);color:var(--text);box-shadow:var(--sh-1)}
.busca-btn .busca-txt{flex:1;text-align:left}

/* ----- Ticker de mercado (topo, entre Buscar e o tema) ----- */
.mkt{display:flex;align-items:stretch;gap:4px;min-width:0;flex:1 1 auto;overflow:hidden;
  margin:0 4px;mask-image:linear-gradient(90deg,#000 calc(100% - 16px),transparent)}
.mkt-i{display:flex;flex-direction:column;justify-content:center;gap:1px;padding:3px 10px;
  border-radius:var(--r-md);white-space:nowrap;line-height:1.15;flex:none}
.mkt-i:hover{background:var(--surface-2)}
.mkt-i.edit{cursor:pointer}
.mkt-k{font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-subtle);display:flex;align-items:center;gap:4px}
.mkt-flag{height:9px;width:auto;border-radius:1px;flex:none;display:block;box-shadow:0 0 0 .5px rgba(0,0,0,.15)}
/* bandeiras do ticker agora em TODAS as telas (consistência do refino) */
.mkt-v{font-size:var(--fs-sm);font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.mkt-v .mkt-pct{font-size:10px;font-weight:600;margin-left:5px}
.mkt-v .up{color:var(--success)}
.mkt-v .down{color:var(--danger)}
.mkt-i.stale{opacity:.55}
.mkt-sep{width:1px;background:var(--border);flex:none;margin:4px 0}
.mkt-skel{height:32px;flex:1;border-radius:var(--r-md);background:var(--surface-2);
  animation:mkt-pulse 1.2s var(--ease) infinite}
@keyframes mkt-pulse{50%{opacity:.5}}
/* flash quando um valor MUDA (só o item alterado) — verde sobe, vermelho cai, neutro p/ texto */
.mkt-v.mkt-flash-up{animation:mkt-fl-up 1.5s var(--ease)}
.mkt-v.mkt-flash-down{animation:mkt-fl-down 1.5s var(--ease)}
.mkt-v.mkt-flash{animation:mkt-fl 1.5s var(--ease)}
@keyframes mkt-fl-up{0%{color:var(--success);text-shadow:0 0 10px var(--success)}30%{color:var(--success);transform:translateY(-1px)}100%{color:var(--text);text-shadow:none;transform:none}}
@keyframes mkt-fl-down{0%{color:var(--danger);text-shadow:0 0 10px var(--danger)}30%{color:var(--danger);transform:translateY(1px)}100%{color:var(--text);text-shadow:none;transform:none}}
@keyframes mkt-fl{0%{color:var(--brand-500)}100%{color:var(--text)}}
@media (prefers-reduced-motion:reduce){.mkt-v.mkt-flash-up,.mkt-v.mkt-flash-down,.mkt-v.mkt-flash{animation:none}}
/* O ticker só aparece quando há espaço para mostrá-lo INTEIRO (largura natural ~557px) mesmo
   com a sidebar aberta — abaixo disso ele seria cortado pela máscara (itens Fed sumindo), o que
   parece "faltar informação / precisar rolar". Some por completo em vez de cortar pela metade. */
@media (max-width:1365px){ .mkt{display:none} }
/* paleta */
.pal-ov{
  position:fixed;inset:0;background:rgba(10,18,35,.5);z-index:11000;
  display:flex;align-items:flex-start;justify-content:center;padding:12vh 16px 16px;
  animation:ov-in var(--t) var(--ease);
}
[data-theme="dark"] .pal-ov{background:rgba(0,0,0,.6)}
.pal-box{
  width:100%;max-width:840px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--sh-4);overflow:hidden;display:flex;flex-direction:column;
  max-height:min(560px,72vh);animation:modal-in var(--t-slow) var(--ease);
  transition:max-width var(--t-slow) var(--ease),max-height var(--t-slow) var(--ease);
}
/* modal expandido — quando o conteúdo precisa de mais espaço (ex.: detalhamento da IA): evita scroll lateral e reduz o vertical */
.pal-box.pal-wide{max-width:1240px;max-height:86vh}
.pal-wide .pal-det{max-height:min(60vh,520px)}
.pal-wide .pal-det-tbl td.nm{max-width:480px}
@media (prefers-reduced-motion:reduce){.pal-box{transition:none}}
.pal-in{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);flex:none}
.pal-in input{
  flex:1;border:none;background:transparent;color:var(--text);font-size:var(--fs-md);outline:none;min-width:0;
}
.pal-in input::placeholder{color:var(--text-subtle)}
/* botão de fechar da busca: desktop mostra o atalho "esc" (agora clicável); mobile mostra o X (ver media query) */
.pal-x{display:inline-flex;align-items:center;justify-content:center;gap:4px;background:none;border:none;cursor:pointer;padding:4px;color:var(--text-subtle);border-radius:var(--r-sm)}
.pal-x:hover{color:var(--text)}
.pal-x .pal-x-ico{display:none;width:20px;height:20px}
.pal-list{overflow-y:auto;padding:4px 8px 8px;flex:1;-webkit-overflow-scrolling:touch}
.pal-g{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text-subtle);padding:10px 8px 4px}
.pal-it{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md);cursor:pointer}
.pal-it.on{background:var(--brand-50)}
[data-theme="dark"] .pal-it.on{background:var(--brand-100)}
.pal-it .pi{flex:none;width:30px;height:30px;border-radius:var(--r-md);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:15px}
.pal-it .pt{flex:1;min-width:0}
.pal-it .pt b{display:block;font-size:var(--fs-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pal-it .pt small{display:block;color:var(--text-muted);font-size:var(--fs-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pal-it .pv{font-variant-numeric:tabular-nums;font-weight:700;font-size:var(--fs-sm);white-space:nowrap}
.pal-tag{flex:none;font-size:10px;font-weight:600;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--r-full);padding:2px 8px;white-space:nowrap}
.pal-enter{visibility:hidden}
.pal-it.on .pal-enter{visibility:visible}
.pal-acao{flex:none;padding:4px 10px;font-size:11px;min-height:0}
.pal-vazio{padding:28px 16px;text-align:center;color:var(--text-muted);font-size:var(--fs-sm);line-height:1.6}
.pal-dica{padding:10px;text-align:center;color:var(--text-subtle);font-size:var(--fs-xs)}
.pal-dica-btn{background:none;border:0;padding:0;font:inherit;color:var(--info);cursor:pointer}
.pal-dica-btn:hover{text-decoration:underline}
/* faixa de totais do período (item 1) — logo abaixo do título do grupo A Pagar/Receber */
.pal-resumo{margin:0 8px 4px;padding:6px 10px;border-radius:var(--r-md);background:var(--surface-2);color:var(--text-muted);font-size:var(--fs-xs);font-variant-numeric:tabular-nums}
.pal-resumo b{color:var(--text);font-weight:700}
/* item "ver todos os N na tela" (item 3) — atalho discreto que leva à tela completa filtrada */
.pal-vertodos .pt b{font-weight:600;color:var(--brand-600)}
.pal-vertodos .pi{background:transparent;color:var(--brand-600)}
/* Assistente de IA — launcher e painel de resposta */
.pal-ia .pt b{font-weight:600;color:var(--brand-600)}
.pal-ia-resp{display:flex;gap:10px;align-items:flex-start;padding:10px 12px}
.pal-ia-resp .pi{flex:none;width:30px;height:30px;border-radius:var(--r-md);background:var(--brand-50);display:flex;align-items:center;justify-content:center;font-size:15px}
.pal-ia-txt{font-size:var(--fs-sm);line-height:1.55;color:var(--text);white-space:normal}
/* markdown leve no balão da IA (negrito/itálico/código/listas/tabela) */
.pal-ia-txt>div+div{margin-top:5px}
.pal-ia-txt strong{font-weight:700}
.pal-ia-txt code{background:var(--surface-2);padding:1px 5px;border-radius:5px;font-size:.92em;font-family:var(--font-mono,monospace)}
.pal-ia-txt ul,.pal-ia-txt ol{margin:6px 0;padding-left:20px}
.pal-ia-txt li{margin:2px 0}
.pal-ia-txt .md-tbl{border-collapse:collapse;margin:8px 0;font-size:var(--fs-xs);width:100%}
.pal-ia-txt .md-tbl th,.pal-ia-txt .md-tbl td{border:1px solid var(--border);padding:4px 8px;text-align:left}
.pal-ia-txt .md-tbl th{background:var(--surface-2);font-weight:600;color:var(--text-muted);white-space:nowrap}
.pal-ia-txt .md-tbl td{font-variant-numeric:tabular-nums}
.pal-ia-rod{margin-top:8px;font-size:var(--fs-xs);color:var(--text-subtle);display:flex;align-items:center;gap:5px}
.pal-ia-nav{margin-top:10px}/* botão "Abrir tela" (abrir_tela) — leva o operador direto ao módulo certo */
/* feedback 👍/👎 da resposta (path 5) */
.ia-fb-wrap{display:inline-flex;align-items:center;gap:4px}
.ia-fb{background:none;border:0;cursor:pointer;padding:0 2px;font-size:1em;line-height:1;opacity:.65;transition:opacity var(--t-fast,.12s) var(--ease,ease),transform var(--t-fast,.12s) var(--ease,ease)}
.ia-fb:hover{opacity:1;transform:scale(1.18)}
.ia-fb-done{color:var(--text-muted)}
/* tela admin "Assistente IA" (path 4) — KPIs + tabela de garimpo */
.ia-adm-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.ia-adm-kpi{padding:12px 14px;text-align:center}
.ia-adm-kpi-n{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.ia-adm-kpi-l{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}
.ia-adm-chips{display:flex;gap:6px;flex-wrap:wrap}
.ia-adm-tbl{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.ia-adm-tbl th{text-align:left;color:var(--text-muted);font-weight:600;padding:7px 9px;border-bottom:1px solid var(--border);white-space:nowrap}
.ia-adm-tbl td{padding:7px 9px;border-bottom:1px solid var(--border);vertical-align:top}
.ia-adm-tbl .nowrap{white-space:nowrap;font-variant-numeric:tabular-nums}
.ia-adm-row{cursor:pointer}
.ia-adm-row:hover td{background:var(--brand-100)!important}
.ia-adm-row.on td{background:var(--brand-50)}
.ia-adm-q{max-width:420px}
/* Ferramentas: pílulas em fluxo inline (NÃO flex no td — flex encolhe a célula e quebra o realce da linha) */
.ia-adm-fer{line-height:1.9}
.ia-adm-fer .pill{margin:0 4px 2px 0}
.ia-adm-det td{background:var(--surface-2);font-size:var(--fs-sm)}
.ia-adm-det-r{margin-top:6px;color:var(--text-muted)}
@media(max-width:700px){.ia-adm-kpis{grid-template-columns:repeat(2,1fr)}}
/* símbolo da IA (orbe) — marca fixa do assistente (item "Perguntar à IA", avatar da resposta, rodapé) */
.ai-orb{flex:none;position:relative;width:30px;height:30px;border-radius:9px;
  background:conic-gradient(from 140deg,#2f6fed,#7c5cff,#36c6dc,#2f6fed);
  box-shadow:0 2px 8px rgba(47,111,237,.35),inset 0 0 6px rgba(255,255,255,.25)}
.ai-orb::before{content:"";position:absolute;inset:5px;border-radius:6px;
  background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.9),rgba(255,255,255,0) 60%)}
.ai-orb .ai-spk{position:absolute;top:-3px;right:-3px;width:10px;height:10px;background:#fff;border-radius:50%;
  clip-path:polygon(50% 0,60% 40%,100% 50%,60% 60%,50% 100%,40% 60%,0 50%,40% 40%);filter:drop-shadow(0 0 2px rgba(124,92,255,.8))}
.ai-orb.xs{width:16px;height:16px;border-radius:5px;box-shadow:0 1px 4px rgba(47,111,237,.3)}
.ai-orb.xs::before{inset:3px;border-radius:3px}.ai-orb.xs .ai-spk{width:6px;height:6px;top:-2px;right:-2px}
/* estado "pesquisando": anel de pontos com onda girando (circle-wave) + texto em shimmer + frase rotativa */
.ai-wave{flex:none;position:relative;width:32px;height:32px}
.ai-wave i{position:absolute;width:5px;height:5px;border-radius:50%;transform:scale(.35);animation:ai-wave 1.2s ease-in-out infinite}
@keyframes ai-wave{0%,40%,100%{transform:scale(.35);opacity:.4}20%{transform:scale(1.3);opacity:1}}
.ai-think-txt{font-size:var(--fs-sm);font-weight:600;background-size:220% 100%;-webkit-background-clip:text;background-clip:text;
  color:transparent;animation:ai-shimmer 1.8s linear infinite;
  background-image:linear-gradient(90deg,var(--text-subtle) 0,var(--text-subtle) 35%,var(--brand-500) 50%,var(--text-subtle) 65%,var(--text-subtle) 100%)}
@keyframes ai-shimmer{to{background-position:-220% 0}}
.ai-think-sub{font-size:var(--fs-xs);color:var(--text-subtle);margin-top:3px;min-height:15px;transition:opacity .18s}
@media (prefers-reduced-motion:reduce){
  .ai-wave i{animation:none;transform:scale(.95);opacity:.85}
  .ai-think-txt{animation:none;-webkit-text-fill-color:var(--text-muted)}
  .ai-think-sub{transition:none}
}
/* conversa multi-turno: turno do usuário (balão à direita) + caixa de resposta/refino */
.ia-thread{display:flex;flex-direction:column}
.ia-q{font-size:var(--fs-sm);color:var(--text);background:var(--brand-50);border:1px solid var(--brand-100);
  border-radius:var(--r-md);padding:6px 11px;margin:8px 10px 4px;align-self:flex-end;max-width:88%}
.ia-q-rot{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-600);margin-bottom:1px}
.ia-reply{display:flex;gap:8px;padding:8px 12px 6px;border-top:1px solid var(--border)}
.ia-reply input{flex:1;height:34px;border:1px solid var(--border);border-radius:var(--r-md);padding:0 11px;background:var(--surface);color:var(--text);font-size:var(--fs-sm)}
.ia-reply input:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}
/* gráfico de série (resposta da IA): barras empilhadas liquidado + aberto */
.pal-grafico{margin-top:10px}
.pal-grafico .g-leg{display:flex;gap:14px;align-items:center;font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:5px}
.pal-grafico .g-leg i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px;vertical-align:-1px}
.pal-grafico .g-leg .g-max{margin-left:auto;color:var(--text-subtle)}
.pal-grafico text{fill:var(--text-subtle);font-size:11px}
.pal-grafico-vazio{margin-top:8px;font-size:var(--fs-xs);color:var(--text-subtle)}
.pal-grafico .g-bar{cursor:default}
.pal-grafico .g-bar:hover rect[rx]{opacity:.82}
/* tooltip custom do gráfico — segue o cursor */
.pal-graf-tip{position:fixed;z-index:12000;pointer-events:none;min-width:160px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-4);
  padding:7px 10px;font-size:var(--fs-xs);color:var(--text)}
.pal-graf-tip .gt-rot{font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}
.pal-graf-tip .gt-row{display:flex;align-items:center;gap:6px;line-height:1.7;white-space:nowrap}
.pal-graf-tip .gt-row b{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:600}
.pal-graf-tip .gt-dot{width:8px;height:8px;border-radius:2px;flex:none}
.pal-graf-tip .gt-dot.ab{background:var(--warning)}
.pal-graf-tip .gt-dot.liq{background:var(--success)}
.pal-graf-tip .gt-tot{border-top:1px solid var(--border);margin-top:3px;padding-top:4px}
/* dropdown "Ver detalhamento" — botão + tabela de títulos/notas */
.pal-det-btn{margin-top:8px;background:none;border:0;padding:2px 0;color:var(--brand-600);font-size:var(--fs-xs);font-weight:600;cursor:pointer}
.pal-det-btn:hover{text-decoration:underline}
.pal-det{margin-top:6px;max-height:240px;overflow:auto;border:1px solid var(--border);border-radius:var(--r-md)}
.pal-det-tbl{width:100%;border-collapse:collapse;font-size:var(--fs-xs)}
.pal-det-tbl th{position:sticky;top:0;background:var(--surface-2);text-align:left;color:var(--text-muted);font-weight:600;padding:5px 8px;white-space:nowrap}
.pal-det-tbl td{padding:5px 8px;border-top:1px solid var(--border);white-space:nowrap}
.pal-det-tbl td.nm{max-width:180px;overflow:hidden;text-overflow:ellipsis}
.pal-det-tbl td.vl{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.pal-det-row{cursor:pointer}
.pal-det-row:hover td{background:var(--brand-50)}
/* tabela de MÚTUOS (inline, estilo Excel) — resumo credora→devedora com linha de total */
.pal-mutuos{margin-top:8px;border:1px solid var(--border);border-radius:var(--r-md);overflow:auto;max-height:min(50vh,420px)}
.pal-mutuos-h{padding:7px 9px;font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border)}
.pal-mutuos-tbl tbody tr:hover td{background:var(--brand-50)}
.pal-mutuos-tbl tfoot td{border-top:2px solid var(--border);background:var(--surface-2);font-weight:700;font-variant-numeric:tabular-nums}
.pal-foot{display:flex;gap:16px;padding:8px 14px;border-top:1px solid var(--border);font-size:10.5px;color:var(--text-subtle);flex:none}
.pal-foot span{display:inline-flex;align-items:center;gap:4px}
@media (max-width:767px){
  .busca-btn{min-width:0;width:40px;height:40px;padding:0;justify-content:center;flex:none}
  .busca-btn .busca-txt,.busca-btn kbd{display:none}
  .pal-ov{padding:10px 8px}
  .pal-box{max-height:calc(100dvh - 20px - var(--bnav-h))}
  .pal-in input{font-size:16px}   /* evita zoom automático do iOS */
  .pal-x{padding:8px;min-width:40px;min-height:40px}   /* alvo de toque */
  .pal-x kbd{display:none}                              /* sem tecla esc no celular */
  .pal-x .pal-x-ico{display:block}                      /* mostra o X clicável */
  .pal-it{min-height:48px}
  .pal-foot{display:none}
}

/* Contas Movimento — alternador de modo (Conciliação | Saldos diários) */
.mv-modo{display:flex;gap:6px;margin:0 0 10px}
.mv-modo .btn{flex:0 0 auto}

/* Contas Movimento — view "Saldos diários" (linha do tempo do saldo bancário) */
.mv-saldos-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.mv-saldos-tbl{width:100%}
.mv-saldos-tbl thead th{position:sticky;top:0;background:var(--surface);z-index:1;
  font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;
  padding:6px 8px;border-bottom:1px solid var(--border)}
.mv-saldos-tbl td{padding:7px 8px;border-bottom:1px solid var(--border-subtle,var(--border))}
.mv-srow{transition:background var(--t-fast) var(--ease)}
.mv-srow:hover td{background:var(--brand-100)!important}
@media (max-width:767px){.mv-saldos-head h3{font-size:15px}}

/* Contas Movimento — abas mobile (Sistema | Extrato); invisíveis no desktop */
.mv-tabs{display:none}
@media (max-width:767px){
  .mv-tabs{display:flex;gap:6px;margin:0 0 10px;position:sticky;top:54px;z-index:25;
    background:var(--surface-sunken);padding:4px 0}
  .mv-tabs .btn{flex:1;min-height:46px;flex-direction:column;gap:1px;line-height:1.2}
  .mv-tabs .btn small{font-size:10px;font-weight:500;opacity:.85}
  .mv-tabs .btn.cob{flex:0 0 auto;min-width:52px}
  /* só o painel da aba ativa aparece; calendário/mapa vivem no sheet "Cobertura" */
  .mv-grid[data-aba="sis"] .mv-pane-ex{display:none}
  .mv-grid[data-aba="ex"] .mv-pane-sis{display:none}
  .mv-grid .mv-right{display:none}
  .mv-pane{min-width:0!important;flex:1 1 100%!important;padding:10px}
  .mv-scroll{max-height:none;border:none}
  /* linhas viram alvos de toque */
  .mv-tbl td{padding:9px 8px!important;font-size:13px}
  .mv-acoes .btn.sm{min-height:38px;padding:7px 12px}
  /* barra de conciliação: empilha acima da bottom-nav (posição já tratada no bloco do shell) */
  .mv-bar{flex-wrap:wrap;gap:6px 12px;padding:10px 12px}
  .mv-bar-side{flex:1 1 40%}
  .mv-bar-side b{font-size:15px}
  .mv-bar-mid{flex:1 1 100%;justify-content:space-between;order:3}
  .mv-bar .btn.sm{min-height:42px}
  .content.mv-page #mv-painel{padding-bottom:170px}
  /* toolbar do movimento empilha */
  .mv-toolbar{flex-direction:column;align-items:stretch}
  .mv-toolbar .ft,.mv-toolbar select{width:100%;min-width:0}
  .mv-toolbar .row{flex-wrap:wrap}
  /* sheet de cobertura: calendário e mapa lado a lado viram pilha */
  .cobertura-sheet .mv-cal,.cobertura-sheet .mv-mapa{margin-bottom:12px}
  .cobertura-sheet .mv-mapa-list{max-height:40dvh;overflow:auto}
}

/* cards do CAP mobile (fora da media p/ o desktop só escondê-los) */
.cap-cards{display:none;flex-direction:column;gap:var(--sp-2)}
@media (max-width:767px){ .tela-titulos .cap-cards{display:flex} }
.cap-card{
  display:flex;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;
  animation:card-in var(--t-slow) var(--ease);
}
@keyframes card-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cap-card.liq-flash{animation:row-flash 1.2s var(--ease)}
.cap-card .cc-sel{display:none;align-items:center;padding:0 4px 0 12px}
.tela-titulos.selecting .cap-card .cc-sel{display:flex}
.cap-card .cc-main{flex:1;min-width:0;padding:12px 14px;cursor:pointer}
.cap-card .cc-top{display:flex;justify-content:space-between;align-items:baseline;gap:var(--sp-2);min-width:0}
.cap-card .cc-forn{flex:1;min-width:0;font-weight:700;font-size:var(--fs-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cap-card .cc-val{font-size:var(--fs-lg);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.2px;white-space:nowrap}
.cap-card .cc-venc{display:block;font-size:var(--fs-xs);color:var(--text-muted);margin-top:3px}
.cap-card .cc-venc.due{color:var(--danger-fg);font-weight:600}
.cap-card .cc-foot{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);margin-top:8px;min-width:0}
.cap-card .cc-emp{flex:1;min-width:0;font-size:var(--fs-xs);color:var(--text-subtle);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cap-card .cc-act{display:flex;align-items:center;padding-right:12px}
.cap-card .cc-act .btn{min-height:44px;min-width:76px}
.tela-titulos.selecting .cap-card .cc-act{display:none}
.cap-sentinel{height:1px}
.cap-more-info{text-align:center;font-size:var(--fs-xs);color:var(--text-subtle);padding:var(--sp-3)}

/* cards genéricos de CADASTRO (mobile): tabela some, lista de cards entra */
.cad-cards{display:none;flex-direction:column;gap:var(--sp-2)}
.cad-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-1);padding:12px 14px;animation:card-in var(--t-slow) var(--ease);
}
.cad-card .cd-t{font-weight:700;font-size:var(--fs-base);overflow-wrap:anywhere}
.cad-card .cd-sub{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px;overflow-wrap:anywhere}
.cad-card .cd-act{display:flex;gap:var(--sp-2);margin-top:10px}
.cad-card .cd-act .btn{flex:1;min-height:42px}

/* DRE — visão mobile "um mês por vez": chips de período + lista vertical.
   Componentes ficam ocultos no desktop; a media query (max-width:767px) os liga. */
.dre-mobbar,.dre-mob{display:none}
.drm-chips{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px 0;flex:1;scrollbar-width:none}
.drm-chips::-webkit-scrollbar{display:none}
.drm-chip{flex:0 0 auto;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);
  border-radius:var(--r-full);padding:6px 12px;font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;
  font-variant-numeric:tabular-nums}
.drm-chip.on{background:var(--brand-500);color:var(--text-on-brand);border-color:transparent}
.drm-chip.drm-tot{font-weight:700}
.drm-cmp{flex:0 0 auto;border:1px solid var(--border);background:var(--surface);color:var(--text);
  border-radius:var(--r-md);padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;min-height:38px}
.drm-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
  padding:9px 4px;border-bottom:1px solid var(--border)}
.drm-row.drm-n1{font-weight:700;background:var(--surface-2)}
.drm-row.drm-sub{font-weight:600}
.drm-row.drm-ana{font-size:11.5px;color:var(--text-muted);border-bottom:none;padding:2px 4px 2px 34px}
.drm-nm{display:flex;align-items:flex-start;gap:4px;min-width:0;flex:1}
.drm-txt{overflow-wrap:anywhere}
.drm-caret{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:20px;color:var(--muted);cursor:pointer}
.drm-caret-x{cursor:default}
.drm-tag{font-size:9px;border:1px solid var(--border);border-radius:4px;padding:0 4px;margin-left:6px}
.drm-v{flex:0 0 auto;text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;padding-top:1px}
.dre-mob .drm-row:active{background:var(--brand-100)}

/* Fechamento de Caixa — lista vertical do calendário (só no mobile; oculta no desktop) */
.cx-callist{display:none}
.cxl-row{display:flex;align-items:center;gap:12px;padding:11px 12px;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;margin-bottom:8px;cursor:pointer}
.cxl-row:active{background:var(--brand-100)}
.cxl-d{flex:0 0 auto;width:38px;text-align:center;line-height:1.05}
.cxl-d b{display:block;font-size:18px}
.cxl-d span{font-size:10px;color:var(--muted);text-transform:uppercase}
.cxl-mid{flex:1;min-width:0}
.cxl-tot{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums}
.cxl-sub{font-size:11.5px;color:var(--muted)}
.cxl-st{flex:0 0 auto;font-size:11px;font-weight:600;white-space:nowrap}

@media (max-width:767px){
  .cad-tbl{display:none}
  .cad-cards{display:flex}

  /* toolbars marcadas como .mob-filtros saem do fluxo (vão p/ o sheet via UI.sheetDeFiltros) */
  .mob-filtros{display:none!important}
  .filtros-sheet-body .mob-filtros{display:flex!important;flex-direction:column;align-items:stretch;
    border:none;box-shadow:none;padding:0;margin:0;background:transparent}
  .filtros-sheet-body .mob-filtros .ft,.filtros-sheet-body .mob-filtros select,
  .filtros-sheet-body .mob-filtros .dp,.filtros-sheet-body .mob-filtros .rp{width:100%;min-width:0}
  .filtros-sheet-body .mob-filtros .btn{min-height:44px}

  /* Conciliação de Cartões: calendário ocupa a largura; detalhe do dia abre em sheet
     (!important: vence o style inline herdado do layout desktop) */
  .ct-cal-col{flex:1 1 100%!important;max-width:none!important}
  .ct-dia-col{display:none}

  /* Fechamento de Caixa: os pop-ups legados (lojas do dia / Ver Caixa / depósitos / cartões)
     viram bottom sheets; o modo split desktop não se aplica no celular */
  .cx-ov{align-items:flex-end!important;padding:0!important}
  .cx-ov>div{
    width:100%!important;max-width:none!important;border-radius:var(--r-xl) var(--r-xl) 0 0!important;
    max-height:92dvh;overflow:auto;-webkit-overflow-scrolling:touch;
    padding-bottom:env(safe-area-inset-bottom,0px);transform:none!important;
  }
  .cx-split-left>div,.cx-split-right>div{max-width:none!important}
  .cx-ov table{font-size:12px}

  /* Conferência: as duas colunas (Vendas do PDV | modalidade+diferenças) empilham — vence o g2 global (1fr 1fr) */
  .cx-ov .grid.g2{grid-template-columns:1fr!important}
  .cx-ov .cx-pdv td{white-space:normal;word-break:break-word}

  /* Ver Caixa (filial e Todas): cabeçalho fixo ao rolar, input do Total Real estreito, nome da linha quebra
     em vez de empurrar a tabela pra fora da tela */
  .cx-ov .vc-compact thead th{position:sticky;top:0;background:var(--surface);z-index:2}
  .cx-ov .vc-compact input{width:84px!important;min-height:36px}
  .cx-ov .vc-compact td:first-child,.cx-ov .vc-compact th:first-child{white-space:normal;word-break:break-word}
  .cx-ov .vc-compact td,.cx-ov .vc-compact th{padding-left:6px;padding-right:6px}

  /* Matriz de completude (filial × dia): 1ª coluna (filial) fixa ao rolar na horizontal */
  .cmp-tab .cmp-fil{position:sticky;left:0;z-index:1;background:var(--card);box-shadow:1px 0 0 var(--gray-100)}

  /* Calendário de fechamento: troca a grade 7×7 pela lista vertical de dias com movimento */
  .cx-calgrid{display:none!important}
  .cx-callist{display:block}

  /* tabelas largas de relatório: rolagem horizontal contida + 1ª coluna fixa */
  .dre-scroll{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
  .dre-scroll table th:first-child,.dre-scroll table td:first-child{
    position:sticky;left:0;background:var(--surface);z-index:2;max-width:62vw;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-shadow:1px 0 0 var(--border);
  }
  .dre-scroll table td,.dre-scroll table th{padding:8px 10px}

  /* DRE no Relatório: lista "um mês por vez" é o padrão; a matriz vira o modo "Comparar" */
  .dre-mobbar{display:flex;gap:8px;align-items:center;margin-bottom:8px;
    position:sticky;top:0;z-index:3;background:var(--surface);padding:6px 0}
  .dre-mob{display:block}
  #dre-rep .dre-scroll{display:none}
  #dre-rep.dre-cmp .dre-mob{display:none}
  #dre-rep.dre-cmp .drm-chips{display:none}
  #dre-rep.dre-cmp .dre-scroll{display:block}
}

/* ------------------- 14. PATCHES DARK p/ telas legadas ---------------------- */
/* Muitos modais antigos pintam background:#fff inline. No dark, força a superfície do tema. */
[data-theme="dark"] [style*="background:#fff"],
[data-theme="dark"] [style*="background: #fff"],
[data-theme="dark"] [style*="background:#ffffff"]{background:var(--surface)!important}
[data-theme="dark"] [style*="background:#f6f8fb"],
[data-theme="dark"] [style*="background:#f1f3f7"],
[data-theme="dark"] [style*="background:#fafbfd"]{background:var(--surface-2)!important}
[data-theme="dark"] [style*="background:#eef4ff"],
[data-theme="dark"] [style*="background:#e8f0ff"],
[data-theme="dark"] [style*="background:#eaf1ff"],
[data-theme="dark"] [style*="background:#f0f6ff"]{background:var(--brand-50)!important}
[data-theme="dark"] [style*="color:#1f2d3d"]{color:var(--text)!important}
[data-theme="dark"] .preview-flag{background:var(--info-bg);border-color:var(--brand-700);color:var(--info-fg)}
[data-theme="dark"] .restrict{background:var(--warning-bg);border-color:var(--warning-fg);color:var(--warning-fg)}
[data-theme="dark"] th.th-sort:hover{background:var(--gray-200)}
[data-theme="dark"] .rp-presets button:hover,[data-theme="dark"] .rp-day:hover,
[data-theme="dark"] .rp-cal-nav:hover,[data-theme="dark"] .rp-month:hover,
[data-theme="dark"] .ms-opt:hover,[data-theme="dark"] .pp-item.active,
[data-theme="dark"] .pp-item:hover,[data-theme="dark"] .mv-row:hover,
[data-theme="dark"] .mv-mapa-item:hover{background:var(--brand-50)}
[data-theme="dark"] .rp-day.in-range{background:var(--brand-100)}
[data-theme="dark"] .es .es-grp-head,[data-theme="dark"] .es .es-todas{background:var(--surface-2)}
[data-theme="dark"] .ring{background:conic-gradient(var(--blue) calc(var(--p)*1%),var(--gray-200) 0)}
[data-theme="dark"] .ring .in{background:var(--surface)}
[data-theme="dark"] .login-card{background:var(--surface)}
[data-theme="dark"] .mv-resumo{background:var(--surface-2)}
[data-theme="dark"] .mv-cal-cell{background:var(--gray-100);color:var(--text)}
[data-theme="dark"] .mv-cal-cell.sem{background:var(--gray-100);color:var(--text-subtle)}
[data-theme="dark"] .dre .ln.g{background:var(--surface-2)}

/* movimento reduzido (preferência do usuário do navegador) */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ============================================================================
   DASHBOARD (bento) — layout executivo inspirado em B2B analytics + F360.
   Tokens do theme garantem dark mode automático. Cada .dcard pode ser atalho.
   ============================================================================ */
.dash-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:13px;align-items:stretch}
.dash-grid>*{min-width:0}
.c12{grid-column:span 12}.c8{grid-column:span 8}.c7{grid-column:span 7}.c6{grid-column:span 6}
.c5{grid-column:span 5}.c4{grid-column:span 4}.c3{grid-column:span 3}
@media(max-width:1180px){.c8,.c7{grid-column:span 12}.c6,.c5{grid-column:span 12}}
@media(max-width:1180px){.c4{grid-column:span 6}.c3{grid-column:span 6}}
@media(max-width:680px){.dash-grid{gap:12px}.c4,.c3{grid-column:span 12}}

.dcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  box-shadow:var(--sh-1);padding:13px 15px 11px;display:flex;flex-direction:column}
.dcard.click{cursor:pointer;transition:box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}
.dcard.click:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.dcard.accent{background:linear-gradient(135deg,var(--brand-700),var(--brand-900));border-color:transparent;color:#fff}
.dcard-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.dcard-h .t{font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}
.dcard.accent .dcard-h .t{color:#fff}
.dcard-h .i{color:var(--text-subtle);font-size:11px;border:1px solid var(--border);border-radius:50%;
  width:15px;height:15px;display:inline-grid;place-items:center;cursor:help}
.dcard-h .act{font-size:12px;color:var(--brand-600);font-weight:600;cursor:pointer;
  border:1px solid var(--border);background:var(--surface);border-radius:var(--r-md);padding:4px 10px}
.dcard-h .act:hover{background:var(--surface-2);border-color:var(--border-strong)}

.dhero-val{font-size:27px;font-weight:600;letter-spacing:-.6px;line-height:1.05;font-variant-numeric:tabular-nums;color:var(--text)}
.dhero-sub{font-size:12.5px;color:var(--text-muted);margin-top:5px}
.dhero-sub b{color:var(--text)}

/* pill de variação (▲ verde / ▼ vermelho) */
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:700;
  padding:2px 8px;border-radius:var(--r-full);line-height:1.5;white-space:nowrap}
.delta.up{background:var(--success-bg);color:var(--success-fg)}
.delta.down{background:var(--danger-bg);color:var(--danger-fg)}
.delta.flat{background:var(--gray-100);color:var(--text-muted)}

/* barra de progresso (Hoje: recebido/a receber) */
.prog{height:9px;border-radius:var(--r-full);background:var(--surface-sunken);overflow:hidden}
.prog>i{display:block;height:100%;border-radius:var(--r-full)}

/* donut grande (conciliação) */
.donut{position:relative;width:84px;height:84px;border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--dc,var(--brand-500)) calc(var(--p,0)*1%),var(--gray-200) 0)}
.donut .in{position:absolute;inset:11px;border-radius:50%;background:var(--surface);
  display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .in b{font-size:16px;font-weight:800;color:var(--text);line-height:1}
.donut .in span{font-size:10px;color:var(--text-muted);margin-top:2px}

/* mini-stat (rodapé do herói) */
.dmini{display:flex;gap:10px;align-items:center}
.dmini .ic{width:31px;height:31px;border-radius:var(--r-md);background:var(--brand-50);color:var(--brand-600);
  display:grid;place-items:center;font-size:14px;flex:0 0 auto}
.dmini .v{font-size:14px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.dmini .l{font-size:11px;color:var(--text-muted);margin-top:1px}

/* controle segmentado (tabs do gráfico) */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:3px}
.seg button{border:0;background:transparent;padding:5px 13px;border-radius:var(--r-full);
  font-size:12.5px;color:var(--text-muted);cursor:pointer;font-weight:600}
.seg button.on{background:var(--surface);color:var(--text);box-shadow:var(--sh-1)}
/* botão "Projeção" do Painel de vendas: estado ligado (tom da marca) */
.btn.dash-proj-btn.on{background:var(--brand-50);border-color:var(--brand-500);color:var(--brand-600);box-shadow:none}
[data-theme="dark"] .btn.dash-proj-btn.on{color:var(--info-fg)}

/* mini barra vertical (Notas fiscais) */
.vbar{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.vbar .col{width:100%;max-width:42px;display:flex;align-items:flex-end;justify-content:center;height:38px}
.vbar .col>i{width:60%;background:var(--brand-500);border-radius:4px 4px 0 0;min-height:3px}
.vbar .n{font-size:14px;font-weight:700;color:var(--text)}
.vbar .l{font-size:10.5px;color:var(--text-muted)}

/* item de lista (maiores a pagar / saldo por conta) */
.drow{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:8px 2px;border-bottom:1px solid var(--line);font-size:13px;cursor:pointer}
.drow:last-child{border-bottom:0}
.drow .nm{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drow .vl{font-variant-numeric:tabular-nums;font-weight:700;color:var(--text);flex:0 0 auto}
.drow-bar{height:6px;border-radius:var(--r-full);background:var(--surface-sunken);margin-top:5px}
.drow-bar>i{display:block;height:6px;border-radius:var(--r-full);background:var(--brand-500)}

/* ---- Tooltip dinâmico dos gráficos do dashboard (segue o mouse, com crosshair no SVG) ---- */
.dash-tip{position:fixed;z-index:1000;pointer-events:none;background:var(--surface);border:1px solid var(--border-strong);
  box-shadow:var(--sh-3);border-radius:var(--r-md);padding:9px 11px;font-size:12px;min-width:170px;max-width:300px;
  opacity:0;transform:translateY(3px);transition:opacity .08s,transform .08s}
.dash-tip.on{opacity:1;transform:none}
.dash-tip .tt-h{font-weight:700;font-size:12.5px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;gap:14px;align-items:baseline}
.dash-tip .tt-h .tot{font-variant-numeric:tabular-nums;color:var(--text);margin-left:auto}
.dash-tip .tt-r{display:flex;justify-content:space-between;gap:14px;line-height:1.7}
.dash-tip .tt-r .k{color:var(--text-muted);display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-tip .tt-r .v{font-variant-numeric:tabular-nums;font-weight:600;flex:0 0 auto;color:var(--text)}
.dash-tip .tt-dot{width:8px;height:8px;border-radius:2px;flex:0 0 auto}
.dash-tip .tt-mut{color:var(--text-subtle);font-size:11px;margin-top:5px}
.dash-tip .tt-sep{border-top:1px solid var(--line);margin:5px 0 4px}
.dash-tip .tt-hint{color:var(--text-subtle);font-size:10px;margin-top:6px;padding-top:5px;border-top:1px dashed var(--line);text-align:center;opacity:.8}
/* tooltip fixado por clique: interativo (rolagem + botões) e sem seguir o mouse */
.dash-tip.pinned{pointer-events:auto;cursor:default;max-height:min(70vh,440px);overflow-y:auto}
.dash-tip .tt-close{flex:0 0 auto;margin-left:6px;border:0;background:transparent;color:var(--text-subtle);
  cursor:pointer;font-size:12px;line-height:1;padding:2px 4px;border-radius:var(--r-sm);transition:background .12s,color .12s}
.dash-tip .tt-close:hover{background:var(--brand-100);color:var(--text)}
.dash-tip .tt-more{display:block;width:100%;text-align:left;margin-top:6px;border:0;background:transparent;
  color:var(--brand-500);cursor:pointer;font-size:11px;font-weight:600;padding:4px 2px;border-radius:var(--r-sm);transition:background .12s}
.dash-tip .tt-more:hover{background:var(--brand-100)}
#dash-hero-chart svg,#dash-proj-chart svg,#dash-fluxo-chart svg{cursor:crosshair}

/* Trilha de auditoria (Histórico do título — CAP/CAR) */
.aud-tl{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow:auto}
.aud-ev{border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:8px;padding:8px 10px;background:var(--surface-2)}
.aud-cab{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.aud-acao{font-weight:600;color:var(--ink)}
.aud-quem{font-weight:600;color:var(--blue)}
.aud-quando{margin-left:auto;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.aud-campo{font-size:13px;margin-top:4px;color:var(--ink)}
.aud-de{color:var(--muted);text-decoration:line-through}
.aud-para{color:var(--green);font-weight:600}

/* ============================================================================
   REFINO (Claude Design) — componentes sobre as classes REAIS do app.
   Backup: theme.css.bak.refino-20260613-225411. Para reverter, apague esta seção.
   ========================================================================== */

/* ---- Pílulas de status (Fechamento de Caixa e telas que reusem) — espelham .status, theme-aware ---- */
.pill.ok{background:var(--success-bg);color:var(--success-fg)}
.pill.warn{background:var(--warning-bg);color:var(--warning-fg)}
.pill.bad{background:var(--danger-bg);color:var(--danger-fg)}
.pill.info{background:var(--info-bg);color:var(--info-fg)}

/* ---- Sidebar: item ativo navy-gradiente + barra de destaque (era sólido + barra vermelha) ---- */
.side nav{padding:0 10px}
.side nav a{
  border-radius:var(--r-md);border-left:0;padding:9px 12px;gap:11px;margin:1px 0;
  color:rgba(255,255,255,.76);font-weight:500;position:relative;
  transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease);
}
.side nav a:hover{background:rgba(255,255,255,.07);color:#fff;border-left:0}
.side nav a.active{
  background:linear-gradient(90deg,rgba(43,92,184,.38),rgba(43,92,184,.15));
  color:#fff;font-weight:600;border-left:0;
  box-shadow:inset 0 0 0 1px rgba(90,131,201,.34);
}
.side nav a.active::before{
  content:"";position:absolute;left:-10px;top:7px;bottom:7px;width:3px;
  background:#5a83c9;border-radius:0 3px 3px 0;
}
.side .user .role{background:rgba(90,131,201,.20);color:#bcd0f0}

/* ---- Status do Conector no menu lateral: bolinha (verde=ok / vermelho=erro / âmbar=ocioso / off). ---- */
.side nav a .conector-dot{
  position:absolute;top:50%;right:10px;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;background:var(--text-muted);
  box-shadow:0 0 0 2px rgba(0,0,0,.12);
}
.side nav a .conector-dot.st-ok{background:var(--success);box-shadow:0 0 0 3px color-mix(in srgb,var(--success) 28%,transparent)}
.side nav a .conector-dot.st-erro{background:var(--danger);box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 30%,transparent)}
.side nav a .conector-dot.st-idle{background:var(--warning)}
.side nav a .conector-dot.st-off{background:var(--text-muted);opacity:.45;box-shadow:none}

/* ---- Donut da conciliação: SVG com pontas arredondadas (qualidade Claude Design) ---- */
.donut{position:relative;width:110px;height:110px;flex:0 0 auto;background:none;border-radius:0}
.donut svg{display:block;width:110px;height:110px}
.donut .donut-trk{stroke:var(--gray-200)}
.donut .in{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none}
.donut .in b{font-size:23px;font-weight:700;letter-spacing:-.4px;color:var(--text);line-height:1}
.donut .in span{font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-subtle);margin-top:3px}

/* ---- Ticker de mercado: valor maior, mais ar, hover arredondado ---- */
.mkt-i{padding:4px 13px;border-radius:var(--r-md);gap:2px}
.mkt-k{font-size:9px;letter-spacing:.07em}
.mkt-v{font-size:14px;font-weight:600;letter-spacing:-.01em}
.mkt-v .mkt-pct{font-size:10.5px;font-weight:600}
.mkt-sep{margin:7px 0}

/* ---- KPIs e mini-valores: peso 600 (mais elegante, alinhado ao herói) ---- */
.kpi .val{font-weight:600}
.dmini .v{font-weight:600}

/* ---- Tabelas: cabeçalho em maiúsculas espaçadas (densidade das linhas intacta) ---- */
.cap-table th{text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--text-muted)}

/* ---- Cards (.dcard): mais respiro no cabeçalho + título e botão de ação refinados ---- */
.dcard{padding:15px 17px 13px}
.dcard-h{margin-bottom:14px}
.dcard-h .t{font-size:14.5px;letter-spacing:-.005em}
.dcard-h .act{color:var(--brand-600);border-color:var(--border-strong);border-radius:var(--r-md);font-weight:600}
.dcard-h .act:hover{background:var(--surface-2);border-color:var(--brand-500);color:var(--brand-600)}

/* ---- Campos de filtro (.ft) e de formulário (.field): raio 10px, borda firme, rótulo 600 ---- */
.ft label,.field label{font-weight:600}
.ft input,.ft select{border-radius:var(--r-md);border-color:var(--border-strong);padding:9px 11px}
.field input{border-radius:var(--r-md);border-color:var(--border-strong)}

/* ---- Topbar: busca, breadcrumb e usuário (padrão Claude Design) ---- */
.busca-btn{
  display:inline-flex;align-items:center;gap:8px;min-width:210px;
  background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);
  padding:8px 11px;color:var(--text-subtle);font-size:13px;cursor:pointer;
  transition:border-color var(--t-fast) var(--ease),background var(--t-fast) var(--ease);
}
.busca-btn:hover{border-color:var(--border-strong);background:var(--surface)}
.busca-txt{color:var(--text-muted)}
.busca-btn kbd{
  font-family:var(--font-sans);font-size:10.5px;font-weight:600;color:var(--text-muted);
  background:var(--surface);border:1px solid var(--border-strong);border-radius:5px;
  padding:2px 6px;margin-left:auto;line-height:1.4;
}
.top .crumb{font-size:11px;color:var(--text-muted);font-weight:500}
.top .crumb b{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--text)}
.top .right .nm{font-weight:500}
.top .right .nm small{font-size:10px;font-weight:600;letter-spacing:.06em}

/* ---- Sidebar: ícones de linha (SVG) com micro-animação no hover/ativo (Claude Design) ----
   Reaproveita o <span class="ic"> do MENU; o SVG herda a cor via currentColor.
   Gatilho real do app: .side nav a:hover  OU  .side nav a.active                  */
.side nav a .ic{display:flex;align-items:center;justify-content:center;line-height:0}
.side nav a .ic svg{
  width:19px;height:19px;flex:none;overflow:visible;opacity:.85;
  transition:transform .4s var(--ease-spring),opacity .2s ease;
}
.side nav a .ic svg *{transform-box:fill-box;transform-origin:center}
.side nav a:hover .ic svg,
.side nav a.active .ic svg{opacity:1}
/* transição compartilhada das partes animáveis */
.side nav a .ic svg [class]{transition:transform .42s var(--ease-spring),stroke-dashoffset .5s var(--ease-soft)}

/* 1 · Dashboard — tiles se espalham */
:is(.side nav a:hover,.side nav a.active) .ic-dash .t1{transform:translate(-1.1px,-1.1px)}
:is(.side nav a:hover,.side nav a.active) .ic-dash .t2{transform:translate(1.1px,-1.1px);transition-delay:.04s}
:is(.side nav a:hover,.side nav a.active) .ic-dash .t3{transform:translate(1.1px,1.1px);transition-delay:.08s}
:is(.side nav a:hover,.side nav a.active) .ic-dash .t4{transform:translate(-1.1px,1.1px);transition-delay:.12s}

/* 2 · Cadastros — a pasta entreabre */
.ic-folder .lid{transform-origin:12px 11px}
:is(.side nav a:hover,.side nav a.active) .ic-folder .lid{transform:translateY(1.6px) scaleY(1.08)}

/* 3 · Contas a Pagar — seta sai p/ cima/direita */
:is(.side nav a:hover,.side nav a.active) .ic-pay .arr{transform:translate(1.6px,-1.6px)}

/* 4 · Contas a Receber — seta cai na bandeja */
:is(.side nav a:hover,.side nav a.active) .ic-recv .arr{transform:translateY(1.8px)}

/* 5 · Fechamento de Caixa — gaveta desliza */
:is(.side nav a:hover,.side nav a.active) .ic-cash .drawer{transform:translateY(1.7px)}

/* 6 · Conciliação de Cartões — check se desenha */
.ic-card .chk{stroke-dasharray:13;stroke-dashoffset:13}
:is(.side nav a:hover,.side nav a.active) .ic-card .chk{stroke-dashoffset:0}

/* 7 · Contas Movimento — setas se cruzam */
:is(.side nav a:hover,.side nav a.active) .ic-move .a1{transform:translateX(1.7px)}
:is(.side nav a:hover,.side nav a.active) .ic-move .a2{transform:translateX(-1.7px)}

/* 8 · Nota Fiscal — linhas avançam em sequência */
.ic-doc .ln{transform-origin:left center}
:is(.side nav a:hover,.side nav a.active) .ic-doc .ln1{transform:translateX(1.4px)}
:is(.side nav a:hover,.side nav a.active) .ic-doc .ln2{transform:translateX(1.4px);transition-delay:.07s}
:is(.side nav a:hover,.side nav a.active) .ic-doc .ln3{transform:translateX(1.4px);transition-delay:.14s}

/* 9 · DRE — barras sobem */
.ic-dre .bar{stroke-width:2.4}
.ic-dre .b1{transform-origin:7px 20px}
.ic-dre .b2{transform-origin:12px 20px}
.ic-dre .b3{transform-origin:17px 20px}
:is(.side nav a:hover,.side nav a.active) .ic-dre .b1{transform:scaleY(1.32)}
:is(.side nav a:hover,.side nav a.active) .ic-dre .b2{transform:scaleY(1.5);transition-delay:.05s}
:is(.side nav a:hover,.side nav a.active) .ic-dre .b3{transform:scaleY(1.18);transition-delay:.1s}

/* 10 · Fechar Período — arco do cadeado levanta */
:is(.side nav a:hover,.side nav a.active) .ic-lock .shk{transform:translateY(-1.6px)}

/* 11 · Conectores — o plug encaixa */
:is(.side nav a:hover,.side nav a.active) .ic-plug .plug{transform:translateY(-1.8px)}

/* 12 · Permissões — a chave gira */
.ic-key .key{transform-origin:8px 8px}
:is(.side nav a:hover,.side nav a.active) .ic-key .key{transform:rotate(-22deg)}

/* 13 · Assistente IA — o sparkle cintila */
:is(.side nav a:hover,.side nav a.active) .ic-spark .s1{transform:rotate(18deg) scale(1.06)}
:is(.side nav a:hover,.side nav a.active) .ic-spark .s2{transform:scale(1.4)}
@media (prefers-reduced-motion: no-preference){
  .side nav a.active .ic-spark .s1{animation:spk1 3s var(--ease-soft) infinite}
  .side nav a.active .ic-spark .s2{animation:spk2 3s var(--ease-soft) .2s infinite}
}
@keyframes spk1{0%,100%{transform:none}50%{transform:rotate(16deg) scale(1.05)}}
@keyframes spk2{0%,100%{transform:none;opacity:.8}50%{transform:scale(1.35);opacity:1}}

@media (prefers-reduced-motion: reduce){
  .side nav a .ic svg,.side nav a .ic svg [class]{transition:none;animation:none}
}

/* mesmos SVGs reaproveitados no bottom-nav mobile e no menu "Mais" — só dimensionar */
.bnav a .bic svg{width:21px;height:21px;display:block}
.more-it .mic svg{width:22px;height:22px;display:block}

/* ---- Botão de tema: sol ↔ lua animado (Claude Design) ----
   Mantém o shell .theme-toggle e o toggleTheme()/[data-theme] já existentes;
   o ícone morfa sozinho via CSS conforme :root[data-theme="dark"].            */
.theme-toggle .ic-theme{width:18px;height:18px;overflow:visible;color:var(--text-muted)}
.theme-toggle:hover .ic-theme{color:var(--text)}
.ic-theme *{transform-box:fill-box;transform-origin:center}
.ic-theme .tt-core{transition:r .42s var(--ease-spring)}
.ic-theme .tt-cut{transition:cx .5s var(--ease-spring),cy .5s var(--ease-spring)}
.ic-theme .tt-rays{transition:transform .55s var(--ease-spring),opacity .35s ease}
.ic-theme .tt-rays line{transition:transform .45s var(--ease-spring)}
/* hover no SOL (tema claro): raios giram + disco respira */
.theme-toggle:hover .tt-rays{transform:rotate(42deg)}
.theme-toggle:hover .tt-core{r:5.7}
/* tema ESCURO: o sol vira lua — dirigido pelo data-theme que o app já usa */
:root[data-theme="dark"] .ic-theme .tt-cut{cx:15;cy:9}
:root[data-theme="dark"] .ic-theme .tt-core{r:6.3}
:root[data-theme="dark"] .ic-theme .tt-rays{opacity:0;transform:rotate(-55deg) scale(.35)}
:root[data-theme="dark"] .theme-toggle:hover .tt-rays{transform:rotate(-40deg) scale(.42)}
@media (prefers-reduced-motion: reduce){
  .ic-theme .tt-core,.ic-theme .tt-cut,.ic-theme .tt-rays,.ic-theme .tt-rays line{transition:none}
}

/* =================== CALENDÁRIO FINANCEIRO (nativo) v2 =========================
   Componente calendario.js. Renderiza dentro de #content (não é modal). Grade Seg–Sex +
   coluna "Semana" comprimida (Pagar/Receber) ou Seg–Dom (NF). Barras por grupo de empresa.
   Drawer "trabalho do dia" à direita com toggle ✓/✗ (Pagar). Tudo em tokens; dark-mode ok. */

/* paleta de categorias (grupos de empresa) — 6 cores estáveis por índice */
:root{
  --cat-1:#2b5cb8; --cat-2:#e0820a; --cat-3:#2e9e5b; --cat-4:#9333ea; --cat-5:#0891b2; --cat-6:#c2410c;
}
[data-theme="dark"]{
  --cat-1:#5b8def; --cat-2:#f0a93a; --cat-3:#3fb56e; --cat-4:#b873f5; --cat-5:#2bb6d4; --cat-6:#f08a4a;
}
.calf-g0{--gc:var(--cat-1)} .calf-g1{--gc:var(--cat-2)} .calf-g2{--gc:var(--cat-3)}
.calf-g3{--gc:var(--cat-4)} .calf-g4{--gc:var(--cat-5)} .calf-g5{--gc:var(--cat-6)}

.calf-wrap{display:flex;flex-direction:column;gap:10px}
.calf-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}
.calf-nav{display:flex;align-items:center;gap:8px}
.calf-mes{min-width:150px;text-align:center;font-weight:700;font-size:var(--fs-md);letter-spacing:-.2px}
.calf-leg{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:var(--fs-xs);color:var(--text-muted)}

/* grade */
.calf-grid{display:grid;gap:5px;align-items:stretch}
.calf-grid.c6{grid-template-columns:repeat(5,1fr) 0.8fr}
.calf-grid.c7{grid-template-columns:repeat(7,1fr)}
.calf-grid.calf-busy{opacity:.5;pointer-events:none}
.calf-dow{text-align:center;font-size:var(--fs-xs);font-weight:600;color:var(--text-muted);padding-bottom:2px}
.calf-cell{min-height:92px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);
  padding:5px 6px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.calf-cell.sem{background:var(--surface-2);cursor:default}
.calf-cell.fora{opacity:.4}
.calf-cell.hoje{border-color:var(--brand-500);box-shadow:0 0 0 1px var(--brand-500) inset}
.calf-cell[data-dia]:hover{border-color:var(--brand-500);box-shadow:var(--sh-2)}
.calf-cnum{font-size:var(--fs-xs);font-weight:600;color:var(--text-muted)}
.calf-cell.hoje .calf-cnum{color:var(--brand-500)}

/* bloco por grupo dentro da célula */
.calf-grp{border-left:3px solid var(--gc);padding:2px 5px;border-radius:4px;background:color-mix(in srgb,var(--gc) 9%,transparent)}
.calf-grp-top{display:flex;justify-content:space-between;align-items:center;gap:6px;font-size:10.5px}
.calf-grp-nome{font-weight:700;color:var(--gc);text-transform:uppercase;letter-spacing:.3px;font-size:9px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64%}
.calf-grp-val{font-weight:700;font-variant-numeric:tabular-nums}
.calf-liq{height:5px;border-radius:var(--r-full);background:var(--surface-sunken);overflow:hidden;margin-top:2px}
.calf-liq>i{display:block;height:100%;border-radius:var(--r-full);background:var(--gc,var(--brand-500))}
.calf-liq.mini{display:inline-block;width:38px;vertical-align:middle}
.calf-daytot{margin-top:auto;text-align:right;font-size:var(--fs-sm);font-weight:700;color:var(--text);
  font-variant-numeric:tabular-nums;border-top:1px solid var(--border);padding-top:3px}

/* coluna Semana (comprimida) */
.calf-semana{background:var(--surface-2);gap:2px}
.calf-wk{display:flex;justify-content:space-between;gap:5px;font-size:10px;font-weight:600;color:var(--gc);
  border-left:2px solid var(--gc);padding-left:4px}
.calf-wk span:last-child{color:var(--text);font-variant-numeric:tabular-nums}
.calf-wktot{margin-top:auto;text-align:right;font-size:var(--fs-sm);font-weight:800;font-variant-numeric:tabular-nums;
  border-top:2px solid var(--border);padding-top:3px}

/* selo NF */
.calf-selo{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:1px 7px;
  border-radius:var(--r-full);white-space:nowrap;line-height:1.5}
.calf-selo.inl{font-size:var(--fs-xs)}
.calf-dot{width:7px;height:7px;border-radius:var(--r-full);flex:none;background:currentColor}
.calf-selo.ok{background:var(--success-bg);color:var(--success-fg)}
.calf-selo.gerar{background:var(--warning-bg);color:var(--warning-fg)}
.calf-selo.tratar{background:var(--danger-bg);color:var(--danger-fg)}

/* ---- drawer "trabalho do dia" ---- */
.calf-dov{position:fixed;inset:0;background:rgba(15,23,42,.34);z-index:60}
.calf-drawer{position:fixed;top:0;right:0;height:100vh;width:min(440px,94vw);background:var(--surface);
  box-shadow:var(--sh-4);z-index:61;display:flex;flex-direction:column;transform:translateX(100%);
  transition:transform .26s var(--ease-soft,ease)}
.calf-drawer.aberto{transform:translateX(0)}
.calf-drawer[hidden]{display:none}
.calf-dr-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border)}
.calf-dr-head h3{margin:0;font-size:var(--fs-md)}
.calf-dr-x{border:none;background:transparent;font-size:22px;line-height:1;color:var(--text-muted);cursor:pointer;border-radius:var(--r-md);width:30px;height:30px}
.calf-dr-x:hover{background:var(--surface-sunken);color:var(--text)}
.calf-dr-body{flex:1;overflow:auto;padding:10px 14px}
.calf-dr-load{padding:20px;text-align:center;color:var(--text-muted)}
.calf-grp-sec{margin-bottom:14px}
.calf-grp-h{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:4px 8px;border-radius:var(--r-sm);
  border-left:3px solid var(--gc);background:color-mix(in srgb,var(--gc) 10%,transparent);margin-bottom:5px}
.calf-grp-h b{color:var(--gc);font-size:var(--fs-sm)}
.calf-grp-tot{font-size:var(--fs-sm);font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.calf-irow{display:flex;align-items:center;gap:9px;padding:6px 4px;border-bottom:1px solid var(--border)}
.calf-irow.excl{opacity:.5}
.calf-irow.liq{opacity:.85}
.calf-iinfo{flex:1;min-width:0;cursor:pointer;border-radius:var(--r-sm);padding:2px 4px}
.calf-iinfo:hover{background:var(--brand-50)}
.calf-iline{display:flex;justify-content:space-between;gap:8px;font-size:var(--fs-sm)}
.calf-inum{font-weight:600}
.calf-iline b{font-variant-numeric:tabular-nums}
.calf-isub{font-size:var(--fs-xs);color:var(--text-muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
/* ---- Cobertura de importação OFX (fonte 'movimento'): célula colorida pelo estado do dia ---- */
.calf-cell.cov{justify-content:flex-start}
.calf-cell.cov .cov-body{margin-top:auto;display:flex;flex-direction:column;gap:2px;align-items:flex-start}
.calf-cell.cov .cov-frac{font-size:var(--fs-md);font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
.calf-cell.cov .cov-lbl{font-size:var(--fs-xs);font-weight:600}
.calf-cell.cov.ok{background:var(--success-bg);border-color:color-mix(in srgb,var(--success) 40%,transparent)}
.calf-cell.cov.ok .cov-frac,.calf-cell.cov.ok .cov-lbl,.calf-cell.cov.ok .calf-cnum{color:var(--success-fg)}
.calf-cell.cov.pend{background:var(--danger-bg);border-color:color-mix(in srgb,var(--danger) 40%,transparent)}
.calf-cell.cov.pend .cov-frac,.calf-cell.cov.pend .cov-lbl,.calf-cell.cov.pend .calf-cnum{color:var(--danger-fg)}
.calf-cell.cov.erro{background:var(--warning-bg);border-color:color-mix(in srgb,var(--warning) 45%,transparent)}
.calf-cell.cov.erro .cov-frac,.calf-cell.cov.erro .cov-lbl,.calf-cell.cov.erro .calf-cnum{color:var(--warning-fg)}
.cov-pend{display:inline-block;font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:var(--r-full);
  background:var(--warning-bg);color:var(--warning-fg);border:1px solid color-mix(in srgb,var(--warning) 45%,transparent)}
.calf-cell.cov.ok .cov-pend,.calf-cell.cov.pend .cov-pend{background:rgba(255,255,255,.22);color:inherit;border-color:transparent}
/* KPIs cobertura */
.calf-kpi.cov-k.ok b{color:var(--success-fg)} .calf-kpi.cov-k.falta b{color:var(--danger-fg)}
.calf-kpi.cov-k.erro b{color:var(--warning-fg)} .calf-kpi.cov-k.pendk b{color:var(--warning-fg)}
/* legenda cobertura */
.cov-leg{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:middle;margin-right:3px}
.cov-leg.ok{background:var(--success)} .cov-leg.pend{background:var(--danger)}
.cov-leg.erro{background:var(--warning)} .cov-leg.sem{background:var(--surface-2);border:1px solid var(--border)}
/* drawer cobertura */
.cov-dr-sum{padding:10px 14px;font-size:var(--fs-sm);border-bottom:1px solid var(--border)}
.cov-dr-sum .ok{color:var(--success-fg)} .cov-dr-sum .al{color:var(--danger-fg)} .cov-dr-sum .musc{color:var(--text-muted)}
.cov-row{cursor:pointer}
.cov-cnome{font-weight:600}
.cov-pill{font-size:10.5px;font-weight:700;padding:1px 9px;border-radius:var(--r-full);white-space:nowrap}
.cov-pill.ok{background:var(--success-bg);color:var(--success-fg)}
.cov-pill.falta{background:var(--danger-bg);color:var(--danger-fg)}
.cov-pill.just{background:var(--surface-2);color:var(--text-muted)}
.cov-pill.erro{background:var(--warning-bg);color:var(--warning-fg)}
/* toggle ✓/✗ */
.calf-chk{flex:none;width:26px;height:26px;border-radius:var(--r-sm);border:2px solid var(--border);background:var(--surface);
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}
.calf-chk svg{width:15px;height:15px}
.calf-chk.on{border-color:var(--success);background:var(--success-bg);color:var(--success-fg)}
.calf-chk.off{border-color:var(--danger);background:var(--danger-bg);color:var(--danger-fg)}
.calf-chk.done{border-color:var(--success);background:var(--success);color:#fff;cursor:default}
.calf-chk.ro{cursor:default}
button.calf-chk:hover{transform:scale(1.08)}
/* rodapé do drawer */
.calf-dr-foot{border-top:1px solid var(--border);padding:10px 14px;display:flex;flex-direction:column;gap:8px}
.calf-dr-foot[hidden]{display:none}
.calf-foot-acts{display:flex;gap:8px}
.calf-foot-ro{font-size:var(--fs-xs);color:var(--text-muted)}
.calf-foot-tot{display:flex;align-items:center;gap:14px;font-size:var(--fs-sm)}
.calf-foot-tot b{font-variant-numeric:tabular-nums}
.calf-foot-tot #calf-tot-pagar{color:var(--success-fg)}
.calf-foot-tot #calf-tot-excl{color:var(--danger-fg)}
.calf-foot-tot .btn{margin-left:auto}

@media (max-width:768px){
  .calf-grid{gap:3px}
  .calf-cell{min-height:62px;padding:3px;gap:2px}
  .calf-grp-nome{max-width:100%}
  .calf-daytot,.calf-wktot{font-size:var(--fs-xs)}
  .calf-drawer{width:100vw}
}

/* ---- Calendário: painel do dia condensado (por fornecedor) + filtros + resumo por empresa ---- */
.calf-dr-tit, #calf-dr-tit{display:flex;align-items:baseline;gap:8px}
.calf-dow-lbl{font-size:var(--fs-xs);font-weight:500;color:var(--text-muted)}
.calf-dr-body{padding:0}                     /* densifica: o respiro vem dos blocos internos */
/* barra de filtros (sticky) */
.calf-fil{position:sticky;top:0;z-index:2;background:var(--surface);padding:8px 12px;border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:7px}
.calf-chips{display:flex;flex-wrap:wrap;gap:5px}
.calf-chip{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:var(--r-full);
  padding:2px 11px;font-size:var(--fs-xs);font-weight:600;cursor:pointer;transition:all var(--t) var(--ease)}
.calf-chip:hover{border-color:var(--brand-500);color:var(--text)}
.calf-chip.on{background:var(--brand-500);border-color:var(--brand-500);color:var(--text-on-brand)}
.calf-busca{width:100%;padding:5px 9px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);font-size:var(--fs-sm)}
.calf-busca:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}
.calf-secs{padding:8px 12px}
/* seção de grupo */
.calf-grp-sec{margin-bottom:10px}
.calf-grp-sec .calf-grp-h{margin-bottom:4px;padding:3px 7px}
/* bloco do fornecedor (condensado) */
.calf-forn{border-bottom:1px solid var(--border)}
.calf-forn-h{display:flex;align-items:center;gap:7px;padding:4px 2px}
.calf-forn-toggle{flex:1;min-width:0;display:flex;align-items:center;gap:5px;border:none;background:transparent;
  cursor:pointer;text-align:left;padding:2px 0;color:var(--text);font:inherit;border-radius:var(--r-sm)}
.calf-forn-toggle:hover{color:var(--brand-500)}
.calf-caret{width:13px;height:13px;flex:none;color:var(--text-muted);transition:transform var(--t) var(--ease)}
.calf-forn.aberto .calf-caret{transform:rotate(90deg)}
.calf-forn-nome{font-size:var(--fs-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calf-forn-cnt{flex:none;font-size:10px;font-weight:700;color:var(--text-muted);background:var(--surface-sunken);
  border-radius:var(--r-full);padding:1px 7px;font-variant-numeric:tabular-nums}
.calf-forn-tot{flex:none;font-size:var(--fs-sm);font-weight:700;font-variant-numeric:tabular-nums}
.calf-forn-det{padding:2px 0 6px 20px;border-left:2px solid var(--border);margin-left:8px}
.calf-forn-det[hidden]{display:none}
/* linhas de item (densas) */
.calf-secs .calf-irow{gap:8px;padding:4px 2px;border-bottom:1px solid var(--border)}
.calf-secs .calf-irow:last-child{border-bottom:none}
.calf-secs .calf-iline{font-size:var(--fs-sm)}
.calf-secs .calf-isub{font-size:11px}
/* toggle parcial (fornecedor com itens mistos) */
.calf-chk.partial{border-color:var(--warning);background:var(--warning-bg);color:var(--warning-fg)}
.calf-chk.sup{width:24px;height:24px}
.calf-chk.sup svg{width:14px;height:14px}
span.calf-chk{cursor:default}
/* resumo por empresa (cards) */
.calf-sumrow{display:flex;flex-wrap:wrap;gap:8px}        /* quebra linha — sem rolagem horizontal */
.calf-sumcard{flex:1 1 128px;min-width:124px;border:1px solid var(--border);border-left:3px solid var(--gc,var(--brand-500));
  border-radius:var(--r-md);padding:6px 9px;background:var(--surface)}
.calf-sum-h{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--gc,var(--brand-500));
  margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calf-sum-r{display:flex;justify-content:space-between;gap:10px;font-size:11px;line-height:1.5}
.calf-sum-r span{color:var(--text-muted)}
.calf-sum-r b{font-variant-numeric:tabular-nums}
.calf-sum-r b.ok{color:var(--success-fg)} .calf-sum-r b.al{color:var(--danger-fg)}
.calf-sum-sep{height:1px;background:var(--border);margin:3px 0}
.calf-foot-acts{display:flex;gap:8px;align-items:center}
.calf-foot-acts .btn:last-child{margin-left:auto}
.calf-foot-ro{font-size:var(--fs-xs);color:var(--text-muted)}

/* filtros no topo do calendário (Empresa · Fornecedor · Modalidade) */
.calf-filtros{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.calf-filtros .ft{margin:0}
/* filtros ficam colados à direita da barra (margin-left:auto) — abrir o painel para a esquerda
   p/ não estourar a borda direita da tela (vale p/ EmpresaSelect/MultiSelect do calendário). */
.calf-filtros .ms-panel{left:auto;right:0}

/* KPIs por empresa (total do mês) no topo do calendário */
.calf-kpis-wrap{display:flex;flex-direction:column;gap:4px}
.calf-kpis-cap{font-size:var(--fs-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}
.calf-kpis-cap:empty{display:none}
.calf-kpis{display:flex;flex-wrap:wrap;gap:8px}
.calf-kpi{display:flex;flex-direction:column;gap:1px;border:1px solid var(--border);border-left:3px solid var(--gc,var(--brand-500));
  border-radius:var(--r-md);padding:5px 11px;background:var(--surface);min-width:118px}
.calf-kpi-g{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--gc,var(--brand-500))}
.calf-kpi b{font-size:var(--fs-md);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.2px}
/* barra de filtros ativos (chips) — reaproveita .chip / .chip-x */
.calf-chips-ativos{display:flex;flex-wrap:wrap;gap:6px}
.calf-chips-ativos:empty{display:none}

/* KPI "Total geral" (somatório) em destaque, primeiro/à esquerda */
.calf-kpi-geral{border-left-color:var(--brand-500);background:var(--brand-50)}
.calf-kpi-geral .calf-kpi-g{color:var(--brand-500)}
/* filtros do topo colados à direita mesmo quando quebram de linha */
.calf-filtros{margin-left:auto}

/* "(N)" de lançamentos ao lado do nome do Plano de Contas (tela de Cadastros). Clicável = navy de ação;
   leva ao Pagar/Receber filtrado. (0) = sem uso, apenas informativo (cinza, sem clique). */
.plano-usos{color:var(--brand-500);font-variant-numeric:tabular-nums;font-weight:600;cursor:pointer;margin-left:2px}
.plano-usos:hover{text-decoration:underline}
.plano-usos.zero{color:var(--text-muted);font-weight:500;cursor:default}

/* ===== DRILL-DOWN da DRE (clicar no valor → composição: Linha ▸ Loja ▸ Lançamentos) ===== */
.dre-cell,.dre-cell-m{cursor:pointer;border-radius:6px;transition:background .12s var(--ease)}
.dre-cell:hover,.dre-cell:focus-visible,.dre-cell-m:hover,.dre-cell-m:focus-visible{background:var(--brand-100)!important;outline:none}
.drill-bc{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;margin-bottom:10px}
.drill-crumb{color:var(--text-muted);cursor:pointer;border-radius:6px;padding:2px 6px}
.drill-crumb:hover,.drill-crumb:focus-visible{background:var(--brand-100);color:var(--text);outline:none}
.drill-crumb.on{color:var(--text);font-weight:600;cursor:default}
.drill-sep{color:var(--text-muted);font-size:11px}
.drill-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;
  padding:10px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:10px}
.drill-sub-l{font-weight:700}
.drill-sub-v{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}
.drill-nota{font-size:11.5px;color:var(--text-muted);background:var(--surface-2);
  border:1px dashed var(--line);border-radius:var(--r-md);padding:8px 10px;margin-bottom:10px}
.drill-scroll{overflow:auto;max-height:56vh}
.drill-tbl{width:100%}
.drill-tbl tbody tr.drill-click{cursor:pointer}

/* ===== DRE mobile: faixa de período fixa + afford. de toque no drill ===== */
.drm-vnum{font-variant-numeric:tabular-nums}
.drm-chev{color:var(--brand-500);font-weight:700;font-size:15px;line-height:1;flex:0 0 auto}
@media (max-width:768px){
  /* faixa de chips (período) fixa no topo enquanto rola a DRE longa → nunca se perde o que está vendo */
  #dre-rep .dre-mobbar{position:sticky;top:0;z-index:5;background:var(--surface);
    padding:6px 0 8px;border-bottom:1px solid var(--line);margin-bottom:6px}
  /* valor = alvo de toque maior (número + ›), com realce ao tocar */
  .dre-mob .drm-v.dre-cell-m{display:inline-flex;align-items:center;justify-content:flex-end;gap:5px;
    padding:6px 4px 6px 10px;margin:-6px -4px -6px 0;border-radius:8px;min-height:32px}
  .dre-mob .drm-v.dre-cell-m:active{background:var(--brand-100)}
}

/* ===== Drill da DRE: cabeçalho de coluna ordenável (A↔Z / menor↔maior) ===== */
.drill-tbl th.drill-th{cursor:pointer;user-select:none;white-space:nowrap}
.drill-tbl th.drill-th:hover,.drill-tbl th.drill-th:focus-visible{color:var(--brand-500);outline:none}
.drill-sort{margin-left:3px;font-size:10px;color:var(--brand-500)}
