/* ═══════════════════════════════════════════════════════════════════════
   NexCash — Enterprise UI v1.0
   Arquitetura: CSS Grid fixo (sidebar como coluna), Rail Mode, Z-index em camadas
   Breakpoints: 1280px (desktop), 900px (rail/notebook), 768px (tablet/mobile)
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Reset & Base ─────────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Cores - Tema Dourado & Preto Premium */
  --bg:#050505;
  --panel:#0f0f0f;
  --panel2:#161616;
  --panel3:#1f1f1f;
  --border:rgba(201,168,76,.12);
  --text:#f5f5f5;
  --muted:#9e9e9e;
  --muted2:#757575;
  --primary:#c9a84c;
  --primary2:#e8d48b;
  --success:#00c853;
  --warning:#ffb300;
  --danger:#ff1744;
  --purple:#c9a84c;
  --cyan:#e8d48b;
  --radius:14px;
  --radius-lg:22px;
  /* Layout */
  --sidebar-width:280px;
  --sidebar-rail-width:72px;
  --topbar-height:64px;
  /* Z-index em camadas (padrão enterprise) */
  --z-content:1;
  --z-dropdown:100;
  --z-sidebar:200;
  --z-topbar:300;
  --z-overlay:400;
  --z-modal:1000;
  --z-toast:2000;
}

html,body{height:100%;overflow:hidden}
body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:
    radial-gradient(circle at 15% 10%,rgba(201,168,76,.06),transparent 24%),
    radial-gradient(circle at 85% 20%,rgba(201,168,76,.04),transparent 22%),
    linear-gradient(180deg,#050505 0%,#0a0a0a 100%);
  color:var(--text);
  font-size:13px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    linear-gradient(90deg,rgba(201,168,76,.01) 1px,transparent 1px),
    linear-gradient(rgba(201,168,76,.01) 1px,transparent 1px);
  background-size:120px 120px;
  opacity:.2;
  pointer-events:none;
  z-index:0;
}
.hidden{display:none!important}
button{cursor:pointer;font:inherit}
input,select,textarea{font:inherit}

/* ── Scrollbar ────────────────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--panel3);border-radius:3px}

/* ══════════════════════════════════════════════════════════════════════
   AUTH SCREEN
   ══════════════════════════════════════════════════════════════════════ */
