/* ================================================
   PlenarA+ — Premium UI v2
   Azul Escuro · Verde · Branco
   ================================================ */

:root {
  --primary:       #0f2d55;
  --primary-light: #1a4480;
  --primary-soft:  #e8f0fb;
  --accent:        #00c97a;
  --accent-dark:   #00a864;
  --accent-light:  #e6faf3;
  --danger:        #f53b57;
  --danger-light:  #fff0f3;
  --warning:       #ff9f1a;
  --warning-light: #fff8ee;
  --purple:        #6c5ce7;
  --purple-light:  #f0eeff;
  --white:         #ffffff;
  --bg:            #f0f4fa;
  --bg-card:       #ffffff;
  --text:          #0d1b2a;
  --text-muted:    #6b7a99;
  --text-light:    #b0bac7;
  --border:        #e2e8f4;
  --shadow-sm:     0 2px 8px rgba(15,45,85,.06);
  --shadow:        0 4px 20px rgba(15,45,85,.09);
  --shadow-md:     0 8px 32px rgba(15,45,85,.13);
  --shadow-lg:     0 16px 48px rgba(15,45,85,.18);
  --radius:        18px;
  --radius-sm:     12px;
  --radius-xs:     8px;
  --sidebar-w:     260px;
  --topbar-h:      64px;
  --ease:          cubic-bezier(.4,0,.2,1);
  --transition:    all .22s var(--ease);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;min-height:100vh}

/* ── SPLASH ──────────────────────────────────────────── */
#splash-screen{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 60%,#004d3022 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s ease,visibility .6s ease;
}
#splash-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.splash-content{text-align:center;color:#fff}
.splash-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}
.splash-logo .logo-icon{font-size:2.8rem;color:var(--accent);animation:pulseGlow 2s infinite}
.splash-logo .logo-text{font-size:2.8rem;font-weight:800;letter-spacing:-1px}
.splash-logo .logo-plus{color:var(--accent)}
.splash-tagline{font-size:.9rem;opacity:.65;letter-spacing:2px;text-transform:uppercase;margin-bottom:36px}
.splash-loader{width:200px;height:4px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden;margin:0 auto}
.loader-bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),#00ffaa);border-radius:99px;animation:loaderFill 1.8s ease forwards}
@keyframes loaderFill{to{width:100%}}

/* ── SIDEBAR ─────────────────────────────────────────── */
.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);
  background:var(--primary);
  display:flex;flex-direction:column;z-index:100;
  box-shadow:4px 0 24px rgba(0,0,0,.15);
  transition:transform .28s var(--ease);
}
.sidebar-header{
  padding:22px 20px 16px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.logo{display:flex;align-items:center;gap:9px}
.logo .logo-icon{font-size:1.35rem;color:var(--accent)}
.logo .logo-text{font-size:1.35rem;font-weight:800;color:#fff;letter-spacing:-.5px}
.logo .logo-plus{color:var(--accent)}
.sidebar-toggle{
  background:rgba(255,255,255,.08);border:none;color:#fff;
  width:32px;height:32px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--transition);
}
.sidebar-toggle:hover{background:rgba(255,255,255,.16)}

.user-profile{
  padding:18px 20px;display:flex;align-items:center;gap:12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.user-avatar{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;position:relative;
}
.avatar-status{
  width:10px;height:10px;background:#2ecc71;border-radius:50%;
  border:2px solid var(--primary);position:absolute;bottom:-2px;right:-2px;
}
.user-name{font-weight:600;color:#fff;font-size:.88rem}
.user-subtitle{font-size:.72rem;color:var(--accent);margin-top:1px}

.sidebar-nav{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--radius-sm);
  color:rgba(255,255,255,.6);text-decoration:none;font-size:.88rem;font-weight:500;
  transition:var(--transition);position:relative;
}
.nav-item i{width:17px;text-align:center;font-size:.95rem}
.nav-item span{flex:1}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{
  background:linear-gradient(135deg,rgba(0,201,122,.18),rgba(0,201,122,.08));
  color:var(--accent);border:1px solid rgba(0,201,122,.25);
}
.nav-item.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--accent);border-radius:0 3px 3px 0;
}
.nav-badge{
  background:var(--accent);color:var(--primary);
  font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:99px;min-width:20px;text-align:center;
}
.nav-ai-dot{width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulseDot 2s infinite}

.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.08)}
.btn-voice-mini{
  width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  border:none;color:#fff;padding:11px 16px;border-radius:var(--radius-sm);cursor:pointer;
  font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:9px;transition:var(--transition);
  font-family:'Inter',sans-serif;
}
.btn-voice-mini:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,201,122,.35)}

/* ── MAIN ────────────────────────────────────────────── */
.main-content{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;transition:margin .28s var(--ease)}

/* ── TOPBAR ──────────────────────────────────────────── */
.topbar{
  background:#fff;border-bottom:1px solid var(--border);
  padding:0 28px;height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm);
}
.topbar-left{display:flex;align-items:center;gap:14px}
.mobile-menu-btn{display:none;background:none;border:none;font-size:1.2rem;color:var(--primary);cursor:pointer;padding:6px}
.page-title{font-size:1.05rem;font-weight:700;color:var(--primary)}
.topbar-right{display:flex;align-items:center;gap:12px}
.date-time{font-size:.8rem;color:var(--text-muted);font-weight:500}
.topbar-btn{
  width:38px;height:38px;background:var(--bg);border:1px solid var(--border);
  border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:var(--transition);position:relative;font-size:.95rem;
}
.topbar-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.notif-dot{
  width:8px;height:8px;background:var(--accent);border-radius:50%;
  position:absolute;top:5px;right:5px;display:none;
}
.notif-dot.active{display:block;animation:pulseDot 2s infinite}

/* ── CONTENT ─────────────────────────────────────────── */
.content-area{padding:24px 28px;flex:1}
.view{display:none;animation:fadeUp .28s ease}
.view.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.view-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px}
.view-header h2{font-size:1.45rem;font-weight:700;color:var(--primary);margin-bottom:2px}
.view-subtitle{font-size:.82rem;color:var(--text-muted)}

/* ── WELCOME BANNER ──────────────────────────────────── */
.welcome-banner{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);
  border-radius:var(--radius);padding:24px 28px;color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;position:relative;overflow:hidden;
}
.welcome-banner::before{
  content:'';position:absolute;right:-50px;top:-50px;
  width:180px;height:180px;background:var(--accent);opacity:.07;border-radius:50%;
}
.welcome-text h2{font-size:1.55rem;font-weight:700;margin-bottom:3px}
.welcome-text p{opacity:.72;font-size:.88rem}
.greeting-badge{
  background:rgba(0,201,122,.2);color:var(--accent);
  border:1px solid rgba(0,201,122,.3);padding:8px 16px;
  border-radius:99px;font-size:.8rem;font-weight:600;
  display:flex;align-items:center;gap:6px;flex-shrink:0;
  backdrop-filter:blur(10px);
}

