/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#080e1a;
  --bg2:#0d1526;
  --bg3:#121e33;
  --surface:#162038;
  --surface2:#1c2a45;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.12);
  --text:#eef4ff;
  --text2:#7a9bbf;
  --text3:#3d5a7a;
  --green:#3ddc84;
  --green2:#2bb56a;
  --greenb:rgba(61,220,132,0.12);
  --red:#ff6b6b;
  --red2:#e05555;
  --redb:rgba(255,107,107,0.12);
  --blue:#4da6ff;
  --blue2:#2d8fef;
  --blueb:rgba(77,166,255,0.12);
  --purple:#b57bee;
  --purple2:#9560d4;
  --purpleb:rgba(181,123,238,0.12);
  --cyan:#22d3ee;
  --yellow:#fbbf24;
  --orange:#fb923c;
  --gold:#f59e0b;
  --r:18px;
  --rsm:12px;
  --shadow:0 12px 40px rgba(0,0,0,0.5);
  --shadowsm:0 4px 16px rgba(0,0,0,0.35);
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --mono:'SF Mono','Fira Code',Consolas,'Courier New',monospace;
  --navh:70px;
  --headh:62px;
  --ease:cubic-bezier(.4,0,.2,1);
}
[data-theme=light]{
  --bg:#f0f5ff;--bg2:#e4ecf7;--bg3:#d8e6f5;
  --surface:#fff;--surface2:#f5f9ff;
  --border:rgba(0,0,0,0.07);--border2:rgba(0,0,0,0.13);
  --text:#0a1628;--text2:#3d5a7a;--text3:#8faabe;
  --shadow:0 12px 40px rgba(0,0,0,0.1);--shadowsm:0 4px 16px rgba(0,0,0,0.07);
}

html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);overflow:hidden;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;user-select:none}

