:root{
    --navy:#1e1b4b;
    --navy2:#2a2566;
    --ink:#1f2937;
    --muted:#9ca3af;
    --line:#eceef2;
    --bg:#f6f7f9;
    --green:#16a34a;
    --red:#ef4444;
    --pink:#f97316;
    --lime:#84cc16;
    --purple:#7c3aed;
    --radius:14px;
    --maxw:1040px;   /* largura padrão do conteúdo das páginas internas */
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
    font-family:"Inter",-apple-system,Segoe UI,Roboto,Arial,sans-serif;
    color:var(--ink);background:var(--bg);font-size:13px;
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

.topstrip{height:6px;background:linear-gradient(90deg,#ea580c,#f97316,#fb923c)}

.app{display:flex;height:calc(100vh - 6px)}

/* ---------------- Sidebar ---------------- */
.sidebar{
    width:148px;flex:0 0 148px;background:#fff;border-right:1px solid var(--line);
    display:flex;flex-direction:column;padding:14px 10px;gap:4px;
}
.brand{
    width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#fb923c,#ea580c);
    color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;margin:2px 4px 14px;
    overflow:hidden;
}
.brand img{width:100%;height:100%;object-fit:cover;display:block}
.navitem{
    display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;color:#4b5563;
    font-weight:600;font-size:13px;cursor:pointer;transition:background .12s,color .12s;
}
.navitem:hover{background:#f3f4f6}
.navitem.active{background:#fff1e6;color:var(--pink)}
.navitem .ico{width:18px;text-align:center;font-size:15px;color:#9ca3af}
.navitem.active .ico{color:var(--pink)}
.navitem .badge{
    background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border-radius:6px;
    font-size:11px;font-weight:700;width:20px;height:18px;display:inline-flex;align-items:center;justify-content:center;
}
.navsep{height:1px;background:var(--line);margin:8px 6px}

/* ---------------- Content ---------------- */
.content{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
    display:flex;align-items:center;gap:16px;padding:14px 22px;border-bottom:1px solid var(--line);background:#fff;
}
.topbar h1{font-size:18px;margin:0;flex:0 0 auto}
.topcenter{flex:1;display:flex;justify-content:center}
.topright{flex:0 0 auto;width:60px}
.yearnav{display:flex;align-items:center;gap:14px;font-weight:700;color:#374151}
.yearnav .ynav{
    width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;
    background:#f3f4f6;color:#6b7280;font-size:16px;
}
.yearnav .ynav:hover{background:#e9eaee}

.page{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}

/* ---------------- Saldos / grid ---------------- */
.saldos-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 24px 0}
.saldos-toolbar.dre-mode #switchColapsar{visibility:hidden}

/* alternador Saldo / DRE */
.viewtoggle{display:inline-flex;background:#eef0f4;border-radius:10px;padding:3px;gap:2px}
.vt-btn{border:0;background:transparent;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;
    color:#6b7280;padding:6px 18px;border-radius:8px;transition:color .12s}
.vt-btn.active{background:#fff;color:var(--pink);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none;
    font-size:12px;font-weight:600;color:#6b7280}
.switch input{display:none}
.switch .track{width:38px;height:21px;border-radius:20px;background:#d1d5db;position:relative;transition:background .15s}
.switch .knob{position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:#fff;
    box-shadow:0 1px 2px rgba(0,0,0,.25);transition:left .15s}
.switch input:checked + .track{background:var(--pink)}
.switch input:checked + .track .knob{left:19px}

/* meses recolhidos (antes do início do controle) */
.month.prestart .month-title-cell{cursor:pointer}
.month.prestart .caret{display:inline-block;margin-left:6px;color:#c0c4cc;font-size:11px}
.collapse-label{display:none}
.month.is-collapsed{min-width:46px;width:46px;align-self:stretch}
.month.is-collapsed > table{display:none}
.month.is-collapsed .collapse-label{
    display:flex;align-items:center;justify-content:center;width:100%;min-height:160px;height:100%;
    writing-mode:vertical-rl;transform:rotate(180deg);
    background:#fff;border:1px solid var(--line);border-radius:12px;
    font-weight:700;font-size:13px;color:#9ca3af;cursor:pointer;letter-spacing:.5px;
    box-shadow:0 1px 3px rgba(0,0,0,.05);
}
.month.is-collapsed .collapse-label:hover{color:var(--pink);border-color:#fed7aa}

.saldos-scroll{
    flex:1;overflow:auto;display:flex;gap:26px;padding:0 22px 0;align-items:flex-start;
    border-top:16px solid transparent;
    scrollbar-width:thin;scrollbar-color:rgba(120,125,150,.28) transparent;
}
.saldos-scroll[hidden]{display:none}
/* barra de rolagem fina e quase invisível */
.saldos-scroll::-webkit-scrollbar{width:10px;height:10px}
.saldos-scroll::-webkit-scrollbar-track{background:transparent}
.saldos-scroll::-webkit-scrollbar-thumb{
    background:rgba(120,125,150,.25);border-radius:10px;
    border:3px solid transparent;background-clip:content-box;
}
.saldos-scroll::-webkit-scrollbar-thumb:hover{background:rgba(120,125,150,.5);background-clip:content-box}
.saldos-scroll::-webkit-scrollbar-corner{background:transparent}

.month{flex:0 0 auto;min-width:560px}

table.grid{border-collapse:separate;border-spacing:0;width:100%;background:#fff;border-radius:12px;
    box-shadow:0 1px 3px rgba(0,0,0,.05);}
table.grid th,table.grid td{padding:7px 12px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}

/* linha do nome do mês (fixa no topo) */
table.grid thead tr.month-row th{
    position:sticky;top:0;z-index:6;background:#fff;text-align:left;
    font-size:14px;font-weight:700;color:#374151;padding:11px 12px;
    border-top-left-radius:12px;border-top-right-radius:12px;
}
.mes-atual table.grid thead tr.month-row th{color:var(--pink)}
/* linha das categorias (fixa logo abaixo do nome do mês) */
table.grid thead tr.cols-row th{
    position:sticky;top:39px;z-index:5;background:#fff;
    font-size:11px;color:#6b7280;font-weight:600;border-bottom:1px solid var(--line);
}
table.grid thead tr.cols-row th.c-dia{text-align:left}

.c-dia{width:46px;text-align:left !important}
.num{text-align:right}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--c,#ccc);margin-right:6px;vertical-align:middle}
thead .dot{opacity:1}
td .dot{opacity:.9}
td.zero{color:#c7cad1}
td.zero .dot{background:#dfe2e7 !important}

.day-row{border-bottom:1px solid #f3f4f6}
.day-row:hover{background:#fafafe;cursor:pointer}
.day-row.is-hoje{background:#fff7ed}
.diabox{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;
    border-radius:6px;font-weight:600;color:#374151}
.diabox.hoje{background:#111827;color:#fff}

.c-saldo{font-weight:700;color:#374151;border-left:1px solid var(--line)}
.c-saldo .saldo-val{display:block}
.saldo-diario{display:none;font-size:11px;font-weight:600;color:var(--pink);opacity:.85}

/* Coluna Fluxo (entrada/saída resumidos) — oculta no desktop, exibida no mobile */
.c-fluxo{display:none}
.c-fluxo .fl-in{display:block;color:#16a34a;font-weight:600}
.c-fluxo .fl-out{display:block;color:#ef4444;font-weight:600}
.c-fluxo .fl-zero{color:#c7cad1}

/* Cabeçalho do mês com setas de navegação */
.mhead{display:flex;align-items:center;justify-content:space-between;gap:8px}
.mhead .mtitle{flex:1 1 auto}
.mnav{flex:0 0 auto;width:26px;height:26px;border:1px solid var(--line);background:#fff;
    border-radius:7px;color:#6b7280;font-size:17px;line-height:1;cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;padding:0;transition:all .12s}
.mnav:hover{color:var(--pink);border-color:#fed7aa;background:#fff7ed}

/* rodapé fixo no fundo, colado à barra de rolagem */
table.grid tfoot td{
    position:sticky;bottom:0;z-index:5;background:#f8f9fb;
    box-shadow:0 -1px 0 var(--line);
}
table.grid tfoot td:first-child{border-bottom-left-radius:12px}
table.grid tfoot td:last-child{border-bottom-right-radius:12px}
tfoot td.foot{font-weight:700;color:#374151}

/* efeito hover instantâneo nos valores */
table.grid tbody td.num:hover{
    background:#eef2ff;color:#111827;
    box-shadow:inset 0 0 0 1px #c7d2fe;cursor:pointer;
}
table.grid tbody td.num.zero:hover{color:#6b7280}

/* ---------------- DRE ---------------- */
.dre-scroll{
    flex:1;overflow:auto;padding:0 22px 22px 0;border-top:16px solid transparent;
    scrollbar-width:thin;scrollbar-color:rgba(120,125,150,.28) transparent;
}
.dre-scroll[hidden]{display:none}
.dre-scroll::-webkit-scrollbar{width:10px;height:10px}
.dre-scroll::-webkit-scrollbar-track{background:transparent}
.dre-scroll::-webkit-scrollbar-thumb{background:rgba(120,125,150,.25);border-radius:10px;border:3px solid transparent;background-clip:content-box}
.dre-scroll::-webkit-scrollbar-thumb:hover{background:rgba(120,125,150,.5);background-clip:content-box}
.dre-scroll::-webkit-scrollbar-corner{background:transparent}

table.dre{border-collapse:separate;border-spacing:0;background:#fff;border-radius:12px;
    box-shadow:0 1px 3px rgba(0,0,0,.05);min-width:100%}
table.dre th,table.dre td{padding:12px 16px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;font-size:13px}
table.dre thead th{position:sticky;top:0;z-index:3;background:#f8f9fb;color:#6b7280;font-size:11px;
    font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
table.dre thead th.dre-cur{color:var(--pink)}
/* primeira coluna (rótulos) fixa à esquerda */
table.dre .dre-lbl{position:sticky;left:0;z-index:2;background:#fff;text-align:left;font-weight:600;
    color:#374151;min-width:200px;box-shadow:1px 0 0 var(--line)}
table.dre thead .dre-lbl{z-index:4;background:#f8f9fb}
table.dre thead th:first-child{border-top-left-radius:12px}
table.dre thead th:last-child{border-top-right-radius:12px}
.dre-row td{border-bottom:1px solid #f3f4f6}
.dre-row:last-child td{border-bottom:0}
.dre-tot-h,td.dre-tot{border-left:1px solid var(--line);font-weight:700;background:#fafbfc}
td.dre-cur{background:#fff7ed}
td.dre-cur.dre-tot{background:#fff7ed}
.dre-rec td.num{color:#15803d}
.dre-desp td.num{color:#b91c1c}
td.num.zero{color:#c7cad1}
/* Linha-cabeçalho de tópico (total da seção) */
.dre-sec td{font-weight:700}
.dre-sec td.dre-lbl{color:#111827;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.03em}
.dre-sec td.num{font-weight:700}
/* Sub-linhas por categoria */
.dre-sub td.dre-lbl{padding-left:30px;font-weight:500;color:#6b7280}
.dre-sub td.num{font-weight:500;opacity:.85}

.dre-res td{font-weight:700;border-top:2px solid var(--line);background:#fafbfc}
.dre-res td.dre-lbl{background:#fafbfc;color:#111827}
.dre-res td.pos{color:#15803d}
.dre-res td.neg{color:#dc2626}
.dre-res td.dre-cur{background:#fdeef4}
/* Saldo total acumulado */
.dre-saldo td{font-weight:700;background:#f4f6fb}
.dre-saldo td.dre-lbl{background:#f4f6fb;color:#111827}
.dre-saldo td.pos{color:#15803d}
.dre-saldo td.neg{color:#dc2626}
.dre-saldo td.dre-cur{background:#eef1fa}

/* ---------------- Modais ---------------- */
.modal-overlay{position:fixed;inset:0;background:rgba(30,27,75,.45);display:none;align-items:flex-start;
    justify-content:center;z-index:50;padding-top:8vh;backdrop-filter:blur(1px)}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:18px;width:380px;max-width:92vw;padding:20px;
    box-shadow:0 20px 60px rgba(0,0,0,.25);animation:pop .14s ease}
@keyframes pop{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.modal-head h2{font-size:20px;margin:0;font-weight:700}
.modal-close{border:0;background:none;font-size:24px;color:#9ca3af;cursor:pointer;line-height:1}

.fld{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}
.fld-ico{width:18px;text-align:center;color:#9ca3af;font-size:15px}
.fld input,.fld select{border:0;outline:0;font-size:15px;width:100%;background:none;color:var(--ink);font-family:inherit}
.fld input::placeholder{color:#c0c4cc}
#f_valor{font-size:20px;font-weight:600}
.fld.select .fld-stack{flex:1}
.fld-stack small{display:block;font-size:11px;color:#9ca3af;font-weight:600}
.fld-stack select{font-size:14px;padding:2px 0;font-weight:600}

.tagpick{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px}
.tagopt input{display:none}
.tagopt span{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;
    border:1px solid var(--c);color:var(--c);cursor:pointer}
.tagopt input:checked + span{background:var(--c);color:#fff}

.modal-actions{display:flex;gap:10px;margin-top:18px}
.btn-primary{flex:1;border:0;background:#22c55e;color:#fff;font-weight:700;font-size:15px;
    padding:13px;border-radius:24px;cursor:pointer}
.btn-primary:hover{background:#1eb152}
.btn-ghost{border:1px solid var(--line);background:#fff;border-radius:24px;padding:13px 18px;font-weight:600;cursor:pointer}
.btn-ghost.danger{color:var(--red);border-color:#fecaca}
.btn-ghost.danger:hover{background:#fef2f2}

/* lista de transações do dia */
.dia-lista{display:flex;flex-direction:column;gap:8px;max-height:50vh;overflow:auto}
.dia-item{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px}
.dia-item:hover{background:#fafafe;cursor:pointer}
.dia-item .di-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.dia-item .di-desc{flex:1;min-width:0}
.dia-item .di-desc b{display:block;font-size:13px}
.dia-item .di-desc small{color:var(--muted)}
.dia-item .di-val{font-weight:700;font-variant-numeric:tabular-nums}

/* ---------------- Detalhamento da DRE ---------------- */
table.dre th.dre-clik{cursor:pointer}
table.dre th.dre-clik:hover{color:var(--pink);text-decoration:underline}
.modal.modal-wide{width:560px}
.dd-resumo{display:flex;gap:10px;margin-bottom:14px}
.dd-resumo .dd-card{flex:1;border:1px solid var(--line);border-radius:12px;padding:10px 14px;background:#fafbfc}
.dd-resumo .dd-card small{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-bottom:2px}
.dd-resumo .dd-card b{font-size:18px;font-variant-numeric:tabular-nums}
.dd-resumo .dd-card b.pos{color:#15803d}
.dd-resumo .dd-card b.neg{color:#dc2626}
.dd-body{display:flex;flex-direction:column;gap:18px;max-height:62vh;overflow:auto}
.dd-sec-head{display:flex;justify-content:space-between;align-items:baseline;padding:0 2px 6px;
    border-bottom:2px solid var(--line);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.03em}
.dd-sec-head b{font-size:14px;font-variant-numeric:tabular-nums}
.dd-rec .dd-sec-head{color:#15803d}
.dd-fix .dd-sec-head,.dd-var .dd-sec-head{color:#b91c1c}
.dd-empty{padding:8px 2px;color:var(--muted);font-size:13px}
.dd-cat{margin-top:10px}
.dd-cat-top{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:13px;padding:0 2px}
.dd-cat-top b{font-variant-numeric:tabular-nums}
.dd-cat-meta{display:block;color:var(--muted);font-size:11px;padding:0 2px 2px}
.dd-item{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:10px;
    padding:7px 8px;border-bottom:1px solid #f3f4f6;font-size:13px}
.dd-item:last-child{border-bottom:0}
.dd-item .dd-data{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px}
.dd-item .dd-desc{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-item .dd-desc small{color:var(--muted);margin-left:6px}
.dd-item .dd-val{font-weight:600;font-variant-numeric:tabular-nums}
.dd-item.dd-prev{opacity:.75;font-style:italic}
.dd-item.dd-prev .dd-data{color:var(--pink)}
.dia-empty{color:var(--muted);text-align:center;padding:18px}

/* ---------------- Páginas internas (cards) ---------------- */
/* page-pad centraliza o conteúdo e impõe a MESMA largura em todas as páginas */
.page-pad{padding:22px 24px;overflow:auto;flex:1;display:flex;flex-direction:column;align-items:center}
.page-pad > *{width:100%;max-width:var(--maxw)}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;margin:0 0 16px}
.card:last-child{margin-bottom:0}
.resumo{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.resumo .box{border:1px solid var(--line);border-radius:12px;padding:12px 14px;min-width:0}
.resumo .box small{color:var(--muted);font-size:11px;display:block;margin-bottom:4px}
.resumo .box b{font-size:20px;display:block;font-variant-numeric:tabular-nums;white-space:nowrap}
.card h2{margin:0 0 16px;font-size:18px}
.cat-hint{margin:0 0 14px;font-size:13px}
.cat-empty{padding:14px 2px}

/* Cartões de categoria (Menu) — layout flexível e auto-explicativo */
.catlist{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}
.linha{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
    padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;transition:border-color .12s}
.linha:hover{border-color:#e2d9f5}
.linha .cat-id{display:flex;align-items:center;gap:10px;flex:1 1 240px;min-width:200px}
.linha .nome{flex:1 1 auto;min-width:0;font-weight:700;font-size:14px;
    border:1px solid var(--line);background:#f8f9fb;border-radius:9px;padding:9px 11px;font-family:inherit}
.linha .nome:focus{background:#fff;border-color:var(--purple,#7c3aed);outline:0}
.linha .valwrap{flex:0 0 auto;display:flex;align-items:center;gap:0;
    border:1px solid var(--line);background:#f8f9fb;border-radius:9px;overflow:hidden}
.linha .valwrap:focus-within{background:#fff;border-color:var(--purple,#7c3aed)}
.linha .valpre{padding:0 4px 0 10px;color:var(--muted);font-size:13px;font-weight:600}
.linha .valor{width:90px;text-align:right;border:0;background:transparent;padding:9px 11px 9px 2px;font-size:14px;font-weight:700;font-family:inherit}
.linha .valor:focus{outline:0}
.linha .cat-meta{flex:1 1 220px;min-width:180px;display:flex;flex-direction:column;gap:6px}
.linha .cat-bar{height:6px;border-radius:99px;background:#eef0f4;overflow:hidden}
.linha .cat-bar span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#a78bfa,#7c3aed)}
.linha .cat-bar span[data-over="1"]{background:linear-gradient(90deg,#fb7185,#ef4444)}
.linha .cat-nums{display:flex;justify-content:space-between;gap:12px;font-size:13px}
.linha .cat-nums small{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.linha .cat-gasto{color:#374151;font-weight:700}
.linha .cat-disp{font-weight:700;color:#16a34a;text-align:right}
.linha .cat-disp[data-neg="1"]{color:var(--red)}
.linha.linha-fixa .cat-id{flex:1 1 100%}
.linha .acoes{display:flex;gap:6px;justify-content:flex-end;flex:0 0 auto}
.mini{border:1px solid var(--line);background:#fff;border-radius:8px;padding:5px 10px;cursor:pointer;font-weight:600;font-size:12px}
.mini.del{color:var(--red);border-color:#fecaca}
.mini.save{color:#fff;background:#22c55e;border-color:#22c55e}
.addrow{display:flex;gap:8px;margin-top:14px}
.addrow input{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px;font-family:inherit;font-size:13px}

.totais-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;max-width:900px;margin:0 auto 22px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.tcard small{color:var(--muted);display:flex;align-items:center;gap:6px;font-weight:600}
.tcard b{font-size:22px;display:block;margin-top:8px}

.tag-grid{display:flex;flex-direction:column;gap:10px}
.swatch{width:16px;height:16px;border-radius:50%;flex:0 0 auto}
.tag-grid .linha .t-nome{font-weight:700;border:1px solid var(--line);background:#f8f9fb;border-radius:9px;padding:9px 11px;font-family:inherit;font-size:14px;flex:1 1 auto;min-width:0}
.tag-grid .linha .t-nome:focus{background:#fff;border-color:var(--purple,#7c3aed);outline:0}
.tag-grid .linha .acoes{align-items:center}
.tag-grid .linha .t-cor{width:40px;height:34px;padding:0;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}

/* indicadores reutilizáveis */
.pos{color:#15803d}
.neg{color:#dc2626}
.warn{color:#d97706}

/* ---- Totais: controle Mês/Ano no topo ---- */
.totnav{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center}
.seg{display:inline-flex;background:#eef0f4;border-radius:10px;padding:3px;gap:2px}
.seg-btn{padding:7px 18px;border-radius:8px;font-weight:600;font-size:13px;color:#6b7280;line-height:1}
.seg-btn.active{background:#fff;color:var(--pink);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.totnav .period{display:flex;align-items:center;gap:12px;font-weight:700;color:#374151}
.totnav .period .ynav{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;
    border-radius:8px;background:#f3f4f6;color:#374151;font-size:18px}
.totnav .period .ynav:hover{background:#e9eaee;color:var(--pink)}

/* ---- Totais: layout em duas colunas (preenche a largura padrão) ---- */
.totais-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.tot-col{margin:0}

/* valores: largura reservada + dígitos tabulares → estrutura não se mexe */
.calc-top b,.mov-row b,.cfg-val{font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}

.calc-item{padding:13px 0;border-bottom:1px solid var(--line)}
.calc-item:last-child{border-bottom:0;padding-bottom:0}
.calc-item:first-of-type{padding-top:0}
.calc-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.calc-lbl{font-weight:700;font-size:15px;min-width:0}
.calc-top b{font-size:20px;font-weight:800;flex:0 0 auto}
.calc-bot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:6px}
.calc-formula{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:13px;font-weight:600;flex:0 0 auto}
.calc-formula .dot{margin-right:0}
.calc-bot small{font-weight:700;font-size:12px;text-align:right}
.calc-bar{height:7px;border-radius:99px;background:#eef0f4;overflow:hidden;margin-top:8px}
.calc-bar span{display:block;height:100%;border-radius:99px;background:#22c55e}
.calc-bar span.warn{background:#f59e0b}
.calc-bar span.neg{background:#ef4444}

.mov-list{display:flex;flex-direction:column}
.mov-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.mov-row:first-child{padding-top:2px}
.mov-lbl{display:flex;align-items:center;gap:9px;color:#374151;font-weight:600;min-width:0}
.mov-row b{font-size:16px;font-weight:700;flex:0 0 auto}
.mov-saldo{border-bottom:0;margin-top:4px;border-top:2px solid var(--line);padding-top:14px}
.mov-saldo .mov-lbl{font-weight:800}
.mov-saldo b{font-size:18px;font-weight:800}

/* ---- Configurações: subabas (barra cheia, botões iguais) ---- */
.subtabs{display:flex;background:#eef0f4;border-radius:12px;padding:4px;gap:2px;margin-bottom:16px}
.subtab{flex:1 1 0;border:0;background:transparent;cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;
    color:#6b7280;padding:10px 16px;border-radius:9px;line-height:1;text-align:center}
.subtab.active{background:#fff;color:var(--pink);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.tabpane{display:none}
.tabpane.active{display:block}

/* ---- Configurações: campos do saldo ---- */
.box input{font-size:20px;font-weight:700;border:0;width:100%;outline:0;background:transparent;font-family:inherit;font-variant-numeric:tabular-nums}
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:14px}
.cfg-field{display:flex;flex-direction:column;gap:6px}
.cfg-field span{font-weight:600;color:#374151;font-size:13px}
.cfg-field input{border:1px solid var(--line);background:#f8f9fb;border-radius:9px;padding:11px 12px;font-family:inherit;font-size:15px;width:100%}
.cfg-field input:focus{background:#fff;border-color:var(--purple,#7c3aed);outline:0}

/* FAB (oculto no desktop, aparece no mobile) */
.fab{display:none}

/* ================================================================
   RESPONSIVO — celular (≤ 760px)
   ================================================================ */
@media (max-width: 760px){
    body{font-size:14px}
    .app{flex-direction:column;height:calc(100vh - 6px)}

    /* --- Navegação inferior fixa (ex-sidebar) --- */
    .sidebar{
        position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;flex:0 0 auto;
        flex-direction:row;border-right:0;border-top:1px solid var(--line);
        padding:6px 6px;gap:2px;z-index:40;box-shadow:0 -2px 12px rgba(0,0,0,.06);
        justify-content:space-around;
    }
    .sidebar .brand,.sidebar .navsep,#btnAdicionar{display:none}
    .sidebar nav{display:flex;flex-direction:row;width:100%;justify-content:space-around;gap:2px}
    .navitem{
        flex-direction:column;gap:3px;padding:6px 4px;border-radius:10px;
        font-size:10px;font-weight:600;flex:1;justify-content:center;text-align:center;min-width:0;
    }
    .navitem .ico{font-size:20px;width:auto}
    .navitem .lbl{font-size:10px}
    .navitem .badge{width:22px;height:20px;font-size:12px}

    /* --- Conteúdo ocupa tudo, com espaço pra barra inferior --- */
    .content{padding-bottom:62px}
    .topbar{padding:10px 14px;gap:8px}
    .topbar h1{font-size:16px}
    .topright{display:none}
    .yearnav{gap:8px;font-size:13px}
    .yearnav .ynav{width:30px;height:30px;font-size:18px}

    /* --- Barra de ferramentas Saldo/DRE --- */
    .saldos-toolbar{padding:8px 12px 0;gap:8px}
    #switchColapsar{display:none}
    .vt-btn{padding:8px 22px;font-size:14px}

    /* --- Saldos: um mês por tela, deslizando (snap) --- */
    .saldos-scroll{
        gap:12px;padding:12px 12px 0;border-top:0;
        scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    }
    .month{min-width:calc(100vw - 24px);width:calc(100vw - 24px);scroll-snap-align:center}
    /* desativa o recolhimento de meses no mobile */
    .month.is-collapsed{min-width:calc(100vw - 24px);width:calc(100vw - 24px);align-self:auto}
    .month.is-collapsed > table{display:table}
    .collapse-label{display:none !important}
    .month.prestart .caret{display:none}

    /* tabela enxuta: Dia, Fluxo e Saldo */
    table.grid th.c-entrada,table.grid td.c-entrada,
    table.grid th.c-saida,table.grid td.c-saida,
    table.grid th.c-diario,table.grid td.c-diario,
    table.grid th.c-economia,table.grid td.c-economia,
    table.grid th.c-cartao,table.grid td.c-cartao{display:none}
    table.grid th.c-fluxo,table.grid td.c-fluxo{display:table-cell;text-align:right}
    table.grid tfoot{display:none}
    table.grid th,table.grid td{padding:11px 14px}
    table.grid thead tr.month-row th{font-size:16px;padding:13px 14px}
    table.grid thead tr.cols-row th{top:43px;font-size:12px}
    .c-dia{width:auto}
    .diabox{min-width:30px;height:30px;font-size:15px}
    .c-saldo{font-size:16px}
    .c-fluxo{font-size:13px;line-height:1.35}
    .saldo-diario{display:block;margin-top:2px}
    .day-row{border-bottom:1px solid #eef0f4}
    .mnav{width:32px;height:32px;font-size:19px}

    /* --- DRE: rolagem horizontal, células compactas --- */
    .dre-scroll{padding:12px 12px 0;border-top:0}
    table.dre th,table.dre td{padding:10px 12px;font-size:12px}
    table.dre .dre-lbl{min-width:150px}

    /* --- Modais viram "bottom sheet" --- */
    .modal-overlay{align-items:flex-end;padding-top:0}
    .modal,.modal.modal-wide{
        width:100%;max-width:100%;border-radius:20px 20px 0 0;
        padding:18px 18px calc(18px + env(safe-area-inset-bottom));
        max-height:92vh;overflow:auto;animation:sheet .22s ease;
    }
    @keyframes sheet{from{transform:translateY(100%)}to{transform:none}}
    .modal-head h2{font-size:19px}
    .fld{padding:14px 4px}
    .fld input,.fld select{font-size:16px}      /* ≥16px evita zoom no iOS */
    #f_valor{font-size:22px}
    .modal-actions{position:sticky;bottom:0;background:#fff;padding-top:12px}
    .btn-primary{padding:15px}
    .dd-body{max-height:none}
    .dd-resumo .dd-card b{font-size:17px}

    /* --- FAB (novo gasto rápido) --- */
    .fab{
        display:flex;align-items:center;justify-content:center;
        position:fixed;right:16px;bottom:74px;z-index:45;
        width:58px;height:58px;border-radius:50%;border:0;cursor:pointer;
        background:linear-gradient(135deg,#fb923c,#ea580c);color:#fff;font-size:30px;font-weight:300;
        box-shadow:0 8px 20px rgba(234,88,12,.4);
    }
    .fab:active{transform:scale(.94)}

    /* --- Páginas internas: cards fluidos --- */
    .page-pad{padding:16px 14px}
    .card{padding:16px;border-radius:14px}
    .resumo .box b{font-size:18px}

    /* Totais: empilha as duas colunas e o controle Mês/Ano */
    .totais-wrap{grid-template-columns:1fr;gap:14px}
    .totnav{gap:10px}
    .totnav .period{font-size:14px}
    .calc-top b{font-size:19px}

    /* Configurações: subabas mais compactas */
    .subtab{padding:10px 6px;font-size:13px}

    /* cartões de categoria do diário no mobile */
    .linha .cat-id{flex:1 1 100%}
    .linha .nome{font-size:15px}
    .linha .valor{width:100px;font-size:15px}
    .linha .cat-meta{flex:1 1 100%}
    .linha .acoes{flex:1 1 100%;justify-content:flex-start;margin-top:2px}
    .linha.linha-fixa{align-items:center}
    .linha.linha-fixa .acoes{flex:0 0 auto;margin-top:0}
    .mini{padding:9px 16px;font-size:14px}
    .addrow{flex-wrap:wrap}
    .addrow input{flex:1 1 100%}
    .addrow .btn-primary{flex:1 1 100%}
}
