/* ============================================================
   WebProFinanceBot — Premium Dark Finance UI
   Inspired by finbot.online aesthetic
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Palette */
  --bg:       #0f1117;
  --bg2:      #141824;
  --card:     #1a2236;
  --card2:    #1f2840;
  --card3:    #243050;
  --border:   #252f47;
  --border2:  #2e3a55;

  /* Accent */
  --green:    #00e676;
  --green-d:  #00c853;
  --green-bg: rgba(0,230,118,.08);
  --green-b:  rgba(0,230,118,.22);
  --red:      #ff1744;
  --red-bg:   rgba(255,23,68,.08);
  --red-b:    rgba(255,23,68,.22);
  --blue:     #448aff;
  --blue-bg:  rgba(68,138,255,.08);
  --blue-b:   rgba(68,138,255,.22);
  --orange:   #ff9100;
  --purple:   #7c4dff;

  /* Nav active */
  --nav-active-bg:  rgba(68,138,255,.15);
  --nav-active-col: #82b1ff;
  --nav-active-bd:  #448aff;

  /* Text */
  --t1: #e8eeff;
  --t2: #7a8aaa;
  --t3: #3d4f70;

  /* Misc */
  --sidebar: 220px;
  --topbar:  58px;
  --r:       12px;
  --rs:      9px;
  --font:    'Inter',-apple-system,sans-serif;
  --ease:    all .18s cubic-bezier(.4,0,.2,1);
}

html,body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--t1);
  min-height:100vh;
  overflow-x:hidden;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
a{text-decoration:none;color:inherit}
.green,.g{color:var(--green)}
.red{color:var(--red)}