.auth-screen{
  position:relative;
  min-height:100vh;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  background:transparent;
  overflow:auto;
}
.auth-left,.auth-right{position:relative;z-index:1}
.auth-left{
  padding:56px 60px;
  background:linear-gradient(180deg,rgba(9,18,38,.9),rgba(6,11,23,.82));
  border-right:1px solid rgba(255,255,255,.05);
  overflow:hidden;
}
.auth-left::after{
  content:'';position:absolute;right:-180px;bottom:-180px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(76,141,255,.22),transparent 60%);
  filter:blur(10px);
}
.auth-left-inner{max-width:520px;margin-left:auto;height:100%;display:flex;flex-direction:column;justify-content:center}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:34px}
.auth-brand-icon{
  width:52px;height:52px;
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.5rem;color:#000;
  box-shadow:0 8px 32px rgba(201,168,76,.3);
}
.auth-brand-logo{
  width:72px;height:72px;
  object-fit:contain;
  filter:drop-shadow(0 8px 32px rgba(201,168,76,.4));
}
.auth-brand h1{font-size:2.2rem;line-height:1.05;margin:0 0 6px}
.auth-brand p{font-size:.95rem;color:var(--muted2)}
.auth-headline{margin-bottom:40px}
.auth-headline h2{font-size:3.05rem;line-height:1.12;font-weight:300;letter-spacing:-.04em;margin-bottom:18px}
.auth-headline h2 strong{font-weight:800;background:linear-gradient(135deg,#ffffff 0%,#86a8ff 45%,#8d6bff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-headline p{font-size:1rem;line-height:1.75;color:var(--muted2);max-width:460px}
.auth-features{display:flex;flex-direction:column;gap:18px;margin-top:14px}
.auth-feature{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  border-radius:18px;backdrop-filter:blur(10px);
}
.auth-feature-icon{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(76,141,255,.22),rgba(141,107,255,.16));
  border:1px solid rgba(173,197,255,.12);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.auth-feature-text{font-size:.9rem;line-height:1.6;color:var(--muted2)}
.auth-feature-text strong{display:block;font-size:.95rem;color:var(--text);font-weight:600;margin-bottom:4px}
.auth-right{
  padding:40px;
  background:radial-gradient(circle at 20% 30%,rgba(76,141,255,.08),transparent 22%),
    linear-gradient(180deg,rgba(6,11,23,.84),rgba(7,13,25,.94));
  display:flex;align-items:center;justify-content:center;
}
.glass-panel{
  position:relative;
  background:linear-gradient(180deg,rgba(11,19,37,.92),rgba(10,18,34,.84));
  border:1px solid rgba(173,197,255,.1);
  box-shadow:0 24px 80px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(20px);
}
.auth-form-container{width:100%;max-width:520px;padding:30px 30px 28px;border-radius:28px}
.auth-form-container::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(180deg,rgba(143,211,255,.25),rgba(255,255,255,0));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.auth-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.auth-mini-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:#fff}
.auth-mini-icon{width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;box-shadow:0 10px 26px rgba(201,168,76,.28)}
.auth-mini-logo{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 6px 16px rgba(201,168,76,.3))}
.auth-badge{padding:8px 12px;border-radius:999px;background:rgba(24,211,158,.1);border:1px solid rgba(24,211,158,.22);color:#7ce8c5;font-size:.78rem;font-weight:700}
.auth-form-title{font-size:2.35rem;letter-spacing:-.03em;margin-bottom:8px}
.auth-form-subtitle{font-size:1rem;line-height:1.6;color:var(--muted2);margin-bottom:22px}
.password-hint{font-size:.76rem;color:var(--muted);margin-top:8px}
.auth-divider{display:flex;align-items:center;gap:16px;margin:18px 0;color:var(--muted2);font-size:.8rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-footer{margin-top:22px;text-align:center;font-size:.92rem;color:var(--muted2)}
.auth-footer a{color:var(--primary);text-decoration:none;font-weight:600;margin-left:6px}
.auth-footer a:hover{text-decoration:underline}

/* ══════════════════════════════════════════════════════════════════════
   FORMULÁRIOS & BOTÕES (compartilhados entre auth e app)
   ══════════════════════════════════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.82rem;letter-spacing:.01em;color:var(--muted);margin-bottom:8px;font-weight:500}
.form-control{
  width:100%;
  background:var(--panel2);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px 16px;
  color:var(--text);font-size:.95rem;
  transition:.2s;
}
.form-control::placeholder{color:#7385ad}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(201,168,76,.1)}
.input-icon{position:relative}
.input-icon .form-control{padding-left:42px}
.input-icon::before{content:attr(data-icon);position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:1rem;opacity:.82}
.input-icon .input-right{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.85rem}
.password-strength{font-size:.75rem;margin-top:6px}
.password-strength.weak{color:var(--danger)}
.password-strength.medium{color:var(--warning)}
.password-strength.strong{color:var(--success)}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.alert{padding:12px 16px;border-radius:16px;margin-bottom:18px;font-size:.85rem;display:flex;align-items:center;gap:10px}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#f87171}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);color:#34d399}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 16px;
  border-radius:16px;
  font-weight:700;letter-spacing:.01em;
  border:1px solid rgba(173,197,255,.08);
  background:var(--panel2);color:var(--text);
  transition:.2s;font-size:.85rem;
  white-space:nowrap;
}
.btn:hover{background:var(--panel3);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,#4c8dff 0%,#6f7cff 100%);border:none;color:#fff;box-shadow:0 12px 30px rgba(76,141,255,.26)}
.btn-primary:hover{background:linear-gradient(135deg,#5c98ff 0%,#7f88ff 100%);box-shadow:0 6px 20px rgba(59,130,246,.35)}
.btn-success{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.25);color:var(--success)}
.btn-danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.25);color:var(--danger)}
.btn-ghost{background:transparent;border-color:transparent}
.btn-sm{padding:7px 12px;font-size:.8rem}
.btn-lg{padding:15px 20px;font-size:.96rem}
.btn-block{width:100%}
.btn-google{background:rgba(255,255,255,.03);border:1px solid rgba(173,197,255,.1);color:var(--text);gap:10px;padding:13px 16px;font-weight:600}
.btn-google:hover{background:rgba(255,255,255,.05)}
.btn-google img{width:18px;height:18px}

/* ══════════════════════════════════════════════════════════════════════
   APP SHELL — ARQUITETURA ENTERPRISE
   Layout: CSS Grid de 2 colunas. Sidebar é coluna fixa, nunca flutua no desktop.
   ══════════════════════════════════════════════════════════════════════ */
.app{
  display:grid;
  grid-template-columns:var(--sidebar-width) 1fr;
  grid-template-rows:1fr;
  height:100vh;
  width:100vw;
  overflow:hidden; /* Previne overflow horizontal global */
  background:transparent;
  position:relative;
  z-index:var(--z-content);
}

/* ── Sidebar ──────────────────────────────────────────────────────────── */
.sidebar{
  grid-column:1;
  grid-row:1;
  width:var(--sidebar-width);
  height:100vh;
  display:flex;
  flex-direction:column;
  background:var(--bg);
  border-right:1px solid var(--border);
  overflow:hidden;
  transition:width .25s ease;
  z-index:var(--z-sidebar);
  position:relative;
}
.sidebar-header{
  padding:22px 22px 18px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
}
.sidebar-header .logo{display:flex;align-items:center;gap:12px;overflow:hidden;flex:1;min-width:0}
.sidebar-header .logo div{
  width:42px;height:42px;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.1rem;color:#000;
  box-shadow:0 10px 26px rgba(201,168,76,.24);
}
.sidebar-logo{
  width:42px;height:42px;flex-shrink:0;
  object-fit:contain;
  filter:drop-shadow(0 6px 16px rgba(201,168,76,.3));
}
.sidebar-header h1{font-size:1.18rem;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-header .logo-text{transition:opacity .2s,width .2s}

/* Botão colapsar sidebar */
.sidebar-collapse-btn{
  flex-shrink:0;
  width:28px;height:28px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(173,197,255,.1);
  border-radius:8px;
  color:var(--muted2);
  font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  transition:.2s;
  cursor:pointer;
  line-height:1;
}
.sidebar-collapse-btn:hover{background:rgba(255,255,255,.1);color:var(--text)}

/* Estado colapsado: sidebar some completamente */
.sidebar.collapsed{width:0;border-right:none;overflow:hidden}
.app.sidebar-collapsed{grid-template-columns:0 1fr}
/* Botão flutuante para reabrir quando colapsado */
.sidebar-expand-fab{
  position:fixed;
  left:12px;top:50%;
  transform:translateY(-50%);
  width:32px;height:56px;
  background:var(--panel2);
  border:1px solid rgba(173,197,255,.12);
  border-radius:0 10px 10px 0;
  color:var(--muted2);
  font-size:1.1rem;
  display:none;
  align-items:center;justify-content:center;
  cursor:pointer;
  z-index:calc(var(--z-sidebar) + 1);
  transition:.2s;
  box-shadow:4px 0 16px rgba(0,0,0,.3);
}
.sidebar-expand-fab:hover{color:var(--text);background:var(--panel3)}
.app.sidebar-collapsed .sidebar-expand-fab{display:flex}

.sidebar-nav{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden}
.nav-section{margin-bottom:20px}
.nav-section-title{
  font-size:.72rem;font-weight:600;color:#8ea2ce;
  text-transform:uppercase;letter-spacing:.08em;
  padding:10px 12px 8px;
  white-space:nowrap;overflow:hidden;
  transition:opacity .2s;
}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:14px;
  color:#b5c2df;font-size:.95rem;
  transition:.2s;cursor:pointer;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;
}
.nav-item:hover{background:rgba(255,255,255,.035);color:var(--text)}
.nav-item.active{
  background:linear-gradient(90deg,rgba(76,141,255,.18),rgba(76,141,255,.08));
  color:#dce8ff;border:1px solid rgba(76,141,255,.16);
}
.nav-item .nav-icon{font-size:1.1rem;flex-shrink:0;width:20px;text-align:center}
.nav-item .nav-label{flex:1;transition:opacity .2s,width .2s}
.nav-item .badge{
  margin-left:auto;flex-shrink:0;
  background:var(--danger);color:#fff;
  font-size:.7rem;padding:2px 6px;border-radius:10px;
}

.sidebar-footer{
  padding:16px;
  border-top:1px solid rgba(173,197,255,.06);
  flex-shrink:0;
  display:flex;flex-direction:column;gap:10px;
}
.user-card{
  display:flex;align-items:center;gap:10px;
  padding:12px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(173,197,255,.08);
  border-radius:16px;overflow:hidden;
}
.user-avatar{
  width:36px;height:36px;flex-shrink:0;
  border-radius:12px;
  background:linear-gradient(135deg,#8b5cf6,var(--primary));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.9rem;
  box-shadow:0 12px 28px rgba(76,141,255,.2);
}
.user-info{flex:1;min-width:0;transition:opacity .2s,width .2s}
.user-name{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-email{font-size:.7rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-footer .btn-logout{
  width:100%;
  background:rgba(255,93,115,.08);
  border:1px solid rgba(255,93,115,.15);
  color:var(--danger);
  padding:9px 12px;
  font-size:.82rem;
  border-radius:12px;
  justify-content:center;
}
.sidebar-footer .btn-logout:hover{background:rgba(255,93,115,.15)}

/* ── Rail Mode (notebooks 900px–1280px) ──────────────────────────────── */
/* Sidebar encolhe para só ícones, sem texto */
.sidebar.rail{width:var(--sidebar-rail-width)}
.sidebar.rail .sidebar-header h1,
.sidebar.rail .nav-label,
.sidebar.rail .nav-section-title,
.sidebar.rail .user-info,
.sidebar.rail .badge{opacity:0;width:0;overflow:hidden;pointer-events:none}
.sidebar.rail .sidebar-header{padding:18px 14px}
.sidebar.rail .nav-item{padding:12px;justify-content:center;gap:0}
.sidebar.rail .user-card{padding:10px;justify-content:center}
.sidebar.rail .sidebar-footer .btn-logout span{display:none}
.sidebar.rail .sidebar-footer .btn-logout{padding:9px}
.sidebar.rail .sidebar-collapse-btn{display:none}

/* Tooltip nos itens do rail */
.sidebar.rail .nav-item{position:relative}
.sidebar.rail .nav-item::after{
  content:attr(data-label);
  position:absolute;left:calc(var(--sidebar-rail-width) + 8px);top:50%;transform:translateY(-50%);
  background:var(--panel3);border:1px solid var(--border);
  color:var(--text);font-size:.82rem;font-weight:600;
  padding:6px 12px;border-radius:10px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .15s;
  z-index:var(--z-dropdown);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}
.sidebar.rail .nav-item:hover::after{opacity:1}

/* Quando sidebar está em rail, o grid do app ajusta */
.app.rail-mode{grid-template-columns:var(--sidebar-rail-width) 1fr}

/* ── Main (coluna de conteúdo) ────────────────────────────────────────── */
.main{
  grid-column:2;
  grid-row:1;
  display:flex;
  flex-direction:column;
  height:100vh;
  overflow:hidden; /* O scroll é feito pelo .content, não pelo .main */
  min-width:0; /* Previne que o conteúdo expanda além da coluna */
}

/* ── Topbar ───────────────────────────────────────────────────────────── */
.topbar{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  height:var(--topbar-height);
  background:rgba(9,16,31,.74);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(173,197,255,.08);
  gap:16px;
  z-index:var(--z-topbar);
  position:relative;
}
.topbar-left{display:flex;align-items:center;gap:16px;min-width:0;flex:1}
.menu-btn{
  display:none;background:none;border:none;
  color:var(--text);font-size:1.4rem;padding:6px;
  border-radius:10px;flex-shrink:0;
}
.menu-btn:hover{background:var(--panel2)}
.page-title{min-width:0}
.page-title h1{font-size:1.52rem;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.page-title p{font-size:.86rem;color:#9aaad0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;gap:8px;flex-shrink:0}
.btn-active{background:rgba(255,183,77,.15)!important;border-color:rgba(255,183,77,.4)!important;color:var(--warning)!important;}
.search-box{position:relative;width:280px}
.search-box input{
  width:100%;
  background:rgba(17,27,49,.92);
  border:1px solid rgba(173,197,255,.1);
  border-radius:15px;
  padding:10px 14px 10px 40px;
  color:var(--text);font-size:.9rem;
}
.search-box input:focus{outline:none;border-color:rgba(111,124,255,.55);box-shadow:0 0 0 4px rgba(76,141,255,.12)}
.search-box::before{content:'🔍';position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:.85rem}

/* ── Content Area ─────────────────────────────────────────────────────── */
.content{
  flex:1;
  padding:24px;
  overflow-y:auto;
  overflow-x:hidden; /* Previne barra de rolagem horizontal */
  min-width:0;
}

/* ══════════════════════════════════════════════════════════════════════
   COMPONENTES UI
   ══════════════════════════════════════════════════════════════════════ */

/* ── Cards & Painéis ──────────────────────────────────────────────────── */
.card,.stat-card,.goal-card,.filter-bar,.modal,.toast{
  background:linear-gradient(180deg,rgba(11,19,37,.92),rgba(10,17,32,.84));
  border:1px solid rgba(173,197,255,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.26);
}
.card,.stat-card,.goal-card{border-radius:20px}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,.01));
}
.card-title{font-weight:700;display:flex;align-items:center;gap:8px}
.card-body{padding:20px}

/* ── Stats Grid ───────────────────────────────────────────────────────── */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:18px;
  margin-bottom:24px;
}
.stat-card{
  padding:22px;overflow:hidden;
  position:relative;cursor:pointer;transition:.2s;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, var(--primary), var(--primary2))}
/* Ícone do stat-card: container quadrado com ícone centralizado */
.stat-icon{
  width:44px;height:44px;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  display:grid;place-items:center;
  font-size:1.3rem;
  margin-bottom:14px;
  flex-shrink:0;
}
.stat-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);opacity:0.8;font-weight:700}
.stat-value{font-size:1.8rem;font-weight:800;letter-spacing:-.03em;margin-top:4px;line-height:1.1}
.stat-sub{font-size:.8rem;color:var(--muted);margin-top:4px}

/* ── Grids ────────────────────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ── Tabelas ──────────────────────────────────────────────────────────── */
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:480px}
th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border)}
th{font-size:.73rem;font-weight:600;color:#90a0c6;text-transform:uppercase;letter-spacing:.08em;background:rgba(255,255,255,.02)}
tbody tr:hover{background:rgba(255,255,255,.03)}
.text-right{text-align:right}

/* ── Utilitários de texto ─────────────────────────────────────────────── */
.text-success{color:var(--success);font-weight:700}
.text-danger{color:var(--danger);font-weight:700}
.text-warning{color:var(--warning);font-weight:700}
.text-primary{color:var(--primary);font-weight:700}
.text-muted{color:var(--muted)}
.text-sm{font-size:.8rem}
.mt-2{margin-top:8px}
.mb-2{margin-bottom:8px}

/* ── Tags / Badges ────────────────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:999px;font-size:.75rem;font-weight:700;border:1px solid rgba(255,255,255,.05)}
.tag-success{background:rgba(24,211,158,.15);color:#5de1b8}
.tag-danger{background:rgba(255,93,115,.14);color:#ff92a2}
.tag-warning{background:rgba(255,183,77,.15);color:#ffc978}
.tag-primary{background:rgba(76,141,255,.15);color:#8eb6ff}

/* ── Empty State ──────────────────────────────────────────────────────── */
.empty{text-align:center;padding:56px 20px;color:var(--muted)}
.empty-icon{font-size:3rem;margin-bottom:12px;opacity:.72}
.empty-title{font-weight:600;color:var(--text);margin-bottom:8px}

/* ── Progress ─────────────────────────────────────────────────────────── */
.progress{height:8px;background:var(--panel3);border-radius:4px;overflow:hidden}
.progress-bar{height:100%;background:var(--primary);border-radius:4px;transition:width .3s}
.progress-bar.success{background:#22c55e}
.progress-bar.warning{background:#facc15}
.progress-bar.danger{background:#ef4444}
.progress-bar.blink{animation:progressBlink 1s ease-in-out infinite}

/* ── Modal ────────────────────────────────────────────────────────────── */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.7);
  display:none;align-items:center;justify-content:center;
  z-index:var(--z-modal);
  padding:20px;
}
.modal-backdrop.show{display:flex}
.modal{
  background:linear-gradient(180deg,rgba(11,19,37,.96),rgba(10,17,32,.9));
  border:1px solid rgba(173,197,255,.1);
  border-radius:24px;
  width:100%;max-width:560px;max-height:90vh;
  display:flex;flex-direction:column;
  box-shadow:0 24px 80px rgba(0,0,0,.5);
}
.modal-lg{max-width:840px}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px;border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.02);flex-shrink:0;
}
.modal-title{font-weight:700;font-size:1.05rem}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{
  display:flex;justify-content:flex-end;gap:10px;
  padding:16px 20px;border-top:1px solid var(--border);
  background:rgba(255,255,255,.02);flex-shrink:0;
}

