/* ================================================
   CLARIM — Controle Financeiro
   style.css
   ================================================ */

*{margin:0;padding:0;box-sizing:border-box}
/* ── TEMA ESCURO (padrão) ────────────────────────────────── */
:root{
  --bg:#0A0F1E;--bg2:#111827;--bg3:#1a2234;--bg4:#0d1526;
  --green:#4FFFB0;--red:#FF6B6B;--yellow:#FFD166;--blue:#60A5FA;--purple:#A78BFA;
  --text:#fff;--text2:rgba(255,255,255,0.6);--text3:rgba(255,255,255,0.3);
  --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.14);
  --f:'DM Sans',sans-serif;--fd:'Sora',sans-serif;
  /* derivadas — overrideáveis pelo tema */
  --shadow:none;
  --color-scheme:dark;
  --modal-overlay-bg:rgba(0,0,0,.78);
  --card-cc-end:#1e2d4a;
  --hover-bg:rgba(255,255,255,.025);
  --bar-track:rgba(255,255,255,.06);
  /* sidebar */
  --sb-bg:var(--bg2);
  --sb-text:var(--text2);
  --sb-text-hover:var(--text);
  --sb-active-bg:rgba(79,255,176,.06);
  --sb-hover-bg:var(--hover-bg);
  --sb-sec:var(--text3);
}