/* ── STATS GRID ──────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.stat-card{
  background:#fff;border-radius:var(--radius);padding:18px 20px;
  display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);
  cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;
}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px}
.stat-card.blue::after{background:var(--primary)}
.stat-card.green::after{background:var(--accent)}
.stat-card.teal::after{background:#00b4cc}
.stat-card.red::after{background:var(--danger)}
.stat-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.stat-card.blue .stat-icon{background:var(--primary-soft);color:var(--primary)}
.stat-card.green .stat-icon{background:var(--accent-light);color:var(--accent-dark)}
.stat-card.teal .stat-icon{background:#e0f8fc;color:#00849a}
.stat-card.red .stat-icon{background:var(--danger-light);color:var(--danger)}
.stat-info{flex:1}
.stat-value{font-size:1.4rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:3px}
.stat-label{font-size:.75rem;color:var(--text-muted);font-weight:500}
.stat-arrow{color:var(--text-light);font-size:.75rem}

/* ── DASHBOARD GRID ──────────────────────────────────── */
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card-full{grid-column:1/-1}

/* ── CARD ────────────────────────────────────────────── */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:var(--transition)}
.card:hover{box-shadow:var(--shadow-md)}
.card-header{
  padding:16px 20px 13px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.card-header h3{font-size:.92rem;font-weight:600;color:var(--primary);display:flex;align-items:center;gap:7px}
.card-header h3 i{color:var(--accent)}
.card-badge{
  background:var(--danger-light);color:var(--danger);
  font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:99px;
}
.btn-sm{
  background:var(--bg);border:1px solid var(--border);color:var(--primary);
  padding:5px 13px;border-radius:8px;font-size:.76rem;font-weight:600;cursor:pointer;
  transition:var(--transition);font-family:'Inter',sans-serif;
}
.btn-sm:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── PRIORITY CARD ───────────────────────────────────── */
.priority-content{padding:12px 16px;display:flex;flex-direction:column;gap:8px;min-height:80px}
.priority-task-item{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--bg);border-radius:var(--radius-sm);transition:var(--transition);
  border-left:3px solid transparent;
}
.priority-task-item.alta{border-left-color:var(--danger)}
.priority-task-item.media{border-left-color:var(--warning)}
.priority-task-item.baixa{border-left-color:var(--accent)}
.priority-task-item:hover{background:var(--primary-soft)}
.priority-task-title{flex:1;font-size:.85rem;font-weight:600;color:var(--text)}
.priority-task-due{font-size:.73rem;color:var(--text-muted)}
.priority-task-due.overdue{color:var(--danger);font-weight:600}
.priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-alta{background:var(--danger)}
.dot-media{background:var(--warning)}
.dot-baixa{background:var(--accent)}

/* ── BALANCE MINI ────────────────────────────────────── */
.balance-mini{padding:14px 20px 6px;display:flex;flex-direction:column;gap:8px}
.balance-mini-row{display:flex;align-items:center;gap:10px;font-size:.85rem}
.balance-mini-icon{
  width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
}
.balance-mini-row.income .balance-mini-icon{background:var(--accent-light);color:var(--accent-dark)}
.balance-mini-row.expense .balance-mini-icon{background:var(--danger-light);color:var(--danger)}
.balance-mini-row.balance .balance-mini-icon{background:var(--primary-soft);color:var(--primary)}
.balance-mini-row span{flex:1;color:var(--text-muted)}
.balance-mini-row strong{font-weight:700;font-size:.9rem}
.balance-mini-row.income strong{color:var(--accent-dark)}
.balance-mini-row.expense strong{color:var(--danger)}
.balance-mini-row.balance strong{color:var(--primary);font-size:1rem}
.balance-mini-divider{height:1px;background:var(--border);margin:2px 0}

/* ── AI CARD ─────────────────────────────────────────── */
.ai-card{border:1px solid rgba(0,201,122,.18)}
.ai-pulse-wrap{display:flex;align-items:center;gap:7px;font-size:.75rem;color:var(--accent-dark);font-weight:500}
.ai-insight-text{
  padding:16px 20px;font-size:.88rem;line-height:1.7;color:var(--text);
  background:linear-gradient(135deg,var(--accent-light),#f0f8ff);
  border-top:none;
}
.ai-insight-loading{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-style:italic}
.ai-card-footer{
  padding:12px 20px 16px;display:flex;gap:10px;
  border-top:1px solid var(--border);
}
.btn-ai-chat{
  flex:1;background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff;border:none;padding:10px 16px;border-radius:var(--radius-sm);
  font-size:.83rem;font-weight:600;cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:8px;transition:var(--transition);font-family:'Inter',sans-serif;
}
.btn-ai-chat:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(15,45,85,.3)}
.btn-ai-voice{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);
  font-size:.83rem;font-weight:600;cursor:pointer;display:flex;align-items:center;
  gap:7px;transition:var(--transition);font-family:'Inter',sans-serif;
}
.btn-ai-voice:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,201,122,.35)}

/* ── MINI LISTS ──────────────────────────────────────── */
.mini-task-list{
  padding:10px 14px;max-height:220px;overflow-y:auto;
  display:flex;flex-direction:column;gap:6px;
}
.mini-task-item{
  display:flex;align-items:center;gap:9px;padding:9px 11px;
  border-radius:var(--radius-xs);background:var(--bg);transition:var(--transition);cursor:pointer;
}
.mini-task-item:hover{background:var(--primary-soft)}
.mini-task-check{font-size:1rem;color:var(--text-light);cursor:pointer;transition:var(--transition);flex-shrink:0}
.mini-task-check:hover{color:var(--accent)}
.mini-task-title{flex:1;font-size:.83rem;font-weight:500}
.mini-task-title.done{text-decoration:line-through;color:var(--text-muted)}
.mini-task-badge{font-size:.68rem;padding:2px 8px;border-radius:99px;font-weight:600;flex-shrink:0}
.badge-alta{background:var(--danger-light);color:var(--danger)}
.badge-media{background:var(--warning-light);color:var(--warning)}
.badge-baixa{background:var(--accent-light);color:var(--accent-dark)}

/* ── EMPTY STATE ─────────────────────────────────────── */
.empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:52px 20px;text-align:center;color:var(--text-muted);
}
.empty-state i{font-size:2.8rem;margin-bottom:14px;opacity:.25;color:var(--primary)}
.empty-state h3{font-size:.95rem;font-weight:600;margin-bottom:5px;color:var(--text)}
.empty-state p{font-size:.82rem;opacity:.7}
.empty-state-mini{
  display:flex;flex-direction:column;align-items:center;padding:24px 16px;
  color:var(--text-muted);text-align:center;
}
.empty-state-mini i{font-size:1.6rem;margin-bottom:7px;opacity:.22;color:var(--primary)}
.empty-state-mini p{font-size:.78rem}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;
  padding:11px 20px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;
  cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:var(--transition);
  font-family:'Inter',sans-serif;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(15,45,85,.3)}
.btn-ghost{
  background:none;border:1px solid var(--border);color:var(--text-muted);
  padding:11px 20px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;
  cursor:pointer;transition:var(--transition);font-family:'Inter',sans-serif;
}
.btn-ghost:hover{background:var(--bg);color:var(--text)}