/* ── Toast ────────────────────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:10px}
.toast{border-radius:18px;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 40px rgba(0,0,0,.3);animation:slideIn .3s ease;min-width:280px;max-width:360px}
@keyframes slideIn{from{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}

/* ── Dashboard Gauges (Donut) ──────────────────────────────────────────────────────────────────── */
.donut-gauge-card .card-body{display:flex;align-items:center;justify-content:center;padding:24px 20px}
.gauge-wrap{display:flex;align-items:center;gap:20px;width:100%}
.gauge-donut{position:relative;flex-shrink:0}
.gauge-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}
.gauge-pct{font-size:1.5rem;font-weight:800;line-height:1}
.gauge-info{flex:1;min-width:0}
.gauge-valor{font-size:1.1rem;font-weight:700;color:#e2e8f0;margin-bottom:2px}
.gauge-desc{font-size:.8rem;color:#94a3b8;margin-bottom:6px}
.gauge-base{font-size:.75rem;color:#64748b}
@keyframes gaugePulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes progressBlink{0%,100%{opacity:1;filter:brightness(1)}50%{opacity:.35;filter:brightness(1.15)}}
.gauge-blink circle:last-child,.gauge-blink .gauge-pct{animation:gaugePulse 1s ease-in-out infinite}
.gauge-solid circle:last-child,.gauge-solid .gauge-pct{animation:none;opacity:1}
.toast.success{border-left:4px solid var(--success)}
.toast.error{border-left:4px solid var(--danger)}
.toast-icon{font-size:1.2rem;flex-shrink:0}
.toast-content{flex:1;min-width:0}
.toast-title{font-weight:600;font-size:.9rem}
.toast-msg{font-size:.8rem;color:var(--muted)}

/* ── Filter Bar ───────────────────────────────────────────────────────── */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-bottom:20px;padding:16px 18px;
  border-radius:18px;align-items:center;
}
.filter-bar .form-control{width:auto;min-width:170px}
.filter-bar .spacer{flex:1}

/* ── Quick Actions ────────────────────────────────────────────────────── */
.quick-actions{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}

/* ── Sections ─────────────────────────────────────────────────────────── */
.section{display:none}
.section.active{display:block}

/* ── Chart ────────────────────────────────────────────────────────────── */
.chart-container{position:relative;height:250px}

/* ── Account Items ────────────────────────────────────────────────────── */
.account-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.account-item:last-child{border-bottom:none}
.account-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.account-info{flex:1;min-width:0}
.account-name{font-weight:600}
.account-type{font-size:.75rem;color:var(--muted)}
.account-balances{display:flex;gap:10px;font-size:.75rem;color:var(--muted2);flex-wrap:wrap;margin-top:2px}
.account-balance{font-weight:700;text-align:right;flex-shrink:0}
.account-actions{display:flex;gap:4px;margin-left:8px;flex-shrink:0}
@media(max-width:480px){
  .account-item{flex-wrap:wrap}
  .account-balance{display:none}
  .account-actions{margin-left:auto}
}

/* ── Goal Cards ───────────────────────────────────────────────────────── */
.goal-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px}
.goal-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.goal-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.goal-info h3{font-size:1rem;margin-bottom:2px}
.goal-info p{font-size:.8rem;color:var(--muted)}
.goal-progress{margin-bottom:12px}
.goal-values{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:8px}
.goal-footer{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--muted)}

