:root{
  --bg: #070B10;
  --panel: rgba(17, 25, 38, 0.72);
  --panel2: rgba(12, 18, 28, 0.75);
  --border: rgba(255,255,255,0.10);
  --border2: rgba(255,255,255,0.14);
  --text: #eaf1fb;
  --muted: #a9bdd3;
  --muted2: rgba(169,189,211,0.75);

  --brand: #4ea1ff;
  --brand2:#8a5cff;
  --ok: #27e0a3;
  --good: #27e0a3;
  --danger:#ff5c72;
  --bad: #ff5c72;
  --warn:#ffcf5c;

  --card: rgba(17, 25, 38, 0.72);
  --shadow: 0 20px 50px rgba(0,0,0,0.45);
  --r: 18px;
  --r2: 14px;

  /* Additional variables for investments page */
  --radius: 18px;
  --stroke: rgba(255,255,255,0.10);
  --stroke2: rgba(255,255,255,0.14);
  --txt: #eaf1fb;
  
  --sidebar-w: 280px;
}

* {
  scroll-behavior: smooth;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes slideInRight {
  from { opacity: 0; transform: translateX(30px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes slideInUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes shimmer {
  0% { left: -100%; }
  100% { left: 100%; }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

@keyframes fadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

@keyframes glow {
  0% { box-shadow: 0 0 0 1px rgba(78,161,255,0.2), 0 2px 8px rgba(78,161,255,0.15); }
  50% { box-shadow: 0 0 0 1px rgba(78,161,255,0.3), 0 2px 12px rgba(78,161,255,0.25); }
  100% { box-shadow: 0 0 0 1px rgba(78,161,255,0.2), 0 2px 8px rgba(78,161,255,0.15); }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

@keyframes slideInNav {
  from { 
    opacity: 0; 
    transform: translateX(-20px);
  }
  to { 
    opacity: 1; 
    transform: translateX(0);
  }
}

*{ box-sizing: border-box; }
html, body { 
  height: 100%; 
  width: 100%;
  margin: 0;
  padding: 0;
}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(78,161,255,0.12), transparent 60%),
    radial-gradient(900px 600px at 80% 15%, rgba(138,92,255,0.12), transparent 60%),
    radial-gradient(900px 600px at 35% 85%, rgba(39,224,163,0.06), transparent 60%),
    var(--bg);
  color: var(--text);
  animation: fadeIn 0.6s ease-out;
}

a{ color: inherit; text-decoration: none; }

/* ========== CUSTOM SCROLLBAR (DISCRETA) ========== */
/* Chrome, Edge, Safari */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: 6px;
  border: 3px solid transparent;
  background-clip: content-box;
  transition: background 0.3s;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.20);
  background-clip: content-box;
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}

/* ========== LAYOUT BASE ========== */
.app {
  display: flex;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--sidebar-w);
  height: 100vh;
  overflow-y: auto;
  z-index: 1000;
  background: linear-gradient(180deg, 
    rgba(17, 25, 38, 0.95) 0%, 
    rgba(12, 18, 28, 0.98) 100%);
  backdrop-filter: blur(20px);
  border-right: 1px solid var(--border);
  box-shadow: 4px 0 24px rgba(0, 0, 0, 0.3);
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}

.content {
  margin-left: var(--sidebar-w);
  flex: 1;
  height: 100vh;
  overflow: hidden;
  padding: 0;
  display: flex;
  flex-direction: column;
}

#pageRoot {
  width: 100%;
  height: 100%;
  overflow: auto;
  padding: 24px;
  display: flex;
  flex-direction: column;
}

/* evita 100vw dentro do layout criando scroll fantasma */
.content * { max-width: 100%; }

/* Scrollbar styling */
.content::-webkit-scrollbar {
  width: 10px;
}
.content::-webkit-scrollbar-track {
  background: transparent;
}
.content::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.16);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: content-box;
}
.content::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,.26);
  border: 3px solid transparent;
  background-clip: content-box;
}

@media (max-width: 980px) {
  .app { flex-direction: column; }
  .sidebar { 
    position: relative; 
    width: 100%; 
    height: auto;
    padding: 16px 12px;
    border-right: none;
    border-bottom: 1px solid var(--border);
    max-height: none;
  }
  .content { margin-left: 0; padding: 18px; }
  
  .brand {
    padding-bottom: 12px;
    margin-bottom: 12px;
  }
  
  .brand-icon svg {
    width: 28px;
    height: 28px;
  }
  
  .nav {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
    overflow: visible;
  }
  
  .nav-label {
    grid-column: 1 / -1;
    padding: 8px 4px 4px 4px;
  }
  
  .nav-label:first-child {
    padding-top: 0;
  }
  
  .nav-section {
    display: contents;
  }
  
  .nav a {
    padding: 8px 10px;
    font-size: 13px;
  }
  
  .nav-icon {
    font-size: 16px;
  }
  
  .sidebar-footer {
    display: none;
  }
}

/* ========== PAGE HEADER PADRONIZADO ========== */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 26px 32px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(135deg, rgba(7,11,16,0.8), rgba(20,25,35,0.6));
  backdrop-filter: blur(12px);
  position: sticky;
  top: 0;
  z-index: 50;
  gap: 24px;
  flex-wrap: wrap;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}

.page-header-left {
  flex: 1;
  min-width: 250px;
}

.page-header-title {
  font-size: 36px;
  font-weight: 900;
  margin: 0 0 6px 0;
  background: linear-gradient(135deg, rgba(255,255,255,1), rgba(200,220,255,0.95));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.page-header-description {
  font-size: 13px;
  color: var(--muted);
  margin: 0;
  opacity: 0.85;
}

.page-header-actions {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .page-header {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .page-header-actions {
    width: 100%;
  }
}

.container{
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 28px 56px;
  width: 100%;
}

@media (max-width: 1280px) {
  .container {
    max-width: 100%;
    padding: 24px 24px 48px 24px;
  }
}

@media (max-width: 768px) {
  .container {
    padding: 0 16px 40px 16px;
  }
}

.brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 12px 16px;
  min-height: 85px;
  border: 1.5px solid rgba(78, 161, 255, 0.25);
  border-radius: 18px;
  background: linear-gradient(135deg, 
    rgba(78, 161, 255, 0.12) 0%, 
    rgba(138, 92, 255, 0.12) 100%);
  box-shadow: 0 12px 40px rgba(0,0,0,0.4), 
              inset 0 1px 0 rgba(255,255,255,0.08);
  transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}

.brand::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, 
    transparent, 
    rgba(255,255,255,0.08), 
    transparent);
  transition: left 0.6s ease;
}

.brand:hover::before {
  left: 100%;
}

.brand:hover {
  transform: translateY(-3px);
  filter: brightness(1.05);
  box-shadow: 0 16px 50px rgba(78, 161, 255, 0.3);
  border-color: rgba(78, 161, 255, 0.5);
}

.brand-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  text-align: center;
  width: 100%;
  height: 100%;
}

.brand-text strong { 
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -0.5px;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin: 0;
  word-spacing: normal;
}

.brand-text span {
  color: var(--muted); 
  font-size: 11px;
  font-weight: 600;
  opacity: 0.85;
  line-height: 1.2;
  margin: 0;
}

.nav {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px 0;
}

.nav-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--muted);
  opacity: 0.6;
  padding: 0 10px;
  margin-top: 8px;
  display: block;
}

.nav-label:first-child {
  margin-top: 0;
}

.nav-section {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.navItem {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  border-radius: 10px;
  color: var(--muted);
  font-weight: 600;
  font-size: 14px;
  transition: all .12s ease;
  position: relative;
  overflow: hidden;
  animation: slideInNav calc(0.15s + var(--nav-index) * 0.05s) ease-out both;
}

.navItem::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  border-radius: 0 999px 999px 0;
  transition: all .12s ease;
}

.navItem:hover {
  color: var(--text);
  background: rgba(255,255,255,.06);
  transform: translateY(-2px);
  filter: brightness(1.03);
}

.navItem:hover::before {
  width: 4px;
  height: 20px;
}

.navItem.active {
  color: var(--text);
  background: linear-gradient(135deg, 
    rgba(78, 161, 255, 0.15), 
    rgba(138, 92, 255, 0.15));
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 
              0 4px 16px rgba(78,161,255,0.2);
}

.navItem.active::before {
  width: 4px;
  height: 26px;
  box-shadow: 0 0 12px rgba(78,161,255,0.6);
}

.nav-icon {
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  flex-shrink: 0;
  filter: grayscale(0.3);
  transition: filter .12s ease;
}

.navItem:hover .nav-icon,
.navItem.active .nav-icon {
  filter: grayscale(0);
}

.nav-text {
  flex: 1;
  letter-spacing: -0.01em;
}

.nav a{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 11px 14px;
  border-radius: 12px;
  border: 1px solid transparent;
  color: var(--muted);
  background: transparent;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
  font-size: 14px;
  font-weight: 500;
  animation: slideInNav 0.5s ease-out both;
  animation-delay: calc(var(--nav-index, 0) * 0.05s);
}

.nav a::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  background: linear-gradient(180deg, var(--brand), var(--brand2));
  transform: scaleY(0);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 0 4px 4px 0;
}

.nav a::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent);
  transition: left 0.6s;
}

.nav a:hover::after {
  left: 100%;
}

.nav a:hover{
  border-color: var(--border);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  transform: translateX(4px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.nav a.active{
  border-color: rgba(78,161,255,0.3);
  background: linear-gradient(135deg, 
    rgba(78,161,255,0.15) 0%, 
    rgba(138,92,255,0.10) 100%);
  color: var(--text);
  box-shadow: 0 0 0 1px rgba(78,161,255,0.2), 
              0 4px 16px rgba(78,161,255,0.2),
              inset 0 1px 0 rgba(255,255,255,0.1);
  font-weight: 600;
}

.nav a.active::before {
  transform: scaleY(1);
}

.nav-icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

/* ========== BRAND ========== */
/* ========== NAV ========== */
.nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.nav::-webkit-scrollbar {
  width: 4px;
}

.nav::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1);
  border-radius: 999px;
}

.nav-label {
  font-size: 11px;
  font-weight: 800;
  color: var(--muted2);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 16px 12px 8px 12px;
  opacity: 0.6;
}

.nav-label:first-child {
  padding-top: 0;
}

.nav-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
}

.nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: rgba(255,255,255,0.75);
  font-size: 14px;
  font-weight: 500;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.nav a::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 3px;
  height: 100%;
  background: linear-gradient(180deg, var(--brand), var(--brand2));
  transform: translateX(-3px);
  opacity: 0;
  transition: all 0.2s ease;
}

.nav a:hover {
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.95);
  transform: translateX(2px);
}

.nav a:hover::before {
  transform: translateX(0);
  opacity: 1;
}

.nav a.active {
  background: linear-gradient(90deg, 
    rgba(78,161,255,0.15) 0%, 
    rgba(138,92,255,0.10) 100%);
  color: var(--text);
  font-weight: 600;
  box-shadow: 
    inset 0 0 0 1px rgba(78,161,255,0.3),
    0 2px 8px rgba(78,161,255,0.15);
}

.nav a.active::before {
  transform: translateX(0);
  opacity: 1;
}

.nav-icon {
  font-size: 18px;
  line-height: 1;
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.nav a:hover .nav-icon {
  transform: scale(1.15);
}

.nav a.active .nav-icon {
  transform: scale(1.15);
  filter: drop-shadow(0 0 8px rgba(78,161,255,0.5));
}

.nav-text {
  flex: 1;
}

.badge{
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255,92,114,0.15);
  border: 1px solid rgba(255,92,114,0.3);
  color: #ff5c72;
  font-weight: 700;
  line-height: 1;
}

/* ========== SIDEBAR FOOTER ========== */
.sidebar-footer {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sidebar-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 0 4px;
}

.sidebar-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.stat-label {
  font-size: 10px;
  color: var(--muted2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  opacity: 0.6;
}

.stat-value {
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
}

.stat-value.positive {
  color: var(--ok);
}

.stat-value.negative {
  color: var(--danger);
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  transition: all 0.2s ease;
  cursor: pointer;
}

.sidebar-user:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.1);
  transform: translateY(-1px);
}

.sidebar-user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.sidebar-user-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sidebar-user-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.2;
}

.sidebar-user-status {
  font-size: 10px;
  color: var(--muted2);
  display: flex;
  align-items: center;
  gap: 4px;
  opacity: 0.7;
}

.status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 2px rgba(39,224,163,0.2);
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.sidebar-user-menu {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.sidebar-user-menu:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text);
}

.nav-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: 12px 0;
  opacity: 0.5;
}

.topbar{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  animation: fadeIn 1s ease-out 0.6s both;
}

.title h1{ 
  margin:0; 
  font-size: 26px; 
  background: linear-gradient(135deg, var(--text), var(--brand));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 3s infinite;
}
.title p{ margin: 6px 0 0; color: var(--muted); font-size: 13px; }

.controls{
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap: wrap;
}

.btn{
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(10px);
}

.btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s;
}

.btn:hover::before {
  left: 100%;
}

.btn:hover{ 
  background: rgba(255,255,255,0.06);
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

.btn.primary{
  border-color: rgba(78,161,255,0.40);
  background: linear-gradient(135deg, rgba(78,161,255,0.20), rgba(138,92,255,0.18));
}

.btn.primary:hover {
  box-shadow: 0 0 30px rgba(78,161,255,0.5);
}

.btn.danger{
  border-color: rgba(255,92,114,0.40);
  background: rgba(255,92,114,0.10);
  color: #ffd6dc;
}

.btn.danger:hover {
  box-shadow: 0 0 30px rgba(255,92,114,0.5);
}

.grid{
  display:grid;
  gap: 18px;
  width: 100%;
  box-sizing: border-box;
  align-items: stretch;
}

/* Media queries for grid layouts are handled by .kpiGrid and .dashboardLowerGrid */

.card{
  border-radius: var(--r);
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  padding: 18px;
  transition: all 0.3s ease;
  animation: fadeIn 1s ease-out both;
  animation-delay: calc(var(--i, 0) * 0.1s);
}

/* Cards dentro de grids devem ocupar altura total */
.grid > .card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 30px 60px rgba(0,0,0,0.5);
  border-color: rgba(78,161,255,0.2);
}

.card h2{ 
  margin:0 0 10px; 
  font-size: 16px; 
  background: linear-gradient(135deg, var(--text), var(--brand));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.small{ color: var(--muted); font-size: 13px; }

.hr{ height: 1px; background: var(--border); margin: 12px 0; }

.stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

@media (max-width: 600px){
  .stats{ grid-template-columns: 1fr; }
}

.stat{
  border-radius: var(--r2);
  border: 1px solid var(--border);
  background: var(--panel2);
  padding: 12px;
}

.stat .k{ font-size: 12px; color: var(--muted); }
.stat .v{ font-size: 18px; margin-top: 6px; font-weight: 700; }

.list{
  margin: 0;
  padding: 0;
  list-style: none;
  display:flex;
  flex-direction: column;
  gap: 8px;
}

.item{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-radius: var(--r);
  border: 1px solid var(--border);
  background: rgba(7,11,16,0.55);
}

.item .left{ display:flex; flex-direction: column; gap: 4px; min-width: 0; }
.item .desc{ color: var(--muted); font-size: 12px; overflow:hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 520px; }

.pill{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
}
.pill .dot{
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--muted);
}
.pill.income .dot{ background: var(--ok); }
.pill.expense .dot{ background: var(--danger); }