/* ─────────────────────────────────────
   AUTH
───────────────────────────────────── */
.auth-screen{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse 70% 60% at 15% 0%,rgba(68,138,255,.07),transparent 60%),
    radial-gradient(ellipse 55% 50% at 90% 100%,rgba(0,230,118,.06),transparent 60%),
    var(--bg);
}
.auth-bg,.auth-blob{display:none}
.auth-card{
  width:100%;max-width:390px;
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:18px;
  padding:40px 36px;
  box-shadow:0 32px 64px rgba(0,0,0,.6);
}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:9px;margin-bottom:28px}
.auth-logo span:first-child{font-size:26px}
.auth-logo-text{font-size:17px;font-weight:800;color:#fff;letter-spacing:-.4px}
.auth-logo-text span{color:var(--green)}
.auth-card h2{font-size:19px;font-weight:800;color:#fff;text-align:center;margin-bottom:5px;letter-spacing:-.4px}
.auth-sub{font-size:13px;color:var(--t2);text-align:center;margin-bottom:24px}
.auth-error{
  background:var(--red-bg);border:1px solid var(--red-b);
  color:#ff6b87;padding:10px 13px;border-radius:8px;
  font-size:12.5px;margin-bottom:14px;display:none;
}
.form-group{margin-bottom:14px}
.form-group label{
  display:block;font-size:10.5px;font-weight:700;color:var(--t2);
  text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;
}
.form-group input,.form-group select{
  width:100%;padding:10px 13px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:8px;color:var(--t1);
  font-size:13.5px;font-family:var(--font);outline:none;transition:var(--ease);
}
.form-group input:focus,.form-group select:focus{
  border-color:var(--blue);background:rgba(68,138,255,.05);
  box-shadow:0 0 0 3px rgba(68,138,255,.12);
}
.form-group input::placeholder{color:var(--t3)}
.form-group select{cursor:pointer;-webkit-appearance:none}
.form-group select option{background:#1a2236}
.hint{font-size:11px;color:var(--t3);margin-top:5px;display:block}
.btn-auth{
  width:100%;padding:12px;margin-top:6px;
  background:linear-gradient(135deg,var(--green),var(--green-d));
  color:#02200a;font-size:14.5px;font-weight:800;
  border:none;border-radius:9px;cursor:pointer;
  font-family:var(--font);transition:var(--ease);
  box-shadow:0 4px 18px rgba(0,230,118,.25);
}
.btn-auth:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,230,118,.38)}
.btn-auth:active{transform:none}
.auth-switch{text-align:center;font-size:12.5px;color:var(--t2);margin-top:16px}
.auth-switch a{color:var(--green);font-weight:600}

/* ─────────────────────────────────────
   APP SHELL
───────────────────────────────────── */
.app-screen{display:flex;min-height:100vh}

/* ─────────────────────────────────────
   SIDEBAR
───────────────────────────────────── */
.sidebar{
  width:var(--sidebar);
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;
  z-index:200;transition:transform .28s cubic-bezier(.4,0,.2,1);
}
.sidebar-top{padding:20px 16px 16px}
.sidebar-logo{
  display:flex;align-items:center;gap:8px;
  margin-bottom:20px;padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.sidebar-logo span:first-child{font-size:18px}
.sidebar-logo span:last-child{font-size:13px;font-weight:800;color:#fff;letter-spacing:-.3px}
.sidebar-logo .g{color:var(--green)}

.user-info{
  display:flex;align-items:center;gap:9px;
  padding:9px 11px;background:var(--card);
  border:1px solid var(--border);border-radius:10px;
}
.user-avatar{
  width:32px;height:32px;border-radius:8px;
  background:linear-gradient(135deg,var(--green),var(--green-d));
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
}
.user-name{font-size:12.5px;font-weight:700;color:#fff;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-plan{font-size:10px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.8px;margin-top:1px}

.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 11px;border-radius:9px;
  font-size:13px;font-weight:500;color:var(--t2);
  cursor:pointer;transition:var(--ease);
  border:none;background:transparent;
  width:100%;text-align:left;font-family:var(--font);
  white-space:nowrap;position:relative;
}
/* Icon circles for nav */
.nav-item .ni{
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
  background:rgba(255,255,255,.05);
  transition:var(--ease);
}
.nav-item:hover{background:rgba(255,255,255,.04);color:var(--t1)}
.nav-item:hover .ni{background:rgba(255,255,255,.08)}
.nav-item.active{
  background:var(--nav-active-bg);
  color:var(--nav-active-col);
  font-weight:600;
}
.nav-item.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;background:var(--nav-active-bd);border-radius:0 3px 3px 0;
}
.nav-item[data-page="dashboard"].active .ni{background:rgba(68,138,255,.2)}
.nav-item[data-page="transactions"].active .ni{background:rgba(0,230,118,.15)}
.nav-item[data-page="limits"].active .ni{background:rgba(255,145,0,.15)}
.nav-item[data-page="funds"].active .ni{background:rgba(124,77,255,.15)}
.nav-item[data-page="reminders"].active .ni{background:rgba(255,23,68,.15)}
.nav-item[data-page="shopping"].active .ni{background:rgba(0,230,118,.15)}
.nav-item[data-page="settings"].active .ni{background:rgba(68,138,255,.15)}
.nav-item.logout{color:var(--t3)}
.nav-item.logout:hover{background:var(--red-bg);color:var(--red)}
.nav-item.logout:hover .ni{background:var(--red-bg)}
.sidebar-bottom{padding:8px 8px 18px;border-top:1px solid var(--border)}

/* ─────────────────────────────────────
   MAIN WRAP + TOPBAR
───────────────────────────────────── */
.main-wrap{margin-left:var(--sidebar);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{
  height:var(--topbar);
  background:rgba(15,17,23,.9);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 22px;
  position:sticky;top:0;z-index:100;gap:12px;
}
.menu-btn{display:none;background:none;border:none;color:var(--t2);font-size:19px;cursor:pointer;padding:4px;border-radius:6px;transition:var(--ease)}
.menu-btn:hover{color:var(--t1);background:var(--card)}
.topbar-center{flex:1}
.topbar-center h1{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.2px}
.topbar-right{display:flex;align-items:center}
.greeting{font-size:12.5px;color:var(--t2)}

.main-content{flex:1;padding:22px;max-width:1200px;margin:0 auto;width:100%}
.page{display:none;animation:pgIn .2s ease}
.page.active{display:block}
@keyframes pgIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ─────────────────────────────────────
   CARDS
───────────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:18px;margin-bottom:16px;
}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-header h3{font-size:13px;font-weight:700;color:var(--t1);letter-spacing:-.1px}
.btn-link{background:none;border:none;color:var(--blue);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);padding:3px 7px;border-radius:5px;transition:var(--ease)}
.btn-link:hover{background:var(--blue-bg)}

/* ─────────────────────────────────────
   DASHBOARD GREETING
───────────────────────────────────── */
.dash-greeting{font-size:20px;font-weight:800;color:#fff;margin-bottom:18px;letter-spacing:-.5px}
.dash-greeting .green{font-weight:900}

/* ─────────────────────────────────────
   BALANCE CARDS
───────────────────────────────────── */
.balance-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.bal-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);padding:16px 18px;
  position:relative;overflow:hidden;transition:var(--ease);
}
.bal-card::after{
  content:'';position:absolute;right:-10px;bottom:-10px;
  width:70px;height:70px;border-radius:50%;opacity:.12;
  filter:blur(16px);pointer-events:none;
}
.income-card{border-color:rgba(0,230,118,.18)}
.income-card::after{background:var(--green)}
.expense-card{border-color:rgba(255,23,68,.18)}
.expense-card::after{background:var(--red)}
.balance-card{border-color:rgba(68,138,255,.18)}
.balance-card::after{background:var(--blue)}
.bal-card:hover{transform:translateY(-2px)}
.income-card:hover{border-color:rgba(0,230,118,.35);box-shadow:0 4px 20px rgba(0,230,118,.08)}
.expense-card:hover{border-color:rgba(255,23,68,.35);box-shadow:0 4px 20px rgba(255,23,68,.08)}
.balance-card:hover{border-color:rgba(68,138,255,.35);box-shadow:0 4px 20px rgba(68,138,255,.08)}
.bal-label{
  font-size:10px;font-weight:700;color:var(--t2);
  text-transform:uppercase;letter-spacing:.8px;
  display:flex;align-items:center;gap:7px;margin-bottom:10px;
}
.bal-icon{
  width:22px;height:22px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;flex-shrink:0;
}
.income-card .bal-icon{background:rgba(0,230,118,.15)}
.expense-card .bal-icon{background:rgba(255,23,68,.15)}
.balance-card .bal-icon{background:rgba(68,138,255,.15)}
.bal-value{
  font-size:24px;font-weight:900;letter-spacing:-.8px;
  margin-bottom:6px;line-height:1;
}
.income-card .bal-value{color:var(--green)}
.expense-card .bal-value{color:var(--red)}
.balance-card .bal-value{color:var(--blue)}
.bal-sub{font-size:11px;color:var(--t3)}