/* ── FILTER BAR ──────────────────────────────────────── */
.filter-bar{display:flex;gap:7px;margin-bottom:18px;flex-wrap:wrap}
.filter-btn{
  background:#fff;border:1px solid var(--border);color:var(--text-muted);
  padding:7px 16px;border-radius:99px;font-size:.8rem;font-weight:500;cursor:pointer;
  transition:var(--transition);font-family:'Inter',sans-serif;display:flex;align-items:center;gap:6px;
}
.filter-btn.active,.filter-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── TASKS GRID ──────────────────────────────────────── */
.tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.task-card{
  background:#fff;border-radius:var(--radius);padding:16px 18px;
  box-shadow:var(--shadow);transition:var(--transition);
  border-left:4px solid transparent;position:relative;
}
.task-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.task-card.priority-alta{border-left-color:var(--danger)}
.task-card.priority-media{border-left-color:var(--warning)}
.task-card.priority-baixa{border-left-color:var(--accent)}
.task-card.status-concluida{opacity:.6}
.task-card.status-concluida .task-card-title{text-decoration:line-through;color:var(--text-muted)}
.task-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.task-card-title{font-size:.9rem;font-weight:600;color:var(--primary);flex:1;line-height:1.4}
.task-card-actions{display:flex;gap:5px;margin-left:8px}
.task-action-btn{
  width:28px;height:28px;background:var(--bg);border:none;border-radius:7px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:.72rem;color:var(--text-muted);transition:var(--transition);
}
.task-action-btn:hover{background:var(--primary);color:#fff}
.task-action-btn.complete:hover{background:var(--accent);color:#fff}
.task-action-btn.delete:hover{background:var(--danger);color:#fff}
.task-card-desc{font-size:.79rem;color:var(--text-muted);margin-bottom:10px;line-height:1.5}
.task-card-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.task-priority-badge{font-size:.7rem;padding:3px 10px;border-radius:99px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.task-due{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.task-due.overdue{color:var(--danger);font-weight:600}
.task-cat-tag{font-size:.7rem;color:var(--text-muted);background:var(--bg);padding:2px 8px;border-radius:99px}

/* ── FINANCE SUMMARY BAR ─────────────────────────────── */
.finance-summary-bar{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);
  border-radius:var(--radius);padding:24px 28px;margin-bottom:18px;
  display:flex;align-items:center;color:#fff;box-shadow:var(--shadow-md);
}
.fsb-card{flex:1;display:flex;align-items:center;gap:14px}
.fsb-icon{
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;
}
.fsb-card.income .fsb-icon{background:rgba(0,201,122,.25);color:#00ffaa}
.fsb-card.expense .fsb-icon{background:rgba(245,59,87,.25);color:#ff7d8f}
.fsb-label{font-size:.75rem;opacity:.7;margin-bottom:3px;text-transform:uppercase;letter-spacing:.8px}
.fsb-value{font-size:1.3rem;font-weight:700}
.fsb-divider{text-align:center;padding:0 24px;flex-shrink:0}
.fsb-balance-label{font-size:.72rem;opacity:.65;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.fsb-balance{font-size:1.8rem;font-weight:800;line-height:1}
.fsb-balance-sub{font-size:.72rem;opacity:.65;margin-top:4px}

/* ── CATEGORY FILTER ─────────────────────────────────── */
.category-filter{display:flex;gap:7px;margin-bottom:14px;flex-wrap:wrap;overflow-x:auto;padding-bottom:4px}
.cat-btn{
  background:#fff;border:1px solid var(--border);color:var(--text-muted);
  padding:6px 14px;border-radius:99px;font-size:.77rem;font-weight:500;
  cursor:pointer;transition:var(--transition);font-family:'Inter',sans-serif;
  white-space:nowrap;display:flex;align-items:center;gap:5px;
}
.cat-btn.active,.cat-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── FINANCE AI ALERT ────────────────────────────────── */
.finance-ai-alert{
  display:flex;align-items:flex-start;gap:12px;padding:14px 18px;
  background:linear-gradient(135deg,var(--warning-light),#fff8f0);
  border:1px solid rgba(255,159,26,.3);border-radius:var(--radius-sm);
  margin-bottom:14px;font-size:.84rem;color:var(--text);line-height:1.5;
}
.finance-ai-alert i{color:var(--warning);font-size:1.1rem;flex-shrink:0;margin-top:1px}
.finance-ai-alert.hidden{display:none}
.finance-ai-alert.danger-alert{
  background:linear-gradient(135deg,var(--danger-light),#fff8f9);
  border-color:rgba(245,59,87,.3);
}
.finance-ai-alert.danger-alert i{color:var(--danger)}

/* ── TRANSACTIONS ────────────────────────────────────── */
.search-mini{
  display:flex;align-items:center;gap:7px;background:var(--bg);
  border:1px solid var(--border);border-radius:8px;padding:6px 11px;
}
.search-mini i{color:var(--text-muted);font-size:.78rem}
.search-mini input{background:none;border:none;outline:none;font-size:.8rem;color:var(--text);width:130px;font-family:'Inter',sans-serif}
.transactions-list{padding:10px 14px;display:flex;flex-direction:column;gap:7px;max-height:420px;overflow-y:auto}
.transaction-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border-radius:var(--radius-sm);background:var(--bg);transition:var(--transition);
}
.transaction-item:hover{background:var(--primary-soft)}
.trans-icon{
  width:38px;height:38px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:.95rem;flex-shrink:0;
}
.trans-icon.income{background:var(--accent-light);color:var(--accent-dark)}
.trans-icon.expense{background:var(--danger-light);color:var(--danger)}
.trans-info{flex:1;min-width:0}
.trans-desc{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trans-cat{font-size:.72rem;color:var(--text-muted);margin-top:2px;text-transform:capitalize}
.trans-right{text-align:right;flex-shrink:0}
.trans-amount{font-size:.9rem;font-weight:700}
.trans-amount.income{color:var(--accent-dark)}
.trans-amount.expense{color:var(--danger)}
.trans-date{font-size:.7rem;color:var(--text-muted);margin-top:2px}
.trans-delete{background:none;border:none;color:var(--text-light);cursor:pointer;padding:5px;border-radius:6px;transition:var(--transition);font-size:.78rem}
.trans-delete:hover{background:var(--danger-light);color:var(--danger)}

/* ── AI CONTAINER ────────────────────────────────────── */
.ai-status-badge{display:flex;align-items:center;gap:7px;font-size:.8rem;color:var(--accent-dark);font-weight:500;background:var(--accent-light);padding:6px 14px;border-radius:99px}
.ai-container{
  display:flex;flex-direction:column;
  height:calc(100vh - 210px);min-height:450px;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
}
.ai-chat-area{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:14px}
.ai-message{display:flex;gap:11px;animation:fadeUp .28s ease}
.ai-message.user{flex-direction:row-reverse}
.ai-avatar{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;
}
.ai-message.user .ai-avatar{background:linear-gradient(135deg,var(--accent),var(--accent-dark))}
.ai-bubble{
  max-width:72%;padding:13px 16px;border-radius:14px;
  font-size:.86rem;line-height:1.65;color:var(--text);
}
.ai-message.bot .ai-bubble{background:var(--bg);border-radius:4px 14px 14px 14px}
.ai-message.user .ai-bubble{
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff;border-radius:14px 4px 14px 14px;
}
.ai-bubble p{margin-bottom:7px}
.ai-bubble p:last-child{margin-bottom:0}
.ai-bubble ul{padding-left:16px}
.ai-bubble ul li{margin-bottom:3px}
.ai-bubble strong{font-weight:600}

.voice-status{
  display:flex;align-items:center;gap:11px;padding:9px 16px;
  background:var(--accent-light);border-top:1px solid rgba(0,201,122,.2);
}
.voice-status.hidden{display:none}
.voice-waves{display:flex;align-items:center;gap:3px;height:22px}
.voice-waves span{width:3px;background:var(--accent);border-radius:99px;animation:wave 1s ease-in-out infinite}
.voice-waves span:nth-child(1){height:7px;animation-delay:0s}
.voice-waves span:nth-child(2){height:14px;animation-delay:.1s}
.voice-waves span:nth-child(3){height:22px;animation-delay:.2s}
.voice-waves span:nth-child(4){height:14px;animation-delay:.3s}
.voice-waves span:nth-child(5){height:7px;animation-delay:.4s}
@keyframes wave{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.5)}}
#voice-status-text{font-size:.82rem;color:var(--accent-dark);font-weight:500}

.ai-input-section{border-top:1px solid var(--border);padding:14px 18px;background:#fff}
.quick-actions{display:flex;gap:7px;margin-bottom:11px;flex-wrap:wrap}
.quick-btn{
  background:var(--bg);border:1px solid var(--border);color:var(--text);
  padding:6px 13px;border-radius:99px;font-size:.76rem;font-weight:500;cursor:pointer;
  transition:var(--transition);font-family:'Inter',sans-serif;
}
.quick-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.ai-input-area{display:flex;align-items:flex-end;gap:9px}
.ai-input-wrapper{flex:1}
.ai-input-wrapper textarea{
  width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:11px 14px;font-size:.86rem;resize:none;outline:none;
  font-family:'Inter',sans-serif;color:var(--text);line-height:1.5;
  transition:var(--transition);max-height:120px;
}
.ai-input-wrapper textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,45,85,.08)}
.voice-btn{
  width:46px;height:46px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;flex-shrink:0;transition:var(--transition);
}
.voice-btn:hover{transform:scale(1.05);box-shadow:0 6px 16px rgba(0,201,122,.4)}
.voice-btn.recording{background:linear-gradient(135deg,var(--danger),#c0392b);animation:pulseRecord 1s infinite}
.send-btn{
  width:46px;height:46px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:.95rem;flex-shrink:0;transition:var(--transition);
}
.send-btn:hover{transform:scale(1.05);box-shadow:0 6px 16px rgba(15,45,85,.35)}

/* ── MODAIS ──────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.42);backdrop-filter:blur(4px);
  z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;visibility:hidden;transition:var(--transition);
}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{
  background:#fff;border-radius:20px;width:100%;max-width:500px;
  box-shadow:var(--shadow-lg);animation:modalPop .3s cubic-bezier(.34,1.56,.64,1);
}
.modal-sm{max-width:410px}
@keyframes modalPop{from{transform:scale(.9) translateY(20px)}to{transform:scale(1) translateY(0)}}
.modal-header{
  padding:18px 22px 14px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.modal-header h3{font-size:1rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:8px}
.modal-header h3 i{color:var(--accent)}
.modal-close{
  width:30px;height:30px;background:var(--bg);border:none;border-radius:7px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:.85rem;transition:var(--transition);
}
.modal-close:hover{background:var(--danger);color:#fff}
.modal-body{padding:18px 22px}
.modal-footer{padding:14px 22px 18px;display:flex;justify-content:flex-end;gap:9px;border-top:1px solid var(--border)}

/* ── FORMS ───────────────────────────────────────────── */
.form-group{margin-bottom:14px}
.form-group label{display:flex;align-items:center;gap:6px;font-size:.79rem;font-weight:600;color:var(--text);margin-bottom:5px}
.form-group label i{color:var(--accent);font-size:.8rem}
.form-group input,.form-group textarea,.form-group select{
  width:100%;border:1px solid var(--border);border-radius:var(--radius-xs);
  padding:9px 13px;font-size:.86rem;outline:none;color:var(--text);
  font-family:'Inter',sans-serif;transition:var(--transition);background:#fff;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,45,85,.08);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.type-toggle{display:flex;gap:9px;margin-bottom:4px}
.type-btn{
  flex:1;padding:11px;border:2px solid var(--border);border-radius:var(--radius-sm);
  background:#fff;cursor:pointer;font-size:.85rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:7px;
  transition:var(--transition);font-family:'Inter',sans-serif;color:var(--text-muted);
}
.type-btn[data-type="receita"].active{border-color:var(--accent);background:var(--accent-light);color:var(--accent-dark)}
.type-btn[data-type="despesa"].active{border-color:var(--danger);background:var(--danger-light);color:var(--danger)}
.input-currency{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-xs);overflow:hidden;transition:var(--transition)}
.input-currency:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,45,85,.08)}
.input-currency span{padding:9px 13px;background:var(--bg);color:var(--text-muted);font-size:.86rem;font-weight:600;border-right:1px solid var(--border)}
.input-currency input{border:none;border-radius:0;box-shadow:none!important;flex:1}

/* ── VOICE MODAL ─────────────────────────────────────── */
.voice-orb{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  display:flex;align-items:center;justify-content:center;font-size:2.3rem;color:#fff;
  margin:0 auto 14px;cursor:pointer;transition:var(--transition);
  box-shadow:0 8px 28px rgba(15,45,85,.3);
}
.voice-orb:hover{transform:scale(1.05)}
.voice-orb.active{
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  animation:pulseRecord 1s infinite;box-shadow:0 8px 28px rgba(0,201,122,.45);
}
.voice-instruction{font-size:.87rem;color:var(--text-muted);margin-bottom:14px;font-weight:500}
.voice-transcript-box{
  background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:12px 16px;min-height:52px;margin-bottom:14px;text-align:left;
}
.voice-transcript-text{font-size:.86rem;color:var(--text);line-height:1.5;font-style:italic}
.voice-examples p{font-size:.77rem;color:var(--text-muted);margin-bottom:8px}
.voice-example-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.voice-example-pills span{
  background:var(--primary-soft);color:var(--primary);
  font-size:.73rem;padding:4px 11px;border-radius:99px;font-weight:500;
}

/* ── NOTIFICATIONS ───────────────────────────────────── */
#notification-container{
  position:fixed;top:18px;right:18px;z-index:9000;
  display:flex;flex-direction:column;gap:9px;max-width:350px;
}
.notification-toast{
  background:#fff;border-radius:14px;padding:13px 16px;box-shadow:var(--shadow-lg);
  display:flex;align-items:flex-start;gap:11px;
  animation:toastIn .32s cubic-bezier(.34,1.56,.64,1);
  border-left:4px solid var(--primary);
}
.notification-toast.success{border-left-color:var(--accent)}
.notification-toast.error{border-left-color:var(--danger)}
.notification-toast.warning{border-left-color:var(--warning)}
.notification-toast.hide{animation:toastOut .28s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}
.toast-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.notification-toast.success .toast-icon{background:var(--accent-light);color:var(--accent-dark)}
.notification-toast.error .toast-icon{background:var(--danger-light);color:var(--danger)}
.notification-toast.warning .toast-icon{background:var(--warning-light);color:var(--warning)}
.notification-toast.info .toast-icon{background:var(--primary-soft);color:var(--primary)}
.toast-body{flex:1}
.toast-title{font-size:.84rem;font-weight:700;color:var(--text);margin-bottom:2px}
.toast-msg{font-size:.77rem;color:var(--text-muted);line-height:1.4}
.toast-close{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:.72rem;padding:2px;transition:var(--transition)}
.toast-close:hover{color:var(--danger)}

/* Botão de logout na sidebar */
.btn-logout {
  display:flex; align-items:center; gap:10px;
  width:100%; padding:10px 14px;
  background:none; border:none; border-radius:12px;
  font-family:'Inter',sans-serif; font-size:.85rem; font-weight:600;
  color:var(--text-muted); cursor:pointer;
  transition:all .2s; margin-top:6px;
}
.btn-logout:hover { background:var(--danger-light); color:var(--danger); }
.btn-logout i { font-size:.9rem; width:18px; text-align:center; }

/* ── FAVORITOS ────────────────────────────────────────────── */

/* Seção de favoritos */
.favorites-section {
  background:#fff; border-radius:var(--radius); padding:18px 20px;
  border:2px solid #fff3cd; margin-bottom:20px;
  box-shadow:var(--shadow-sm);
}
.fav-section-header {
  display:flex; align-items:center; gap:10px;
  font-size:.9rem; font-weight:700; color:#b8860b;
  margin-bottom:14px;
}
.fav-section-header i { color:#f4c430; font-size:1rem; }
.fav-section-sub {
  font-size:.75rem; font-weight:400; color:var(--text-muted); margin-left:4px;
}

/* Lista rápida de favoritos */
.fav-quick-list { display:flex; flex-direction:column; gap:8px; }

.fav-quick-item {
  display:flex; align-items:center; gap:12px;
  background:var(--bg); border-radius:12px; padding:10px 14px;
  border:1.5px solid var(--border); transition:all .2s;
}
.fav-quick-item:hover { background:#fff; box-shadow:var(--shadow-sm); }

.fav-quick-icon {
  width:36px; height:36px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
}
.fav-quick-icon.income  { background:var(--accent-light); color:var(--accent-dark); }
.fav-quick-icon.expense { background:var(--danger-light);  color:var(--danger); }

.fav-quick-info { flex:1; min-width:0; }
.fav-quick-title {
  display:block; font-size:.86rem; font-weight:700;
  color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.fav-quick-meta {
  display:block; font-size:.74rem; color:var(--text-muted); margin-top:2px;
}

/* Botão Usar */
.fav-use-btn {
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  color:#fff; border:none; border-radius:9px; padding:7px 14px;
  font-size:.78rem; font-weight:700; cursor:pointer; white-space:nowrap;
  font-family:'Inter',sans-serif; flex-shrink:0;
  display:flex; align-items:center; gap:5px; transition:all .2s;
  box-shadow:0 3px 10px rgba(0,201,122,.25);
}
.fav-use-btn:hover { transform:translateY(-1px); box-shadow:0 5px 14px rgba(0,201,122,.35); }

/* Botão estrela nas tarefas */
.task-action-btn.fav-btn { color:var(--text-light); }
.task-action-btn.fav-btn.fav-active { color:#f4c430; }
.task-action-btn.fav-btn:hover { color:#f4c430; }

/* Botão estrela nas finanças */
.trans-actions { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.trans-fav-btn {
  background:none; border:none; cursor:pointer; padding:6px;
  color:var(--text-light); border-radius:8px; font-size:.85rem;
  transition:all .2s; line-height:1;
}
.trans-fav-btn:hover      { color:#f4c430; background:#fff8e1; }
.trans-fav-btn.fav-active { color:#f4c430; }

/* ── HORÁRIO E BADGES DE TEMPO NAS TAREFAS ───────────────────── */
.task-time-tag {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.75rem; font-weight:700; color:var(--primary-light);
  background:var(--primary-soft); padding:3px 9px; border-radius:99px;
}
.task-time-tag i { font-size:.65rem; }

.task-time-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-size:.7rem; font-weight:700; padding:2px 8px; border-radius:99px;
}
.task-time-badge.soon { background:#fff8ee; color:var(--warning); animation:pulseBadge 1.5s ease-in-out infinite; }
.task-time-badge.past { background:var(--danger-light); color:var(--danger); }
@keyframes pulseBadge { 0%,100%{opacity:1}50%{opacity:.6} }

.task-card.task-soon      { border-left:3px solid var(--warning) !important; }
.task-card.task-time-past { border-left:3px solid var(--danger)  !important; }

.mini-task-time {
  font-size:.7rem; font-weight:600; color:var(--primary-light);
  background:var(--primary-soft); padding:2px 7px; border-radius:99px;
  display:inline-flex; align-items:center; gap:3px; flex-shrink:0;
}
.mini-task-time i { font-size:.6rem; }

/* Máscara de moeda */
.input-currency input[type="text"] {
  text-align:right; font-weight:700; font-size:1rem; letter-spacing:.3px;
}

/* ── ANIMATIONS ──────────────────────────────────────── */
@keyframes pulseGlow{0%,100%{opacity:1}50%{opacity:.6}}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
@keyframes pulseRecord{0%,100%{box-shadow:0 0 0 0 rgba(245,59,87,.5)}50%{box-shadow:0 0 0 12px rgba(245,59,87,0)}}

/* ── SCROLLBAR ───────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--text-light)}

/* ══════════════════════════════════════════════════════
   PLANOS — View interna do app
   ══════════════════════════════════════════════════════ */

/* Nav badge de plano */
.nav-plan-badge {
  font-size:.6rem; font-weight:700; padding:2px 8px;
  border-radius:99px; background:var(--primary-soft);
  color:var(--primary); letter-spacing:.3px; margin-left:auto;
  white-space:nowrap;
}

/* Card plano ativo */
.plan-active-card {
  background:#fff; border-radius:var(--radius); padding:22px 28px;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; border:2px solid var(--border); margin-bottom:24px;
  box-shadow:var(--shadow); transition:border-color .3s;
}
.plan-active-card .pac-left { display:flex; align-items:center; gap:18px; }
.pac-icon {
  width:56px; height:56px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; flex-shrink:0;
  background:var(--primary-soft); color:var(--primary);
}
.pac-info .pac-badge {
  display:inline-block; font-size:.68rem; font-weight:700;
  padding:3px 12px; border-radius:99px; color:#fff;
  background:var(--primary); letter-spacing:.5px;
  text-transform:uppercase; margin-bottom:5px;
}
.pac-info h3 { font-size:1.1rem; font-weight:800; color:var(--text); margin-bottom:3px; }
.pac-info p  { font-size:.82rem; color:var(--text-muted); }
.pac-right   { text-align:right; flex-shrink:0; }
.pac-price   { font-size:1.8rem; font-weight:900; color:var(--text); line-height:1; }
.pac-price span { font-size:.85rem; font-weight:500; color:var(--text-muted); }
.pac-trial   { font-size:.78rem; color:var(--text-muted); margin-top:5px;
               display:flex; align-items:center; gap:5px; justify-content:flex-end; }
.pac-trial i { color:var(--accent); }

/* Seletor de planos */
.plans-selector { margin-bottom:24px; }
.ps-title { font-size:.95rem; font-weight:700; color:var(--text); margin-bottom:16px;
            display:flex; align-items:center; gap:8px; }
.ps-title i { color:var(--accent); }

.ps-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
@media(max-width:900px){ .ps-grid { grid-template-columns:1fr; max-width:420px; } }

.ps-card {
  background:#fff; border-radius:var(--radius); padding:22px 20px;
  border:2px solid var(--border); cursor:pointer; position:relative;
  transition:all .25s ease; box-shadow:var(--shadow-sm);
}
.ps-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.ps-card.ps-active { border-width:2px; }
.ps-card.popular { border-color:var(--accent); }

.ps-popular-tag {
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  color:#fff; font-size:.72rem; font-weight:700;
  padding:4px 14px; border-radius:99px;
  display:flex; align-items:center; gap:4px;
  box-shadow:0 4px 14px rgba(0,201,122,.35); white-space:nowrap;
}

.ps-card-top { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.ps-icon {
  width:40px; height:40px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.ps-icon.free        { background:var(--primary-soft); color:var(--primary); }
.ps-icon.essencial   { background:#e6faf3; color:var(--accent-dark); }
.ps-icon.inteligente { background:#ede9ff; color:var(--purple); }

.ps-badge {
  font-size:.68rem; font-weight:700; padding:2px 10px;
  border-radius:99px; letter-spacing:.5px; text-transform:uppercase;
}
.free-b        { background:var(--primary-soft); color:var(--primary); }
.essencial-b   { background:#e6faf3; color:var(--accent-dark); }
.inteligente-b { background:#ede9ff; color:var(--purple); }

.ps-card h4 { font-size:1rem; font-weight:800; color:var(--text); margin-bottom:4px; }
.ps-card h4 span { color:var(--accent); }
.ps-card.popular h4 span { color:var(--accent); }
.ps-card:has(.ps-icon.inteligente) h4 span { color:var(--purple); }
.ps-card p  { font-size:.78rem; color:var(--text-muted); margin-bottom:12px; line-height:1.4; }

.ps-price {
  font-size:1.5rem; font-weight:900; color:var(--text);
  margin-bottom:14px; line-height:1;
}
.ps-price span { font-size:.78rem; font-weight:500; color:var(--text-muted); }

.ps-features { list-style:none; padding:0; margin:0 0 16px; }
.ps-features li {
  display:flex; align-items:center; gap:8px;
  font-size:.8rem; color:var(--text); padding:5px 0;
  border-bottom:1px solid var(--border);
}
.ps-features li:last-child { border-bottom:none; }
.ps-features li i { color:var(--accent); width:14px; text-align:center; font-size:.75rem; }
.ps-features li.ps-no { color:var(--text-muted); }
.ps-features li.ps-no i { color:var(--text-light); }

.ps-cta {
  width:100%; padding:11px; border-radius:12px; border:none;
  font-size:.85rem; font-weight:700; cursor:pointer;
  font-family:'Inter',sans-serif; transition:all .2s;
}
.free-ps-cta        { background:var(--primary-soft); color:var(--primary); }
.free-ps-cta:hover  { background:var(--primary); color:#fff; }
.essencial-ps-cta   { background:linear-gradient(135deg,var(--accent),var(--accent-dark)); color:#fff;
                      box-shadow:0 4px 14px rgba(0,201,122,.3); }
.essencial-ps-cta:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(0,201,122,.4); }
.inteligente-ps-cta { background:linear-gradient(135deg,var(--purple),#5a4fcf); color:#fff;
                      box-shadow:0 4px 14px rgba(108,92,231,.3); }
.inteligente-ps-cta:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(108,92,231,.4); }
.ps-cta:disabled { cursor:default; transform:none !important; }

/* Recursos do plano */
.plan-resources { margin-top:4px; }
.pr-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:10px;
  padding:4px 0;
}
@media(max-width:600px){ .pr-grid { grid-template-columns:1fr; } }

.pr-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:10px; background:var(--bg);
}
.pr-item.pr-no { opacity:.55; }
.pr-icon-wrap {
  width:32px; height:32px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.8rem;
}
.pr-icon-wrap.ok { background:#e6faf3; color:var(--accent-dark); }
.pr-icon-wrap.no { background:#f5f5f5; color:var(--text-light); }
.pr-item span    { flex:1; font-size:.82rem; font-weight:500; color:var(--text); }
.pr-status       { flex-shrink:0; font-size:.9rem; }

/* ══════════════════════════════════════════════════════
   SISTEMA DE RESTRIÇÕES / UPGRADE — Estilos
   ══════════════════════════════════════════════════════ */

/* Feature bloqueada */
.locked-feature {
  opacity:.5; cursor:not-allowed !important;
  position:relative;
}
.locked-feature::after {
  content:'\f023'; font-family:'Font Awesome 6 Free'; font-weight:900;
  font-size:.6rem; position:absolute; top:2px; right:4px;
  color:var(--text-muted);
}

/* Seção bloqueada */
.locked-section { position:relative; }
.locked-section::before {
  content:''; position:absolute; inset:0; background:rgba(255,255,255,.5);
  border-radius:12px; z-index:1; pointer-events:none;
}

/* Modal de Upgrade */
.modal-upgrade {
  max-width:420px !important; text-align:center; padding:40px 32px 32px !important;
  position:relative;
}
.upgrade-icon {
  width:64px; height:64px; border-radius:20px; margin:0 auto 4px;
  display:flex; align-items:center; justify-content:center; font-size:1.6rem;
}
.upgrade-lock {
  width:28px; height:28px; border-radius:50%; background:var(--warning);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:.75rem; margin:-16px auto 16px; position:relative; z-index:1;
  box-shadow:0 2px 8px rgba(255,159,26,.4);
}
.modal-upgrade h3 { font-size:1.3rem; font-weight:800; color:var(--text); margin-bottom:6px; }
.upgrade-feature-name {
  font-size:.9rem; font-weight:600; color:var(--primary);
  background:var(--primary-soft); padding:5px 16px; border-radius:99px;
  display:inline-block; margin-bottom:12px;
}
.upgrade-desc { font-size:.87rem; color:var(--text-muted); line-height:1.6; margin-bottom:20px; }

.upgrade-plans-preview {
  display:flex; gap:10px; justify-content:center; margin-bottom:22px;
}
.upp-item {
  flex:1; background:var(--bg); border:2px solid var(--border);
  border-radius:12px; padding:12px 10px;
  display:flex; align-items:center; gap:8px;
  transition:all .2s;
}
.upp-item.highlight { background:#fff; }
.upp-icon {
  width:34px; height:34px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
}
.upp-item strong { display:block; font-size:.82rem; color:var(--text); }
.upp-item span   { font-size:.72rem; color:var(--text-muted); }

.btn-upgrade-now {
  width:100%; padding:14px; border:none; border-radius:14px;
  color:#fff; font-size:.95rem; font-weight:700; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
  font-family:'Inter',sans-serif; margin-bottom:12px;
  box-shadow:0 6px 20px rgba(0,0,0,.2);
  transition:all .22s ease;
}
.btn-upgrade-now:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.25); }
.upgrade-see-all {
  font-size:.8rem; color:var(--text-muted); text-decoration:none;
  display:block; transition:color .2s;
}
.upgrade-see-all:hover { color:var(--accent); }

/* Banner de insight bloqueado no dashboard */
.insight-upgrade-banner {
  background:linear-gradient(135deg,var(--primary-soft),#e8f4fb);
  border:1.5px solid var(--primary-soft); border-radius:14px;
  padding:16px; margin-top:12px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  flex-wrap:wrap;
}
.iub-content { display:flex; align-items:flex-start; gap:12px; flex:1; }
.iub-icon { font-size:1.5rem; color:var(--warning); flex-shrink:0; margin-top:2px; }
.iub-content strong { display:block; font-size:.88rem; color:var(--text); margin-bottom:3px; }
.iub-content p { font-size:.79rem; color:var(--text-muted); line-height:1.5; margin:0; }
.iub-btn {
  background:var(--primary); color:#fff; border:none; border-radius:10px;
  padding:9px 16px; font-size:.82rem; font-weight:700; cursor:pointer;
  display:flex; align-items:center; gap:6px; white-space:nowrap;
  font-family:'Inter',sans-serif; transition:all .2s; flex-shrink:0;
}
.iub-btn:hover { background:var(--primary-light); transform:translateY(-1px); }

/* Banner contextual de upgrade nas views */
.plan-upgrade-banner {
  background:#fff; border-radius:16px; padding:18px 20px;
  border:1.5px solid var(--border); border-left:4px solid var(--accent);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  margin-top:16px; box-shadow:var(--shadow-sm); flex-wrap:wrap;
}
.pub-left { display:flex; align-items:flex-start; gap:12px; flex:1; }
.pub-icon {
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.pub-left strong { display:block; font-size:.88rem; color:var(--text); margin-bottom:3px; }
.pub-left p { font-size:.78rem; color:var(--text-muted); margin:0; line-height:1.5; }
.pub-btn {
  color:#fff; border:none; border-radius:10px; padding:9px 16px;
  font-size:.82rem; font-weight:700; cursor:pointer; white-space:nowrap;
  display:flex; align-items:center; gap:6px; font-family:'Inter',sans-serif;
  transition:all .2s; flex-shrink:0;
}
.pub-btn:hover { filter:brightness(1.1); transform:translateY(-1px); }

/* ══════════════════════════════════════════════════════
   RELATÓRIOS INTELIGENTES — Estilos completos
   ══════════════════════════════════════════════════════ */

/* Tela de bloqueio */
.report-locked-screen {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; padding:60px 24px; text-align:center;
  background:#fff; border-radius:var(--radius); border:2px dashed var(--border);
  min-height:300px; gap:14px;
}
.rls-icon {
  width:72px; height:72px; border-radius:50%;
  background:var(--primary-soft); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; margin-bottom:6px;
}
.report-locked-screen h3 { font-size:1.3rem; font-weight:800; color:var(--text); }
.report-locked-screen p  { font-size:.88rem; color:var(--text-muted); max-width:360px; line-height:1.6; }

/* Grid de scores */
.report-scores {
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:22px;
}
@media(max-width:900px){ .report-scores { grid-template-columns:repeat(2,1fr); } }
@media(max-width:520px){ .report-scores { grid-template-columns:1fr; } }

.report-score-card {
  background:#fff; border-radius:var(--radius); padding:16px 18px;
  border:2px solid var(--border); box-shadow:var(--shadow-sm);
  transition:all .25s;
}
.report-score-card:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.report-score-card.highlight { border-color:currentColor; }

.rsc-icon {
  width:38px; height:38px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.95rem;
  margin-bottom:10px;
}
.rsc-info { margin-bottom:10px; }
.rsc-value { font-size:1.5rem; font-weight:900; line-height:1; margin-bottom:2px; }
.rsc-label { font-size:.75rem; color:var(--text-muted); font-weight:600; text-transform:uppercase; letter-spacing:.4px; }
.rsc-sub   { font-size:.73rem; color:var(--text-muted); margin-top:3px; }
.rsc-bar   { height:5px; background:var(--border); border-radius:99px; overflow:hidden; }
.rsc-bar-fill { height:100%; border-radius:99px; transition:width .6s ease; }

/* Grid principal do relatório */
.report-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px;
}
@media(max-width:820px){ .report-grid { grid-template-columns:1fr; } }

.report-card { border-radius:var(--radius); }
.report-full { grid-column:1/-1; }

/* Badge de plano inline */
.plan-badge-inline {
  font-size:.65rem; font-weight:700; padding:3px 10px; border-radius:99px;
  background:#e6faf3; color:var(--accent-dark); letter-spacing:.5px;
  text-transform:uppercase;
}
.plan-badge-inline.inteligente {
  background:#ede9ff; color:var(--purple);
}

/* Badge de data no relatório */
.report-date-badge {
  font-size:.78rem; font-weight:600; color:var(--text-muted);
  background:var(--bg); padding:4px 12px; border-radius:99px;
  border:1.5px solid var(--border);
}

/* Resumo executivo */
.exec-summary { display:flex; flex-direction:column; gap:14px; }
.exec-intro {
  font-size:.9rem; color:var(--text); line-height:1.7;
  background:var(--bg); padding:14px 16px; border-radius:12px;
  border-left:4px solid var(--primary);
}
.exec-points { display:flex; flex-direction:column; gap:10px; }
.exec-point {
  display:flex; align-items:flex-start; gap:12px; padding:12px 14px;
  border-radius:12px; background:#fff; border:1.5px solid var(--border);
  border-left:4px solid var(--primary);
}
.exp-icon {
  width:34px; height:34px; border-radius:9px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
}
.exp-text { font-size:.83rem; color:var(--text); line-height:1.5; }
.exp-text strong { display:block; margin-bottom:2px; }

/* Produtividade */
.report-productivity { padding:4px 0; }
.prod-rate-wrap { display:flex; align-items:center; gap:24px; margin-bottom:16px; }
.prod-rate-circle {
  width:90px; height:90px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  background: conic-gradient(
    var(--color, #00a864) 0%,
    var(--color, #00a864) calc(var(--rate, 0) * 1%),
    var(--border, #e2e8f4) calc(var(--rate, 0) * 1%)
  );
}
.prod-rate-circle::before {
  content:''; width:68px; height:68px; border-radius:50%;
  background:#fff; position:absolute;
}
.prod-rate-val { font-size:1.2rem; font-weight:900; color:var(--text); position:relative; z-index:1; }
.prod-rate-lbl { display:none; }
.prod-stats { display:flex; flex-direction:column; gap:6px; }
.prod-stat {
  display:flex; align-items:center; gap:8px;
  font-size:.82rem; color:var(--text);
}
.prod-stat span { font-weight:800; font-size:1rem; }

.prod-priority-bars { display:flex; flex-direction:column; gap:8px; }
.prod-bar-row { display:flex; align-items:center; gap:10px; }
.prod-bar-label { font-size:.78rem; font-weight:600; color:var(--text-muted); width:42px; flex-shrink:0; }
.prod-bar-track { flex:1; height:8px; background:var(--border); border-radius:99px; overflow:hidden; }
.prod-bar-fill  { height:100%; border-radius:99px; transition:width .6s ease; }
.prod-bar-count { font-size:.8rem; font-weight:700; width:22px; text-align:right; flex-shrink:0; }
.prod-empty     { font-size:.82rem; color:var(--text-muted); text-align:center; padding:16px 0; }

/* Saúde Financeira */
.report-finance-health { padding:4px 0; }
.fin-health-top { display:flex; align-items:flex-start; gap:20px; margin-bottom:16px; }
.fin-score-wrap { text-align:center; flex-shrink:0; }
.fin-score-num  { font-size:2.4rem; font-weight:900; line-height:1; }
.fin-score-label{ font-size:.72rem; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); font-weight:700; margin-top:2px; }
.fin-health-stats { flex:1; display:flex; flex-direction:column; gap:6px; }
.fhs-row {
  display:flex; align-items:center; gap:8px;
  font-size:.82rem; color:var(--text); padding:6px 10px;
  background:var(--bg); border-radius:8px;
}
.fhs-row i { width:14px; text-align:center; }
.fhs-row strong { margin-left:auto; }
.fhs-row.income  strong { color:#00a864; }
.fhs-row.expense strong { color:#f53b57; }
.fhs-meta { font-size:.7rem; color:var(--text-muted); margin-left:4px; }

.fin-cat-breakdown { padding-top:10px; }
.fcb-title { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); margin-bottom:10px; }
.fcb-row { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.fcb-cat { font-size:.78rem; font-weight:600; color:var(--text); width:90px; flex-shrink:0; }
.fcb-bar-track { flex:1; height:7px; background:var(--border); border-radius:99px; overflow:hidden; }
.fcb-bar-fill  { height:100%; border-radius:99px; transition:width .6s ease; }
.fcb-val { font-size:.77rem; font-weight:700; text-align:right; width:100px; flex-shrink:0; }

/* Recomendações Estratégicas */
.recs-grid { display:flex; flex-direction:column; gap:12px; }
.rec-card {
  display:flex; align-items:flex-start; gap:14px; padding:16px 18px;
  background:var(--bg); border-radius:12px; border-left:4px solid;
  border:1.5px solid var(--border);
}
.rec-icon {
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:.9rem;
}
.rec-body { flex:1; }
.rec-body strong { display:block; font-size:.88rem; color:var(--text); margin-bottom:4px; }
.rec-body p { font-size:.81rem; color:var(--text-muted); margin:0; line-height:1.5; }

/* Projeções Financeiras */
.proj-intro {
  font-size:.82rem; color:var(--text-muted); background:var(--bg);
  padding:10px 14px; border-radius:10px; margin-bottom:16px;
  display:flex; align-items:center; gap:8px; line-height:1.5;
}
.proj-intro i { color:var(--primary); flex-shrink:0; }
.proj-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
@media(max-width:600px){ .proj-grid { grid-template-columns:1fr; } }

.proj-card {
  background:var(--bg); border-radius:14px; padding:18px;
  border:1.5px solid var(--border); text-align:center;
  transition:all .25s;
}
.proj-card:hover { background:#fff; box-shadow:var(--shadow); transform:translateY(-2px); }
.proj-header { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--text-muted); margin-bottom:8px; }
.proj-value  { font-size:1.6rem; font-weight:900; line-height:1; margin-bottom:4px; }
.proj-label  { font-size:.73rem; color:var(--text-muted); margin-bottom:12px; }
.proj-details { border-top:1.5px solid var(--border); padding-top:10px; display:flex; flex-direction:column; gap:5px; }
.proj-det-row { display:flex; justify-content:space-between; align-items:center; font-size:.77rem; color:var(--text-muted); }
.proj-det-row strong { font-size:.82rem; }
.proj-alert {
  background:#fff8ee; border:1.5px solid var(--warning); border-radius:10px;
  padding:12px 14px; font-size:.8rem; color:var(--text); margin-top:14px;
  display:flex; align-items:center; gap:8px;
}
.proj-alert i { color:var(--warning); }

/* Empty state mini (usado nos gráficos vazios) */
.empty-state-mini {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:30px; color:var(--text-muted); gap:8px; text-align:center;
}
.empty-state-mini i { font-size:1.8rem; opacity:.4; }
.empty-state-mini p { font-size:.82rem; margin:0; }

/* Priority Task Items no Dashboard */
.priority-task-item {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  border-radius:10px; background:var(--bg); margin-bottom:8px; cursor:pointer;
  transition:background .2s;
}
.priority-task-item:hover { background:var(--primary-soft); }
.pti-rank { font-size:1rem; flex-shrink:0; }
.pti-content { flex:1; min-width:0; }
.pti-title { font-size:.85rem; font-weight:600; color:var(--text);
             white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pti-due { font-size:.73rem; color:var(--text-muted); margin-top:2px;
           display:flex; align-items:center; gap:4px; }
.pti-badge { font-size:.68rem; font-weight:700; padding:2px 9px;
             border-radius:99px; flex-shrink:0; text-transform:capitalize; }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr}}
@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{transform:translateX(-260px);width:260px}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 40px rgba(0,0,0,.3)}
  .main-content{margin-left:0}
  .mobile-menu-btn{display:flex}
  .content-area{padding:16px}
  .topbar{padding:0 16px}
  .finance-summary-bar{flex-direction:column;gap:18px;text-align:center}
  .fsb-divider{order:-1}
  .form-row{grid-template-columns:1fr}
  .ai-container{height:calc(100vh - 170px)}
  .welcome-banner{padding:20px 22px}
  .greeting-badge{display:none}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .tasks-grid{grid-template-columns:1fr}
  .view-header{flex-direction:column;gap:10px}
}