/* ── Budget Items ─────────────────────────────────────────────────────── */
.budget-item{padding:16px 0;border-bottom:1px solid var(--border)}
.budget-item:last-child{border-bottom:none}
.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.budget-cat{display:flex;align-items:center;gap:10px}
.budget-cat-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.budget-values{text-align:right}
.budget-spent{font-weight:700}
.budget-limit{font-size:.8rem;color:var(--muted)}

/* ── Transaction Items ────────────────────────────────────────────────── */
.tx-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid rgba(173,197,255,.08)}
.tx-item:last-child{border-bottom:none}
.tx-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.tx-info{flex:1;min-width:0}
.tx-desc{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-meta{font-size:.75rem;color:var(--muted);display:flex;gap:8px}
.tx-amount{font-weight:700;text-align:right;flex-shrink:0}
.tx-amount.income{color:var(--success);font-weight:800}
.tx-amount.expense{color:var(--danger);font-weight:800}

/* ── Dropdown ─────────────────────────────────────────────────────────── */
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;top:100%;right:0;
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);min-width:150px;
  display:none;z-index:var(--z-dropdown);
  box-shadow:0 10px 40px rgba(0,0,0,.3);
}
.dropdown-menu.show{display:block}
.dropdown-item{padding:10px 14px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:8px;font-size:.9rem}
.dropdown-item:hover{background:var(--panel2)}
.dropdown-item.danger{color:var(--danger)}
.threshold-help{font-size:.86rem;line-height:1.6;color:#94a3b8;margin-bottom:16px}
.threshold-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.threshold-preview{margin-top:4px;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(173,197,255,.08);color:#cbd5e1;font-size:.82rem;line-height:1.5}
.gauge-thresholds{font-size:.74rem;color:#64748b;margin-top:8px}
.progress-bar.strong{box-shadow:0 0 10px rgba(239,68,68,.28)}
.gauge-critical circle:last-child,.gauge-critical .gauge-pct{filter:drop-shadow(0 0 8px rgba(239,68,68,.32))}

/* ── Detail List ──────────────────────────────────────────────────────── */
.detail-list{max-height:400px;overflow-y:auto}
.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.detail-row:last-child{border-bottom:none}

/* ── Sidebar Overlay (mobile) ─────────────────────────────────────────── */
.sidebar-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  z-index:calc(var(--z-sidebar) - 1);
  display:none;
}
.sidebar-overlay.show{display:block}

/* ══════════════════════════════════════════════════════════════════════
   BREAKPOINTS RESPONSIVOS
   ══════════════════════════════════════════════════════════════════════ */

/* Desktop grande (> 1280px): sidebar expandida completa — padrão acima */

/* Notebook / Desktop médio (900px – 1280px): sidebar em modo Rail */
@media(max-width:1280px) and (min-width:901px){
  .app{grid-template-columns:var(--sidebar-rail-width) 1fr}
  .sidebar{width:var(--sidebar-rail-width)}
  .sidebar-header h1,
  .sidebar .nav-label,
  .sidebar .nav-section-title,
  .sidebar .user-info,
  .sidebar .badge{opacity:0;width:0;overflow:hidden;pointer-events:none}
  .sidebar-header{padding:18px 14px}
  .sidebar .nav-item{padding:12px;justify-content:center;gap:0}
  .sidebar .user-card{padding:10px;justify-content:center}
  .sidebar-footer .btn-logout span{display:none}
  .sidebar-footer .btn-logout{padding:9px;justify-content:center}
  /* Tooltip no rail */
  .sidebar .nav-item{position:relative}
  .sidebar .nav-item::after{
    content:attr(data-label);
    position:absolute;left:calc(var(--sidebar-rail-width) + 8px);top:50%;transform:translateY(-50%);
    background:var(--panel3);border:1px solid var(--border);
    color:var(--text);font-size:.82rem;font-weight:600;
    padding:6px 12px;border-radius:10px;
    white-space:nowrap;pointer-events:none;
    opacity:0;transition:opacity .15s;
    z-index:var(--z-dropdown);
    box-shadow:0 8px 24px rgba(0,0,0,.3);
  }
  .sidebar .nav-item:hover::after{opacity:1}
  .search-box{width:200px}
}

/* Tablet landscape (769px – 900px): sidebar gaveta, menu-btn visível */
@media(max-width:900px) and (min-width:769px){
  .app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:-300px;top:0;
    width:var(--sidebar-width);height:100vh;
    z-index:var(--z-sidebar);
    transition:left .3s ease;
  }
  .sidebar.open{left:0}
  .menu-btn{display:flex}
  .search-box{width:180px}
}

/* Mobile / Tablet portrait (≤ 768px): sidebar gaveta */
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:-300px;top:0;
    width:var(--sidebar-width);height:100vh;
    z-index:var(--z-sidebar);
    transition:left .3s ease;
  }
  .sidebar.open{left:0}
  .menu-btn{display:flex}
  .search-box{display:none}
  .sidebar-collapse-btn{display:none}
  .sidebar-expand-fab{display:none!important}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .topbar{padding:0 16px}
  .content{
    padding:16px;
    padding-bottom:calc(100px + env(safe-area-inset-bottom, 20px));
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    flex:1;
    min-height:0;
    box-sizing:border-box;
  }
  .main{
    height:100vh;
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }
  /* Modais ocupam tela cheia no mobile */
  .modal-overlay{align-items:flex-end}
  .modal{width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0;max-height:92vh}
  /* Botões de ação em coluna no mobile */
  .quick-actions{flex-wrap:wrap;gap:8px}
  .quick-actions .btn{flex:1;min-width:120px;font-size:.82rem;padding:9px 12px}
  /* Topbar compacta */
  .topbar-title{font-size:.95rem}
  /* Cards com menos padding */
  .card-body{padding:14px}
  /* Stat cards menores */
  .stat-value{font-size:1.4rem}
}