/* ── TEMA CLARO (Organizze-inspired) ─────────────────────── */
:root.theme-light{
  --bg:#f5f6fa;--bg2:#ffffff;--bg3:#eef0f6;--bg4:#e4e7f0;
  --green:#00a86b;--red:#e74c3c;--yellow:#c97f12;--blue:#2779bd;--purple:#7c3aed;
  --text:#1e2533;--text2:rgba(30,37,51,.62);--text3:rgba(30,37,51,.36);
  --border:rgba(30,37,51,.1);--border2:rgba(30,37,51,.17);
  --shadow:0 2px 14px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.04);
  --color-scheme:light;
  --modal-overlay-bg:rgba(50,60,80,.5);
  --card-cc-end:#d4daf5;
  --hover-bg:rgba(0,0,0,.035);
  --bar-track:rgba(0,0,0,.07);
  /* sidebar — alto contraste no tema claro */
  --sb-bg:#edf0f5;          /* cinza frio: cria profundidade contra o branco do conteúdo */
  --sb-text:#475569;        /* slate-600: legível sem ser preto total */
  --sb-text-hover:#1e2533;  /* quase preto no hover */
  --sb-active-bg:#ffffff;   /* branco no fundo cinza = destaque imediato */
  --sb-hover-bg:rgba(0,0,0,.06);
  --sb-sec:#7c8ca0;         /* cinza médio — seções visíveis mas hierarquicamente abaixo */
}
body{font-family:var(--f);background:var(--bg);color:var(--text);min-height:100vh}
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:2.5rem;width:400px;text-align:center;box-shadow:var(--shadow)}
.login-logo{font-family:var(--fd);font-size:2rem;font-weight:700;margin-bottom:.4rem}
.login-logo span{color:var(--green)}
.login-sub{color:var(--text2);font-size:.9rem;margin-bottom:2rem}
.lf{margin-bottom:1rem;text-align:left}
.lf label{font-size:.8rem;color:var(--text2);display:block;margin-bottom:5px}
.lf input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;color:var(--text);font-family:var(--f);font-size:.95rem;outline:none}
.lf input:focus{border-color:rgba(79,255,176,.4)}
.btn-login{width:100%;background:var(--green);color:#0A0F1E;border:none;padding:.85rem;border-radius:50px;font-family:var(--fd);font-weight:600;font-size:1rem;cursor:pointer;margin-top:.5rem}
.login-hint{font-size:.72rem;color:var(--text3);margin-top:1rem}
#app{display:none;min-height:100vh}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:220px;background:var(--sb-bg);border-right:1px solid var(--border);padding:1.5rem 0;display:flex;flex-direction:column;z-index:50;transition:background .25s}
.sb-logo{font-family:var(--fd);font-size:1.4rem;font-weight:700;padding:0 1.5rem;margin-bottom:1.5rem}
.sb-logo span{color:var(--green)}
.sb-sec{font-size:.62rem;color:var(--sb-sec);text-transform:uppercase;letter-spacing:1.5px;padding:.5rem 1.5rem;margin-top:.3rem}
.sb-item{display:flex;align-items:center;gap:10px;padding:.65rem 1.5rem;cursor:pointer;color:var(--sb-text);font-size:.875rem;transition:color .18s,background .18s;border-left:3px solid transparent}
.sb-item:hover{color:var(--sb-text-hover);background:var(--sb-hover-bg)}
.sb-item.active{color:var(--green);background:var(--sb-active-bg);border-left-color:var(--green)}
.sb-item .ic{font-size:15px;width:18px;text-align:center;transition:inherit}
.sb-user{padding:1rem 1.5rem;border-top:1px solid var(--border)}
.sb-name{font-size:.85rem;font-weight:500;color:var(--sb-text-hover)}
.sb-plan{font-size:.7rem;color:var(--green)}
.sb-out{font-size:.72rem;color:var(--sb-sec);cursor:pointer;margin-top:3px;transition:color .18s}
.sb-out:hover{color:var(--red)}
.main{margin-left:220px;padding:2rem;min-height:100vh}
.page{display:none}.page.active{display:block}
.pg-title{font-family:var(--fd);font-size:1.5rem;font-weight:700;margin-bottom:.25rem}
.pg-sub{color:var(--text2);font-size:.875rem;margin-bottom:1.5rem}
.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.scard{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.2rem 1.4rem;box-shadow:var(--shadow)}

/* ── Category Segmented Control ─────────────────────────── */
.cat-filters{
  display:flex;gap:0;background:var(--bg3);border-radius:50px;
  padding:3px;border:1px solid var(--border);flex-shrink:0
}
.cat-filter-btn{
  padding:.36rem .95rem;border:none;border-radius:50px;
  background:none;color:var(--text2);font-family:var(--f);
  font-size:.78rem;cursor:pointer;white-space:nowrap;
  transition:background .2s,color .2s,font-weight .2s
}
.cat-filter-btn:hover:not(.active){background:var(--hover-bg);color:var(--text)}
.cat-filter-btn.active{
  background:var(--green);color:#0A0F1E;font-weight:600
}
html.theme-light .cat-filter-btn.active{color:#fff}
/* Tipo badge nos cards */
.cat-tipo-badge{
  font-size:.68rem;color:var(--text3);margin-top:.25rem;
  text-transform:capitalize;letter-spacing:.3px
}
/* ── Category Search ──────────────────────────────────────── */
.cat-search-wrap{
  position:relative;display:flex;align-items:center;flex:1;max-width:300px
}
.cat-search-icon{
  position:absolute;left:.75rem;font-size:.88rem;pointer-events:none;
  line-height:1;top:50%;transform:translateY(-50%)
}
.cat-search-input{
  width:100%;background:var(--bg2);border:1px solid var(--border);
  border-radius:10px;padding:.55rem .9rem .55rem 2.15rem;
  color:var(--text);font-family:var(--f);font-size:.85rem;outline:none
}
.cat-search-input:focus{border-color:rgba(79,255,176,.35)}
html.theme-light .cat-search-input{background:#f8f9fa}
html.theme-light .cat-search-input:focus{border-color:rgba(0,168,107,.4)}
/* Card: animação de entrada e saída suave */
.cat-card{
  animation:catFadeIn .22s ease both;
  transition:opacity .18s,transform .18s
}
.cat-card.cat-hidden{
  display:none
}
@keyframes catFadeIn{
  from{opacity:0;transform:scale(.96) translateY(4px)}
  to  {opacity:1;transform:scale(1)   translateY(0)}
}
/* Empty state */
#cats-empty-state{
  grid-column:1/-1;padding:2.5rem 1rem;text-align:center;
  color:var(--text3);font-size:.85rem
}
#cats-empty-state::before{content:'🔍';display:block;font-size:2rem;margin-bottom:.5rem}
.sc-label{font-size:.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.sc-value{font-family:var(--fd);font-size:1.35rem;font-weight:700}
.sc-sub{font-size:.72rem;color:var(--text3);margin-top:3px}
.c-green{color:var(--green)}.c-red{color:var(--red)}.c-yellow{color:var(--yellow)}.c-blue{color:var(--blue)}
.panel{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.3rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}
.panel-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.panel-title{font-family:var(--fd);font-size:.95rem;font-weight:600}
.panel-action{font-size:.75rem;color:var(--green);cursor:pointer;background:rgba(79,255,176,.1);border:1px solid rgba(79,255,176,.2);border-radius:6px;padding:3px 10px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}
.month-nav{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.mn-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:15px}
.mn-label{font-family:var(--fd);font-size:1rem;font-weight:600;min-width:130px;text-align:center}
.toolbar{display:flex;gap:.75rem;margin-bottom:1.2rem;align-items:center;flex-wrap:wrap}
.search-box{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:.55rem .9rem;color:var(--text);font-family:var(--f);font-size:.85rem;outline:none;min-width:180px}
.search-box:focus{border-color:rgba(79,255,176,.3)}
.fsel{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:.55rem .9rem;color:var(--text2);font-family:var(--f);font-size:.78rem;outline:none;cursor:pointer}
.fsel option{background:var(--bg2)}
.btn-add{background:var(--green);color:#0A0F1E;border:none;border-radius:10px;padding:.55rem 1.1rem;font-family:var(--fd);font-weight:600;font-size:.82rem;cursor:pointer;white-space:nowrap}
.btn-danger{background:rgba(255,107,107,.15);color:var(--red);border:1px solid rgba(255,107,107,.4);border-radius:10px;padding:.55rem 1.1rem;font-family:var(--fd);font-weight:600;font-size:.82rem;cursor:pointer;white-space:nowrap}
.btn-danger:hover{background:rgba(255,107,107,.28);border-color:rgba(255,107,107,.65)}
.row-cb{width:15px;height:15px;accent-color:var(--red);cursor:pointer;flex-shrink:0}
/* TABLE */
/* Scroll wrapper — habilita scroll horizontal em telas estreitas */
.tbl-scroll-x{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px}
.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
/* Despesas: grid estrito — 40+100+100+200+150+120+90+130 = 930px base + gaps */
.desp-grid{grid-template-columns:40px 100px 100px minmax(200px,1fr) 150px 120px 90px 130px;gap:12px}
.tbl-scroll-x .tbl-wrap{min-width:1050px}
.tbl-head{display:grid;padding:.65rem 1.1rem;background:var(--bg3);font-size:.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;user-select:none}
.tbl-head .th{display:flex;align-items:center;gap:4px;cursor:pointer;user-select:none;transition:color .15s;min-width:0}
.tbl-head .th:hover{color:var(--text)}
.tbl-head .th.sorted{color:var(--green)}
.sort-arrow{font-size:.65rem;font-weight:700;margin-left:2px;color:var(--green)}
.tbl-row{display:grid;padding:.7rem 1.1rem;border-top:1px solid var(--border);align-items:center;transition:background .15s}
.tbl-row>*{min-width:0}
.tbl-row:hover{background:var(--hover-bg)}
.td-date{font-size:.78rem;color:var(--text2);white-space:nowrap}
.td-desc{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px}
.td-sub{font-size:.68rem;color:var(--text3)}
.td-cat{font-size:.72rem;color:var(--text3)}
.td-val-neg{font-size:.85rem;font-weight:500;color:var(--text);text-align:right}
.td-val-pos{font-size:.85rem;font-weight:500;color:var(--green);text-align:right}
.badge{border-radius:50px;padding:2px 9px;font-size:.68rem}
.b-pago{background:rgba(79,255,176,.15);color:var(--green);border:1px solid rgba(79,255,176,.3)}
.b-recebido{background:rgba(79,255,176,.15);color:var(--green);border:1px solid rgba(79,255,176,.3)}
.b-avencer{background:rgba(255,209,102,.12);color:var(--yellow);border:1px solid rgba(255,209,102,.3)}
.b-previsto{background:rgba(255,209,102,.12);color:var(--yellow);border:1px solid rgba(255,209,102,.3)}
.b-atrasado{background:rgba(255,107,107,.12);color:var(--red);border:1px solid rgba(255,107,107,.3)}
.b-recebido{background:rgba(79,255,176,.1);color:var(--green)}
.b-previsto{background:rgba(96,165,250,.1);color:var(--blue)}
.btn-sm{border-radius:6px;padding:3px 9px;font-size:.7rem;cursor:pointer;font-family:var(--f);border:1px solid;transition:all .15s}
.btn-baixa{background:rgba(79,255,176,.1);color:var(--green);border-color:rgba(79,255,176,.25)}
.btn-edit{background:rgba(96,165,250,.1);color:var(--blue);border-color:rgba(96,165,250,.25)}
.btn-del{background:rgba(255,107,107,.1);color:var(--red);border-color:rgba(255,107,107,.25)}
.pag{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-top:1px solid var(--border)}
.pag-info{font-size:.78rem;color:var(--text3)}
.pag-btns{display:flex;gap:5px}
.pag-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:3px 9px;border-radius:6px;cursor:pointer;font-size:.78rem}
.pag-btn.active{border-color:var(--green);color:var(--green)}
/* AI chips (shared) */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.ai-chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:5px 13px;border-radius:50px;font-size:.75rem;cursor:pointer;transition:border-color .15s,color .15s}
.ai-chip:hover{border-color:var(--green);color:var(--green)}
/* ── Clarim IA Page ── */
#page-ia.active{display:flex;flex-direction:column;height:calc(100vh - 4rem);padding-bottom:0}
.ai-page-wrap{display:flex;flex-direction:column;height:100%;max-width:760px;margin:0 auto;width:100%}
.ai-page-hero{text-align:center;padding:1.2rem 0 .8rem;position:relative}
.ai-page-glow{position:absolute;top:0;left:50%;transform:translateX(-50%);width:400px;height:130px;background:radial-gradient(ellipse at center,rgba(0,255,163,.13) 0%,transparent 70%);pointer-events:none}
.ai-page-icon{font-size:2.2rem;line-height:1;margin-bottom:.3rem}
.ai-page-title{font-family:var(--fd);font-size:1.6rem;font-weight:700;background:linear-gradient(135deg,#00ffa3,#03dac5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ai-page-sub{font-size:.78rem;color:var(--text3);margin-top:.15rem}
.ai-page-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:.9rem}
.ai-page-body{flex:1;overflow-y:auto;border-radius:14px;border:1px solid rgba(0,255,163,.1);background:linear-gradient(180deg,rgba(0,255,163,.03) 0%,rgba(3,218,197,.03) 100%);padding:.9rem 1rem;margin-bottom:.75rem;display:flex;flex-direction:column;gap:.6rem}
.ai-page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:.5rem;color:var(--text3);padding:2rem 0}
.ai-empty-icon{font-size:2.5rem;opacity:.5}
.ai-empty-hint{font-size:.73rem;opacity:.7}
.ai-bubble-user{align-self:flex-end;background:var(--bg3);border:1px solid var(--border);border-radius:16px 16px 4px 16px;padding:.6rem 1rem;font-size:.85rem;max-width:78%;color:var(--text);word-break:break-word}
.ai-bubble-bot{align-self:flex-start;background:rgba(0,255,163,.06);border:1px solid rgba(0,255,163,.18);border-left:3px solid var(--green);border-radius:4px 16px 16px 16px;padding:.65rem 1rem;font-size:.85rem;max-width:82%;color:var(--text2);line-height:1.6;word-break:break-word}
.ai-bubble-thinking{opacity:.55;font-style:italic}
.ai-md-line{line-height:1.55;min-height:1.1em}
.ai-md-item{line-height:1.55;padding-left:.2rem}
.ai-md-gap{height:.5rem}
.ai-bubble-bot strong{color:var(--text);font-weight:600}
.ai-bubble-err{border-color:rgba(239,68,68,.3);border-left-color:var(--red);background:rgba(239,68,68,.06);color:var(--red)}
.ai-page-input-bar{display:flex;gap:8px;padding:.6rem 0 .5rem;border-top:1px solid var(--border);background:var(--bg1);position:sticky;bottom:0}
.ai-page-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:.65rem 1.2rem;color:var(--text);font-family:var(--f);font-size:.88rem;outline:none;transition:border-color .2s}
.ai-page-input:focus{border-color:rgba(0,255,163,.45)}
.ai-page-send{background:linear-gradient(135deg,#00ffa3,#03dac5);color:#0A0F1E;border:none;border-radius:50px;padding:.65rem 1.5rem;font-family:var(--fd);font-weight:700;font-size:.82rem;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}
.ai-page-send:hover{opacity:.88}
.ai-page-send:active{transform:scale(.95)}
/* ── Confirmation card ── */
.ai-confirm-card{padding:1rem !important;border-color:rgba(0,255,163,.28) !important;background:var(--bg2) !important}
.ai-confirm-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.65rem}
.ai-confirm-icon{font-size:1.5rem;line-height:1;flex-shrink:0;margin-top:.1rem}
.ai-confirm-info{flex:1;min-width:0}
.ai-confirm-type{font-size:.68rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:.15rem}
.ai-confirm-desc{font-size:.92rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-confirm-valor{font-family:var(--fd);font-size:1.05rem;font-weight:700;flex-shrink:0;padding-top:.1rem}
.ai-confirm-details{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.55rem}
.ai-confirm-tag{background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:2px 9px;font-size:.71rem;color:var(--text2)}
.ai-tag-pago{background:rgba(0,255,163,.1);border:1px solid rgba(0,255,163,.3);border-radius:50px;padding:2px 9px;font-size:.71rem;color:var(--green)}
.ai-tag-pend{background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:2px 9px;font-size:.71rem;color:var(--text3)}
.ai-confirm-hint{font-size:.77rem;color:var(--text3);margin-bottom:.7rem;font-style:italic}
.ai-confirm-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.ai-confirm-btn{background:linear-gradient(135deg,#00ffa3,#03dac5);color:#0A0F1E;border:none;border-radius:50px;padding:.48rem 1.1rem;font-family:var(--fd);font-weight:700;font-size:.78rem;cursor:pointer;transition:opacity .15s,transform .1s}
.ai-confirm-btn:hover{opacity:.88}.ai-confirm-btn:active{transform:scale(.95)}.ai-confirm-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.ai-confirm-cancel{background:none;border:1px solid var(--border);border-radius:50px;padding:.48rem 1rem;font-family:var(--f);font-size:.78rem;color:var(--text3);cursor:pointer;transition:border-color .15s,color .15s}
.ai-confirm-cancel:hover{border-color:var(--red);color:var(--red)}
.ai-confirm-success-card{background:rgba(0,255,163,.05) !important;border-color:rgba(0,255,163,.25) !important}
.ai-confirm-success{font-size:.85rem;color:var(--green);line-height:1.5}
/* ── Campos interativos do fluxo guiado ── */
.ai-field-prompt{padding:.75rem 1rem !important}
.ai-field-label{font-size:.83rem;color:var(--text2);margin-bottom:.6rem;line-height:1.4}
.ai-field-opts{display:flex;gap:.5rem;flex-wrap:wrap}
.ai-field-btn{background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:.45rem 1.2rem;font-family:var(--f);font-size:.82rem;color:var(--text);cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.ai-field-btn:hover:not(:disabled){border-color:var(--green);color:var(--green)}
.ai-field-btn.ai-field-btn-rec:hover:not(:disabled){border-color:#03dac5;color:#03dac5}
.ai-field-btn:disabled{opacity:.4;cursor:not-allowed}
.ai-field-btn.ai-chip-sel{background:rgba(0,255,163,.12);border-color:var(--green);color:var(--green);opacity:1}
.ai-field-btn.ai-field-btn-rec.ai-chip-sel{background:rgba(3,218,197,.1);border-color:#03dac5;color:#03dac5}
.ai-field-chips{display:flex;gap:.4rem;flex-wrap:wrap}
.ai-chip-opt{background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:3px 12px;font-family:var(--f);font-size:.75rem;color:var(--text2);cursor:pointer;transition:border-color .15s,color .15s,background .15s;line-height:1.6}
.ai-chip-opt:hover:not(:disabled){border-color:var(--green);color:var(--green)}
.ai-chip-opt:disabled{opacity:.35;cursor:not-allowed}
.ai-chip-opt.ai-chip-sel{background:rgba(0,255,163,.12);border-color:var(--green);color:var(--green);opacity:1}
html.theme-light .ai-field-btn{background:var(--bg3);color:var(--text)}
html.theme-light .ai-chip-opt{background:var(--bg3);color:var(--text2)}
html.theme-light .ai-chip-opt.ai-chip-sel,html.theme-light .ai-field-btn.ai-chip-sel{background:rgba(0,168,107,.1);border-color:var(--green);color:var(--green)}
/* ── Botão cancelar (tom vermelho suave) ── */
.ai-field-btn-cancel{background:rgba(255,80,80,.07);border-color:rgba(255,80,80,.3);color:#ff8888}
.ai-field-btn-cancel:hover:not(:disabled){background:rgba(255,80,80,.15);border-color:#ff6060;color:#fff}
/* ── Preview da série na desambiguação ── */
.ai-serie-preview{margin:.4rem 0 .75rem;padding:.5rem .75rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;gap:.2rem}
.ai-serie-preview strong{font-size:.88rem;color:var(--text1)}
.ai-serie-preview span{font-size:.76rem;color:var(--text2)}
html.theme-light .ai-serie-preview{background:rgba(0,0,0,.03)}
/* ── Edição inline na prévia ── */
/* Qualquer elemento com ai-tag-edit vira clicável e revela o ícone ✏️ ao hover */
.ai-tag-edit{cursor:pointer;position:relative;transition:border-color .15s,color .15s,opacity .15s}
.ai-tag-edit:hover{border-color:var(--green) !important;color:var(--green) !important}
.ai-confirm-desc.ai-tag-edit:hover,.ai-confirm-valor.ai-tag-edit:hover{opacity:.8}
.ai-edit-ico{font-size:.65em;opacity:0;margin-left:.25rem;transition:opacity .15s;pointer-events:none}
.ai-tag-edit:hover .ai-edit-ico{opacity:.85}
/* Light theme overrides */
html.theme-light .ai-bubble-bot{background:rgba(0,168,107,.06);border-color:rgba(0,168,107,.2);border-left-color:var(--green)}
html.theme-light .ai-page-body{background:linear-gradient(180deg,rgba(0,168,107,.03) 0%,rgba(3,218,197,.03) 100%);border-color:rgba(0,168,107,.12)}
html.theme-light .ai-confirm-card{background:var(--bg2) !important;border-color:rgba(0,168,107,.3) !important}
html.theme-light .ai-tag-pago{background:rgba(0,168,107,.1);border-color:rgba(0,168,107,.3);color:var(--green)}
/* VENCIMENTOS no dashboard — clicáveis */
.venc-row{display:flex;align-items:center;gap:9px;padding:.55rem .7rem;border-radius:10px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.venc-row:hover{background:rgba(255,255,255,.03)}
.venc-row:last-child{border-bottom:none}
.venc-ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.venc-info{flex:1;min-width:0}
.venc-nm{font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.venc-dt{font-size:.68rem;color:var(--text3)}
.venc-val{font-size:.82rem;font-weight:500;flex-shrink:0}
.cat-row{display:flex;align-items:center;gap:9px;padding:.4rem 0}
.cat-bar-w{flex:1;background:var(--bar-track);border-radius:50px;height:5px;overflow:hidden}
.cat-bar{height:100%;border-radius:50px}
.cat-nm{font-size:.78rem;min-width:110px}
.cat-vl{font-size:.78rem;color:var(--text2);min-width:75px;text-align:right}
/* CARTOES */
.card-cc{background:linear-gradient(135deg,var(--bg3),var(--card-cc-end));border:1px solid rgba(96,165,250,.25);border-radius:14px;padding:1.2rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.card-cc:hover{border-color:rgba(96,165,250,.5);transform:translateY(-2px)}
.cc-name{font-family:var(--fd);font-size:1rem;font-weight:600;margin-bottom:.3rem}
.cc-limit{font-size:.75rem;color:var(--text3);margin-bottom:.8rem}
.cc-used{font-family:var(--fd);font-size:1.4rem;font-weight:700;color:var(--blue)}
.cc-footer{display:flex;justify-content:space-between;margin-top:.8rem;font-size:.72rem;color:var(--text3)}
.cc-bar-wrap{background:rgba(255,255,255,.08);border-radius:50px;height:4px;margin-top:.5rem;overflow:hidden}
.cc-bar{height:100%;border-radius:50px;background:var(--blue)}
/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:var(--modal-overlay-bg);z-index:200;align-items:flex-start;justify-content:center;overflow-y:auto;padding:2rem 1rem}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:1.8rem;width:520px;max-width:100%;margin:auto;box-shadow:0 8px 40px rgba(0,0,0,.25)}
.modal-title{font-family:var(--fd);font-size:1.1rem;font-weight:600;margin-bottom:1.3rem}
.fr{margin-bottom:.9rem}
.fr label{font-size:.78rem;color:var(--text2);display:block;margin-bottom:5px}
.fr input,.fr select,.fr textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:.65rem .9rem;color:var(--text);font-family:var(--f);font-size:.875rem;outline:none}
.fr input:focus,.fr select:focus{border-color:rgba(79,255,176,.35)}
.fr select option{background:var(--bg2)}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.9rem}
.modal-btns{display:flex;gap:.9rem;margin-top:1.3rem}
.btn-cancel{flex:1;background:transparent;border:1px solid var(--border);color:var(--text2);padding:.65rem;border-radius:9px;font-family:var(--f);cursor:pointer}
.btn-save{flex:1;background:var(--green);color:#0A0F1E;border:none;padding:.65rem;border-radius:9px;font-family:var(--fd);font-weight:600;cursor:pointer}
.tipo-tabs{display:flex;gap:.5rem;margin-bottom:1rem}
.tipo-tab{flex:1;padding:.5rem;border-radius:9px;border:1px solid var(--border);color:var(--text2);font-size:.8rem;cursor:pointer;text-align:center;transition:all .2s;background:transparent}
.tipo-tab.active{background:rgba(79,255,176,.1);border-color:rgba(79,255,176,.4);color:var(--green);font-weight:500}
.tipo-tab.active.cartao{background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.4);color:var(--blue)}
.rec-opts{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem}
.rec-opt{padding:4px 10px;border-radius:50px;border:1px solid var(--border);color:var(--text2);font-size:.75rem;cursor:pointer;background:transparent}
.rec-opt.active{background:rgba(79,255,176,.1);border-color:rgba(79,255,176,.4);color:var(--green)}
.baixa-box{background:var(--bg3);border-radius:10px;padding:.9rem;margin-bottom:.9rem}
.baixa-row{display:flex;justify-content:space-between;font-size:.83rem;padding:3px 0}
.baixa-row span:first-child{color:var(--text2)}
.ajuste-info{font-size:.7rem;color:var(--text3);margin-top:3px}
.tag{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;padding:2px 7px;border-radius:50px}
.tag-deb{background:rgba(79,255,176,.1);color:var(--green);border:1px solid rgba(79,255,176,.2)}
.tag-cc{background:rgba(96,165,250,.1);color:var(--blue);border:1px solid rgba(96,165,250,.2)}
.empty{text-align:center;padding:2.5rem;color:var(--text3);font-size:.875rem}
/* CONFIRM DIALOG */
.confirm-box{background:var(--bg2);border:1px solid var(--yellow);border-radius:16px;padding:1.5rem;width:420px;max-width:95vw;margin:auto;text-align:center}
.confirm-box h3{font-family:var(--fd);font-size:1rem;margin-bottom:.6rem}
.confirm-box p{font-size:.85rem;color:var(--text2);margin-bottom:1.3rem;line-height:1.5}
.confirm-btns{display:flex;gap:.8rem}
.btn-confirm-one{flex:1;background:rgba(96,165,250,.15);color:var(--blue);border:1px solid rgba(96,165,250,.3);padding:.65rem;border-radius:9px;cursor:pointer;font-family:var(--f);font-size:.85rem}
.btn-confirm-all{flex:1;background:rgba(255,209,102,.15);color:var(--yellow);border:1px solid rgba(255,209,102,.3);padding:.65rem;border-radius:9px;cursor:pointer;font-family:var(--f);font-size:.85rem}
.btn-confirm-cancel{flex:1;background:transparent;color:var(--text3);border:1px solid var(--border);padding:.65rem;border-radius:9px;cursor:pointer;font-family:var(--f);font-size:.85rem}
/* TOAST */
.toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(100px);background:var(--bg2);border:1px solid var(--green);border-radius:12px;padding:.75rem 1.4rem;font-size:.83rem;color:var(--green);z-index:9999;opacity:0;transition:all .3s;white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
/* ── Mobile bottom navigation ─────────────────────────────── */
.mob-nav{display:none}
.mob-drawer-overlay{display:none}
.mob-drawer{display:none}

@media(max-width:768px){
  /* Ocultar sidebar lateral */
  .sidebar{display:none}
  .main{margin-left:0;padding:.9rem;padding-bottom:calc(82px + env(safe-area-inset-bottom))}

  /* Layout */
  .cards4{grid-template-columns:1fr 1fr;gap:.7rem}
  .cards3{grid-template-columns:1fr 1fr;gap:.7rem}
  .grid2{grid-template-columns:1fr}
  .tbl-head{display:none}
  .tbl-row{grid-template-columns:1fr auto!important;gap:3px}
  .tbl-scroll-x .tbl-head{display:grid}
  .tbl-scroll-x .tbl-row.desp-grid{grid-template-columns:40px 100px 100px minmax(200px,1fr) 150px 120px 90px 130px!important;gap:12px}
  .td-cat,.hide-m{display:none}
  .tbl-scroll-x .td-cat{display:block}
  /* Modais: borda arredondada só no topo, 100% largura */
  .modal-overlay{padding:0;align-items:flex-end}
  .modal{width:100%;max-width:100%;border-radius:16px 16px 0 0;padding:1.4rem 1.2rem}
  .fr2,.fr3{grid-template-columns:1fr}
  .login-box{width:94vw;padding:2rem 1.4rem}
  .toolbar{gap:.5rem}
  .search-box{width:100%;min-width:unset}
  .btn-add{width:100%}

  /* ── Barra de navegação inferior ───────────────────────── */
  .mob-nav{
    display:-webkit-box;
    display:-webkit-flex;
    display:flex;
    position:fixed;
    bottom:0;left:0;right:0;
    /* altura base + safe area do iPhone notch */
    height:calc(60px + env(safe-area-inset-bottom));
    padding-bottom:env(safe-area-inset-bottom);
    background:var(--bg2);
    border-top:1px solid var(--border);
    z-index:999;
    -webkit-box-align:center;
    -webkit-align-items:center;
    align-items:center;
    -webkit-justify-content:space-around;
    justify-content:space-around;
    /* força GPU no Safari iOS */
    -webkit-transform:translateZ(0);
    transform:translateZ(0);
    box-sizing:border-box;
  }
  .mob-nav-item{
    display:-webkit-box;
    display:-webkit-flex;
    display:flex;
    -webkit-box-orient:vertical;
    -webkit-flex-direction:column;
    flex-direction:column;
    -webkit-box-align:center;
    -webkit-align-items:center;
    align-items:center;
    -webkit-justify-content:center;
    justify-content:center;
    gap:2px;-webkit-box-flex:1;-webkit-flex:1;flex:1;
    height:60px; /* altura fixa, sem safe area */
    background:none;border:none;cursor:pointer;
    color:#64748b;font-family:var(--f);font-size:.6rem;font-weight:600;
    -webkit-transition:color .15s;transition:color .15s;
    padding:0 2px;-webkit-tap-highlight-color:transparent;
  }
  .mob-nav-item:hover,.mob-nav-item.mob-active{color:var(--green)}
  .mob-nav-ic{font-size:1.15rem;line-height:1;display:block}
  .mob-nav-lbl{line-height:1;margin-top:1px;display:block}

  /* Botão FAB central */
  .mob-nav-fab{
    display:-webkit-box;
    display:-webkit-flex;
    display:flex;
    -webkit-box-align:center;-webkit-align-items:center;align-items:center;
    -webkit-justify-content:center;justify-content:center;
    width:48px;height:48px;border-radius:50%;
    background:var(--green);border:none;
    color:#0A0F1E;font-size:1.6rem;font-weight:700;line-height:1;
    box-shadow:0 4px 16px rgba(79,255,176,.35);
    cursor:pointer;
    -webkit-transition:transform .15s,box-shadow .15s;
    transition:-webkit-transform .15s,box-shadow .15s;
    -webkit-flex-shrink:0;flex-shrink:0;
    margin-bottom:4px;
    -webkit-tap-highlight-color:transparent;
    -webkit-appearance:none;appearance:none;
  }
  .mob-nav-fab:active{
    -webkit-transform:scale(.93);transform:scale(.93);
    box-shadow:0 2px 8px rgba(79,255,176,.2);
  }

  /* ── Drawer lateral "Mais" ──────────────────────────────── */
  .mob-drawer-overlay{
    display:block;
    position:fixed;
    top:0;left:0;right:0;bottom:0; /* sem inset: não suportado Safari iOS ≤14 */
    z-index:1000;
    background:rgba(0,0,0,.55);
    opacity:0;pointer-events:none;
    -webkit-transition:opacity .22s;transition:opacity .22s;
  }
  .mob-drawer-overlay.open{opacity:1;pointer-events:auto}

  .mob-drawer{
    display:-webkit-box;
    display:-webkit-flex;
    display:flex;
    -webkit-box-orient:vertical;
    -webkit-flex-direction:column;
    flex-direction:column;
    position:fixed;
    top:0;right:0;bottom:0; /* sem inset: não suportado Safari iOS ≤14 */
    width:80vw;max-width:300px; /* sem min(): não suportado Safari iOS ≤10 */
    z-index:1001;
    background:var(--bg2);border-left:1px solid var(--border);
    padding-top:max(env(safe-area-inset-top),1.5rem);
    padding-bottom:calc(env(safe-area-inset-bottom) + 1rem);
    -webkit-transform:translateX(100%);transform:translateX(100%);
    -webkit-transition:-webkit-transform .25s cubic-bezier(.4,0,.2,1);
    transition:transform .25s cubic-bezier(.4,0,.2,1);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch; /* momentum scroll no iOS */
  }
  .mob-drawer.open{-webkit-transform:translateX(0);transform:translateX(0)}

  .mob-drawer-header{
    padding:1.1rem 1.25rem .75rem;
    font-family:var(--fd);font-size:.72rem;font-weight:700;
    color:var(--text3);text-transform:uppercase;letter-spacing:.08em;
    border-bottom:1px solid var(--border);margin-bottom:.35rem;
  }
  .mob-drawer-item{
    display:-webkit-box;display:-webkit-flex;display:flex;
    -webkit-box-align:center;-webkit-align-items:center;align-items:center;
    gap:.85rem;padding:.85rem 1.25rem;cursor:pointer;
    font-size:.9rem;font-weight:500;color:var(--text2);
    -webkit-transition:background .12s,color .12s;transition:background .12s,color .12s;
  }
  .mob-drawer-item:hover,.mob-drawer-item.mob-active{
    background:rgba(79,255,176,.06);color:var(--green);
  }
  .mob-drawer-ic{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}
}

.sh{cursor:pointer;user-select:none;display:inline-flex;align-items:center;gap:2px}
.sh:hover{color:var(--green)}.sh.asc,.sh.desc{color:var(--green)}
.sh::after{content:"↕";font-size:.65rem;opacity:.4;margin-left:2px}
.sh.asc::after{content:"↑";opacity:1}.sh.desc::after{content:"↓";opacity:1}
.venc-row{cursor:pointer;transition:background .15s;border-radius:7px;margin:0 -4px;padding:4px}
.venc-row:hover{background:rgba(79,255,176,.05)}
.dash-hint{font-size:.68rem;color:var(--text3);margin-bottom:.6rem;font-style:italic}
.st-sel{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:2px 5px;color:var(--text);font-size:.68rem;cursor:pointer;outline:none}
.cor-opt{transition:transform .15s}.cor-opt:hover{transform:scale(1.2)}
.btn-imp-exp{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:10px;padding:.55rem .9rem;font-size:.78rem;cursor:pointer}
.btn-imp-exp:hover{border-color:var(--green);color:var(--green)}
.exp-relat-btn:hover{border-color:var(--green)!important;cursor:pointer}

.cat-card:hover{border-color:var(--green)!important;transform:translateY(-2px)}

/* ===== AUTH / LOGIN EXTRAS ===== */
.login-box select{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  border-radius:10px;padding:.75rem 1rem;color:var(--text);
  font-family:var(--f);font-size:.95rem;outline:none;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.login-box select:focus{border-color:rgba(79,255,176,.4)}
.login-box input:focus{border-color:rgba(79,255,176,.4)}
#auth-error{animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.btn-login:disabled{opacity:.6;cursor:not-allowed}

/* badge clicável (reversão pago → pendente) */
.badge-rev{cursor:pointer;transition:opacity .15s;display:inline-block}
.badge-rev:hover{opacity:.7}

/* btn-action (gerado pelo app.js nas linhas de tabela) */
.btn-action{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:3px 9px;font-size:.72rem;cursor:pointer;font-family:var(--f);transition:background .15s,border-color .15s,color .15s,transform .08s;white-space:nowrap}
.btn-action:hover{border-color:var(--green);color:var(--green)}
.btn-action:active{transform:scale(0.93);filter:brightness(0.9)}
.btn-action.btn-del{background:rgba(255,107,107,.08);border-color:rgba(255,107,107,.2);color:var(--red)}
.btn-action.btn-del:hover{background:rgba(255,107,107,.18)}
.btn-action.btn-del:active{transform:scale(0.93)}
/* Linha aguardando confirmação do Firebase (atualização otimista em voo) */
.row-pending{opacity:.55;pointer-events:none;transition:opacity .15s}

/* ── Relatórios — Performance Cards ─────────────────────── */
.relat-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}
.relat-period-lbl{font-size:.82rem;color:var(--text2);white-space:nowrap}
.relat-period-controls{display:flex;gap:.5rem}
.relat-sel{background:var(--bg2);border:1px solid var(--border2);border-radius:10px;padding:.42rem .75rem;color:var(--text);font-family:var(--f);font-size:.85rem;outline:none;cursor:pointer;transition:border-color .15s}
.relat-sel:hover,.relat-sel:focus{border-color:var(--green)}
.perf-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.perf-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.4rem 1.2rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.45rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.perf-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.perf-icon{font-size:1.5rem;line-height:1}
.gauge-svg{display:block}
.gauge-empty{width:90px;height:90px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--text3);background:var(--bg3);border-radius:50%;border:3px dashed var(--border2)}
.perf-kpi{font-family:var(--fd);font-size:1.55rem;font-weight:700;line-height:1.1;margin:.2rem 0}
.perf-kpi-red{color:var(--red)}
.perf-kpi-green{color:var(--green)}
.perf-title{font-family:var(--fd);font-size:.88rem;font-weight:600;color:var(--text)}
.perf-sub{font-size:.72rem;color:var(--text2);line-height:1.45;max-width:170px}
.perf-ok{font-size:.68rem;color:var(--green);background:rgba(79,255,176,.08);border:1px solid rgba(79,255,176,.2);border-radius:8px;padding:.3rem .65rem;margin-top:.1rem}
.perf-alert{font-size:.68rem;color:var(--yellow);background:rgba(255,209,102,.1);border:1px solid rgba(255,209,102,.25);border-radius:8px;padding:.3rem .65rem;margin-top:.1rem}
.perf-danger{font-size:.68rem;color:var(--red);background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.25);border-radius:8px;padding:.3rem .65rem;margin-top:.1rem}
.perf-hint{font-size:.68rem;color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:.3rem .65rem;margin-top:.1rem}
.section-divider{font-size:.72rem;text-transform:uppercase;letter-spacing:.9px;color:var(--text3);font-weight:600;margin:1.4rem 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
@media(max-width:700px){.perf-cards{grid-template-columns:1fr}}

/* ── Navegação de mês (despesas) ─────────────────────────── */
.desp-nav-strip{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem;flex-wrap:wrap}
.desp-month-nav{display:flex;align-items:center;gap:.2rem;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:.22rem .4rem}
.desp-month-nav .mn-btn{background:none;border:none;color:var(--text2);font-size:1.05rem;cursor:pointer;padding:.15rem .55rem;border-radius:6px;line-height:1;transition:background .15s}
.desp-month-nav .mn-btn:hover{background:var(--bg3)}
.desp-month-nav .mn-label{font-size:.88rem;font-weight:600;color:var(--text);font-family:var(--fd);padding:0 .35rem;min-width:120px;text-align:center}
.periodo-bar{display:flex;align-items:center;gap:.45rem;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:.3rem .7rem}
.date-inp{background:none;border:none;color:var(--text);font-family:var(--f);font-size:.82rem;outline:none;cursor:pointer;padding:.1rem .2rem;color-scheme:var(--color-scheme)}
.date-inp::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}
.periodo-sep{font-size:.75rem;color:var(--text3);flex-shrink:0}
.btn-periodo-toggle{background:none;border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:.32rem .85rem;font-size:.78rem;cursor:pointer;font-family:var(--f);white-space:nowrap;transition:all .2s}
.btn-periodo-toggle:hover{background:var(--bg3);color:var(--text)}
.btn-periodo-toggle.active{background:rgba(96,165,250,.12);border-color:var(--blue);color:var(--blue)}
@media(max-width:720px){.desp-nav-strip{gap:.4rem}.desp-month-nav .mn-label{min-width:90px}}

/* ── Cashflow Header ─────────────────────────────────────── */
.dash-cashflow-header{
  position:relative;display:flex;align-items:stretch;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:18px;padding:1.4rem 1rem 1.75rem;
  margin-bottom:1.25rem;box-shadow:var(--shadow);
  overflow:hidden;gap:0
}
.cf-block{
  flex:1;text-align:center;padding:.1rem 1.1rem;position:relative
}
.cf-block + .cf-block::before{
  content:'';position:absolute;left:0;top:8%;height:84%;
  width:1px;background:var(--border2)
}
.cf-label{
  font-size:.63rem;color:var(--text3);text-transform:uppercase;
  letter-spacing:1.1px;margin-bottom:.4rem;
  display:flex;align-items:center;justify-content:center;gap:.25rem
}
.cf-value{
  font-family:var(--fd);font-size:1.7rem;font-weight:700;
  line-height:1.1;margin-bottom:.3rem;letter-spacing:-.5px;
  white-space:nowrap
}
.cf-sub{font-size:.72rem;color:var(--text3)}
.cf-alert{font-size:1rem;margin-right:.15rem;vertical-align:middle}
/* Barra de proporção fixada na base do widget */
.cf-progress-track{
  position:absolute;bottom:0;left:0;right:0;height:4px;
  background:var(--bar-track)
}
.cf-progress-fill{
  height:100%;border-radius:0;
  transition:width .55s ease,background .35s ease
}
/* Responsivo: empilha em telas pequenas */
@media(max-width:640px){
  .dash-cashflow-header{flex-direction:column;padding:1.1rem 1.2rem 1.6rem;gap:.9rem}
  .cf-block + .cf-block::before{top:0;left:8%;width:84%;height:1px}
  .cf-value{font-size:1.35rem}
}
/* Tema claro: reforça separadores */
html.theme-light .cf-block + .cf-block::before{background:var(--border)}

/* ── Icon Picker (modal categorias) ─────────────────────── */
.icon-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.28rem;max-height:156px;overflow-y:auto;padding:.4rem;background:var(--bg3);border-radius:9px;border:1px solid var(--border)}
.icon-opt{background:none;border:2px solid transparent;border-radius:7px;padding:.22rem;font-size:1.22rem;cursor:pointer;text-align:center;transition:background .12s,border-color .12s;line-height:1}
.icon-opt:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.icon-opt.selected{background:rgba(79,255,176,.15);border-color:rgba(79,255,176,.5)}

/* ── Toggle Switch ───────────────────────────────────────── */
.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-thumb{position:absolute;cursor:pointer;inset:0;background:var(--bg3);border:1px solid var(--border2);border-radius:50px;transition:background .2s,border-color .2s}
.toggle-thumb::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;background:var(--text3);border-radius:50%;transition:transform .2s,background .2s}
.toggle-switch input:checked + .toggle-thumb{background:rgba(79,255,176,.18);border-color:rgba(79,255,176,.5)}
.toggle-switch input:checked + .toggle-thumb::before{transform:translateX(18px);background:var(--green)}
.budget-toggle-wrap{background:var(--bg3);border-radius:10px;padding:.75rem .9rem;border:1px solid var(--border)}

/* ── Chart Panel ────────────────────────────────────────── */
.panel-charts .chart-body{
  display:flex;gap:1.75rem;align-items:flex-start;padding:.35rem 0
}
.chart-donut-wrap{
  width:190px;min-width:150px;flex-shrink:0;position:relative
}
.chart-legend{
  flex:1;min-width:0;overflow-y:auto;max-height:280px;
  /* scrollbar fina */
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent
}
.chart-legend::-webkit-scrollbar{width:4px}
.chart-legend::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.chart-leg-item{
  display:flex;align-items:flex-start;gap:.65rem;
  padding:.42rem .5rem;border-radius:8px;cursor:pointer;
  transition:background .15s
}
.chart-leg-item:hover{background:var(--hover-bg)}
.leg-dot{
  width:9px;height:9px;border-radius:50%;
  flex-shrink:0;margin-top:4px
}
/* Mobile: empilha vertical */
@media(max-width:580px){
  .panel-charts .chart-body{flex-direction:column;align-items:center;gap:1rem}
  .chart-donut-wrap{width:160px}
  .chart-legend{max-height:none;width:100%}
}

/* ── Budget Bar (dashboard) ──────────────────────────────── */
.budget-track{height:4px;background:rgba(255,255,255,.07);border-radius:50px;overflow:hidden;margin-top:.3rem}
.budget-fill{height:100%;border-radius:50px;transition:width .45s ease}
.budget-ok{background:var(--green)}
.budget-warn{background:var(--yellow)}
.budget-over{background:var(--red)}
.budget-info{display:flex;justify-content:space-between;font-size:.65rem;color:var(--text3);margin-top:.22rem;line-height:1.4}

/* ── Rename Category Modal ───────────────────────────────── */
.rename-opt{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:.85rem 1rem;
  border:1.5px solid var(--border);
  border-radius:12px;
  cursor:pointer;
  transition:border-color .18s,background .18s;
  user-select:none
}
.rename-opt:hover{border-color:var(--border2);background:var(--hover-bg)}
.rename-opt-active{
  border-color:rgba(79,255,176,.42) !important;
  background:rgba(79,255,176,.06)  !important
}
html.theme-light .rename-opt-active{
  border-color:rgba(0,168,107,.35) !important;
  background:rgba(0,168,107,.06)   !important
}

/* ── Import Review Modal ─────────────────────────────────── */
.imp-modal{max-width:870px;width:95vw}
/* 7 colunas: cb | data | descrição | valor | ação | categoria | conta */
.imp-head,
.imp-row{display:grid;grid-template-columns:28px 80px 1fr 76px 112px 130px 122px;gap:.4rem;align-items:center}
.imp-head{padding:.45rem .9rem;background:var(--bg3);border-radius:10px 10px 0 0;font-size:.64rem;color:var(--text3);text-transform:uppercase;letter-spacing:.75px;border:1px solid var(--border);border-bottom:none}
.imp-row{padding:.55rem .9rem;border-top:1px solid var(--border);transition:background .12s}
.imp-row:hover{background:rgba(255,255,255,.018)}
.imp-row-dup{opacity:.52}
.imp-row-dup:hover{opacity:.82;transition:opacity .15s}
.imp-date{font-size:.78rem;color:var(--text2)}
.imp-desc{font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.imp-val{font-size:.82rem;font-weight:600;text-align:right;color:var(--red)}
.imp-sel{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:.28rem .4rem;color:var(--text);font-family:var(--f);font-size:.74rem;outline:none;cursor:pointer}
.imp-sel:focus{border-color:rgba(79,255,176,.35)}
.imp-sel option{background:var(--bg2)}
.imp-badge{display:inline-flex;align-items:center;border-radius:50px;padding:2px 8px;font-size:.7rem;white-space:nowrap;border:1px solid}
.imp-new{background:rgba(79,255,176,.1);color:var(--green);border-color:rgba(79,255,176,.25)}
.imp-baixa{background:rgba(96,165,250,.1);color:var(--blue);border-color:rgba(96,165,250,.25)}
.imp-dup{background:rgba(255,209,102,.1);color:var(--yellow);border-color:rgba(255,209,102,.25)}

/* ── Bank Dot ────────────────────────────────────────────── */
.bank-dot{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--fd);letter-spacing:.4px;user-select:none}
.bank-dot-sm{width:26px;height:26px;font-size:.55rem}

/* ── Toast erro ──────────────────────────────────────────── */
.toast-err{border-color:var(--red)!important;color:var(--red)!important}

/* ── Tema Claro: ajustes específicos ─────────────────────── */
html.theme-light .sidebar{box-shadow:2px 0 16px rgba(0,0,0,.09)}
/* Item ativo: card branco flutuante dentro da sidebar cinza */
html.theme-light .sb-item.active{
  margin:1px .55rem;
  padding:.6rem .95rem;
  border-radius:10px;
  border-left-width:3px;
  box-shadow:0 1px 8px rgba(0,0,0,.1)
}
/* Hover: fundo levemente mais escuro, ícone acompanha o texto */
html.theme-light .sb-item:hover:not(.active){
  border-radius:8px;
  margin:0 .3rem;
  padding:.65rem 1.2rem
}
/* Seções e usuário no tema claro */
html.theme-light .sb-user{border-top-color:rgba(30,37,51,.12)}
/* Ícone herda a cor do sb-item — nenhuma regra extra necessária (CSS inheritance) */
html.theme-light .ai-panel{border-color:rgba(0,168,107,.22)}
html.theme-light .ai-msg.bot{background:rgba(0,168,107,.07);border-color:rgba(0,168,107,.15)}
html.theme-light .ai-inp:focus{border-color:rgba(0,168,107,.4)}
html.theme-light .imp-row:hover{background:var(--hover-bg)}
html.theme-light .budget-track{background:var(--bar-track)}
html.theme-light body{background:var(--bg)}

/* ── Grupo Familiar (configurações) ─────────────────────── */
.grupo-section-title{font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;color:var(--text3);margin-bottom:.5rem}
.grupo-member{display:flex;align-items:center;gap:10px;padding:.7rem .75rem;
  background:var(--bg3);border-radius:10px}
.grupo-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}
.grupo-member-info{display:flex;flex-direction:column;min-width:0;flex:1}
.grupo-member-name{font-size:.875rem;font-weight:500;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.grupo-member-sub{font-size:.72rem;color:var(--text3);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.grupo-btn-cancel-invite{margin-left:auto;flex-shrink:0;
  background:rgba(255,80,80,.08);border:1px solid rgba(255,80,80,.25);
  color:#ff8888;border-radius:6px;cursor:pointer;padding:.25rem .55rem;
  font-size:.75rem;transition:background .15s,border-color .15s}
.grupo-btn-cancel-invite:hover{background:rgba(255,80,80,.18);
  border-color:#ff6060;color:#fff}
.grupo-invite-form{margin-top:1rem}
.grupo-email-input{flex:1;background:var(--bg3);border:1px solid var(--border);
  border-radius:8px;padding:.5rem .75rem;font-size:.82rem;color:var(--text1);
  outline:none;font-family:var(--fd);transition:border-color .15s;min-width:0}
.grupo-email-input:focus{border-color:var(--green)}
.grupo-invite-btn{padding:.5rem 1rem!important;font-size:.82rem!important;
  white-space:nowrap;flex-shrink:0}
.grupo-invite-err{font-size:.72rem;color:#ff8888;margin-top:.4rem}
.grupo-empty{font-size:.82rem;color:var(--text3);text-align:center;
  padding:.75rem 0;margin:0}
html.theme-light .grupo-btn-cancel-invite{background:rgba(200,30,30,.06);
  border-color:rgba(200,30,30,.2);color:#c00}
html.theme-light .grupo-btn-cancel-invite:hover{background:rgba(200,30,30,.14);
  border-color:#c00;color:#700}
.td-author{font-size:.68rem;color:var(--text3);margin-left:.35rem;font-weight:400;white-space:nowrap}

/* ── Trial banner ────────────────────────────────────────── */
.trial-banner{
  background:rgba(255,200,50,.07);
  border:1px solid rgba(255,200,50,.3);
  border-radius:12px;
  padding:.75rem 1.25rem;
  margin-bottom:1.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  position:sticky;
  top:0;
  z-index:10;
}
.trial-banner-content{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}
.trial-banner-icon{font-size:1.15rem;flex-shrink:0;line-height:1}
.trial-banner-text{font-size:.82rem;color:var(--text2);line-height:1.5}
.trial-banner-text strong{color:var(--yellow);display:block;margin-bottom:.1rem;font-family:var(--fd)}
.trial-banner-cta{
  background:var(--yellow);
  color:#0A0F1E;
  border:none;
  border-radius:9px;
  padding:.48rem 1.1rem;
  font-family:var(--fd);
  font-weight:600;
  font-size:.8rem;
  cursor:pointer;
  white-space:nowrap;
  flex-shrink:0;
  transition:opacity .15s;
}
.trial-banner-cta:hover{opacity:.85}
html.theme-light .trial-banner{background:rgba(180,110,0,.06);border-color:rgba(180,110,0,.25)}

/* ── Plans modal ─────────────────────────────────────────── */
.modal-planos{max-width:660px!important}
.plans-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.75rem;
}
.plan-card{
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.3rem .9rem 1rem;
  text-align:center;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:.3rem;
  transition:border-color .18s,transform .18s;
}
.plan-card:hover{border-color:rgba(79,255,176,.35);transform:translateY(-2px)}
.plan-card.plan-highlight{border-color:var(--green);background:rgba(79,255,176,.05)}
.plan-badge{
  position:absolute;
  top:-.7rem;
  left:50%;
  transform:translateX(-50%);
  background:var(--green);
  color:#0A0F1E;
  font-size:.6rem;
  font-weight:700;
  font-family:var(--fd);
  padding:.2rem .65rem;
  border-radius:20px;
  white-space:nowrap;
  letter-spacing:.3px;
}
.plan-name{
  font-family:var(--fd);
  font-size:.88rem;
  font-weight:700;
  color:var(--text);
  margin-top:.3rem;
}
.plan-price{
  font-family:var(--fd);
  font-size:1.55rem;
  font-weight:700;
  color:var(--text);
  line-height:1;
  margin-top:.35rem;
}
.plan-cents{font-size:.9rem}
.plan-cycle{font-size:.68rem;color:var(--text3);margin-top:-.1rem}
.plan-users{
  font-size:.74rem;
  color:var(--text2);
  margin:auto 0 .5rem;
  padding:.3rem .5rem;
  background:var(--bg);
  border-radius:6px;
  margin-top:.6rem;
}
.plan-cta{
  font-size:.76rem!important;
  padding:.5rem .5rem!important;
  flex:none!important;
}
@media(max-width:620px){
  .plans-grid{grid-template-columns:repeat(2,1fr)}
  .trial-banner{flex-direction:column;align-items:flex-start}
  .trial-banner-cta{width:100%}
}

/* ── Descrição clicável na tabela de despesas ─────────────── */
.td-desc-link{cursor:pointer;transition:color .12s}
.td-desc-link:hover{color:var(--green)}
.td-desc-link:hover .td-author{color:var(--text3)}

/* ── Abas do modal de detalhe ─────────────────────────────── */
.det-tab{
  flex:1;background:none;border:none;border-radius:8px;
  padding:.45rem .75rem;font-family:var(--fd);font-weight:600;
  font-size:.8rem;color:var(--text2);cursor:pointer;transition:all .15s;
}
.det-tab:hover{color:var(--text);background:rgba(255,255,255,.05)}
.det-tab.det-tab-active{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.25)}
html.theme-light .det-tab.det-tab-active{background:#fff;box-shadow:0 1px 6px rgba(0,0,0,.12)}

/* ── Entradas do histórico ────────────────────────────────── */
.hist-entry{display:flex;align-items:flex-start;gap:.75rem;padding:.65rem .1rem;border-bottom:1px solid var(--border)}
.hist-entry:last-child{border-bottom:none}
.hist-icon{font-size:1rem;line-height:1.4;flex-shrink:0}
.hist-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.hist-action{font-size:.83rem;color:var(--text2);line-height:1.4}
.hist-action strong{color:var(--text)}
.hist-date{font-size:.72rem;color:var(--text3)}
.hist-empty{padding:1.5rem;text-align:center;color:var(--text3);font-size:.82rem}

/* ── Terms checkboxes ────────────────────────────────────── */
.terms-check-label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;font-size:.79rem;color:var(--text2);line-height:1.5}
.terms-check-label input[type="checkbox"]{margin-top:.15rem;flex-shrink:0;accent-color:var(--green);width:14px;height:14px;cursor:pointer}
.terms-check-label a{color:var(--green);text-decoration:none}
.terms-check-label a:hover{text-decoration:underline}

/* ── Profile banner ──────────────────────────────────────── */
.profile-banner{
  background:rgba(96,165,250,.07);
  border:1px solid rgba(96,165,250,.25);
  border-radius:12px;
  padding:.65rem 1.25rem;
  margin-bottom:1.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.profile-banner-cta{
  background:var(--blue);
  color:#0A0F1E;
  border:none;
  border-radius:9px;
  padding:.42rem 1rem;
  font-family:var(--fd);
  font-weight:600;
  font-size:.78rem;
  cursor:pointer;
  white-space:nowrap;
  flex-shrink:0;
  transition:opacity .15s;
}
.profile-banner-cta:hover{opacity:.85}
html.theme-light .profile-banner{background:rgba(30,100,220,.05);border-color:rgba(30,100,220,.2)}
@media(max-width:620px){
  .profile-banner{flex-direction:column;align-items:flex-start}
  .profile-banner-cta{width:100%}
}

/* ── Campo de comprovante ────────────────────────────────── */
.comprovante-drop-area{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.comprovante-btn{
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  color:var(--text2);font-family:var(--fd);font-size:.8rem;font-weight:600;
  padding:.38rem .85rem;cursor:pointer;transition:all .15s;white-space:nowrap;
}
.comprovante-btn:hover{background:var(--bg2);color:var(--text);border-color:var(--green)}
.comprovante-nome{font-size:.78rem;color:var(--text3);word-break:break-all}
.comp-thumb{max-width:100%;max-height:120px;border-radius:8px;border:1px solid var(--border);object-fit:contain}
.comp-pdf-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--green);text-decoration:none;font-weight:600}
.comp-pdf-link:hover{text-decoration:underline}
.comp-trocar-btn{background:none;border:none;font-size:.75rem;color:var(--text3);cursor:pointer;padding:0;text-decoration:underline;font-family:var(--fd)}
.comp-trocar-btn:hover{color:var(--text2)}
.comprovante-existente{margin:.5rem 0 .25rem;display:flex;flex-direction:column;gap:.35rem}
.hist-comp-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.77rem;color:var(--green);text-decoration:none;font-weight:600;margin-top:.15rem}
.hist-comp-link:hover{text-decoration:underline}

/* ── Lightbox de comprovante ─────────────────────────────── */
#lightbox-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.85);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;cursor:zoom-out;
}
#lightbox-img{
  max-width:90vw;max-height:90vh;border-radius:8px;
  object-fit:contain;cursor:default;
}
#lightbox-close{
  position:absolute;top:20px;right:28px;background:none;border:none;
  color:#fff;font-size:2rem;cursor:pointer;line-height:1;opacity:.8;
  transition:opacity .15s;
}
#lightbox-close:hover{opacity:1}