.money{
  font-weight: 800;
  white-space: nowrap;
}
.row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 1024px) {
  .row {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
}

@media (max-width: 700px){
  .row{ 
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
label{
  display:block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}
.actions{
  margin-top: 12px;
  display:flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.desc{ color: var(--muted); }


.brand{
  font-weight:800;
  letter-spacing:.4px;
  font-size:18px;
  margin-bottom:10px;
}

.nav{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.navItem{
  padding:10px 12px;
  border-radius:12px;
  color:rgba(255,255,255,.85);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
}

.navItem:hover{
  transform: translateY(-1px);
  background:rgba(255,255,255,.06);
}

.navItem.active{
  background:rgba(120,160,255,.16);
  border-color: rgba(120,160,255,.35);
}

.topbar{
  background:rgba(10,16,24,.35);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:16px 20px;
  backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.pageTitle{ margin:0; font-size:18px; }

.page{
  min-height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.small{ color: var(--muted); }
.muted{ color: var(--muted2); }

.hr{
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  margin: 20px 0;
}

label{
  font-size: 13px;
  color: var(--muted);
  display:block;
  margin-bottom:8px;
  font-weight: 500;
}

input, select, textarea{
  width:100%;
  background: rgba(0,0,0,.35);
  color: var(--txt);
  border: 1.5px solid rgba(255,255,255,.12);
  border-radius: 12px;
  padding: 13px 16px;
  outline: none;
  transition: all .25s cubic-bezier(0.34, 1.56, 0.64, 1);
  font-size: 14px;
  font-weight: 500;
}

input:focus, select:focus, textarea:focus {
  background: rgba(0,0,0,.45);
  border-color: rgba(120,160,255,.5);
  box-shadow: 0 0 0 3px rgba(120,160,255,.12);
  transform: translateY(-1px);
}

/* Remove number input spinners */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  appearance: textfield;
  -moz-appearance: textfield;
}

/* Style all select options */
select option {
  background: #070B10;
  color: var(--txt);
  padding: 8px;
}

select option:checked {
  background: linear-gradient(#4ea1ff, #4ea1ff);
  background-color: #4ea1ff !important;
  color: white !important;
}

select option:hover {
  background: #0a0f1a;
}

input::placeholder, textarea::placeholder {
  color: rgba(255,255,255,.5);
}

input:focus, select:focus, textarea:focus{
  border-color: rgba(120,160,255,.45);
  box-shadow: 0 0 0 4px rgba(120,160,255,.12);
  background: rgba(0,0,0,.35);
}

.actions{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  margin-top:18px;
  flex-wrap: wrap;
}

button{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: var(--txt);
  border-radius: 12px;
  padding: 11px 16px;
  cursor:pointer;
  transition: all .2s cubic-bezier(0.34, 1.56, 0.64, 1);
  font-size: 14px;
  font-weight: 600;
  min-height: 40px;
  position: relative;
  overflow: hidden;
}

button:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
}

button.primary{
  background: linear-gradient(135deg, rgba(120,160,255,.95), rgba(95,130,255,.85));
  border-color: rgba(120,160,255,.55);
  color: #081022;
  font-weight: 800;
  box-shadow: 0 8px 24px rgba(120,160,255,0.3);
}

button.primary:hover{
  filter: brightness(1.1);
  box-shadow: 0 12px 32px rgba(120,160,255,0.5);
  transform: translateY(-4px);
}

button.danger{
  background: rgba(255, 88, 88, .10);
  border-color: rgba(255, 88, 88, .28);
}
button.danger:hover{
  background: rgba(255, 88, 88, .18);
  border-color: rgba(255, 88, 88, .40);
  transform: translateY(-2px);
}

.stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.stat{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 12px 14px;
}
.stat .k{ color: var(--muted); font-size: 12px; }
.stat .v{ font-size: 18px; font-weight: 800; margin-top: 4px; }

.list{ margin: 12px 0 0; padding: 0; list-style:none; display:flex; flex-direction:column; gap:12px; }

.item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
}
.item .left{ display:flex; flex-direction:column; gap: 4px; }
.item .money{ font-weight: 800; letter-spacing: .2px; }

.badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  font-size: 12px;
  font-weight: 500;
  transition: all 0.2s;
}

.badge:hover {
  background: rgba(0,0,0,.25);
}

.badge .dot{
  width: 8px; height: 8px; border-radius: 999px;
  background: rgba(255,255,255,.55);
}

.badge.income{ 
  border-color: rgba(78,205,138,.35);
  background: rgba(78,205,138,.08);
}

.badge.income .dot{ background: rgba(78,205,138,.85); }

.badge.expense{ 
  border-color: rgba(255,88,88,.35);
  background: rgba(255,88,88,.08);
}

.badge.expense .dot{ background: rgba(255,88,88,.85); }

/* layout mais clean */
.container{ 
  max-width: 1280px; 
  margin: 0 auto; 
  width: 100%;
  padding: 0 16px;
}

/* Large screens - better space utilization for all pages */
@media (min-width: 1400px) {
  .container {
    max-width: 1400px;
    padding: 0 20px;
  }
}

/* Extra large screens */
@media (min-width: 1800px) {
  .container {
    max-width: 1600px;
    padding: 0 24px;
  }
}

.header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 20px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

/* ========== CARTÕES DE CRÉDITO ========== */

.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
  margin-top: 20px;
  padding: 0 8px;
  align-items: start;
}

@media (max-width: 1400px) {
  .cards-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

@media (max-width: 1100px) {
  .cards-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
}

@media (max-width: 768px) {
  .cards-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 0;
  }
}

@media (max-width: 640px) {
  .cards-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* ========== EXECUTIVE CREDIT CARDS REDESIGN ========== */

.exec-card {
  position: relative;
  border-radius: 22px;
  padding: 0;
  min-height: 420px;
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0px 1px rgba(255,255,255,0.15) inset;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
}

.exec-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.15), rgba(255,255,255,0.01), rgba(255,255,255,0.08));
  pointer-events: none;
  z-index: 1;
  opacity: 0.6;
}

.exec-card-shine {
  position: absolute;
  top: -50%;
  right: -50%;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle, rgba(255,255,255,0.1), transparent 70%);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.exec-card:hover .exec-card-shine {
  opacity: 1;
}

.exec-card:hover {
  transform: translateY(-18px) scale(1.04);
  box-shadow: 0 60px 140px rgba(0,0,0,0.75), 0 0px 1px rgba(255,255,255,0.3) inset;
  border-color: rgba(255,255,255,0.25);
}

.exec-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 22px 24px 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.01));
  border-bottom: 1px solid rgba(255,255,255,0.1);
  position: relative;
  z-index: 2;
  gap: 12px;
}

.exec-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

.exec-brand {
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 2.8px;
  color: rgba(255,255,255,0.98);
  text-shadow: 0 2px 8px rgba(0,0,0,0.4);
  background: linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0.08));
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.15);
  backdrop-filter: blur(12px);
  white-space: nowrap;
  display: inline-block;
}

.exec-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.2);
  border: 1.5px solid rgba(255,255,255,0.15);
  white-space: nowrap;
  backdrop-filter: blur(10px);
}

.exec-status-icon {
  font-size: 12px;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.exec-status-text {
  color: rgba(255,255,255,0.95);
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

.exec-menu {
  background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.85);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  font-size: 18px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 10;
  flex-shrink: 0;
}

.exec-menu:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.35);
  color: white;
  transform: scale(1.12) rotate(15deg);
  box-shadow: 0 6px 16px rgba(0,0,0,0.3);
}

.exec-limit-section {
  flex: 1;
  padding: 24px 24px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
  gap: 16px;
}

.exec-limit-context {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.exec-limit-label {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: rgba(255,255,255,0.65);
  text-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

.exec-utilization-badge {
  font-size: 11px;
  font-weight: 900;
  color: rgba(255,255,255,0.9);
  background: rgba(0,0,0,0.25);
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.12);
}

.exec-limit-value {
  font-size: 36px;
  font-weight: 900;
  color: white;
  letter-spacing: -1.5px;
  text-shadow: 0 3px 10px rgba(0,0,0,0.35);
  line-height: 1;
}

.exec-progress {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.exec-progress-bar {
  height: 10px;
  background: rgba(255,255,255,0.12);
  border-radius: 999px;
  overflow: hidden;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.3), 0 1px 3px rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.08);
}

.exec-progress-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 20px currentColor;
  filter: brightness(1.15);
}

.exec-progress-labels {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,0.75);
}

.exec-label-used {
  color: rgba(255,255,255,0.8);
}

.exec-label-limit {
  color: rgba(255,255,255,0.65);
}

.exec-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 14px 20px;
  background: rgba(0,0,0,0.2);
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  position: relative;
  z-index: 1;
}

.exec-stat-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 8px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  transition: all 0.2s ease;
}

.exec-stat-box:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.12);
}

.exec-stat-icon {
  font-size: 16px;
  line-height: 1;
}

.exec-stat-label {
  font-size: 8px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: rgba(255,255,255,0.6);
  font-weight: 700;
}

.exec-stat-value {
  font-size: 14px;
  font-weight: 900;
  color: rgba(255,255,255,0.95);
  text-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.exec-stat-value-date {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  font-family: 'Courier New', monospace;
}

.exec-bottom {
  padding: 16px 24px 20px;
  background: linear-gradient(180deg, rgba(0,0,0,0.1), rgba(0,0,0,0.25));
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
  z-index: 1;
  gap: 12px;
  flex-wrap: wrap;
}

.exec-card-info {
  flex: 1;
  min-width: 120px;
}

.exec-name {
  font-size: 15px;
  font-weight: 800;
  color: white;
  margin-bottom: 3px;
  letter-spacing: -0.3px;
  text-shadow: 0 1px 3px rgba(0,0,0,0.2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.exec-digits {
  font-size: 10px;
  font-weight: 600;
  color: rgba(255,255,255,0.7);
  letter-spacing: 1.2px;
  font-family: 'Courier New', monospace;
  margin-top: 2px;
}

.exec-card-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.exec-btn {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.2);
  color: white;
  padding: 8px 12px;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  backdrop-filter: blur(10px);
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  letter-spacing: 0.3px;
  white-space: nowrap;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  position: relative;
}

.exec-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 9px;
  background: linear-gradient(180deg, rgba(255,255,255,0.1), transparent);
  pointer-events: none;
}

.exec-btn:hover {
  background: rgba(255,255,255,0.25);
  border-color: rgba(255,255,255,0.35);
  transform: translateY(-3px) scale(1.08);
  box-shadow: 0 8px 20px rgba(0,0,0,0.25);
}

.exec-btn-sm {
  padding: 7px 11px;
  font-size: 12px;
  min-width: 30px;
  height: 30px;
}

.exec-btn-primary {
  background: linear-gradient(135deg, rgba(78,161,255,0.25), rgba(78,161,255,0.12));
  border-color: rgba(78,161,255,0.35);
  color: rgba(210,240,255,0.98);
}

.exec-btn-primary:hover {
  background: linear-gradient(135deg, rgba(78,161,255,0.35), rgba(78,161,255,0.18));
  border-color: rgba(78,161,255,0.5);
  box-shadow: 0 8px 20px rgba(78,161,255,0.25);
}

.exec-btn-secondary {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.15);
}

.exec-btn-secondary:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.25);
}

.exec-btn-danger {
  background: rgba(255, 92, 114, 0.15);
  border-color: rgba(255, 92, 114, 0.3);
  color: rgba(255, 240, 245, 0.95);
}

.exec-btn-danger:hover {
  background: rgba(255, 92, 114, 0.28);
  border-color: rgba(255, 92, 114, 0.5);
  color: white;
  box-shadow: 0 8px 20px rgba(255, 92, 114, 0.2);
}

.exec-card-tooltip {
  position: absolute;
  bottom: -28px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,0.9);
  color: rgba(255,255,255,0.95);
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
  z-index: 100;
  border: 1px solid rgba(255,255,255,0.2);
}

.exec-card:hover .exec-card-tooltip {
  opacity: 1;
}

/* Keep old credit-card for backwards compatibility */
.credit-card {
  position: relative;
  border-radius: 24px;
  padding: 32px;
  min-height: 360px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0px 1px rgba(255,255,255,0.2) inset;
  transition: transform 0.3s ease, box-shadow 0.3s ease, scale 0.2s ease;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.1);
}

.credit-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
  pointer-events: none;
}

.credit-card:hover {
  transform: translateY(-8px);
  scale: 1.02;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0px 1px rgba(255,255,255,0.3) inset;
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 28px;
  position: relative;
  z-index: 1;
}

.card-brand {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,0.98);
  background: rgba(0,0,0,0.25);
  padding: 8px 14px;
  border-radius: 10px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.1);
}

.card-menu {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.15);
  color: white;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  font-size: 20px;
  cursor: pointer;
  transition: all 0.2s;
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-menu:hover {
  background: rgba(255,255,255,0.2);
  border-color: rgba(255,255,255,0.25);
  transform: scale(1.1);
}

.card-body {
  flex: 1;
  position: relative;
  z-index: 1;
  margin-bottom: 20px;
}

.card-name {
  font-size: 22px;
  font-weight: 800;
  color: white;
  margin-bottom: 10px;
  text-shadow: 0 2px 6px rgba(0,0,0,0.3);
  letter-spacing: -0.5px;
}

.card-number {
  font-size: 16px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  letter-spacing: 2px;
  font-family: 'Courier New', monospace;
  margin-top: 8px;
}

.card-footer {
  margin-top: auto;
  position: relative;
  z-index: 1;
}

.card-limit {
  background: rgba(0,0,0,0.3);
  border-radius: 14px;
  padding: 16px;
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.08);
}

.limit-value {
  font-size: 28px;
  font-weight: 800;
  color: white;
  margin: 8px 0;
  letter-spacing: -0.5px;
}

.limit-bar {
  height: 8px;
  background: rgba(255,255,255,0.15);
  border-radius: 999px;
  overflow: hidden;
  margin: 10px 0;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.3);
}

.limit-fill {
  height: 100%;
  background: linear-gradient(90deg, #27e0a3, #4ea1ff);
  border-radius: 999px;
  transition: width 0.3s ease;
  box-shadow: 0 0 12px rgba(74, 161, 255, 0.5);
}

.card-actions {
  display: flex;
  gap: 10px;
  margin-top: auto;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}

.card-btn {
  flex: 1;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  color: white;
  padding: 12px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  backdrop-filter: blur(20px);
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

.card-btn:hover {
  background: rgba(255,255,255,0.18);
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.3);
}

.card-due {
  text-align: center;
  color: rgba(255,255,255,0.65);
  font-size: 11px;
  position: relative;
  z-index: 1;
  font-weight: 500;
  letter-spacing: 0.3px;
}

/* ========== MODAL ========== */

.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.85), rgba(10,8,20,0.8));
  backdrop-filter: blur(12px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
  animation: fadeIn 0.3s ease-out;
}

.modal-content {
  background: linear-gradient(135deg, rgba(12,16,28,0.98), rgba(20,25,40,0.95));
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 20px;
  max-width: 600px;
  width: 100%;
  max-height: 90vh;
  box-shadow: 0 80px 160px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.1);
  animation: slideUp 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(24px);
}

.modal-content.modal-lg {
  max-width: 750px;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 28px 32px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  gap: 16px;
  background: rgba(255,255,255,0.02);
}

.modal-header h2 {
  margin: 0;
  font-size: 22px;
  font-weight: 800;
  background: linear-gradient(135deg, rgba(255,255,255,1), rgba(200,220,255,0.95));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.modal-subtitle {
  font-size: 13px;
  color: var(--muted);
}

.modal-close {
  background: none;
  border: none;
  color: var(--txt);
  font-size: 28px;
  cursor: pointer;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all 0.2s;
  flex-shrink: 0;
}

.modal-close:hover {
  background: rgba(255,255,255,0.12);
  transform: rotate(90deg);
}

.modal-content form {
  padding: 28px;
  flex: 1;
  overflow-y: auto;
}

.form-grid {
  display: grid;
  gap: 20px;
}

.modal-actions {
  display: flex;
  gap: 12px;
  padding: 20px 28px;
  border-top: 1px solid rgba(255,255,255,0.08);
  justify-content: flex-end;
}

.btn-secondary {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--txt);
  padding: 12px 22px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  transition: all 0.3s;
}

.btn-secondary:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.2);
}

.color-picker {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding: 12px;
  background: rgba(0,0,0,0.2);
  border-radius: 12px;
}

.color-option {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  cursor: pointer;
  border: 3px solid transparent;
  transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  position: relative;
}