/* Mobile pequeno (≤ 480px) */
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .quick-actions .btn{flex:1}
  .page-title h1{font-size:1.1rem}
  .modal{border-radius:16px 16px 0 0}
  body{font-size:12px}
  .content{
    padding:10px;
    padding-bottom:calc(100px + env(safe-area-inset-bottom, 20px));
  }
  .topbar{height:54px}
  .menu-btn{width:36px;height:36px}
  .badge{font-size:.65rem;padding:2px 6px}
}

/* ══════════════════════════════════════════════════════════════════
   TABELAS → CARDS NO MOBILE
   Cada linha <tr> vira um card compacto com label + valor
   ══════════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Esconde o cabeçalho da tabela */
  .table-scroll thead{display:none}

  /* Cada linha vira um bloco card */
  .table-scroll tr{
    display:block;
    background:var(--panel2);
    border:1px solid var(--border);
    border-radius:12px;
    margin-bottom:10px;
    padding:12px 14px;
  }
  .table-scroll tr:hover{background:var(--panel3)}

  /* Cada célula vira uma linha label: valor */
  .table-scroll td{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:5px 0;
    border:none;
    font-size:.85rem;
    gap:8px;
  }
  .table-scroll td:last-child{border-bottom:none}

  /* Label à esquerda via data-label */
  .table-scroll td[data-label]::before{
    content:attr(data-label);
    font-size:.72rem;
    font-weight:600;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.05em;
    flex-shrink:0;
    min-width:80px;
  }

  /* Valor à direita */
  .table-scroll td>*{margin-left:auto}
  .table-scroll td.text-right{justify-content:space-between}

  /* Remove min-width da tabela no mobile (não precisa mais) */
  .table-scroll table{min-width:0}

  /* Linha de ações alinhada à direita */
  .table-scroll td[data-label="Ações"]{
    justify-content:flex-end;
    padding-top:8px;
    margin-top:4px;
    border-top:1px solid var(--border);
  }
  .table-scroll td[data-label="Ações"]::before{display:none}
}

/* ══════════════════════════════════════════════════════════════════════
   AUTH: colapsa para single-column em tablet
   ══════════════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .auth-screen{grid-template-columns:1fr}
  .auth-left{display:none}
  .auth-right{padding:24px}
  .auth-form-container{max-width:620px}
}
@media(max-width:480px){
  .auth-form-title{font-size:1.9rem}
  .auth-form-container{padding:24px 20px}
}
