/* ===== FONTS ===== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;600;700&display=swap');

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

:root {
  --bg-root:           #070c1a;
  --glass-bg:          rgba(255,255,255,0.042);
  --glass-bg-md:       rgba(255,255,255,0.075);
  --glass-bg-high:     rgba(255,255,255,0.11);
  --glass-border:      rgba(255,255,255,0.09);
  --glass-border-focus:rgba(255,255,255,0.20);
  --glass-blur:        blur(20px);
  --grad-primary:      linear-gradient(135deg, #3b5bdb 0%, #7c3aed 100%);
  --grad-primary-h:    linear-gradient(135deg, #4c6ef5 0%, #9333ea 100%);
  --grad-accent:       linear-gradient(135deg, #06b6d4 0%, #3b5bdb 100%);
  --grad-bg:           linear-gradient(160deg, #070c1a 0%, #0c1230 45%, #110a28 100%);
  --grad-card:         linear-gradient(135deg, rgba(59,91,219,0.09) 0%, rgba(124,58,237,0.07) 100%);
  --blue:   #4c6ef5;
  --purple: #7c3aed;
  --cyan:   #06b6d4;
  --green:  #10b981;
  --red:    #f43f5e;
  --yellow: #f59e0b;
  --orange: #f97316;
  --text-1: #f8fafc;
  --text-2: #a8b8d0;
  --text-3: #5e7291;
  --text-4: #3d5068;
  /* Shadows com mais profundidade */
  --shadow-sm:   0 2px 8px rgba(0,0,0,0.45);
  --shadow-md:   0 6px 24px rgba(0,0,0,0.55);
  --shadow-lg:   0 12px 48px rgba(0,0,0,0.65);
  --shadow-xl:   0 20px 64px rgba(0,0,0,0.75);
  --shadow-blue: 0 4px 28px rgba(59,91,219,0.35);
  --shadow-green:0 4px 24px rgba(16,185,129,0.30);
  --glow-blue:   0 0 40px rgba(76,110,245,0.22);
  --glow-purple: 0 0 40px rgba(124,58,237,0.18);
  --glow-green:  0 0 30px rgba(16,185,129,0.20);
  --radius-xs: 6px;
  --radius-sm: 12px;
  --radius:    18px;
  --radius-lg: 24px;
  --radius-xl: 30px;
  --font: 'Poppins', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --transition: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-spring: 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
  --transition-smooth: 0.28s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html, body {
  height: 100%;
  font-family: var(--font);
  font-size: 15px;
  color: var(--text-1);
  background: var(--bg-root);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.35); border-radius: 99px; }

/* ===== BACKGROUND ===== */
.bg-mesh {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: var(--grad-bg);
}
.bg-mesh::before {
  content: ''; position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 80% 65% at 10% -5%,  rgba(76,110,245,0.22) 0%, transparent 55%),
    radial-gradient(ellipse 60% 55% at 95% 10%,  rgba(124,58,237,0.17) 0%, transparent 50%),
    radial-gradient(ellipse 65% 55% at 85% 95%,  rgba(6,182,212,0.12)  0%, transparent 55%),
    radial-gradient(ellipse 45% 45% at 5%  90%,  rgba(124,58,237,0.12) 0%, transparent 50%),
    radial-gradient(ellipse 40% 30% at 50% 50%,  rgba(59,91,219,0.06)  0%, transparent 60%);
  pointer-events: none;
}
.bg-mesh::after {
  content: ''; position: fixed; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: 0.018;
}