.color-option:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0,0,0,0.3);
}

.color-option.selected {
  border-color: white;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.3), 0 0 0 4px white;
  transform: scale(1.05);
}

.color-option.selected::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 20px;
  font-weight: bold;
  text-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

/* ========== EMPTY STATE ========== */

.empty-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: 50px 30px;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  opacity: 1;
}

.empty-icon {
  font-size: 48px;
  margin-bottom: 8px;
  opacity: 0.4;
}

.empty-state h3 {
  margin: 0 0 6px;
  font-size: 18px;
  font-weight: 500;
}

.empty-state p {
  margin: 0;
  max-width: 380px;
  opacity: 0.7;
  font-size: 13px;
}

.empty-state button {
  margin-top: 8px;
  padding: 10px 14px;
  border-radius: 12px;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 768px) {
  .cards-grid {
    grid-template-columns: 1fr;
  }
  
  .modal-content {
    margin: 0 10px;
  }
}/* ========== CATEGORIAS ========== */

.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 24px;
  margin-bottom: 24px;
}

/* Large screens - better stats layout */
@media (min-width: 1200px) {
  .stats-row {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
  }
}

@media (min-width: 1600px) {
  .stats-row {
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .stats-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.stat-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 20px;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.stat-card:hover {
  transform: translateY(-2px);
  border-color: var(--stroke2);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.stat-card:hover::before {
  opacity: 1;
}

.stat-card.highlight {
  background: linear-gradient(135deg, rgba(78,161,255,0.1), rgba(138,92,255,0.1));
  border-color: rgba(78,161,255,0.3);
}

.stat-content-full {
  flex: 1;
}

.stat-value-large {
  font-size: 32px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.stat-sublabel {
  font-size: 12px;
  color: var(--muted2);
  margin-top: 2px;
}

.mini-progress-bar {
  width: 100%;
  height: 6px;
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 8px;
}

.mini-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  border-radius: 3px;
  transition: width 0.8s ease;
}

.stat-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  background: rgba(255,255,255,0.05);
  border-radius: 14px;
  border: 1px solid var(--stroke);
}

.stat-icon.income {
  background: rgba(78, 205, 138, 0.1);
  border-color: rgba(78, 205, 138, 0.3);
}

.stat-icon.expense {
  background: rgba(255, 88, 88, 0.1);
  border-color: rgba(255, 88, 88, 0.3);
}

.stat-label {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 4px;
}

.stat-value {
  font-size: 28px;
  font-weight: 800;
  color: var(--txt);
}

/* ========== TYPE SELECTOR ========== */

.type-selector {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 8px;
}

.type-option {
  cursor: pointer;
}

.type-option input[type="radio"] {
  display: none;
}

.type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 18px;
  border: 2px solid var(--stroke);
  border-radius: 12px;
  background: rgba(255,255,255,0.02);
  transition: all 0.3s ease;
  text-align: center;
}

.type-option:hover .type-card {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke2);
  transform: translateY(-2px);
}

.type-option input[type="radio"]:checked + .type-card {
  border-color: var(--brand);
  background: rgba(120,160,255,0.15);
  box-shadow: 0 0 0 4px rgba(120,160,255,0.1);
}

.type-icon {
  font-size: 32px;
}

/* ========== ICON PICKER ========== */

.icon-picker {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(56px, 1fr));
  gap: 10px;
  margin-top: 12px;
  max-height: 240px;
  overflow-y: auto;
  padding: 10px;
  background: rgba(0,0,0,0.2);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
}

.icon-option {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  border-radius: 12px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  background: rgba(255,255,255,0.04);
}

.icon-option:hover {
  background: rgba(255,255,255,0.12);
  transform: scale(1.15);
}

.icon-option.selected {
  border-color: var(--brand);
  background: rgba(78, 161, 255, 0.18);
  box-shadow: 0 0 0 3px rgba(78, 161, 255, 0.2), inset 0 0 0 1px rgba(78, 161, 255, 0.3);
}

.icon-preview-box {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 120px;
  border: 2px dashed rgba(255,255,255,0.15);
  border-radius: 14px;
  background: rgba(255,255,255,0.03);
  transition: all 0.3s;
}

/* ========== PRESET CATEGORIES ========== */

.section-header {
  margin-bottom: 26px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.section-header h2 {
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.section-header .small {
  margin: 0;
  font-size: 14px;
}

.preset-section {
  margin-bottom: 0;
  padding: 0;
  background: transparent;
  border: none;
}

.preset-section:last-child {
  margin-bottom: 0;
}

.preset-section h3 {
  font-size: 14px;
  margin: 0 0 12px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.preset-btn .preset-check {
  color: var(--good);
  font-size: 18px;
  font-weight: 700;
}

.preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
}

@media (max-width: 768px) {
  .preset-grid {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
  }
}

/* ========== SEARCH BOX ========== */

.categories-controls {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 8px;
}

.search-box {
  flex: 1;
  position: relative;
  max-width: 400px;
}

.search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  pointer-events: none;
}

.search-input {
  width: 100%;
  padding: 12px 16px 12px 44px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  color: var(--txt);
  font-size: 14px;
  font-family: inherit;
  transition: all 0.3s;
}

.search-input:focus {
  outline: none;
  background: rgba(255,255,255,0.08);
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(78, 161, 255, 0.1);
}

.search-input::placeholder {
  color: var(--muted);
}

/* ========== NOTIFICATIONS ========== */

.notification {
  position: fixed;
  bottom: 30px;
  right: 30px;
  padding: 14px 20px;
  border-radius: 12px;
  font-weight: 600;
  font-size: 14px;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 9999;
  max-width: 300px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
}

.notification.show {
  opacity: 1;
  transform: translateY(0);
}

.notification-success {
  background: rgba(39, 224, 163, 0.15);
  color: var(--good);
  border: 1px solid rgba(39, 224, 163, 0.3);
}

.notification-error {
  background: rgba(255, 92, 114, 0.15);
  color: var(--danger);
  border: 1px solid rgba(255, 92, 114, 0.3);
}

.notification-info {
  background: rgba(78, 161, 255, 0.15);
  color: var(--brand);
  border: 1px solid rgba(78, 161, 255, 0.3);
}

/* ========== LINK BUTTON ========== */

.linkBtn {
  display: inline-block;
  color: var(--brand);
  font-weight: 700;
  font-size: 13px;
  text-decoration: none;
  cursor: pointer;
  background: none;
  border: none;
  padding: 8px 0;
  transition: all 0.3s;
}

.linkBtn:hover {
  color: rgba(210, 240, 255, 0.98);
  transform: translateX(2px);
}

/* ========== PANEL ========== */

.panel {
  padding: 20px;
}

.panelHead {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.panelTitle {
  font-size: 16px;
  font-weight: 800;
  color: var(--txt);
}

.muted {
  color: rgba(255,255,255,0.55);
}

.preset-btn {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 14px;
  background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid var(--stroke);
  border-radius: 14px;
  color: var(--txt);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-align: center;
  font-size: 13px;
  font-weight: 500;
}

.preset-btn:not(.disabled):hover {
  background: linear-gradient(135deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.06) 100%);
  border-color: var(--brand);
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(78, 161, 255, 0.2);
}

.preset-btn.disabled {
  opacity: 0.45;
  cursor: not-allowed;
  background: linear-gradient(135deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.01) 100%);
}

.preset-icon {
  font-size: 20px;
}

.preset-btn .check {
  margin-left: auto;
  color: var(--good);
  font-size: 16px;
}

/* ========== TABS ========== */

.tabs {
  display: flex;
  gap: 8px;
  margin: 28px 0 24px;
  border-bottom: 1px solid var(--stroke);
  padding-bottom: 0;
}

.tab {
  padding: 14px 22px;
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
}

.tab.active {
  color: var(--txt);
  border-bottom-color: var(--brand);
}

.tab:hover {
  color: var(--txt);
  background: rgba(255,255,255,0.04);
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

/* ========== CATEGORIES SECTION ========== */

.categories-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 24px;
}

@media (min-width: 1400px) {
  .categories-section {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }
}

.category-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

@media (max-width: 768px) {
  .category-list {
    grid-template-columns: 1fr;
  }
}

.category-item {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  position: relative;
}

.category-item.unused {
  opacity: 0.65;
}

.category-item:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(78, 161, 255, 0.3);
  transform: translateX(2px);
  box-shadow: 0 4px 12px rgba(78, 161, 255, 0.12);
}

.category-icon-box {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.12) 0%, rgba(138, 92, 255, 0.08) 100%);
  border: 1px solid rgba(78, 161, 255, 0.15);
  border-radius: 10px;
  flex-shrink: 0;
  transition: all 0.3s;
}

.category-item:hover .category-icon-box {
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.2) 0%, rgba(138, 92, 255, 0.12) 100%);
  border-color: rgba(78, 161, 255, 0.25);
}

.category-icon {
  font-size: 22px;
}

.category-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.category-info {
  flex: 1;
  min-width: 0;
}

.category-name {
  font-weight: 700;
  margin-bottom: 4px;
  font-size: 14px;
  color: var(--txt);
}

.category-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.usage-indicator {
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(39, 224, 163, 0.12);
  color: var(--good);
  font-weight: 600;
}

.usage-indicator.unused {
  background: rgba(255,255,255,0.06);
  color: var(--muted);
}

.category-middle {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 120px;
}

.category-total-amount {
  font-weight: 800;
  font-size: 16px;
  color: var(--good);
  text-align: right;
}

.usage-bar {
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}

.usage-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.3s ease;
}

.category-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.category-actions {
  display: flex;
  gap: 6px;
}

.btn-icon-mini {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s;
  font-size: 15px;
  flex-shrink: 0;
}

.btn-icon-mini:hover {
  background: rgba(78, 161, 255, 0.15);
  border-color: rgba(78, 161, 255, 0.25);
  transform: scale(1.08);
}

.btn-icon-mini.danger:hover {
  background: rgba(255, 92, 114, 0.15);
  border-color: rgba(255, 92, 114, 0.25);
}

.category-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.category-icon {
  font-size: 24px;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.15) 0%, rgba(138, 92, 255, 0.1) 100%);
  border: 1px solid rgba(78, 161, 255, 0.2);
  border-radius: 12px;
  flex-shrink: 0;
  transition: all 0.3s;
}

.category-item:hover .category-icon {
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.25) 0%, rgba(138, 92, 255, 0.15) 100%);
  border-color: rgba(78, 161, 255, 0.4);
  transform: scale(1.1);
}

.category-info {
  flex: 1;
  min-width: 0;
}

.category-name {
  font-weight: 700;
  margin-bottom: 6px;
  font-size: 15px;
  color: var(--txt);
}

.category-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  background: rgba(78, 161, 255, 0.12);
  color: var(--brand);
  border: 1px solid rgba(78, 161, 255, 0.24);
  transition: all 0.2s ease;
}

.badge:hover {
  transform: translateY(-1px);
  background: rgba(78, 161, 255, 0.18);
}

.badge.income {
  background: rgba(39, 224, 163, 0.12);
  color: var(--good);
  border-color: rgba(39, 224, 163, 0.24);
}

.badge.income:hover {
  background: rgba(39, 224, 163, 0.18);
}

.badge.expense {
  background: rgba(255, 92, 114, 0.12);
  color: var(--danger);
  border-color: rgba(255, 92, 114, 0.24);
}

.badge.expense:hover {
  background: rgba(255, 92, 114, 0.18);
}

.category-right {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-self: end;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.category-total {
  font-weight: 700;
  font-size: 16px;
  color: var(--ok);
  min-width: 100px;
  text-align: right;
}

.category-actions {
  display: flex;
  gap: 6px;
}

.btn-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--stroke);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-size: 16px;
  flex-shrink: 0;
}

.btn-icon:hover {
  background: rgba(78, 161, 255, 0.15);
  border-color: rgba(78, 161, 255, 0.3);
  transform: scale(1.08);
  box-shadow: 0 2px 8px rgba(78, 161, 255, 0.15);
}

.btn-icon.danger:hover {
  background: rgba(255, 92, 114, 0.15);
  border-color: rgba(255, 92, 114, 0.3);
  box-shadow: 0 2px 8px rgba(255, 92, 114, 0.15);
}

.btn-icon:active {
  transform: scale(0.95);
}

/* ========== BUDGETS ========== */

.budget-card {
  margin-bottom: 16px;
}

.budget-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
}

.budget-header h3 {
  margin: 0;
  font-size: 18px;
}

.budget-actions {
  display: flex;
  gap: 8px;
}

.budget-stats {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.budget-amount {
  font-weight: 700;
  font-size: 16px;
}

/* ========== EMPTY STATE MINI ========== */

.empty-mini {
  text-align: center;
  padding: 60px 30px;
  opacity: 0.7;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 100%);
  border: 1px solid var(--stroke);
}

.empty-mini .empty-icon {
  font-size: 56px;
  display: block;
  margin-bottom: 16px;
}

.empty-mini p {
  margin: 0 0 8px 0;
  color: var(--muted);
  font-size: 15px;
  font-weight: 500;
}

.empty-cta {
  font-size: 13px;
  color: var(--muted);
  opacity: 0.8;
}

.badge-pill {
  display: inline-block;
  background: rgba(78, 161, 255, 0.12);
  color: var(--brand);
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
}

.panelHead {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.panelTitle {
  font-size: 16px;
  font-weight: 800;
  color: var(--txt);
}

/* ========== RESPONSIVE ========== */

@media (max-width: 768px) {
  .stats-row {
    grid-template-columns: 1fr;
  }

  .categories-section {
    grid-template-columns: 1fr;
  }

  .preset-grid {
    grid-template-columns: 1fr 1fr;
  }
}
/* ========== CONFIGURAÇÕES ========== */

.config-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap: 24px;
  margin-top: 24px;
}

/* Large screens - better config layout */
@media (min-width: 1200px) {
  .config-grid {
    grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
    gap: 26px;
  }
}

@media (min-width: 1600px) {
  .config-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
}

@media (max-width: 768px) {
  .config-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.config-section {
  display: flex;
  flex-direction: column;
}

.config-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  border-bottom: 1px solid var(--stroke);
}

.config-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  background: rgba(255,255,255,0.06);
  border-radius: 14px;
  border: 1px solid var(--stroke);
  flex-shrink: 0;
}

.config-header h2 {
  margin: 0 0 4px;
  font-size: 18px;
}

.config-content {
  padding: 20px;
}

/* ========== USER CARD ========== */

.user-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 14px;
  margin-bottom: 20px;
}

.user-avatar {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border-radius: 50%;
  color: #fff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.2);
  flex-shrink: 0;
}

.user-info {
  flex: 1;
}

.user-name {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 4px;
}

/* ========== SETTINGS ========== */

.setting-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 12px 0;
}

.setting-label {
  font-weight: 600;
  margin-bottom: 4px;
}

.setting-item select {
  min-width: 180px;
}

/* ========== TOGGLE SWITCH ========== */

.toggle {
  position: relative;
  display: inline-block;
  width: 52px;
  height: 28px;
}

.toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255,255,255,0.15);
  border: 1px solid var(--stroke);
  transition: 0.3s;
  border-radius: 28px;
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 20px;
  width: 20px;
  left: 4px;
  bottom: 3px;
  background: white;
  transition: 0.3s;
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.toggle input:checked + .toggle-slider {
  background: var(--brand);
  border-color: var(--brand);
}

.toggle input:checked + .toggle-slider:before {
  transform: translateX(24px);
}

/* ========== DATA STATS ========== */

.data-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.data-stat {
  text-align: center;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 12px;
}

.data-value {
  font-size: 24px;
  font-weight: 800;
  color: var(--brand);
  margin-bottom: 4px;
}

.data-label {
  font-size: 12px;
  color: var(--muted);
}

/* ========== ACTION BUTTONS ========== */

.action-buttons {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.action-buttons-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}

@media (max-width: 600px) {
  .action-buttons-grid {
    grid-template-columns: 1fr;
  }
}