/* ─────────────────────────────────────
   DAILY BUDGET BANNER
───────────────────────────────────── */
.daily-budget-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:13px 16px;
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;font-size:13px;color:var(--t2);
}
.db-icon{font-size:18px;flex-shrink:0}

/* ─────────────────────────────────────
   CHARTS ROW
───────────────────────────────────── */
.charts-row{display:grid;grid-template-columns:1.6fr 1fr;gap:12px;margin-bottom:14px}
.chart-card-wide{margin-bottom:0!important}
.chart-box{position:relative;width:100%}
.monthly-box{height:190px}
.category-box{height:220px}

/* ─────────────────────────────────────
   LIMITS PREVIEW — 3 colunas inline
───────────────────────────────────── */
#limitsPreviewList{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.limit-item{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:var(--rs);
  padding:12px 13px;
  transition:var(--ease);
}
.limit-item:hover{border-color:var(--border2)}
.limit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.limit-cat{font-size:12.5px;font-weight:700;color:var(--t1)}
.limit-vals{font-size:10.5px;color:var(--t2)}
.limit-bar{height:5px;background:rgba(255,255,255,.07);border-radius:3px;overflow:hidden;margin-bottom:6px}
.limit-fill{height:100%;border-radius:3px;transition:width .7s cubic-bezier(.4,0,.2,1)}
.limit-fill.ok{background:var(--green)}
.limit-fill.warn{background:var(--orange)}
.limit-fill.over{background:var(--red)}
.limit-pct{font-size:11.5px;font-weight:700}
.limit-pct.ok{color:var(--green)}
.limit-pct.warn{color:var(--orange)}
.limit-pct.over{color:var(--red)}