/* ===== SPLASH ===== */
#splash{
  transition:opacity 0.25s ease,visibility 0.25s ease;
  position:fixed;inset:0;
  background:radial-gradient(ellipse at 30% 20%,#0d2a3d 0%,#080e1a 60%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  z-index:9999;transition:opacity 0.25s ease,visibility 0.25s ease;
}
#splash.out{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{animation:spl 2s ease infinite}
@keyframes spl{0%,100%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.06) rotate(2deg)}}
.splash-title{
  font-size:32px;font-weight:800;letter-spacing:-1px;
  background:linear-gradient(135deg,#3ddc84,#22d3ee);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.splash-sub{color:var(--text3);font-size:14px;font-weight:500}
.splash-bar{width:180px;height:3px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden;margin-top:6px}
.splash-prog{height:100%;width:0%;background:linear-gradient(90deg,#3ddc84,#22d3ee);border-radius:2px;animation:lb 0.4s ease forwards}
@keyframes lb{to{width:100%}}

/* ===== INSTALL BANNER ===== */
.install-banner{
  position:fixed;bottom:calc(var(--navh) + 10px);left:12px;right:12px;
  background:linear-gradient(135deg,#162038,#1c2a45);
  border:1px solid var(--border2);border-radius:var(--r);
  padding:14px 16px;display:flex;align-items:center;gap:12px;
  z-index:800;box-shadow:var(--shadow);animation:slideUp .4s var(--ease);
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.inst-icon{font-size:30px}
.inst-text{flex:1}
.inst-text strong{display:block;font-size:13px;font-weight:700;color:var(--text)}
.inst-text span{font-size:11px;color:var(--text3)}
.btn-inst{
  background:linear-gradient(135deg,var(--green2),var(--cyan));
  color:#000;border:none;border-radius:10px;
  padding:9px 14px;font-size:12px;font-weight:800;
  cursor:pointer;white-space:nowrap;font-family:var(--font);
}
.btn-inst-x{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:4px;line-height:1}

/* ===== APP ===== */
.app{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg)}
.hidden{display:none!important}

/* ===== HEADER ===== */
.header{
  height:var(--headh);background:rgba(13,21,38,0.95);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 18px;flex-shrink:0;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.hbrand{display:flex;align-items:center;gap:10px;font-size:19px;font-weight:800;letter-spacing:-.5px;
  background:linear-gradient(135deg,#3ddc84,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hactions{display:flex;align-items:center;gap:8px}
.ibtn{
  position:relative;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:8px;color:var(--text2);cursor:pointer;
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  font-size:17px;transition:all .2s var(--ease);
}
.ibtn svg{width:18px;height:18px;stroke:currentColor}
.ibtn:hover{background:var(--surface2);color:var(--text)}
.badge{
  position:absolute;top:-5px;right:-5px;
  background:var(--red);color:#fff;font-size:9px;font-weight:800;
  min-width:17px;height:17px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg2);padding:0 3px;
}

/* ===== ALERT PANEL ===== */
.alert-panel{
  position:absolute;top:var(--headh);left:0;right:0;
  background:var(--bg2);border-bottom:1px solid var(--border);
  z-index:700;max-height:280px;overflow-y:auto;box-shadow:var(--shadow);
}
.ap-head{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border)}
.ap-head h3{font-size:14px;font-weight:700}
.ap-list{padding:10px}
.alert-item{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;border-radius:10px;margin-bottom:6px;font-size:13px;line-height:1.4}
.alert-item.danger{background:var(--redb);border-left:3px solid var(--red)}
.alert-item.warn{background:rgba(251,191,36,.1);border-left:3px solid var(--yellow)}
.alert-item.ok{background:var(--greenb);border-left:3px solid var(--green)}

/* ===== PAGES ===== */
.main{flex:1;overflow:hidden;position:relative}
.page{display:none;position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--navh)+20px);-webkit-overflow-scrolling:touch}
.page.active{display:block;animation:pf .3s var(--ease)}
@keyframes pf{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ===== BALANCE HERO ===== */
.bal-hero{
  background:linear-gradient(160deg,#0a1e30 0%,#081528 50%,#0a1a0d 100%);
  border-bottom:1px solid var(--border);
  padding:28px 20px 22px;text-align:center;
  position:relative;overflow:hidden;
}
.bal-hero::before{
  content:'';position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(61,220,132,0.07) 0%,transparent 70%);
  pointer-events:none;
}
.bal-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px;font-weight:600}
.bal-val{
  font-size:40px;font-weight:800;font-family:var(--mono);line-height:1;
  background:linear-gradient(135deg,#3ddc84,#22d3ee);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  transition:all .4s var(--ease);
}
.bal-val.negative{background:linear-gradient(135deg,#ff6b6b,#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.bal-meta{margin-top:14px;font-size:13px;display:flex;justify-content:center;gap:20px;font-weight:600}
.min{color:var(--green)}.mout{color:var(--red)}.mdiv{color:var(--text3)}
.period-row{display:flex;gap:8px;justify-content:center;margin-top:18px}
.pbtn{
  background:rgba(255,255,255,0.05);border:1px solid var(--border);
  color:var(--text2);border-radius:20px;padding:6px 16px;
  font-size:12px;font-family:var(--font);font-weight:600;cursor:pointer;transition:all .2s;
}
.pbtn.active{background:rgba(61,220,132,0.15);border-color:var(--green);color:var(--green)}

/* ===== SCORE ===== */
.score-card{
  margin:14px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:18px 20px;display:flex;
  align-items:center;justify-content:space-between;box-shadow:var(--shadowsm);
}
.sc-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-weight:600}
.sc-val{font-size:40px;font-weight:800;font-family:var(--mono);line-height:1}
.sc-status{font-size:12px;font-weight:700;margin-top:6px}

/* ===== QUICK GRID ===== */
.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 14px 14px}
.qcard{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:16px 14px;cursor:pointer;transition:all .2s var(--ease);
  position:relative;overflow:hidden;
}
.qcard::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  border-radius:0 0 var(--r) var(--r);
}
.qcard.green::after{background:linear-gradient(90deg,var(--green),var(--cyan))}
.qcard.red::after{background:linear-gradient(90deg,var(--red),var(--orange))}
.qcard.blue::after{background:linear-gradient(90deg,var(--blue),var(--cyan))}
.qcard.purple::after{background:linear-gradient(90deg,var(--purple),var(--blue))}
.qcard:active{transform:scale(0.96)}
.qi{font-size:24px;margin-bottom:8px}
.ql{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;font-weight:600}
.qv{font-size:16px;font-weight:800;font-family:var(--mono)}
.green-t{color:var(--green)}.red-t{color:var(--red)}.blue-t{color:var(--blue)}.purple-t{color:var(--purple)}

/* ===== CARDS ===== */
.card{margin:0 14px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadowsm)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.card-head h3{font-size:14px;font-weight:700}
.sel-sm{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:9px;padding:5px 10px;font-size:12px;font-family:var(--font);cursor:pointer}
.lbtn{background:none;border:none;color:var(--cyan);font-size:13px;cursor:pointer;font-family:var(--font);font-weight:600}

/* ===== CATEGORY BARS ===== */
.cat-item{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.cat-em{font-size:20px;width:30px;text-align:center}
.cat-inf{flex:1}
.cat-nm{font-size:12px;color:var(--text2);margin-bottom:5px;font-weight:600}
.cat-bw{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.cat-b{height:100%;border-radius:3px;transition:width .9s var(--ease)}
.cat-pc{font-size:11px;color:var(--text3);font-family:var(--mono);white-space:nowrap}

/* ===== SUGGESTIONS ===== */
.sugg-item{padding:12px 14px;border-radius:12px;font-size:13px;line-height:1.5;margin-bottom:8px;border-left:3px solid;font-weight:500}
.sugg-item.good{background:var(--greenb);border-color:var(--green);color:var(--green)}
.sugg-item.warn{background:rgba(251,191,36,.08);border-color:var(--yellow);color:var(--yellow)}
.sugg-item.danger{background:var(--redb);border-color:var(--red);color:var(--red)}
.sugg-item.info{background:var(--blueb);border-color:var(--blue);color:var(--blue)}

/* ===== TRANSACTION LIST ===== */
.txlist{display:flex;flex-direction:column}
.txi{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;
}
.txi:last-child{border-bottom:none}
.txi:active{background:var(--surface2)}
.txi-ic{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.txi-ic.entrada{background:var(--greenb)}.txi-ic.saida{background:var(--redb)}.txi-ic.parcela{background:var(--blueb)}
.txi-inf{flex:1;min-width:0}
.txi-desc{font-size:14px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.txi-meta{font-size:11px;color:var(--text3);font-weight:500}
.txi-amt{font-size:15px;font-weight:800;font-family:var(--mono);white-space:nowrap}
.txi-amt.entrada{color:var(--green)}.txi-amt.saida{color:var(--red)}.txi-amt.parcela{color:var(--blue)}
.del-btn{background:var(--redb);border:none;color:var(--red);border-radius:9px;padding:7px 9px;font-size:14px;cursor:pointer;flex-shrink:0}

/* ===== PAGE HEROES ===== */
.phero{padding:28px 20px 22px;border-bottom:1px solid var(--border);margin-bottom:6px}
.phero h2{font-size:24px;font-weight:800;margin-bottom:8px}
.htotal{font-size:30px;font-weight:800;font-family:var(--mono)}
.hsub{font-size:14px;color:var(--text2);margin-top:4px}
.green-hero{background:linear-gradient(160deg,#0c2a18,#081a10)}
.red-hero{background:linear-gradient(160deg,#2a0c0c,#1a0808)}
.blue-hero{background:linear-gradient(160deg,#0c1a2a,#081018)}
.purple-hero{background:linear-gradient(160deg,#1a0c2a,#100818)}
.dark-hero{background:var(--bg2)}

/* ===== FAB ===== */
.fab{
  display:block;width:calc(100% - 28px);margin:14px auto;
  background:linear-gradient(135deg,var(--green2),var(--cyan));
  color:#000;border:none;border-radius:var(--r);
  padding:15px;font-size:15px;font-weight:800;
  cursor:pointer;font-family:var(--font);
  box-shadow:0 6px 24px rgba(61,220,132,.3);transition:all .2s;
}
.fab:active{transform:scale(0.98)}

/* ===== PARCELAS ===== */
.par-tabs{display:flex;gap:0;margin:14px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);background:var(--bg3)}
.par-tab{flex:1;padding:11px 8px;border:none;background:transparent;color:var(--text2);font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .2s;text-align:center;letter-spacing:.3px}
.par-tab.active{background:var(--surface2);color:var(--text);box-shadow:inset 0 0 0 1px var(--border2)}

.par-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:18px;margin-bottom:12px;box-shadow:var(--shadowsm);
  position:relative;overflow:hidden;
}
.par-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.par-card.credcard::before{background:linear-gradient(90deg,#f59e0b,#fb923c)}
.par-card.financing::before{background:linear-gradient(90deg,#4da6ff,#22d3ee)}
.par-card.credit::before{background:linear-gradient(90deg,#b57bee,#4da6ff)}

.par-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.par-title{font-size:15px;font-weight:800;margin-bottom:3px}
.par-cat{font-size:11px;color:var(--text3);font-weight:600}
.par-type-badge{
  font-size:10px;font-weight:800;padding:4px 9px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;
}
.par-type-badge.credcard{background:rgba(245,158,11,.15);color:var(--gold)}
.par-type-badge.financing{background:var(--blueb);color:var(--blue)}
.par-type-badge.credit{background:var(--purpleb);color:var(--purple)}

.par-values{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.par-vbox{background:var(--bg3);border-radius:10px;padding:10px 12px}
.par-vbox label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;font-weight:700;display:block;margin-bottom:3px}
.par-vbox span{font-size:16px;font-weight:800;font-family:var(--mono);color:var(--text)}

.par-prog-wrap{height:8px;background:var(--bg3);border-radius:4px;overflow:hidden;margin-bottom:10px}
.par-prog{height:100%;border-radius:4px;transition:width .9s var(--ease)}

.par-installments{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;max-height:90px;overflow-y:auto}
.inst-pill{
  min-width:36px;height:32px;border-radius:8px;
  border:1.5px solid;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;cursor:pointer;transition:all .2s;
  font-family:var(--mono);padding:0 6px;
}
.inst-pill.pago{background:var(--greenb);border-color:var(--green);color:var(--green)}
.inst-pill.atrasado{background:var(--redb);border-color:var(--red);color:var(--red);animation:pulse .8s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}
.inst-pill.pendente{background:var(--bg3);border-color:var(--border2);color:var(--text3)}
.inst-pill.futuro{background:transparent;border-color:var(--border);color:var(--text3);opacity:.5}

.par-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.par-info-txt{font-size:11px;color:var(--text3);font-weight:600}
.par-del{background:var(--redb);border:none;color:var(--red);border-radius:9px;padding:7px 12px;font-size:12px;cursor:pointer;font-weight:700}

.inst-legend{display:flex;gap:14px;margin-bottom:10px;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text3);font-weight:600}
.legend-dot{width:8px;height:8px;border-radius:50%}
.legend-dot.pago{background:var(--green)}.legend-dot.atrasado{background:var(--red)}.legend-dot.pendente{background:var(--text3)}

/* ===== SIMULAÇÃO ===== */
.sim-block{margin:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--shadowsm)}
.sim-block h3{font-size:15px;font-weight:800;margin-bottom:18px}
.simres{margin-top:16px;background:var(--bg3);border-radius:var(--rsm);padding:16px;font-size:13px;line-height:1.9;border-left:3px solid var(--cyan)}
.simres strong{color:var(--cyan);font-family:var(--mono)}

.meta-card{background:var(--bg3);border-radius:var(--rsm);padding:14px;border-left:3px solid var(--purple);margin-bottom:10px}
.meta-nm{font-size:14px;font-weight:800;margin-bottom:4px}
.meta-inf{font-size:12px;color:var(--text2);margin-bottom:10px;line-height:1.6}
.meta-pw{height:6px;background:var(--bg);border-radius:3px;overflow:hidden;margin-bottom:8px}
.meta-pb{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--purple),var(--blue))}
.meta-del{background:none;border:none;color:var(--red);font-size:12px;cursor:pointer;font-weight:700}

/* ===== FILTER BAR ===== */
.fbar{padding:12px 14px;display:flex;gap:8px;border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap}
.fsel{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 12px;font-size:13px;font-family:var(--font);flex:1;min-width:90px}
.finp{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 12px;font-size:13px;font-family:var(--font);flex:1;min-width:90px;outline:none}
.finp::placeholder{color:var(--text3)}

/* ===== FORMS ===== */
.fg{margin-bottom:15px}
.fg label{display:block;font-size:11px;color:var(--text3);margin-bottom:7px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.inp{
  width:100%;background:var(--bg3);border:1.5px solid var(--border);
  color:var(--text);border-radius:var(--rsm);padding:13px 15px;
  font-size:15px;font-family:var(--font);outline:none;transition:all .2s;
  -webkit-appearance:none;appearance:none;
}
.inp:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.12)}

/* valor dual input */
.val-dual{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.val-dual-lbl{grid-column:1/-1;font-size:11px;color:var(--text3);margin-bottom:7px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.val-sub{font-size:10px;color:var(--text3);margin-top:4px;text-align:center}

/* parcela type selector */
.type-sel{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:6px}
.type-opt{
  padding:10px 6px;border-radius:11px;border:1.5px solid var(--border);
  background:var(--bg3);color:var(--text2);font-size:11px;font-weight:700;
  text-align:center;cursor:pointer;transition:all .2s;font-family:var(--font);
}
.type-opt.sel-credit{border-color:var(--gold);color:var(--gold);background:rgba(245,158,11,.1)}
.type-opt.sel-financing{border-color:var(--blue);color:var(--blue);background:var(--blueb)}
.type-opt.sel-credcard{border-color:var(--purple);color:var(--purple);background:var(--purpleb)}

.btnp{
  background:linear-gradient(135deg,var(--green2),var(--cyan));
  color:#000;border:none;border-radius:var(--rsm);
  padding:14px 24px;font-size:15px;font-weight:800;
  cursor:pointer;font-family:var(--font);transition:all .2s;
}
.btnp:active{transform:scale(.98)}
.btnp.full{width:100%}
.pad{padding:4px 0 8px}

/* ===== MODAL ===== */
.modal-ov{
  position:fixed;inset:0;background:rgba(0,0,0,.8);
  z-index:900;display:flex;align-items:flex-end;justify-content:center;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.modal-box{
  background:var(--bg2);border-radius:26px 26px 0 0;
  width:100%;max-width:520px;max-height:94vh;
  display:flex;flex-direction:column;
  animation:msu .35s var(--ease);
}
@keyframes msu{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-head{
  padding:20px 20px 16px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;flex-shrink:0;
}
.modal-head h3{font-size:18px;font-weight:800}
.modal-body{padding:20px;overflow-y:auto;flex:1}

/* ===== BOTTOM NAV ===== */
.bnav{
  height:var(--navh);background:rgba(13,21,38,0.97);
  border-top:1px solid var(--border);
  display:flex;align-items:center;padding:0 4px;flex-shrink:0;
  padding-bottom:env(safe-area-inset-bottom,0);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.ni{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  background:none;border:none;color:var(--text3);cursor:pointer;
  padding:8px 4px;transition:all .2s var(--ease);border-radius:14px;
  font-family:var(--font);font-size:10px;font-weight:600;height:58px;
}
.ni svg{width:21px;height:21px;transition:all .2s}
.ni.active{color:var(--green)}
.ni.active svg{stroke:var(--green);filter:drop-shadow(0 0 8px rgba(61,220,132,.5))}

/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:calc(var(--navh) + 16px);left:50%;transform:translateX(-50%);
  background:var(--surface2);border:1px solid var(--border2);
  color:var(--text);padding:12px 22px;border-radius:22px;
  font-size:14px;font-weight:700;z-index:9000;white-space:nowrap;
  box-shadow:var(--shadow);animation:tp .3s var(--ease);
}
@keyframes tp{from{transform:translateX(-50%) translateY(12px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}

/* ===== EMPTY ===== */
.empty{text-align:center;padding:48px 24px;color:var(--text3)}
.empty .eic{font-size:52px;margin-bottom:14px}
.empty p{font-size:14px;font-weight:500}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:2px}

/* ===== RESPONSIVE ===== */
@media(min-width:500px){
  .qgrid{grid-template-columns:repeat(4,1fr)}
  .modal-box{margin-bottom:24px;border-radius:26px;max-height:88vh}
  .modal-ov{align-items:center}
}

/* ===== PREVISÃO ===== */
.prev-hero{padding:28px 20px 22px;border-bottom:1px solid var(--border);background:linear-gradient(160deg,#1a1a0c,#101008)}
.prev-hero h2{font-size:24px;font-weight:800;margin-bottom:8px}
.prev-saldo{font-size:32px;font-weight:800;font-family:var(--mono)}
.prev-saldo.pos{color:var(--green)}.prev-saldo.neg{color:var(--red)}.prev-saldo.neu{color:var(--yellow)}
.prev-meta{margin-top:6px;font-size:13px;color:var(--text2);display:flex;gap:16px}
.prev-section{margin:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadowsm)}
.prev-section h3{font-size:14px;font-weight:800;margin-bottom:14px}
.prev-add-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;margin-bottom:10px;align-items:end}
.prev-add-row .inp{font-size:14px;padding:11px 13px}
.prev-btn-add{background:var(--green2);color:#000;border:none;border-radius:var(--rsm);padding:11px 14px;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);white-space:nowrap}
.prev-btn-add.red{background:var(--red2);color:#fff}
.prev-list-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.prev-list-item:last-child{border-bottom:none}
.prev-li-desc{flex:1;font-size:14px;font-weight:600}
.prev-li-val{font-size:14px;font-weight:800;font-family:var(--mono)}
.prev-li-val.ent{color:var(--green)}.prev-li-val.sai{color:var(--red)}
.prev-li-del{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:2px 6px}
.prev-summary{margin:14px;border-radius:var(--r);overflow:hidden}
.prev-sum-row{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;background:var(--surface);border-bottom:1px solid var(--border)}
.prev-sum-row:last-child{border-bottom:none;background:var(--surface2)}
.prev-sum-lbl{font-size:13px;color:var(--text2);font-weight:600}
.prev-sum-val{font-size:15px;font-weight:800;font-family:var(--mono)}
.prev-month-nav{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px;background:var(--bg2);border-bottom:1px solid var(--border)}
.prev-month-nav button{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 16px;font-size:14px;cursor:pointer;font-family:var(--font)}
.prev-month-nav span{font-size:15px;font-weight:800;min-width:140px;text-align:center}
.prev-tip{margin:0 14px 14px;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);border-radius:var(--rsm);padding:12px 14px;font-size:12px;color:var(--yellow);line-height:1.5}
.prev-recurring-badge{font-size:10px;background:var(--blueb);color:var(--blue);border-radius:6px;padding:2px 6px;font-weight:700;margin-left:6px}

/* ===== FAMÍLIA ===== */
.fam-hero{padding:28px 20px 22px;border-bottom:1px solid var(--border);background:linear-gradient(160deg,#0c1a2a,#080e18)}
.fam-hero h2{font-size:24px;font-weight:800;margin-bottom:6px}
.fam-hero p{font-size:13px;color:var(--text2);line-height:1.5}
.fam-section{margin:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadowsm)}
.fam-section h3{font-size:14px;font-weight:800;margin-bottom:4px}
.fam-section p{font-size:12px;color:var(--text3);margin-bottom:16px;line-height:1.5}
.fam-member-card{background:var(--bg3);border-radius:var(--rsm);padding:14px 16px;margin-bottom:10px;border:1px solid var(--border)}
.fam-member-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.fam-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.fam-avatar.a0{background:linear-gradient(135deg,#3ddc84,#22d3ee)}
.fam-avatar.a1{background:linear-gradient(135deg,#b57bee,#4da6ff)}
.fam-avatar.a2{background:linear-gradient(135deg,#fb923c,#f59e0b)}
.fam-avatar.a3{background:linear-gradient(135deg,#f472b6,#b57bee)}
.fam-member-info{flex:1}
.fam-member-name{font-size:15px;font-weight:800}
.fam-member-sub{font-size:11px;color:var(--text3)}
.fam-member-vals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.fam-val-box{background:var(--bg);border-radius:9px;padding:8px 10px;text-align:center}
.fam-val-box label{display:block;font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-weight:700}
.fam-val-box span{font-size:13px;font-weight:800;font-family:var(--mono)}
.fam-total-card{background:linear-gradient(135deg,#0d2a18,#081a24);border:1px solid rgba(61,220,132,.2);border-radius:var(--r);padding:20px;margin:14px}
.fam-total-card h3{font-size:13px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-weight:700}
.fam-total-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}
.fam-total-row:last-child{border-bottom:none;margin-top:6px;padding-top:14px}
.fam-total-row span:first-child{font-size:13px;color:var(--text2);font-weight:600}
.fam-total-row span:last-child{font-size:15px;font-weight:800;font-family:var(--mono)}
.export-box{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--rsm);padding:14px;font-family:var(--mono);font-size:11px;color:var(--text2);word-break:break-all;margin-bottom:12px;max-height:80px;overflow:hidden;user-select:all}
.fam-btn-row{display:flex;gap:8px;flex-wrap:wrap}
.fam-btn{flex:1;min-width:120px;padding:12px;border-radius:var(--rsm);border:none;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);transition:all .2s}
.fam-btn.share{background:linear-gradient(135deg,var(--green2),var(--cyan));color:#000}
.fam-btn.copy{background:var(--surface2);border:1px solid var(--border2);color:var(--text)}
.fam-btn.whats{background:#25d366;color:#fff}
.import-area{width:100%;min-height:80px;background:var(--bg3);border:1.5px dashed var(--border2);color:var(--text);border-radius:var(--rsm);padding:12px;font-size:13px;font-family:var(--font);resize:none;outline:none}
.import-area:focus{border-color:var(--cyan)}
.fam-del-btn{background:var(--redb);border:none;color:var(--red);border-radius:8px;padding:5px 10px;font-size:11px;cursor:pointer;font-weight:700}
.fam-empty{text-align:center;padding:32px 16px;color:var(--text3)}
.fam-empty .eic{font-size:44px;margin-bottom:12px}

/* ===== QR CODE MODAL ===== */
.qr-modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:950;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);padding:24px}
.qr-modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:24px;padding:28px 24px;width:100%;max-width:340px;text-align:center}
.qr-modal-box h3{font-size:17px;font-weight:800;margin-bottom:6px}
.qr-modal-box p{font-size:12px;color:var(--text3);margin-bottom:20px;line-height:1.5}
#qrCanvas{border-radius:14px;margin:0 auto;display:block;background:white;padding:12px}
.qr-actions{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
.qr-actions button{flex:1;padding:12px 8px;border-radius:12px;border:none;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font)}
.qr-scan-area{width:100%;height:260px;border-radius:14px;overflow:hidden;background:#000;position:relative;margin-bottom:16px}
.qr-scan-area video{width:100%;height:100%;object-fit:cover}
.qr-scan-line{position:absolute;left:10%;right:10%;height:2px;background:var(--green);box-shadow:0 0 8px var(--green);animation:scanLine 2s ease infinite}
@keyframes scanLine{0%{top:10%}100%{top:90%}}
.qr-scan-frame{position:absolute;inset:20px;border:2px solid rgba(61,220,132,.4);border-radius:12px;pointer-events:none}
.qr-scan-corner{position:absolute;width:20px;height:20px;border-color:var(--green);border-style:solid}
.qr-scan-corner.tl{top:20px;left:20px;border-width:3px 0 0 3px;border-radius:4px 0 0 0}
.qr-scan-corner.tr{top:20px;right:20px;border-width:3px 3px 0 0;border-radius:0 4px 0 0}
.qr-scan-corner.bl{bottom:20px;left:20px;border-width:0 0 3px 3px;border-radius:0 0 0 4px}
.qr-scan-corner.br{bottom:20px;right:20px;border-width:0 3px 3px 0;border-radius:0 0 4px 0}

/* ===== PAR EDIT ===== */
.par-edit-btn{background:var(--blueb);border:none;color:var(--blue);border-radius:8px;padding:5px 10px;font-size:11px;cursor:pointer;font-weight:700;margin-right:6px}

/* ===== DASHBOARD SALDO MELHORADO ===== */
.bal-breakdown{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.bbd-box{background:var(--surface);border-radius:12px;padding:10px 12px;text-align:center;border:1px solid var(--border)}
.bbd-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.8px;font-weight:700;color:var(--text3);margin-bottom:4px}
.bbd-val{font-size:13px;font-weight:800;font-family:var(--mono)}

/* ===== PAR MES SELECTOR ===== */
.par-mes-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg2);border-bottom:1px solid var(--border);margin-bottom:4px}
.par-mes-row label{font-size:12px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.par-mes-sel{background:var(--surface);border:1px solid var(--border2);color:var(--text);border-radius:10px;padding:7px 10px;font-size:13px;font-family:var(--font);cursor:pointer}
.par-totais{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:0 14px 14px}
.par-tot-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;text-align:center}
.par-tot-box label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;display:block;margin-bottom:4px}
.par-tot-box span{font-size:13px;font-weight:800;font-family:var(--mono)}

/* ===== FAMÍLIA MELHORADA ===== */
.fam-mes-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg3);border-radius:var(--rsm);margin-bottom:14px}
.fam-mes-row label{font-size:12px;font-weight:700;color:var(--text2)}
.fam-qr-section{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.fam-qr-btn{padding:16px 10px;border-radius:14px;border:none;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .2s}
.fam-qr-btn .btn-icon-big{font-size:26px}
.fam-qr-btn.generate{background:linear-gradient(135deg,#0d2a18,#081a24);border:1px solid rgba(61,220,132,.3);color:var(--green)}
.fam-qr-btn.scan{background:linear-gradient(135deg,#0d1a2a,#081018);border:1px solid rgba(77,166,255,.3);color:var(--blue)}
.fam-member-card-v2{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:10px;position:relative;overflow:hidden}
.fam-member-card-v2::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.fam-member-card-v2.me::before{background:linear-gradient(90deg,var(--green),var(--cyan))}
.fam-member-card-v2.other::before{background:linear-gradient(90deg,var(--purple),var(--blue))}
.fam-mv2-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.fam-mv2-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border:2px solid var(--border2)}
.fam-mv2-info{flex:1}
.fam-mv2-name{font-size:16px;font-weight:800}
.fam-mv2-sub{font-size:11px;color:var(--text3);margin-top:2px}
.fam-mv2-badge{font-size:10px;font-weight:800;padding:3px 8px;border-radius:20px;margin-left:6px}
.fam-mv2-badge.me{background:var(--greenb);color:var(--green)}
.fam-mv2-badge.other{background:var(--purpleb);color:var(--purple)}
.fam-mv2-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.fam-mv2-box{background:var(--bg3);border-radius:10px;padding:9px 10px;text-align:center}
.fam-mv2-box label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;display:block;margin-bottom:3px}
.fam-mv2-box span{font-size:14px;font-weight:800;font-family:var(--mono)}
.fam-consolidated{margin:14px;background:linear-gradient(135deg,#0a1e14,#080e1a);border:1px solid rgba(61,220,132,.2);border-radius:var(--r);padding:20px}
.fam-cons-title{font-size:13px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.fam-cons-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border)}
.fam-cons-row:last-child{border-bottom:none;padding-top:14px;margin-top:4px}
.fam-cons-lbl{font-size:13px;color:var(--text2);font-weight:600}
.fam-cons-val{font-size:15px;font-weight:800;font-family:var(--mono)}

/* ===== HELP SYSTEM ===== */
.help-btn{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.7);border-radius:50%;width:24px;height:24px;font-size:12px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.help-btn:hover{background:var(--cyan);color:#000;border-color:var(--cyan)}
.help-btn.light{background:rgba(255,255,255,0.15)}
.phero-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.phero-head h2{flex:1}
.bal-lbl-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}
.bal-lbl-row .bal-lbl{margin:0}
.help-tooltip{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.help-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px)}
.help-tooltip-content{position:relative;background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:24px;max-width:340px;width:100%;box-shadow:var(--shadow)}
.help-tooltip-title{font-size:17px;font-weight:800;margin-bottom:12px;color:var(--cyan)}
.help-tooltip-body{font-size:14px;color:var(--text2);line-height:1.7}
.help-tooltip-body strong{color:var(--text);display:block;margin-top:10px;margin-bottom:2px}
.help-close{width:100%;margin-top:18px;background:linear-gradient(135deg,var(--green2),var(--cyan));color:#000;border:none;border-radius:12px;padding:12px;font-size:14px;font-weight:800;cursor:pointer;font-family:var(--font)}

/* ===== MES ANTERIOR ===== */
.mes-anterior-card{display:flex;justify-content:space-between;align-items:center;margin:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;box-shadow:var(--shadowsm)}
.ma-left .ma-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:4px}
.ma-left .ma-val{font-size:22px;font-weight:800;font-family:var(--mono)}
.ma-right{font-size:28px}

/* ===== METAS SONHOS ===== */
.meta-card-v2{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--shadowsm)}
.meta-v2-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.meta-v2-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.meta-v2-title{font-size:15px;font-weight:800;flex:1}
.meta-v2-cat{font-size:11px;color:var(--text3);margin-top:2px}
.meta-v2-vals{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.meta-v2-box{background:var(--bg3);border-radius:10px;padding:8px 12px}
.meta-v2-box label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;display:block;margin-bottom:2px}
.meta-v2-box span{font-size:14px;font-weight:800;font-family:var(--mono)}
.meta-v2-prog{height:8px;background:var(--bg3);border-radius:4px;overflow:hidden;margin-bottom:8px}
.meta-v2-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--gold),var(--orange));transition:width .9s}
.meta-v2-footer{display:flex;justify-content:space-between;align-items:center}
.meta-v2-pct{font-size:12px;font-weight:800;color:var(--text3)}
.meta-del{background:var(--redb);border:none;color:var(--red);border-radius:8px;padding:5px 10px;font-size:11px;cursor:pointer;font-weight:700}
.meta-add-btn{background:var(--greenb);border:none;color:var(--green);border-radius:8px;padding:5px 10px;font-size:11px;cursor:pointer;font-weight:700;margin-right:4px}

.sonho-card{background:linear-gradient(135deg,var(--surface),var(--bg3));border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:14px}
.sonho-emoji{font-size:36px;flex-shrink:0}
.sonho-info{flex:1}
.sonho-nome{font-size:15px;font-weight:800;margin-bottom:4px}
.sonho-val{font-size:14px;color:var(--gold);font-family:var(--mono);font-weight:700}
.sonho-del{background:var(--redb);border:none;color:var(--red);border-radius:8px;padding:6px;font-size:14px;cursor:pointer}

.inv-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--shadowsm)}
.inv-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.inv-title{font-size:15px;font-weight:800}
.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.inv-box{background:var(--bg3);border-radius:10px;padding:8px 12px}
.inv-box label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;display:block;margin-bottom:2px}
.inv-box span{font-size:14px;font-weight:800;font-family:var(--mono)}

/* ===== SAIDAS DATE DISPLAY ===== */
.htotal-sub{font-size:13px;color:var(--text2);margin-top:6px}
.txi-dates{font-size:10px;color:var(--text3);margin-top:1px}
.txi-dates span{margin-right:8px}

/* ===== PAG MODAL ===== */
.pag-par-info{background:var(--bg3);border-radius:var(--rsm);padding:12px 14px;margin-bottom:16px;border-left:3px solid var(--blue)}
.pag-par-info .pag-desc{font-size:14px;font-weight:800;margin-bottom:4px}
.pag-par-info .pag-val{font-size:18px;font-weight:800;color:var(--blue);font-family:var(--mono)}

/* ===== ANÁLISE IA ===== */
.analise-hero{padding:28px 20px 22px;background:linear-gradient(160deg,#080e18 0%,#0d1a0d 100%);border-bottom:1px solid var(--border)}
.analise-hero h2{font-size:24px;font-weight:800;margin-bottom:6px}
.analise-hero p{font-size:13px;color:var(--text2);line-height:1.5}
.analise-btn-big{display:block;width:calc(100% - 28px);margin:16px auto;background:linear-gradient(135deg,#4ade80,#22d3ee);color:#000;border:none;border-radius:var(--r);padding:18px;font-size:17px;font-weight:800;cursor:pointer;font-family:var(--font);box-shadow:0 6px 28px rgba(74,222,128,.35);transition:all .2s;text-align:center}
.analise-btn-big:active{transform:scale(.98)}
.analise-btn-big.loading{background:linear-gradient(135deg,#1a3a2a,#0d2a2a);color:var(--green);animation:pulse2 1s ease infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.6}}
.analise-score-card{margin:14px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.asc-top{padding:20px;display:flex;align-items:center;gap:16px}
.asc-gauge{flex-shrink:0}
.asc-info h3{font-size:20px;font-weight:800;margin-bottom:4px}
.asc-info p{font-size:13px;line-height:1.4}
.asc-grade{font-size:48px;font-weight:800;font-family:var(--mono);line-height:1}
.asc-bars{padding:14px 20px 16px;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:10px}
.asc-bar-item label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;display:block;margin-bottom:4px}
.asc-bar-wrap{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:3px}
.asc-bar-fill{height:100%;border-radius:3px;transition:width 1s}
.asc-bar-val{font-size:11px;font-weight:700;font-family:var(--mono)}
.analise-section{margin:0 14px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadowsm)}
.analise-section h3{font-size:14px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.plano-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.plano-item:last-child{border-bottom:none}
.plano-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;margin-top:2px}
.plano-num.alta{background:var(--redb);color:var(--red)}
.plano-num.media{background:rgba(251,191,36,.15);color:var(--yellow)}
.plano-num.baixa{background:var(--greenb);color:var(--green)}
.plano-text{flex:1;font-size:13px;line-height:1.5;color:var(--text2)}
.plano-text strong{display:block;color:var(--text);font-size:14px;margin-bottom:3px}
.rel-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px}
.rel-btn{padding:14px;border-radius:var(--r);border:none;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .2s}
.rel-btn .rel-icon{font-size:26px}
.rel-btn.html-btn{background:linear-gradient(135deg,#1a2a3a,#0d1a2a);border:1px solid var(--blue);color:var(--blue)}
.rel-btn.pdf-btn{background:linear-gradient(135deg,#2a1a1a,#1a0d0d);border:1px solid var(--red);color:var(--red)}
.analise-empty{text-align:center;padding:48px 24px;color:var(--text3)}
.analise-empty .eic{font-size:52px;margin-bottom:14px}

/* ===== DASHBOARD CLARITY v11 ===== */
.bal-period-tag{
  font-size:12px;font-weight:700;color:var(--cyan);
  text-transform:uppercase;letter-spacing:1.5px;
  margin-bottom:6px;
}
.bal-formula{
  margin-top:10px;font-size:12px;
  display:flex;justify-content:center;gap:6px;flex-wrap:wrap;
  line-height:1.4;
}
.bal-formula .min{color:var(--green);font-weight:600}
.bal-formula .mout{color:var(--red);font-weight:600}
.bal-formula .mdiv{color:var(--text3)}
.bal-historico-row{
  margin-top:8px;padding:6px 12px;
  background:rgba(255,255,255,0.05);border-radius:8px;
  display:inline-flex;gap:6px;align-items:center;
}

/* Explanation tooltip on saldo */
.saldo-explain{
  font-size:11px;color:var(--text3);margin-top:4px;
  background:rgba(255,255,255,.04);border-radius:8px;
  padding:6px 10px;line-height:1.5;
}

/* Fix help HELPS object for painel */

/* ===== CÁLCULO EXPLICADO ===== */
.calc-explain-card{
  margin:0 14px 12px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r);
  padding:14px 16px;box-shadow:var(--shadowsm);
}
.ce-title{font-size:11px;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.ce-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;border-bottom:1px solid var(--border)}
.ce-row:last-of-type{border-bottom:none}
.ce-lbl{color:var(--text2);font-weight:600}
.ce-val{font-family:var(--mono);font-weight:800}
.ce-val.pos{color:var(--green)}.ce-val.neg{color:var(--red)}.ce-val.neu{color:var(--blue)}
.ce-result{display:flex;justify-content:space-between;align-items:center;padding:10px 0 0;margin-top:6px;border-top:2px solid var(--border2);font-size:14px;font-weight:800}

/* ===== APONTAMENTO MODAL v13 ===== */
.pag-choice-btn{
  display:flex;align-items:center;gap:14px;
  width:100%;padding:16px 18px;border:2px solid var(--border);
  border-radius:16px;cursor:pointer;font-family:var(--font);
  transition:all .2s;text-align:left;
  background:var(--bg3);color:var(--text);
}
.pag-choice-btn:active{transform:scale(.97)}
.pag-choice-btn.pago{border-color:var(--green);background:var(--greenb)}
.pag-choice-btn.pago:hover{background:rgba(61,220,132,.2)}
.pag-choice-btn.atrasado{border-color:var(--red);background:var(--redb)}
.pag-choice-btn.atrasado:hover{background:rgba(255,107,107,.2)}
.pag-choice-btn.pendente{border-color:var(--text3);background:var(--surface)}
.pag-choice-btn.pendente:hover{background:var(--surface2)}

/* ===== NOVO PAINEL SIMPLES v14 ===== */

/* HERO PRINCIPAL */
.hero-main{
  background:linear-gradient(160deg,#071a10 0%,#050d1a 100%);
  padding:28px 20px 22px;
  border-bottom:1px solid var(--border);
  text-align:center;
  position:relative;
}
.hero-top-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:6px}
.hero-lbl{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px}
.hero-saldo-acu{
  font-size:46px;font-weight:800;font-family:var(--mono);line-height:1;
  background:linear-gradient(135deg,#3ddc84,#22d3ee);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:4px;
}
.hero-saldo-acu.negativo{background:linear-gradient(135deg,#ff6b6b,#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-saldo-sub{font-size:12px;color:var(--text3);margin-bottom:16px;font-weight:500}

/* Barra de saúde financeira */
.hero-health-bar{
  height:8px;background:rgba(255,255,255,.08);border-radius:4px;
  overflow:hidden;margin:0 auto 6px;max-width:280px;
}
.hero-health-fill{height:100%;border-radius:4px;transition:width 1s var(--ease)}
.hero-health-label{font-size:13px;font-weight:800;margin-bottom:0}

/* RESUMO DO MÊS */
.mes-resumo-card{
  margin:14px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadowsm);
}
.mes-resumo-title{
  padding:10px 16px;font-size:12px;font-weight:700;
  color:var(--text3);background:var(--bg3);
  text-transform:uppercase;letter-spacing:.8px;
  border-bottom:1px solid var(--border);
}
.mes-resumo-grid{display:grid;grid-template-columns:1fr 1fr 1fr}
.mrs-item{
  padding:14px 10px;display:flex;align-items:center;gap:8px;
  border-right:1px solid var(--border);
}
.mrs-item:last-child{border-right:none}
.mrs-icon{
  width:32px;height:32px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;flex-shrink:0;
}
.mrs-item.entrou .mrs-icon{background:var(--greenb);color:var(--green)}
.mrs-item.saiu .mrs-icon{background:var(--redb);color:var(--red)}
.mrs-item.sobrou .mrs-icon{background:var(--blueb);color:var(--blue)}
.mrs-lbl{font-size:10px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.mrs-val{font-size:13px;font-weight:800;font-family:var(--mono)}
.mrs-item.entrou .mrs-val{color:var(--green)}
.mrs-item.saiu .mrs-val{color:var(--red)}
.mrs-item.sobrou .mrs-val{color:var(--blue)}

/* ALERTA PENDENTE */
.alerta-pendente{
  margin:0 14px 14px;background:rgba(251,191,36,.08);
  border:1px solid rgba(251,191,36,.3);border-radius:var(--r);
  padding:14px 16px;display:flex;align-items:center;gap:12px;
}
.ap-icon{font-size:24px;flex-shrink:0}
.ap-info{flex:1}
.ap-titulo{font-size:12px;color:var(--yellow);font-weight:700;margin-bottom:2px}
.ap-val{font-size:18px;font-weight:800;font-family:var(--mono);color:var(--yellow)}
.ap-btn{
  background:rgba(251,191,36,.15);border:1px solid rgba(251,191,36,.3);
  color:var(--yellow);border-radius:10px;padding:8px 12px;
  font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);white-space:nowrap;
}

/* AÇÕES RÁPIDAS */
.acoes-rapidas{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:8px;margin:0 14px 14px;
}
.ar-btn{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:12px 4px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  cursor:pointer;font-family:var(--font);font-size:11px;font-weight:700;
  color:var(--text2);transition:all .2s;
}
.ar-btn:active{transform:scale(.95)}
.ar-icon{font-size:22px;line-height:1}
.ar-btn.green{border-color:rgba(61,220,132,.3);color:var(--green);background:rgba(61,220,132,.06)}
.ar-btn.red{border-color:rgba(255,107,107,.3);color:var(--red);background:rgba(255,107,107,.06)}
.ar-btn.blue{border-color:rgba(77,166,255,.3);color:var(--blue);background:rgba(77,166,255,.06)}
.ar-btn.purple{border-color:rgba(181,123,238,.3);color:var(--purple);background:rgba(181,123,238,.06)}
.ar-btn.cyan{border-color:rgba(34,211,238,.3);color:var(--cyan);background:rgba(34,211,238,.06)}

/* ── VOICE INPUT ── */
.voice-ov{position:fixed;inset:0;background:rgba(8,14,26,.94);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;opacity:0;pointer-events:none;transition:opacity .3s}
.voice-ov.ativo{opacity:1;pointer-events:all}
.voice-waves{display:flex;align-items:flex-end;gap:5px;height:56px;margin-bottom:28px}
.voice-wave{width:5px;border-radius:3px;background:linear-gradient(to top,var(--green),var(--cyan));min-height:6px;animation:vwave 1s ease infinite}
.voice-wave:nth-child(1){animation-delay:0s}.voice-wave:nth-child(2){animation-delay:.1s}.voice-wave:nth-child(3){animation-delay:.2s}.voice-wave:nth-child(4){animation-delay:.15s}.voice-wave:nth-child(5){animation-delay:.05s}.voice-wave:nth-child(6){animation-delay:.25s}.voice-wave:nth-child(7){animation-delay:.1s}.voice-wave:nth-child(8){animation-delay:.2s}
@keyframes vwave{0%,100%{height:6px;opacity:.35}50%{height:50px;opacity:1}}
.voice-ov.parado .voice-wave{animation:none;height:6px;opacity:.25}
.voice-texto{font-size:21px;font-weight:700;color:var(--text);text-align:center;min-height:30px;margin-bottom:8px}
.voice-sub{font-size:13px;color:var(--text2);text-align:center;margin-bottom:28px;min-height:18px}
.voice-dicas{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px}
.voice-dica{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
.voice-dica:active{background:rgba(34,211,238,.12);border-color:var(--cyan);color:var(--cyan)}
.voice-cancelar{background:transparent;border:1px solid var(--border2);color:var(--text2);border-radius:30px;padding:12px 32px;font-size:14px;cursor:pointer;font-family:var(--font);transition:all .2s}
.voice-cancelar:active{border-color:var(--red);color:var(--red)}

/* PERIOD SELECTOR */
.period-selector-row{
  display:flex;align-items:center;gap:10px;
  padding:0 14px 14px;
}
.psr-lbl{font-size:12px;color:var(--text3);font-weight:700;white-space:nowrap}