.btn.secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--stroke);
  padding: 12px;
  border-radius: 12px;
  font-weight: 600;
  transition: all 0.2s;
}

.btn.secondary:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--stroke2);
  transform: translateY(-2px);
}

.btn.secondary span {
  font-size: 18px;
}

/* ===== ICON PICKER GRID ===== */
.icon-picker-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px;
  padding: 12px;
  background: rgba(0,0,0,0.2);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 12px;
}

.icon-picker-btn {
  width: 100%;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  border-radius: 10px;
  cursor: pointer;
  border: 2px solid transparent;
  background: rgba(255,255,255,0.05);
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 0;
}

.icon-picker-btn:hover {
  background: rgba(255,255,255,0.12);
  transform: translateY(-2px);
}

.icon-picker-btn.selected {
  background: rgba(120, 140, 255, 0.3);
  border-color: rgba(120, 140, 255, 0.6);
  box-shadow: 0 0 12px rgba(120, 140, 255, 0.2);
}

/* ===== USER INFO GRID ===== */
.user-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  padding: 16px 0;
}

.user-info-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.08);
}

.user-info-item .label {
  font-size: 12px;
  color: rgba(255,255,255,0.58);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.user-info-item .value {
  font-size: 16px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  word-break: break-all;
}

/* ===== DANGER SECTION ===== */
.danger-section {
  background: linear-gradient(135deg, rgba(255,80,120,0.08), rgba(255,80,120,0.04));
  border-color: rgba(255,80,120,0.2) !important;
}

.security-buttons-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}

@media (max-width: 600px) {
  .security-buttons-grid {
    grid-template-columns: 1fr;
  }
}

.danger-hint {
  color: rgba(255,120,120,0.7) !important;
}

.form-hint {
  font-size: 12px;
  color: rgba(255,255,255,0.54);
  margin: 0;
  font-style: italic;
}

/* ========== WARNING ZONE ========== */

.warning-zone {
  background: rgba(255, 88, 88, 0.08);
  border: 1px solid rgba(255, 88, 88, 0.25);
  border-radius: 14px;
  padding: 16px;
}

.warning-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.warning-icon {
  font-size: 24px;
}

.warning-title {
  font-weight: 700;
  color: var(--danger);
  margin-bottom: 2px;
}

.warning-zone .btn.danger {
  background: rgba(255, 88, 88, 0.15);
  border-color: rgba(255, 88, 88, 0.4);
  color: #ffcdd2;
}

.warning-zone .btn.danger:hover {
  background: rgba(255, 88, 88, 0.25);
  border-color: rgba(255, 88, 88, 0.6);
}

/* ========== ABOUT SECTION ========== */

.about-info {
  text-align: center;
  padding: 20px 0;
}

.about-logo {
  font-size: 64px;
  margin-bottom: 16px;
}

.about-info h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.version {
  display: inline-block;
  padding: 4px 12px;
  background: rgba(120,160,255,0.15);
  border: 1px solid rgba(120,160,255,0.3);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--brand);
  margin-bottom: 12px;
}

.about-info p {
  max-width: 360px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ========== FEATURES LIST ========== */

.features-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: 10px;
  font-size: 14px;
}

.feature-icon {
  font-size: 18px;
  flex-shrink: 0;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 768px) {
  .config-grid {
    grid-template-columns: 1fr;
  }

  .data-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .setting-item {
    flex-direction: column;
    align-items: flex-start;
  }

  .setting-item select {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .data-stats {
    grid-template-columns: 1fr;
  }

  .user-card {
    flex-direction: column;
    text-align: center;
  }
}

/* ========== DASHBOARD ========== */

.dashboard-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 24px;
  margin-top: 32px;
  margin-bottom: 32px;
}

.stat-value.positive {
  color: var(--good);
}

.stat-value.negative {
  color: var(--bad);
}

@media (max-width: 1200px) {
  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ========== DASHBOARD AVANÇADO ========== */

.month-selector {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.month-selector input {
  width: 160px;
}

/* Hide month input spinners */
input[type="month"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  border-radius: 4px;
  margin-right: 2px;
  opacity: 0.6;
  filter: invert(1);
}

input[type="month"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}

/* ========== KPI GRID ========== */

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 24px;
  margin-bottom: 32px;
}

@media (max-width: 1100px) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .kpi-grid {
    grid-template-columns: 1fr;
  }
}

.kpi-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 24px 28px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  min-height: 160px;
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}

.kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
}

.kpi-card:hover {
  transform: translateY(-6px) scale(1.01);
  border-color: rgba(255,255,255,0.2);
  box-shadow: 0 16px 48px rgba(0,0,0,0.3), 0 0px 1px rgba(255,255,255,0.1) inset;
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
}

.kpi-card.income {
  border-left: 4px solid var(--good);
}

.kpi-card.expense {
  border-left: 4px solid var(--bad);
}

.kpi-card.balance.positive {
  border-left: 4px solid var(--good);
}

.kpi-card.balance.negative {
  border-left: 4px solid var(--bad);
}

.kpi-icon {
  font-size: 40px;
  width: 70px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
  border-radius: 14px;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: inset 0 1px 2px rgba(255,255,255,0.1);
}

.kpi-content {
  flex: 1;
}

.kpi-label {
  font-size: 12px;
  color: rgba(255,255,255,0.65);
  margin-bottom: 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.kpi-value {
  font-size: 28px;
  font-weight: 900;
  color: white;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
  line-height: 1.2;
}

.kpi-change {
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: fit-content;
  margin-top: auto;
}

.kpi-change.positive {
  background: rgba(39, 224, 163, 0.2);
  color: #27e0a3;
}

.kpi-change.negative {
  background: rgba(255, 92, 114, 0.2);
  color: #ff5c72;
}

.kpi-meta {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  margin-top: auto;
  font-weight: 500;
}

.kpi-change.positive {
  background: rgba(78, 205, 138, 0.15);
  color: var(--good);
}

.kpi-change.negative {
  background: rgba(255, 88, 88, 0.15);
  color: var(--bad);
}

.kpi-meta {
  font-size: 11px;
  color: var(--muted2);
  margin-top: 4px;
}

/* ========== CARD HEADER ========== */

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--stroke);
  gap: 12px;
}

.card-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: white;
  letter-spacing: -0.3px;
}

/* ========== CHART CONTAINER ========== */

.chart-container {
  height: 340px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-top: 8px;
}

/* ========== BAR CHART ========== */

.bar-chart {
  display: flex;
  align-items: end;
  gap: 14px;
  height: 220px;
  margin-bottom: 24px;
}

.bar-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.bar-label {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  text-align: center;
  font-weight: 500;
  margin-top: 4px;
}

.bars {
  display: flex;
  align-items: end;
  gap: 4px;
  width: 100%;
  height: 100%;
}

.bar-wrapper {
  flex: 1;
  display: flex;
  align-items: end;
  justify-content: center;
  position: relative;
}

.bar {
  width: 100%;
  max-width: 44px;
  border-radius: 6px 6px 0 0;
  position: relative;
  display: flex;
  align-items: end;
  justify-content: center;
  padding: 4px;
  min-height: 2px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  transition: all 0.3s ease;
}

.bar:hover {
  filter: brightness(1.15);
  box-shadow: 0 6px 16px rgba(0,0,0,0.3);
}

.bar.income {
  background: linear-gradient(180deg, #27e0a3 0%, rgba(39, 224, 163, 0.6) 100%);
}

.bar.expense {
  background: linear-gradient(180deg, #ff5c72 0%, rgba(255, 92, 114, 0.6) 100%);
}

.bar-value {
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

/* ========== CHART LEGEND ========== */

.chart-legend {
  display: flex;
  gap: 20px;
  justify-content: center;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--muted);
}

.legend-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.legend-dot.income {
  background: var(--good);
}

.legend-dot.expense {
  background: var(--bad);
}

/* ========== CATEGORIES CHART ========== */

.categories-chart {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.category-bar {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.category-bar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.category-bar-name {
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

.category-bar-value {
  font-weight: 700;
  color: var(--txt);
}

.progress-bar {
  height: 8px;
  background: rgba(255,255,255,0.1);
  border-radius: 999px;
  overflow: hidden;
}

.progress-bar.mini {
  height: 6px;
}

.progress-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.3s ease;
}

.progress-fill.over {
  background: var(--danger);
}

.progress-fill.warning {
  background: var(--warn);
}

.progress-fill.good {
  background: var(--ok);
}

/* ========== BUDGETS ========== */

.budgets-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.budget-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.budget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.budget-name {
  font-weight: 600;
}

.budget-values {
  font-weight: 700;
  color: var(--txt);
}

/* ========== CARDS SUMMARY ========== */

.cards-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 16px;
}

@media (min-width: 1200px) {
  .cards-summary {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 18px;
  }
}

@media (max-width: 768px) {
  .cards-summary {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.mini-card {
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  padding: 18px;
  transition: all 0.3s ease;
}

.mini-card:hover {
  border-color: rgba(255,255,255,0.18);
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  transform: translateY(-2px);
}

.mini-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}

.mini-card-name {
  font-weight: 700;
  color: white;
  font-size: 15px;
}

.mini-card-limit {
  margin-bottom: 10px;
}

.mini-card-value {
  font-size: 20px;
  font-weight: 800;
  color: white;
}

/* ========== INCOME LIST ========== */

.income-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.income-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: 10px;
}

.income-icon {
  font-size: 24px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(78, 205, 138, 0.1);
  border-radius: 8px;
}

.income-info {
  flex: 1;
}

.income-name {
  font-weight: 600;
  margin-bottom: 2px;
}

.income-value {
  font-weight: 700;
  color: var(--good);
}

/* ========== RECENT TRANSACTIONS ========== */

.recent-transactions {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.recent-tx {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  transition: all 0.3s ease;
}

.recent-tx:hover {
  background: linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.03));
  border-color: rgba(255,255,255,0.15);
  transform: translateX(4px);
}

.recent-tx-icon {
  font-size: 20px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
}

.recent-tx-icon.income {
  background: rgba(78, 205, 138, 0.1);
}

.recent-tx-icon.expense {
  background: rgba(255, 88, 88, 0.1);
}

.recent-tx-info {
  flex: 1;
}

.recent-tx-desc {
  font-weight: 700;
  margin-bottom: 3px;
  color: white;
  font-size: 14px;
}

.recent-tx-category {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
}

.recent-tx-amount {
  font-weight: 700;
  font-size: 16px;
}

.recent-tx-amount.income {
  color: var(--good);
}

.recent-tx-amount.expense {
  color: var(--bad);
}

.view-all-link {
  display: inline-block;
  margin-top: 16px;
  color: var(--brand);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
}

.view-all-link:hover {
  text-decoration: underline;
}

/* ========== SUMMARY CARD ========== */

.summary-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 20px;
}

.summary-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: 8px;
}

.summary-label {
  font-size: 13px;
  color: var(--muted);
}

.summary-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--txt);
}

/* ========== HEALTH SCORE ========== */

.health-score {
  text-align: center;
}

.health-label {
  font-weight: 600;
  margin-bottom: 12px;
  color: var(--txt);
}

.health-bar {
  height: 12px;
  background: rgba(255,255,255,0.1);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 8px;
}

.health-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--bad), #ffcf5c, var(--good));
  border-radius: 999px;
  transition: width 0.5s ease;
}

.health-text {
  font-size: 14px;
  color: var(--muted);
}

/* ========== RESPONSIVE ========== */

@media (max-width: 1024px) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .kpi-grid {
    grid-template-columns: 1fr;
  }

  .cards-summary {
    grid-template-columns: 1fr;
  }

  .summary-stats {
    grid-template-columns: 1fr;
  }

  .bar-chart {
    gap: 8px;
  }

  .bar {
    max-width: 30px;
  }

  .bar-value {
    font-size: 9px;
  }
}

@media (max-width: 480px) {
  .kpi-card {
    padding: 16px;
  }

  .kpi-icon {
    width: 50px;
    height: 50px;
    font-size: 24px;
  }

  .kpi-value {
    font-size: 20px;
  }

  .recent-tx {
    padding: 10px;
  }

  .income-item {
    padding: 10px;
  }
}/* ========== DASHBOARD ========== */

.month-selector {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 220px;
}

.month-selector label {
  margin: 0;
  font-size: 12px;
  opacity: 0.75;
}

.month-selector input[type="month"] {
  width: 100%;
}

/* Hide month input spinners */
input[type="month"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  border-radius: 4px;
  margin-right: 2px;
  opacity: 0.6;
  filter: invert(1);
}

input[type="month"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}

/* ========== DASHBOARD GRID ========== */

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 20px;
  margin-top: 24px;
}

/* Large screens - better dashboard layout */
@media (min-width: 1200px) {
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 24px;
  }
}

@media (min-width: 1600px) {
  .dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.card-header h2 {
  margin: 0;
  font-size: 18px;
}

/* ========== BAR CHART ========== */

.chart-card {
  grid-column: 1 / -1;
}

.chart-container {
  padding: 20px 0;
}

.bar-chart {
  display: flex;
  align-items: flex-end;
  justify-content: space-around;
  gap: 16px;
  height: 200px;
  margin-bottom: 16px;
}

.bar-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  height: 100%;
}

.bar-label {
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
}

.bars {
  display: flex;
  gap: 6px;
  align-items: flex-end;
  height: 100%;
  width: 100%;
  justify-content: center;
}

.bar-wrapper {
  flex: 1;
  display: flex;
  align-items: flex-end;
  height: 100%;
  max-width: 40px;
}

.bar {
  width: 100%;
  min-height: 4px;
  border-radius: 6px 6px 0 0;
  position: relative;
  transition: all 0.3s;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 4px;
}

.bar:hover {
  opacity: 0.8;
  transform: translateY(-2px);
}

.bar.income {
  background: linear-gradient(180deg, #27e0a3, #1fb37f);
}

.bar.expense {
  background: linear-gradient(180deg, #ff5c72, #e03f54);
}

.bar-value {
  font-size: 10px;
  font-weight: 700;
  color: white;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  white-space: nowrap;
}

.chart-legend {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 16px;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--muted);
}

.legend-dot {
  width: 12px;
  height: 12px;
  border-radius: 3px;
}

.legend-dot.income {
  background: #27e0a3;
}

.legend-dot.expense {
  background: #ff5c72;
}

/* ========== CATEGORY BARS ========== */

.categories-chart {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.category-bar {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.category-bar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.category-bar-name {
  font-weight: 600;
  font-size: 14px;
}

.category-bar-value {
  font-weight: 700;
  font-size: 15px;
}

.progress-bar {
  height: 10px;
  background: rgba(255,255,255,0.08);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.04);
}

.progress-bar.mini {
  height: 5px;
}

.progress-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.5s ease;
  box-shadow: 0 0 8px rgba(0,0,0,0.3);
}

/* ========== CARDS SUMMARY ========== */

.cards-summary {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mini-card {
  padding: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 12px;
}

.mini-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.mini-card-name {
  font-weight: 600;
  font-size: 14px;
}

.mini-card-brand {
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.mini-card-limit {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.mini-card-value {
  font-size: 18px;
  font-weight: 800;
}

/* ========== INCOME LIST ========== */

.income-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.income-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: rgba(78, 205, 138, 0.06);
  border: 1px solid rgba(78, 205, 138, 0.2);
  border-radius: 10px;
}

.income-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  background: rgba(78, 205, 138, 0.15);
  border-radius: 10px;
  flex-shrink: 0;
}

.income-info {
  flex: 1;
}

.income-name {
  font-weight: 600;
  margin-bottom: 2px;
}

.income-value {
  font-size: 16px;
  font-weight: 800;
  color: var(--good);
}

/* ========== RECENT TRANSACTIONS ========== */

.recent-transactions {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.recent-tx {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  transition: all 0.2s;
}

.recent-tx:hover {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke2);
  transform: translateY(-2px);
}

.recent-tx-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  border-radius: 10px;
  flex-shrink: 0;
}

.recent-tx-icon.income {
  background: rgba(78, 205, 138, 0.15);
}

.recent-tx-icon.expense {
  background: rgba(255, 88, 88, 0.15);
}

.recent-tx-info {
  flex: 1;
  min-width: 0;
}

.recent-tx-desc {
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.recent-tx-amount {
  font-size: 16px;
  font-weight: 800;
  white-space: nowrap;
}

.recent-tx-amount.income {
  color: var(--good);
}

.recent-tx-amount.expense {
  color: var(--danger);
}

.view-all-link {
  display: block;
  text-align: center;
  margin-top: 12px;
  color: var(--brand);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
}

.view-all-link:hover {
  color: var(--brand2);
}

/* ========== SUMMARY CARD ========== */

.summary-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 20px;
}

.summary-item {
  text-align: center;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 12px;
}

.summary-label {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 8px;
}

.summary-value {
  font-size: 32px;
  font-weight: 800;
  color: var(--brand);
}

/* ========== HEALTH SCORE ========== */

.health-score {
  text-align: center;
}

.health-label {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 12px;
  color: var(--muted);
}

.health-bar {
  height: 12px;
  background: rgba(255,255,255,0.08);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 12px;
}

.health-fill {
  height: 100%;
  background: linear-gradient(90deg, #ff5c72, #ffcf5c, #27e0a3);
  border-radius: 999px;
  transition: width 0.5s ease;
}

.health-text {
  font-size: 14px;
  font-weight: 600;
  color: var(--txt);
}

/* ========== RESPONSIVE ========== */

@media (max-width: 1200px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
  
  .chart-card {
    grid-column: 1;
  }
}

@media (max-width: 768px) {
  .kpi-grid {
    grid-template-columns: 1fr;
  }

  .bar-chart {
    height: 180px;
    gap: 8px;
  }

  .bar-value {
    font-size: 8px;
  }

  .summary-stats {
    grid-template-columns: 1fr;
  }
}

/* ========== INVESTIMENTOS ========== */

.inv-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 24px;
  margin-bottom: 32px;
}

@media (min-width: 1200px) {
  .inv-stats {
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .inv-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}

.inv-stat-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding: 28px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  backdrop-filter: blur(12px);
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 1px rgba(255,255,255,0.1) inset;
}

.inv-stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  transition: left 0.6s ease;
}