.bg-watermark {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.bg-watermark img {
  width: min(70vw, 520px); opacity: 0.03;
  filter: grayscale(1) brightness(5);
  user-select: none; pointer-events: none;
}

/* ===== SCREENS ===== */
.screen {
  display: none; min-height: 100vh;
  padding-top: 56px;   /* topbar fixa */
  padding-bottom: 80px; /* bottom nav */
  position: relative; z-index: 1;
}
.screen.active { display: block; }
#screen-login.active { display: flex; padding-top: 0; padding-bottom: 0; }
#screen-home.active  { padding-top: 0; } /* home tem header próprio */

/* Transição entre telas */
@keyframes screenIn  { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
@keyframes screenOut { from { opacity:1; } to { opacity:0; } }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }
@keyframes slideUp   { from { transform:translateY(70px); opacity:0; } to { transform:translateY(0); opacity:1; } }
@keyframes pulse     { 0%,100%{opacity:1;} 50%{opacity:0.5;} }

/* Premium micro-interactions */
@keyframes paySuccess {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0 rgba(16,185,129,0.6); }
  30%  { transform: scale(1.06); box-shadow: 0 0 0 12px rgba(16,185,129,0.25); }
  60%  { transform: scale(0.97); box-shadow: 0 0 0 20px rgba(16,185,129,0.0); }
  100% { transform: scale(1);    box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}
@keyframes checkPop {
  0%   { transform: scale(0) rotate(-15deg); opacity: 0; }
  55%  { transform: scale(1.25) rotate(8deg); opacity: 1; }
  80%  { transform: scale(0.9) rotate(-3deg); }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
@keyframes savePulse {
  0%   { box-shadow: 0 0 0 0 rgba(76,110,245,0.55); }
  60%  { box-shadow: 0 0 0 14px rgba(76,110,245,0.0); }
  100% { box-shadow: 0 0 0 0 rgba(76,110,245,0); }
}
@keyframes valueCountUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes glowPulse {
  0%,100% { opacity: 1; }
  50%     { opacity: 0.6; }
}
@keyframes ripple {
  0%   { transform: scale(0); opacity: 0.5; }
  100% { transform: scale(4); opacity: 0; }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastIn {
  from { transform: translateX(-50%) translateY(20px) scale(0.92); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0)    scale(1);    opacity: 1; }
}
.screen.active { animation: screenIn 0.22s cubic-bezier(0.4,0,0.2,1); }

/* ===== LOGIN ===== */
#screen-login { display:flex; align-items:center; justify-content:center; min-height:100vh; padding:24px 20px; }
.login-card {
  background: rgba(12,18,48,0.82); backdrop-filter: blur(32px); -webkit-backdrop-filter: blur(32px);
  border: 1px solid rgba(76,110,245,0.20); border-radius: var(--radius-xl);
  padding: 48px 36px; width: 100%; max-width: 420px;
  box-shadow: var(--shadow-xl), var(--glow-blue), inset 0 1px 0 rgba(255,255,255,0.07);
  position: relative; overflow: hidden;
}
.login-card::before {
  content:''; position:absolute; top:-80px; left:-80px; width:260px; height:260px;
  background: radial-gradient(circle, rgba(76,110,245,0.15), transparent 65%); pointer-events:none;
}
.login-card::after {
  content:''; position:absolute; bottom:-60px; right:-60px; width:200px; height:200px;
  background: radial-gradient(circle, rgba(124,58,237,0.12), transparent 65%); pointer-events:none;
}
.login-logo { display:flex; flex-direction:column; align-items:center; margin-bottom:36px; position:relative; z-index:1; }
.login-logo img { width:220px; height:auto; object-fit:contain; margin-bottom:6px; filter:drop-shadow(0 0 24px rgba(76,110,245,0.5)); }
.login-logo .brand { font-size:1.6rem; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; letter-spacing:-0.02em; margin-bottom:2px; }
.login-logo .tagline { font-size:0.7rem; color:var(--text-3); letter-spacing:0.13em; text-transform:uppercase; font-weight:500; }
.login-title { font-size:0.86rem; color:var(--text-2); text-align:center; margin-bottom:28px; position:relative; z-index:1; font-weight:400; }

/* ===== FORM ===== */
.form-group { margin-bottom:16px; position:relative; z-index:1; }
.form-group label { display:block; font-size:0.68rem; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:0.09em; margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:var(--glass-bg); backdrop-filter:blur(8px);
  border:1px solid var(--glass-border); border-radius:var(--radius-sm);
  color:var(--text-1); font-family:var(--font); font-size:0.9rem; font-weight:400;
  padding:13px 16px; outline:none; transition:all var(--transition); -webkit-appearance:none;
}
.form-group input::placeholder { color:var(--text-4); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: rgba(99,102,241,0.6); background:var(--glass-bg-md);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12), var(--shadow-sm);
}
.form-group select option { background:#1e2640; color:var(--text-1); }
.form-group textarea { resize:vertical; min-height:88px; line-height:1.6; }

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:12px; font-family:var(--font); font-size:0.86rem;
  font-weight:600; cursor:pointer; border:none; transition:all var(--transition);
  text-decoration:none; white-space:nowrap; letter-spacing:0.01em;
  position:relative; overflow:hidden;
}
/* Ripple on click */
.btn::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at var(--rx,50%) var(--ry,50%), rgba(255,255,255,0.18) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.3s ease;
  border-radius: inherit;
}
.btn:active::before { opacity: 1; }
.btn:after { content:''; position:absolute; inset:0; background:rgba(255,255,255,0); transition:background var(--transition); border-radius:inherit; }
.btn:hover::after { background:rgba(255,255,255,0.06); }
.btn:active { transform:scale(0.965); }
.btn:disabled { opacity:0.38; cursor:not-allowed; pointer-events:none; }