/* ─────────────────────────────────────
   CARD SECTION LABEL (ex: TRANSAÇÕES RECENTES)
───────────────────────────────────── */
.section-label{
  font-size:10px;font-weight:800;color:var(--t3);
  text-transform:uppercase;letter-spacing:1.2px;
  margin-bottom:12px;display:flex;align-items:center;gap:8px;
}
.section-label::after{content:'';flex:1;height:1px;background:var(--border)}

/* ─────────────────────────────────────
   TRANSACTIONS LIST
───────────────────────────────────── */
.tx-list{display:flex;flex-direction:column}
.tx-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 0;
  border-bottom:1px solid var(--border);
  transition:var(--ease);
}
.tx-item:last-child{border-bottom:none;padding-bottom:0}
.tx-item:first-child{padding-top:0}
.tx-icon{
  width:36px;height:36px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.tx-icon.income{background:var(--green-bg);border:1px solid var(--green-b)}
.tx-icon.expense{background:var(--red-bg);border:1px solid var(--red-b)}
.tx-info{flex:1;min-width:0}
.tx-desc{font-size:13px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tx-cat{font-size:11px;color:var(--t3);margin-top:1px}
.tx-amount{font-size:13.5px;font-weight:700;white-space:nowrap}
.tx-amount.income{color:var(--green)}
.tx-amount.expense{color:var(--red)}
.tx-date{font-size:10.5px;color:var(--t3);white-space:nowrap;margin-left:4px}
.tx-actions{display:flex;gap:5px;align-items:center;flex-shrink:0}
.tx-edit-btn{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.25);color:#60a5fa;cursor:pointer;padding:4px 7px;border-radius:6px;font-size:12px;transition:var(--ease);line-height:1}
.tx-edit-btn:hover{background:rgba(59,130,246,.25);color:#93c5fd}
.tx-del-btn{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#f87171;cursor:pointer;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:600;transition:var(--ease);white-space:nowrap;line-height:1}
.tx-del-btn:hover{background:rgba(239,68,68,.2);color:#fca5a5}
/* legacy — keep for compatibility */
.tx-delete{background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;border-radius:5px;font-size:14px;transition:var(--ease);flex-shrink:0}
.tx-delete:hover{color:var(--red);background:var(--red-bg)}

/* Empty */
.empty-state{text-align:center;padding:32px 16px;color:var(--t3);font-size:13px;line-height:1.6}
.empty-state::before{content:'📭';display:block;font-size:26px;margin-bottom:8px}

/* ─────────────────────────────────────
   TRANSACTIONS PAGE
───────────────────────────────────── */
.page-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.type-tabs{display:flex;gap:3px;background:var(--card);border-radius:8px;padding:3px;border:1px solid var(--border)}
.tab-btn{padding:6px 14px;border:none;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--t2);background:transparent;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.tab-btn.active{background:var(--card3);color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.actions-right{display:flex;align-items:center;gap:8px}
.month-input{padding:6px 10px;background:var(--card);border:1px solid var(--border);border-radius:7px;color:var(--t1);font-size:12.5px;font-family:var(--font);outline:none;cursor:pointer}
.month-input:focus{border-color:var(--blue)}
.btn-add{padding:7px 15px;background:var(--green);color:#02200a;border:none;border-radius:7px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-add:hover{background:var(--green-d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,230,118,.28)}
.btn-add-sm{padding:5px 12px;background:var(--green-bg);color:var(--green);border:1px solid var(--green-b);border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-add-sm:hover{background:rgba(0,230,118,.14)}
.btn-sm-red{padding:5px 12px;background:var(--red-bg);color:var(--red);border:1px solid var(--red-b);border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-sm-red:hover{background:rgba(255,23,68,.14)}
.btn-delete,.btn-del-sm{background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;border-radius:5px;font-size:14px;transition:var(--ease)}
.btn-delete:hover,.btn-del-sm:hover{color:var(--red);background:var(--red-bg)}
.loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:26px;color:var(--t3);font-size:13px}
.loading::before{content:'';width:16px;height:16px;border:2px solid var(--border2);border-top-color:var(--green);border-radius:50%;animation:sp .7s linear infinite;flex-shrink:0}
@keyframes sp{to{transform:rotate(360deg)}}

/* ─────────────────────────────────────
   LIMITS & GOALS PAGE
───────────────────────────────────── */
.limits-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* limit items on limits page — vertical list style */
#limitsList .limit-item{
  display:block;
}
#limitsList .limit-header{margin-bottom:8px}
#limitsList .limit-bar{margin-bottom:5px}

/* goals */
.goals-list{display:flex;flex-direction:column;gap:10px}
.goal-item{
  display:flex;align-items:flex-start;gap:12px;
  background:var(--card2);border:1px solid var(--border);
  border-radius:var(--rs);padding:13px;margin-bottom:10px;
  transition:var(--ease);
}
.goal-item:hover{border-color:var(--border2)}
.goal-img-placeholder{
  width:40px;height:40px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;background:var(--card3);border-radius:9px;
}
.goal-body{flex:1;min-width:0}
.goal-name{font-size:13.5px;font-weight:700;color:#fff;margin-bottom:3px}
.goal-amounts{display:flex;justify-content:space-between;font-size:11px;color:var(--t3);margin-bottom:7px}
.goal-bar{height:4px;background:rgba(255,255,255,.07);border-radius:3px;overflow:hidden;margin-bottom:5px}
.goal-fill{height:100%;border-radius:3px;transition:width .7s cubic-bezier(.4,0,.2,1)}
.goal-pct{font-size:11px;color:var(--t3);margin-bottom:8px}
.goal-actions{display:flex;gap:6px}
.goal-btn{padding:5px 11px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease);border:1px solid}
.goal-btn.deposit{background:var(--green-bg);border-color:var(--green-b);color:var(--green)}
.goal-btn.deposit:hover{background:rgba(0,230,118,.15)}
.goal-btn.del{background:var(--red-bg);border-color:var(--red-b);color:var(--red)}
.goal-btn.del:hover{background:rgba(255,23,68,.15)}

/* ─────────────────────────────────────
   MINI STATS ROW (Funds / Subscriptions)
───────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:600px){.stats-row{grid-template-columns:1fr}}
.mini-stat{border-radius:var(--r);padding:14px 16px;border:1px solid rgba(255,255,255,.07)}
.mini-stat-label{font-size:10.5px;color:rgba(255,255,255,.55);font-weight:600;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.mini-stat-val{font-size:20px;font-weight:900;color:#fff;letter-spacing:-.5px}

/* ─────────────────────────────────────
   INVESTIMENTOS E RESERVAS
───────────────────────────────────── */
.inv-list{display:flex;flex-direction:column;gap:12px}
.inv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;transition:var(--ease)}
.inv-card:hover{border-color:var(--border2);box-shadow:0 6px 24px rgba(0,0,0,.3)}
.inv-card-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}
.inv-emoji{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.inv-info{flex:1}
.inv-name{font-size:15px;font-weight:800;color:#fff;margin-bottom:3px}
.inv-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:20px;font-weight:700;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);margin-bottom:4px}
.inv-desc{font-size:12px;color:var(--t3)}
.inv-amounts{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}
.inv-current{font-size:22px;font-weight:900;color:var(--green);letter-spacing:-.7px}
.inv-of{font-size:12px;color:var(--t3)}
.inv-target{font-size:14px;font-weight:700;color:var(--t2)}
.inv-bar-wrap{height:6px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden;margin-bottom:6px}
.inv-bar-fill{height:100%;border-radius:4px;transition:width .7s cubic-bezier(.4,0,.2,1)}
.inv-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--t3);margin-bottom:12px}
.inv-pct{font-weight:700;color:var(--t2)}
.inv-actions{display:flex;gap:8px}
.btn-deposit{flex:1;padding:8px;border:1px solid var(--green-b);background:var(--green-bg);color:var(--green);border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-deposit:hover{background:rgba(0,230,118,.18)}
.btn-withdraw{flex:1;padding:8px;border:1px solid rgba(255,165,0,.3);background:rgba(255,165,0,.07);color:var(--orange);border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-withdraw:hover{background:rgba(255,165,0,.15)}
.btn-del-inv{width:36px;padding:8px;border:1px solid rgba(255,80,80,.25);background:rgba(255,80,80,.07);color:var(--red);border-radius:7px;font-size:12px;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-del-inv:hover{background:rgba(255,80,80,.18)}

/* ─────────────────────────────────────
   PARCELAMENTOS & ASSINATURAS
───────────────────────────────────── */
.subs-tab{padding:8px 18px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--t2);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.subs-tab.active{background:var(--green);color:#000;border-color:var(--green)}
.subs-list{display:flex;flex-direction:column;gap:10px}
.sub-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:var(--ease)}
.sub-card:hover{border-color:var(--border2)}
.sub-card-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.sub-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:rgba(255,255,255,.06)}
.sub-name{font-size:14px;font-weight:800;color:#fff;flex:1}
.sub-badge{font-size:10px;padding:3px 9px;border-radius:20px;font-weight:700;background:rgba(0,230,118,.12);color:var(--green)}
.sub-badge.purple{background:rgba(147,51,234,.15);color:#c084fc}
.sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.sub-field{background:rgba(255,255,255,.04);border-radius:7px;padding:8px 10px}
.sub-field-label{font-size:10px;color:var(--t3);font-weight:600;margin-bottom:2px}
.sub-field-val{font-size:14px;font-weight:800;color:#fff}
.sub-due{font-size:11px;color:var(--t3);margin-bottom:10px}
.sub-bar-wrap{height:4px;background:rgba(255,255,255,.07);border-radius:3px;overflow:hidden;margin-bottom:5px}
.sub-bar-fill{height:100%;border-radius:3px;background:var(--green);transition:width .7s}
.sub-progress-txt{font-size:11px;color:var(--t3);margin-bottom:10px}
.sub-actions{display:flex;gap:8px}
.btn-edit-sub{flex:1;padding:7px;border:1px solid var(--border2);background:rgba(255,255,255,.05);color:var(--t2);border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-cancel-sub{flex:1;padding:7px;border:1px solid rgba(255,80,80,.25);background:rgba(255,80,80,.07);color:var(--red);border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease)}

/* ─────────────────────────────────────
   REMINDERS (kept for compatibility)
───────────────────────────────────── */
.reminders-list{display:flex;flex-direction:column;gap:8px}
.reminder-item{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--rs);padding:12px 15px;
  display:flex;align-items:center;gap:11px;transition:var(--ease);
}
.reminder-item:hover{border-color:var(--border2)}
.reminder-item.overdue{border-color:var(--red-b);background:var(--red-bg)}
.reminder-emoji{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--card2);border-radius:9px}
.reminder-info{flex:1;min-width:0}
.reminder-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:2px}
.reminder-due{font-size:11px;color:var(--t3)}
.reminder-amount{font-size:14px;font-weight:700;color:var(--orange);white-space:nowrap}
.reminder-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.btn-pay{padding:5px 11px;border:1px solid var(--green-b);background:var(--green-bg);color:var(--green);border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-pay:hover{background:rgba(0,230,118,.15)}

/* ─────────────────────────────────────
   SHOPPING
───────────────────────────────────── */
.add-item-row{display:flex;gap:7px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.add-item-row input{flex:1;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:7px;color:var(--t1);font-size:13px;font-family:var(--font);outline:none;transition:var(--ease)}
.add-item-row input:focus{border-color:var(--green);background:rgba(0,230,118,.04)}
.shopping-items{display:flex;flex-direction:column}
.shop-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.shop-item:last-child{border-bottom:none}
.shop-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--ease);font-size:10px;font-weight:800;color:#02200a}
.shop-check.checked{background:var(--green);border-color:var(--green)}
.shop-name{flex:1;font-size:13px;font-weight:500;color:var(--t1);transition:var(--ease)}
.shop-name.done,.shop-name.checked{text-decoration:line-through;color:var(--t3)}
.shop-qty{font-size:11px;color:var(--t3);background:var(--card2);padding:2px 7px;border-radius:4px}
.shop-del{background:none;border:none;color:var(--t3);cursor:pointer;font-size:13px;transition:var(--ease);padding:3px}
.shop-del:hover{color:var(--red)}

/* ─────────────────────────────────────
   SETTINGS
───────────────────────────────────── */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bot-number{background:var(--card2);border:1px solid var(--green-b);border-radius:9px;padding:14px;margin-bottom:14px}
.bn-label{font-size:10px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.bn-number{font-size:16px;font-weight:800;color:var(--green);letter-spacing:.4px}
.commands-list{display:flex;flex-direction:column;gap:7px}
.cmd{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--t2);padding:6px 0;border-bottom:1px solid var(--border)}
.cmd:last-child{border-bottom:none}
.cmd code{background:var(--card2);padding:2px 7px;border-radius:5px;font-size:11.5px;color:var(--green);font-family:'Courier New',monospace}
.plan-info{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:12px;background:var(--card2);border-radius:9px;border:1px solid var(--border)}
.plan-badge{background:linear-gradient(135deg,var(--green),var(--green-d));color:#02200a;font-size:12px;font-weight:800;padding:4px 12px;border-radius:20px;letter-spacing:.4px}
.plan-trial{font-size:12.5px;color:var(--t2)}
.plan-features{display:flex;flex-direction:column;gap:7px}
.plan-features div{font-size:13px;color:var(--t1)}

/* ─────────────────────────────────────
   MODALS
───────────────────────────────────── */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:500;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-card{
  background:var(--card);border:1px solid var(--border2);
  border-radius:16px;padding:24px;
  width:100%;max-width:400px;max-height:90vh;overflow-y:auto;
  box-shadow:0 28px 56px rgba(0,0,0,.75);
  animation:mup .2s cubic-bezier(.4,0,.2,1);
}
@keyframes mup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-header h3{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.3px}
.modal-header button{background:rgba(255,255,255,.06);border:none;color:var(--t2);width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:var(--ease)}
.modal-header button:hover{background:var(--red-bg);color:var(--red)}
.form-row{display:flex;gap:7px;margin-bottom:13px}
.type-btn{flex:1;padding:9px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--t2);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:var(--ease);text-align:center}
.type-btn.active[data-type="expense"]{background:var(--red-bg);border-color:var(--red-b);color:var(--red)}
.type-btn.active[data-type="income"]{background:var(--green-bg);border-color:var(--green-b);color:var(--green)}
.type-btn:hover{border-color:var(--border2)}

/* ─────────────────────────────────────
   REMINDERS (lembretes de pagamento)
───────────────────────────────────── */
.rem-list{display:flex;flex-direction:column;gap:10px}
.rem-item{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--card2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:var(--ease)}
.rem-item:hover{border-color:var(--border2);background:var(--card3)}
.rem-item.rem-overdue{border-color:rgba(255,23,68,.35);background:rgba(255,23,68,.04)}
.rem-item.rem-paid{opacity:.55}
.rem-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}
.rem-emoji{font-size:24px;line-height:1;flex-shrink:0}
.rem-info{flex:1;min-width:0}
.rem-title{font-size:14px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rem-title strong{color:var(--green)}
.rem-meta{font-size:12px;color:var(--t3);margin-top:2px}
.rem-meta strong{color:var(--t2);font-weight:600}
.rem-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.rem-tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;border:1px solid transparent}
.rem-tag.rec{background:rgba(68,138,255,.1);border-color:rgba(68,138,255,.25);color:var(--blue)}
.rem-tag.one{background:rgba(124,77,255,.1);border-color:rgba(124,77,255,.25);color:#b388ff}
.rem-tag.adv{background:rgba(255,145,0,.08);border-color:rgba(255,145,0,.2);color:var(--orange)}
.rem-tag.over{background:var(--red-bg);border-color:var(--red-b);color:var(--red)}
.rem-tag.today{background:rgba(0,230,118,.08);border-color:var(--green-b);color:var(--green)}
.rem-tag.paid{background:rgba(0,230,118,.06);border-color:var(--green-b);color:var(--green)}
.rem-actions{display:flex;gap:6px;flex-shrink:0;align-items:center}
.btn-sm{padding:5px 10px;background:var(--card3);color:var(--t2);border:1px solid var(--border2);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-sm:hover{border-color:var(--border2);color:var(--t1)}
.btn-sm-green{padding:5px 11px;background:var(--green-bg);color:var(--green);border:1px solid var(--green-b);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-sm-green:hover{background:rgba(0,230,118,.15)}
.btn-sm-blue{padding:5px 9px;background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-sm-blue:hover{background:rgba(68,138,255,.14)}
.btn-sm-orange{padding:5px 11px;background:rgba(255,145,0,.1);color:var(--orange);border:1px solid rgba(255,145,0,.3);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);transition:var(--ease)}
.btn-sm-orange:hover{background:rgba(255,145,0,.18)}

/* ─────────────────────────────────────
   TOAST
───────────────────────────────────── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--card2);border:1px solid var(--border2);border-radius:10px;padding:11px 15px;font-size:13px;font-weight:600;color:#fff;box-shadow:0 8px 28px rgba(0,0,0,.5);z-index:999;max-width:270px;animation:ti .22s ease}
.toast.success{border-color:var(--green-b);background:var(--green-bg);color:var(--green)}
.toast.error{border-color:var(--red-b);background:var(--red-bg);color:var(--red)}
@keyframes ti{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─────────────────────────────────────
   RESPONSIVE — TABLET
───────────────────────────────────── */
@media(max-width:900px){
  :root{--sidebar:0px}
  .sidebar{transform:translateX(-100%);width:240px}
  .sidebar.open{transform:translateX(0)}
  .main-wrap{margin-left:0}
  .menu-btn{display:flex}
  .balance-cards{grid-template-columns:1fr 1fr}
  .charts-row{grid-template-columns:1fr}
  .limits-grid,.settings-grid{grid-template-columns:1fr}
  #limitsPreviewList{grid-template-columns:1fr 1fr}
  .monthly-box{height:160px}
  .category-box{height:200px}
  .main-content{padding:14px}
  .topbar{padding:0 14px}
}

/* ─────────────────────────────────────
   RESPONSIVE — MOBILE
───────────────────────────────────── */
@media(max-width:600px){
  .balance-cards{grid-template-columns:1fr}
  #limitsPreviewList{grid-template-columns:1fr}
  .page-actions{flex-direction:column;align-items:stretch}
  .actions-right{flex-wrap:wrap;justify-content:space-between}
  .month-input{flex:1}
  .auth-card{padding:26px 18px}
  .funds-grid{grid-template-columns:1fr}
  .bal-value{font-size:20px}
  .dash-greeting{font-size:17px}
  .monthly-box{height:140px}
  .category-box{height:180px}
  .card{padding:14px}
  .topbar-center h1{font-size:14px}
  .charts-row{gap:10px}
  .reminder-item{flex-wrap:wrap}
  .reminder-actions{margin-left:0;width:100%;justify-content:flex-end;margin-top:6px}
  .rem-item{flex-direction:column;gap:10px}
  .rem-actions{align-self:flex-start;margin-left:0;margin-top:0}
  .limit-header{flex-wrap:wrap;gap:4px}
  .limits-grid{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
}