.inv-stat-card:hover::before {
  left: 100%;
}

.inv-stat-card:hover {
  transform: translateY(-8px) translateX(2px);
  box-shadow: 0 20px 52px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.24);
  background: linear-gradient(135deg, rgba(255,255,255,0.09), rgba(255,255,255,0.03));
}

.inv-stat-card.primary {
  background: linear-gradient(135deg, rgba(120,160,255,0.15), rgba(120,160,255,0.04));
  border-color: rgba(120,160,255,0.4);
}

.inv-stat-card.primary:hover {
  box-shadow: 0 20px 52px rgba(120,160,255,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}

.inv-stat-card.success {
  background: linear-gradient(135deg, rgba(78,205,138,0.15), rgba(78,205,138,0.04));
  border-color: rgba(78,205,138,0.4);
}

.inv-stat-card.success:hover {
  box-shadow: 0 20px 52px rgba(78,205,138,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}

.inv-stat-card.gain {
  background: linear-gradient(135deg, rgba(78,205,138,0.15), rgba(78,205,138,0.04));
  border-color: rgba(78,205,138,0.4);
}

.inv-stat-card.gain:hover {
  box-shadow: 0 20px 52px rgba(78,205,138,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}

.inv-stat-card.loss {
  background: linear-gradient(135deg, rgba(255,88,88,0.15), rgba(255,88,88,0.04));
  border-color: rgba(255,88,88,0.4);
}

.inv-stat-card.loss:hover {
  box-shadow: 0 20px 52px rgba(255,88,88,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}

.inv-stat-card.info {
  background: linear-gradient(135deg, rgba(138,92,255,0.15), rgba(138,92,255,0.04));
  border-color: rgba(138,92,255,0.4);
}

.inv-stat-card.info:hover {
  box-shadow: 0 20px 52px rgba(138,92,255,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}

.inv-stat-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  background: rgba(255,255,255,0.08);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  flex-shrink: 0;
}

.inv-stat-content {
  flex: 1;
  width: 100%;
}

.inv-stat-label {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  margin-bottom: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.inv-stat-value {
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 6px;
  line-height: 1.1;
  word-break: break-word;
  letter-spacing: -0.02em;
  position: relative;
  z-index: 1;
}

.inv-stat-change {
  font-size: 13px;
  font-weight: 700;
}

.inv-stat-change.positive {
  color: var(--good);
}

.inv-stat-change.negative {
  color: var(--danger);
}

.inv-stat-meta {
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
}

/* ========== PORTFOLIO DISTRIBUTION ========== */

.portfolio-distribution {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 0;
}

.portfolio-item {
  padding: 20px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.008));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 13px;
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  backdrop-filter: blur(8px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.portfolio-item:hover {
  background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.02));
  border-color: rgba(255,255,255,0.18);
  transform: translateX(8px);
  box-shadow: 0 12px 28px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.1);
}

.portfolio-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  gap: 12px;
}

.portfolio-type {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1;
  min-width: 0;
}

.portfolio-icon {
  font-size: 26px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  border-radius: 11px;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,0.06);
}

.portfolio-name {
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 3px;
  color: rgba(255,255,255,0.95);
}

.portfolio-value {
  text-align: right;
  flex-shrink: 0;
}

.portfolio-amount {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 2px;
  color: rgba(255,255,255,0.95);
}

/* ========== INVESTMENTS LIST ========== */

.investments-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 24px;
  margin-top: 28px;
}

/* Large screens - better investment cards layout */
@media (min-width: 1200px) {
  .investments-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
}

@media (min-width: 1600px) {
  .investments-list {
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
  }
}

/* Tablet */
@media (max-width: 1024px) {
  .investments-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .investments-list {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

.investment-card {
  background: linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.005));
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 15px;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  min-height: 260px;
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(8px);
  position: relative;
}

.investment-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
}

.investment-card:hover {
  transform: translateY(-10px) scale(1.01);
  box-shadow: 0 24px 48px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.18);
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
}

.inv-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 24px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.015);
  gap: 12px;
}

.inv-card-left {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  flex: 1;
  min-width: 0;
}

.inv-card-icon {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  border-radius: 12px;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  border: 1px solid rgba(255,255,255,0.08);
}

.inv-card-name {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
  color: var(--text);
  line-height: 1.3;
}

.inv-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.inv-card-actions {
  display: flex;
  gap: 6px;
}

.inv-card-body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.inv-card-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 14px;
  margin-bottom: 0;
}

.inv-card-stat {
  text-align: center;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 11px;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.inv-card-stat:hover {
  background: rgba(255,255,255,0.08);
  transform: translateY(-3px) scale(1.02);
  border-color: rgba(255,255,255,0.16);
  box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

.inv-card-stat-value {
  font-size: 16px;
  font-weight: 700;
  margin-top: 4px;
  line-height: 1.2;
}

.inv-card-stat-value.gain {
  color: var(--good);
}

.inv-card-stat-value.loss {
  color: var(--danger);
}

.inv-card-stat-value .small {
  font-size: 12px;
  font-weight: 600;
  opacity: 0.8;
}

.inv-card-footer {
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: auto;
}

.inv-notes {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
  border: 1px solid var(--stroke);
}

/* ========== RISK ANALYSIS ========== */

.risk-analysis {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 0;
}

.risk-item {
  padding: 20px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.008));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 13px;
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  backdrop-filter: blur(8px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.risk-item:hover {
  background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.02));
  border-color: rgba(255,255,255,0.18);
  box-shadow: 0 12px 28px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.1);
  transform: translateY(-2px);
}

.risk-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.risk-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 15px;
}

.risk-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.risk-value {
  font-size: 18px;
  font-weight: 800;
}

/* ========== INVESTMENT CARDS RESPONSIVE ========== */

@media (max-width: 768px) {
  .inv-card-header {
    padding: 16px;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  
  .inv-card-left {
    width: 100%;
  }
  
  .inv-card-actions {
    width: 100%;
    justify-content: flex-end;
  }
  
  .inv-card-body {
    padding: 16px;
  }
  
  .inv-card-stats {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  
  .inv-card-stat {
    padding: 12px;
  }
}

/* ========== FORM TEXTAREA ========== */

textarea {
  width: 100%;
  background: rgba(0,0,0,0.25);
  color: var(--txt);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 12px;
  padding: 10px 12px;
  outline: none;
  transition: .15s;
  font-family: inherit;
  resize: vertical;
  min-height: 80px;
}

textarea:focus {
  border-color: rgba(120,160,255,0.45);
  box-shadow: 0 0 0 4px rgba(120,160,255,0.12);
}

/* ========== RESPONSIVE ========== */

@media (max-width: 768px) {
  .inv-stats {
    grid-template-columns: 1fr;
  }

  .inv-card-header {
    flex-direction: column;
    gap: 16px;
  }

  .inv-card-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .inv-card-stats {
    grid-template-columns: 1fr 1fr;
  }

  .portfolio-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .portfolio-value {
    text-align: left;
  }
}

@media (max-width: 480px) {
  .inv-card-stats {
    grid-template-columns: 1fr;
  }
}

/* ========== LANÇAMENTOS ========== */

.tx-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  margin: 24px 0;
}

.tx-stat-card {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 24px;
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}

.tx-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.tx-stat-card.income {
  background: linear-gradient(135deg, rgba(39,205,138,0.1), rgba(39,205,138,0.02));
  border-color: rgba(39,205,138,0.3);
}

.tx-stat-card.expense {
  background: linear-gradient(135deg, rgba(255,88,88,0.1), rgba(255,88,88,0.02));
  border-color: rgba(255,88,88,0.3);
}

.tx-stat-card.balance.positive {
  background: linear-gradient(135deg, rgba(39,205,138,0.1), rgba(39,205,138,0.02));
  border-color: rgba(39,205,138,0.3);
}

.tx-stat-card.balance.negative {
  background: linear-gradient(135deg, rgba(255,88,88,0.1), rgba(255,88,88,0.02));
  border-color: rgba(255,88,88,0.3);
}

.tx-stat-card.info {
  background: linear-gradient(135deg, rgba(138,92,255,0.1), rgba(138,92,255,0.02));
  border-color: rgba(138,92,255,0.3);
}

.tx-stat-icon {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  background: rgba(255,255,255,0.06);
  border-radius: 16px;
  border: 1px solid var(--stroke);
  flex-shrink: 0;
}

.tx-stat-content {
  flex: 1;
}

.tx-stat-label {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 6px;
  font-weight: 500;
}

.tx-stat-value {
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 4px;
  line-height: 1;
}

.tx-stat-change {
  font-size: 13px;
  font-weight: 700;
}

.tx-stat-change.positive {
  color: var(--good);
}

.tx-stat-change.negative {
  color: var(--danger);
}

.tx-stat-meta {
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
}

.tx-grid {
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 24px;
  margin-top: 24px;
}

.tx-form-section {
  position: sticky;
  top: 20px;
  height: fit-content;
}

.add-transaction-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  background: linear-gradient(135deg, rgba(78,161,255,0.1), rgba(78,161,255,0.02));
  border: 2px dashed rgba(78,161,255,0.3);
  border-radius: var(--radius);
  color: var(--brand);
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  margin-bottom: 24px;
}

.add-transaction-btn:hover {
  background: linear-gradient(135deg, rgba(78,161,255,0.15), rgba(78,161,255,0.05));
  border-color: rgba(78,161,255,0.5);
  transform: translateY(-1px);
}

.add-icon {
  font-size: 24px;
  font-weight: bold;
}

.quick-categories {
  margin-top: 20px;
}

.quick-category-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.quick-category-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s;
  text-align: left;
}

.quick-category-btn:hover {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke2);
  transform: translateY(-1px);
}

.quick-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-size: 16px;
  flex-shrink: 0;
}

.transactions-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 32px;
}

.transaction-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 16px;
  transition: all 0.2s;
}

.transaction-card:hover {
  background: rgba(255,255,255,0.05);
  border-color: var(--stroke2);
  transform: translateY(-1px);
}

.tx-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8px;
}

.tx-card-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

.tx-card-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  font-size: 20px;
  flex-shrink: 0;
}

.tx-card-category {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 4px;
}

.tx-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.tx-card-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.tx-card-amount {
  font-size: 18px;
  font-weight: 800;
  min-width: 100px;
  text-align: right;
}

.tx-card-amount.income {
  color: var(--good);
}

.tx-card-amount.expense {
  color: var(--danger);
}

.tx-card-description {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
  border: 1px solid var(--stroke);
  margin-top: 12px;
}

.category-breakdown {
  border-top: 1px solid var(--stroke);
  padding-top: 24px;
}

.category-breakdown h3 {
  margin: 0 0 16px 0;
  font-size: 18px;
  font-weight: 700;
}

.category-item {
  padding: 12px 0;
  border-bottom: 1px solid var(--stroke);
}

.category-item:last-child {
  border-bottom: none;
}

.category-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.category-info {
  display: flex;
  align-items: center;
  gap: 12px;
}

.category-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 18px;
  flex-shrink: 0;
}

.category-name {
  font-weight: 600;
  margin-bottom: 2px;
}

.category-amounts {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.category-net {
  font-size: 16px;
  font-weight: 800;
}

.category-net.positive {
  color: var(--good);
}

.category-net.negative {
  color: var(--danger);
}

/* ========== TYPE SELECTOR ========== */

.type-selector {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 8px;
}

.type-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: rgba(255,255,255,0.03);
  border: 2px solid var(--stroke);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}

.type-option:hover {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke2);
}

.type-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.type-option input[type="radio"]:checked + .type-icon {
  background: var(--brand);
  color: white;
  border-color: var(--brand);
}

.type-option:has(input[type="radio"]:checked) {
  background: rgba(78,161,255,0.1);
  border-color: var(--brand);
}

.type-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  background: rgba(255,255,255,0.06);
  border: 2px solid var(--stroke);
  border-radius: 12px;
  transition: all 0.2s;
  flex-shrink: 0;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 1024px) {
  .tx-grid {
    grid-template-columns: 1fr;
  }

  .tx-form-section {
    position: static;
    order: 2;
  }

  .tx-list-section {
    order: 1;
  }
}

@media (max-width: 768px) {
  .tx-stats {
    grid-template-columns: 1fr;
  }

  .tx-stat-card {
    padding: 20px;
  }

  .tx-stat-icon {
    width: 56px;
    height: 56px;
    font-size: 28px;
  }

  .tx-stat-value {
    font-size: 24px;
  }

  .tx-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .tx-card-actions {
    width: 100%;
    justify-content: space-between;
  }

  .category-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .category-amounts {
    text-align: left;
    width: 100%;
  }

  .type-selector {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .quick-category-grid {
    grid-template-columns: 1fr;
  }

  .tx-card-amount {
    font-size: 16px;
    min-width: auto;
  }
}

/* ========== Goals Page Styles ========== */
.goals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
  margin-top: 16px;
}

/* Large screens - better goals layout */
@media (min-width: 1200px) {
  .goals-grid {
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
    gap: 14px;
  }
}

@media (min-width: 1600px) {
  .goals-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
  }
}

.goal-card-modern {
  transition: all 0.3s ease;
  animation: fadeIn 0.4s ease-out;
}

.goal-card-modern:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
  background: rgba(255,255,255,0.06) !important;
}

.goal-icon-modern {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  flex-shrink: 0;
}

.contribute-btn-modern {
  display: flex;
  align-items: center;
  padding: 12px 20px;
  border-radius: 10px;
  font-weight: 800;
  font-size: 14px;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.contribute-btn-modern:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(78,161,255,0.4);
}

.goal-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 280px;
  animation: fadeIn 0.4s ease-out;
}

.goal-card::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.03), transparent);
  transform: rotate(45deg);
  transition: all 0.5s ease;
  opacity: 0;
}

.goal-card:hover::after {
  opacity: 1;
}

.goal-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 2;
}