.btn-primary   { background:var(--grad-primary); color:#fff; box-shadow: var(--shadow-blue), inset 0 1px 0 rgba(255,255,255,0.15); }
.btn-primary:hover { background:var(--grad-primary-h); box-shadow:0 6px 32px rgba(99,102,241,0.45), inset 0 1px 0 rgba(255,255,255,0.15); transform:translateY(-1px); }
.btn-primary:active { transform:scale(0.965) translateY(0); }
.btn-secondary { background:var(--glass-bg-md); backdrop-filter:blur(8px); border:1px solid var(--glass-border); color:var(--text-1); }
.btn-secondary:hover { background:var(--glass-bg-high); border-color:var(--glass-border-focus); box-shadow:var(--shadow-sm); }
.btn-danger  { background:rgba(244,63,94,0.10); border:1px solid rgba(244,63,94,0.22); color:var(--red); }
.btn-danger:hover { background:rgba(244,63,94,0.20); border-color:rgba(244,63,94,0.40); box-shadow:0 4px 16px rgba(244,63,94,0.15); }
.btn-success { background:rgba(16,185,129,0.10); border:1px solid rgba(16,185,129,0.22); color:var(--green); }
.btn-success:hover { background:rgba(16,185,129,0.20); border-color:rgba(16,185,129,0.40); box-shadow: 0 4px 16px rgba(16,185,129,0.15); }
.btn-warning { background:rgba(245,158,11,0.12); border:1px solid rgba(245,158,11,0.28); color:var(--yellow); }
.btn-warning:hover { background:rgba(245,158,11,0.22); border-color:var(--yellow); box-shadow:0 4px 16px rgba(245,158,11,0.12); }
.btn-biometric {
  background: linear-gradient(135deg, rgba(16,185,129,0.12), rgba(6,182,212,0.12));
  border: 1px solid rgba(16,185,129,0.30); color: var(--green);
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 0.9rem; letter-spacing: 0.02em;
}
.btn-biometric:hover { background: linear-gradient(135deg, rgba(16,185,129,0.25), rgba(6,182,212,0.20)); border-color: var(--green); box-shadow: var(--glow-green); }
.btn-biometric:active { transform: scale(0.97); }
.bio-icon { font-size: 1.1rem; }
.btn-sm   { padding:7px 15px; font-size:0.76rem; border-radius:10px; }
.btn-icon { padding:9px; width:36px; height:36px; border-radius:10px; font-size:0.88rem; }
.btn-full { width:100%; }

/* ===== TOPBAR GLOBAL (fixa) ===== */
#global-topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px; height: 56px;
  background: rgba(10,15,30,0.88);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--glass-border);
  transition: opacity 0.2s ease;
}
#global-topbar.hidden { display: none; }
.topbar-back-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  color: var(--text-2); font-family: var(--font); font-size: 0.78rem;
  font-weight: 500; cursor: pointer; padding: 7px 13px;
  border-radius: 10px; transition: all var(--transition); min-width: 44px;
}
.topbar-back-btn:hover { background: var(--glass-bg-md); color: var(--text-1); border-color: var(--glass-border-focus); }
.topbar-back-btn.hidden { visibility: hidden; pointer-events: none; }
#global-topbar-title {
  font-size: 0.92rem; font-weight: 700;
  background: var(--grad-primary); -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; background-clip: text;
  flex: 1; text-align: center;
}
.topbar-logo-img { height: 26px; width: auto; object-fit: contain; filter: drop-shadow(0 0 10px rgba(76,110,245,0.5)); }
/* Manter compatibilidade com topbars inline (serão removidas do HTML) */
.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 20px; background:rgba(10,15,30,0.75);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--glass-border); position:sticky; top:0; z-index:100;
}
.topbar-left  { display:flex; align-items:center; gap:12px; }
.topbar-logo  { height:28px; width:auto; object-fit:contain; filter:drop-shadow(0 0 10px rgba(76,110,245,0.5)); }
.topbar-title { font-size:0.92rem; font-weight:700; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.topbar-right { display:flex; gap:8px; }
.back-btn {
  display:flex; align-items:center; gap:5px; background:var(--glass-bg);
  border:1px solid var(--glass-border); color:var(--text-2); font-family:var(--font);
  font-size:0.78rem; font-weight:500; cursor:pointer; padding:7px 13px;
  border-radius:10px; transition:all var(--transition);
}
.back-btn:hover { background:var(--glass-bg-md); color:var(--text-1); border-color:var(--glass-border-focus); }

/* ===== BOTTOM NAVIGATION ===== */
#bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: stretch;
  background: rgba(10,15,30,0.92);
  backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
  border-top: 1px solid var(--glass-border);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  height: calc(64px + env(safe-area-inset-bottom, 0px));
}
#bottom-nav.hidden { display: none; }
.bnav-item {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 3px; cursor: pointer; padding: 8px 4px;
  transition: all var(--transition); position: relative; border: none;
  background: transparent; font-family: var(--font);
}
.bnav-item::before {
  content: ''; position: absolute; top: 0; left: 25%; right: 25%; height: 2px;
  background: var(--grad-primary); border-radius: 0 0 4px 4px;
  transform: scaleX(0); transition: transform 0.22s cubic-bezier(0.34,1.56,0.64,1);
}
.bnav-item.active::before { transform: scaleX(1); }
.bnav-icon {
  font-size: 1.3rem; transition: transform var(--transition-spring);
  filter: grayscale(0.4) opacity(0.55);
}
.bnav-item.active .bnav-icon { filter: none; transform: scale(1.1); }
.bnav-item:active .bnav-icon { transform: scale(0.92); }
.bnav-label {
  font-size: 0.55rem; font-weight: 600; letter-spacing: 0.02em;
  color: var(--text-4); text-transform: uppercase;
  transition: color var(--transition);
}
.bnav-item.active .bnav-label { color: #818cf8; }

/* ===== HOME ===== */
.home-header {
  padding: 24px 20px 20px; text-align: center;
  padding-top: calc(56px + 20px); /* topbar fixa */
}
.home-logo { display:flex; flex-direction:column; align-items:center; margin-bottom:12px; }
.home-logo img { width:160px; height:auto; object-fit:contain; filter:drop-shadow(0 0 20px rgba(76,110,245,0.45)); margin-bottom:4px; }
.home-greeting { font-size:1.3rem; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; letter-spacing:-0.02em; }
.home-sub { font-size:0.75rem; color:var(--text-3); margin-top:3px; font-weight:400; }

/* ===== DASHBOARD ===== */
.dashboard-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:4px;
}
.dash-card {
  border-radius:var(--radius); padding:18px 16px;
  display:flex; flex-direction:column; gap:7px; position:relative; overflow:hidden;
  border:1px solid rgba(255,255,255,0.07); transition:all var(--transition-spring);
  cursor: default;
}
.dash-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.dash-card::before { content:''; position:absolute; top:-28px; right:-28px; width:90px; height:90px; border-radius:50%; opacity:0.14; }
.dash-card::after  { content:''; position:absolute; inset:0; border-radius:inherit; opacity:0; transition: opacity 0.3s ease; }
.dash-card:hover::after { opacity:1; }
.dash-blue   { background:linear-gradient(135deg,rgba(76,110,245,0.20),rgba(76,110,245,0.07)); box-shadow:inset 0 1px 0 rgba(76,110,245,0.20); }
.dash-blue::before   { background:#4c6ef5; }
.dash-blue::after    { background:linear-gradient(135deg,rgba(76,110,245,0.06),transparent); }
.dash-green  { background:linear-gradient(135deg,rgba(16,185,129,0.18),rgba(16,185,129,0.06)); box-shadow:inset 0 1px 0 rgba(16,185,129,0.18); }
.dash-green::before  { background:#10b981; }
.dash-green::after   { background:linear-gradient(135deg,rgba(16,185,129,0.06),transparent); }
.dash-yellow { background:linear-gradient(135deg,rgba(245,158,11,0.18),rgba(245,158,11,0.06)); box-shadow:inset 0 1px 0 rgba(245,158,11,0.16); }
.dash-yellow::before { background:#f59e0b; }
.dash-yellow::after  { background:linear-gradient(135deg,rgba(245,158,11,0.06),transparent); }
.dash-red    { background:linear-gradient(135deg,rgba(244,63,94,0.18),rgba(244,63,94,0.06)); box-shadow:inset 0 1px 0 rgba(244,63,94,0.16); }
.dash-red::before    { background:#f43f5e; }
.dash-red::after     { background:linear-gradient(135deg,rgba(244,63,94,0.06),transparent); }
.dash-icon   { font-size:1.4rem; position:relative; z-index:1; }
.dash-label  { font-size:0.62rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.09em; font-weight:700; position:relative; z-index:1; }
.dash-value  {
  font-size:1.05rem; font-weight:800; color:var(--text-1);
  letter-spacing:-0.03em; position:relative; z-index:1;
  font-family:var(--font-mono);
  animation: valueCountUp 0.35s ease;
}

/* ===== MODULES ===== */
.modules-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; padding:0 16px; }
.module-card {
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius);
  padding:24px 18px 22px; cursor:pointer; transition:all var(--transition-spring);
  position:relative; overflow:hidden; display:flex; flex-direction:column; align-items:flex-start; gap:12px;
  box-shadow: var(--shadow-sm);
}
.module-card::before { content:''; position:absolute; inset:0; opacity:0; transition:opacity 0.25s ease; }
.module-card:hover { border-color:var(--glass-border-focus); transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.module-card:hover::before { opacity:1; }
.module-card:active { transform:scale(0.96) translateY(0); box-shadow:var(--shadow-sm); }
.module-card.blue::before   { background:linear-gradient(135deg,rgba(76,110,245,0.12),rgba(124,58,237,0.08)); }
.module-card.cyan::before   { background:linear-gradient(135deg,rgba(6,182,212,0.10),transparent); }
.module-card.purple::before { background:linear-gradient(135deg,rgba(124,58,237,0.10),transparent); }
.module-card.green::before  { background:linear-gradient(135deg,rgba(16,185,129,0.09),transparent); }
.module-icon { width:48px; height:48px; border-radius:15px; display:flex; align-items:center; justify-content:center; font-size:1.35rem; position:relative; z-index:1; transition:transform var(--transition-spring); }
.module-card:hover .module-icon { transform: scale(1.12); }
.module-icon.blue   { background:rgba(76,110,245,0.18); box-shadow:0 0 20px rgba(76,110,245,0.18), inset 0 1px 0 rgba(255,255,255,0.1); }
.module-icon.cyan   { background:rgba(6,182,212,0.15);  box-shadow:0 0 20px rgba(6,182,212,0.14), inset 0 1px 0 rgba(255,255,255,0.1); }
.module-icon.purple { background:rgba(124,58,237,0.15); box-shadow:0 0 20px rgba(124,58,237,0.14), inset 0 1px 0 rgba(255,255,255,0.1); }
.module-icon.green  { background:rgba(16,185,129,0.14); box-shadow:0 0 20px rgba(16,185,129,0.12), inset 0 1px 0 rgba(255,255,255,0.1); }
.module-name { font-size:0.92rem; font-weight:700; color:var(--text-1); position:relative; z-index:1; line-height:1; }
.module-desc { font-size:0.7rem; color:var(--text-3); position:relative; z-index:1; line-height:1.4; font-weight:400; margin-top:-6px; }

/* ===== PROGRESS ===== */
.progress-section {
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius); padding:20px 22px;
}
.progress-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.progress-label  { font-size:0.78rem; color:var(--text-2); font-weight:600; }
.progress-pct    { font-size:1.1rem; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.progress-bar-bg { height:8px; background:rgba(255,255,255,0.06); border-radius:99px; overflow:hidden; }
.progress-bar-fill { height:100%; border-radius:99px; background:var(--grad-primary); transition:width 0.6s cubic-bezier(0.4,0,0.2,1); box-shadow:0 0 16px rgba(99,102,241,0.5); }
.progress-actions { display:flex; gap:8px; margin-top:14px; }

/* ===== PAGE ===== */
.page-content { padding:20px 16px; }
.section-title { font-size:0.86rem; font-weight:700; color:var(--text-1); margin-bottom:14px; display:flex; align-items:center; gap:8px; letter-spacing:0.01em; }
.section-title .dot { width:6px; height:6px; border-radius:50%; background:var(--grad-primary); flex-shrink:0; box-shadow:0 0 8px rgba(99,102,241,0.6); }

/* ===== CARD ===== */
.card {
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius); padding:18px; margin-bottom:12px;
  transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  box-shadow: var(--shadow-sm);
}
.card:hover { border-color:var(--glass-border-focus); box-shadow: var(--shadow-md); }
.card-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px; }
.card-title  { font-size:0.9rem; font-weight:700; color:var(--text-1); line-height:1.3; }
.card-actions { display:flex; gap:6px; }
.card-body   { font-size:0.83rem; color:var(--text-2); line-height:1.65; font-weight:400; }

/* ===== BADGES ===== */
.badge { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:99px; font-size:0.65rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; }
.badge-blue   { background:rgba(76,110,245,0.15);  color:#818cf8; border:1px solid rgba(76,110,245,0.25); }
.badge-green  { background:rgba(16,185,129,0.12);  color:#34d399; border:1px solid rgba(16,185,129,0.25); }
.badge-red    { background:rgba(244,63,94,0.12);   color:#fb7185; border:1px solid rgba(244,63,94,0.25); }
.badge-yellow { background:rgba(245,158,11,0.12);  color:#fbbf24; border:1px solid rgba(245,158,11,0.25); }
.badge-purple { background:rgba(124,58,237,0.12);  color:#a78bfa; border:1px solid rgba(124,58,237,0.25); }
.badge-gray   { background:rgba(255,255,255,0.06); color:var(--text-3); border:1px solid var(--glass-border); }
.badge-orange { background:rgba(249,115,22,0.12);  color:#fb923c; border:1px solid rgba(249,115,22,0.25); }

/* ===== ACCOUNTS ===== */
.accounts-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:20px; }
.account-card {
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius); padding:18px 16px;
  cursor:pointer; transition:all var(--transition-spring); position:relative; overflow:hidden;
}
.account-card::after { content:''; position:absolute; inset:0; background:var(--grad-card); opacity:0; transition:opacity var(--transition); }
.account-card:hover { border-color:var(--glass-border-focus); transform:translateY(-3px); box-shadow:var(--shadow-md), var(--glow-blue); }
.account-card:hover::after { opacity:1; }
.account-card:active { transform: scale(0.97) translateY(0); }
.account-icon    { font-size:1.3rem; margin-bottom:10px; position:relative; z-index:1; }
.account-name    { font-size:0.62rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.09em; font-weight:700; margin-bottom:6px; position:relative; z-index:1; }
.account-balance { font-size:1.05rem; font-weight:700; position:relative; z-index:1; letter-spacing:-0.03em; font-family:var(--font-mono); }
.account-balance.positive { color:#34d399; text-shadow: 0 0 20px rgba(52,211,153,0.3); }
.account-balance.zero     { color:var(--text-3); }
.account-balance.negative { color:#fb7185; text-shadow: 0 0 20px rgba(251,113,133,0.25); }
.account-tap-hint { font-size:0.58rem; color:var(--text-4); margin-top:4px; position:relative; z-index:1; }

/* ===== TRANSACTIONS ===== */
.transaction-item { display:flex; align-items:center; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--glass-border); }
.transaction-item:last-child { border-bottom:none; }
.tx-left   { display:flex; align-items:center; gap:12px; }
.tx-icon   { width:38px; height:38px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.tx-icon.entrada { background:rgba(16,185,129,0.12); }
.tx-icon.saida   { background:rgba(244,63,94,0.12); }
.tx-info .tx-desc { font-size:0.84rem; color:var(--text-1); font-weight:600; }
.tx-info .tx-meta { font-size:0.7rem; color:var(--text-3); margin-top:2px; font-weight:400; }
.tx-amount { font-size:0.9rem; font-weight:700; letter-spacing:-0.02em; font-family:var(--font-mono); }
.tx-amount.entrada { color:#34d399; text-shadow:0 0 12px rgba(52,211,153,0.25); }
.tx-amount.saida   { color:#fb7185; text-shadow:0 0 12px rgba(251,113,133,0.20); }

/* ===== BILLS ===== */
.month-nav { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.month-label { font-size:1.05rem; font-weight:700; color:var(--text-1); }
.bills-summary { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-bottom:16px; }
.summary-card {
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius-sm); padding:12px 8px; text-align:center;
}
.summary-card .s-label { font-size:0.58rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.09em; font-weight:700; margin-bottom:5px; }
.summary-card .s-value { font-size:0.85rem; font-weight:700; letter-spacing:-0.02em; font-family:var(--font-mono); }
.bill-item {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--radius-sm); padding:14px 16px; margin-bottom:8px; gap:10px;
  transition:all var(--transition); animation: slideInRight 0.2s ease;
}
.bill-item:hover { border-color:var(--glass-border-focus); transform:translateX(2px); box-shadow:var(--shadow-sm); }
.bill-item.paid  { opacity:0.48; }
.bill-item.paid .bill-name { text-decoration:line-through; color:var(--text-3); }
.bill-item.overdue { border-color:rgba(244,63,94,0.35); background:rgba(244,63,94,0.04); box-shadow:inset 0 0 0 1px rgba(244,63,94,0.10); }
.bill-left  { display:flex; align-items:center; gap:12px; flex:1; min-width:0; }
.bill-check { width:24px; height:24px; border:2px solid rgba(255,255,255,0.18); border-radius:8px; display:flex; align-items:center; justify-content:center; cursor:pointer; flex-shrink:0; transition:all var(--transition-spring); font-size:0.76rem; color:transparent; }
.bill-check:hover { border-color: rgba(16,185,129,0.5); background: rgba(16,185,129,0.08); transform: scale(1.1); }
.bill-check.checked { background:var(--green); border-color:var(--green); color:white; box-shadow:0 0 16px rgba(16,185,129,0.4); animation: checkPop 0.45s cubic-bezier(0.34,1.56,0.64,1); }
.bill-check.pay-anim { animation: paySuccess 0.55s ease forwards; }
.bill-name  { font-size:0.84rem; color:var(--text-1); font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bill-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.bill-value { font-size:0.92rem; font-weight:700; color:var(--text-1); letter-spacing:-0.02em; font-family:var(--font-mono); }
.bill-meta  { font-size:0.65rem; color:var(--text-3); margin-top:2px; }

/* Upcoming bills */
.upcoming-bill {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius-sm);
  padding:12px 14px; margin-bottom:8px; transition:all var(--transition);
}
.upcoming-bill.overdue  { border-color:rgba(244,63,94,0.4); background:rgba(244,63,94,0.06); }
.upcoming-bill.due-soon { border-color:rgba(245,158,11,0.4); background:rgba(245,158,11,0.04); }
.ub-left   { display:flex; flex-direction:column; gap:2px; }
.ub-name   { font-size:0.84rem; font-weight:600; color:var(--text-1); }
.ub-date   { font-size:0.7rem; color:var(--text-3); }
.ub-right  { display:flex; align-items:center; gap:8px; }
.ub-value  { font-size:0.88rem; font-weight:800; color:var(--text-1); }

/* ===== MODAL ===== */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.65);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  z-index:1000; display:flex; align-items:flex-end; justify-content:center; animation:fadeIn 0.2s ease;
}
.modal-overlay.hidden { display:none; }
.modal {
  background:rgba(10,15,42,0.97); backdrop-filter:blur(36px); -webkit-backdrop-filter:blur(36px);
  border:1px solid rgba(255,255,255,0.11); border-top:1px solid rgba(255,255,255,0.16);
  border-radius:28px 28px 0 0;
  padding:28px 20px calc(28px + env(safe-area-inset-bottom, 12px));
  width:100%; max-width:480px;
  max-height:92vh; overflow-y:auto;
  animation:slideUp 0.32s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 -16px 60px rgba(0,0,0,0.7), var(--glow-purple);
}
/* Full-screen em telas muito pequenas */
@media (max-height: 600px) {
  .modal { max-height: 100vh; border-radius: 0; }
  .modal-overlay { align-items: flex-start; }
}
.modal-handle { width:36px; height:4px; background:var(--glass-border-focus); border-radius:99px; margin:0 auto 22px; }
.modal-title  { font-size:1.08rem; font-weight:700; color:var(--text-1); margin-bottom:22px; text-align:center; letter-spacing:-0.01em; }

/* ===== STATUS TABS ===== */
.project-status-tabs { display:flex; gap:6px; margin-bottom:18px; overflow-x:auto; padding-bottom:2px; -ms-overflow-style:none; scrollbar-width:none; }
.project-status-tabs::-webkit-scrollbar { display:none; }
.status-tab { padding:7px 16px; border-radius:99px; font-size:0.74rem; font-weight:600; cursor:pointer; border:1px solid var(--glass-border); color:var(--text-3); background:var(--glass-bg); white-space:nowrap; transition:all var(--transition); }
.status-tab.active, .status-tab:hover { background:rgba(99,102,241,0.15); border-color:rgba(99,102,241,0.4); color:#818cf8; }

/* ===== PLANNING ===== */
.planning-cats { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.cat-chip { display:flex; align-items:center; gap:8px; background:var(--glass-bg); backdrop-filter:var(--glass-blur); border:1px solid var(--glass-border); border-radius:var(--radius-sm); padding:11px 14px; font-size:0.78rem; color:var(--text-2); cursor:pointer; transition:all var(--transition); font-weight:500; }
.cat-chip.active, .cat-chip:hover { background:rgba(99,102,241,0.12); border-color:rgba(99,102,241,0.35); color:var(--text-1); }

/* ===== BENEAPPS ===== */
.beneapps-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.app-chip { background:var(--glass-bg); backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur); border:1px solid var(--glass-border); border-radius:var(--radius); padding:22px 16px; text-align:center; cursor:pointer; transition:all var(--transition-spring); display:flex; flex-direction:column; align-items:center; gap:10px; }
.app-chip:hover { border-color:var(--glass-border-focus); transform:translateY(-3px); box-shadow:var(--shadow-md); background:var(--glass-bg-md); }
.app-chip-icon { font-size:1.9rem; }
.app-chip-name { font-size:0.78rem; font-weight:700; color:var(--text-2); }
.app-chip-tag  { font-size:0.6rem; color:var(--text-4); text-transform:uppercase; letter-spacing:0.07em; font-weight:600; }

/* ===== OPTION LIST ===== */
.option-list { display:flex; flex-direction:column; gap:8px; }
.option-item { display:flex; align-items:center; gap:12px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius-sm); padding:14px 16px; cursor:pointer; transition:all var(--transition); font-size:0.84rem; font-weight:500; color:var(--text-2); }
.option-item:hover { background:rgba(99,102,241,0.12); border-color:rgba(99,102,241,0.35); color:var(--text-1); transform:translateX(3px); }

/* ===== TOAST ===== */
.toast {
  position:fixed; bottom:calc(72px + env(safe-area-inset-bottom, 0px)); left:50%;
  transform:translateX(-50%) translateY(20px) scale(0.92);
  background:rgba(12,18,48,0.97); backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-focus); border-radius:16px;
  padding:13px 24px; font-size:0.82rem; font-weight:600; color:var(--text-1);
  z-index:9999; box-shadow:var(--shadow-lg);
  transition: transform 0.0s, opacity 0.0s; opacity:0;
  white-space:nowrap; pointer-events:none;
  display: flex; align-items: center; gap: 8px;
}
.toast.show {
  animation: toastIn 0.38s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
.toast.toast-success { border-color: rgba(16,185,129,0.45); box-shadow: var(--shadow-lg), 0 0 24px rgba(16,185,129,0.12); }
.toast.toast-error   { border-color: rgba(244,63,94,0.45);  box-shadow: var(--shadow-lg), 0 0 24px rgba(244,63,94,0.12); }
.toast.toast-info    { border-color: rgba(76,110,245,0.45); box-shadow: var(--shadow-lg), 0 0 24px rgba(76,110,245,0.12); }

/* ===== EMPTY STATE ===== */
.empty-state { text-align:center; padding:44px 20px; color:var(--text-3); }
.empty-state .empty-icon  { font-size:2.6rem; margin-bottom:14px; }
.empty-state .empty-title { font-size:0.9rem; color:var(--text-2); font-weight:700; margin-bottom:6px; }
.empty-state .empty-sub   { font-size:0.76rem; font-weight:400; }

/* ===== SEARCH BAR ===== */
.search-bar-wrap {
  position:relative; display:flex; align-items:center;
}
.search-icon { position:absolute; left:14px; font-size:0.9rem; z-index:1; pointer-events:none; }
.search-bar {
  width:100%; background:var(--glass-bg); backdrop-filter:blur(8px);
  border:1px solid var(--glass-border); border-radius:var(--radius-sm);
  color:var(--text-1); font-family:var(--font); font-size:0.88rem;
  padding:11px 14px 11px 40px; outline:none; transition:all var(--transition);
}
.search-bar::placeholder { color:var(--text-4); }
.search-bar:focus { border-color:rgba(99,102,241,0.6); background:var(--glass-bg-md); box-shadow:0 0 0 3px rgba(99,102,241,0.12); }

/* ===== FILTER SELECT ===== */
.filter-select {
  background:var(--glass-bg); backdrop-filter:blur(8px);
  border:1px solid var(--glass-border); border-radius:8px;
  color:var(--text-2); font-family:var(--font); font-size:0.72rem; font-weight:500;
  padding:7px 10px; outline:none; cursor:pointer; transition:all var(--transition);
  -webkit-appearance:none;
}
.filter-select:focus { border-color:rgba(99,102,241,0.5); color:var(--text-1); }
.filter-select option { background:#1e2640; color:var(--text-1); }

/* ===== UTILS ===== */
.divider { height:1px; background:var(--glass-border); margin:16px 0; }
.logout-btn { display:inline-flex; align-items:center; gap:6px; background:rgba(244,63,94,0.08); border:1px solid rgba(244,63,94,0.2); color:rgba(244,63,94,0.65); padding:7px 16px; border-radius:10px; font-family:var(--font); font-size:0.74rem; font-weight:600; cursor:pointer; transition:all var(--transition); }
.logout-btn:hover { background:rgba(244,63,94,0.15); border-color:var(--red); color:var(--red); }
.flex         { display:flex; }
.flex-between { display:flex; justify-content:space-between; align-items:center; }
.flex-center  { display:flex; align-items:center; justify-content:center; }
.gap-6  { gap:6px; }
.gap-8  { gap:8px; }
.gap-12 { gap:12px; }
.mt-4   { margin-top:4px; }
.mt-8   { margin-top:8px; }
.mt-12  { margin-top:12px; }
.mt-16  { margin-top:16px; }
.mt-20  { margin-top:20px; }
.mb-4   { margin-bottom:4px; }
.mb-8   { margin-bottom:8px; }
.mb-12  { margin-bottom:12px; }
.mb-16  { margin-bottom:16px; }
.mb-20  { margin-bottom:20px; }
.text-sm    { font-size:0.82rem; }
.text-xs    { font-size:0.72rem; }
.text-muted { color:var(--text-3); }
.text-right { text-align:right; }
.fw-bold    { font-weight:700; }
.hidden     { display:none !important; }

/* ===== NOTES FIELD ===== */
.card-notes { font-size:0.76rem; color:var(--text-3); margin-top:8px; line-height:1.5; padding:8px 12px; background:rgba(255,255,255,0.03); border-radius:8px; border-left:2px solid rgba(99,102,241,0.3); }

/* ===== PAYMENT HISTORY ===== */
.pay-history-item { font-size:0.73rem; color:var(--text-3); padding:4px 0; border-bottom:1px solid var(--glass-border); display:flex; justify-content:space-between; }
.pay-history-item:last-child { border-bottom:none; }

/* ===== CATEGORY FILTER CHIPS ===== */
.cat-filter-wrap {
  display: flex; gap: 6px; overflow-x: auto; padding-bottom: 4px;
  -ms-overflow-style: none; scrollbar-width: none;
}
.cat-filter-wrap::-webkit-scrollbar { display: none; }
.cat-filter-chip {
  flex-shrink: 0; padding: 6px 14px; border-radius: 99px;
  font-size: 0.73rem; font-weight: 600; cursor: pointer;
  border: 1px solid var(--glass-border); color: var(--text-3);
  background: var(--glass-bg); white-space: nowrap;
  transition: all var(--transition); font-family: var(--font);
}
.cat-filter-chip.active {
  background: rgba(99,102,241,0.15);
  border-color: rgba(99,102,241,0.4); color: #818cf8;
}

/* ===== CATEGORY MANAGER ===== */
.cat-manager-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: var(--radius-sm);
  background: var(--glass-bg); margin-bottom: 6px;
}
.cat-manager-icon { font-size: 1.2rem; flex-shrink: 0; }
.cat-manager-name { flex: 1; font-size: 0.84rem; font-weight: 600; color: var(--text-1); }
.cat-manager-actions { display: flex; gap: 4px; flex-shrink: 0; }

/* ===== CATEGORY DASHBOARD ===== */
.cat-dashboard-list { display: flex; flex-direction: column; gap: 8px; }
.cat-dash-item {
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm); padding: 12px 14px;
  cursor: pointer; transition: all var(--transition);
  position: relative; overflow: hidden;
}
.cat-dash-item:hover { border-color: var(--cat-color, var(--glass-border-focus)); background: var(--glass-bg-md); }
.cat-dash-active { border-color: var(--cat-color, var(--blue)) !important; background: var(--glass-bg-md) !important; }
.cat-dash-left { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.cat-dash-icon { font-size: 1.3rem; flex-shrink: 0; }
.cat-dash-name { font-size: 0.84rem; font-weight: 700; color: var(--text-1); }
.cat-dash-meta { font-size: 0.68rem; color: var(--text-3); margin-top: 2px; }
.cat-dash-right { position: absolute; top: 12px; right: 14px; text-align: right; }
.cat-dash-value { font-size: 0.9rem; font-weight: 800; color: var(--text-1); }
.cat-dash-paid { font-size: 0.68rem; color: var(--green); margin-top: 2px; }
.cat-dash-bar-bg {
  height: 4px; background: rgba(255,255,255,0.07);
  border-radius: 99px; overflow: hidden; margin-top: 4px;
}
.cat-dash-bar-fill {
  height: 100%; border-radius: 99px;
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
  opacity: 0.85;
}

/* ===== RELATÓRIOS ===== */
.rep-tabs {
  display: flex; gap: 8px; margin-bottom: 16px;
}
.rep-tab {
  flex: 1; padding: 10px 16px; border-radius: var(--radius-sm);
  font-family: var(--font); font-size: 0.82rem; font-weight: 600;
  cursor: pointer; border: 1px solid var(--glass-border);
  background: var(--glass-bg); color: var(--text-3);
  transition: all var(--transition);
}
.rep-tab.active {
  background: var(--grad-primary); color: #fff;
  border-color: transparent; box-shadow: var(--shadow-blue);
}
.rep-filters {
  display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap;
}
.rep-filters .filter-select { flex: 1; min-width: 130px; }
.rep-period-label {
  font-size: 0.78rem; font-weight: 700; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 0.1em;
  margin-bottom: 14px;
}
.rep-kpi-grid {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; margin-bottom: 14px;
}
.rep-kpi {
  border-radius: var(--radius-sm); padding: 14px 12px;
  border: 1px solid rgba(255,255,255,0.07);
}
.rep-kpi-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.07em; font-weight: 600; color: var(--text-4); margin-bottom: 5px; }
.rep-kpi-value { font-size: 0.95rem; font-weight: 800; letter-spacing: -0.02em; }
.rep-kpi-blue   { background: linear-gradient(135deg,rgba(76,110,245,0.18),rgba(76,110,245,0.06)); }
.rep-kpi-blue .rep-kpi-value   { color: #818cf8; }
.rep-kpi-green  { background: linear-gradient(135deg,rgba(16,185,129,0.16),rgba(16,185,129,0.05)); }
.rep-kpi-green .rep-kpi-value  { color: #34d399; }
.rep-kpi-yellow { background: linear-gradient(135deg,rgba(245,158,11,0.16),rgba(245,158,11,0.05)); }
.rep-kpi-yellow .rep-kpi-value { color: #fbbf24; }
.rep-kpi-red    { background: linear-gradient(135deg,rgba(244,63,94,0.16),rgba(244,63,94,0.05)); }
.rep-kpi-red .rep-kpi-value    { color: #fb7185; }

.rep-chart-card, .rep-table-card {
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  border-radius: var(--radius); padding: 18px 16px; margin-bottom: 12px;
}
.rep-chart-title {
  font-size: 0.8rem; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 16px;
}
.rep-chart-wrap { position: relative; height: 200px; }

/* Categoria rows */
.rep-cat-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--glass-border);
  position: relative; flex-wrap: wrap;
}
.rep-cat-row:last-child { border-bottom: none; }
.rep-cat-row-left  { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.rep-cat-row-right { text-align: right; flex-shrink: 0; }
.rep-cat-icon  { font-size: 1.2rem; flex-shrink: 0; }
.rep-cat-name  { font-size: 0.83rem; font-weight: 700; color: var(--text-1); }
.rep-cat-meta  { font-size: 0.67rem; color: var(--text-4); margin-top: 1px; }
.rep-cat-total { font-size: 0.88rem; font-weight: 800; color: var(--text-1); }
.rep-cat-paid  { font-size: 0.67rem; color: var(--green); margin-top: 2px; }
.rep-prog-bg   { width: 100%; height: 3px; background: rgba(255,255,255,0.06); border-radius: 99px; overflow: hidden; margin-top: 8px; }
.rep-prog-fill { height: 100%; border-radius: 99px; transition: width 0.5s ease; opacity: 0.85; }

/* Tabela anual */
.rep-month-table { display: flex; flex-direction: column; gap: 0; }
.rep-month-header {
  display: grid; grid-template-columns: 2fr 3fr 3fr 1.5fr;
  padding: 6px 8px; font-size: 0.62rem; color: var(--text-4);
  text-transform: uppercase; letter-spacing: 0.07em; font-weight: 600;
}
.rep-month-row {
  display: grid; grid-template-columns: 2fr 3fr 3fr 1.5fr;
  padding: 10px 8px; font-size: 0.8rem; font-weight: 600; color: var(--text-2);
  border-top: 1px solid var(--glass-border); cursor: pointer;
  transition: background var(--transition); border-radius: 6px;
}
.rep-month-row:hover { background: var(--glass-bg-md); }
.rep-month-current { color: var(--text-1) !important; background: rgba(99,102,241,0.08); }
.rep-month-empty   { opacity: 0.4; }
.rep-month-name    { font-weight: 700; }

/* ===== RESPONSIVE ===== */
@media (max-width:400px) {
  .accounts-grid, .modules-grid, .beneapps-grid { grid-template-columns:1fr; }
  .planning-cats { grid-template-columns:1fr; }
  .dashboard-grid { grid-template-columns:repeat(2,1fr); }
  .bills-summary { grid-template-columns:repeat(2,1fr); }
  .login-card { padding:32px 20px; }
  .page-content { padding:16px 14px; }
}

@media (min-width:600px) {
  .dashboard-grid { grid-template-columns:repeat(4,1fr); }
  .bills-summary  { grid-template-columns:repeat(4,1fr); }
  /* Em tablets o bottom nav fica mais compacto */
  #bottom-nav { max-width: 540px; left: 50%; right: auto; transform: translateX(-50%); border-radius: 20px 20px 0 0; }
}