.goal-badge.urgent {
  background: linear-gradient(135deg, var(--warn), #ffb84d);
  color: #000;
  box-shadow: 0 2px 8px rgba(255,207,92,0.4);
}

.goal-badge.overdue {
  background: linear-gradient(135deg, var(--danger), #ff3d5c);
  color: white;
  box-shadow: 0 2px 8px rgba(255,92,114,0.4);
  animation: pulse 2s infinite;
}

.goal-badge.soon {
  background: linear-gradient(135deg, var(--brand), #5aa1ff);
  color: white;
  box-shadow: 0 2px 8px rgba(78,161,255,0.4);
}

.goal-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 25px 60px rgba(0,0,0,0.5);
  border-color: var(--border2);
}

.goal-card.completed {
  border-color: var(--ok);
  background: linear-gradient(135deg, rgba(39,224,163,0.1), var(--panel));
}

.goal-card.completed::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--ok), var(--brand));
}

.goal-header {
  display: flex;
  justify-content: space-between;
  align-items: ce20px;
}

.goal-icon {
  font-size: 40px;
  opacity: 0.9;
  line-height: 1;
}

.goal-actions {
  display: flex;
  gap: 8px;
}

.icon-btn {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  padding: 4px;
  border-radius: 6px;
  transition: all 0.2s ease;
  font-size: 16px;
}

.icon-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--text);
}

.goal-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.goal-content h3 {
  margin: 0 0 16px 0;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.3;
}

.goal-amounts {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 20px;
}

.current-amount {
  font-size: 28px;
  font-weight: 700;
  color: var(--brand);
  line-height: 1;
}

.target-amount {
  font-size: 14px;
  color: var(--muted);
}

.progress-bar {
  width: 100%;
  height: 10px;
  background: var(--panel2);
  border-radius: 5px;
  overflow: hidden;
  margin-bottom: 12px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.2);
}

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  border-radius: 5px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.progress-shimmer {
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2s infinite;
}

.progress-fill.completed {
  background: linear-gradient(90deg, var(--ok), #1bc98e);
}

.goal-card.completed .progress-fill {
  background: linear-gradient(90deg, var(--ok), var(--brand));
}

.goal-meta {
  display: flex;
  align-items: center;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 12px;
  gap: 12px;
}

.progress-text {
  font-weight: 600;
  color: var(--text);
}

.remaining-text {
  color: var(--warn);
  font-weight: 500;
}

.deadline-info {
  display: flex;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,0.06);
  margin-bottom: 16px;
  text-align: center;
  font-weight: 500;
}

.deadline-info.urgent {
  background: rgba(255,207,92,0.1);
  color: var(--warn);
}

.deadline-info.overdue {
  background: rgba(255,92,114,0.1);
  color: var(--danger);
}

.celebration {
  text-align: center;
  font-size: 16px;
  color: var(--ok);
  font-weight: 700;
  margin: 16px 0;
  padding: 12px;
  background: rgba(39,224,163,0.1);
  border-radius: 8px;
}

.form-section {
  margin-bottom: 24px;
}

.form-field-full {
  grid-column: 1 / -1;
}

.category-selector {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.category-option {
  background: var(--panel2);
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 16px 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.category-option::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.category-option:hover {
  border-color: var(--border2);
  background: var(--panel);
  transform: translateY(-2px);
}

.category-option.selected {
  border-color: var(--brand);
  background: linear-gradient(135deg, rgba(78,161,255,0.15), rgba(138,92,255,0.1));
  box-shadow: 0 4px 12px rgba(78,161,255,0.3);
}

.category-option.selected::before {
  opacity: 1;
}

.category-icon {
  font-size: 28px;
  line-height: 1;
}

.category-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
}

.goal-footer {
  margin-top: auto;
  padding-top: 16px;
  text-align: center;
}

.contribute-btn {
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  transition: all 0.3s ease;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.contribute-btn.primary-gradient {
  background: linear-gradient(135deg, var(--brand), var(--brand2));
}

.contribute-btn.primary-gradient::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s ease;
}

.contribute-btn.primary-gradient:hover::before {
  left: 100%;
}

.contribute-btn.primary-gradient:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(78,161,255,0.4);
  background: linear-gradient(135deg, #5aaeff, #9a6cff);
}

.contribute-btn.primary-gradient:active {
  transform: translateY(0);
}

.contribute-btn.completed {
  background: linear-gradient(135deg, var(--ok), #1bc98e);
  cursor: default;
  opacity: 0.8;
}

.btn-icon {
  font-size: 16px;
  line-height: 1;
}

.empty-state {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--muted);
  padding: 60px 20px;
  font-style: italic;
  font-size: 15px;
  background: var(--panel2);
  border-radius: var(--r);
  border: 1px dashed var(--border);
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}

.form-section {
  margin-bottom: 24px;
}

.form-field-full {
  grid-column: 1 / -1;
}

.category-selector {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.category-option {
  background: var(--panel2);
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 16px 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.category-option::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.category-option:hover {
  border-color: var(--border2);
  background: var(--panel);
  transform: translateY(-2px);
}

.category-option.selected {
  border-color: var(--brand);
  background: linear-gradient(135deg, rgba(78,161,255,0.15), rgba(138,92,255,0.1));
  box-shadow: 0 4px 12px rgba(78,161,255,0.3);
}

.category-option.selected::before {
  opacity: 1;
}

.category-icon {
  font-size: 28px;
  line-height: 1;
}

.category-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
}

.form-section {
  margin-bottom: 24px;
}

.form-field-full {
  grid-column: 1 / -1;
}

.category-selector {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.category-option {
  background: var(--panel2);
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 16px 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.category-option::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.category-option:hover {
  border-color: var(--border2);
  background: var(--panel);
  transform: translateY(-2px);
}

.category-option.selected {
  border-color: var(--brand);
  background: linear-gradient(135deg, rgba(78,161,255,0.15), rgba(138,92,255,0.1));
  box-shadow: 0 4px 12px rgba(78,161,255,0.3);
}

.category-option.selected::before {
  opacity: 1;
}

.category-icon {
  font-size: 28px;
  line-height: 1;
}

.category-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
}

.form-grid div {
  display: flex;
  flex-direction: column;
}

.form-grid label {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 6px;
  color: var(--text);
}

.form-grid input {
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--panel2);
  color: var(--text);
  font-size: 14px;
}

.form-grid input:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 2px rgba(78,161,255,0.2);
}

.form-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
}

@media (max-width: 768px) {
  .goals-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .goal-card {
    padding: 24px;
    min-height: auto;
  }
  
  .goal-amounts {
    margin-bottom: 16px;
  }
  
  .current-amount {
    font-size: 24px;
  }

  .goal-amounts {
    flex-direction: column;
    gap: 4px;
  }

  .goal-meta {
    flex-direction: column;
    gap: 4px;
  }

  .form-grid {
    grid-template-columns: 1fr;
  }
}

/* Counter Styles */
.counter-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  padding: 2rem;
}

.counter-display {
  text-align: center;
  margin-bottom: 2rem;
}

.counter-value {
  font-size: 5rem;
  font-weight: bold;
  color: var(--brand);
  transition: transform 0.3s ease;
}

.counter-value.bounce {
  animation: bounce 0.3s ease;
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-10px);
  }
  60% {
    transform: translateY(-5px);
  }
}

.counter-label {
  font-size: 1.2rem;
  color: var(--muted);
  margin-top: 0.5rem;
}

.counter-controls, .counter-features {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}

.btn {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: var(--r);
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
}

.btn:hover {
  background: var(--panel2);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.btn-primary {
  background: var(--brand);
  color: white;
}

.btn-secondary {
  background: var(--muted);
}

.btn-danger {
  background: var(--danger);
  color: white;
}

.btn-info {
  background: var(--brand2);
  color: white;
}

.btn-warning {
  background: var(--warn);
  color: var(--bg);
}

.btn-success {
  background: var(--ok);
  color: white;
}

.counter-history {
  width: 100%;
  max-width: 600px;
  background: var(--panel);
  border-radius: var(--r);
  padding: 1.5rem;
  border: 1px solid var(--border);
}

.counter-history h3 {
  margin-top: 0;
  color: var(--text);
}

.counter-history ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.counter-history li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
}

.counter-history li:last-child {
  border-bottom: none;
}

/* Improved main.js styles */
.fade-in {
  animation: fadeIn 0.3s ease-out;
}

.loading {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  color: var(--text);
  font-size: 1.2rem;
}

.error-screen {
  padding: 2rem;
  text-align: center;
  color: var(--text);
  background: var(--bg);
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.error-screen h2 {
  color: var(--danger);
  margin-bottom: 1rem;
}

.error-screen pre {
  background: var(--panel);
  padding: 1rem;
  border-radius: var(--r);
  border: 1px solid var(--border);
  white-space: pre-wrap;
  max-width: 600px;
  overflow-x: auto;
  margin-bottom: 1rem;
}

.error-screen button {
  background: var(--brand);
  color: var(--text);
  border: none;
  padding: 0.5rem 1rem;
  border-radius: var(--r2);
  cursor: pointer;
  transition: background 0.2s;
}

.error-screen button:hover {
  background: var(--brand2);
}

.sidebar-footer {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
}

.topbar-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
}

#globalSearch {
  background: var(--panel);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 0.5rem 1rem;
  border-radius: var(--r2);
  outline: none;
  transition: border-color 0.2s;
}

#globalSearch:focus {
  border-color: var(--brand);
}

#globalSearch::placeholder {
  color: var(--muted);
}

/* ========== MODERN CONFIG CARDS ========== */

.config-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.config-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  border-color: var(--stroke2);
}

.config-card-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px;
  border-bottom: 1px solid var(--stroke);
  background: linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
}

.config-card-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border-radius: 12px;
  color: white;
  flex-shrink: 0;
}

.config-card-header h2 {
  margin: 0 0 4px;
  font-size: 20px;
  font-weight: 700;
}

.config-card-subtitle {
  margin: 0;
  font-size: 14px;
  color: var(--muted);
}

.config-card-content {
  padding: 24px;
}

/* ========== USER PROFILE ========== */

.user-profile {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 24px;
  padding: 20px;
  background: rgba(255,255,255,0.02);
  border-radius: 12px;
  border: 1px solid var(--stroke);
}

.user-avatar-large {
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border-radius: 50%;
  color: white;
  text-shadow: 0 2px 4px rgba(0,0,0,0.2);
  flex-shrink: 0;
}

.user-details {
  flex: 1;
}

.user-name {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 4px;
}

.user-status {
  font-size: 14px;
  color: var(--muted);
}

/* ========== SETTINGS ========== */

.setting-group {
  margin-bottom: 24px;
}

.setting-group:last-child {
  margin-bottom: 0;
}

.setting-label {
  display: block;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--text);
}

.setting-description {
  font-size: 14px;
  color: var(--muted);
  margin: 4px 0 0;
}

.setting-select {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  color: var(--text);
  font-size: 16px;
  transition: all 0.2s;
}

.setting-select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(78,161,255,0.1);
}

/* ========== THEME OPTIONS ========== */

.theme-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.theme-option-card {
  position: relative;
  display: flex;
  align-items: center;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  border: 2px solid var(--stroke);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s;
}

.theme-option-card:hover {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke2);
  transform: translateY(-1px);
}

.theme-option-card.active {
  background: rgba(78,161,255,0.1);
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(78,161,255,0.2);
}

.theme-option-card input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.theme-option-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.theme-option-icon {
  font-size: 24px;
}

.theme-option-name {
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}

/* ========== TOGGLE SWITCH ========== */

.setting-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.setting-toggle-info {
  flex: 1;
}

.toggle {
  position: relative;
  display: inline-block;
  width: 52px;
  height: 28px;
  flex-shrink: 0;
}

.toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255,255,255,0.15);
  border: 1px solid var(--stroke);
  transition: 0.3s;
  border-radius: 28px;
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 20px;
  width: 20px;
  left: 4px;
  bottom: 3px;
  background: white;
  transition: 0.3s;
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.toggle input:checked + .toggle-slider {
  background: var(--brand);
  border-color: var(--brand);
}

.toggle input:checked + .toggle-slider:before {
  transform: translateX(24px);
}

/* ========== DATA OVERVIEW ========== */

.data-overview {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}

.data-metric {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--stroke);
  border-radius: 12px;
}

.data-metric-icon {
  font-size: 24px;
  flex-shrink: 0;
}

.data-metric-content {
  flex: 1;
}

.data-metric-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 2px;
}

.data-metric-label {
  font-size: 14px;
  color: var(--muted);
}

.backup-section {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--stroke);
}

/* ========== STATS GRID ========== */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 16px;
}

.stat-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  transition: all 0.2s;
}

.stat-item:hover {
  background: rgba(255,255,255,0.06);
  transform: translateY(-1px);
}

.stat-item-icon {
  font-size: 20px;
  flex-shrink: 0;
}

.stat-item-content {
  flex: 1;
}

.stat-item-value {
  font-size: 24px;
  font-weight: 800;
  color: var(--brand);
  margin-bottom: 2px;
}

.stat-item-label {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ========== DANGER SECTION ========== */

.danger-notice {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  background: rgba(255, 88, 88, 0.08);
  border: 1px solid rgba(255, 88, 88, 0.25);
  border-radius: 12px;
  margin-bottom: 24px;
}

.danger-icon {
  font-size: 24px;
  flex-shrink: 0;
}

.danger-notice p {
  margin: 0;
  font-size: 14px;
  color: #ffcdd2;
}

.danger-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ========== ABOUT SECTION ========== */

.about-content {
  text-align: center;
}

.about-logo {
  font-size: 64px;
  margin-bottom: 16px;
}

.about-content h3 {
  margin: 0 0 8px;
  font-size: 28px;
  font-weight: 700;
}

.version-badge {
  display: inline-block;
  padding: 6px 12px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color: white;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 16px;
}

.about-description {
  font-size: 16px;
  line-height: 1.6;
  color: var(--muted);
  margin-bottom: 24px;
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

.about-features {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 24px;
}

.feature-tag {
  padding: 6px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--stroke);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}

.about-links {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.about-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--stroke);
  border-radius: 8px;
  color: var(--text);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.2s;
}

.about-link:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--stroke2);
  transform: translateY(-1px);
}

/* ========== CONFIG ACTIONS ========== */

.config-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 24px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border: 1px solid var(--stroke);
  border-radius: 12px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
  background: rgba(255,255,255,0.04);
  color: var(--text);
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.btn-primary {
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border-color: var(--brand);
  color: white;
}

.btn-primary:hover {
  filter: brightness(1.1);
  box-shadow: 0 0 20px rgba(78,161,255,0.4);
}

.btn-secondary {
  background: rgba(255,255,255,0.06);
  border-color: var(--stroke);
}

.btn-secondary:hover {
  background: rgba(255,255,255,0.12);
  border-color: var(--stroke2);
}

.btn-success {
  background: linear-gradient(135deg, var(--good), #22c55e);
  border-color: var(--good);
  color: white;
}

.btn-success:hover {
  filter: brightness(1.1);
  box-shadow: 0 0 20px rgba(39,224,163,0.4);
}

.btn-warning {
  background: linear-gradient(135deg, var(--warn), #f59e0b);
  border-color: var(--warn);
  color: white;
}

.btn-warning:hover {
  filter: brightness(1.1);
  box-shadow: 0 0 20px rgba(255,207,92,0.4);
}

.btn-danger {
  background: linear-gradient(135deg, var(--danger), #ef4444);
  border-color: var(--danger);
  color: white;
}

.btn-danger:hover {
  filter: brightness(1.1);
  box-shadow: 0 0 20px rgba(255,92,114,0.4);
}

/* ========== RESPONSIVE ========== */

@media (max-width: 768px) {
  .config-grid {
    grid-template-columns: 1fr;
  }

  .data-overview {
    grid-template-columns: 1fr;
  }

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .theme-options {
    grid-template-columns: 1fr;
  }

  .setting-toggle {
    flex-direction: column;
    align-items: flex-start;
  }

  .user-profile {
    flex-direction: column;
    text-align: center;
  }

  .config-actions {
    flex-direction: column;
  }

  .about-links {
    flex-direction: column;
  }
}

@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .config-card-header {
    flex-direction: column;
    text-align: center;
  }

  .config-card-icon {
    align-self: center;
  }
}

/* Fix for config page scrolling */
.config-page {
  height: 100%;
  overflow-y: auto;
  padding-top: 0;
}

.config-page .header {
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 10;
  padding: 20px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--stroke);
}

/* Extra large screens - enhanced typography and spacing */
@media (min-width: 1800px) {
  .goals-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
  }
  
  .cards-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
  }
  
  .config-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
  }
  
  /* Enhanced typography for large screens */
  h1 {
    font-size: 2.5rem;
  }
  
  h2 {
    font-size: 1.8rem;
  }
  
  .content {
    padding: 32px 32px 50px;
  }
}
:root{
  --sidebar-w: 280px;
}

/* base */
html, body { height: 100%; }
body { margin: 0; overflow-x: hidden; }

/* ========== VALIDATION STYLES ========== */

/* Input validation states */
input:invalid:not(:focus):not(:placeholder-shown), 
select:invalid:not(:focus):not(:placeholder-shown) {
  border-color: rgba(255, 92, 114, 0.5);
  background: rgba(255, 92, 114, 0.05);
}

input:valid:not(:placeholder-shown), 
select:valid:not(:placeholder-shown) {
  border-color: rgba(39, 224, 163, 0.3);
}

/* Error messages */
.error-message {
  color: var(--danger);
  font-size: 12px;
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
  animation: fadeIn 0.3s ease-out;
}

.error-message::before {
  content: '⚠️';
}

/* Success messages */
.success-message {
  color: var(--ok);
  font-size: 12px;
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
  animation: fadeIn 0.3s ease-out;
}

.success-message::before {
  content: '✓';
}

/* Field with error */
.field-error input,
.field-error select,
.field-error textarea {
  border-color: var(--danger) !important;
  background: rgba(255, 92, 114, 0.05);
}

/* Field with success */
.field-success input,
.field-success select,
.field-success textarea {
  border-color: var(--ok) !important;
  background: rgba(39, 224, 163, 0.05);
}

/* Input limits hint */
input[maxlength] + .small.muted,
textarea[maxlength] + .small.muted {
  opacity: 0.7;
  transition: opacity 0.3s;
}

input[maxlength]:focus + .small.muted,
textarea[maxlength]:focus + .small.muted {
  opacity: 1;
  color: var(--brand);
}

/* Number input step hint */
input[type="number"][step] + .small.muted {
  opacity: 0.7;
  transition: opacity 0.3s;
}

/* ========== CONFIG PAGE STYLES ========== */

/* Search Bar */
.config-search {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}

.config-search input {
  flex: 1;
  padding: 11px 14px;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(120, 160, 255, 0.3);
  border-radius: 10px;
  color: var(--text);
  font-size: 14px;
  transition: all 0.2s;
}

.config-search input:focus {
  background: rgba(0, 0, 0, 0.35);
  border-color: rgba(120, 160, 255, 0.6);
  box-shadow: 0 0 0 3px rgba(120, 160, 255, 0.1);
  outline: none;
}

.config-search input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

/* Filter Buttons */
.filter-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.filter-btn {
  padding: 8px 14px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
  cursor: pointer;
  transition: all 0.2s;
  font-size: 13px;
  font-weight: 500;
}

.filter-btn:hover {
  background: rgba(78, 161, 255, 0.15);
  border-color: rgba(78, 161, 255, 0.3);
  color: var(--text);
}

.filter-btn.active {
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.25), rgba(138, 92, 255, 0.15));
  border-color: rgba(120, 160, 255, 0.4);
  color: var(--text);
}

/* Category Cards */
.category-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: all 0.2s;
}

.category-card:hover {
  transform: translateY(-2px);
  border-color: rgba(78, 161, 255, 0.3);
  box-shadow: 0 8px 16px rgba(78, 161, 255, 0.1);
}

.category-card-content {
  display: flex;
  gap: 12px;
  flex: 1;
  align-items: center;
}

.category-icon {
  font-size: 32px;
  line-height: 1;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(120, 160, 255, 0.12);
  flex-shrink: 0;
}

.category-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.category-name {
  font-weight: 600;
  font-size: 15px;
  color: var(--text);
}

.category-type {
  font-size: 12px;
  color: var(--muted);
}

.category-type.income {
  color: rgba(39, 224, 163, 0.85);
}

.category-type.expense {
  color: rgba(255, 92, 114, 0.85);
}

.category-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.action-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 16px;
  padding: 0;
}

.action-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  transform: scale(1.05);
}

.action-btn.edit:hover {
  background: rgba(78, 161, 255, 0.15);
  border-color: rgba(78, 161, 255, 0.3);
}

.action-btn.delete:hover {
  background: rgba(255, 92, 114, 0.15);
  border-color: rgba(255, 92, 114, 0.3);
}

/* Toast Notifications */
.toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 400px;
  pointer-events: none;
}

.toast {
  padding: 12px 16px;
  border-radius: 10px;
  background: var(--panel);
  border: 1px solid var(--border);
  backdrop-filter: blur(10px);
  animation: slideInRight 0.3s ease-out;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 500;
  pointer-events: auto;
}

.toast.success {
  border-left: 3px solid #27e0a3;
}

.toast.error {
  border-left: 3px solid #ff5c72;
}

.toast.info {
  border-left: 3px solid #4ea1ff;
}

.toast-icon {
  font-size: 16px;
  flex-shrink: 0;
}

/* Section Header */
.config-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 12px;
}

.config-section-header-info h2 {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 600;
}

.config-section-header-info p {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
}

/* Stats Cards */
.stats-card {
  padding: 16px;
  background: rgba(120, 160, 255, 0.08);
  border: 1px solid rgba(120, 160, 255, 0.15);
  border-radius: 12px;
  transition: all 0.2s;
}

.stats-card.income {
  background: rgba(39, 224, 163, 0.08);
  border-color: rgba(39, 224, 163, 0.15);
}

.stats-card.expense {
  background: rgba(255, 92, 114, 0.08);
  border-color: rgba(255, 92, 114, 0.15);
}

.stats-card:hover {
  transform: translateY(-2px);
  background: rgba(120, 160, 255, 0.12);
  border-color: rgba(120, 160, 255, 0.25);
}

.stats-card.income:hover {
  background: rgba(39, 224, 163, 0.12);
  border-color: rgba(39, 224, 163, 0.25);
}

.stats-card.expense:hover {
  background: rgba(255, 92, 114, 0.12);
  border-color: rgba(255, 92, 114, 0.25);
}

.stats-card-label {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
  font-weight: 500;
}

.stats-card-value {
  font-size: 28px;
  font-weight: 700;
  color: var(--text);
}

/* Mobile Responsiveness */
@media (max-width: 768px) {
  .config-search {
    width: 100%;
  }

  .config-search input {
    width: 100%;
  }

  .action-btn {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }

  .toast-container {
    left: 12px;
    right: 12px;
    max-width: none;
  }
}

.no-results p {
  margin: 0;
  font-size: 13px;
}

/* Keyboard Hints */
.keyboard-hint {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  background: rgba(0, 0, 0, 0.2);
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 8px;
}

/* Mobile Optimization */
@media (max-width: 768px) {
  .category-card {
    padding: 14px;
  }

  .category-icon {
    font-size: 28px;
    width: 44px;
    height: 44px;
  }

  .action-btn {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }

  .toast-container {
    left: 12px;
    right: 12px;
    top: 12px;
    max-width: none;
  }

  .filter-buttons {
    flex-wrap: wrap;
  }

  .config-search {
    flex-direction: column;
  }

  .config-search input {
    min-width: auto;
  }
}

input[type="number"][step]:focus + .small.muted {
  opacity: 1;
  color: var(--brand);
}

/* Alert/Toast animation */
@keyframes slideInDown {
  from {
    opacity: 0;
    transform: translateY(-100%);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideOutUp {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-100%);
  }
}

/* Better alert styling (for future custom alerts) */
.custom-alert {
  position: fixed;
  top: 20px;
  right: 20px;
  max-width: 400px;
  padding: 16px 20px;
  border-radius: var(--r);
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  z-index: 10000;
  animation: slideInDown 0.3s ease-out;
  backdrop-filter: blur(14px);
}

.custom-alert.error {
  border-color: var(--danger);
  background: rgba(255, 92, 114, 0.1);
}

.custom-alert.success {
  border-color: var(--ok);
  background: rgba(39, 224, 163, 0.1);
}

.custom-alert.warning {
  border-color: var(--warn);
  background: rgba(255, 207, 92, 0.1);
}

.custom-alert.info {
  border-color: var(--brand);
  background: rgba(78, 161, 255, 0.1);
}

/* Required field indicator */
label:has(+ input[required])::after,
label:has(+ select[required])::after,
label:has(+ textarea[required])::after {
  content: ' *';
  color: var(--danger);
  font-weight: 600;
}

/* Disabled state improvements */
input:disabled,
select:disabled,
textarea:disabled,
button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  filter: grayscale(0.5);
}

/* Loading state for buttons */
button.loading {
  position: relative;
  color: transparent;
  pointer-events: none;
}

button.loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 16px;
  margin: -8px 0 0 -8px;
  border: 2px solid var(--text);
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Form validation summary */
.form-validation-summary {
  padding: 12px 16px;
  border-radius: var(--r2);
  margin-bottom: 16px;
  display: flex;
  align-items: start;
  gap: 12px;
  animation: fadeIn 0.3s ease-out;
}

.form-validation-summary.error {
  background: rgba(255, 92, 114, 0.1);
  border: 1px solid rgba(255, 92, 114, 0.3);
}

.form-validation-summary.warning {
  background: rgba(255, 207, 92, 0.1);
  border: 1px solid rgba(255, 207, 92, 0.3);
}

.form-validation-summary ul {
  margin: 0;
  padding-left: 20px;
  list-style: none;
}

.form-validation-summary li {
  margin: 4px 0;
  font-size: 13px;
}

.form-validation-summary li::before {
  content: '• ';
  color: var(--danger);
}

/* Tooltip for hints */
.input-hint {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  cursor: help;
}

.input-hint:hover .hint-tooltip {
  opacity: 1;
  visibility: visible;
}

.hint-tooltip {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: 8px;
  padding: 8px 12px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r2);

/* ========== CONFIGURAÇÕES PAGE ========== */

/* Dashboard header styling now in global.css - avoid duplicate definitions */

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.form-group label {
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  margin: 0;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 10px;
  color: var(--text);
  font-size: 14px;
  transition: all 0.15s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  background: rgba(0, 0, 0, 0.35);
  border-color: rgba(120, 160, 255, 0.45);
  box-shadow: 0 0 0 4px rgba(120, 160, 255, 0.12);
  outline: none;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

/* Grid com 2 colunas para formulários */
.cols-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 768px) {
  .cols-2 {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* Modal customizado para config */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
  animation: fadeIn 0.3s ease-out;
}

.modal-overlay.hidden {
  display: none;
}

.modal-overlay .modal {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  max-width: 500px;
  width: 100%;
  max-height: 90vh;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
  animation: slideInUp 0.3s ease-out;
  display: flex;
  flex-direction: column;
}

@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.modal .header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  gap: 16px;
}

.modal .header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}

.modal .close {
  background: none;
  border: none;
  color: var(--text);
  font-size: 24px;
  cursor: pointer;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all 0.2s;
  flex-shrink: 0;
}

.modal .close:hover {
  background: rgba(255, 255, 255, 0.1);
  transform: rotate(90deg);
}

.modal .body {
  padding: 24px;
  flex: 1;
  overflow-y: auto;
}

.modal .footer {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.1);
}

.modal .footer button {
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
}

.modal .footer button.btn {
  padding: 10px 16px;
}

.modal .footer button.ghost {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.2);
}

.modal .footer button.ghost:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.3);
}

.modal .footer button.primary {
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.85), rgba(138, 92, 255, 0.75));
  border-color: rgba(78, 161, 255, 0.4);
  color: #081022;
  font-weight: 600;
}

.modal .footer button.primary:hover {
  background: linear-gradient(135deg, rgba(78, 161, 255, 0.95), rgba(138, 92, 255, 0.85));
  box-shadow: 0 8px 20px rgba(78, 161, 255, 0.3);
}

/* Categorias Grid */
.grid.cols-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 16px;
}

@media (max-width: 1024px) {
  .grid.cols-2 {
    grid-template-columns: 1fr;
  }
}

.grid.cols-2 .card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  transition: all 0.2s;
}

.grid.cols-2 .card:hover {
  transform: translateY(-2px);
  border-color: rgba(78, 161, 255, 0.3);
}

.grid.cols-2 .card > div:first-child {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.grid.cols-2 .card .iconBtn {
  background: none;
  border: none;
  font-size: 18px;
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: all 0.2s;
}

.grid.cols-2 .card .iconBtn:hover {
  background: rgba(255, 255, 255, 0.1);
  transform: scale(1.05);
}

.grid.cols-2 .card .iconBtn.danger {
  color: var(--danger);
}

.grid.cols-2 .card .iconBtn.danger:hover {
  background: rgba(255, 92, 114, 0.15);
}

.iconBtn {
  background: none;
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 6px 8px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 16px;
}

.iconBtn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Panel styles */
.panel {
  background: linear-gradient(135deg, rgba(12,18,28,0.6), rgba(18,25,40,0.4));
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 24px;
  backdrop-filter: blur(14px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  transition: all 0.3s ease;
}
  font-size: 12px;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  pointer-events: none;
  box-shadow: var(--shadow);
  z-index: 1000;
}

/* Character counter */
.char-counter {
  font-size: 11px;
  color: var(--muted);
  text-align: right;
  margin-top: 4px;
  transition: color 0.3s;
}

.char-counter.warning {
  color: var(--warn);
}

.char-counter.danger {
  color: var(--danger);
}

/* Better focus states */
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
button:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* Prevent zoom on mobile inputs */
@media (max-width: 768px) {
  input, select, textarea {
    font-size: 16px;
  }
}

/* ===== AUTH PAGE STYLES ===== */
.auth-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, #0a1428 0%, #0f2d5c 50%, #1a1a3e 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9999;
  overflow: hidden;
}

.auth-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 20% 50%, rgba(78, 161, 255, 0.1) 0%, transparent 50%),
              radial-gradient(circle at 80% 80%, rgba(138, 92, 255, 0.1) 0%, transparent 50%);
  pointer-events: none;
}

.auth-wrapper {
  width: 100%;
  max-width: 440px;
  background: rgba(15, 25, 45, 0.95);
  border: 1px solid rgba(78, 161, 255, 0.2);
  border-radius: 20px;
  padding: 48px 40px;
  box-shadow: 0 25px 80px rgba(0, 0, 0, 0.6),
              inset 0 1px 0 rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(20px);
  animation: fadeIn 0.5s ease-out;
  position: relative;
  z-index: 1;
}

.auth-header {
  text-align: center;
  margin-bottom: 48px;
}

.auth-header h1 {
  font-size: 32px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 8px 0;
  letter-spacing: -0.5px;
}

.auth-header p {
  font-size: 14px;
  color: var(--muted);
  margin: 0;
  font-weight: 500;
}

.auth-form {
  opacity: 1;
  transition: all 0.3s ease;
}

.auth-form.hidden {
  display: none;
}

.auth-form h2 {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 28px 0;
  letter-spacing: -0.3px;
}

.form-group {
  margin-bottom: 24px;
}

.form-group label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: rgba(169, 189, 211, 0.8);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.form-group input {
  width: 100%;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1.5px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  color: var(--text);
  font-size: 15px;
  font-family: inherit;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.form-group input:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}

.form-group input:focus {
  outline: none;
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(78, 161, 255, 0.15),
              inset 0 0 0 1px rgba(78, 161, 255, 0.1);
}

.form-group input::placeholder {
  color: rgba(169, 189, 211, 0.4);
}

.auth-error {
  padding: 14px 16px;
  background: rgba(255, 92, 114, 0.12);
  border: 1px solid rgba(255, 92, 114, 0.3);
  border-radius: 12px;
  color: #ff9db5;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 20px;
  animation: slideInRight 0.3s ease;
}

.btn-block {
  width: 100%;
  margin-top: 8px;
}

.auth-divider {
  text-align: center;
  margin: 28px 0;
  font-size: 12px;
  color: rgba(169, 189, 211, 0.6);
  position: relative;
  font-weight: 500;
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: calc(50% - 24px);
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.1) 100%);
}

.auth-divider::before {
  left: 0;
}

.auth-divider::after {
  right: 0;
}

.auth-footer {
  text-align: center;
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  color: var(--muted);
  font-size: 13px;
  font-weight: 500;
}

.btn.primary {
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand2) 100%);
  color: white;
  border: none;
  padding: 13px 24px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 8px 20px rgba(78, 161, 255, 0.25),
              0 0 0 1px rgba(78, 161, 255, 0.1);
}

.btn.primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(78, 161, 255, 0.35),
              0 0 0 1px rgba(78, 161, 255, 0.15);
}

.btn.primary:active {
  transform: translateY(0);
}

.btn.ghost {
  background: transparent;
  color: var(--brand);
  border: 1.5px solid rgba(78, 161, 255, 0.25);
  padding: 13px 24px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn.ghost:hover {
  background: rgba(78, 161, 255, 0.08);
  border-color: var(--brand);
  color: #6bb3ff;
}

.sidebar-logout-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 20px;
  padding: 4px 8px;
  transition: all 0.3s ease;
  border-radius: 6px;
}

.sidebar-logout-btn:hover {
  color: var(--danger);
  background: rgba(255, 92, 114, 0.1);
  transform: scale(1.1);
}

/* Mobile */
@media (max-width: 480px) {
  .auth-wrapper {
    padding: 36px 24px;
  }

  .auth-header {
    margin-bottom: 36px;
  }

  .auth-header h1 {
    font-size: 28px;
  }

  .form-group {
    margin-bottom: 20px;
  }
}

/* ========== PREMIUM TRANSACTION MODAL ========== */

.txModal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 180ms ease-out;
  padding: 16px;
  overflow-y: auto;
}

.txModal-container {
  background: linear-gradient(135deg, var(--panel) 0%, rgba(12, 18, 28, 0.95) 100%);
  border: 1px solid var(--border2);
  border-radius: 16px;
  width: 100%;
  max-width: min(540px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 25px 70px rgba(0, 0, 0, 0.6), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  animation: fadeIn 200ms ease-out, slideInUp 200ms ease-out;
  position: relative;
}

.txModal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 32px 32px 28px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.txModal-title {
  font-size: 1.5625rem;
  font-weight: 700;
  color: var(--text);
  margin: 0;
  line-height: 1.3;
  letter-spacing: -0.3px;
}

.txModal-subtitle {
  font-size: 0.8750rem;
  color: var(--muted);
  margin: 8px 0 0 0;
  font-weight: 400;
}

.txModal-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-width: 40px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  color: var(--muted);
  cursor: pointer;
  transition: all 150ms ease-out;
  padding: 0;
  flex-shrink: 0;
}

.txModal-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.15);
  transform: scale(1.05);
}

.txModal-close:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;

.txModal-close:active {
  transform: scale(0.95);
}

.txModal-form {
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* ========== MODAL SECTIONS ========== */

.txModal-section {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.txModal-fieldset-title {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--muted);
  letter-spacing: 0.6px;
  margin-bottom: 6px;
}

/* ========== LABELS & REQUIRED ========== */

.txModal-label {
  display: block;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.3;
}

.txModal-required {
  color: var(--danger);
  margin-left: 2px;
  font-weight: 700;
}

.txModal-required-optional {
  font-weight: 400;
  color: var(--muted);
  font-size: 0.8125rem;
  margin-left: 4px;
}

/* ========== SEGMENTED CONTROL (Tipo) ========== */

.txModal-radio {
  display: none;
}

.txModal-segmented {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.txModal-seg-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  color: var(--muted);
  font-weight: 600;
  font-size: 0.9375rem;
  cursor: pointer;
  transition: all 160ms ease-out;
  user-select: none;
  min-height: 46px;
}

.txModal-seg-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--border2);
  color: var(--text);
  transform: translateY(-1px);
}

.txModal-seg-btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.txModal-seg-btn:active {
  transform: scale(0.98);
}

.txModal-seg-icon {
  font-size: 1.35rem;
  display: flex;
  align-items: center;
}

/* Estados para Receita */
#txType-income:checked + .txModal-seg-income {
  background: linear-gradient(135deg, rgba(39, 224, 163, 0.18), rgba(39, 224, 163, 0.08));
  border-color: var(--ok);
  color: var(--ok);
  box-shadow: 0 0 0 2px rgba(39, 224, 163, 0.2), inset 0 1px 2px rgba(39, 224, 163, 0.15);
}

#txType-income:checked + .txModal-seg-income:hover {
  background: linear-gradient(135deg, rgba(39, 224, 163, 0.25), rgba(39, 224, 163, 0.15));
  box-shadow: 0 0 0 2px rgba(39, 224, 163, 0.25), inset 0 1px 2px rgba(39, 224, 163, 0.2);
}

/* Estados para Despesa */
#txType-expense:checked + .txModal-seg-expense {
  background: linear-gradient(135deg, rgba(255, 92, 114, 0.18), rgba(255, 92, 114, 0.08));
  border-color: var(--danger);
  color: var(--danger);
  box-shadow: 0 0 0 2px rgba(255, 92, 114, 0.2), inset 0 1px 2px rgba(255, 92, 114, 0.15);
}

#txType-expense:checked + .txModal-seg-expense:hover {
  background: linear-gradient(135deg, rgba(255, 92, 114, 0.25), rgba(255, 92, 114, 0.15));
  box-shadow: 0 0 0 2px rgba(255, 92, 114, 0.25), inset 0 1px 2px rgba(255, 92, 114, 0.2);
}

/* ========== INPUTS & SELECT ========== */

.txModal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.txModal-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
}

.txModal-input {
  padding: 12px 15px;
  height: 46px;
  background: linear-gradient(135deg, var(--panel2), rgba(12, 18, 28, 0.95));
  border: 1.5px solid var(--border);
  border-radius: 12px;
  color: var(--text);
  font-size: 0.9375rem;
  font-family: inherit;
  font-weight: 400;
  transition: all 160ms ease-out;
  outline: none;
  color-scheme: dark;
}

.txModal-input::placeholder {
  color: var(--muted2);
  font-weight: 400;
}

.txModal-input:hover {
  border-color: var(--border2);
  background: linear-gradient(135deg, rgba(30, 41, 59, 0.95), rgba(15, 20, 30, 0.95));
}

.txModal-input:focus-visible {
  border-color: var(--brand);
  background: linear-gradient(135deg, rgba(20, 30, 45, 0.95), rgba(12, 18, 28, 0.98));
  box-shadow: 0 0 0 3px rgba(78, 161, 255, 0.15), inset 0 0 0 1px rgba(78, 161, 255, 0.25);
}

/* Date picker refinements */
input[type="date"].txModal-input {
  position: relative;
}

input[type="date"].txModal-input::-webkit-calendar-picker-indicator {
  cursor: pointer;
  border-radius: 6px;
  margin-right: 6px;
  opacity: 0.5;
  transition: all 150ms ease-out;
  filter: invert(1);
}

input[type="date"].txModal-input:hover::-webkit-calendar-picker-indicator {
  opacity: 0.8;
}

input[type="date"].txModal-input:focus-visible::-webkit-calendar-picker-indicator {
  opacity: 1;
  filter: invert(0.8) brightness(1.2);
}

/* Resetar :invalid padrão - crucial para evitar borda vermelha automática */
.txModal-input:invalid {
  border-color: var(--border);
  box-shadow: none;
}

.txModal-input:invalid:placeholder-shown {
  border-color: var(--border);
  box-shadow: none;
}

/* Validation states - APENAS com .is-error ou .is-valid */
.txModal-input.is-error {
  border-color: var(--danger);
  background: linear-gradient(135deg, rgba(255, 92, 114, 0.08), rgba(255, 92, 114, 0.04));
}

.txModal-input.is-error:focus-visible {
  box-shadow: 0 0 0 3px rgba(255, 92, 114, 0.15), inset 0 0 0 1px rgba(255, 92, 114, 0.3);
}

.txModal-input.is-valid {
  border-color: var(--ok);
  background: linear-gradient(135deg, rgba(39, 224, 163, 0.08), rgba(39, 224, 163, 0.04));
}

.txModal-input.is-valid:focus-visible {
  box-shadow: 0 0 0 3px rgba(39, 224, 163, 0.15), inset 0 0 0 1px rgba(39, 224, 163, 0.3);
}

.txModal-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: rgba(255, 255, 255, 0.02);
}

/* Error message */
.txModal-error-msg {
  font-size: 0.8125rem;
  color: var(--danger);
  line-height: 1.4;
  margin-top: -2px;
  display: none;
  font-weight: 500;
  letter-spacing: 0.2px;
}

.txModal-field.is-error .txModal-error-msg {
  display: block;
  animation: slideInDown 150ms ease-out;
}

/* ========== CUSTOM SELECT ========== */

.txModal-select-hidden {
  display: none !important;
}

.txModal-select-wrapper {
  position: relative;
  z-index: 100;
}

.txModal-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 46px;
  padding: 12px 15px;
  background: linear-gradient(135deg, var(--panel2), rgba(12, 18, 28, 0.95));
  border: 1.5px solid var(--border);
  border-radius: 12px;
  color: var(--text);
  font-size: 0.9375rem;
  font-family: inherit;
  font-weight: 400;
  cursor: pointer;
  transition: all 160ms ease-out;
  text-align: left;
  gap: 10px;
  outline: none;
}

.txModal-select-trigger:hover {
  border-color: var(--border2);
  background: linear-gradient(135deg, rgba(30, 41, 59, 0.95), rgba(15, 20, 30, 0.95));
}

.txModal-select-trigger:focus-visible {
  border-color: var(--brand);
  background: linear-gradient(135deg, rgba(20, 30, 45, 0.95), rgba(12, 18, 28, 0.98));
  box-shadow: 0 0 0 3px rgba(78, 161, 255, 0.15), inset 0 0 0 1px rgba(78, 161, 255, 0.25);
}

.txModal-select-trigger.is-open {
  border-color: var(--brand);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: 0 0 0 3px rgba(78, 161, 255, 0.1), inset 0 0 0 1px rgba(78, 161, 255, 0.2);
}

.txModal-select-trigger.is-error {
  border-color: var(--danger);
  background: linear-gradient(135deg, rgba(255, 92, 114, 0.08), rgba(255, 92, 114, 0.04));
}

.txModal-select-trigger.is-error:focus-visible {
  box-shadow: 0 0 0 3px rgba(255, 92, 114, 0.15), inset 0 0 0 1px rgba(255, 92, 114, 0.3);
}

.txModal-select-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.txModal-select-trigger.is-empty .txModal-select-label {
  color: var(--muted2);
}

.txModal-select-icon {
  flex-shrink: 0;
  color: var(--muted);
  font-size: 1.1rem;
  transition: transform 160ms ease-out;
  display: flex;
  align-items: center;
}

.txModal-select-trigger.is-open .txModal-select-icon {
  transform: scaleY(-1);
}

.txModal-select-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: linear-gradient(135deg, var(--panel2), rgba(15, 22, 35, 0.95));
  border: 1.5px solid var(--border2);
  border-radius: 12px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  max-height: 260px;
  min-height: 160px;
  overflow-y: auto;
  overflow-x: hidden;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.6), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  z-index: 1003;
  animation: slideInDown 160ms ease-out;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.txModal-select-dropdown::-webkit-scrollbar {
  width: 7px;
}

.txModal-select-dropdown::-webkit-scrollbar-track {
  background: transparent;
}

.txModal-select-dropdown::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: 4px;
}

.txModal-select-dropdown::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.2);
}

.txModal-select-option {
  padding: 14px 15px;
  color: var(--text);
  cursor: pointer;
  user-select: none;
  transition: all 120ms ease-out;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9375rem;
  line-height: 1.4;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  font-family: inherit;
  font-weight: 400;
}

.txModal-select-option:first-child {
  padding-top: 10px;
}

.txModal-select-option:last-child {
  padding-bottom: 10px;
}

.txModal-select-option:hover:not(:disabled) {
  background: rgba(78, 161, 255, 0.12);
  color: var(--text);
  padding-left: 18px;
  transition: all 120ms ease-out;
}

.txModal-select-option:focus-visible {
  background: rgba(78, 161, 255, 0.16);
  outline: none;
}

.txModal-select-option.is-active {
  background: rgba(78, 161, 255, 0.18);
  color: var(--brand);
  font-weight: 500;
  border-left: 3px solid var(--brand);
  padding-left: 12px;
  transition: all 120ms ease-out;
}

.txModal-select-option.is-active:hover {
  background: rgba(78, 161, 255, 0.25);
  padding-left: 15px;
}

.txModal-select-option:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

@keyframes slideInDown {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ========== AÇÕES ========== */

.txModal-actions {
  display: flex;
  gap: 14px;
  margin-top: 12px;
}

.txModal-divider {
  height: 1.5px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: 16px 0 12px 0;
}

.txModal-dangerous {
  display: flex;
}

.txModal-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 18px;
  min-height: 46px;
  font-size: 0.9375rem;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: all 160ms ease-out;
  font-family: inherit;
  user-select: none;
  outline: none;
  flex: 1;
}

.txModal-btn:active {
  transform: scale(0.97);
}

.txModal-btn-primary {
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color: white;
  font-weight: 700;
  box-shadow: 0 10px 30px rgba(78, 161, 255, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.2);
  letter-spacing: 0.3px;
  transition: all 160ms ease-out;
}

.txModal-btn-primary:hover {
  background: linear-gradient(135deg, #62b8ff, #b080ff);
  box-shadow: 0 14px 42px rgba(78, 161, 255, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.25);
  transform: translateY(-2px);
}

.txModal-btn-primary:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 3px;
  box-shadow: 0 10px 30px rgba(78, 161, 255, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.txModal-btn-primary:active {
  transform: scale(0.96);
}

.txModal-btn-secondary {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  border: 1px solid var(--border);
  transition: all 150ms ease-out;
}

.txModal-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: var(--border2);
  transition: all 150ms ease-out;
}

.txModal-btn-secondary:focus {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  transition: all 150ms ease-out;
}

.txModal-btn-secondary:active {
  transform: scale(0.98);
}

.txModal-btn-danger {
  background: transparent;
  color: var(--danger);
  border: 1px solid rgba(255, 92, 114, 0.35);
  font-weight: 400;
  width: 100%;
  flex: none;
  font-size: 0.8125rem;
  padding: 9px 12px;
  min-height: 38px;
  gap: 6px;
  transition: all 150ms ease-out;
  letter-spacing: 0.3px;
}

.txModal-btn-danger:hover {
  background: rgba(255, 92, 114, 0.05);
  border-color: rgba(255, 92, 114, 0.55);
  color: var(--danger);
  transition: all 150ms ease-out;
}

.txModal-btn-danger:focus {
  outline: 2px solid var(--danger);
  outline-offset: 2px;
  transition: all 150ms ease-out;
}

.txModal-btn-danger:active {
  transform: scale(0.96);
  transition: all 100ms ease-out;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 640px) {
  .txModal-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .txModal-container {
    max-height: 95vh;
  }

  .txModal-header {
    padding: 20px 20px 16px;
  }

  .txModal-form {
    padding: 16px 20px;
    gap: 20px;
  }

  .txModal-title {
    font-size: 1.25rem;
  }

  .txModal-actions {
    flex-direction: column;
    gap: 10px;
  }

  .txModal-btn {
    flex: 1;
  }
}
