/* ============================================= */
/*              CSS CLEANED & OPTIMIZED          */
/*              FinanceSolux V31                 */
/* ============================================= */

/* ============================================= */
/*          1. VARIABLES & ROOT                 */
/* ============================================= */

:root {
  /* ===== NEOMORPHIC LIGHT — PREMIUM 2026 ===== */

  /* Superfície neomórfica — cinza-azulado médio para sombras visíveis */
  --bg-primary:    #e3e8f0;          /* base principal — tom médio-claro */
  --bg-secondary:  #e3e8f0;          /* cards = mesma cor que base (efeito extrudido) */
  --bg-tertiary:   #d9dee8;          /* inputs — superfície afundada */
  --bg-surface:    #eaeff5;          /* elementos com leve elevação */

  /* Textos elegantes e legíveis */
  --text-primary:   #1e293b;         /* principal, cinza-escuro elegante */
  --text-secondary: #5a6a80;         /* subtítulos, mais presença */
  --text-muted:     #8896a8;         /* textos menores */
  --text-accent:    #0f72e8;         /* azul moderno para destaques */

  /* Bordas quase imperceptíveis */
  --border-color:   #cdd4e0;
  --border-subtle:  rgba(30, 41, 59, 0.06);

  /* Cores semânticas discretas */
  --success:        #10b981;
  --danger:         #ef4444;
  --warning:        #f59e0b;
  --info:           #3b82f6;

  /* Motion + focus */
  --motion-fast:    0.22s cubic-bezier(.4,0,.2,1);
  --motion-smooth:  0.28s cubic-bezier(.4,0,.2,1);
  --focus-ring:     0 0 0 3px rgba(15, 114, 232, 0.14);

  /* Button intent tokens */
  --btn-confirm-bg:         #1f8a63;
  --btn-confirm-text:       #f5fffb;
  --btn-confirm-bg-hover:   #177452;
  --btn-confirm-bg-active:  #125c42;

  --btn-cancel-bg:          #6f7f98;
  --btn-cancel-text:        #f7fbff;
  --btn-cancel-bg-hover:    #5f708c;
  --btn-cancel-bg-active:   #52617a;

  --btn-danger-bg:          #fee2e2;
  --btn-danger-text:        #dc2626;
  --btn-danger-bg-hover:    #fecaca;
  --btn-danger-bg-active:   #fca5a5;

  /* Legado para compatibilidade */
  --success-light:  #10b981;
  --danger-light:   #ef4444;
  --warning-light:  #f59e0b;
  --info-light:     #3b82f6;
  --card-bg:        #e3e8f0;
  --accent-color:   #0d1636;
  --accent-dark:    #0a0f23;
  --accent-light:   #1a2449;
  --hover-border:   #0d1636;

  /* NEOMORFISMO PREMIUM — PROFISSIONAL */
  /* ==================================== */

  /* Elevação — cards "saem" visivelmente da superfície */
  --shadow-outer:
    5px 5px 15px rgba(163, 177, 198, 0.50),
   -5px -5px 15px rgba(255, 255, 255, 0.80);

  /* Afundado — inputs parecem pressionados */
  --shadow-inset:
    inset 3px 3px 8px rgba(163, 177, 198, 0.40),
    inset -3px -3px 8px rgba(255, 255, 255, 0.75);

  /* Sombra pequena — ícones e detalhes */
  --shadow-sm:
    3px 3px 8px rgba(163, 177, 198, 0.35),
   -3px -3px 8px rgba(255, 255, 255, 0.80);

  /* Hover — elevação ampliada */
  --shadow-hover:
    8px 8px 20px rgba(163, 177, 198, 0.50),
   -8px -8px 20px rgba(255, 255, 255, 0.90);

  /* Sombra grande — modais e painéis flutuantes */
  --shadow-lg:
    10px 10px 30px rgba(163, 177, 198, 0.55),
   -10px -10px 30px rgba(255, 255, 255, 0.85);

  /* Sombra light (compatibilidade) */
  --shadow-light: rgba(255, 255, 255, 0.85);
  --shadow-dark: rgba(163, 177, 198, 0.35);
}

/* ============================================= */
/*    APLICAÇÃO GLOBAL LIGHT MODE - NEOMÓRFICO  */
/* ============================================= */

/* Cards neomórficos premium light */
.neomorphic-card,
.stat-card,
.modal-content,
.chart-container,
.month-selector,
.installment-simulation-box {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  border: none;
  border-radius: 20px;
  padding: 1.5rem;
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Hover — elevação clara */
.stat-card:hover,
.neomorphic-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

/* Inputs afundados — efeito "pressionado" nítido */
.neomorphic-input,
input,
select,
textarea {
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  color: var(--text-primary);
  border: none;
  border-radius: 14px;
  padding: 0.9rem 1.3rem;
  font-size: 1rem;
  transition: box-shadow 0.25s ease, background-color 0.25s ease;
}

.neomorphic-input:focus,
input:focus,
select:focus,
textarea:focus {
  box-shadow:
    var(--shadow-inset),
    0 0 0 3px rgba(15, 114, 232, 0.12);
}

/* Botões elevados neomórficos */
.neomorphic-button,
.btn-primary,
.btn-secondary {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  color: var(--text-primary);
  border: none;
  border-radius: 14px;
  padding: 0.85rem 1.4rem;
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.22s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.22s ease, color 0.22s ease;
}

.neomorphic-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.neomorphic-button:active {
  transform: translateY(1px);
  box-shadow: var(--shadow-inset);
}

/* FAB neomórfico */
#fabButton {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  border: none;
}

#fabButton:hover {
  transform: scale(1.06) translateY(-3px);
  box-shadow: var(--shadow-hover);
}

.sidebar-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background-color 0.22s ease, color 0.22s ease, border-color 0.22s ease;
  border-left: 3px solid transparent;
  border-radius: 12px;
  margin: 4px 12px;
  box-shadow: none;
}

.sidebar-item:hover {
  background: var(--bg-surface);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.sidebar-item.active {
  background: var(--bg-tertiary);
  color: var(--text-accent);
  font-weight: 600;
  box-shadow: var(--shadow-inset);
  transform: none;
}

/* Textos coloridos mantêm semântica light */
.text-green-500 { color: var(--success) !important; }
.text-red-500   { color: var(--danger)  !important; }
.text-blue-500  { color: var(--info)    !important; }

[data-theme="dark"] {
  /* ===== NEOMORPHIC DARK — CLEAN MINIMALIST 2026 ===== */

  /* Background layers — rich deep blue-charcoal */
  --bg-primary:    #181c25;
  --bg-secondary:  #1f2430;
  --bg-tertiary:   #272d3b;
  --bg-surface:    #1c2029;

  /* Text — crisp, high-contrast, effortlessly readable */
  --text-primary:   #e4e9f1;
  --text-secondary: #a5b2c6;
  --text-muted:     #7f8ca3;
  --text-accent:    #7baaf7;

  /* Borders — barely there, defining depth */
  --border-color:   rgba(255, 255, 255, 0.07);
  --border-subtle:  rgba(255, 255, 255, 0.04);

  /* Semantic colors — vivid but not harsh on dark */
  --success:        #5eeda6;
  --danger:         #ff8080;
  --warning:        #ffc464;
  --info:           #6cb8ff;

  /* Motion + focus */
  --motion-fast:    0.22s cubic-bezier(.4,0,.2,1);
  --motion-smooth:  0.28s cubic-bezier(.4,0,.2,1);
  --focus-ring:     0 0 0 3px rgba(123, 170, 247, 0.16);

  /* Button intent tokens */
  --btn-confirm-bg:         #235c4a;
  --btn-confirm-text:       #eafff6;
  --btn-confirm-bg-hover:   #2c745d;
  --btn-confirm-bg-active:  #1d4b3c;

  --btn-cancel-bg:          #3a4861;
  --btn-cancel-text:        #e8eefc;
  --btn-cancel-bg-hover:    #465777;
  --btn-cancel-bg-active:   #313f56;

  --btn-danger-bg:          rgba(220, 38, 38, 0.15);
  --btn-danger-text:        #fca5a5;
  --btn-danger-bg-hover:    rgba(220, 38, 38, 0.25);
  --btn-danger-bg-active:   rgba(220, 38, 38, 0.20);

  /* Legacy compat */
  --success-light:  #5eeda6;
  --danger-light:   #ff8080;
  --warning-light:  #ffc464;
  --info-light:     #6cb8ff;
  --card-bg:        #1f2430;
  --accent-color:   #7baaf7;
  --accent-dark:    #5a8cd8;
  --accent-light:   #a0c6ff;
  --hover-border:   #3a4560;

  /* ===== SHADOWS — DARK (refined depth system 2026) ===== */

  --shadow-sm:
    0 1px 3px rgba(0, 0, 0, 0.28),
    0 4px 12px rgba(0, 0, 0, 0.18);

  --shadow-outer:
    0 2px 6px rgba(0, 0, 0, 0.32),
    0 8px 24px rgba(0, 0, 0, 0.22);

  --shadow-inset:
    inset 0 2px 6px rgba(0, 0, 0, 0.45);

  --shadow-hover:
    0 4px 12px rgba(0, 0, 0, 0.38),
    0 14px 36px rgba(0, 0, 0, 0.28);

  --shadow-lg:
    0 6px 20px rgba(0, 0, 0, 0.50),
    0 20px 56px rgba(0, 0, 0, 0.40);

  /* Subtle top-left highlight for depth (replaces light-side shadow) */
  --border-highlight: 1px solid rgba(255, 255, 255, 0.06);

  --shadow-light: rgba(255, 255, 255, 0.03);
  --shadow-dark:  rgba(0, 0, 0, 0.50);
}

/* ============================================= */
/*    APLICAÇÃO GLOBAL CONSISTENTE DARK 2026    */
/* ============================================= */


/* Aplicação global – sensação de paz e limpeza */
[data-theme="dark"] body {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* Cards neomórficos minimalistas */
[data-theme="dark"] .neomorphic-card,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .chart-container,
[data-theme="dark"] .month-selector,
[data-theme="dark"] .installment-simulation-box {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  border: var(--border-highlight);
  border-radius: 20px;
  padding: 1.4rem;
  transition: transform 0.28s cubic-bezier(.4,0,.2,1), box-shadow 0.28s cubic-bezier(.4,0,.2,1);
}

/* Hover sutil – eleva e ilumina borda */
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .neomorphic-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(255, 255, 255, 0.08);
}

/* Inputs afundados clean */
[data-theme="dark"] .neomorphic-input,
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  color: var(--text-primary);
  border: var(--border-highlight);
  border-radius: 14px;
  padding: 0.9rem 1.3rem;
  font-size: 1rem;
  transition: box-shadow 0.25s cubic-bezier(.4,0,.2,1), border-color 0.25s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] .neomorphic-input:focus {
  box-shadow: 
    var(--shadow-inset),
    0 0 0 2px rgba(123, 170, 247, 0.12);
  border-color: rgba(123, 170, 247, 0.18);
}

/* Botões minimalistas neomórficos */
[data-theme="dark"] .neomorphic-button,
[data-theme="dark"] .btn-primary,
[data-theme="dark"] .btn-secondary {
  background: var(--bg-surface);
  box-shadow: var(--shadow-outer);
  color: var(--text-primary);
  border: var(--border-highlight);
  border-radius: 14px;
  padding: 0.85rem 1.4rem;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s cubic-bezier(.4,0,.2,1), background-color 0.25s cubic-bezier(.4,0,.2,1), color 0.25s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] .neomorphic-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .neomorphic-button:active {
  transform: translateY(1px);
  box-shadow: var(--shadow-inset);
}

/* FAB discreto e clean */
[data-theme="dark"] #fabButton {
  background: var(--bg-surface);
  box-shadow: var(--shadow-outer);
  border: var(--border-highlight);
}

[data-theme="dark"] #fabButton:hover {
  transform: scale(1.06) translateY(-3px);
  box-shadow: var(--shadow-hover);
}

/* Sidebar serena e minimalista */
[data-theme="dark"] .sidebar {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  border-right: none;
}

[data-theme="dark"] .sidebar-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background-color 0.22s ease, color 0.22s ease, border-color 0.22s ease;
  border-left: 3px solid transparent;
  border-radius: 12px;
  margin: 4px 12px;
  box-shadow: none;
}

[data-theme="dark"] .sidebar-item:hover {
  background: rgba(123, 170, 247, 0.05);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

[data-theme="dark"] .sidebar-item.active {
  background: rgba(123, 170, 247, 0.08);
  color: var(--text-accent);
  font-weight: 500;
  box-shadow: var(--shadow-inset);
}

/* Textos coloridos mantêm semântica, mas suaves */
[data-theme="dark"] .text-green-500 { color: var(--success) !important; }
[data-theme="dark"] .text-red-500   { color: var(--danger)  !important; }
[data-theme="dark"] .text-blue-500  { color: var(--info)    !important; }

/* Remove qualquer ruído visual restante */
[data-theme="dark"] body,
[data-theme="dark"] .sidebar-item,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .neomorphic-card,
[data-theme="dark"] .neomorphic-button,
[data-theme="dark"] .btn-primary,
[data-theme="dark"] .btn-secondary {
  text-shadow: none;
}

/* ============================================= */
/*   MODAIS — DARK THEME OVERRIDES (NEOMORPHIC) */
/* ============================================= */

/* Overlay — deep dark */
[data-theme="dark"] .modal {
  background: rgba(2, 4, 10, 0.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* Modal Card — dark */
[data-theme="dark"] .modal-content {
  background: var(--bg-secondary);
  border: var(--border-highlight);
  box-shadow: var(--shadow-lg);
  scrollbar-color: rgba(123, 170, 247, 0.15) transparent;
}

/* Scrollbar Dark */
[data-theme="dark"] .modal-content::-webkit-scrollbar { width: 4px; }
[data-theme="dark"] .modal-content::-webkit-scrollbar-track { background: transparent; }
[data-theme="dark"] .modal-content::-webkit-scrollbar-thumb {
  background: rgba(123, 170, 247, 0.14);
  border-radius: 10px;
}
[data-theme="dark"] .modal-content::-webkit-scrollbar-thumb:hover {
  background: rgba(123, 170, 247, 0.25);
}

/* Header */
[data-theme="dark"] .modal-content > div:first-of-type {
  background: var(--bg-secondary);
}

[data-theme="dark"] .modal-content h3 {
  color: var(--text-primary);
}

/* Close Button — dark */
[data-theme="dark"] .modal-content .transition-colors {
  color: var(--text-muted);
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight);
}
[data-theme="dark"] .modal-content .transition-colors:hover {
  color: #f87171;
  box-shadow: var(--shadow-inset);
}

/* Form Groups — invisible */
[data-theme="dark"] .modal-content .space-y-4 > div {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}
[data-theme="dark"] .modal-content .space-y-4 > div:hover {
  background: transparent !important;
}

/* Labels */
[data-theme="dark"] .modal-content label {
  color: var(--text-secondary);
}

/* Inputs — dark neomorphic inset */
[data-theme="dark"] .modal-content input[type="text"],
[data-theme="dark"] .modal-content input[type="email"],
[data-theme="dark"] .modal-content input[type="password"],
[data-theme="dark"] .modal-content input[type="number"],
[data-theme="dark"] .modal-content input[type="date"],
[data-theme="dark"] .modal-content input[type="month"],
[data-theme="dark"] .modal-content select {
  background: var(--bg-secondary);
  border: var(--border-highlight);
  color: var(--text-primary);
  box-shadow: var(--shadow-inset);
  -webkit-user-select: text;
  user-select: text;
  touch-action: manipulation;
}

@media (max-width: 768px) {
  [data-theme="dark"] .modal-content input[type="text"],
  [data-theme="dark"] .modal-content input[type="email"],
  [data-theme="dark"] .modal-content input[type="password"],
  [data-theme="dark"] .modal-content input[type="number"],
  [data-theme="dark"] .modal-content input[type="date"],
  [data-theme="dark"] .modal-content input[type="month"],
  [data-theme="dark"] .modal-content select {
    font-size: 16px;
  }
}

[data-theme="dark"] .modal-content input::placeholder {
  color: var(--text-muted);
}

/* Focus — dark neomorphic glow */
[data-theme="dark"] .modal-content input[type="text"]:focus,
[data-theme="dark"] .modal-content input[type="email"]:focus,
[data-theme="dark"] .modal-content input[type="password"]:focus,
[data-theme="dark"] .modal-content input[type="number"]:focus,
[data-theme="dark"] .modal-content input[type="date"]:focus,
[data-theme="dark"] .modal-content input[type="month"]:focus,
[data-theme="dark"] .modal-content select:focus {
  outline: none;
  background: var(--bg-secondary);
  box-shadow:
    var(--shadow-inset),
    0 0 0 2px rgba(59, 130, 246, 0.18);
}

/* Select arrow dark */
[data-theme="dark"] .modal-content select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237baaf7' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px 12px;
}

/* Type Selector Buttons — dark neomorphic raised */
[data-theme="dark"] .modal-content .btn-transaction-type,
[data-theme="dark"] .modal-content .btn-recurring-type,
[data-theme="dark"] .modal-content .btn-duration {
  background: var(--bg-secondary) !important;
  border: var(--border-highlight) !important;
  color: var(--text-secondary) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .modal-content .btn-transaction-type:hover,
[data-theme="dark"] .modal-content .btn-recurring-type:hover,
[data-theme="dark"] .modal-content .btn-duration:hover {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-outer) !important;
  transform: translateY(-1px) !important;
}

/* Selected States — dark neomorphic inset + color */
[data-theme="dark"] .modal-content .btn-income-selected,
[data-theme="dark"] .modal-content .btn-permanent-selected {
  background: rgba(16, 185, 129, 0.10) !important;
  border: none !important;
  color: #5eeda6 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content .btn-income-selected:hover,
[data-theme="dark"] .modal-content .btn-permanent-selected:hover {
  background: rgba(16, 185, 129, 0.14) !important;
  box-shadow: var(--shadow-inset) !important;
}

[data-theme="dark"] .modal-content .btn-expense-selected {
  background: rgba(239, 68, 68, 0.10) !important;
  border: none !important;
  color: #ff8080 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content .btn-expense-selected:hover {
  background: rgba(239, 68, 68, 0.14) !important;
  box-shadow: var(--shadow-inset) !important;
}

[data-theme="dark"] .modal-content .btn-temporary-selected {
  background: rgba(245, 158, 11, 0.10) !important;
  border: none !important;
  color: #ffc464 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content .btn-temporary-selected:hover {
  background: rgba(245, 158, 11, 0.14) !important;
  box-shadow: var(--shadow-inset) !important;
}

/* Button Group Footer — no separator */
[data-theme="dark"] .modal-content .flex.gap-3.pt-4::before {
  display: none;
}

/* Suggestion Boxes — dark neomorphic */
[data-theme="dark"] #descriptionSuggestion,
[data-theme="dark"] #recurringDescriptionSuggestion,
[data-theme="dark"] .suggestion-box {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] #descriptionSuggestion:hover,
[data-theme="dark"] #recurringDescriptionSuggestion:hover,
[data-theme="dark"] .suggestion-box:hover {
  background: var(--bg-tertiary) !important;
  border: none !important;
  box-shadow: var(--shadow-outer) !important;
}

/* Installment Simulation — dark */
[data-theme="dark"] .modal-content .installment-simulation-box {
  background: rgba(255, 255, 255, 0.02);
  box-shadow: none;
}
[data-theme="dark"] .modal-content .installment-simulation-box h4 {
  color: #8892a8;
}
[data-theme="dark"] .modal-content .installment-simulation-box .space-y-2 > div {
  color: #64748b;
}

/* Helper Text */
[data-theme="dark"] .modal-content p {
  color: var(--text-muted);
}
[data-theme="dark"] .modal-content .text-xs {
  color: var(--text-muted);
}

/* Category Add Button — dark */
[data-theme="dark"] .modal-content .bg-green-600,
[data-theme="dark"] .modal-content .bg-green-700,
[data-theme="dark"] .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] {
  background: var(--success) !important;
  color: #0d2818 !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .modal-content .bg-green-600:hover,
[data-theme="dark"] .modal-content .bg-green-700:hover,
[data-theme="dark"] .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"]:hover {
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] svg {
  stroke: #0d2818 !important;
  color: #0d2818 !important;
}

/* Warning box — dark neomorphic */
[data-theme="dark"] #adjustBalanceModal .bg-yellow-900 {
  background: rgba(245, 158, 11, 0.10) !important;
  border: none !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] #adjustBalanceModal .bg-yellow-900 p {
  color: #fbbf24 !important;
}

/* ============================================= */
/*   DYNAMIC MODALS — TAILWIND CLASS OVERRIDES  */
/*   (fixes hardcoded dark classes in light)    */
/* ============================================= */

/* Light mode: override dark-looking Tailwind text utilities inside modals */
.modal-content .text-gray-300 { color: #374151 !important; }
.modal-content .text-gray-400 { color: #6b7280 !important; }
.modal-content .text-gray-500 { color: #9ca3af !important; }
.modal-content .text-white { color: #0f172a !important; }
.modal-content .text-red-300 { color: #dc2626 !important; }
.modal-content .text-red-400 { color: #dc2626 !important; }
.modal-content .text-red-500 { color: #dc2626 !important; }
.modal-content .text-yellow-500 { color: #d97706 !important; }

/* Dark mode: restore proper light-on-dark colors */
[data-theme="dark"] .modal-content .text-gray-300 { color: #d1d5db !important; }
[data-theme="dark"] .modal-content .text-gray-400 { color: #94a3b8 !important; }
[data-theme="dark"] .modal-content .text-gray-500 { color: #64748b !important; }
[data-theme="dark"] .modal-content .text-white { color: #f1f5f9 !important; }
[data-theme="dark"] .modal-content .text-red-300 { color: #fca5a5 !important; }
[data-theme="dark"] .modal-content .text-red-400 { color: #f87171 !important; }
[data-theme="dark"] .modal-content .text-red-500 { color: #f87171 !important; }
[data-theme="dark"] .modal-content .text-yellow-500 { color: #fbbf24 !important; }

/* Background blocks inside dynamic modals — light neomorphic */
.modal-content .bg-gray-800 {
  background: var(--bg-tertiary) !important;
  border-radius: 14px;
  border: none !important;
  box-shadow: var(--shadow-inset) !important;
}
.modal-content .bg-red-500.bg-opacity-20,
.modal-content .bg-red-900 {
  background: #fef2f2 !important;
  border: none !important;
  border-radius: 14px;
  box-shadow:
    inset 2px 2px 5px rgba(248, 113, 113, 0.12),
    inset -2px -2px 5px rgba(255, 255, 255, 0.55) !important;
}

/* Background blocks — dark neomorphic */
[data-theme="dark"] .modal-content .bg-gray-800 {
  background: var(--bg-secondary) !important;
  border: none !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content .bg-red-500.bg-opacity-20,
[data-theme="dark"] .modal-content .bg-red-900 {
  background: rgba(239, 68, 68, 0.10) !important;
  border: none !important;
  box-shadow: var(--shadow-inset) !important;
}

/* Close buttons in dynamic modals — light mode */
.modal-content .text-gray-400.hover\:text-white {
  color: #94a3b8 !important;
}
.modal-content .text-gray-400.hover\:text-white:hover {
  color: #ef4444 !important;
}
[data-theme="dark"] .modal-content .text-gray-400.hover\:text-white {
  color: #64748b !important;
}
[data-theme="dark"] .modal-content .text-gray-400.hover\:text-white:hover {
  color: #f87171 !important;
}

/* Dynamic modal confirm inputs — neomorphic inset */
.modal-content .bg-gray-700 {
  background: var(--bg-tertiary) !important;
  border: none !important;
  color: var(--text-primary) !important;
  border-radius: 14px !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content .bg-gray-700 {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-inset) !important;
}

/* Calculator — Dark */
[data-theme="dark"] #calculatorModal .modal-content {
  background: var(--bg-primary);
  box-shadow: var(--shadow-lg);
}
[data-theme="dark"] .calc-display-area {
  background: #0f1322;
  box-shadow: var(--shadow-inset);
  border-radius: 20px;
  margin: 16px 16px 0;
}
[data-theme="dark"] .calc-expression {
  color: rgba(123, 170, 247, 0.40);
}
[data-theme="dark"] .calc-display-value {
  color: #f0f4ff;
}
[data-theme="dark"] .calc-grid {
  background: var(--bg-primary);
}
[data-theme="dark"] .calc-grid .calc-btn {
  background: var(--bg-surface) !important;
  color: var(--text-primary) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn:hover {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn:active {
  background: var(--bg-primary) !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-operator {
  background: #1a2240 !important;
  color: var(--text-accent) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-operator:hover {
  background: #222c52 !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-operator:active {
  background: #151c38 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-fn {
  background: var(--bg-surface) !important;
  color: var(--text-secondary) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-fn:hover {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-fn:active {
  background: var(--bg-primary) !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-clear {
  background: #2a1520 !important;
  color: var(--danger) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-clear:hover {
  background: #381c28 !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-clear:active {
  background: #201018 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-equals {
  background: #142a22 !important;
  color: var(--success) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-equals:hover {
  background: #1c382e !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-equals:active {
  background: #0e201a !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-send {
  background: #1a2240 !important;
  color: var(--text-accent) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-sm) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-send:hover {
  background: #222c52 !important;
  box-shadow: var(--shadow-outer) !important;
}
[data-theme="dark"] .calc-grid .calc-btn-send:active {
  background: #151c38 !important;
  box-shadow: var(--shadow-inset) !important;
}

/* Adjust Balance — Dark */
[data-theme="dark"] #adjustBalanceModal .bg-yellow-900 {
  background: rgba(255, 196, 100, 0.06) !important;
  border-color: rgba(255, 196, 100, 0.14) !important;
}
[data-theme="dark"] #adjustBalanceModal .bg-yellow-900 p {
  color: var(--warning) !important;
}

/* Goal Modal — override hardcoded Tailwind dark classes */
.modal-content textarea,
.modal-content textarea.bg-gray-700 {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: #1e293b !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
  font-family: inherit !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  transition: all 0.22s ease !important;
  box-shadow:
    inset 3px 3px 6px rgba(163, 177, 198, 0.40),
    inset -3px -3px 6px rgba(255, 255, 255, 0.70) !important;
  resize: vertical;
}
.modal-content textarea::placeholder {
  color: #94a3b8 !important;
}
.modal-content textarea:focus {
  outline: none !important;
  border: none !important;
  box-shadow:
    inset 3px 3px 6px rgba(163, 177, 198, 0.45),
    inset -3px -3px 6px rgba(255, 255, 255, 0.75),
    0 0 0 2px rgba(59, 130, 246, 0.15) !important;
}
[data-theme="dark"] .modal-content textarea,
[data-theme="dark"] .modal-content textarea.bg-gray-700 {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: #e2e8f0 !important;
  box-shadow: var(--shadow-inset) !important;
}
[data-theme="dark"] .modal-content textarea::placeholder {
  color: #4a5568 !important;
}
[data-theme="dark"] .modal-content textarea:focus {
  border: none !important;
  box-shadow:
    var(--shadow-inset),
    0 0 0 2px rgba(123, 170, 247, 0.15) !important;
}

@media (max-width: 768px) {
  .modal-content input,
  .modal-content select,
  .modal-content textarea {
    font-size: 16px !important;
    -webkit-text-size-adjust: 100%;
  }
}

/* Goal priority select — neomorphic inset */
.modal-content select.bg-gray-700 {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: #1e293b !important;
  box-shadow:
    inset 3px 3px 6px rgba(163, 177, 198, 0.40),
    inset -3px -3px 6px rgba(255, 255, 255, 0.70) !important;
}
[data-theme="dark"] .modal-content select.bg-gray-700 {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: #e2e8f0 !important;
  box-shadow: var(--shadow-inset) !important;
}

/* ============================================= */
/*          2. GLOBAL RESET & STYLES           */
/* ============================================= */

* {
  box-sizing: border-box;
}

body {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: 'Quicksand', 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* Kill ALL transitions instantly during theme switch */
.theme-transitioning,
.theme-transitioning *,
.theme-transitioning *::before,
.theme-transitioning *::after {
  transition: none !important;
  animation: none !important;
}

button {
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Exception for primary, secondary, settings, and auth buttons */
button.btn-primary,
button.btn-secondary,
button.goal-btn {
  background: inherit !important;
  border: inherit !important;
  box-shadow: inherit !important;
}

button.plan-confirm-btn {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  border: none !important;
  box-shadow: 0 4px 20px rgba(16,185,129,0.35), 0 1px 3px rgba(0,0,0,0.1) !important;
  position: relative;
  overflow: hidden;
}
button.plan-confirm-btn:hover {
  background: linear-gradient(135deg, #34d399, #10b981) !important;
  box-shadow: 0 8px 32px rgba(16,185,129,0.45) !important;
}
button.plan-confirm-btn.free {
  background: linear-gradient(135deg, #6366f1, #4f46e5) !important;
  box-shadow: 0 4px 20px rgba(99,102,241,0.35) !important;
}
button.plan-confirm-btn.free:hover {
  background: linear-gradient(135deg, #818cf8, #6366f1) !important;
  box-shadow: 0 8px 32px rgba(99,102,241,0.45) !important;
}

button.settings-btn,
button.settings-btn-accent,
button.settings-btn-outline,
button.settings-btn-danger {
  background: unset !important;
  box-shadow: unset !important;
}

button.btn-primary[style*="width: auto"] {
  background: #0d1636 !important;
  box-shadow: 0 6px 16px rgba(13, 22, 54, 0.3) !important;
}

button.btn-secondary[style*="width: auto"] {
  background: var(--bg-primary) !important;
  color: var(--text-secondary) !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid rgba(0, 61, 143, 0.12) !important;
}

button.btn-secondary[style*="width: auto"]:hover {
  background: rgba(15, 114, 232, 0.08) !important;
  color: var(--text-accent) !important;
  box-shadow: var(--shadow-hover) !important;
  transform: translateY(-2px) !important;
}

button.btn-secondary[style*="width: auto"].active-filter {
  background: var(--text-accent) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(15, 114, 232, 0.25) !important;
  border-color: var(--text-accent) !important;
}

button:hover,
button:focus,
button:active {
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Exception for intent and auth/settings buttons hover/focus/active */
button.btn-primary:hover,
button.btn-primary:focus,
button.btn-primary:active,
button.btn-secondary:hover,
button.btn-secondary:focus,
button.btn-secondary:active,
button.btn-danger:hover,
button.btn-danger:focus,
button.btn-danger:active,
button.settings-btn-accent:hover,
button.settings-btn-accent:focus,
button.settings-btn-accent:active,
button.settings-btn-outline:hover,
button.settings-btn-outline:focus,
button.settings-btn-outline:active,
button.settings-btn-danger:hover,
button.settings-btn-danger:focus,
button.settings-btn-danger:active,
button.goal-btn:hover,
button.goal-btn:focus,
button.goal-btn:active {
  background: inherit !important;
  box-shadow: inherit !important;
}

button::-moz-focus-inner {
  border: 0 !important;
  padding: 0 !important;
}

/* Botão de visibilidade de senha - sem fundo */
button[onclick*="togglePasswordVisibility"] {
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  width: auto !important;
  height: auto !important;
}

button[onclick*="togglePasswordVisibility"]:hover,
button[onclick*="togglePasswordVisibility"]:focus,
button[onclick*="togglePasswordVisibility"]:active {
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
}

input, select, textarea {
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-primary);
  padding: 12px 16px;
  border-radius: 14px;
  transition: box-shadow 0.25s ease, background-color 0.25s ease;
  width: 100%;
  box-shadow: var(--shadow-inset);
}

input:focus, select:focus, textarea:focus {
  outline: none;
  box-shadow:
    var(--shadow-inset),
    0 0 0 3px rgba(15, 114, 232, 0.12);
  background: var(--bg-tertiary);
}

/* ============================================= */
/*          3. ANIMATIONS & KEYFRAMES          */
/* ============================================= */

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideDown {
  from {
    transform: translateX(-50%) translateY(-100px);
    opacity: 0;
  }
  to {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
  }
}

@keyframes float {
  0%, 100% { transform: translateY(0px) rotate(0deg); }
  33% { transform: translateY(-20px) rotate(5deg); }
  66% { transform: translateY(-10px) rotate(-5deg); }
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.06); }
}

@keyframes shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ============================================= */
/*          4. LAYOUT - SIDEBAR & MAIN         */
/* ============================================= */

.sidebar {
  background: var(--bg-secondary);
  border-right: none;
  width: 280px;
  position: fixed;
  height: 100%;
  left: 0;
  top: 0;
  overflow-y: auto;
  transition: transform 0.3s ease;
  z-index: 100;
  display: flex;
  flex-direction: column;
  box-shadow:
    5px 0 15px rgba(163, 177, 198, 0.30),
   -2px 0 8px rgba(255, 255, 255, 0.60);
}

.main-content {
  margin-left: 280px;
  min-height: 100%;
  width: calc(100% - 280px);
}

.page {
  display: none;
}

.page.active {
  display: block;
  animation: fadeIn 0.25s ease;
}

/* ============================================= */
/*      4b. PAGE INTERNAL ELEMENTS             */
/* ============================================= */

/* Headings dentro das páginas */
h1, h2, h3, h4, h5, h6 {
  color: var(--text-primary);
  font-weight: 700;
}

h1 {
  font-size: 2.25rem;
  margin-bottom: 12px;
  letter-spacing: -0.5px;
}

h2 {
  font-size: 1.875rem;
  margin-bottom: 16px;
  letter-spacing: -0.3px;
}

h3 {
  font-size: 1.25rem;
  margin-bottom: 12px;
  letter-spacing: -0.2px;
  font-weight: 700;
  color: var(--text-primary);
}

/* Labels em formulários */
label,
.label {
  display: block;
  color: var(--text-secondary);
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 8px;
  text-transform: none;
}

label:hover,
.label:hover {
  color: var(--text-primary);
}

/* Text helpers */
.text-secondary {
  color: var(--text-secondary);
  transition: color 0.3s ease;
}

.text-muted {
  color: rgba(0, 0, 0, 0.5);
  font-size: 0.875rem;
}

.text-uppercase {
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 0.75rem;
  font-weight: 700;
}

/* ============================================= */
/*          5. DASHBOARD CARDS & STATS         */
/* ============================================= */

.stat-card {
  background: var(--bg-secondary);
  border-radius: 20px;
  box-shadow: var(--shadow-outer);
  padding: 1.5rem;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: none;
}

.stat-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.stat-card svg {
  width: 36px;
  height: 36px;
  padding: 8px;
  border-radius: 12px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.stat-card:hover svg {
  background: var(--bg-tertiary);
  box-shadow:
    inset 4px 4px 10px rgba(163, 177, 198, 0.45),
    inset -4px -4px 10px rgba(255, 255, 255, 0.70);
}

.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (max-width: 768px) {
  .stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }

  .stats-grid .stat-card:nth-child(1) {
    grid-column: 1 / -1;
  }
}

@media (min-width: 1024px) {
  .stats-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
}

.progress-bar {
  height: 8px;
  background: #e2e8f0;
  border-radius: 999px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background: var(--accent-color);
  transition: width 0.5s ease;
  position: relative;
  overflow: hidden;
}

.progress-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  animation: shimmer 2s infinite;
}

/* ============================================= */
/*          6. TRANSACTION ITEMS                */
/* ============================================= */

.transaction-item {
  background: var(--bg-secondary);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  padding: 16px;
  margin-bottom: 12px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  border: none;
}

.transaction-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.transaction-item.projected {
  background: rgba(0, 61, 143, 0.08);
  border: 2px dashed rgba(13, 22, 54, 0.3);
  border-radius: 16px;
}

.transaction-item.projected:hover {
  border-color: rgba(13, 22, 54, 0.5);
}

.transaction-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 8px;
}

.transaction-icon {
  font-size: 18px;
  font-weight: bold;
  min-width: 24px;
  text-align: center;
  flex-shrink: 0;
}

.transaction-main {
  flex: 1;
  min-width: 0;
}

.transaction-title-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.transaction-description {
  font-weight: 600;
  font-size: 14px;
  word-break: break-word;
  color: inherit;
}

.badge-status {
  font-size: 11px;
  background: rgba(180, 83, 9, 0.08);
  color: #92400e;
  padding: 2px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.badge-projected {
  font-size: 11px;
  background: rgba(37, 99, 235, 0.08);
  color: #1d4ed8;
  padding: 2px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.badge-preview {
  font-size: 11px;
  background: rgba(245, 158, 11, 0.10);
  color: #b45309;
  padding: 2px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.transaction-item.future-preview {
  opacity: 0.72;
}

.transaction-meta {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--text-secondary);
}

.meta-item {
  word-break: break-word;
  max-width: 100%;
}

.meta-separator {
  color: var(--border-color);
}

.transaction-amount {
  font-size: 16px;
  font-weight: 700;
  text-align: right;
  word-break: break-word;
}

.transaction-actions {
  display: flex;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  justify-content: flex-end;
}

.action-btn {
  background: transparent;
  border: 1px solid transparent;
  padding: 4px 8px;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.edit-btn {
  color: var(--accent-color);
}

.edit-btn:hover {
  background: rgba(0, 61, 143, 0.1);
  /* pure shadow based design */
}

.delete-btn {
  color: var(--danger);
}

.delete-btn:hover {
  background: rgba(239, 68, 68, 0.1);
  /* pure shadow based design */
}

/* ============================================= */
/*          7. RECURRING ITEMS                  */
/* ============================================= */

.recurring-item {
  background: var(--bg-secondary);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  padding: 12px;
  margin-bottom: 12px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  border: none;
}

.recurring-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.recurring-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.recurring-icon {
  font-size: 18px;
  font-weight: bold;
  min-width: 22px;
  text-align: center;
  flex-shrink: 0;
}

.recurring-main {
  flex: 1;
  min-width: 0;
}

.recurring-title {
  font-weight: 600;
  font-size: 14px;
  word-break: break-word;
  color: inherit;
  margin-bottom: 2px;
}

.recurring-meta {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--text-secondary);
}

.recurring-meta span {
  display: inline;
}

.recurring-badge-container {
  display: flex;
  gap: 4px;
}

.recurring-badge {
  font-size: 12px;
  padding: 3px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.recurring-badge.permanent {
  background: rgba(16, 185, 129, 0.2);
  color: var(--success);
}

.recurring-badge.temporary {
  background: rgba(251, 191, 36, 0.2);
  color: var(--warning);
}

.recurring-expires {
  font-size: 10px;
  background: rgba(180, 83, 9, 0.08);
  color: #92400e;
  padding: 2px 6px;
  border-radius: 3px;
}

.recurring-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 8px;
  border-top: 1px solid rgba(0, 61, 143, 0.1);
}

.recurring-amount {
  font-size: 15px;
  font-weight: 700;
  word-break: break-word;
}

.recurring-actions {
  display: flex;
  gap: 6px;
}

/* ============================================= */
/*          8. GOAL ITEMS                       */
/* ============================================= */

.goal-item {
  background: var(--bg-secondary);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 16px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid var(--border-color);
  position: relative;
  overflow: hidden;
}

.goal-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.goal-item .goal-priority-stripe {
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  border-radius: 20px 0 0 20px;
}

.goal-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
}

.goal-main {
  flex: 1;
  min-width: 0;
}

.goal-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}

.goal-title {
  font-weight: 700;
  font-size: 1rem;
  word-break: break-word;
  color: var(--text-primary);
  margin: 0;
}

.goal-badge {
  font-size: 0.65rem;
  padding: 3px 8px;
  border-radius: 20px;
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.goal-badge.completed {
  background: rgba(16, 185, 129, 0.15);
  color: var(--success);
}

.goal-badge.overdue {
  background: rgba(239, 68, 68, 0.15);
  color: var(--danger);
}

.goal-badge.deadline {
  background: rgba(251, 191, 36, 0.15);
  color: var(--warning);
}

.goal-meta {
  font-size: 0.75rem;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 6px;
}

.goal-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.goal-actions .action-btn {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-color);
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s ease;
}

.goal-actions .action-btn:hover {
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
}

.goal-actions .action-btn.delete-btn:hover {
  color: var(--danger);
  border-color: var(--danger);
  background: rgba(239, 68, 68, 0.08);
}

.goal-values {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 16px;
}

.goal-value-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 8px;
  background: var(--bg-tertiary);
  border-radius: 14px;
  border: 1px solid var(--border-subtle);
}

.goal-value-label {
  font-size: 0.65rem;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.goal-value-amount {
  font-size: 0.85rem;
  font-weight: 800;
}

.goal-progress {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}

.goal-progress-bar-container {
  flex: 1;
  height: 10px;
  background: var(--bg-tertiary);
  border-radius: 99px;
  overflow: hidden;
  border: 1px solid var(--border-subtle);
}

.goal-progress-bar {
  height: 100%;
  border-radius: 99px;
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.goal-progress-text {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text-primary);
  min-width: 38px;
  text-align: right;
}

.goal-footer {
  display: flex;
  gap: 10px;
}

.goal-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.goal-btn.add-btn {
  background: var(--success);
  color: #fff;
}

.goal-btn.add-btn:hover {
  filter: brightness(1.1);
  box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35);
  transform: translateY(-1px);
}

.goal-btn.withdraw-btn {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}

.goal-btn.withdraw-btn:hover {
  background: var(--info);
  color: #fff;
  border-color: var(--info);
  box-shadow: 0 4px 14px rgba(59, 130, 246, 0.3);
  transform: translateY(-1px);
}

/* Goals empty state */
.goals-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  text-align: center;
}

.goals-empty svg {
  color: var(--text-muted);
  margin-bottom: 16px;
  opacity: 0.5;
}

.goals-empty h4 {
  color: var(--text-secondary);
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 6px 0;
}

.goals-empty p {
  color: var(--text-muted);
  font-size: 0.85rem;
  margin: 0;
}

/* Goal item completed state */
.goal-item.goal-completed {
  border-color: var(--success);
}

.goal-item.goal-completed .goal-priority-stripe {
  background: var(--success) !important;
}

/* ============================================= */
/*          9. WALLET CARDS                      */
/*    REALISTIC · NEOMORPHIC · UNIFORM           */
/* ============================================= */

/* --- Grid Container --- */
#cardsList.wallet-cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

@media (min-width: 640px) {
  #cardsList.wallet-cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1280px) {
  #cardsList.wallet-cards-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* --- Section Titles --- */
.wallet-section-title-wrap {
  grid-column: 1 / -1;
}

.wallet-section-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 0;
}

.wallet-section-title--credit { color: #eab308; }
.wallet-section-title--debit  { color: #10b981; }

/* --- Card Wrapper (container for card + info) --- */
.wallet-card-wrapper {
  border-radius: 20px;
  overflow: hidden;
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.wallet-card-wrapper:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}

/* --- The Visual Card Element --- */
.wallet-card {
  aspect-ratio: 1.586 / 1;
  border-radius: 14px;
  padding: 22px 24px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 12px 12px 0 12px;
  color: #ffffff;
}

.wallet-card--credit { background: #1e3a8a; }
.wallet-card--debit  { background: #065f46; }

/* Decorative circles */
.wallet-card::before {
  content: '';
  position: absolute;
  width: 200px;
  height: 200px;
  background: rgba(255, 255, 255, 0.035);
  border-radius: 50%;
  top: -90px;
  right: -70px;
  pointer-events: none;
}

.wallet-card::after {
  content: '';
  position: absolute;
  width: 140px;
  height: 140px;
  background: rgba(255, 255, 255, 0.025);
  border-radius: 50%;
  bottom: -50px;
  left: -40px;
  pointer-events: none;
}

/* --- Card Top Row --- */
.wallet-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.wallet-card-type {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  opacity: 0.6;
}

/* --- Card Chip --- */
.wallet-card-chip {
  width: 38px;
  height: 28px;
  border-radius: 5px;
  background: #c9a84c;
  position: relative;
  z-index: 1;
  box-shadow:
    1px 1px 3px rgba(0, 0, 0, 0.30),
    inset 0 0 2px rgba(255, 255, 255, 0.15);
}

.wallet-card-chip::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 14px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 2px;
}

.wallet-card-chip::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 5px;
  right: 5px;
  height: 1px;
  background: rgba(0, 0, 0, 0.10);
}

/* --- Card Number --- */
.wallet-card-number {
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  position: relative;
  z-index: 1;
  font-family: 'Courier New', 'Consolas', monospace;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

/* --- Card Bottom Row --- */
.wallet-card-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.wallet-card-name {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.8;
  max-width: 60%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-card-detail {
  font-size: 0.6rem;
  opacity: 0.5;
  text-align: right;
  line-height: 1.6;
}

/* --- Info Panel Below Card --- */
.wallet-card-info {
  padding: 14px 20px 16px;
}

.wallet-card-info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 0;
}

.wallet-card-info-label {
  font-size: 0.72rem;
  color: #6b7280;
  font-weight: 500;
}

.wallet-card-info-value {
  font-size: 0.82rem;
  font-weight: 700;
}

/* --- Usage Bar --- */
.wallet-usage-bar {
  height: 4px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.07);
  margin: 8px 0;
  overflow: hidden;
}

.wallet-usage-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s ease;
}

/* --- Action Buttons --- */
.wallet-card-actions {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.wallet-card-btn {
  flex: 1;
  padding: 8px 10px;
  border-radius: 11px;
  font-size: 0.7rem;
  font-weight: 700;
  border: 1px solid transparent !important;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  line-height: 1;
}

.wallet-card-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.wallet-card-btn span {
  display: inline-block;
  transform: translateY(0.5px);
}

.wallet-card-btn--pay {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  color: #fff !important;
  box-shadow: 0 6px 14px rgba(16,185,129,0.28) !important;
}
.wallet-card-btn--pay:hover {
  box-shadow: 0 9px 18px rgba(16,185,129,0.36) !important;
  transform: translateY(-1px);
}

.wallet-card-btn--future {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #fff !important;
  box-shadow: 0 6px 14px rgba(59,130,246,0.28) !important;
}
.wallet-card-btn--future:hover {
  box-shadow: 0 9px 18px rgba(59,130,246,0.36) !important;
  transform: translateY(-1px);
}

.wallet-card-btn--icon {
  flex: 0 0 auto;
  width: 34px;
  padding: 7px 0;
  background: rgba(0, 0, 0, 0.03) !important;
  color: #9ca3af !important;
  box-shadow: var(--shadow-outer) !important;
}
.wallet-card-btn--icon:hover {
  color: #3b82f6 !important;
  background: rgba(59, 130, 246, 0.06) !important;
}
.wallet-card-btn--icon.delete:hover {
  color: #ef4444 !important;
  background: rgba(239, 68, 68, 0.06) !important;
}

/* Card delete confirmation modal */
/* ============================================= */
/*   UNIFIED DELETE CONFIRMATION MODAL (cdm)    */
/*   Premium · Animated · Theme-aware · 2026    */
/* ============================================= */

@keyframes cdmIconPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.25); }
  50%      { box-shadow: 0 0 0 12px rgba(239, 68, 68, 0); }
}

@keyframes cdmShake {
  0%, 100% { transform: rotate(0deg); }
  20%      { transform: rotate(-6deg); }
  40%      { transform: rotate(6deg); }
  60%      { transform: rotate(-4deg); }
  80%      { transform: rotate(3deg); }
}

.cdm-content {
  max-width: 420px;
  width: 100%;
  padding: 32px 28px 28px;
  border-radius: 24px;
  text-align: center;
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-lg);
  animation: modalContentIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* --- Icon Circle --- */
.cdm-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--btn-danger-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  animation: cdmIconPulse 2s ease-in-out infinite;
  transition: transform 0.3s ease;
}
.cdm-icon svg {
  color: var(--danger);
  animation: cdmShake 0.5s ease-in-out 0.3s;
}
.cdm-icon--warning {
  background: rgba(245, 158, 11, 0.12);
  animation: none;
}
.cdm-icon--warning svg {
  color: var(--warning);
  animation: cdmShake 0.5s ease-in-out 0.3s;
}

/* --- Title --- */
.cdm-title {
  margin: 0 0 8px;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.3px;
}

/* --- Body text --- */
.cdm-text {
  margin: 0 0 20px;
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.65;
}
.cdm-text strong {
  color: var(--text-primary);
  font-weight: 700;
}

/* --- Warning box (cascading deletes) --- */
.cdm-warning {
  background: rgba(239, 68, 68, 0.06);
  border: 1px solid rgba(239, 68, 68, 0.15);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 20px;
  text-align: left;
}
.cdm-warning--amber {
  background: rgba(245, 158, 11, 0.06);
  border-color: rgba(245, 158, 11, 0.15);
}
.cdm-warning-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--danger);
}
.cdm-warning--amber .cdm-warning-head {
  color: var(--warning);
}
.cdm-warning-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-left: 2px;
}
.cdm-warning-list > div {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--text-secondary);
}
.cdm-warning-list > div svg {
  flex-shrink: 0;
  opacity: 0.7;
}

/* --- Info box (non-destructive notes) --- */
.cdm-info {
  background: rgba(59, 130, 246, 0.06);
  border: 1px solid rgba(59, 130, 246, 0.12);
  border-radius: 14px;
  padding: 12px 16px;
  margin-bottom: 20px;
  text-align: left;
  font-size: 0.82rem;
  line-height: 1.55;
  color: var(--text-secondary);
}

/* --- Select (category relocation) --- */
.cdm-select {
  width: 100%;
  margin-bottom: 20px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.cdm-select:focus {
  outline: none;
  border-color: var(--text-accent);
  box-shadow: var(--focus-ring);
}

/* --- Actions row --- */
.cdm-actions {
  display: flex;
  gap: 10px;
}

/* --- Buttons --- */
.cdm-btn {
  flex: 1;
  min-height: 46px;
  border-radius: 13px;
  border: none;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--motion-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  letter-spacing: 0.01em;
}
.cdm-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.cdm-btn--cancel {
  background: var(--btn-cancel-bg);
  color: var(--btn-cancel-text);
}
.cdm-btn--cancel:hover:not(:disabled) {
  background: var(--btn-cancel-bg-hover);
}

.cdm-btn--danger {
  background: #ef4444;
  color: #fff;
  box-shadow: 0 2px 8px rgba(239, 68, 68, 0.25);
}
.cdm-btn--danger:hover:not(:disabled) {
  background: #dc2626;
  box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35);
  transform: translateY(-1px);
}
.cdm-btn--danger:active:not(:disabled) {
  transform: translateY(0);
}

.cdm-btn--confirm {
  background: var(--btn-confirm-bg);
  color: var(--btn-confirm-text);
  box-shadow: 0 2px 8px rgba(16, 185, 129, 0.2);
}
.cdm-btn--confirm:hover:not(:disabled) {
  background: var(--btn-confirm-bg-hover);
  box-shadow: 0 4px 14px rgba(16, 185, 129, 0.3);
  transform: translateY(-1px);
}

/* --- Stacked buttons variant --- */
.cdm-actions--stack {
  flex-direction: column;
  gap: 8px;
}

/* --- Entity badge (amount, parcelas) --- */
.cdm-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  margin-top: 8px;
}

/* ===== Dark theme overrides ===== */
[data-theme="dark"] .cdm-content {
  border: 1px solid rgba(255, 255, 255, 0.06);
}
[data-theme="dark"] .cdm-warning {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.18);
}
[data-theme="dark"] .cdm-warning--amber {
  background: rgba(245, 158, 11, 0.08);
  border-color: rgba(245, 158, 11, 0.18);
}
[data-theme="dark"] .cdm-info {
  background: rgba(59, 130, 246, 0.08);
  border-color: rgba(59, 130, 246, 0.15);
}
[data-theme="dark"] .cdm-btn--danger {
  box-shadow: 0 2px 10px rgba(239, 68, 68, 0.3);
}
[data-theme="dark"] .cdm-btn--danger:hover:not(:disabled) {
  box-shadow: 0 4px 18px rgba(239, 68, 68, 0.4);
}

.wallet-card-btn--icon.adjust:hover {
  color: #eab308;
  background: rgba(234, 179, 8, 0.06);
}

/* ============================================= */
/*   UNIFIED ACTION MODAL (um) — extends CDM    */
/*   For add/withdraw/pay/adjust/password/etc   */
/* ============================================= */

.um-content {
  max-width: 440px;
  width: 100%;
  padding: 32px 28px 26px;
  border-radius: 22px;
  text-align: center;
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  box-shadow: 0 24px 64px rgba(0,0,0,0.25);
  animation: modalContentIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.um-content--wide { max-width: 540px; }

/* Icon circle */
.um-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}
.um-icon--green  { background: rgba(16,185,129,0.12); color: #10b981; }
.um-icon--blue   { background: rgba(59,130,246,0.12); color: #3b82f6; }
.um-icon--amber  { background: rgba(245,158,11,0.1);  color: #f59e0b; }
.um-icon--red    { background: rgba(239,68,68,0.1);   color: #ef4444; }
.um-icon--purple { background: rgba(139,92,246,0.1);  color: #8b5cf6; }

.um-title {
  margin: 0 0 6px;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.3px;
}
.um-desc {
  margin: 0 0 20px;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.5;
}
.um-desc strong { color: var(--text-primary); font-weight: 700; }

/* Info banner inside modal */
.um-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 12px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 18px;
  text-align: left;
}
.um-info--green { background: rgba(16,185,129,0.06); border-color: rgba(16,185,129,0.15); color: #10b981; }
.um-info--blue  { background: rgba(59,130,246,0.06); border-color: rgba(59,130,246,0.12); color: #60a5fa; }
.um-info--amber { background: rgba(245,158,11,0.06); border-color: rgba(245,158,11,0.12); color: #fbbf24; }
.um-info svg    { flex-shrink: 0; opacity: 0.7; }

/* Value highlight box */
.um-value-box {
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-subtle);
  margin-bottom: 18px;
}
.um-value-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.um-value-amount {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-primary);
}
.um-value-amount--green { color: #10b981; }
.um-value-amount--amber { color: #f59e0b; }
.um-value-amount--red   { color: #ef4444; }

/* Form fields inside unified modal */
.um-field {
  margin-bottom: 16px;
  text-align: left;
}
.um-label {
  display: block;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.um-input,
.um-select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1.5px solid var(--border-color);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  font-size: 0.92rem;
  font-weight: 500;
  transition: border-color 0.2s, box-shadow 0.2s;
  box-sizing: border-box;
}
.um-input:focus,
.um-select:focus {
  outline: none;
  border-color: var(--text-accent);
  box-shadow: 0 0 0 3px rgba(16,185,129,0.12);
}
.um-input::placeholder { color: var(--text-muted); }

/* Row for two fields */
.um-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* Action buttons */
.um-actions {
  display: flex;
  gap: 10px;
  margin-top: 22px;
}
.um-btn {
  flex: 1;
  min-height: 48px;
  border-radius: 13px;
  border: none;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.um-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.um-btn--cancel {
  background: var(--btn-cancel-bg) !important;
  color: var(--btn-cancel-text);
}
.um-btn--cancel:hover:not(:disabled) {
  background: var(--btn-cancel-bg-hover) !important;
}

.um-btn--green {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  color: #fff;
  box-shadow: 0 3px 12px rgba(16,185,129,0.25);
}
.um-btn--green:hover:not(:disabled) {
  box-shadow: 0 6px 20px rgba(16,185,129,0.35);
  transform: translateY(-1px);
}

.um-btn--blue {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #fff;
  box-shadow: 0 3px 12px rgba(59,130,246,0.25);
}
.um-btn--blue:hover:not(:disabled) {
  box-shadow: 0 6px 20px rgba(59,130,246,0.35);
  transform: translateY(-1px);
}

.um-btn--amber {
  background: linear-gradient(135deg, #f59e0b, #d97706) !important;
  color: #fff;
  box-shadow: 0 3px 12px rgba(245,158,11,0.25);
}
.um-btn--amber:hover:not(:disabled) {
  box-shadow: 0 6px 20px rgba(245,158,11,0.35);
  transform: translateY(-1px);
}

.um-btn--red {
  background: rgba(239,68,68,0.1) !important;
  color: #f87171;
  border: 1px solid rgba(239,68,68,0.2);
}
.um-btn--red:hover:not(:disabled) {
  background: rgba(239,68,68,0.18) !important;
}

/* Dark overrides */
[data-theme="dark"] .um-content {
  border: 1px solid rgba(255,255,255,0.06);
}
[data-theme="dark"] .um-input,
[data-theme="dark"] .um-select {
  background: var(--bg-secondary);
  border-color: rgba(255,255,255,0.08);
  box-shadow: var(--shadow-inset);
}
[data-theme="dark"] .um-info {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.06);
}

@media (max-width: 480px) {
  .um-content { padding: 24px 20px 22px; }
  .um-actions { flex-direction: column; }
}

/* Checkbox rows for partial delete modal */
.um-delete-check {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 4px;
}
.um-delete-check:hover { background: var(--bg-tertiary); }
.um-delete-check input[type="checkbox"] {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  border: 2px solid var(--border-color);
  accent-color: #ef4444;
  cursor: pointer;
  flex-shrink: 0;
}
.um-delete-check-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.um-delete-check-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
  min-width: 0;
}
.um-delete-check-name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-primary);
}
.um-delete-check-count {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

/* ============================================= */
/*          10. MODALS & DIALOGS                */
/*  NEOMORPHIC · SOFT · BORDERLESS · 2026       */
/* ============================================= */

.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(190, 200, 215, 0.55);
  backdrop-filter: blur(18px) saturate(1.3);
  -webkit-backdrop-filter: blur(18px) saturate(1.3);
  z-index: 999;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: modalOverlayIn 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal.active {
  display: flex;
}

@keyframes modalOverlayIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes modalContentIn {
  from { opacity: 0; transform: translateY(16px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

#categoryModal,
#cardModal {
  z-index: 1000 !important;
}

.modal-content {
  background: var(--bg-secondary);
  border-radius: 28px;
  padding: 0;
  max-width: 520px;
  width: 100%;
  max-height: 88vh;
  overflow: hidden;
  overflow-y: auto;
  border: none;
  box-shadow: var(--shadow-lg);
  scrollbar-width: thin;
  scrollbar-color: rgba(100, 116, 139, 0.15) transparent;
  animation: modalContentIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.modal-content::-webkit-scrollbar {
  width: 4px;
}

.modal-content::-webkit-scrollbar-track {
  background: transparent;
  margin: 16px 0;
}

.modal-content::-webkit-scrollbar-thumb {
  background: rgba(100, 116, 139, 0.18);
  border-radius: 10px;
}

.modal-content::-webkit-scrollbar-thumb:hover {
  background: rgba(100, 116, 139, 0.30);
}

/* ——— Modal Header ——— */
.modal-content > div:first-of-type {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px 32px 16px;
  margin-bottom: 0;
  border-bottom: none;
  position: sticky;
  top: 0;
  z-index: 5;
  background: inherit;
  border-radius: 28px 28px 0 0;
}

.modal-content > div:first-of-type::after {
  display: none;
}

.modal-content h3 {
  color: #1e293b;
  font-weight: 800;
  font-size: 1.35rem;
  margin: 0;
  letter-spacing: -0.5px;
  line-height: 1.2;
}

/* Close button — neomorphic pill */
.modal-content .transition-colors {
  color: #94a3b8;
  cursor: pointer;
  padding: 6px;
  border-radius: 12px;
  transition: all 0.22s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: var(--bg-secondary);
  width: 36px;
  height: 36px;
  box-shadow: var(--shadow-sm);
  border: none;
}

.modal-content .transition-colors:hover {
  color: #ef4444;
  box-shadow: var(--shadow-inset);
  transform: none;
}

/* ——— Modal Body (form area) ——— */
.modal-content form {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0 32px;
}

/* Form Group Containers — totally invisible, no partitions */
.modal-content .space-y-4 > div {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0;
  background: transparent !important;
  border: none !important;
  border-radius: 0;
  margin-bottom: 0;
  transition: none;
  position: relative;
  box-shadow: none !important;
}

.modal-content .space-y-4 > div:hover {
  background: transparent !important;
}

.modal-content .space-y-4 > div:last-of-type {
  margin-bottom: 0;
}

/* Gap between form fields */
.modal-content .space-y-4 {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 8px;
}

/* ——— Labels ——— */
.modal-content label {
  display: block;
  color: #64748b;
  font-size: 0.76rem;
  font-weight: 700;
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: 0.9px;
}

/* ——— Inputs — neomorphic inset ——— */
.modal-content input[type="text"],
.modal-content input[type="email"],
.modal-content input[type="password"],
.modal-content input[type="number"],
.modal-content input[type="date"],
.modal-content input[type="month"],
.modal-content select {
  background: var(--bg-tertiary);
  border: none;
  color: var(--text-primary);
  padding: 13px 16px;
  border-radius: 14px;
  font-size: 0.95rem;
  transition: all 0.22s ease;
  width: 100%;
  font-family: inherit;
  font-weight: 500;
  box-shadow: var(--shadow-inset);
  -webkit-user-select: text;
  user-select: text;
  touch-action: manipulation;
}

@media (max-width: 768px) {
  .modal-content input[type="text"],
  .modal-content input[type="email"],
  .modal-content input[type="password"],
  .modal-content input[type="number"],
  .modal-content input[type="date"],
  .modal-content input[type="month"],
  .modal-content select {
    font-size: 16px;
  }
}

.modal-content input::placeholder {
  color: var(--text-muted);
  font-weight: 400;
}

/* Focus state — neomorphic glow */
.modal-content input[type="text"]:focus,
.modal-content input[type="email"]:focus,
.modal-content input[type="password"]:focus,
.modal-content input[type="number"]:focus,
.modal-content input[type="date"]:focus,
.modal-content input[type="month"]:focus,
.modal-content select:focus {
  outline: none;
  background: var(--bg-tertiary);
  box-shadow:
    var(--shadow-inset),
    0 0 0 3px rgba(59, 130, 246, 0.15);
}

/* Select arrow */
.modal-content select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px 12px;
  padding-right: 40px;
}

/* ——— Type Selector Buttons — neomorphic raised ——— */
.modal-content .btn-transaction-type,
.modal-content .btn-recurring-type,
.modal-content .btn-duration {
  background: var(--bg-secondary);
  border: none !important;
  color: var(--text-secondary);
  padding: 14px 18px !important;
  border-radius: 14px;
  font-weight: 700;
  font-size: 0.93rem;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  box-shadow: var(--shadow-outer);
  min-height: 52px;
  position: relative;
  overflow: hidden;
}

.modal-content .btn-transaction-type::before,
.modal-content .btn-recurring-type::before,
.modal-content .btn-duration::before {
  display: none;
}

.modal-content .btn-transaction-type:hover,
.modal-content .btn-recurring-type:hover,
.modal-content .btn-duration:hover {
  color: var(--text-primary);
  background: var(--bg-secondary);
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
  border: none !important;
}

/* Selected States — neomorphic inset + color accent */
.modal-content .btn-income-selected,
.modal-content .btn-permanent-selected {
  background: #ecfdf5 !important;
  border: none !important;
  border-width: 0 !important;
  color: #065f46 !important;
  box-shadow:
    inset 3px 3px 6px rgba(52, 211, 153, 0.20),
    inset -3px -3px 6px rgba(255, 255, 255, 0.60) !important;
  font-weight: 800;
  min-height: 52px;
}

.modal-content .btn-income-selected:hover,
.modal-content .btn-permanent-selected:hover {
  box-shadow:
    inset 4px 4px 8px rgba(52, 211, 153, 0.25),
    inset -4px -4px 8px rgba(255, 255, 255, 0.65) !important;
  transform: none !important;
}

.modal-content .btn-expense-selected {
  background: #fef2f2 !important;
  border: none !important;
  border-width: 0 !important;
  color: #991b1b !important;
  box-shadow:
    inset 3px 3px 6px rgba(248, 113, 113, 0.20),
    inset -3px -3px 6px rgba(255, 255, 255, 0.60) !important;
  font-weight: 800;
  min-height: 52px;
}

.modal-content .btn-expense-selected:hover {
  box-shadow:
    inset 4px 4px 8px rgba(248, 113, 113, 0.25),
    inset -4px -4px 8px rgba(255, 255, 255, 0.65) !important;
  transform: none !important;
}

.modal-content .btn-temporary-selected {
  background: #fffbeb !important;
  border: none !important;
  border-width: 0 !important;
  color: #78350f !important;
  box-shadow:
    inset 3px 3px 6px rgba(251, 191, 36, 0.20),
    inset -3px -3px 6px rgba(255, 255, 255, 0.60) !important;
  font-weight: 800;
  min-height: 52px;
}

.modal-content .btn-temporary-selected:hover {
  box-shadow:
    inset 4px 4px 8px rgba(251, 191, 36, 0.25),
    inset -4px -4px 8px rgba(255, 255, 255, 0.65) !important;
  transform: none !important;
}

/* ——— Button Group (footer) ——— */
.modal-content .flex.gap-3.pt-4 {
  padding: 20px 32px 30px;
  border-top: none;
  margin-top: 4px;
  gap: 12px;
  display: flex;
  position: relative;
}

.modal-content .flex.gap-3.pt-4::before {
  display: none;
}

.modal-content .flex.gap-3.pt-4 button {
  flex: 1;
  padding: 14px 20px !important;
  font-weight: 700;
  font-size: 0.95rem;
  border-radius: 14px;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

/* ——— Suggestion Boxes — neomorphic ——— */
#descriptionSuggestion,
#recurringDescriptionSuggestion,
.suggestion-box {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: #1e293b !important;
  border-radius: 12px;
  padding: 12px 16px !important;
  font-size: 0.92rem;
  cursor: pointer;
  transition: all 0.22s ease;
  font-weight: 600;
  box-shadow: var(--shadow-sm) !important;
}

#descriptionSuggestion:hover,
#recurringDescriptionSuggestion:hover,
.suggestion-box:hover {
  background: var(--bg-surface) !important;
  border: none !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover) !important;
}

/* ——— Installment Simulation ——— */
.modal-content .installment-simulation-box {
  background: rgba(0, 0, 0, 0.015);
  border: none;
  border-radius: 16px;
  padding: 20px;
  margin-top: 12px;
  box-shadow: none;
}

.modal-content .installment-simulation-box h4 {
  font-weight: 800;
  font-size: 0.90rem;
  color: #475569;
  margin: 0 0 14px 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.modal-content .installment-simulation-box .space-y-2 > div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  font-size: 0.88rem;
  color: #64748b;
  border-bottom: none;
}

.modal-content .installment-simulation-box .space-y-2 > div:last-child {
  border-bottom: none;
}

/* ——— Category Add Button ——— */
.modal-content .bg-green-600,
.modal-content .bg-green-700,
.modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] {
  background: #10b981 !important;
  color: white !important;
  border: none !important;
  border-radius: 14px;
  padding: 11px 14px;
  cursor: pointer;
  transition: all 0.25s ease;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(16, 185, 129, 0.20);
}

.modal-content .bg-green-600:hover,
.modal-content .bg-green-700:hover,
.modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"]:hover {
  background: #059669 !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(16, 185, 129, 0.30);
}

.modal-content .bg-green-600 svg,
.modal-content .bg-green-700 svg,
.modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] svg {
  stroke: white !important;
  color: white !important;
  width: 22px !important;
  height: 22px !important;
  stroke-width: 2.5 !important;
}

/* Hide orphaned duplicate SVG close icons in modal headers */
.modal-content > div:first-of-type > svg {
  display: none !important;
}

/* Modal Helper Text */
.modal-content p {
  font-size: 0.78rem;
  color: #94a3b8;
  margin-top: 6px;
  line-height: 1.5;
  font-weight: 500;
}

.modal-content .text-xs {
  font-size: 0.78rem;
  color: #94a3b8;
  font-weight: 500;
}

/* Modal Form Sub-Groups */
.modal-content .flex.gap-3 {
  display: flex;
  gap: 12px;
  margin-top: 10px;
}

.modal-content .flex.gap-2 {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

/* ============================================= */
/*    10b. CALCULATOR MODAL — PERFECT DESIGN    */
/* ============================================= */

#calculatorModal .modal-content {
  max-width: 360px;
  padding: 0;
  border-radius: 28px;
  overflow: hidden;
  background: var(--bg-secondary);
  box-shadow: var(--shadow-lg);
}

/* ——— Calculator Body ——— */
.calc-body {
  display: flex;
  flex-direction: column;
}

/* ——— Display Area ——— */
.calc-display-area {
  background: var(--bg-tertiary);
  padding: 24px 28px 28px;
  text-align: right;
  position: relative;
  overflow: hidden;
  min-height: 110px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 6px;
  box-shadow: var(--shadow-inset);
  border-radius: 20px;
  margin: 16px 16px 0;
}

.calc-expression {
  font-size: 0.88rem;
  color: rgba(0, 30, 80, 0.35);
  font-weight: 500;
  min-height: 20px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.calc-display-value {
  font-size: 2.8rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.5px;
}

/* ——— Button Grid ——— */
.calc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 18px 20px 20px;
  background: var(--bg-secondary);
}

.calc-grid .calc-btn {
  background: var(--bg-secondary) !important;
  border: none !important;
  color: var(--text-primary) !important;
  padding: 0 !important;
  border-radius: 14px !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  cursor: pointer;
  transition: all 0.18s ease !important;
  box-shadow: var(--shadow-outer) !important;
  min-height: 56px;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.calc-grid .calc-btn:hover {
  background: var(--bg-surface) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-hover) !important;
}

.calc-grid .calc-btn:active {
  transform: scale(0.97) !important;
  box-shadow: var(--shadow-inset) !important;
  transition-duration: 0.06s !important;
}

/* Dot */
.calc-btn-dot {
  font-size: 1.5rem !important;
  font-weight: 900 !important;
}

/* ——— Operators ——— */
.calc-grid .calc-btn-operator {
  background: var(--bg-tertiary) !important;
  color: #1a56db !important;
  box-shadow: var(--shadow-outer) !important;
  font-size: 1.3rem !important;
}

.calc-grid .calc-btn-operator:hover {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-hover) !important;
}

.calc-grid .calc-btn-operator:active {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset) !important;
}

/* ——— Function keys (backspace, percent) ——— */
.calc-grid .calc-btn-fn {
  background: var(--bg-surface) !important;
  color: var(--text-secondary) !important;
  font-size: 1.15rem !important;
  box-shadow: var(--shadow-sm) !important;
}

.calc-grid .calc-btn-fn:hover {
  background: var(--bg-surface) !important;
  box-shadow: var(--shadow-hover) !important;
}

.calc-grid .calc-btn-fn:active {
  box-shadow: var(--shadow-inset) !important;
}

/* ——— AC / Clear ——— */
.calc-grid .calc-btn-clear {
  background: #ecd8d8 !important;
  color: #dc2626 !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  letter-spacing: 1px;
  box-shadow:
    5px 5px 15px rgba(220, 38, 38, 0.10),
    -5px -5px 15px rgba(255, 255, 255, 0.80) !important;
}

.calc-grid .calc-btn-clear:hover {
  background: #e4cccc !important;
  box-shadow:
    8px 8px 20px rgba(220, 38, 38, 0.14),
    -8px -8px 20px rgba(255, 255, 255, 0.90) !important;
}

.calc-grid .calc-btn-clear:active {
  background: #dcc0c0 !important;
  box-shadow:
    inset 3px 3px 8px rgba(220, 38, 38, 0.15),
    inset -3px -3px 8px rgba(255, 255, 255, 0.50) !important;
}

/* ——— Equals ——— */
.calc-grid .calc-btn-equals {
  background: #d4eede !important;
  color: #059669 !important;
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  box-shadow:
    5px 5px 15px rgba(16, 185, 129, 0.10),
    -5px -5px 15px rgba(255, 255, 255, 0.80) !important;
}

.calc-grid .calc-btn-equals:hover {
  background: #c4e6d2 !important;
  box-shadow:
    8px 8px 20px rgba(16, 185, 129, 0.14),
    -8px -8px 20px rgba(255, 255, 255, 0.90) !important;
}

.calc-grid .calc-btn-equals:active {
  background: #b0dcbf !important;
  box-shadow:
    inset 3px 3px 8px rgba(16, 185, 129, 0.15),
    inset -3px -3px 8px rgba(255, 255, 255, 0.50) !important;
}

/* ——— Send / Enviar ——— */
.calc-grid .calc-btn-send {
  background: var(--bg-tertiary) !important;
  color: #1a56db !important;
  font-size: 0.92rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.5px;
  box-shadow: var(--shadow-outer) !important;
}

.calc-grid .calc-btn-send:hover {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-hover) !important;
}

.calc-grid .calc-btn-send:active {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset) !important;
}

/* ============================================= */
/*    10c. ADJUST BALANCE MODAL SPECIFIC        */
/* ============================================= */

#adjustBalanceModal .bg-yellow-900 {
  background: rgba(245, 158, 11, 0.06) !important;
  border: 1px solid rgba(245, 158, 11, 0.18) !important;
  border-radius: 14px;
  padding: 14px 16px;
}

#adjustBalanceModal .bg-yellow-900 p {
  color: #b45309 !important;
  font-weight: 600;
}

/* ============================================= */
/*          11. BUTTONS                         */
/* ============================================= */

/* Visuals moved to: BUTTON INTENT SYSTEM — CONSOLIDATED (end of file) */
/* Keep only structural helpers here. */

button.btn-primary[style*="width: auto"] {
  padding: 12px 22px !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  border-radius: 12px !important;
  position: relative !important;
  white-space: nowrap !important;
  overflow: visible !important;
  width: auto !important;
  transition: transform var(--motion-fast), box-shadow var(--motion-fast), background-color var(--motion-fast), color var(--motion-fast) !important;
}

button.btn-primary[style*="width: auto"]:hover {
  transform: translateY(-2px) !important;
}

button.btn-primary[style*="width: auto"]:active {
  transform: translateY(0) !important;
}

button.btn-primary[style*="width: auto"] svg {
  width: 18px !important;
  height: 18px !important;
  stroke-width: 2.5 !important;
  flex-shrink: 0 !important;
  stroke: currentColor !important;
}

/* Container do botão de ação */
.flex.items-center.gap-2.md\:hidden {
  overflow: visible !important;
}

/* Garante que flex containers não truncam botões */
.flex.items-center.gap-2 > .btn-primary {
  flex-shrink: 0;
}

/* FAB Button - Floating Action Button */
#fabButton {
  background: #0d1636 !important;
  box-shadow: 0 8px 16px rgba(0, 61, 143, 0.3) !important;
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
  position: relative;
  overflow: hidden;
  border-radius: 50% !important;
  border: none !important;
}

#fabButton::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition: width 0.5s, height 0.5s;
}

#fabButton:hover {
  transform: scale(1.12) translateY(-4px) !important;
  box-shadow: 0 12px 24px rgba(0, 61, 143, 0.4) !important;
  background: #1a2449 !important;
}

#fabButton:active {
  transform: scale(0.95) !important;
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.1), inset -4px -4px 8px rgba(255, 255, 255, 0.3) !important;
}

#fabButton svg {
  transition: transform 0.3s ease;
  color: white;
}

#fabButton:hover svg {
  transform: rotate(90deg) scale(1.1);
}
.btn-transaction-type,
.btn-recurring-type,
.btn-duration {
  background: var(--bg-primary);
  border: 1.5px solid rgba(0, 61, 143, 0.15);
  color: var(--text-secondary);
  transition: all 0.25s ease;
  cursor: pointer;
  padding: 10px 16px;
  border-radius: 12px;
  font-size: 0.9rem;
}

.btn-transaction-type:hover,
.btn-recurring-type:hover,
.btn-duration:hover {
  background: rgba(0, 61, 143, 0.08);
  border-color: rgba(0, 61, 143, 0.3);
  color: var(--accent-color);
  transform: translateY(-1px);
}

.btn-income-selected,
.btn-permanent-selected {
  background: rgba(16, 185, 129, 0.12);
  border-color: var(--success);
  color: var(--success);
  transform: none;
}

.btn-expense-selected {
  background: rgba(239, 68, 68, 0.12);
  border-color: var(--danger);
  color: var(--danger);
  transform: none;
}

.btn-temporary-selected {
  background: rgba(245, 158, 11, 0.12);
  border-color: var(--warning);
  color: var(--warning);
  transform: none;
}

.btn-danger {
  color: var(--danger);
  border-color: var(--danger);
}

/* ============================================= */
/*          12. CALCULATOR BUTTONS (legacy)     */
/* ============================================= */
/* Overridden by Section 10b above */

/* ============================================= */
/*          13. TOASTS & MESSAGES              */
/* ============================================= */

.toast {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border: none;
  padding: 16px 24px;
  border-radius: 12px;
  box-shadow: var(--shadow-outer);
  animation: slideDown 0.3s ease;
  z-index: 1000;
  min-width: 300px;
  max-width: 500px;
  cursor: grab;
  user-select: none;
  touch-action: none;
  transition: opacity 0.3s ease;
}

.toast.dragging {
  cursor: grabbing;
  transition: none;
}

.toast.dismissing {
  transition: transform 0.3s ease, opacity 0.3s ease;
}

/* ============================================= */
/*          15. CATEGORIES & CHARTS            */
/* ============================================= */

.category-item {
  background: var(--bg-primary);
  border: none;
  border-radius: 16px;
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s;
  box-shadow: var(--shadow-sm);
}

.category-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

.chart-container {
  background: var(--bg-secondary);
  border: none;
  border-radius: 24px;
  padding: 28px;
  box-shadow: var(--shadow-outer);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.chart-container:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

/* ============================================= */
/*          16. FORM UTILITIES                  */
/* ============================================= */

.month-selector {
  background: var(--bg-tertiary);
  border: none;
  border-radius: 16px;
  box-shadow: var(--shadow-inset);
  transition: all 0.3s ease;
}

.month-label {
  color: var(--accent-color);
  transition: color 0.3s;
}

/* ========================
   CALENDAR FEATURE
   ======================== */

/* Calendar toggle button (next to month-selector) */
.calendar-toggle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: none;
  background: var(--bg-secondary);
  color: var(--accent-color);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: background 0.2s, color 0.2s, box-shadow 0.2s, transform 0.2s;
  flex-shrink: 0;
}

.calendar-toggle-btn:hover {
  background: var(--accent-color);
  color: #fff;
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px);
}

/* Calendar modal content */
.calendar-modal-content {
  max-width: 680px !important;
  padding: 0 !important;
}

.calendar-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 28px 0;
}

.calendar-modal-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-primary);
}

.calendar-modal-close {
  background: none;
  border: none;
  font-size: 1.75rem;
  color: var(--text-secondary);
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background 0.2s, color 0.2s;
}

.calendar-modal-close:hover {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

/* Calendar month navigation */
.calendar-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 20px 28px 12px;
}

.calendar-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: none;
  background: var(--bg-tertiary);
  color: var(--text-primary);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}

.calendar-nav-btn:hover {
  background: var(--accent-color);
  color: #fff;
  transform: scale(1.05);
}

.calendar-month-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--accent-color);
  min-width: 160px;
  text-align: center;
}

/* Calendar summary bar */
.calendar-summary {
  display: flex;
  gap: 10px;
  padding: 0 28px 16px;
  flex-wrap: wrap;
}

.calendar-summary-item {
  flex: 1;
  min-width: 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--bg-tertiary);
}

.calendar-summary-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  margin-bottom: 2px;
}

.calendar-summary-value {
  font-size: 0.85rem;
  font-weight: 700;
}

.calendar-summary-item.income .calendar-summary-value {
  color: #10b981;
}

.calendar-summary-item.expense .calendar-summary-value {
  color: #ef4444;
}

.calendar-summary-item.balance.positive .calendar-summary-value {
  color: #10b981;
}

.calendar-summary-item.balance.negative .calendar-summary-value {
  color: #ef4444;
}

/* Weekday headers */
.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 0 20px;
  margin-bottom: 4px;
}

.calendar-weekdays span {
  text-align: center;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  padding: 6px 0;
}

/* Calendar grid */
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  padding: 0 20px 20px;
}

.calendar-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 62px;
  padding: 6px 2px 4px;
  border-radius: 10px;
  background: var(--bg-primary);
  transition: background 0.15s, box-shadow 0.15s;
  position: relative;
}

.calendar-day.empty {
  background: transparent;
  min-height: 0;
}

.calendar-day.has-data {
  cursor: pointer;
}

.calendar-day.has-data:hover {
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-sm);
}

.calendar-day.today {
  box-shadow: inset 0 0 0 2px var(--accent-color);
}

.calendar-day-number {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.calendar-day.today .calendar-day-number {
  color: var(--accent-color);
  font-weight: 800;
}

.calendar-day-income {
  font-size: 0.6rem;
  font-weight: 700;
  color: #10b981;
  line-height: 1.2;
}

.calendar-day-expense {
  font-size: 0.6rem;
  font-weight: 700;
  color: #ef4444;
  line-height: 1.2;
}

/* Day detail panel */
.calendar-day-detail {
  border-top: 1px solid var(--border-color);
  padding: 20px 28px 24px;
  animation: calDetailSlide 0.25s ease;
}

@keyframes calDetailSlide {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.calendar-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.calendar-detail-header h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
}

.calendar-detail-close {
  background: none;
  border: none;
  font-size: 1.4rem;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
  transition: background 0.2s;
}

.calendar-detail-close:hover {
  background: var(--bg-tertiary);
}

.calendar-detail-empty {
  text-align: center;
  color: var(--text-secondary);
  padding: 16px 0;
  font-size: 0.9rem;
}

.calendar-detail-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.calendar-detail-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--bg-primary);
  gap: 10px;
}

.calendar-detail-item-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex: 1;
}

.calendar-detail-item-left div {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.calendar-detail-item-desc {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-projected-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  background: var(--accent-color);
  color: #fff;
  padding: 1px 6px;
  border-radius: 6px;
  margin-left: 6px;
  vertical-align: middle;
}

.calendar-detail-item-cat {
  font-size: 0.72rem;
  color: var(--text-secondary);
}

.calendar-detail-item-amount {
  font-size: 0.85rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

.calendar-detail-item-amount.income {
  color: #10b981;
}

.calendar-detail-item-amount.expense {
  color: #ef4444;
}

/* Day detail totals */
.calendar-detail-totals {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 10px;
  border-top: 1px solid var(--border-color);
}

.calendar-detail-total {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 3px 0;
}

.calendar-detail-total.income { color: #10b981; }
.calendar-detail-total.expense { color: #ef4444; }
.calendar-detail-total.balance.positive { color: #10b981; font-weight: 700; }
.calendar-detail-total.balance.negative { color: #ef4444; font-weight: 700; }

/* Dark theme overrides for calendar */
[data-theme="dark"] .calendar-toggle-btn {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .calendar-toggle-btn:hover {
  background: var(--accent-color);
  color: #fff;
}

[data-theme="dark"] .calendar-modal-content {
  background: var(--bg-secondary);
}

[data-theme="dark"] .calendar-day {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .calendar-day.has-data:hover {
  background: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .calendar-detail-item {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .calendar-summary-item {
  background: var(--bg-tertiary);
}

/* Calendar responsive */
@media (max-width: 640px) {
  .calendar-modal-content {
    max-width: 100% !important;
    border-radius: 16px !important;
  }

  .calendar-modal-header,
  .calendar-nav,
  .calendar-summary,
  .calendar-day-detail {
    padding-left: 16px;
    padding-right: 16px;
  }

  .calendar-grid,
  .calendar-weekdays {
    padding-left: 8px;
    padding-right: 8px;
    gap: 2px;
  }

  .calendar-day {
    min-height: 52px;
    padding: 4px 1px 3px;
    border-radius: 8px;
  }

  .calendar-day-number {
    font-size: 0.65rem;
  }

  .calendar-day-income,
  .calendar-day-expense {
    font-size: 0.5rem;
  }

  .calendar-summary {
    gap: 6px;
  }

  .calendar-summary-item {
    min-width: 80px;
    padding: 8px 6px;
  }

  .calendar-summary-value {
    font-size: 0.75rem;
  }
}

/* ========================
   END CALENDAR FEATURE
   ======================== */

.installment-simulation-box {
  background: var(--bg-secondary);
  border: none;
  border-radius: 20px;
  padding: 16px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: var(--shadow-sm);
}

.installment-simulation-box:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.installment-title {
  color: var(--accent-color);
  transition: color 0.3s;
}

.installment-label {
  color: var(--text-secondary);
  transition: color 0.3s;
}

.installment-checkbox {
  accent-color: var(--accent-color);
}

/* ============================================= */
/*          17. MOBILE MENU                     */
/* ============================================= */

.mobile-menu-toggle {
  display: none;
  position: fixed;
  top: 20px;
  left: 20px;
  z-index: 101;
  background: var(--bg-secondary);
  border: none;
  border-radius: 8px;
  padding: 8px;
  color: var(--text-primary);
  cursor: pointer;
  transition: all 0.3s ease;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
}

.mobile-menu-toggle:hover {
  background: rgba(0, 61, 143, 0.1);
  border-color: var(--accent-color);
}

.mobile-menu-toggle.active {
  left: calc(280px - 60px);
}

.mobile-menu-toggle.active svg {
  transform: rotate(90deg);
}

.mobile-menu-toggle svg {
  transition: transform 0.3s ease;
  width: 24px;
  height: 24px;
}

.mobile-menu-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 99;
  animation: fadeIn 0.3s ease;
}

.mobile-menu-overlay.active {
  display: block;
}

/* ============================================= */
/*   MOBILE TOP BAR — Background strip          */
/* ============================================= */
.mobile-top-bar {
  display: none;
}

/* ============================================= */
/*   17. LANDING SCREEN — PREMIUM NEOMORPHIC    */
/* ============================================= */

.landing-screen {
  position: fixed;
  inset: 0;
  z-index: 45;
  background: var(--bg-primary);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.landing-ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 15% 15%, rgba(16, 185, 129, 0.18), transparent 28%),
    radial-gradient(circle at 80% 0%, rgba(59, 130, 246, 0.14), transparent 26%),
    radial-gradient(circle at 90% 85%, rgba(16, 185, 129, 0.10), transparent 30%);
}

.landing-shell {
  position: relative;
  z-index: 2;
  width: min(1180px, 100%);
  margin: 0 auto;
  padding: 18px 16px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.landing-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
}

.landing-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.landing-brand-logo {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: drop-shadow(0 4px 10px rgba(16, 185, 129, 0.25));
}

.landing-brand-name {
  font-size: 1.18rem;
  font-weight: 500;
  color: var(--text-primary);
  letter-spacing: -0.3px;
}

.landing-brand-name strong {
  font-weight: 800;
  background: linear-gradient(135deg, #10b981, #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.landing-top-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.landing-hero {
  display: grid;
  grid-template-columns: 1.3fr .9fr;
  gap: 18px;
}

.landing-hero-main,
.landing-hero-side {
  border-radius: 26px;
}

.landing-hero-main {
  padding: 34px 32px;
}

.landing-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 14px;
  background: rgba(16, 185, 129, 0.10);
  color: #059669;
  border: 1px solid rgba(16, 185, 129, 0.2);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.landing-hero-main h1 {
  margin: 14px 0 12px;
  font-size: clamp(1.9rem, 4vw, 3.1rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
  font-weight: 800;
  color: var(--text-primary);
}

.landing-hero-main p {
  margin: 0;
  max-width: 90%;
  color: var(--text-secondary);
  line-height: 1.6;
  font-size: 1.01rem;
}

.landing-cta-row {
  margin-top: 22px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.landing-trust-row {
  margin-top: 22px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.landing-trust-row span {
  padding: 8px 12px;
  border-radius: 12px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  color: var(--text-secondary);
  font-size: .78rem;
  font-weight: 600;
}

.landing-hero-side {
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.landing-hero-side h3 {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.25;
  color: var(--text-primary);
}

.landing-hero-side ul {
  margin: 0;
  padding-left: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: var(--text-secondary);
}

.landing-hero-side li {
  line-height: 1.5;
  font-size: .92rem;
}

.landing-highlight {
  margin-top: auto;
  border-radius: 16px;
  padding: 14px 14px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
}

.landing-highlight p {
  margin: 0;
  color: var(--text-primary);
  font-weight: 600;
  line-height: 1.45;
}

.landing-reveal {
  opacity: 0;
  transform: translateY(18px) scale(.99);
  transition: opacity .6s cubic-bezier(.22,1,.36,1), transform .6s cubic-bezier(.22,1,.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}

.landing-reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.landing-section-head {
  text-align: center;
  margin-bottom: 14px;
}

.landing-section-head h2 {
  margin: 0 0 6px;
  color: var(--text-primary);
  font-size: clamp(1.35rem, 2.5vw, 1.9rem);
  letter-spacing: -0.02em;
}

.landing-section-head p {
  margin: 0;
  color: var(--text-secondary);
  font-size: .94rem;
  line-height: 1.5;
}

.landing-section-head--left {
  text-align: left;
}

.landing-testimonials {
  margin-top: 2px;
}

.landing-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.landing-testimonial-card {
  border-radius: 20px;
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.landing-testimonial-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.6;
  font-size: .92rem;
}

.landing-testimonial-card footer {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.landing-testimonial-card strong {
  color: var(--text-primary);
  font-size: .89rem;
}

.landing-testimonial-card span {
  color: var(--text-muted);
  font-size: .78rem;
}

.landing-faq {
  border-radius: 24px;
  padding: 22px 20px;
}

.landing-faq-list {
  display: grid;
  gap: 10px;
}

.landing-faq-item {
  border-radius: 12px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  padding: 10px 12px;
}

.landing-faq-item summary {
  cursor: pointer;
  color: var(--text-primary);
  font-size: .91rem;
  font-weight: 700;
  list-style: none;
  position: relative;
  padding-right: 20px;
}

.landing-faq-item summary::-webkit-details-marker {
  display: none;
}

.landing-faq-item summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 0;
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1;
}

.landing-faq-item[open] summary::after {
  content: '-';
}

.landing-faq-item p {
  margin: 8px 0 0;
  color: var(--text-secondary);
  font-size: .86rem;
  line-height: 1.5;
}

.plan-intent-overlay {
  position: fixed;
  inset: 0;
  z-index: 70;
  background: rgba(7, 12, 22, 0.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
}

.plan-intent-overlay.hidden {
  display: none !important;
}

.plan-intent-card {
  width: min(520px, 100%);
  border-radius: 22px;
  padding: 24px 20px;
  text-align: center;
}

.plan-intent-card h3 {
  margin: 0;
  color: var(--text-primary);
  font-size: 1.35rem;
}

.plan-intent-card p {
  margin: 8px 0 0;
  color: var(--text-secondary);
  font-size: .92rem;
}

.plan-intent-options {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.plan-intent-option {
  border: none;
  border-radius: 14px;
  background: var(--bg-secondary) !important;
  box-shadow: var(--shadow-outer) !important;
  color: var(--text-primary);
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease;
}

.plan-intent-option:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover) !important;
}

.plan-intent-option.active {
  box-shadow: var(--shadow-inset) !important;
  outline: 2px solid rgba(16, 185, 129, 0.35);
}

.plan-intent-option strong {
  display: block;
  font-size: .92rem;
}

.plan-intent-option span {
  display: block;
  margin-top: 3px;
  color: var(--text-secondary);
  font-size: .8rem;
}

.plan-intent-actions {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

@media (prefers-reduced-motion: reduce) {
  .landing-reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ============================================= */
/*   18. AUTH SCREEN — NEOMORPHIC CLEAN 2026    */
/* ============================================= */

/* --- Screen & Layout --- */
.auth-screen {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-primary);
  font-family: 'Quicksand', 'Poppins', sans-serif;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.auth-screen.hidden {
  display: none !important;
}

.auth-wrapper {
  width: 100%;
  max-width: 980px;
  padding: 20px;
  margin: auto;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 18px;
  align-items: stretch;
}

.auth-info-panel {
  min-width: 0;
}

.auth-info-card {
  height: 100%;
  border-radius: 28px;
  padding: 30px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auth-info-pill {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 12px;
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.2);
  color: #059669;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.auth-info-card h3 {
  margin: 0;
  color: var(--text-primary);
  font-size: 1.5rem;
  line-height: 1.25;
}

.auth-info-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.55;
  font-size: .94rem;
}

.auth-info-card ul {
  margin: 4px 0 0;
  padding-left: 18px;
  color: var(--text-secondary);
  display: flex;
  flex-direction: column;
  gap: 9px;
  font-size: .9rem;
  line-height: 1.45;
}

.auth-back-row {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 8px;
}

.auth-back-btn {
  border: none;
  border-radius: 10px;
  background: var(--bg-secondary) !important;
  box-shadow: var(--shadow-sm) !important;
  color: var(--text-secondary);
  font-size: .82rem;
  font-weight: 700;
  padding: 8px 12px;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, color .2s ease;
}

.auth-back-btn:hover {
  color: var(--text-primary);
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover) !important;
}

/* --- Card principal --- */
.auth-card {
  background: var(--bg-secondary);
  border-radius: 28px;
  box-shadow: var(--shadow-lg);
  padding: 40px 32px 32px;
  text-align: center;
  animation: authSlideIn 0.6s ease-out;
}

@keyframes authSlideIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Auth Brand (logo + name) --- */
.auth-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin: 0 auto 22px;
}
.auth-brand-logo {
  width: 64px;
  height: 64px;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(16, 185, 129, 0.25));
  animation: brandLogoIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.auth-brand-name {
  font-family: 'Quicksand', sans-serif;
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--text-primary);
  letter-spacing: -0.5px;
}
.auth-brand-name strong {
  font-weight: 800;
  background: linear-gradient(135deg, #10b981 0%, #059669 50%, #047857 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

@keyframes brandLogoIn {
  from { opacity: 0; transform: scale(0.7) rotate(-8deg); }
  to   { opacity: 1; transform: scale(1) rotate(0deg); }
}

/* --- Sidebar Brand (logo + name) --- */
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.sidebar-brand-logo {
  width: 36px;
  height: 36px;
  object-fit: contain;
  filter: drop-shadow(0 2px 6px rgba(16, 185, 129, 0.2));
  transition: transform 0.3s ease;
}
.sidebar-brand:hover .sidebar-brand-logo {
  transform: rotate(-6deg) scale(1.08);
}
.sidebar-brand-name {
  font-family: 'Quicksand', sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--text-primary);
  letter-spacing: -0.3px;
  line-height: 1;
}
.sidebar-brand-name strong {
  font-weight: 800;
  background: linear-gradient(135deg, #10b981, #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Legacy compat */
.auth-avatar {
  display: none;
}

/* --- Title & Subtitle --- */
.auth-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
  line-height: 1.2;
}

.auth-subtitle {
  font-size: 0.92rem;
  color: var(--text-secondary);
  margin-bottom: 24px;
  font-weight: 400;
}

/* --- Success message --- */
.auth-success {
  background: var(--accent-color);
  color: #ffffff;
  padding: 10px 16px;
  border-radius: 12px;
  text-align: center;
  margin-bottom: 16px;
  font-size: 0.88rem;
  font-weight: 600;
  box-shadow: var(--shadow-sm);
  animation: authSlideIn 0.4s ease-out;
}

/* --- Form --- */
.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  text-align: left;
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.auth-form.hidden {
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  position: absolute;
  inset: 0;
}

.auth-form:not(.hidden) {
  opacity: 1;
  transform: translateY(0);
  position: relative;
}

/* Reset transparent bg for auth forms (targeted) */
.auth-form {
  background-color: transparent !important;
}

.auth-form > div:not(.auth-field):not(.auth-options):not(.auth-socials):not(.auth-divider):not(.auth-switch) {
  background-color: transparent !important;
}

/* --- Field --- */
.auth-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.auth-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.auth-input {
  background: var(--bg-tertiary) !important;
  border: none !important;
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 0.92rem;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-inset) !important;
  outline: none;
  transition: box-shadow 0.25s ease;
  width: 100%;
}

.auth-input:focus {
  box-shadow:
    var(--shadow-inset),
    0 0 0 3px rgba(59, 130, 246, 0.15) !important;
}

.auth-input::placeholder {
  color: var(--text-muted);
  opacity: 0.8;
}

/* --- Password wrap --- */
.auth-input-wrap {
  position: relative;
}

.auth-input-wrap .auth-input {
  padding-right: 44px;
}

.auth-eye-btn {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent !important;
  border: none;
  cursor: pointer;
  padding: 0;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  outline: none;
}

.auth-eye-btn svg {
  stroke: var(--text-muted);
}

/* --- Options row (remember + forgot) --- */
.auth-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

.auth-remember {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.auth-checkbox {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.25s ease;
  font-size: 12px;
  color: #ffffff;
}

.auth-checkbox.checked {
  background: var(--accent-color) !important;
  box-shadow: 0 2px 8px rgba(var(--accent-rgb, 15, 114, 232), 0.25);
}

.auth-remember-label {
  font-size: 0.82rem;
  color: var(--text-secondary);
  cursor: pointer;
}

.auth-forgot {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-accent);
  text-decoration: none;
  transition: opacity 0.2s;
}

.auth-forgot:hover {
  opacity: 0.75;
}

/* --- Submit button --- */
.auth-submit {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 14px;
  background: var(--accent-color) !important;
  color: #ffffff !important;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--shadow-outer);
  transition: transform 0.22s ease, box-shadow 0.22s ease, opacity 0.22s ease;
  margin-top: 4px;
  letter-spacing: 0.3px;
}

.auth-submit:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.auth-submit:active {
  transform: translateY(1px);
  box-shadow: var(--shadow-inset);
}

/* --- Divider --- */
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0 16px;
  color: var(--text-muted);
  font-size: 0.8rem;
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 2px;
  border-radius: 1px;
  background: transparent;
  box-shadow:
    inset 1px 1px 2px rgba(163, 177, 198, 0.30),
    inset -1px -1px 2px rgba(255, 255, 255, 0.60);
}

/* --- Social buttons --- */
.auth-socials {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 16px;
}

.auth-social-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bg-secondary) !important;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-outer);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.auth-social-btn:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

.auth-social-btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-inset);
}

.auth-social-btn svg {
  width: 22px;
  height: 22px;
  transition: transform 0.2s ease;
}

.auth-social-btn:hover svg {
  transform: scale(1.1);
}

/* Apple icon color adapts to theme */
.auth-social-apple {
  color: var(--text-primary);
}

/* --- Toggle text (switch login/signup) --- */
.auth-switch {
  text-align: center;
  margin-top: 4px;
}

.auth-switch p {
  font-size: 0.85rem;
  color: var(--text-secondary);
}

.auth-switch button {
  background: transparent !important;
  border: none;
  color: var(--text-accent);
  font-weight: 700;
  cursor: pointer;
  font-size: 0.85rem;
  padding: 0;
  transition: opacity 0.2s;
}

.auth-switch button:hover {
  opacity: 0.75;
}

/* --- Footer --- */
.auth-footer {
  text-align: center;
  margin-top: 28px;
  font-size: 0.78rem;
  color: var(--text-muted);
  grid-column: 1 / -1;
}

/* --- Mobile responsive --- */
@media (max-width: 480px) {
  .landing-shell {
    padding: 10px 10px 20px;
  }

  .landing-topbar {
    padding: 10px 12px;
    border-radius: 14px;
  }

  .landing-brand-name {
    font-size: 1.02rem;
  }

  .landing-top-actions {
    gap: 8px;
  }

  .landing-top-actions .btn-primary,
  .landing-top-actions .btn-secondary {
    padding: .65rem .8rem;
    font-size: .82rem;
  }

  .landing-hero {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .landing-section-head {
    text-align: left;
  }

  .landing-testimonials-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .landing-testimonial-card {
    border-radius: 16px;
    padding: 16px 14px;
  }

  .landing-faq {
    border-radius: 18px;
    padding: 16px 12px;
  }

  .landing-faq-item summary {
    font-size: .86rem;
  }

  .landing-faq-item p {
    font-size: .82rem;
  }

  .plan-intent-card {
    border-radius: 18px;
    padding: 18px 14px;
  }

  .plan-intent-card h3 {
    font-size: 1.12rem;
  }

  .landing-hero-main,
  .landing-hero-side {
    border-radius: 18px;
  }

  .landing-hero-main {
    padding: 20px 16px;
  }

  .landing-hero-main p {
    max-width: 100%;
    font-size: .92rem;
  }

  .landing-hero-side {
    padding: 18px 14px;
  }

  .auth-wrapper {
    grid-template-columns: 1fr;
    max-width: 460px;
    padding: 12px;
    gap: 12px;
  }

  .auth-info-panel {
    order: 2;
  }

  .auth-info-card {
    border-radius: 20px;
    padding: 18px 16px;
  }

  .auth-card {
    order: 1;
  }

  .auth-card {
    padding: 28px 20px 24px;
    border-radius: 20px;
  }
  .auth-avatar {
    display: none;
  }
  .auth-brand-logo {
    width: 52px;
    height: 52px;
  }
  .auth-brand-name {
    font-size: 1.3rem;
  }
  .auth-title {
    font-size: 1.5rem;
  }
  .auth-social-btn {
    width: 46px;
    height: 46px;
  }
}

/* ——————————————————————————————————— */
/*   AUTH — DARK THEME NEOMORPHIC      */
/* ——————————————————————————————————— */

[data-theme="dark"] .auth-screen {
  background: var(--bg-primary);
}

[data-theme="dark"] .auth-card {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-lg);
  border: var(--border-highlight);
}

[data-theme="dark"] .auth-avatar {
  display: none;
}

[data-theme="dark"] .auth-brand-logo {
  filter: drop-shadow(0 4px 14px rgba(94, 237, 166, 0.3));
}
[data-theme="dark"] .auth-brand-name {
  color: var(--text-primary);
}
[data-theme="dark"] .auth-brand-name strong {
  background: linear-gradient(135deg, #5eeda6, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-theme="dark"] .sidebar-brand-logo {
  filter: drop-shadow(0 2px 8px rgba(94, 237, 166, 0.25));
}
[data-theme="dark"] .sidebar-brand-name {
  color: var(--text-primary);
}
[data-theme="dark"] .sidebar-brand-name strong {
  background: linear-gradient(135deg, #5eeda6, #34d399);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

[data-theme="dark"] .auth-title {
  color: var(--text-primary);
}

[data-theme="dark"] .auth-subtitle {
  color: var(--text-secondary);
}

[data-theme="dark"] .auth-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .auth-input {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border: var(--border-highlight) !important;
  box-shadow: var(--shadow-inset) !important;
}

[data-theme="dark"] .auth-input:focus {
  box-shadow:
    var(--shadow-inset),
    0 0 0 2px rgba(123, 170, 247, 0.15) !important;
  border-color: rgba(123, 170, 247, 0.18) !important;
}

[data-theme="dark"] .auth-input::placeholder {
  color: var(--text-muted);
}

[data-theme="dark"] .auth-checkbox {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset);
  border: var(--border-highlight);
}

[data-theme="dark"] .auth-checkbox.checked {
  background: var(--text-accent) !important;
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .auth-remember-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .auth-forgot {
  color: var(--text-accent);
}

[data-theme="dark"] .auth-submit {
  background: var(--text-accent) !important;
  color: #0e1525 !important;
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .auth-submit:hover {
  box-shadow: var(--shadow-hover);
}

[data-theme="dark"] .auth-submit:active {
  box-shadow: var(--shadow-inset);
}

[data-theme="dark"] .auth-divider {
  color: var(--text-muted);
}

[data-theme="dark"] .auth-divider::before,
[data-theme="dark"] .auth-divider::after {
  box-shadow: var(--shadow-inset);
}

[data-theme="dark"] .auth-social-btn {
  background: var(--bg-tertiary) !important;
  border: var(--border-highlight);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .auth-social-btn:hover {
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .auth-social-btn:active {
  box-shadow: var(--shadow-inset);
}

[data-theme="dark"] .auth-social-apple {
  color: var(--text-primary);
}

[data-theme="dark"] .auth-switch p {
  color: var(--text-secondary);
}

[data-theme="dark"] .auth-switch button {
  color: var(--text-accent);
}

[data-theme="dark"] .auth-footer {
  color: var(--text-muted);
}

/* ============================================= */
/*         PLAN CHOOSER / UPGRADE MODAL          */
/* ============================================= */

/* ============================================
   PLAN CHOOSER — World-class Pricing UI
   ============================================ */
.plan-chooser-overlay {
  position: fixed;
  inset: 0;
  z-index: 1400;
  background: radial-gradient(ellipse at 50% 0%, rgba(15, 23, 42, 0.85), rgba(2, 6, 23, 0.96));
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  overflow-y: auto;
  animation: pcFadeIn 0.3s ease-out;
}
@keyframes pcFadeIn { from{opacity:0} to{opacity:1} }
@keyframes pcSlideUp { from{opacity:0;transform:translateY(32px) scale(.97)} to{opacity:1;transform:none} }
@keyframes pcCardIn { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
@keyframes pcShimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes pcPulse { 0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.25)} 50%{box-shadow:0 0 0 8px rgba(16,185,129,0)} }
@keyframes pcFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }

/* Shell */
.plan-chooser-shell {
  width: min(960px, 100%);
  max-height: min(92dvh, 920px);
  background: var(--bg-secondary);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 28px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.03), inset 0 1px 0 rgba(255,255,255,0.04);
  padding: 40px 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  overflow-y: auto;
  animation: pcSlideUp 0.5s cubic-bezier(.16,1,.3,1);
}

.plan-chooser-shell-limit {
  width: min(560px, 100%);
}

/* HEADER */
.plan-chooser-head {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.plan-head-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(16,185,129,0.12), rgba(5,150,105,0.08));
  border: 1px solid rgba(16,185,129,0.2);
  color: #34d399;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  animation: pcFloat 3s ease-in-out infinite;
}
.plan-chooser-head h2 {
  margin: 0;
  font-size: 2rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1.2;
  letter-spacing: -0.03em;
}
.plan-chooser-head p {
  margin: 0;
  max-width: 380px;
  color: var(--text-secondary);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* GRID */
.plan-chooser-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}

/* CARDS */
.plan-card {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  transition: transform 0.3s cubic-bezier(.16,1,.3,1), box-shadow 0.3s ease;
  animation: pcCardIn 0.55s cubic-bezier(.16,1,.3,1) both;
}
.plan-card:nth-child(1) { animation-delay: 0.12s; }
.plan-card:nth-child(2) { animation-delay: 0.22s; }
.plan-card:hover { transform: translateY(-4px); }

.plan-card-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 28px 24px;
  position: relative;
  z-index: 2;
}

.plan-card-top {
  padding-left: 36px;
}

/* FREE */
.plan-card-free {
  background: var(--bg-secondary);
  border: 1px solid rgba(148,163,184,0.12);
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.plan-card-free:hover {
  box-shadow: 0 8px 30px rgba(0,0,0,0.1);
  border-color: rgba(148,163,184,0.2);
}

/* PRO */
.plan-card-pro {
  background: linear-gradient(165deg, rgba(16,185,129,0.1) 0%, rgba(16,185,129,0.03) 30%, var(--bg-secondary) 60%);
  border: 1.5px solid rgba(16,185,129,0.35);
  box-shadow: 0 4px 30px rgba(16,185,129,0.12), 0 0 80px rgba(16,185,129,0.06), inset 0 1px 0 rgba(255,255,255,0.06);
}
.plan-card-pro::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 22px;
  background: linear-gradient(105deg, transparent 30%, rgba(16,185,129,0.04) 40%, rgba(16,185,129,0.1) 50%, rgba(16,185,129,0.04) 60%, transparent 70%);
  background-size: 260% 100%;
  animation: pcCardShimmer 5s ease-in-out infinite;
  animation-delay: 1s;
  pointer-events: none;
  z-index: 1;
}
.plan-card-pro:hover {
  box-shadow: 0 16px 50px rgba(16,185,129,0.18), 0 0 100px rgba(16,185,129,0.08), inset 0 1px 0 rgba(255,255,255,0.08);
  border-color: rgba(16,185,129,0.5);
}

/* RIBBON */
.plan-card-ribbon {
  position: absolute;
  top: 18px;
  right: -32px;
  background: linear-gradient(135deg, #34d399, #10b981, #059669);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  padding: 6px 40px;
  transform: rotate(45deg);
  box-shadow: 0 2px 8px rgba(16,185,129,0.3), 0 0 24px rgba(16,185,129,0.25);
  z-index: 4;
  text-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

/* CHIP */
.plan-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  background: rgba(148,163,184,0.1);
  color: var(--text-secondary);
}
.plan-chip.hot {
  background: linear-gradient(135deg, rgba(16,185,129,0.15), rgba(5,150,105,0.1));
  color: #34d399;
}

/* TITLES */
.plan-card h3 {
  margin: 12px 0 0;
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.015em;
}
.plan-tagline {
  margin: 4px 0 0;
  font-size: 0.84rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* PRICE */
.plan-price-block {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.plan-price-row {
  display: flex;
  align-items: baseline;
  gap: 1px;
}
.plan-old-price {
  font-size: 0.82rem;
  font-weight: 600;
  color: #ef4444;
  text-decoration: line-through;
  opacity: 0.85;
}
.plan-currency {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--text-primary);
  align-self: flex-start;
  margin-top: 8px;
  margin-right: 2px;
}
.plan-amount {
  font-size: 3.6rem;
  font-weight: 900;
  color: var(--text-primary);
  line-height: 1;
  letter-spacing: -0.04em;
}
.plan-amount-cents {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-primary);
  align-self: flex-start;
  margin-top: 8px;
}
.plan-period {
  font-size: 0.78rem;
  color: var(--text-secondary);
  font-weight: 500;
}
.plan-period b {
  color: #34d399;
  font-weight: 700;
}
.plan-period-inline {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 600;
  margin-left: 4px;
  align-self: flex-end;
  margin-bottom: 6px;
}

/* RADIO SELECTOR */
.plan-select-radio {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid rgba(148,163,184,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  z-index: 3;
  background: var(--bg-secondary);
}
.plan-radio-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  transform: scale(0);
  transition: all 0.25s cubic-bezier(.16,1,.3,1);
  background: #94a3b8;
}
.plan-card.selected .plan-select-radio {
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15);
}
.plan-card.selected .plan-radio-dot {
  transform: scale(1);
  background: #10b981;
}
.plan-card-free.selected {
  border-color: rgba(99,102,241,0.4) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.1), 0 8px 30px rgba(0,0,0,0.1) !important;
}
.plan-card-free.selected .plan-select-radio {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}
.plan-card-free.selected .plan-radio-dot {
  background: #6366f1;
}
.plan-card-pro.selected {
  border-color: rgba(16,185,129,0.5) !important;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.12), 0 16px 50px rgba(16,185,129,0.18), 0 0 80px rgba(16,185,129,0.06) !important;
}
.plan-card {
  cursor: pointer;
}
.plan-card:hover {
  transform: translateY(-3px);
}

/* CONFIRM BUTTON */
.plan-confirm-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  animation: pcCardIn 0.6s cubic-bezier(.16,1,.3,1) both;
  animation-delay: 0.35s;
}
.plan-confirm-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: none;
  border-radius: 16px;
  min-height: 56px;
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.3s ease;
  width: 100%;
  max-width: 420px;
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
  box-shadow: 0 4px 20px rgba(16,185,129,0.3), 0 1px 3px rgba(0,0,0,0.1);
  animation: pcPulse 2.5s ease-in-out infinite;
  animation-delay: 1s;
}
.plan-confirm-btn:hover {
  background: linear-gradient(135deg, #34d399, #10b981);
  box-shadow: 0 8px 32px rgba(16,185,129,0.4);
  transform: translateY(-2px);
}
.plan-confirm-btn:active { transform: scale(0.97); }
.plan-confirm-btn.free {
  background: linear-gradient(135deg, #6366f1, #4f46e5);
  box-shadow: 0 4px 20px rgba(99,102,241,0.3), 0 1px 3px rgba(0,0,0,0.1);
}
.plan-confirm-btn.free:hover {
  background: linear-gradient(135deg, #818cf8, #6366f1);
  box-shadow: 0 8px 32px rgba(99,102,241,0.4);
}
.plan-confirm-sub {
  font-size: 0.76rem;
  color: var(--text-secondary);
  opacity: 0.7;
  font-weight: 500;
}

/* GUARANTEE */
.plan-guarantee {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-size: 0.74rem;
  color: #34d399;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.08);
  border: 1px solid rgba(16, 185, 129, 0.15);
}

/* DIVIDER */
.plan-card-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(148,163,184,0.12), transparent);
  margin: 20px 0 16px;
}

/* FEATURES */
.plan-features-label {
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  opacity: 0.7;
  margin-bottom: 12px;
  display: block;
}
.plan-features {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.plan-features li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.86rem;
  line-height: 1.3;
}
.plan-features li span {
  flex: 1;
}
.plan-features li b {
  font-weight: 700;
}
.feat-ok {
  color: var(--text-secondary);
}
.feat-ok svg {
  flex-shrink: 0;
  color: #6ea1f7;
}
.feat-no {
  color: var(--text-secondary);
  opacity: 0.45;
}
.feat-no svg {
  flex-shrink: 0;
  color: var(--text-secondary);
  opacity: 0.5;
}
.pro-features .feat-ok svg {
  color: #34d399;
}

/* SOCIAL PROOF */
.plan-social-proof {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  animation: pcCardIn 0.6s cubic-bezier(.16,1,.3,1) both;
  animation-delay: 0.4s;
}
.plan-proof-avatars {
  display: flex;
}
.plan-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  font-weight: 800;
  color: #fff;
  border: 2px solid var(--bg-secondary);
  margin-left: -6px;
}
.plan-avatar:first-child { margin-left: 0; }
.plan-social-proof p {
  margin: 0;
  font-size: 0.82rem;
  color: var(--text-secondary);
}
.plan-social-proof p b {
  color: var(--text-primary);
}

/* CLOSE */
.plan-close-link {
  border: none;
  background: transparent;
  color: var(--text-secondary);
  align-self: center;
  cursor: pointer;
  font-weight: 500;
  font-size: 0.84rem;
  padding: 8px 20px;
  border-radius: 10px;
  transition: all 0.2s ease;
  opacity: 0.5;
}
.plan-close-link:hover {
  background: rgba(255,255,255,0.04);
  opacity: 0.8;
}

/* ═══ ENHANCED PRO MODAL EFFECTS ═══ */

/* Floating ambient orbs */
.plan-chooser-overlay::before,
.plan-chooser-overlay::after {
  content: '';
  position: fixed;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
  z-index: 0;
}
.plan-chooser-overlay::before {
  width: 500px;
  height: 500px;
  background: rgba(16, 185, 129, 0.1);
  top: -180px;
  right: -120px;
  animation: pcOrbDrift 12s ease-in-out infinite;
}
.plan-chooser-overlay::after {
  width: 350px;
  height: 350px;
  background: rgba(99, 102, 241, 0.07);
  bottom: -100px;
  left: -80px;
  animation: pcOrbDrift 15s ease-in-out infinite reverse;
}
@keyframes pcOrbDrift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(40px, -30px) scale(1.1); }
}
@keyframes pcCardShimmer {
  0% { background-position: 260% 0; }
  100% { background-position: -260% 0; }
}

/* Pro card price green gradient */
.plan-card-pro .plan-amount,
.plan-card-pro .plan-amount-cents,
.plan-card-pro .plan-currency {
  background: linear-gradient(135deg, #6ee7b7, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Price header row (old price + discount badge) */
.plan-price-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Discount badge */
.plan-discount-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.15), rgba(239, 68, 68, 0.08));
  border: 1px solid rgba(239, 68, 68, 0.25);
  color: #f87171;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* CTA button shimmer sweep */
.plan-confirm-btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
  animation: pcBtnShimmer 3.5s ease-in-out infinite;
  animation-delay: 2s;
  pointer-events: none;
}
@keyframes pcBtnShimmer {
  0% { left: -100%; }
  40% { left: 160%; }
  100% { left: 160%; }
}

/* Enhanced social proof */
.plan-social-proof {
  padding: 12px 20px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
}

/* ═══ PRO UPGRADE MODAL (settings / limit-reached) ═══ */
.pro-upgrade-shell {
  width: min(540px, calc(100% - 32px));
  max-height: min(92dvh, 860px);
  background: var(--bg-secondary);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 24px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.03), inset 0 1px 0 rgba(255,255,255,0.05);
  padding: 40px 40px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  overflow-y: auto;
  animation: pcSlideUp 0.5s cubic-bezier(.16,1,.3,1);
  position: relative;
  z-index: 1;
}

/* Header */
.pro-upgrade-header {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.pro-upgrade-header h2 {
  margin: 0;
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1.2;
  letter-spacing: -0.03em;
}
.pro-upgrade-gradient {
  background: linear-gradient(135deg, #6ee7b7, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pro-upgrade-header p {
  margin: 0;
  max-width: 380px;
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
}

/* Price area */
.pro-upgrade-price-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 24px 0 8px;
}
.pro-upgrade-old-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pro-upgrade-price-row {
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.pro-upgrade-currency {
  font-size: 1.5rem;
  font-weight: 800;
  align-self: flex-start;
  margin-top: 10px;
  margin-right: 2px;
  background: linear-gradient(135deg, #6ee7b7, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pro-upgrade-amount {
  font-size: 4.2rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #6ee7b7, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pro-upgrade-cents {
  font-size: 1.8rem;
  font-weight: 800;
  align-self: flex-start;
  margin-top: 10px;
  background: linear-gradient(135deg, #6ee7b7, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pro-upgrade-period {
  font-size: 1rem;
  color: var(--text-secondary);
  font-weight: 600;
  align-self: flex-end;
  margin-bottom: 8px;
  margin-left: 4px;
}
.pro-upgrade-savings {
  font-size: 0.82rem;
  color: var(--text-secondary);
  font-weight: 500;
}
.pro-upgrade-savings b {
  color: #34d399;
  font-weight: 700;
}

/* Guarantee pill */
.pro-upgrade-guarantee {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 20px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.08);
  border: 1px solid rgba(16, 185, 129, 0.18);
  color: #34d399;
  font-size: 0.82rem;
  font-weight: 600;
}
.pro-upgrade-guarantee svg {
  flex-shrink: 0;
}

/* Divider */
.pro-upgrade-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(148,163,184,0.12), transparent);
}

/* Features */
.pro-upgrade-features-section {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.pro-upgrade-features-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  opacity: 0.7;
}
.pro-upgrade-features-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 32px;
  width: 100%;
  max-width: 420px;
}
.pro-upgrade-feat {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.3;
}
.pro-upgrade-feat svg {
  flex-shrink: 0;
  color: #34d399;
}
.pro-upgrade-feat b {
  font-weight: 700;
  color: var(--text-primary);
}

/* CTA button */
.pro-upgrade-cta {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: none;
  border-radius: 16px;
  min-height: 56px;
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.3s ease;
  background: linear-gradient(135deg, #10b981, #059669) !important;
  color: #fff;
  box-shadow: 0 4px 24px rgba(16,185,129,0.35), 0 1px 3px rgba(0,0,0,0.1) !important;
  animation: pcPulse 2.5s ease-in-out infinite;
  animation-delay: 1s;
  position: relative;
  overflow: hidden;
}
.pro-upgrade-cta::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
  animation: pcBtnShimmer 3.5s ease-in-out infinite;
  animation-delay: 2s;
  pointer-events: none;
}
.pro-upgrade-cta:hover {
  background: linear-gradient(135deg, #34d399, #10b981) !important;
  box-shadow: 0 8px 32px rgba(16,185,129,0.45) !important;
  transform: translateY(-2px);
}
.pro-upgrade-cta:active {
  transform: scale(0.97);
}
.pro-upgrade-sub {
  font-size: 0.76rem;
  color: var(--text-secondary);
  opacity: 0.7;
  font-weight: 500;
}

/* Responsive */
@media (max-width: 560px) {
  .pro-upgrade-shell {
    width: 100%;
    padding: 28px 20px 20px;
    border-radius: 18px;
    gap: 18px;
    max-height: calc(100dvh - 20px);
  }
  .pro-upgrade-header h2 {
    font-size: 1.4rem;
  }
  .pro-upgrade-amount {
    font-size: 3.2rem;
  }
  .pro-upgrade-cents {
    font-size: 1.4rem;
  }
  .pro-upgrade-currency {
    font-size: 1.2rem;
  }
  .pro-upgrade-features-grid {
    grid-template-columns: 1fr;
    gap: 10px;
    max-width: 100%;
  }
  .pro-upgrade-cta {
    min-height: 50px;
    border-radius: 13px;
    font-size: 0.92rem;
  }
  .pro-upgrade-guarantee {
    font-size: 0.76rem;
    padding: 6px 14px;
  }
}

/* PRO WELCOME POPUP */
.plan-congrats-overlay {
  position: fixed;
  inset: 0;
  z-index: 1450;
  background: radial-gradient(circle at 50% 0%, rgba(16,185,129,0.24), rgba(2,6,23,0.92));
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.plan-congrats-shell {
  width: min(560px, 100%);
  background: var(--bg-secondary);
  border: 1px solid rgba(16,185,129,0.26);
  border-radius: 22px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.38);
  padding: 28px 24px 22px;
  text-align: center;
}

.plan-congrats-badge {
  display: inline-flex;
  margin-bottom: 12px;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: #10b981;
  background: rgba(16,185,129,0.12);
  border: 1px solid rgba(16,185,129,0.22);
}

.plan-congrats-shell h3 {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--text-primary);
}

.plan-congrats-shell p {
  margin: 10px 0 0;
  color: var(--text-secondary);
  line-height: 1.5;
}

.plan-congrats-highlights {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.plan-congrats-highlights span {
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 0.84rem;
  color: var(--text-primary);
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.16);
}

.plan-congrats-btn {
  margin-top: 18px;
  width: 100%;
  min-height: 50px;
  border: none;
  border-radius: 12px;
  font-size: 0.96rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, #10b981, #059669) !important;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}
.plan-congrats-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(16,185,129,0.35);
}

.plan-congrats-confetti {
  font-size: 3rem;
  margin-bottom: 4px;
  animation: congratsBounce 0.6s ease-out;
}

@keyframes congratsBounce {
  0% { transform: scale(0) rotate(-20deg); opacity: 0; }
  60% { transform: scale(1.3) rotate(5deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); }
}

.plan-congrats-status {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  min-height: 24px;
}

.plan-congrats-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(16,185,129,0.25);
  border-top-color: #10b981;
  border-radius: 50%;
  animation: congratsSpin 0.7s linear infinite;
}

@keyframes congratsSpin {
  to { transform: rotate(360deg); }
}

.plan-congrats-overlay {
  animation: congOverlayIn 0.35s ease-out;
}
.plan-congrats-shell {
  animation: congShellIn 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes congOverlayIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes congShellIn {
  from { opacity: 0; transform: scale(0.85) translateY(30px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

/* DARK THEME */
[data-theme="dark"] .plan-chip.hot { color: #6ee7b7; }
[data-theme="dark"] .plan-confirm-btn.free { box-shadow: 0 4px 20px rgba(99,102,241,0.25); }

/* RESPONSIVE */
@media (max-width: 780px) {
  .plan-chooser-overlay {
    align-items: flex-start;
    padding: max(10px, env(safe-area-inset-top)) 10px max(10px, env(safe-area-inset-bottom));
  }
  .plan-chooser-shell {
    width: 100%;
    max-height: calc(100dvh - 20px);
    padding: 20px 14px 14px;
    border-radius: 18px;
    gap: 16px;
  }
  .plan-chooser-head h2 {
    font-size: 1.3rem;
  }
  .plan-chooser-head h2 br { display: none; }
  .plan-chooser-head p {
    font-size: 0.84rem;
    max-width: 100%;
  }
  .plan-chooser-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .plan-card-inner {
    padding: 18px 14px;
  }
  .plan-card-top {
    padding-left: 30px;
  }
  .plan-select-radio {
    top: 14px;
    left: 10px;
    width: 22px;
    height: 22px;
  }
  .plan-radio-dot {
    width: 10px;
    height: 10px;
  }
  .plan-amount {
    font-size: 2.35rem;
  }
  .plan-amount-cents {
    font-size: 1.15rem;
  }
  .plan-features {
    gap: 8px;
  }
  .plan-features li {
    font-size: 0.8rem;
    gap: 8px;
  }
  .plan-confirm-area {
    position: sticky;
    bottom: 0;
    padding-top: 10px;
    margin-top: 4px;
    background: linear-gradient(180deg, rgba(0,0,0,0), var(--bg-secondary) 22%);
    z-index: 3;
  }
  .plan-confirm-btn {
    min-height: 50px;
    border-radius: 13px;
    font-size: 0.9rem;
  }
  .plan-confirm-sub {
    font-size: 0.7rem;
  }
  .plan-social-proof {
    display: none;
  }
  .plan-card-ribbon {
    top: 12px;
    right: -30px;
    font-size: 0.58rem;
    padding: 4px 30px;
  }
  .plan-close-link {
    font-size: 0.8rem;
    padding: 6px 14px;
  }
  .plan-congrats-shell {
    padding: 22px 14px 16px;
    border-radius: 16px;
  }
  .plan-congrats-shell h3 {
    font-size: 1.3rem;
  }
  .plan-congrats-highlights {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 380px) {
  .plan-chooser-shell { padding: 16px 10px 12px; }
  .plan-card-inner { padding: 16px 12px; }
  .plan-amount { font-size: 2.1rem; }
  .plan-currency { font-size: 1.05rem; margin-top: 6px; }
  .plan-period-inline { font-size: 0.78rem; margin-bottom: 4px; }
  .plan-card h3 { font-size: 1.2rem; }
}

[data-theme="dark"] .auth-eye-btn,
[data-theme="dark"] .auth-eye-btn svg {
  color: var(--text-muted);
  stroke: var(--text-muted);
}

[data-theme="dark"] .auth-success {
  background: var(--text-accent);
  color: #0e1525;
}

/* ============================================= */
/*         PLAN LOCKED ITEMS (Soft-Lock)       */
/* ============================================= */

.plan-locked-item {
  position: relative;
  overflow: hidden;
  pointer-events: none;
  user-select: none;
}
.plan-locked-item > *:not(.plan-locked-overlay) {
  opacity: 0.35;
  filter: grayscale(0.5);
}
.plan-locked-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-radius: inherit;
  cursor: pointer;
  pointer-events: auto;
  transition: background 0.2s ease;
  color: #fbbf24;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.plan-locked-overlay:hover {
  background: rgba(0, 0, 0, 0.55);
}
.plan-locked-overlay svg {
  flex-shrink: 0;
  color: #fbbf24;
}

/* ============================================= */
/*          22. THEME & SPECIAL STYLES        */
/* ============================================= */

.active-filter {
  background: var(--text-accent) !important;
  color: white !important;
  border-color: var(--text-accent) !important;
  box-shadow: 0 4px 14px rgba(15, 114, 232, 0.20) !important;
}

#monthIncome {
  color: #059669;
}

#monthExpenses {
  color: #dc2626;
}

#totalBalance.text-green-500 {
  color: #059669;
}

#totalBalance.text-red-500 {
  color: #dc2626;
}

button[onclick*="openCategoryModalFromTransaction"],
button[onclick*="openCardModalFromTransaction"],
button[onclick*="openCategoryModalFromRecurring"],
button[onclick*="openCardModalFromRecurring"] {
  background: #16a34a;
  color: #ffffff;
  border: 2px solid #15803d;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(22, 163, 74, 0.3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 44px;
  font-size: 0.95rem;
}

button[onclick*="openCategoryModalFromTransaction"] svg,
button[onclick*="openCardModalFromTransaction"] svg,
button[onclick*="openCategoryModalFromRecurring"] svg,
button[onclick*="openCardModalFromRecurring"] svg {
  width: 24px;
  height: 24px;
  stroke-width: 2.5;
  flex-shrink: 0;
}

button[onclick*="openCategoryModalFromTransaction"]:hover,
button[onclick*="openCardModalFromTransaction"]:hover,
button[onclick*="openCategoryModalFromRecurring"]:hover,
button[onclick*="openCardModalFromRecurring"]:hover {
  background: #22c55e;
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(22, 163, 74, 0.4);
  border-color: #10b981;
}

button[onclick*="openCategoryModalFromTransaction"]:active,
button[onclick*="openCardModalFromTransaction"]:active,
button[onclick*="openCategoryModalFromRecurring"]:active,
button[onclick*="openCardModalFromRecurring"]:active {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(22, 163, 74, 0.3);
}

/* Calculator Button */
button[onclick*="openCalculator"] {
  color: #10b981 !important;
  font-weight: 700 !important;
  padding: 8px 12px !important;
  border: 2px solid #10b981 !important;
  border-radius: 8px !important;
  background: rgba(16, 185, 129, 0.1) !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 44px !important;
  min-height: 44px !important;
}

button[onclick*="openCalculator"]:hover {
  color: #fff !important;
  background: #10b981 !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
  transform: translateY(-2px) !important;
}

button[onclick*="openCalculator"] svg {
  stroke: currentColor !important;
  stroke-width: 2 !important;
}

/* ============================================= */
/*   23-24. RESPONSIVE — MOBILE OVERHAUL 2026  */
/*   Only mobile ≤768px. Desktop untouched.    */
/* ============================================= */

/* ─── Tablet & small screens (≤768px) ─── */
@media (max-width: 768px) {

  /* Sidebar off-canvas — now hidden by bottom nav system */
  .sidebar {
    display: none !important;
    transform: none !important;
  }
  .sidebar.active {
    display: none !important;
    transform: none !important;
  }

  /* Main content takes full width */
  .main-content {
    margin-left: 0;
    width: 100%;
  }

  /* Hide old mobile menu toggle — replaced by bottom nav */
  .mobile-menu-toggle {
    display: none !important;
  }

  /* Hide old mobile top bar — replaced by bottom nav */
  .mobile-top-bar {
    display: none !important;
  }

  /* Page padding reset */
  .page {
    padding: 0 !important;
  }
  .page > div {
    padding: 16px 16px 140px !important;
  }

  /* Hide old FAB — replaced by contextual FAB */
  #fabButton {
    display: none !important;
  }

  /* ════════════════════════════════════════════════════════
     MOBILE HEADER BAR — Título + seletor mensal lado a lado
     ════════════════════════════════════════════════════════ */

  /* Barra sticky: fica no topo ao rolar, mas começa no fluxo normal */
  #dashboardPage .p-6 > div:first-child,
  #transactionsPage .p-6 > div:first-child,
  #cardsPage .p-6 > div:first-child {
    position: sticky !important;
    top: 0 !important;
    /* Extende a barra para as bordas da tela, compensando o padding da .p-6 */
    margin-left: -16px !important;
    margin-right: -16px !important;
    margin-top: -16px !important;
    margin-bottom: 16px !important;
    z-index: 60;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    padding: 10px 16px !important;
    min-height: 56px !important;
    width: auto !important;
    box-sizing: border-box !important;
    background: color-mix(in srgb, var(--bg-primary) 92%, transparent) !important;
    backdrop-filter: blur(14px) saturate(1.4) !important;
    -webkit-backdrop-filter: blur(14px) saturate(1.4) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12), 0 1px 0 rgba(255,255,255,0.06) inset !important;
  }

  /* Título — esquerda */
  #dashboardPage .p-6 > div:first-child > .order-2.md\:order-1,
  #transactionsPage .p-6 > div:first-child > .order-2.md\:order-1,
  #cardsPage .p-6 > div:first-child > .order-2.md\:order-1 {
    order: 1 !important;
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  /* h2 do título — compacto dentro da barra */
  #dashboardPage .p-6 > div:first-child h2,
  #transactionsPage .p-6 > div:first-child h2,
  #cardsPage .p-6 > div:first-child h2 {
    font-size: 20px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin: 0 !important;
  }

  /* Seletor mensal — direita (não mais flutuante individualmente) */
  #dashboardPage .p-6 > div:first-child > .relative.order-1,
  #transactionsPage .p-6 > div:first-child > .relative.order-1,
  #cardsPage .p-6 > div:first-child > .relative.order-1 {
    order: 2 !important;
    position: static !important;
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
    box-sizing: border-box !important;
  }

  /* Remove os botões duplicados de + Nova no topo (mobile usa + do menu inferior) */
  #dashboardPage .flex.items-center.gap-2.md\:hidden,
  #transactionsPage .flex.items-center.gap-2.md\:hidden,
  #cardsPage .flex.items-center.gap-2.md\:hidden {
    display: none !important;
  }

  /* Month selector — compact inside fixed header bar */
  #dashboardPage .month-selector,
  #transactionsPage .month-selector,
  #cardsPage .month-selector {
    flex: 0 0 162px !important;
    min-width: 162px !important;
    max-width: 162px !important;
    width: 162px !important;
    height: 40px !important;
    padding: 0 4px !important;
    font-size: 13px !important;
    gap: 0 !important;
    justify-content: space-between !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    background: var(--bg-secondary) !important;
    box-shadow: none !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
  }

  /* Arrow buttons inside selector */
  #dashboardPage .month-selector button,
  #transactionsPage .month-selector button,
  #cardsPage .month-selector button {
    padding: 8px !important;
    flex-shrink: 0;
    border-radius: 6px !important;
    background: transparent !important;
    color: var(--text-secondary) !important;
    transition: background 0.15s, color 0.15s !important;
  }
  #dashboardPage .month-selector button:active,
  #transactionsPage .month-selector button:active,
  #cardsPage .month-selector button:active {
    background: var(--bg-tertiary) !important;
    color: var(--text-primary) !important;
  }

  #dashboardPage .month-selector svg,
  #transactionsPage .month-selector svg,
  #cardsPage .month-selector svg {
    width: 16px !important;
    height: 16px !important;
  }

  /* Month label */
  .month-label {
    font-size: 13px !important;
    font-weight: 700 !important;
    white-space: nowrap;
    letter-spacing: 0.2px;
  }

  /* Calendar button — square, same size & radius as menu btn */
  .calendar-toggle-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    border-radius: 8px !important;
    flex-shrink: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--bg-secondary) !important;
    box-shadow: none !important;
    margin-left: 0 !important;
    border: none !important;
    color: var(--accent-color) !important;
    transition: background 0.15s, color 0.15s !important;
  }
  .calendar-toggle-btn:active {
    background: var(--accent-color) !important;
    color: #fff !important;
  }
  .calendar-toggle-btn svg {
    width: 20px !important;
    height: 20px !important;
  }

  /* Back-to-today — mobile aligned with desktop visual */
  .back-to-today-btn {
    position: absolute !important;
    top: calc(100% - 12px) !important;
    left: calc(50% - 24px) !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    padding: 10px 18px !important;
    border-radius: 22px !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    background: var(--bg-secondary) !important;
    color: var(--text-secondary) !important;
    box-shadow: var(--shadow-outer) !important;
    border: none !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.3px !important;
    gap: 8px !important;
    white-space: nowrap !important;
    transition: all 0.2s ease-out !important;
    cursor: pointer !important;
    z-index: 55 !important;
  }
  .back-to-today-btn.visible {
    display: inline-flex !important;
  }
  .back-to-today-btn:hover {
    box-shadow: var(--shadow-hover) !important;
    transform: translateX(-50%) translateY(-2px) !important;
  }
  .back-to-today-btn:active {
    box-shadow: var(--shadow-inset) !important;
    transform: translateX(-50%) translateY(0) !important;
  }
  .back-to-today-btn:active svg {
    stroke: var(--text-secondary) !important;
  }
  .back-to-today-btn svg {
    width: 14px !important;
    height: 14px !important;
    stroke: var(--text-secondary) !important;
    flex-shrink: 0 !important;
    display: block !important;
  }

  /* ── Cards stats ── */
  .stat-card {
    padding: 14px;
    border-radius: 14px !important;
  }
  .stat-card h3 {
    font-size: 13px;
  }
  .stat-card p {
    font-size: 18px;
  }

  /* ── Buttons ── */
  .btn-primary {
    font-size: 13px !important;
    white-space: nowrap !important;
    padding: 8px 14px !important;
    border-radius: 10px !important;
  }

  /* Action buttons (Nova Transação, Novo Cartão, etc.) — compact on mobile */
  button.btn-primary[style*="width: auto"] {
    padding: 7px 12px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    gap: 5px !important;
    border-radius: 8px !important;
    box-shadow: none !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    vertical-align: middle !important;
    line-height: 1.2 !important;
    margin: 0 !important;
  }
  button.btn-primary[style*="width: auto"] svg {
    width: 14px !important;
    height: 14px !important;
  }

  /* ── Charts ── */
  .chart-container {
    padding: 14px;
    border-radius: 14px !important;
  }

  /* ── Headings ── */
  h2 {
    font-size: 22px !important;
  }

  /* Section header rows — h2 + button aligned on same baseline */
  .flex.items-center.justify-between h2,
  .flex.flex-row.items-center h2 {
    margin: 0 !important;
    line-height: 1.2 !important;
  }
  .flex.items-center.justify-between,
  .flex.flex-row.items-center.justify-between {
    align-items: center !important;
    flex-wrap: nowrap !important;
  }
  .flex.items-center.justify-between > button.btn-primary,
  .flex.flex-row.items-center > button.btn-primary {
    align-self: center !important;
    margin: 0 !important;
    line-height: 1.2 !important;
  }

  /* ══════════════════════════════════════════
     MODALS — MOBILE RESPONSIVE
     ══════════════════════════════════════════ */

  /* Overlay — comfortable margin, not edge-to-edge */
  .modal {
    padding: 12px !important;
    padding-bottom: 0 !important;
    align-items: flex-end !important;
    z-index: 99990 !important;
  }

  /* Modais secundários (categoria/cartão) devem ficar acima dos modais principais */
  #categoryModal,
  #cardModal {
    z-index: 99999 !important;
  }

  /* Content — near-full-width bottom-sheet with breathing room */
  .modal-content {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 92vh !important;
    padding: 0 0 80px 0 !important;
    border-radius: 20px 20px 0 0 !important;
    margin: 0 !important;
    animation: modalSlideUp 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
  }

  @keyframes modalSlideUp {
    from { opacity: 0; transform: translateY(100%); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* Modal header — comfortable padding, no separator */
  .modal-content > div:first-of-type {
    padding: 20px 22px 14px !important;
    border-radius: 20px 20px 0 0 !important;
  }
  .modal-content > div:first-of-type::after {
    display: none !important;
  }
  .modal-content h3 {
    font-size: 17px !important;
    line-height: 1.3 !important;
    letter-spacing: -0.4px !important;
  }
  .modal-content .transition-colors {
    width: 32px !important;
    height: 32px !important;
    padding: 6px !important;
    border-radius: 50% !important;
  }

  /* Form body — comfortable side padding */
  .modal-content form {
    padding: 0 22px !important;
  }

  /* Form groups — seamless, no partitions */
  .modal-content .space-y-4 > div {
    padding: 0 !important;
    margin-bottom: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    gap: 5px !important;
  }
  .modal-content .space-y-4 {
    gap: 14px !important;
    display: flex !important;
    flex-direction: column !important;
    padding-bottom: 16px !important;
  }

  /* Labels — compact */
  .modal-content label {
    font-size: 11px !important;
    margin-bottom: 2px !important;
    letter-spacing: 0.5px !important;
  }

  /* Inputs & Selects */
  .modal-content input[type="text"],
  .modal-content input[type="email"],
  .modal-content input[type="password"],
  .modal-content input[type="number"],
  .modal-content input[type="date"],
  .modal-content input[type="month"],
  .modal-content select,
  .modal-content textarea {
    font-size: 14px !important;
    padding: 11px 14px !important;
    border-radius: 12px !important;
    min-height: 42px !important;
  }
  .modal-content select {
    background-position: right 12px center !important;
    padding-right: 32px !important;
  }

  /* Type toggle buttons (Receita / Despesa) */
  .modal-content .btn-transaction-type,
  .modal-content .btn-recurring-type,
  .modal-content .btn-duration,
  .modal-content .btn-income-selected,
  .modal-content .btn-expense-selected,
  .modal-content .btn-permanent-selected,
  .modal-content .btn-temporary-selected {
    padding: 10px 8px !important;
    font-size: 13px !important;
    min-height: 42px !important;
    border-radius: 12px !important;
    gap: 6px !important;
  }
  .modal-content .btn-transaction-type svg,
  .modal-content .btn-recurring-type svg,
  .modal-content .btn-duration svg {
    width: 16px !important;
    height: 16px !important;
  }
  .modal-content .flex.gap-3 {
    gap: 8px !important;
  }

  /* Green "+" buttons beside selects */
  .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] {
    min-width: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    border-radius: 12px !important;
  }
  .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] svg {
    width: 20px !important;
    height: 20px !important;
  }

  /* R$ prefix */
  .modal-content .text-green-500.font-bold.text-lg {
    font-size: 14px !important;
  }

  /* Calculator open button */
  .modal-content .calc-open-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    padding: 0 !important;
    border-radius: 12px !important;
  }
  .modal-content .calc-open-btn svg {
    width: 18px !important;
    height: 18px !important;
  }

  /* Action buttons (Salvar / Cancelar / Deletar) */
  .modal-content .flex.gap-3.pt-4 {
    padding: 16px 22px 22px !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
  }
  .modal-content .flex.gap-3.pt-4 .btn-primary,
  .modal-content .flex.gap-3.pt-4 .btn-secondary {
    padding: 11px 14px !important;
    font-size: 13px !important;
    border-radius: 10px !important;
    min-height: 40px !important;
    flex: 1 1 0% !important;
  }

  /* Installment simulation box */
  .modal-content .installment-simulation-box {
    padding: 10px !important;
    border-radius: 10px !important;
  }
  .modal-content #installmentSchedule {
    max-height: 150px !important;
    font-size: 12px !important;
  }

  /* Adjust balance warning box */
  #adjustBalanceModal .bg-yellow-900 {
    padding: 10px 12px !important;
    border-radius: 10px !important;
  }
  #adjustBalanceModal .bg-yellow-900 p {
    font-size: 11px !important;
  }

  /* ── Calculator Modal ── */
  #calculatorModal .modal-content {
    max-width: 100% !important;
  }
  .calc-body {
    width: 100% !important;
    padding: 0 16px 16px !important;
  }
  .calc-display-area {
    padding: 12px !important;
    border-radius: 12px !important;
    margin-bottom: 10px !important;
  }
  .calc-display-value {
    font-size: 28px !important;
  }
  .calc-expression {
    font-size: 13px !important;
  }
  .calc-grid {
    gap: 6px !important;
  }
  .calc-btn {
    padding: 12px 8px !important;
    font-size: 16px !important;
    border-radius: 10px !important;
    min-height: 44px !important;
  }

  /* ── Calendar Modal ── */
  #calendarModal .modal-content {
    max-width: 100% !important;
  }
  .calendar-modal-header {
    padding: 16px !important;
  }
  .calendar-modal-title {
    font-size: 17px !important;
  }
  .calendar-nav,
  .calendar-summary,
  .calendar-weekdays,
  .calendar-grid,
  .calendar-day-detail {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .calendar-grid {
    gap: 2px !important;
  }
  .calendar-day {
    font-size: 11px !important;
    min-height: 38px !important;
    padding: 2px !important;
    border-radius: 8px !important;
  }
  .calendar-weekdays span {
    font-size: 10px !important;
  }
  .calendar-summary {
    font-size: 12px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    border-radius: 10px !important;
  }

  /* ── Auth screen (new classes) ── */
  .auth-card {
    padding: 28px 20px 24px !important;
    border-radius: 22px !important;
  }
  .auth-title {
    font-size: 1.6rem !important;
  }
  .auth-subtitle {
    font-size: 0.9rem !important;
  }
  .auth-avatar {
    display: none !important;
  }
  .auth-brand-logo {
    width: 50px !important;
    height: 50px !important;
  }
  .auth-brand-name {
    font-size: 1.3rem !important;
  }
  .auth-input {
    padding: 11px 14px !important;
    font-size: 0.9rem !important;
  }
  .auth-submit {
    padding: 12px !important;
    font-size: 0.95rem !important;
  }
  .auth-social-btn {
    width: 46px !important;
    height: 46px !important;
  }
  .auth-label {
    font-size: 0.72rem !important;
  }
  .auth-checkbox {
    width: 20px !important;
    height: 20px !important;
  }
  .auth-switch p,
  .auth-switch button {
    font-size: 0.82rem !important;
  }
}

/* ─── Desktop restoration (≥769px) ─── */
@media (min-width: 769px) {
  .mobile-menu-toggle {
    display: none !important;
  }
  .mobile-top-bar {
    display: none !important;
  }
  #fabButton {
    display: none !important;
  }
  /* Reset container */
  #dashboardPage .relative.order-1,
  #transactionsPage .relative.order-1 {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    gap: 8px !important;
  }
  /* Reset month selector */
  #dashboardPage .month-selector,
  #transactionsPage .month-selector,
  #cardsPage .month-selector {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    width: 280px !important;
    height: auto !important;
    max-width: none !important;
    background: var(--bg-primary) !important;
    box-shadow: var(--shadow-inset) !important;
    border-radius: 16px !important;
  }
  /* Reset calendar btn */
  .calendar-toggle-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    background: var(--bg-primary) !important;
    box-shadow: var(--shadow-sm) !important;
    border-radius: 12px !important;
    margin-left: 0 !important;
    color: var(--accent-color) !important;
  }
  /* Reset back-to-today: absolute + full text */
  .back-to-today-btn {
    position: absolute !important;
    width: auto !important;
    height: auto !important;
    min-width: auto !important;
    margin-left: 0 !important;
    font-size: 13px !important;
    padding: 10px 18px !important;
    border-radius: 22px !important;
    gap: 8px !important;
    background: var(--bg-secondary) !important;
    color: #6b7280 !important;
    box-shadow: var(--shadow-outer) !important;
  }
}

/* ─── Phone (≤480px) ─── */
@media (max-width: 480px) {
  html, body {
    touch-action: pan-y;
    overflow-x: hidden;
  }

  .modal {
    padding: 8px !important;
    padding-bottom: 0 !important;
  }

  .page > div {
    padding: 16px 12px 140px !important;
  }

  #fabButton {
    bottom: 20px !important;
    right: 16px !important;
    width: 52px !important;
    height: 52px !important;
  }
  #fabButton svg {
    width: 22px !important;
    height: 22px !important;
  }

  /* ── Month toolbar: phone — barra sticky com margem negativa para bordas ── */
  #dashboardPage .p-6 > div:first-child,
  #transactionsPage .p-6 > div:first-child,
  #cardsPage .p-6 > div:first-child {
    margin-left: -12px !important;
    margin-right: -12px !important;
    margin-top: -12px !important;
    padding: 8px 12px !important;
  }

  /* ── Month toolbar: phone — seletor mais compacto ── */
  #dashboardPage .p-6 > div:first-child .month-selector,
  #transactionsPage .p-6 > div:first-child .month-selector,
  #cardsPage .p-6 > div:first-child .month-selector {
    flex: 0 0 148px !important;
    min-width: 148px !important;
    max-width: 148px !important;
    width: 148px !important;
    height: 40px !important;
    padding: 0 2px !important;
  }

  #dashboardPage .month-selector,
  #transactionsPage .month-selector,
  #cardsPage .month-selector {
    flex: 0 0 170px !important;
    min-width: 170px !important;
    max-width: 170px !important;
    width: 170px !important;
    height: 40px !important;
    padding: 0 4px !important;
  }

  .month-label {
    font-size: 12px !important;
  }

  #dashboardPage .month-selector button,
  #transactionsPage .month-selector button,
  #cardsPage .month-selector button {
    padding: 6px !important;
  }

  .calendar-toggle-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }
  .calendar-toggle-btn svg {
    width: 18px !important;
    height: 18px !important;
  }

  .back-to-today-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }
  .back-to-today-btn svg {
    width: 18px !important;
    height: 18px !important;
  }

  /* ── Action buttons ── */
  button.btn-primary[style*="width: auto"] {
    padding: 6px 10px !important;
    font-size: 11px !important;
    border-radius: 7px !important;
    gap: 4px !important;
  }
  button.btn-primary[style*="width: auto"] svg {
    width: 12px !important;
    height: 12px !important;
  }

  /* ── Transaction items ── */
  .transaction-item,
  .recurring-item,
  .goal-item {
    padding: 12px !important;
    margin-bottom: 8px !important;
    border-radius: 12px !important;
  }

  .transaction-header,
  .recurring-header,
  .goal-header {
    gap: 8px;
    margin-bottom: 6px;
  }

  .transaction-icon,
  .recurring-icon {
    font-size: 16px;
    min-width: 20px;
  }

  .transaction-description,
  .recurring-title {
    font-size: 13px;
    max-width: 160px;
    word-break: break-word;
  }

  .transaction-meta,
  .recurring-meta {
    font-size: 11px;
    gap: 3px;
  }

  .transaction-amount,
  .recurring-amount {
    font-size: 14px;
    min-width: fit-content;
  }

  .badge-status,
  .badge-projected,
  .recurring-badge {
    font-size: 10px;
    padding: 2px 6px;
  }

  .recurring-expires {
    font-size: 9px;
    padding: 2px 5px;
  }

  .recurring-footer {
    padding-top: 6px;
    gap: 8px;
  }

  .recurring-actions {
    gap: 4px;
  }

  .recurring-actions .action-btn,
  .goal-actions .action-btn {
    padding: 4px 6px;
    width: 28px;
    height: 28px;
  }
  .recurring-actions .action-btn svg,
  .goal-actions .action-btn svg {
    width: 14px;
    height: 14px;
  }

  /* ── Goals ── */
  .goal-title { font-size: 13px; }
  .goal-meta { font-size: 10px; }
  .goal-badge { font-size: 9px; padding: 2px 5px; }

  .goal-values {
    gap: 6px;
    margin-bottom: 8px;
  }
  .goal-value-item { padding: 5px; }
  .goal-value-label { font-size: 9px; }
  .goal-value-amount { font-size: 12px; }

  .goal-progress { gap: 6px; margin-bottom: 8px; }
  .goal-progress-bar-container { height: 5px; }
  .goal-progress-text { font-size: 10px; min-width: 28px; }

  .goal-footer { gap: 4px; }
  .goal-btn { padding: 6px 8px; font-size: 11px; }
  .goal-btn svg { width: 12px; height: 12px; }

  /* ── Stat cards ── */
  .stat-card {
    padding: 12px !important;
    border-radius: 12px !important;
    margin-bottom: 8px !important;
  }

  .stat-card h3 { font-size: 12px; }
  .stat-card p { font-size: 16px; }

  .stat-card .grid.grid-cols-3 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
  }
  .stat-card .grid.grid-cols-3 > div:nth-child(3) {
    grid-column: 1 / -1;
  }
  .stat-card .grid.grid-cols-3 > div {
    padding: 8px !important;
    font-size: 12px;
  }

  .stat-card .flex.items-start.justify-between {
    flex-direction: column !important;
    gap: 6px;
    align-items: flex-start !important;
  }

  .stat-card .flex.gap-2 {
    width: 100%;
    justify-content: flex-end;
    margin-top: 4px;
  }
  .stat-card .flex.gap-2 button {
    padding: 4px !important;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .stat-card .flex.gap-2 svg {
    width: 14px !important;
    height: 14px !important;
  }

  .stat-card .w-full.rounded-full.h-3 {
    height: 5px !important;
  }

  .stat-card .text-xl.font-bold,
  .stat-card h3.text-xl.font-bold {
    font-size: 13px !important;
    word-break: break-word;
  }
  .stat-card .text-lg.font-bold,
  .stat-card h4.font-bold.text-lg {
    font-size: 13px !important;
    word-break: break-word;
  }
  .stat-card .text-2xl.font-bold { font-size: 14px !important; }
  .stat-card .text-xs { font-size: 10px !important; }
  .stat-card span.text-xs {
    font-size: 9px !important;
    padding: 2px 6px !important;
  }

  .stat-card .space-y-4 { gap: 6px !important; }
  .stat-card .space-y-4 > div { padding: 6px !important; }

  .stat-card .flex.items-center.gap-3.mb-2 {
    width: 100%;
    gap: 6px !important;
  }
  .stat-card .flex.items-center.gap-3.mb-2 span {
    font-size: 12px !important;
  }

  .stat-card .flex.items-center.gap-2.mt-1 {
    flex-wrap: wrap;
    gap: 3px !important;
    width: 100%;
    font-size: 10px;
  }
  .stat-card .flex.items-center.gap-2.mt-1 span {
    font-size: 10px !important;
  }

  .stat-card .text-right.flex.items-center.gap-3 {
    width: 100%;
    justify-content: space-between;
    padding-top: 6px;
    border-top: 1px solid var(--border-subtle);
    align-items: center;
  }
  .stat-card .text-right.flex.items-center.gap-3 button {
    padding: 4px !important;
    width: 28px;
    height: 28px;
  }
  .stat-card .text-right.flex.items-center.gap-3 p {
    font-size: 14px !important;
    margin: 0;
  }

  .stat-card .flex.items-center.gap-2.rounded-lg.p-3 {
    width: 100%;
    gap: 6px !important;
    padding: 8px !important;
  }
  .stat-card .flex.items-center.gap-2.rounded-lg.p-3 svg {
    min-width: 12px;
    width: 12px;
    height: 12px;
  }

  /* ── Page content padding ── */
  #transactionsPage .p-6,
  #recurringPage .p-6,
  #goalsPage .p-6 {
    padding: 16px 12px 140px !important;
  }

  /* ── Filter buttons ── */
  .mb-4.flex.gap-2 {
    gap: 4px !important;
    flex-wrap: wrap;
    margin-bottom: 8px !important;
  }
  .mb-4.flex.gap-2 .btn-secondary {
    font-size: 12px !important;
    padding: 6px 10px !important;
    flex: 1;
    min-width: 60px;
  }

  /* ── Auth screen on phone ── */
  .auth-screen {
    padding: 12px;
  }
  .auth-wrapper {
    max-width: 100%;
  }
  .auth-card {
    padding: 24px 18px 20px !important;
    border-radius: 18px !important;
    max-height: calc(100dvh - 24px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .auth-title { font-size: 1.4rem !important; }
  .auth-subtitle {
    font-size: 0.82rem !important;
    margin-bottom: 18px !important;
  }
  .auth-avatar {
    display: none !important;
  }
  .auth-brand-logo {
    width: 44px !important;
    height: 44px !important;
  }
  .auth-brand-name {
    font-size: 1.15rem !important;
  }
  .auth-brand {
    margin-bottom: 14px !important;
  }
  .auth-form { gap: 12px !important; }
  .auth-label { font-size: 0.7rem !important; }
  .auth-input {
    padding: 10px 12px !important;
    font-size: 0.85rem !important;
    border-radius: 10px !important;
  }
  .auth-submit {
    padding: 12px !important;
    font-size: 0.9rem !important;
    border-radius: 10px !important;
    margin-top: 4px !important;
  }
  .auth-divider {
    margin: 14px 0 10px !important;
    font-size: 0.75rem !important;
  }
  .auth-socials {
    gap: 12px !important;
    margin-bottom: 12px !important;
  }
  .auth-social-btn {
    width: 44px !important;
    height: 44px !important;
  }
  .auth-social-btn svg {
    width: 18px !important;
    height: 18px !important;
  }
  .auth-checkbox {
    width: 18px !important;
    height: 18px !important;
  }
  .auth-remember-label { font-size: 0.78rem !important; }
  .auth-forgot { font-size: 0.78rem !important; }
  .auth-switch p,
  .auth-switch button { font-size: 0.78rem !important; }
  .auth-footer { font-size: 0.72rem !important; }
  .auth-success {
    padding: 8px 12px !important;
    font-size: 0.82rem !important;
  }

  /* ── Modals on phone ── */
  .modal-content {
    padding: 0 !important;
    border-radius: 20px 20px 0 0 !important;
    max-height: 93vh !important;
    box-shadow: var(--shadow-lg) !important;
  }
  [data-theme="dark"] .modal-content {
    box-shadow: var(--shadow-lg) !important;
  }
  .modal-content > div:first-of-type {
    padding: 18px 20px 14px !important;
    border-radius: 20px 20px 0 0 !important;
  }
  .modal-content > div:first-of-type::after {
    display: none !important;
  }
  .modal-content h3 {
    font-size: 15px !important;
  }
  .modal-content .transition-colors {
    width: 30px !important;
    height: 30px !important;
    padding: 4px !important;
    border-radius: 10px !important;
    box-shadow: var(--shadow-sm) !important;
  }
  [data-theme="dark"] .modal-content .transition-colors {
    box-shadow: var(--shadow-sm) !important;
  }
  .modal-content form {
    padding: 0 20px !important;
  }
  .modal-content .space-y-4 > div {
    padding: 0 !important;
    margin-bottom: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
  }
  .modal-content .space-y-4 {
    gap: 12px !important;
    padding-bottom: 12px !important;
  }
  .modal-content input[type="text"],
  .modal-content input[type="email"],
  .modal-content input[type="password"],
  .modal-content input[type="number"],
  .modal-content input[type="date"],
  .modal-content input[type="month"],
  .modal-content select,
  .modal-content textarea {
    font-size: 13px !important;
    padding: 10px 12px !important;
    min-height: 40px !important;
    border-radius: 10px !important;
    border: none !important;
    box-shadow: var(--shadow-inset) !important;
  }
  [data-theme="dark"] .modal-content input[type="text"],
  [data-theme="dark"] .modal-content input[type="email"],
  [data-theme="dark"] .modal-content input[type="password"],
  [data-theme="dark"] .modal-content input[type="number"],
  [data-theme="dark"] .modal-content input[type="date"],
  [data-theme="dark"] .modal-content input[type="month"],
  [data-theme="dark"] .modal-content select,
  [data-theme="dark"] .modal-content textarea {
    box-shadow: var(--shadow-inset) !important;
  }
  .modal-content label {
    font-size: 10px !important;
    margin-bottom: 2px !important;
  }
  .modal-content .btn-transaction-type,
  .modal-content .btn-recurring-type,
  .modal-content .btn-duration,
  .modal-content .btn-income-selected,
  .modal-content .btn-expense-selected,
  .modal-content .btn-permanent-selected,
  .modal-content .btn-temporary-selected {
    padding: 9px 6px !important;
    font-size: 12px !important;
    min-height: 40px !important;
    border-radius: 10px !important;
    border: none !important;
  }
  .modal-content .flex.gap-3 {
    gap: 6px !important;
  }
  .modal-content .flex.gap-3.pt-4 {
    padding: 14px 20px 20px !important;
    gap: 8px !important;
  }
  .modal-content .flex.gap-3.pt-4 .btn-primary,
  .modal-content .flex.gap-3.pt-4 .btn-secondary {
    padding: 10px 12px !important;
    font-size: 12px !important;
    min-height: 40px !important;
    border-radius: 10px !important;
  }
  .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] {
    min-width: 40px !important;
    min-height: 40px !important;
    border-radius: 10px !important;
  }
  .modal-content .calc-open-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 38px !important;
    border-radius: 8px !important;
  }
  .calc-btn {
    padding: 10px 6px !important;
    font-size: 15px !important;
    min-height: 40px !important;
  }
  .calc-body {
    padding: 0 12px 12px !important;
  }
  .calc-display-value {
    font-size: 24px !important;
  }

  /* ── h2 ── */
  h2 {
    font-size: 20px !important;
  }
}

/* ─── Extra small phones (≤360px) ─── */
@media (max-width: 360px) {
  .modal {
    padding: 6px !important;
    padding-bottom: 0 !important;
  }

  .page > div {
    padding: 16px 8px 140px !important;
  }

  #fabButton {
    bottom: 16px !important;
    right: 12px !important;
    width: 48px !important;
    height: 48px !important;
  }
  #fabButton svg {
    width: 20px !important;
    height: 20px !important;
  }

  /* Month toolbar: extra-small phone */
  #dashboardPage .relative.order-1,
  #transactionsPage .relative.order-1,
  #cardsPage .relative.order-1 {
    top: 20px !important;
    right: 16px !important;
    height: 36px !important;
    gap: 4px !important;
  }

  #dashboardPage .month-selector,
  #transactionsPage .month-selector,
  #cardsPage .month-selector {
    flex: 0 0 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    width: 150px !important;
    height: 36px !important;
    border-radius: 7px !important;
  }

  .month-label { font-size: 11px !important; }

  #dashboardPage .month-selector button,
  #transactionsPage .month-selector button,
  #cardsPage .month-selector button {
    padding: 4px !important;
  }

  #dashboardPage .month-selector svg,
  #transactionsPage .month-selector svg,
  #cardsPage .month-selector svg {
    width: 14px !important;
    height: 14px !important;
  }

  .calendar-toggle-btn {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 7px !important;
  }
  .calendar-toggle-btn svg {
    width: 16px !important;
    height: 16px !important;
  }

  .back-to-today-btn {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 7px !important;
  }
  .back-to-today-btn svg {
    width: 16px !important;
    height: 16px !important;
  }

  /* Action buttons */
  button.btn-primary[style*="width: auto"] {
    padding: 5px 8px !important;
    font-size: 10px !important;
    border-radius: 6px !important;
    gap: 3px !important;
  }
  button.btn-primary[style*="width: auto"] svg {
    width: 11px !important;
    height: 11px !important;
  }

  /* Transaction items */
  .transaction-item,
  .recurring-item,
  .goal-item {
    padding: 10px !important;
    margin-bottom: 6px !important;
    border-radius: 10px !important;
  }

  .transaction-icon,
  .recurring-icon { font-size: 14px; min-width: 18px; }
  .transaction-description,
  .recurring-title { font-size: 12px; max-width: 130px; }
  .transaction-meta,
  .recurring-meta { font-size: 10px; }
  .transaction-amount,
  .recurring-amount { font-size: 13px; }

  .badge-status,
  .badge-projected,
  .recurring-badge { font-size: 9px; padding: 1px 4px; }

  .recurring-expires { font-size: 8px; padding: 1px 3px; }

  .action-btn,
  .recurring-actions .action-btn {
    padding: 3px 5px;
    width: 24px;
    height: 24px;
  }
  .action-btn svg,
  .recurring-actions .action-btn svg {
    width: 12px;
    height: 12px;
  }

  /* Goals */
  .goal-title { font-size: 12px; max-width: 120px; }
  .goal-meta { font-size: 9px; }
  .goal-badge { font-size: 8px; padding: 1px 3px; }
  .goal-value-label { font-size: 8px; }
  .goal-value-amount { font-size: 10px; }
  .goal-progress-bar-container { height: 4px; }
  .goal-progress-text { font-size: 9px; }
  .goal-btn { padding: 5px 6px; font-size: 10px; }
  .goal-btn svg { width: 11px; height: 11px; }

  /* Stat cards */
  .stat-card {
    padding: 10px !important;
    border-radius: 10px !important;
  }
  .stat-card h3 { font-size: 11px; }
  .stat-card p { font-size: 15px; }
  .stat-card .text-xl.font-bold,
  .stat-card h3.text-xl.font-bold { font-size: 12px !important; }
  .stat-card .text-lg.font-bold,
  .stat-card h4.font-bold.text-lg { font-size: 12px !important; }
  .stat-card .text-2xl.font-bold { font-size: 13px !important; }
  .stat-card .text-xs { font-size: 9px !important; }

  .stat-card .grid.grid-cols-3 > div {
    padding: 6px !important;
    font-size: 10px;
  }
  .stat-card .grid.grid-cols-3 > div p { font-size: 10px !important; }

  .stat-card .flex.gap-2 button { width: 24px; height: 24px; }
  .stat-card .flex.gap-2 svg { width: 12px !important; height: 12px !important; }

  .stat-card .w-full.rounded-full.h-3 { height: 4px !important; }
  .stat-card .space-y-4 { gap: 4px !important; }
  .stat-card .space-y-4 > div { padding: 4px !important; }

  #transactionsPage .p-6,
  #recurringPage .p-6,
  #goalsPage .p-6 {
    padding: 16px 8px 140px !important;
  }

  .mb-4.flex.gap-2 .btn-secondary {
    font-size: 11px !important;
    padding: 4px 8px !important;
  }

  /* Auth */
  .auth-card {
    padding: 18px 14px 16px !important;
    border-radius: 16px !important;
  }
  .auth-title { font-size: 1.2rem !important; }
  .auth-subtitle { font-size: 0.75rem !important; }
  .auth-avatar { display: none !important; }
  .auth-brand-logo { width: 38px !important; height: 38px !important; }
  .auth-brand-name { font-size: 1rem !important; }
  .auth-brand { margin-bottom: 10px !important; gap: 6px !important; }
  .auth-form { gap: 10px !important; }
  .auth-label { font-size: 0.65rem !important; }
  .auth-input {
    padding: 8px 10px !important;
    font-size: 0.8rem !important;
    border-radius: 8px !important;
  }
  .auth-submit {
    padding: 10px !important;
    font-size: 0.82rem !important;
    border-radius: 8px !important;
  }
  .auth-social-btn {
    width: 38px !important;
    height: 38px !important;
  }
  .auth-social-btn svg {
    width: 16px !important;
    height: 16px !important;
  }
  .auth-socials { gap: 10px !important; }
  .auth-checkbox { width: 16px !important; height: 16px !important; }
  .auth-remember-label { font-size: 0.72rem !important; }
  .auth-switch p,
  .auth-switch button { font-size: 0.72rem !important; }

  /* Modals on extra-small phone */
  .modal-content {
    padding: 0 !important;
    border-radius: 18px 18px 0 0 !important;
    box-shadow: var(--shadow-lg) !important;
  }
  [data-theme="dark"] .modal-content {
    box-shadow: var(--shadow-lg) !important;
  }
  .modal-content > div:first-of-type {
    padding: 16px 16px 10px !important;
    border-radius: 18px 18px 0 0 !important;
  }
  .modal-content > div:first-of-type::after {
    display: none !important;
  }
  .modal-content h3 {
    font-size: 14px !important;
  }
  .modal-content .transition-colors {
    width: 26px !important;
    height: 26px !important;
    padding: 4px !important;
    border-radius: 8px !important;
    box-shadow: var(--shadow-sm) !important;
  }
  [data-theme="dark"] .modal-content .transition-colors {
    box-shadow: var(--shadow-sm) !important;
  }
  .modal-content form {
    padding: 0 16px !important;
  }
  .modal-content .space-y-4 > div {
    padding: 0 !important;
    margin-bottom: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
  }
  .modal-content .space-y-4 {
    gap: 10px !important;
    padding-bottom: 10px !important;
  }
  .modal-content input[type="text"],
  .modal-content input[type="email"],
  .modal-content input[type="password"],
  .modal-content input[type="number"],
  .modal-content input[type="date"],
  .modal-content input[type="month"],
  .modal-content select,
  .modal-content textarea {
    font-size: 12px !important;
    padding: 9px 10px !important;
    min-height: 36px !important;
    border-radius: 9px !important;
    border: none !important;
    box-shadow: var(--shadow-inset) !important;
  }
  [data-theme="dark"] .modal-content input[type="text"],
  [data-theme="dark"] .modal-content input[type="email"],
  [data-theme="dark"] .modal-content input[type="password"],
  [data-theme="dark"] .modal-content input[type="number"],
  [data-theme="dark"] .modal-content input[type="date"],
  [data-theme="dark"] .modal-content input[type="month"],
  [data-theme="dark"] .modal-content select,
  [data-theme="dark"] .modal-content textarea {
    box-shadow: var(--shadow-inset) !important;
  }
  .modal-content label {
    font-size: 9.5px !important;
    margin-bottom: 1px !important;
  }
  .modal-content .btn-transaction-type,
  .modal-content .btn-recurring-type,
  .modal-content .btn-duration,
  .modal-content .btn-income-selected,
  .modal-content .btn-expense-selected,
  .modal-content .btn-permanent-selected,
  .modal-content .btn-temporary-selected {
    padding: 8px 5px !important;
    font-size: 11px !important;
    min-height: 36px !important;
    border-radius: 9px !important;
    border: none !important;
  }
  .modal-content .flex.gap-3 {
    gap: 5px !important;
  }
  .modal-content .flex.gap-3.pt-4 {
    padding: 12px 16px 16px !important;
    gap: 6px !important;
  }
  .modal-content .flex.gap-3.pt-4 .btn-primary,
  .modal-content .flex.gap-3.pt-4 .btn-secondary {
    padding: 9px 10px !important;
    font-size: 11px !important;
    min-height: 36px !important;
    border-radius: 9px !important;
  }
  .modal-content .flex.gap-2.items-stretch button[style*="background: #10b981"] {
    min-width: 36px !important;
    min-height: 36px !important;
    border-radius: 9px !important;
  }
  .modal-content .calc-open-btn {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 9px !important;
  }
  .calc-btn {
    padding: 8px 4px !important;
    font-size: 14px !important;
    min-height: 36px !important;
    border-radius: 9px !important;
  }
  .calc-body {
    padding: 0 10px 10px !important;
  }
  .calc-display-value {
    font-size: 22px !important;
  }
  .calc-grid {
    gap: 4px !important;
  }

  h2 { font-size: 18px !important; }
}

/* ============================================= */
/*   NEOMORPHIC DASHBOARD ENHANCEMENTS        */
/* ============================================= */

#dashboardPage .stat-card {
  background: var(--bg-primary);
  box-shadow: var(--shadow-outer);
  border: none;
  border-radius: 18px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#dashboardPage .stat-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

#dashboardPage .chart-container {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
  border: none;
  border-radius: 24px;
  transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#dashboardPage .chart-container:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

#dashboardPage h2 {
  color: var(--text-primary);
  font-weight: 700;
}

#dashboardPage h3 {
  color: var(--text-primary);
  font-weight: 700;
}

#dashboardPage .month-selector {
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  border: none;
  border-radius: 16px;
}

#dashboardPage .month-selector button {
  transition: background-color 0.3s ease, border-radius 0.3s ease;
}

#dashboardPage .month-selector button:hover {
  background: rgba(0, 61, 143, 0.1);
  border-radius: 8px;
}

#transactionsPage .month-selector {
  background: var(--bg-primary);
  box-shadow: var(--shadow-inset);
  border: none;
  border-radius: 16px;
}

#transactionsPage .month-selector button {
  transition: background-color 0.3s ease, border-radius 0.3s ease;
}

#transactionsPage .month-selector button:hover {
  background: rgba(0, 61, 143, 0.1);
  border-radius: 8px;
}

#cardsPage .month-selector {
  background: var(--bg-primary);
  box-shadow: var(--shadow-inset);
  border: none;
  border-radius: 16px;
}

#cardsPage .month-selector button {
  transition: background-color 0.3s ease, border-radius 0.3s ease;
}

#cardsPage .month-selector button:hover {
  background: rgba(0, 61, 143, 0.1);
  border-radius: 8px;
}

/* Estilos adicionais para transações no dashboard */
#dashboardPage .transaction-item {
  background: var(--bg-primary);
  box-shadow: var(--shadow-sm);
  border: none;
  border-radius: 18px;
}

#dashboardPage .transaction-item:hover {
  box-shadow: var(--shadow-hover);
  border: none;
  transform: translateY(-2px);
}

/* Melhoria no menu selector */
.month-label {
  color: #1e293b;
  font-weight: 600;
}

/* Back to Today Button - Neomorphic Theme (base/desktop fallback) */
.back-to-today-btn {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(100% - 16px);
  z-index: 10;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--bg-secondary);
  color: #6b7280;
  font-size: 13px;
  font-weight: 700;
  font-family: 'Quicksand', sans-serif;
  letter-spacing: 0.3px;
  padding: 10px 18px;
  margin: 0;
  border-radius: 22px;
  border: none;
  box-shadow: var(--shadow-outer);
  cursor: pointer;
  transition: all 0.2s ease-out;
  outline: none;
  white-space: nowrap;
  height: auto;
  line-height: 1.2;
  text-decoration: none;
  -webkit-appearance: none;
  appearance: none;
}

.back-to-today-btn.visible {
  display: inline-flex;
}

.back-to-today-btn:hover {
  box-shadow: var(--shadow-hover);
  transform: translateX(-50%) translateY(-2px);
}

.back-to-today-btn:active {
  box-shadow: var(--shadow-inset);
  transform: translateX(-50%) translateY(0);
}

.back-to-today-btn svg {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  stroke: #6b7280;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  display: block;
}

[data-theme="dark"] .back-to-today-btn {
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border: var(--border-highlight);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .back-to-today-btn:hover {
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .back-to-today-btn:active {
  box-shadow: var(--shadow-inset);
}

[data-theme="dark"] .back-to-today-btn svg {
  stroke: var(--text-secondary);
}

/* Center today button relative to month-selector on pages with calendar toggle */
#dashboardPage .back-to-today-btn,
#transactionsPage .back-to-today-btn {
  left: calc(50% - 24px);
}

#dashboardPage .back-to-today-btn:hover,
#transactionsPage .back-to-today-btn:hover {
  transform: translateX(-50%) translateY(-2px);
}

#dashboardPage .back-to-today-btn:active,
#transactionsPage .back-to-today-btn:active {
  transform: translateX(-50%) translateY(0);
}

/*
  DARK MODE PAUSADO / DESATIVADO TEMPORARIAMENTE
  
  - O app está rodando 100% light mode agora
  - CSS está neutro e preparado para dark mode no futuro
  
  Para reativar dark mode no futuro:

.admin-live-banner {
  gap: 16px;
}

.admin-live-banner-copy,
.admin-live-banner-status {
  min-width: 0;
}
    1. Criar [data-theme="dark"] { } com variáveis CSS escuras
    2. Implementar lógica JS para alternar data-theme no <html>
    3. Criar toggleTheme() função funcional
    4. Restaurar elementos de toggle (botão de tema)
    
  O CSS atual não tem nenhuma trava, está totalmente neutro!
*/

/* ============================================= */
/*     FALLBACK: Forçar uso de variáveis CSS   */
/* ============================================= */

/* Cores semânticas que herdam de --success, --danger, etc */
.text-green-400 { color: #059669 !important; }
.text-green-700 { color: #047857 !important; }
.text-blue-400 { color: #2563eb !important; }
.text-yellow-500 { color: #b45309 !important; }
.text-yellow-400 { color: #b45309 !important; }
.text-purple-400 { color: #7c3aed !important; }

/* Estilos para hovering */
.hover\:text-green-500:hover { color: #059669 !important; }
.hover\:text-green-400:hover { color: #059669 !important; }

/* bg-gray-600 used in settings version badge */
.bg-gray-600 { background-color: #e2e8f0 !important; }
.bg-gray-600.bg-opacity-50 { background-color: rgba(226, 232, 240, 0.6) !important; }

/* Background gradients de cores semânticas */
.from-green-500 { background: var(--success) !important; }
.to-green-700 { background: var(--success) !important; }
.from-green-400 { background: var(--success-light) !important; }

/* ============================================= */
/*   LIGHT MODE — TAILWIND DARK-CLASS OVERRIDES  */
/*   Make hardcoded dark Tailwind classes light   */
/* ============================================= */

/* --- Dark backgrounds → light neomorphic --- */
.bg-gray-900 { background-color: var(--bg-secondary) !important; }
.bg-gray-800 { background-color: var(--bg-tertiary) !important; }
.bg-gray-700 { background-color: var(--bg-surface) !important; }
.hover\:bg-gray-600:hover { background-color: var(--bg-tertiary) !important; }
.hover\:bg-red-900:hover { background-color: rgba(239, 68, 68, 0.08) !important; }
.border-gray-700 { border-color: var(--border-color) !important; }
.border-gray-800 { border-color: var(--border-color) !important; }
.border-gray-600 { border-color: var(--border-color) !important; }

/* --- Tailwind gradient overrides for light mode --- */
.bg-gradient-to-r.from-gray-900,
.bg-gradient-to-r.from-gray-800 {
  background: var(--bg-secondary) !important;
  background-image: none !important;
  box-shadow: var(--shadow-outer);
}
.from-gray-800 { --tw-gradient-from: var(--bg-tertiary) !important; }
.via-gray-800 { --tw-gradient-via: var(--bg-tertiary) !important; }
.to-gray-900 { --tw-gradient-to: var(--bg-secondary) !important; }

.bg-gradient-to-r.from-gray-800.to-gray-900 {
  background: transparent !important;
  background-image: none !important;
}

/* --- White text → readable dark text on light bg --- */
.bg-gray-900 .text-white,
.bg-gray-800 .text-white {
  color: var(--text-primary) !important;
}
.bg-gray-900 h3.text-white,
.bg-gray-800 h3.text-white {
  color: var(--text-primary) !important;
}

/* Standalone text-white in pagination/info contexts */
.text-sm .text-white,
.text-sm.font-bold .text-white,
span.text-white {
  color: var(--text-primary) !important;
}

h4.text-white {
  color: var(--text-primary) !important;
}

/* --- Gray text → adequate contrast on light --- */
.text-gray-300 { color: #64748b !important; }
.text-gray-400 { color: #64748b !important; }
.text-gray-500 { color: #475569 !important; }
.text-gray-600 { color: #334155 !important; }
.hover\:text-white:hover { color: var(--text-primary) !important; }

/* --- Progress bar bg in light mode --- */
.bg-gray-700.rounded-full { background-color: var(--bg-tertiary) !important; }
.w-px.bg-gray-700 { background-color: var(--border-color) !important; }

/* --- Pagination/nav buttons in light mode --- */
.bg-gray-800.text-gray-600 {
  background-color: var(--bg-surface) !important;
  color: var(--text-muted) !important;
}

.bg-gray-900.border-2 {
  background-color: var(--bg-secondary) !important;
  box-shadow: var(--shadow-outer);
  border-color: var(--border-color) !important;
}

.bg-gray-900 .bg-gray-900 {
  background-color: var(--bg-secondary) !important;
}

/* --- Gradient text inside cards is fine, just ensure base text is dark --- */
.bg-gray-900 .text-sm.text-gray-400,
.bg-gray-900 .text-xs.text-gray-400,
.bg-gray-900 .text-xs.text-gray-500,
.bg-gray-900 .text-xs.text-gray-600,
.bg-gray-900 .text-sm.text-gray-500 {
  color: #64748b !important;
}

.bg-gray-900 .font-bold.text-gray-400 {
  color: #475569 !important;
}

/* --- Blue gradient buttons in light mode --- */
.from-blue-600 { background-color: #2563eb !important; }
.to-blue-700 { background-color: #1d4ed8 !important; }
.bg-gradient-to-r.from-blue-600 {
  background: #2563eb !important;
  color: #ffffff !important;
  box-shadow: var(--shadow-outer);
}
.bg-gradient-to-r.from-blue-600 .text-white {
  color: #ffffff !important;
}

/* --- Shadow inner → neomorphic inset --- */
.shadow-inner {
  box-shadow: var(--shadow-inset) !important;
}

/* --- Hover shadows → neomorphic --- */
.hover\:shadow-lg:hover {
  box-shadow: var(--shadow-hover) !important;
}

.hover\:shadow-xl:hover {
  box-shadow: var(--shadow-hover) !important;
}

.shadow-lg {
  box-shadow: var(--shadow-outer) !important;
}

/* Tooltip e suggestion box */
.description-suggestion {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 4px;
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
  background: var(--bg-secondary);
  border: none;
  color: var(--text-primary);
}

.description-suggestion.hidden {
  display: none !important;
}

.description-suggestion:hover {
  background: var(--bg-tertiary);
  color: var(--accent-color);
}

/* Botão calculadora (abre a calculadora no modal de transação) */
.calc-open-btn {
  background: var(--bg-secondary) !important;
  border: none !important;
  padding: 10px 14px;
  border-radius: 16px;
  min-width: 48px;
  min-height: 48px;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: var(--shadow-outer);
  color: #065f46 !important;
  cursor: pointer;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s cubic-bezier(.4,0,.2,1), background-color 0.25s cubic-bezier(.4,0,.2,1);
  flex-shrink: 0;
}

.calc-open-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
  background: var(--bg-surface) !important;
}

.calc-open-btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-inset);
}

.calc-open-btn svg {
  display: block !important;
  width: 22px !important;
  height: 22px !important;
  stroke: #065f46 !important;
  color: #065f46 !important;
  fill: none !important;
  flex-shrink: 0;
}
.calc-open-btn svg circle,
.calc-open-btn svg rect,
.calc-open-btn svg path {
  stroke: #065f46 !important;
}
.calc-open-btn svg circle[fill="currentColor"] {
  fill: #065f46 !important;
}

/* Dark mode calc button */
[data-theme="dark"] .calc-open-btn {
  background: rgba(123, 170, 247, 0.18) !important;
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight) !important;
}

[data-theme="dark"] .calc-open-btn:hover {
  background: rgba(123, 170, 247, 0.28) !important;
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .calc-open-btn svg {
  stroke: var(--text-accent) !important;
  color: var(--text-accent) !important;
}
[data-theme="dark"] .calc-open-btn svg circle[fill="currentColor"] {
  fill: var(--text-accent) !important;
}

/* ================================================================= */
/*  DARK THEME — NEOMORPHIC CLEAN MINIMALIST — COMPLETE ENHANCEMENT  */
/*  Overrides & additions for full dark coverage                     */
/* ================================================================= */

/* ——————————————————————————————————— */
/*   SIDEBAR OVERRIDES                 */
/* ——————————————————————————————————— */

[data-theme="dark"] .sidebar {
  border-right: 1px solid var(--border-subtle);
}

[data-theme="dark"] .sidebar-item {
  box-shadow: none;
  margin: 4px 12px;
}

[data-theme="dark"] .sidebar-item:hover {
  background: rgba(123, 170, 247, 0.06);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

[data-theme="dark"] .sidebar-item.active {
  background: rgba(123, 170, 247, 0.10);
  border-left-color: var(--text-accent);
  box-shadow: var(--shadow-sm);
}

/* ——————————————————————————————————— */
/*   BUTTON OVERRIDES                  */
/* ——————————————————————————————————— */

/* Dark button visuals moved to consolidated intent block at end of file */

/* FAB */
[data-theme="dark"] #fabButton {
  background: var(--text-accent) !important;
  box-shadow: var(--shadow-outer) !important;
  border: var(--border-highlight) !important;
}

[data-theme="dark"] #fabButton:hover {
  background: #6a9ce6 !important;
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] #fabButton:active {
  box-shadow: var(--shadow-inset) !important;
}

/* ——————————————————————————————————— */
/*   SCROLLBAR — GLOBAL LIGHT          */
/* ——————————————————————————————————— */

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-primary);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: rgba(100, 116, 139, 0.14);
  border-radius: 4px;
  box-shadow:
    inset 1px 1px 2px rgba(163, 177, 198, 0.30),
    inset -1px -1px 2px rgba(255, 255, 255, 0.50);
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(100, 116, 139, 0.25);
}

::-webkit-scrollbar-corner {
  background: transparent;
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(100, 116, 139, 0.14) transparent;
}

[data-theme="dark"] * {
  scrollbar-color: rgba(123, 170, 247, 0.10) transparent;
}

/* ——————————————————————————————————— */
/*   SCROLLBAR — GLOBAL DARK          */
/* ——————————————————————————————————— */

[data-theme="dark"] ::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

[data-theme="dark"] ::-webkit-scrollbar-track {
  background: var(--bg-primary);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: rgba(123, 170, 247, 0.10);
  border-radius: 4px;
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
  background: rgba(123, 170, 247, 0.20);
}

/* ——————————————————————————————————— */
/*   TRANSACTION / RECURRING / GOAL    */
/* ——————————————————————————————————— */

[data-theme="dark"] .transaction-item {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight);
  border-radius: 20px;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s cubic-bezier(.4,0,.2,1), border-color 0.25s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] .transaction-item:hover {
  box-shadow: var(--shadow-hover);
  border-color: rgba(123, 170, 247, 0.10);
  transform: translateY(-2px);
}

[data-theme="dark"] .transaction-item.projected {
  background: rgba(123, 170, 247, 0.04);
  border: 2px dashed rgba(123, 170, 247, 0.18);
}

[data-theme="dark"] .transaction-description {
  color: var(--text-primary);
}

[data-theme="dark"] .transaction-meta {
  color: var(--text-secondary);
}

[data-theme="dark"] .transaction-actions {
  border-top-color: var(--border-subtle);
}

[data-theme="dark"] .edit-btn {
  color: var(--text-accent) !important;
}

[data-theme="dark"] .edit-btn:hover {
  background: rgba(123, 170, 247, 0.10) !important;
}

[data-theme="dark"] .delete-btn {
  color: var(--danger) !important;
}

[data-theme="dark"] .delete-btn:hover {
  background: rgba(255, 128, 128, 0.10) !important;
}

[data-theme="dark"] .recurring-item {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight);
  border-radius: 20px;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] .recurring-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

[data-theme="dark"] .recurring-title {
  color: var(--text-primary);
}

[data-theme="dark"] .recurring-meta {
  color: var(--text-secondary);
}

[data-theme="dark"] .recurring-footer {
  border-top-color: var(--border-subtle);
}

[data-theme="dark"] .goal-item {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight);
  border-radius: 20px;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1), box-shadow 0.25s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] .goal-item:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

[data-theme="dark"] .goal-title {
  color: var(--text-primary);
}

[data-theme="dark"] .goal-meta {
  color: var(--text-secondary);
}

[data-theme="dark"] .goal-value-item {
  background: rgba(123, 170, 247, 0.06);
}

[data-theme="dark"] .goal-value-label {
  color: var(--text-muted);
}

[data-theme="dark"] .goal-progress-bar-container {
  background: rgba(123, 170, 247, 0.10);
}

/* Goal buttons – light theme explicit colours (beats button{background:transparent!important}) */
:root:not([data-theme="dark"]) button.goal-btn.add-btn,
:root:not([data-theme="dark"]) .goal-btn.add-btn {
  background: var(--success) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(16,185,129,0.3) !important;
}

:root:not([data-theme="dark"]) button.goal-btn.add-btn:hover,
:root:not([data-theme="dark"]) .goal-btn.add-btn:hover {
  background: #0da870 !important;
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(16,185,129,0.45) !important;
}

:root:not([data-theme="dark"]) button.goal-btn.withdraw-btn,
:root:not([data-theme="dark"]) .goal-btn.withdraw-btn {
  background: #e2e8f0 !important;
  color: #1e293b !important;
  border: 1.5px solid #94a3b8 !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08) !important;
}

:root:not([data-theme="dark"]) button.goal-btn.withdraw-btn:hover,
:root:not([data-theme="dark"]) .goal-btn.withdraw-btn:hover {
  background: #3b82f6 !important;
  color: #fff !important;
  border-color: #3b82f6 !important;
  box-shadow: 0 4px 14px rgba(59,130,246,0.35) !important;
}

[data-theme="dark"] .goal-btn.add-btn {
  background: var(--success) !important;
  color: #0d2818 !important;
}

[data-theme="dark"] .goal-btn.withdraw-btn {
  background: var(--text-accent) !important;
  color: #ffffff !important;
}

/* ——————————————————————————————————— */
/*   FILTER BUTTONS                    */
/* ——————————————————————————————————— */

[data-theme="dark"] .filter-btn,
[data-theme="dark"] .btn-filter {
  background: var(--bg-tertiary) !important;
  color: var(--text-secondary) !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid rgba(255, 255, 255, 0.04) !important;
}

[data-theme="dark"] .filter-btn:hover,
[data-theme="dark"] .btn-filter:hover {
  background: rgba(123, 170, 247, 0.08) !important;
  color: var(--text-accent) !important;
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] .filter-btn.active,
[data-theme="dark"] .btn-filter.active {
  background: rgba(123, 170, 247, 0.14) !important;
  color: var(--text-accent) !important;
}

[data-theme="dark"] .active-filter {
  background: var(--text-accent) !important;
  color: #ffffff !important;
  border-color: var(--text-accent) !important;
}

/* ============================================= */


/* ============================================= */
/*   MODAL CANCELAMENTO DE PLANO                 */
/* ============================================= */

/* Cancel Plan Overlay */
.plan-cancel-overlay {
  position: fixed;
  inset: 0;
  z-index: 1450;
  background: radial-gradient(circle at 50% 0%, rgba(239,68,68,0.15), rgba(2,6,23,0.92));
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  animation: cancelOverlayIn 0.3s ease-out;
}
@keyframes cancelOverlayIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.plan-cancel-shell {
  position: relative;
  width: min(480px, 100%);
  background: var(--bg-secondary);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 22px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4);
  padding: 32px 28px 26px;
  text-align: center;
  animation: cancelShellIn 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes cancelShellIn {
  from { opacity: 0; transform: scale(0.88) translateY(24px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

.plan-cancel-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  border: none;
  background: transparent !important;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.plan-cancel-close:hover {
  background: rgba(255,255,255,0.08) !important;
  color: var(--text-primary);
}

.plan-cancel-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(239,68,68,0.1);
  color: #f87171;
  margin-bottom: 14px;
}

.plan-cancel-title {
  margin: 0;
  font-size: 1.45rem;
  font-weight: 900;
  color: var(--text-primary);
}

.plan-cancel-desc {
  margin: 8px 0 0;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.plan-cancel-lose-list {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  text-align: left;
}

.plan-cancel-lose-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 11px;
  font-size: 0.82rem;
  font-weight: 600;
  color: #fca5a5;
  background: rgba(239,68,68,0.07);
  border: 1px solid rgba(239,68,68,0.13);
}
.plan-cancel-lose-item svg {
  flex-shrink: 0;
  color: #ef4444;
  opacity: 0.7;
}

.plan-cancel-note {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 11px;
  font-size: 0.78rem;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
}
.plan-cancel-note svg {
  flex-shrink: 0;
  opacity: 0.5;
}

.plan-cancel-actions {
  display: flex;
  gap: 12px;
  margin-top: 22px;
}

.plan-cancel-btn-back {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 50px;
  border-radius: 13px;
  border: 1px solid rgba(16,185,129,0.3);
  background: rgba(16,185,129,0.08) !important;
  color: #10b981;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
}
.plan-cancel-btn-back:hover {
  background: rgba(16,185,129,0.15) !important;
  border-color: rgba(16,185,129,0.5);
  transform: translateY(-1px);
}

.plan-cancel-btn-confirm {
  flex: 1;
  min-height: 50px;
  border-radius: 13px;
  border: 1px solid rgba(239,68,68,0.25);
  background: rgba(239,68,68,0.1) !important;
  color: #f87171;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.plan-cancel-btn-confirm:hover {
  background: rgba(239,68,68,0.18) !important;
  border-color: rgba(239,68,68,0.4);
}

@media (max-width: 480px) {
  .plan-cancel-shell { padding: 24px 18px 20px; }
  .plan-cancel-lose-list { grid-template-columns: 1fr; }
  .plan-cancel-actions { flex-direction: column; }
}

/* ============================================= */
/*           ADMIN DASHBOARD PAGE                */
/* ============================================= */

.admin-page-wrap {
  display: grid;
  gap: 18px;
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
}

#adminPage,
#adminPage .admin-page-wrap,
#adminPage .admin-dashboard-root,
#adminPage .admin-section-grid,
#adminPage .admin-panel,
#adminPage .admin-panel > *,
#adminPage .admin-kpi-card,
#adminPage .admin-metric-list > div,
#adminPage .admin-filter-bar,
#adminPage .admin-history-item,
#adminPage .admin-table-wrap,
#adminPage .admin-table,
#adminPage .admin-chart,
#adminPage .admin-chart svg {
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.admin-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.admin-subtitle {
  color: var(--text-secondary);
  margin-top: 6px;
  font-size: 0.95rem;
  overflow-wrap: anywhere;
}

.admin-dashboard-root {
  display: grid;
  gap: 16px;
}

.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.adm-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

.adm-kpi {
  background: var(--bg-secondary);
  border-radius: 14px;
  box-shadow: var(--shadow-outer);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-left: 3px solid var(--kpi-accent);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.adm-kpi:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.adm-kpi-top {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.adm-kpi-icon {
  width: 32px;
  height: 32px;
  min-width: 32px;
  background: rgba(var(--kpi-accent-rgb, 15, 114, 232), 0.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--kpi-accent);
  flex-shrink: 0;
}

.adm-kpi-icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
}

.adm-kpi-label {
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.adm-kpi-value {
  font-size: 1.4rem;
  color: var(--kpi-accent);
  font-weight: 700;
  line-height: 1;
}

.adm-icon-sm {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-accent);
  flex-shrink: 0;
}

.adm-icon-sm svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
}

.admin-kpi-card {
  background: var(--bg-secondary);
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
  padding: 14px;
  display: grid;
  gap: 8px;
}

.admin-kpi-card span {
  font-size: 0.8rem;
  color: var(--text-secondary);
}

.admin-kpi-card strong {
  font-size: 1.2rem;
  color: var(--text-primary);
}

.adm-plan-card {
  background: var(--bg-secondary);
  border-radius: 14px;
  box-shadow: var(--shadow-outer);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-top: 3px solid var(--plan-color);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.adm-plan-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.adm-plan-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  color: var(--text-primary);
}

.adm-plan-icon {
  width: 28px;
  height: 28px;
  min-width: 28px;
  background: rgba(var(--plan-color-rgb), 0.15);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--plan-color);
}

.adm-plan-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
}

.adm-plan-card-count {
  font-size: 1.8rem;
  color: var(--plan-color);
  font-weight: 700;
}

.adm-plan-bar {
  width: 100%;
  height: 6px;
  background: var(--bg-tertiary);
  border-radius: 3px;
  overflow: hidden;
  box-shadow: var(--shadow-inset);
}

.adm-plan-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
}

.admin-section-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.admin-panel {
  background: var(--bg-secondary);
  border-radius: 18px;
  box-shadow: var(--shadow-outer);
  padding: 16px;
}

.admin-panel-full {
  grid-column: 1 / -1;
}

.admin-panel h3 {
  margin-bottom: 12px;
  font-size: 1.04rem;
}

.admin-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.admin-panel-head small {
  color: var(--text-muted);
}

.admin-metric-list {
  display: grid;
  gap: 8px;
}

.admin-metric-list > div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
}

.admin-metric-list span {
  color: var(--text-secondary);
  font-size: 0.86rem;
  overflow-wrap: anywhere;
}

.admin-metric-list strong {
  font-size: 0.92rem;
  color: var(--text-primary);
  overflow-wrap: anywhere;
}

.admin-table-wrap {
  overflow-x: auto;
  border-radius: 12px;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 620px;
}

.admin-table th,
.admin-table td {
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 0.85rem;
}

.admin-table th {
  color: var(--text-secondary);
  font-weight: 700;
  background: var(--bg-tertiary);
}

.admin-table td {
  color: var(--text-primary);
}

.admin-customer-scroll {
  max-height: 430px;
  overflow-y: auto;
  overflow-x: hidden;
}

.admin-customer-table {
  min-width: 0;
  width: 100%;
  table-layout: fixed;
}

.admin-customer-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}

.admin-customer-table th,
.admin-customer-table td {
  font-size: 0.8rem;
  padding: 8px 8px;
  white-space: normal;
  word-break: break-word;
  vertical-align: middle;
}

.admin-customer-table th:nth-child(1),
.admin-customer-table td:nth-child(1) {
  width: 26%;
}

.admin-customer-table th:nth-child(2),
.admin-customer-table td:nth-child(2) {
  width: 12%;
}

.admin-customer-table th:nth-child(3),
.admin-customer-table td:nth-child(3) {
  width: 14%;
}

.admin-customer-table th:nth-child(4),
.admin-customer-table td:nth-child(4) {
  width: 18%;
}

.admin-customer-table th:nth-child(5),
.admin-customer-table td:nth-child(5) {
  width: 14%;
}

.admin-customer-table th:nth-child(6),
.admin-customer-table td:nth-child(6) {
  width: 16%;
}

.admin-customer-table .admin-customer-cell {
  gap: 2px;
}

.admin-customer-table .admin-customer-cell small {
  font-size: 0.72rem;
}

.admin-customer-table .admin-mini-btn {
  width: 100%;
  min-height: 34px;
  padding: 7px 8px;
  font-size: 0.74rem;
}

.admin-warning {
  margin-top: 10px;
  color: var(--warning);
  font-size: 0.88rem;
}

.admin-chart {
  width: 100%;
  min-height: 240px;
}

.admin-chart-empty {
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  font-size: 0.9rem;
}

.admin-chart-legend {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.admin-chart-legend-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
  font-size: 0.82rem;
  color: var(--text-secondary);
}

.admin-chart-legend-left {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.admin-chart-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  flex-shrink: 0;
}

.admin-filter-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.admin-filter-control {
  width: 100%;
  background: var(--bg-tertiary);
  border: none;
  border-radius: 12px;
  color: var(--text-primary);
  padding: 11px 12px;
  font-family: inherit;
  box-shadow: var(--shadow-inset);
}

.admin-filter-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.admin-management-shell {
  display: grid;
  gap: 12px;
}

.admin-empty-state {
  border-radius: 14px;
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  padding: 20px;
  text-align: center;
  box-shadow: var(--shadow-inset);
}

.admin-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.admin-mini-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 10px;
  padding: 10px 12px;
  background: var(--btn-confirm-bg);
  color: var(--btn-confirm-text);
  box-shadow: var(--shadow-sm);
  font-weight: 700;
  cursor: pointer;
}

.admin-mini-btn.secondary {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

.admin-mini-btn.ghost {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}

.admin-mini-btn.danger {
  background: rgba(239, 68, 68, 0.14);
  color: #d62828;
}

.admin-customer-cell {
  display: grid;
  gap: 4px;
}

.admin-customer-cell small,
.admin-muted-note {
  color: var(--text-secondary);
  font-size: 0.78rem;
  overflow-wrap: anywhere;
}

.admin-history-list {
  display: grid;
  gap: 10px;
}

.admin-history-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: var(--bg-tertiary);
  box-shadow: var(--shadow-inset);
}

.admin-history-item p,
.admin-history-item small {
  margin: 0;
  color: var(--text-secondary);
}

.admin-history-meta {
  text-align: right;
  display: grid;
  gap: 4px;
}

@media (max-width: 720px) {
  #adminPage {
    overflow-x: hidden;
  }

  #adminPage .p-6,
  #adminPage .admin-page-wrap {
    padding: 96px 10px 88px !important;
    gap: 14px;
  }

  .admin-header-row {
    align-items: flex-start;
    gap: 12px;
  }

  .admin-header-row > div {
    width: 100%;
  }

  .admin-header-row .btn-primary {
    width: 100% !important;
    justify-content: center;
    min-height: 46px;
  }

  .admin-subtitle {
    max-width: none;
    font-size: 0.9rem;
    line-height: 1.45;
  }

  .admin-dashboard-root {
    gap: 12px;
  }

  .admin-kpi-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .admin-kpi-card {
    padding: 12px;
    border-radius: 14px;
  }

  .admin-kpi-card span {
    font-size: 0.75rem;
  }

  .admin-kpi-card strong {
    font-size: 1.05rem;
  }

  .admin-panel {
    padding: 12px;
    border-radius: 15px;
  }

  .admin-panel h3 {
    font-size: 0.95rem;
  }

  .admin-panel-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .admin-live-banner {
    flex-direction: column;
    align-items: flex-start !important;
  }

  .admin-live-banner-status {
    width: 100%;
    text-align: left !important;
  }

  .admin-live-banner-status > span {
    justify-content: flex-start;
  }

  .admin-metric-list > div {
    padding: 9px 10px;
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-metric-list strong {
    align-self: flex-end;
  }

  .admin-chart {
    min-height: 180px;
  }

  .admin-chart svg {
    max-width: 100%;
    height: auto;
  }

  .admin-table-wrap {
    overflow: visible;
  }

  .admin-customer-scroll {
    max-height: 380px;
    overflow-y: auto;
    overflow-x: hidden;
  }

  .admin-customer-table,
  .admin-customer-table thead,
  .admin-customer-table tbody,
  .admin-customer-table tr,
  .admin-customer-table th,
  .admin-customer-table td {
    display: table;
    width: 100%;
    table-layout: fixed;
  }

  .admin-customer-table thead,
  .admin-customer-table tbody {
    display: table-row-group;
  }

  .admin-customer-table tr {
    display: table-row;
  }

  .admin-customer-table th,
  .admin-customer-table td {
    display: table-cell;
    width: auto;
    padding: 7px 6px;
    font-size: 0.72rem;
    border-bottom: 1px solid var(--border-subtle);
  }

  .admin-customer-table td::before {
    content: none;
  }

  .admin-customer-table td > * {
    margin-left: 0;
  }

  .admin-customer-table .admin-customer-cell {
    justify-items: start;
    text-align: left;
  }

  .admin-customer-table .admin-badge {
    width: auto;
    white-space: nowrap;
    font-size: 0.7rem;
    padding: 4px 7px;
  }

  .admin-customer-table .admin-mini-btn {
    min-height: 30px;
    padding: 6px 6px;
    font-size: 0.7rem;
  }

  .admin-table-stack {
    min-width: 0;
  }

  .admin-table-stack thead {
    display: none;
  }

  .admin-table-stack,
  .admin-table-stack tbody,
  .admin-table-stack tr,
  .admin-table-stack td {
    display: block;
    width: 100%;
  }

  .admin-table-stack tbody {
    display: grid;
    gap: 10px;
  }

  .admin-table-stack tr {
    padding: 12px;
    border-radius: 14px;
    background: var(--bg-tertiary);
    box-shadow: var(--shadow-inset);
  }

  .admin-table-stack td {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: 0;
    border-bottom: none;
  }

  .admin-table-stack td + td {
    margin-top: 9px;
  }

  .admin-table-stack td::before {
    content: attr(data-label);
    flex: 0 0 auto;
    color: var(--text-secondary);
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.35;
    max-width: 100%;
  }

  .admin-table-stack td > * {
    margin-left: auto;
  }

  .admin-chart-legend-item {
    display: grid;
    justify-content: stretch;
    gap: 4px;
  }

  .admin-chart-legend-left {
    min-width: 0;
  }

  .admin-badge {
    white-space: normal;
    text-align: center;
  }

  .admin-mini-btn {
    width: 100%;
    padding: 10px;
  }

  .admin-table-stack td[colspan] {
    display: block;
    margin: 0;
    padding: 0;
  }

  .admin-table-stack td[colspan]::before {
    content: none;
  }

  .admin-table-stack .admin-customer-cell {
    justify-items: end;
    text-align: right;
  }

  .admin-table-stack td[data-label="Ação"] {
    display: grid;
    gap: 8px;
  }

  .admin-table-stack td[data-label="Ação"]::before {
    content: attr(data-label);
  }

  .admin-table-stack td[data-label="Ação"] .admin-mini-btn {
    width: 100%;
  }

  .admin-filter-control,
  .admin-mini-btn {
    min-height: 44px;
  }

  .admin-filter-actions {
    grid-template-columns: 1fr;
  }

  .admin-history-item {
    padding: 12px;
    gap: 8px;
  }
}

@media (max-width: 640px) {
  .admin-chart-legend {
    grid-template-columns: 1fr;
  }

  .admin-filter-bar {
    grid-template-columns: 1fr;
  }

  .admin-filter-actions {
    grid-template-columns: 1fr 1fr;
  }

  .admin-history-item {
    grid-template-columns: 1fr;
    display: grid;
  }

  .admin-history-meta {
    text-align: left;
  }
}

/* ─── ADM Redesign Components ─── */

.adm-status-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border-radius: 16px;
  background: var(--bg-secondary);
  box-shadow: var(--shadow-outer);
}

.adm-status-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.adm-status-left strong {
  display: block;
  font-size: 0.9rem;
  color: var(--text-accent);
}

.adm-status-left small {
  display: block;
  font-size: 0.78rem;
  color: var(--text-secondary);
  margin-top: 2px;
}

.adm-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #4ade80;
  flex-shrink: 0;
  animation: admPulse 2s infinite;
}

@keyframes admPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.4); }
  50% { opacity: 0.8; box-shadow: 0 0 0 6px rgba(74, 222, 128, 0); }
}

.adm-status-right {
  text-align: right;
  flex-shrink: 0;
}

.adm-status-live {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  color: var(--text-accent);
  justify-content: flex-end;
}

.adm-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #4ade80;
  animation: admPulse 2s infinite;
}

.adm-status-right small {
  display: block;
  font-size: 0.74rem;
  color: var(--text-secondary);
  margin-top: 3px;
}

/* KPI Row */
.adm-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.adm-kpi {
  background: var(--bg-secondary);
  border-radius: 16px;
  padding: 16px;
  box-shadow: var(--shadow-outer);
  border-left: 3px solid var(--kpi-accent, #5b8ef5);
  display: grid;
  gap: 8px;
}

.adm-kpi-top {
  display: flex;
  align-items: center;
  gap: 8px;
}

.adm-kpi-icon {
  font-size: 1.1rem;
}

.adm-kpi-label {
  font-size: 0.78rem;
  color: var(--text-secondary);
  font-weight: 600;
}

.adm-kpi-value {
  font-size: 1.35rem;
  color: var(--text-primary);
}

/* Plan Distribution Cards */
.adm-plan-grid {
  grid-template-columns: repeat(3, 1fr) !important;
}

.adm-plan-card {
  background: var(--bg-secondary);
  border-radius: 16px;
  padding: 18px;
  box-shadow: var(--shadow-outer);
  display: grid;
  gap: 10px;
  text-align: center;
}

.adm-plan-card-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
}

.adm-plan-card-count {
  font-size: 1.8rem;
  color: var(--plan-color, var(--text-primary));
}

.adm-plan-bar {
  height: 8px;
  border-radius: 99px;
  background: var(--bg-tertiary);
  overflow: hidden;
}

.adm-plan-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.4s ease;
}

.adm-plan-card small {
  font-size: 0.78rem;
  color: var(--text-secondary);
}

/* Metric Divider */
.admin-metric-list > .adm-metric-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 2px 0;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0;
}

/* Pagination */
.adm-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 0 4px;
}

.adm-page-nav {
  background: var(--bg-tertiary) !important;
  color: var(--text-secondary);
  border: none;
  border-radius: 10px;
  padding: 8px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.adm-page-nav:hover:not(:disabled) {
  background: var(--bg-secondary) !important;
  color: var(--text-primary);
}

.adm-page-nav:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.adm-page-numbers {
  display: flex;
  align-items: center;
  gap: 4px;
}

.adm-page-btn {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: none;
  background: var(--bg-tertiary) !important;
  color: var(--text-secondary);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.adm-page-btn:hover {
  background: var(--bg-secondary) !important;
  color: var(--text-primary);
}

.adm-page-active {
  background: var(--btn-confirm-bg) !important;
  color: var(--btn-confirm-text) !important;
  cursor: default;
}

.adm-page-dots {
  font-size: 0.82rem;
  color: var(--text-secondary);
  padding: 0 4px;
}

.adm-page-summary {
  text-align: center;
  font-size: 0.78rem;
  color: var(--text-secondary);
  padding: 6px 0;
}

/* Footer */
.adm-footer {
  padding: 12px;
  text-align: center;
  font-size: 0.76rem;
  color: var(--text-secondary);
  border-radius: 12px;
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
}

/* ─── ADM Responsive Overrides ─── */

@media (max-width: 980px) {
  .adm-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .adm-plan-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 720px) {
  .adm-status-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .adm-status-right {
    text-align: left;
    width: 100%;
  }
  .adm-status-live { justify-content: flex-start; }
  .adm-kpi-row { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .adm-kpi { padding: 12px; border-radius: 14px; }
  .adm-kpi-value { font-size: 1.15rem; }
  .adm-plan-card { padding: 14px; }
  .adm-plan-card-count { font-size: 1.4rem; }
  .adm-pagination { flex-wrap: wrap; }
}

@media (max-width: 640px) {
  .adm-kpi-row { grid-template-columns: 1fr; }
  .adm-plan-card-count { font-size: 1.2rem; }
  .adm-page-nav { padding: 8px 10px; font-size: 0.78rem; }
  .adm-page-btn { width: 32px; height: 32px; font-size: 0.78rem; }
}

@media (max-width: 420px) {
  .adm-kpi-icon { font-size: 0.95rem; }
  .adm-kpi-label { font-size: 0.72rem; }
  .adm-kpi-value { font-size: 1rem; }
}

[data-theme="dark"] .admin-table th {
  background: rgba(34, 39, 51, 0.72);
}

@media (max-width: 980px) {
  .admin-section-grid {
    grid-template-columns: 1fr;
  }

  .admin-panel-full {
    grid-column: auto;
  }

  .admin-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .admin-kpi-grid {
    grid-template-columns: 1fr;
  }

  .admin-header-row h2 {
    font-size: 1.4rem;
    line-height: 1.15;
  }

  .admin-panel {
    padding: 10px;
  }

  .admin-chart {
    min-height: 160px;
  }

  .admin-table-stack td {
    flex-direction: column;
    gap: 4px;
  }

  .admin-table-stack td::before,
  .admin-table-stack td > * {
    margin-left: 0;
  }

  .admin-table-stack tr {
    padding: 10px;
  }

  .admin-table-stack .admin-customer-cell {
    justify-items: start;
    text-align: left;
  }

  .admin-customer-scroll {
    max-height: 350px;
  }

  .admin-customer-table th,
  .admin-customer-table td {
    padding: 6px 5px;
    font-size: 0.68rem;
  }

  .admin-customer-table .admin-customer-cell small {
    font-size: 0.64rem;
  }

  .admin-customer-table .admin-mini-btn {
    font-size: 0.66rem;
  }

  #adminCustomerManagementContent .admin-table-stack td {
    align-items: stretch;
  }

  #adminCustomerManagementContent .admin-table-stack td[data-label="Ação"] {
    gap: 6px;
  }

  .admin-badge {
    width: fit-content;
  }

  .admin-metric-list strong {
    align-self: flex-start;
  }

  .admin-history-item,
  .admin-empty-state {
    padding: 10px;
  }
}

@media (max-width: 420px) {
  #adminPage .p-6,
  #adminPage .admin-page-wrap {
    padding: 92px 8px 86px !important;
  }

  .admin-panel h3 {
    font-size: 0.9rem;
  }

  .admin-kpi-card strong {
    font-size: 1rem;
  }

  .admin-filter-control,
  .admin-mini-btn,
  .admin-header-row .btn-primary {
    min-height: 42px;
  }

  .admin-customer-table th,
  .admin-customer-table td {
    padding: 5px 4px;
    font-size: 0.64rem;
  }

  .admin-customer-scroll {
    max-height: 330px;
  }

  .admin-filter-actions {
    grid-template-columns: 1fr;
  }
}

/* ============================================= */
/*       ADMIN MOBILE POLISH (PLAN MANAGER)      */
/* ============================================= */
@media (max-width: 768px) {
  #adminPage #adminCustomerManagementContent {
    gap: 10px;
  }

  #adminPage .admin-filter-bar {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px;
    border-radius: 14px;
    background: var(--bg-tertiary);
    box-shadow: var(--shadow-inset);
  }

  #adminPage .admin-filter-actions {
    grid-template-columns: 1fr 1fr;
  }

  #adminPage .admin-filter-actions .admin-mini-btn {
    min-height: 42px;
  }

  #adminCustomerManagementContent .admin-customer-scroll {
    max-height: none;
    overflow: visible;
  }

  #adminCustomerManagementContent .admin-table-wrap {
    overflow: visible;
  }

  #adminCustomerManagementContent .admin-customer-table {
    min-width: 0;
    width: 100%;
    table-layout: auto;
  }

  #adminCustomerManagementContent .admin-customer-table thead {
    display: none;
  }

  #adminCustomerManagementContent .admin-customer-table,
  #adminCustomerManagementContent .admin-customer-table tbody,
  #adminCustomerManagementContent .admin-customer-table tr,
  #adminCustomerManagementContent .admin-customer-table td {
    display: block;
    width: 100%;
  }

  #adminCustomerManagementContent .admin-customer-table tbody {
    display: grid;
    gap: 10px;
  }

  #adminCustomerManagementContent .admin-customer-table tr {
    background: linear-gradient(180deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0.06) 100%), var(--bg-secondary);
    border-radius: 16px;
    box-shadow: var(--shadow-outer);
    padding: 12px;
  }

  #adminCustomerManagementContent .admin-customer-table td {
    border-bottom: none;
    padding: 0;
    margin-bottom: 8px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    font-size: 0.82rem;
  }

  #adminCustomerManagementContent .admin-customer-table td:last-child {
    margin-bottom: 0;
  }

  #adminCustomerManagementContent .admin-customer-table td::before {
    content: attr(data-label);
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--text-secondary);
    letter-spacing: 0.01em;
  }

  #adminCustomerManagementContent .admin-customer-table td > * {
    margin-left: auto;
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Cliente"] {
    display: block;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-subtle);
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Cliente"]::before {
    display: block;
    margin-bottom: 6px;
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Cliente"] > * {
    margin-left: 0;
  }

  #adminCustomerManagementContent .admin-customer-table .admin-customer-cell strong {
    font-size: 0.92rem;
    line-height: 1.25;
  }

  #adminCustomerManagementContent .admin-customer-table .admin-customer-cell small {
    font-size: 0.74rem;
    color: var(--text-muted);
    line-height: 1.35;
  }

  #adminCustomerManagementContent .admin-customer-table .admin-badge {
    font-size: 0.72rem;
    padding: 5px 9px;
    max-width: 100%;
    text-align: center;
  }

  #adminCustomerManagementContent .admin-customer-table .admin-muted-note {
    display: block;
    margin-top: 4px;
    font-size: 0.7rem;
    text-align: right;
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Ação"] {
    display: block;
    margin-top: 4px;
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Ação"]::before {
    display: block;
    margin-bottom: 6px;
  }

  #adminCustomerManagementContent .admin-customer-table td[data-label="Ação"] .admin-mini-btn {
    width: 100%;
    min-height: 40px;
    font-size: 0.78rem;
  }

  #adminPage .adm-pagination {
    gap: 6px;
    justify-content: space-between;
  }

  #adminPage .adm-page-numbers {
    flex: 1;
    justify-content: center;
  }

  #adminPage .adm-page-nav {
    min-height: 36px;
    padding: 8px 10px;
    font-size: 0.76rem;
  }
}

@media (max-width: 420px) {
  #adminPage .admin-filter-actions {
    grid-template-columns: 1fr;
  }

  #adminCustomerManagementContent .admin-customer-table tr {
    padding: 10px;
    border-radius: 14px;
  }

  #adminCustomerManagementContent .admin-customer-table td {
    gap: 8px;
    font-size: 0.78rem;
  }

  #adminCustomerManagementContent .admin-customer-table td::before {
    font-size: 0.68rem;
  }

  #adminPage .adm-page-btn {
    width: 30px;
    height: 30px;
  }
}

@media (max-width: 768px) {
  body.chat-open-mobile {
    overflow: hidden !important;
    overscroll-behavior: none;
    touch-action: none;
  }

  /* Barra sticky: conteúdo começa abaixo dela naturalmente (está no fluxo normal) */
}

/* ============================================= */
/*     BUTTON SYSTEM — FINAL CONSOLIDATED       */
/* ============================================= */

/* Base intent buttons */
.btn-primary,
.modal-content .btn-primary,
.auth-submit {
  background: var(--btn-confirm-bg) !important;
  color: var(--btn-confirm-text) !important;
  border: none !important;
  border-radius: 14px !important;
  box-shadow: var(--shadow-outer) !important;
  transition: transform var(--motion-fast), box-shadow var(--motion-fast), background-color var(--motion-fast), color var(--motion-fast) !important;
}

.btn-primary:hover,
.modal-content .btn-primary:hover,
.auth-submit:hover {
  background: var(--btn-confirm-bg-hover) !important;
  box-shadow: var(--shadow-hover) !important;
  transform: translateY(-1px) !important;
}

.btn-primary:active,
.modal-content .btn-primary:active,
.auth-submit:active {
  background: var(--btn-confirm-bg-active) !important;
  box-shadow: var(--shadow-inset) !important;
  transform: translateY(0) !important;
}

.btn-secondary,
.modal-content .btn-secondary,
button.btn-secondary[style*="width: auto"] {
  background: var(--btn-cancel-bg) !important;
  color: var(--btn-cancel-text) !important;
  border: var(--border-highlight, 1px solid rgba(255,255,255,0.35)) !important;
  border-radius: 14px !important;
  box-shadow: var(--shadow-outer) !important;
  transition: transform var(--motion-fast), box-shadow var(--motion-fast), background-color var(--motion-fast), color var(--motion-fast) !important;
}

.btn-secondary:hover,
.modal-content .btn-secondary:hover,
button.btn-secondary[style*="width: auto"]:hover {
  background: var(--btn-cancel-bg-hover) !important;
  color: #ffffff !important;
  box-shadow: var(--shadow-hover) !important;
  transform: translateY(-1px) !important;
}

.btn-secondary:active,
.modal-content .btn-secondary:active,
button.btn-secondary[style*="width: auto"]:active {
  background: var(--btn-cancel-bg-active) !important;
  color: var(--btn-cancel-text) !important;
  box-shadow: var(--shadow-inset) !important;
  transform: translateY(0) !important;
}

/* Ensure Save/Cancel in modals always have strong neomorphic boxes */
.modal-content .btn-primary,
.modal-content .btn-secondary {
  min-height: 46px;
  padding: 14px 18px !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
}

/* +Nova actions (buttons with inline width:auto) — neutral neomorphic, no ugly blue */
button.btn-primary[style*="width: auto"] {
  background: var(--bg-secondary) !important;
  color: var(--btn-confirm-bg) !important;
  border: 1px solid rgba(31, 138, 99, 0.22) !important;
  box-shadow: var(--shadow-outer) !important;
}

button.btn-primary[style*="width: auto"]:hover {
  background: var(--bg-surface) !important;
  color: var(--btn-confirm-bg-hover) !important;
  border-color: rgba(31, 138, 99, 0.32) !important;
  box-shadow: var(--shadow-hover) !important;
}

button.btn-primary[style*="width: auto"]:active {
  background: var(--bg-tertiary) !important;
  color: var(--btn-confirm-bg-active) !important;
  box-shadow: var(--shadow-inset) !important;
}

[data-theme="dark"] button.btn-primary[style*="width: auto"] {
  background: var(--bg-tertiary) !important;
  color: var(--success) !important;
  border: 1px solid rgba(94, 237, 166, 0.24) !important;
  box-shadow: var(--shadow-sm) !important;
}

[data-theme="dark"] button.btn-primary[style*="width: auto"]:hover {
  background: #2b3a46 !important;
  color: #8ff0c3 !important;
  border-color: rgba(94, 237, 166, 0.34) !important;
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] button.btn-primary[style*="width: auto"]:active {
  background: #24323d !important;
  color: #7de6b7 !important;
  box-shadow: var(--shadow-inset) !important;
}

/* Keep this special behavior for balance adjustment confirm button */
[data-theme="dark"] #adjustBalanceModal .btn-primary:hover {
  background: rgba(94, 237, 166, 0.16) !important;
  color: var(--success) !important;
}

[data-theme="dark"] #adjustBalanceModal .btn-primary:active {
  background: rgba(94, 237, 166, 0.12) !important;
  color: var(--success) !important;
}

/* ——————————————————————————————————— */
/*   EMPTY STATE                       */
/* ——————————————————————————————————— */

[data-theme="dark"] .empty-state,
[data-theme="dark"] .no-data {
  background: var(--bg-secondary);
  border: var(--border-highlight);
  border-radius: 20px;
}

[data-theme="dark"] .empty-state-title,
[data-theme="dark"] .no-data-title {
  color: var(--text-primary);
}

[data-theme="dark"] .empty-state-description,
[data-theme="dark"] .no-data-description {
  color: var(--text-secondary);
}

/* ——————————————————————————————————— */
/*   PROGRESS BAR                      */
/* ——————————————————————————————————— */

[data-theme="dark"] .progress-bar {
  background: var(--bg-tertiary);
}

[data-theme="dark"] .progress-fill {
  background: var(--text-accent);
}

/* ——————————————————————————————————— */
/*   TOAST / NOTIFICATIONS             */
/* ——————————————————————————————————— */

[data-theme="dark"] .toast {
  background: var(--bg-secondary);
  color: var(--text-primary);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-subtle);
}

/* ——————————————————————————————————— */
/*   CATEGORIES & CHARTS               */
/* ——————————————————————————————————— */

[data-theme="dark"] .category-item {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-subtle);
}

[data-theme="dark"] .category-item:hover {
  box-shadow: var(--shadow-hover);
}

[data-theme="dark"] .chart-container {
  border: 1px solid var(--border-subtle);
}

/* ——————————————————————————————————— */
/*   MONTH SELECTOR                    */
/* ——————————————————————————————————— */

[data-theme="dark"] .month-selector {
  border: 1px solid var(--border-subtle);
}

[data-theme="dark"] .month-label {
  color: var(--text-accent);
}

[data-theme="dark"] .month-selector button:hover {
  background: rgba(123, 170, 247, 0.10) !important;
  border-radius: 8px;
}

/* ——————————————————————————————————— */
/*   TYPOGRAPHY                        */
/* ——————————————————————————————————— */

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
  color: var(--text-primary);
}

[data-theme="dark"] label,
[data-theme="dark"] .label {
  color: var(--text-secondary);
}

[data-theme="dark"] label:hover,
[data-theme="dark"] .label:hover {
  color: var(--text-primary);
}

[data-theme="dark"] .text-secondary {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .text-muted {
  color: var(--text-muted) !important;
}

/* ——————————————————————————————————— */
/*   DASHBOARD SPECIFIC                */
/* ——————————————————————————————————— */

[data-theme="dark"] #dashboardPage .stat-card {
  background: var(--bg-secondary);
  border: var(--border-highlight);
}

[data-theme="dark"] #dashboardPage h2,
[data-theme="dark"] #dashboardPage h3 {
  color: var(--text-primary);
}

[data-theme="dark"] #dashboardPage .transaction-item {
  background: var(--bg-secondary);
  border: var(--border-highlight);
}

[data-theme="dark"] #dashboardPage .chart-container {
  background: var(--bg-secondary);
  border: var(--border-highlight);
}

[data-theme="dark"] #dashboardPage .month-selector button:hover {
  background: rgba(123, 170, 247, 0.10) !important;
}

/* ——————————————————————————————————— */
/*   WALLET CARDS (DARK)               */
/* ——————————————————————————————————— */

[data-theme="dark"] .wallet-card-wrapper {
  background: var(--bg-secondary);
  border: var(--border-highlight);
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .wallet-card-wrapper:hover {
  box-shadow: var(--shadow-hover);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .wallet-card--credit { background: #0c1a3a; }
[data-theme="dark"] .wallet-card--debit  { background: #081f1a; }

[data-theme="dark"] .wallet-card-info-label {
  color: var(--text-muted, #6b7280);
}

[data-theme="dark"] .wallet-usage-bar {
  background: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .wallet-card-actions {
  border-top-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .wallet-card-btn--icon {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-muted, #6b7280);
}

[data-theme="dark"] .wallet-card-btn--pay {
  background: linear-gradient(135deg, #0e9f6e, #0a7f59) !important;
  box-shadow: 0 7px 15px rgba(16,185,129,0.26) !important;
}

[data-theme="dark"] .wallet-card-btn--future {
  background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
  box-shadow: 0 7px 15px rgba(59,130,246,0.24) !important;
}

[data-theme="dark"] .wallet-card-btn--icon:hover {
  background: rgba(59, 130, 246, 0.10);
  color: #7baaf7;
}

[data-theme="dark"] .wallet-card-btn--icon.delete:hover {
  background: rgba(239, 68, 68, 0.10);
  color: #f87171;
}

[data-theme="dark"] .wallet-card-btn--icon.adjust:hover {
  background: rgba(234, 179, 8, 0.10);
  color: #fbbf24;
}

/* ——————————————————————————————————— */
/*   MOBILE MENU                       */
/* ——————————————————————————————————— */

[data-theme="dark"] .mobile-menu-toggle {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid var(--border-subtle) !important;
}

[data-theme="dark"] .mobile-menu-toggle:hover {
  background: rgba(123, 170, 247, 0.08) !important;
}

[data-theme="dark"] .mobile-menu-overlay {
  background: rgba(0, 0, 0, 0.60);
}

[data-theme="dark"] .mobile-top-bar {
  background: var(--bg-primary);
  box-shadow: var(--shadow-sm);
  border-bottom: 1px solid var(--border-subtle);
}

/* ——————————————————————————————————— */
/*   BACK TO TODAY BUTTON              */
/* ——————————————————————————————————— */

/* Dark desktop-only back-to-today styling */
@media (min-width: 769px) {
  [data-theme="dark"] .back-to-today-btn {
    background: var(--bg-secondary) !important;
    color: var(--text-secondary) !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-subtle) !important;
  }

  [data-theme="dark"] .back-to-today-btn:hover {
    background: var(--bg-tertiary) !important;
    color: var(--text-accent) !important;
  }

  [data-theme="dark"] .back-to-today-btn svg {
    stroke: var(--text-secondary) !important;
  }
}

/* ——————————————————————————————————— */
/*   INFO / ALERT BOXES                */
/* ——————————————————————————————————— */

[data-theme="dark"] .info-box,
[data-theme="dark"] .alert-box {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
  border: var(--border-highlight);
  border-radius: 16px;
}

[data-theme="dark"] .info-box:hover,
[data-theme="dark"] .alert-box:hover {
  background: rgba(123, 170, 247, 0.04);
}

[data-theme="dark"] .info-box-title,
[data-theme="dark"] .alert-box-title {
  color: var(--text-primary);
}

[data-theme="dark"] .info-box-text,
[data-theme="dark"] .alert-box-text {
  color: var(--text-secondary);
}

/* ——————————————————————————————————— */
/*   DIVIDERS / SECTIONS               */
/* ——————————————————————————————————— */

[data-theme="dark"] .divider-section {
  border-color: var(--border-color);
}

[data-theme="dark"] .group-header {
  color: var(--text-muted);
  border-top-color: var(--border-color);
}

[data-theme="dark"] hr {
  background: var(--border-color);
}

/* ——————————————————————————————————— */
/*   BADGES                            */
/* ——————————————————————————————————— */

[data-theme="dark"] .badge-status {
  background: rgba(255, 196, 100, 0.15);
  color: var(--warning);
}

[data-theme="dark"] .badge-projected {
  background: rgba(108, 184, 255, 0.15);
  color: var(--info);
}

[data-theme="dark"] .badge-preview {
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
}

[data-theme="dark"] .recurring-badge.permanent {
  background: rgba(94, 237, 166, 0.12);
  color: var(--success);
}

[data-theme="dark"] .recurring-badge.temporary {
  background: rgba(255, 196, 100, 0.12);
  color: var(--warning);
}

[data-theme="dark"] .recurring-expires {
  background: rgba(255, 196, 100, 0.15);
  color: var(--warning);
}

[data-theme="dark"] .goal-badge.completed {
  background: rgba(94, 237, 166, 0.15);
  color: var(--success);
}

[data-theme="dark"] .goal-badge.overdue {
  background: rgba(255, 128, 128, 0.15);
  color: var(--danger);
}

[data-theme="dark"] .goal-badge.deadline {
  background: rgba(255, 196, 100, 0.15);
  color: var(--warning);
}

/* ——————————————————————————————————— */
/*   EXPANDABLE / GRID / TABLE         */
/* ——————————————————————————————————— */

[data-theme="dark"] .expandable-header {
  background: var(--bg-secondary);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .expandable-content {
  background: var(--bg-secondary);
}

[data-theme="dark"] .grid-header {
  background: rgba(123, 170, 247, 0.04);
  border-bottom-color: var(--border-color);
  color: var(--text-muted);
}

[data-theme="dark"] .grid-row {
  border-bottom-color: var(--border-subtle);
}

[data-theme="dark"] .grid-row:hover {
  background: rgba(123, 170, 247, 0.03);
}

/* ——————————————————————————————————— */
/*   STATUS INDICATORS                 */
/* ——————————————————————————————————— */

[data-theme="dark"] .status-success {
  background: rgba(94, 237, 166, 0.12);
  color: var(--success);
}

[data-theme="dark"] .status-success::before {
  background: var(--success);
}

[data-theme="dark"] .status-error {
  background: rgba(255, 128, 128, 0.12);
  color: var(--danger);
}

[data-theme="dark"] .status-error::before {
  background: var(--danger);
}

[data-theme="dark"] .status-warning {
  background: rgba(255, 196, 100, 0.12);
  color: var(--warning);
}

[data-theme="dark"] .status-warning::before {
  background: var(--warning);
}

[data-theme="dark"] .status-info {
  background: rgba(123, 170, 247, 0.12);
  color: var(--text-accent);
}

[data-theme="dark"] .status-info::before {
  background: var(--text-accent);
}

/* ——————————————————————————————————— */
/*   BALANCE COLORS                    */
/* ——————————————————————————————————— */

[data-theme="dark"] #monthIncome {
  color: var(--success) !important;
}

[data-theme="dark"] #monthExpenses {
  color: var(--danger) !important;
}

/* ——————————————————————————————————— */
/*   GREEN ACTION BUTTONS              */
/* ——————————————————————————————————— */

[data-theme="dark"] button[onclick*="openCategoryModalFromTransaction"],
[data-theme="dark"] button[onclick*="openCardModalFromTransaction"],
[data-theme="dark"] button[onclick*="openCategoryModalFromRecurring"],
[data-theme="dark"] button[onclick*="openCardModalFromRecurring"] {
  background: var(--success) !important;
  color: #0d2818 !important;
  border-color: var(--success) !important;
  box-shadow: 0 4px 18px rgba(94, 237, 166, 0.25) !important;
}

[data-theme="dark"] button[onclick*="openCategoryModalFromTransaction"]:hover,
[data-theme="dark"] button[onclick*="openCardModalFromTransaction"]:hover,
[data-theme="dark"] button[onclick*="openCategoryModalFromRecurring"]:hover,
[data-theme="dark"] button[onclick*="openCardModalFromRecurring"]:hover {
  box-shadow: 0 6px 25px rgba(94, 237, 166, 0.38) !important;
}

/* ——————————————————————————————————— */
/*   CALCULATOR OPEN BUTTON            */
/* ——————————————————————————————————— */

[data-theme="dark"] button[onclick*="openCalculator"] {
  border-color: var(--success) !important;
  color: var(--success) !important;
  background: rgba(94, 237, 166, 0.08) !important;
}

[data-theme="dark"] button[onclick*="openCalculator"]:hover {
  background: var(--success) !important;
  color: #0d2818 !important;
}

/* ——————————————————————————————————— */
/*   DESCRIPTION SUGGESTION            */
/* ——————————————————————————————————— */

[data-theme="dark"] .description-suggestion {
  background: var(--bg-secondary);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .description-suggestion:hover {
  background: var(--bg-tertiary);
  color: var(--text-accent);
}

/* ——————————————————————————————————— */
/*   SETTINGS PAGE — FULL REDESIGN     */
/*   (single source, both themes)      */
/* ——————————————————————————————————— */

/* Header */
.settings-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

.settings-title {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin: 0;
}

.settings-subtitle {
  font-size: 0.88rem;
  color: var(--text-secondary);
  margin-top: 4px;
}

/* 2-column grid */
.settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}

.settings-col {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* Card */
.settings-card {
  background: var(--bg-secondary);
  border-radius: 20px;
  padding: 24px;
  box-shadow: var(--shadow-outer);
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.settings-card-header {
  display: flex;
  align-items: center;
  gap: 14px;
}

.settings-card-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: hsl(var(--icon-hue, 210) 70% 92%);
  color: hsl(var(--icon-hue, 210) 65% 48%);
}

[data-theme="dark"] .settings-card-icon {
  background: hsl(var(--icon-hue, 210) 40% 22%);
  color: hsl(var(--icon-hue, 210) 70% 72%);
}

.settings-card-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
}

.settings-card-desc {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.3;
}

/* Divider */
.settings-divider {
  height: 1px;
  background: var(--border-color);
  margin: 2px 0;
}

/* Toggle rows */
.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 18px;
  background: var(--bg-tertiary);
  border-radius: 14px;
}

.settings-row-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.settings-row-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
}

.settings-row-hint {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

/* Custom toggle switch */
.settings-toggle {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 26px;
  flex-shrink: 0;
  cursor: pointer;
}

.settings-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.settings-toggle-track {
  position: absolute;
  inset: 0;
  background: var(--border-color);
  border-radius: 26px;
  transition: background 0.25s ease;
}

.settings-toggle-track::after {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  top: 3px;
  left: 3px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.18);
  transition: transform 0.25s ease;
}

.settings-toggle input:checked + .settings-toggle-track {
  background: var(--accent-color);
}

.settings-toggle input:checked + .settings-toggle-track::after {
  transform: translateX(22px);
}

/* Input field */
.settings-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.settings-field-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.settings-input-group {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.settings-input-group .settings-input {
  flex: 1;
}

.settings-input-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  border-radius: 12px;
  border: none;
  background: var(--accent-color);
  color: #fff;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: var(--shadow-sm);
  flex-shrink: 0;
}

.settings-input-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover);
}

.settings-input {
  background: var(--bg-tertiary);
  border: none;
  border-radius: 12px;
  padding: 12px 16px;
  font-size: 0.92rem;
  color: var(--text-primary);
  box-shadow: var(--shadow-inset);
  width: 100%;
}

.settings-input:focus {
  outline: none;
  box-shadow: var(--shadow-inset), 0 0 0 2px rgba(123, 170, 247, 0.25);
}

.settings-input::placeholder {
  color: var(--text-muted);
}

/* Plan badges */
.settings-plan-badges {
  display: flex;
  gap: 12px;
}

.settings-plan-badge {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 12px;
  background: var(--bg-tertiary);
  border-radius: 14px;
}

.settings-plan-badge-label {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.settings-plan-badge-value {
  font-size: 1rem;
  font-weight: 800;
  color: var(--text-primary);
}

/* Action buttons */
.settings-actions {
  display: flex;
  gap: 10px;
}

.settings-actions-row {
  display: flex;
  gap: 10px;
}

.settings-actions-vertical {
  flex-direction: column;
}

.settings-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 12px;
  font-size: 0.85rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
  flex: 1;
  white-space: nowrap;
}

/* ============================================= */
/* FINAL FIX - BACK TO TODAY (MOBILE)           */
/* ============================================= */
@media (max-width: 768px) {
  #dashboardPage .back-to-today-btn,
  #transactionsPage .back-to-today-btn,
  #cardsPage .back-to-today-btn {
    position: absolute !important;
    top: calc(100% - 8px) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;

    width: auto !important;
    min-width: fit-content !important;
    max-width: calc(100vw - 130px) !important;
    height: auto !important;

    padding: 10px 18px !important;
    border-radius: 22px !important;
    gap: 8px !important;

    background: var(--bg-secondary) !important;
    color: var(--text-secondary) !important;
    border: none !important;
    box-shadow: var(--shadow-outer) !important;

    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.3px !important;
    white-space: nowrap !important;
    z-index: 55 !important;
  }

  #dashboardPage .back-to-today-btn svg,
  #transactionsPage .back-to-today-btn svg,
  #cardsPage .back-to-today-btn svg {
    width: 14px !important;
    height: 14px !important;
    stroke: var(--text-secondary) !important;
  }

  #dashboardPage .back-to-today-btn:hover,
  #transactionsPage .back-to-today-btn:hover,
  #cardsPage .back-to-today-btn:hover {
    box-shadow: var(--shadow-hover) !important;
    transform: translateX(-50%) translateY(-2px) !important;
  }

  #dashboardPage .back-to-today-btn:active,
  #transactionsPage .back-to-today-btn:active,
  #cardsPage .back-to-today-btn:active {
    box-shadow: var(--shadow-inset) !important;
    transform: translateX(-50%) translateY(0) !important;
  }

  /* Saldo Total (Dashboard) - manter icones reais, nao bolinhas */
  #dashboardPage .stat-card .flex.items-center.justify-between.mb-2 > .flex.items-center.gap-2 {
    gap: 8px !important;
    align-items: center !important;
  }

  #dashboardPage .stat-card .flex.items-center.justify-between.mb-2 > .flex.items-center.gap-2 svg {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    display: block !important;
  }

  #dashboardPage .stat-card .flex.items-center.justify-between.mb-2 > .flex.items-center.gap-2 button {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    min-height: 30px !important;
    padding: 5px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 8px !important;
  }
}

.settings-btn:hover {
  transform: translateY(-1px);
}

.settings-btn:active {
  transform: translateY(0);
}

.settings-btn svg {
  width: 16px !important;
  height: 16px !important;
  padding: 0 !important;
  background: none !important;
  border-radius: 0 !important;
  flex-shrink: 0;
}

/* Accent button */
button.settings-btn-accent {
  background: var(--accent-color) !important;
  color: #fff !important;
  box-shadow: var(--shadow-outer) !important;
}

button.settings-btn-accent:hover {
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] button.settings-btn-accent {
  background: var(--accent-color) !important;
  color: #fff !important;
  box-shadow: var(--shadow-outer) !important;
}

[data-theme="dark"] button.settings-btn-accent:hover {
  box-shadow: var(--shadow-hover) !important;
}

/* Outline button */
button.settings-btn-outline {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-outer) !important;
}

button.settings-btn-outline:hover {
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] button.settings-btn-outline {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-sm) !important;
  border: var(--border-highlight) !important;
}

[data-theme="dark"] button.settings-btn-outline:hover {
  box-shadow: var(--shadow-hover) !important;
}

/* Danger button */
button.settings-btn-danger {
  background: #fee2e2 !important;
  color: #dc2626 !important;
  box-shadow:
    4px 4px 10px rgba(220, 38, 38, 0.08),
   -4px -4px 10px rgba(255, 255, 255, 0.75) !important;
}

button.settings-btn-danger:hover {
  background: #fecaca !important;
  box-shadow:
    6px 6px 14px rgba(220, 38, 38, 0.12),
   -6px -6px 14px rgba(255, 255, 255, 0.85) !important;
}

[data-theme="dark"] button.settings-btn-danger {
  background: rgba(220, 38, 38, 0.15) !important;
  color: #fca5a5 !important;
  box-shadow: var(--shadow-sm) !important;
  border: var(--border-highlight) !important;
}

[data-theme="dark"] button.settings-btn-danger:hover {
  background: rgba(220, 38, 38, 0.25) !important;
  box-shadow: var(--shadow-outer) !important;
}

/* Logout button */
button.settings-btn-logout {
  background: var(--bg-tertiary) !important;
  color: var(--danger) !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid transparent !important;
}

button.settings-btn-logout:hover {
  background: rgba(239, 68, 68, 0.08) !important;
  border-color: var(--danger) !important;
  box-shadow: var(--shadow-hover) !important;
}

[data-theme="dark"] button.settings-btn-logout {
  background: var(--bg-tertiary) !important;
  color: #fca5a5 !important;
  box-shadow: var(--shadow-sm) !important;
}

[data-theme="dark"] button.settings-btn-logout:hover {
  background: rgba(220, 38, 38, 0.15) !important;
  box-shadow: var(--shadow-outer) !important;
}

/* Info banner */
.settings-info-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 12px;
  background: var(--bg-tertiary);
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

.settings-info-banner svg {
  width: 16px !important;
  height: 16px !important;
  padding: 0 !important;
  background: none !important;
  border-radius: 0 !important;
  flex-shrink: 0;
  color: var(--accent-color);
}

/* Stats grid */
.settings-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.settings-stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 8px;
  border-radius: 14px;
  background: var(--bg-tertiary);
  gap: 6px;
}

.settings-stat-value {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--accent-color);
  line-height: 1;
}

.settings-stat-value.settings-stat-green { color: var(--success); }
.settings-stat-value.settings-stat-amber { color: var(--warning); }

.settings-stat-label {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  text-align: center;
}

/* Version badge */
.settings-version-badge {
  margin-left: auto;
  font-size: 0.68rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--bg-tertiary);
  color: var(--text-muted);
}

/* Data & Statistics visual refresh */
.settings-card-data {
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(16, 185, 129, 0.08) 0%, transparent 54%),
    var(--bg-secondary);
  border: 1px solid rgba(148, 163, 184, 0.14);
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .settings-card-data {
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(16, 185, 129, 0.1) 0%, transparent 58%),
    var(--bg-secondary);
  border: var(--border-highlight);
}

.settings-card-data .settings-version-badge {
  background: var(--bg-primary);
  box-shadow: var(--shadow-inset);
  color: var(--text-secondary);
}

.settings-card-data .settings-stats-grid {
  gap: 12px;
}

.settings-card-data .settings-stat-item {
  position: relative;
  border-radius: 16px;
  background: var(--bg-primary);
  box-shadow: var(--shadow-inset);
  border: 1px solid rgba(148, 163, 184, 0.08);
  padding: 18px 10px;
}

.settings-card-data .settings-stat-item::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 10px;
  right: 10px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(16, 185, 129, 0.22), rgba(59, 130, 246, 0.16));
}

.settings-card-data .settings-stat-value {
  font-size: 1.55rem;
  letter-spacing: 0.02em;
}

.settings-card-data .settings-stat-label {
  font-size: 0.7rem;
  color: var(--text-muted);
}

.settings-card-data .settings-info-banner {
  border-radius: 14px;
  background: var(--bg-primary);
  box-shadow: var(--shadow-inset);
  border: 1px solid rgba(148, 163, 184, 0.08);
}

.settings-actions-row-data {
  margin-top: 4px;
  align-items: stretch;
  gap: 10px;
}

.settings-actions-row-data .settings-btn {
  min-height: 46px;
  border-radius: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: var(--shadow-outer) !important;
}

.settings-actions-row-data .settings-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover) !important;
}

.settings-actions-row-data .settings-btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-inset) !important;
}

button.settings-btn-soft {
  background: var(--bg-primary) !important;
  color: var(--text-secondary) !important;
  border: 1px solid rgba(148, 163, 184, 0.14) !important;
  box-shadow: var(--shadow-outer) !important;
}

button.settings-btn-soft:hover {
  color: var(--text-primary) !important;
  border-color: rgba(16, 185, 129, 0.28) !important;
  background: color-mix(in srgb, var(--bg-primary) 88%, var(--accent-color) 12%) !important;
}

[data-theme="dark"] button.settings-btn-soft {
  background: var(--bg-tertiary) !important;
  border: var(--border-highlight) !important;
  color: var(--text-secondary) !important;
}

[data-theme="dark"] button.settings-btn-soft:hover {
  color: #d7fff0 !important;
  background: color-mix(in srgb, var(--bg-tertiary) 84%, var(--accent-color) 16%) !important;
}

/* Export modal (neomorphic) */
.export-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(7, 10, 18, 0.58);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  box-sizing: border-box;
}

.export-modal-shell {
  width: 100%;
  max-width: 430px;
  max-height: 90vh;
  overflow-y: auto;
  border-radius: 20px;
  padding: 24px 22px;
  background: var(--bg-secondary);
  border: 1px solid rgba(148, 163, 184, 0.16);
  box-shadow: var(--shadow-outer);
}

[data-theme="dark"] .export-modal-shell {
  border: var(--border-highlight);
}

.export-modal-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.export-modal-icon-wrap {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-primary);
  color: var(--accent-color);
  box-shadow: var(--shadow-inset);
}

.export-modal-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: 0.01em;
}

.export-modal-subtitle {
  margin: 0 0 18px;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--text-secondary);
}

.export-modal-subtitle b {
  color: var(--text-primary);
}

.export-date-row {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
}

.export-date-col {
  flex: 1;
}

.export-field-label {
  display: block;
  margin-bottom: 5px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.export-date-input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 11px;
  background: var(--bg-primary);
  color: var(--text-primary);
  box-shadow: var(--shadow-inset);
  padding: 10px 11px;
  font-size: 0.92rem;
  outline: none;
}

.export-date-input:focus {
  border-color: rgba(16, 185, 129, 0.45);
  box-shadow: var(--shadow-inset), 0 0 0 3px rgba(16, 185, 129, 0.14);
}

.export-preset-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 18px;
}

.export-preset-btn {
  border: 1px solid rgba(148, 163, 184, 0.16) !important;
  border-radius: 10px;
  background: var(--bg-primary) !important;
  color: var(--text-secondary) !important;
  box-shadow: var(--shadow-outer) !important;
  padding: 8px 9px;
  font-size: 0.77rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .2s ease, color .2s ease, background .2s ease;
}

.export-preset-btn:hover {
  transform: translateY(-1px);
  color: var(--text-primary) !important;
  box-shadow: var(--shadow-hover) !important;
}

.export-preset-btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-inset) !important;
}

.export-action-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.export-action-btn {
  min-height: 44px;
  border: none !important;
  border-radius: 12px;
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .2s ease, filter .2s ease;
}

.export-action-btn:hover {
  transform: translateY(-1px);
}

.export-action-btn:active {
  transform: translateY(0);
}

.export-action-btn-cancel {
  grid-column: 1 / -1;
  background: var(--bg-primary) !important;
  color: var(--text-secondary) !important;
  border: 1px solid rgba(148, 163, 184, 0.16) !important;
  box-shadow: var(--shadow-outer) !important;
}

.export-action-btn-cancel:hover {
  box-shadow: var(--shadow-hover) !important;
  color: var(--text-primary) !important;
}

.export-action-btn-xlsx {
  background: linear-gradient(135deg, #0ea765, #13b981) !important;
  color: #ffffff !important;
  box-shadow: 0 8px 20px rgba(16, 185, 129, 0.3) !important;
}

.export-action-btn-xlsx:hover {
  filter: brightness(1.04);
  box-shadow: 0 10px 24px rgba(16, 185, 129, 0.36) !important;
}

.export-action-btn-pdf {
  background: linear-gradient(135deg, #0f172a, #1e293b) !important;
  color: #ffffff !important;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.28) !important;
}

.export-action-btn-pdf:hover {
  filter: brightness(1.06);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.36) !important;
}

[data-theme="dark"] .export-action-btn-pdf {
  background: linear-gradient(135deg, #111827, #26344b) !important;
}

@media (max-width: 560px) {
  .export-modal-shell {
    padding: 20px 16px;
    border-radius: 18px;
  }

  .export-preset-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .export-action-grid {
    grid-template-columns: 1fr;
  }

  .export-date-row {
    flex-direction: column;
    gap: 8px;
  }
}

/* Responsive — tablet */
@media (max-width: 900px) {
  .settings-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* Responsive — mobile */
@media (max-width: 480px) {
  .settings-header {
    margin-bottom: 20px;
  }

  .settings-title {
    font-size: 1.4rem;
  }

  .settings-card {
    padding: 18px 16px;
  }

  .settings-stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .settings-actions-row {
    flex-direction: column;
  }

  .settings-plan-badges {
    flex-direction: column;
  }
}

/* ——————————————————————————————————— */
/*   STAT CARD SVG ICONS               */
/* ——————————————————————————————————— */

[data-theme="dark"] #dashboardPage .stat-card svg {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset) !important;
  color: var(--text-secondary);
}

/* Keep arrow icons stable on card hover (only edit icon gets highlight hover) */
[data-theme="dark"] #dashboardPage .stat-card:hover svg {
  background: var(--bg-tertiary) !important;
  box-shadow: var(--shadow-inset) !important;
  color: var(--text-secondary);
}

/* Dashboard summary cards: avoid washed-out hover in dark */
[data-theme="dark"] #dashboardPage .stat-card.cursor-pointer.hover\:opacity-80:hover {
  opacity: 1 !important;
  box-shadow: var(--shadow-hover) !important;
}

/* Edit icon inside total balance card behaves like a proper neomorphic button */
[data-theme="dark"] #dashboardPage .stat-card .text-gray-500.hover\:text-green-500 {
  width: 30px;
  height: 30px;
  padding: 6px;
  border-radius: 10px;
  background: var(--bg-tertiary) !important;
  border: var(--border-highlight);
  box-shadow: var(--shadow-sm);
  color: var(--text-muted) !important;
  transition: background-color 0.22s cubic-bezier(.4,0,.2,1), color 0.22s cubic-bezier(.4,0,.2,1), box-shadow 0.22s cubic-bezier(.4,0,.2,1), transform 0.22s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] #dashboardPage .stat-card .text-gray-500.hover\:text-green-500:hover {
  background: rgba(94, 237, 166, 0.14) !important;
  color: var(--success) !important;
  box-shadow: var(--shadow-outer);
  transform: translateY(-1px);
}

[data-theme="dark"] #dashboardPage .stat-card .text-gray-500.hover\:text-green-500:active {
  box-shadow: var(--shadow-inset);
  transform: translateY(0);
}

/* ——————————————————————————————————— */
/*   GLOBAL SELECT ARROW DARK          */
/* ——————————————————————————————————— */

/* Light select neomorphic arrow */
select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 13px center;
  background-size: 12px 12px;
  padding-right: 36px;
}

[data-theme="dark"] select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237baaf7' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 13px center !important;
  background-size: 12px 12px !important;
}

/* ——————————————————————————————————— */
/*   FORM BORDERS & MODAL CONTENT      */
/*   Fine-tuned border lines           */
/* ——————————————————————————————————— */

[data-theme="dark"] .modal-content .space-y-4 > div {
  border: none;
}

[data-theme="dark"] .recurring-footer,
[data-theme="dark"] .transaction-actions {
  border-top: 1px solid var(--border-subtle);
}

/* ——————————————————————————————————— */
/*   SEMANTIC TEXT OVERRIDES           */
/* ——————————————————————————————————— */

[data-theme="dark"] .text-green-500 { color: var(--success) !important; }
[data-theme="dark"] .text-green-400 { color: var(--success) !important; }
[data-theme="dark"] .text-green-700 { color: var(--success) !important; }
[data-theme="dark"] .text-red-500   { color: var(--danger) !important; }
[data-theme="dark"] .text-blue-500  { color: var(--text-accent) !important; }
[data-theme="dark"] .text-blue-400  { color: var(--info) !important; }
[data-theme="dark"] .text-yellow-500 { color: var(--warning) !important; }

/* ——————————————————————————————————— */
/*   INSTALLMENT LABELS                */
/* ——————————————————————————————————— */

[data-theme="dark"] .installment-title {
  color: var(--text-accent);
}

[data-theme="dark"] .installment-label {
  color: var(--text-secondary);
}

/* ——————————————————————————————————— */
/*   DARK MODE — RESTORE TAILWIND     */
/*   (Undo light-mode overrides)       */
/* ——————————————————————————————————— */

/* Restore dark backgrounds */
[data-theme="dark"] .bg-gray-900 { background-color: var(--bg-primary) !important; }
[data-theme="dark"] .bg-gray-800 { background-color: var(--bg-secondary) !important; }
[data-theme="dark"] .bg-gray-700 { background-color: var(--bg-tertiary) !important; }
[data-theme="dark"] .hover\:bg-gray-600:hover { background-color: var(--bg-tertiary) !important; }
[data-theme="dark"] .border-gray-700 { border-color: var(--border-color) !important; }
[data-theme="dark"] .border-gray-800 { border-color: var(--border-subtle) !important; }
[data-theme="dark"] .border-gray-600 { border-color: var(--border-color) !important; }

/* Restore dark gradients */
[data-theme="dark"] .bg-gradient-to-r.from-gray-900,
[data-theme="dark"] .bg-gradient-to-r.from-gray-800 {
  background: none !important;
  background-image: linear-gradient(to right, var(--tw-gradient-stops)) !important;
  box-shadow: none;
}
[data-theme="dark"] .from-gray-800 { --tw-gradient-from: var(--bg-secondary) !important; }
[data-theme="dark"] .via-gray-800 { --tw-gradient-via: var(--bg-secondary) !important; }
[data-theme="dark"] .to-gray-900 { --tw-gradient-to: var(--bg-primary) !important; }
[data-theme="dark"] .bg-gradient-to-r.from-gray-800.to-gray-900 {
  background: none !important;
  background-image: linear-gradient(to right, var(--tw-gradient-stops)) !important;
}

/* Restore light text for dark mode */
[data-theme="dark"] .text-gray-300 { color: #d1d5db !important; }
[data-theme="dark"] .text-gray-400 { color: #9ca3af !important; }
[data-theme="dark"] .text-gray-500 { color: #6b7280 !important; }
[data-theme="dark"] .text-gray-600 { color: var(--text-muted) !important; }
[data-theme="dark"] .hover\:text-white:hover { color: #ffffff !important; }

/* Restore white text inside dark containers */
[data-theme="dark"] .bg-gray-900 .text-white,
[data-theme="dark"] .bg-gray-800 .text-white {
  color: #ffffff !important;
}

/* Restore standalone text-white for dark */
[data-theme="dark"] span.text-white,
[data-theme="dark"] .text-sm .text-white,
[data-theme="dark"] h4.text-white {
  color: #ffffff !important;
}

[data-theme="dark"] .bg-gray-900 .font-bold.text-gray-400 {
  color: #9ca3af !important;
}

/* Restore badge colors for dark */
[data-theme="dark"] .badge-status {
  background: rgba(255, 196, 100, 0.15);
  color: var(--warning);
}

[data-theme="dark"] .badge-projected {
  background: rgba(108, 184, 255, 0.15);
  color: var(--info);
}

[data-theme="dark"] .recurring-expires {
  background: rgba(255, 196, 100, 0.15);
  color: var(--warning);
}

/* Restore dark card look */
[data-theme="dark"] .bg-gray-900.border-2 {
  background-color: var(--bg-primary) !important;
  box-shadow: var(--shadow-outer);
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .bg-gray-900 .bg-gray-900 {
  background-color: var(--bg-primary) !important;
}

[data-theme="dark"] .bg-gray-800.text-gray-600 {
  background-color: var(--bg-secondary) !important;
  color: var(--text-muted) !important;
}

/* Restore hover shadows for dark */
[data-theme="dark"] .shadow-inner {
  box-shadow: var(--shadow-inset) !important;
}

[data-theme="dark"] .shadow-lg {
  box-shadow: var(--shadow-outer) !important;
}

/* Restore pagination blue buttons for dark */
[data-theme="dark"] .bg-gradient-to-r.from-blue-600 {
  background: var(--text-accent) !important;
}

[data-theme="dark"] .bg-gradient-to-r.from-blue-600 .text-white {
  color: #ffffff !important;
}

/* Restore hover text for dark */
[data-theme="dark"] .hover\:text-green-500:hover { color: var(--success) !important; }
[data-theme="dark"] .hover\:text-green-400:hover { color: var(--success) !important; }
[data-theme="dark"] .text-yellow-400 { color: var(--warning) !important; }
[data-theme="dark"] .text-purple-400 { color: #c084fc !important; }
[data-theme="dark"] .bg-gray-600 { background-color: var(--bg-tertiary) !important; }
[data-theme="dark"] .bg-gray-600.bg-opacity-50 { background-color: rgba(39, 45, 59, 0.5) !important; }

/* Restore income/expense colors for dark */
[data-theme="dark"] #monthIncome { color: var(--success); }
[data-theme="dark"] #monthExpenses { color: var(--danger); }
[data-theme="dark"] #totalBalance.text-green-500 { color: var(--success); }
[data-theme="dark"] #totalBalance.text-red-500 { color: var(--danger); }

/* Restore wallet card dark colors for dark theme */
[data-theme="dark"] .wallet-card--credit { background: #0c1a3a; }
[data-theme="dark"] .wallet-card--debit  { background: #081f1a; }

/* Restore active-filter for dark */
[data-theme="dark"] .active-filter {
  background: var(--text-accent) !important;
  color: #ffffff !important;
  border-color: var(--text-accent) !important;
}

/* ============================================= */
/*   SIMULADOR FINANCEIRO — STYLES              */
/* ============================================= */

/* Tabs */
.sim-tabs {
  display: flex;
  gap: 4px;
  background: var(--bg-tertiary, #272d3b);
  border-radius: 16px;
  padding: 4px;
  margin-bottom: 24px;
  width: fit-content;
}

.sim-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary, #a5b2c6);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.22s cubic-bezier(.4,0,.2,1);
}

.sim-tab:hover {
  color: var(--text-primary, #e4e9f1);
  background: rgba(255,255,255,0.04);
}

.sim-tab.active {
  background: var(--bg-secondary, #1f2430);
  color: var(--text-accent, #7baaf7);
  box-shadow: var(--shadow-sm);
}

.sim-tab svg { flex-shrink: 0; }

.sim-tab-content { display: none; }
.sim-tab-content.active { display: block; }

/* Investment Type Grid */
.sim-type-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  margin-bottom: 24px;
}

.sim-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 14px 8px;
  border-radius: 16px;
  background: var(--bg-secondary, #1f2430);
  border: 1px solid var(--border-color, rgba(255,255,255,0.07));
  cursor: pointer;
  transition: all 0.22s cubic-bezier(.4,0,.2,1);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #a5b2c6);
}

.sim-type-card:hover {
  transform: translateY(-2px);
  border-color: rgba(123, 170, 247, 0.2);
  box-shadow: var(--shadow-sm);
}

.sim-type-card.active {
  border-color: var(--text-accent, #7baaf7);
  background: rgba(123, 170, 247, 0.08);
  color: var(--text-primary, #e4e9f1);
  box-shadow: 0 0 0 1px var(--text-accent, #7baaf7), var(--shadow-sm);
}

.sim-type-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sim-type-icon--blue   { background: rgba(108,184,255,0.12); color: #6cb8ff; }
.sim-type-icon--green  { background: rgba(94,237,166,0.12);  color: #5eeda6; }
.sim-type-icon--amber  { background: rgba(255,196,100,0.12); color: #ffc464; }
.sim-type-icon--rose   { background: rgba(255,128,128,0.12); color: #ff8080; }
.sim-type-icon--teal   { background: rgba(45,212,191,0.12);  color: #2dd4bf; }
.sim-type-icon--purple { background: rgba(167,139,250,0.12); color: #a78bfa; }

/* Layout */
.sim-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

/* Form Card */
.sim-form-card { display: flex; flex-direction: column; gap: 16px; }

.sim-form-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.sim-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.sim-badge--blue   { background: rgba(108,184,255,0.12); color: #6cb8ff; }
.sim-badge--green  { background: rgba(94,237,166,0.12);  color: #5eeda6; }
.sim-badge--amber  { background: rgba(255,196,100,0.12); color: #ffc464; }
.sim-badge--rose   { background: rgba(255,128,128,0.12); color: #ff8080; }
.sim-badge--teal   { background: rgba(45,212,191,0.12);  color: #2dd4bf; }
.sim-badge--purple { background: rgba(167,139,250,0.12); color: #a78bfa; }
.sim-badge--sm { font-size: 9px; padding: 2px 8px; }

.sim-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.sim-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sim-field label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #a5b2c6);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.sim-field input,
.sim-field select {
  font-size: 14px;
  padding: 10px 14px;
}

.sim-input-prefix,
.sim-input-suffix {
  display: flex;
  align-items: center;
  background: var(--bg-tertiary, #272d3b);
  border-radius: 14px;
  box-shadow: var(--shadow-inset);
  border: var(--border-highlight, 1px solid rgba(255,255,255,0.06));
  overflow: hidden;
}

.sim-input-prefix > span,
.sim-input-suffix > span {
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted, #7f8ca3);
  flex-shrink: 0;
}

.sim-input-prefix > input,
.sim-input-suffix > input {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  flex: 1;
  min-width: 0;
  border-radius: 0 !important;
}

/* Presets */
.sim-presets {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.sim-presets-label {
  font-size: 11px;
  color: var(--text-muted, #7f8ca3);
  font-weight: 600;
  margin-right: 4px;
}

.sim-presets button {
  padding: 4px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  background: var(--bg-tertiary, #272d3b);
  color: var(--text-secondary, #a5b2c6);
  border: 1px solid var(--border-color, rgba(255,255,255,0.07));
  cursor: pointer;
  transition: all 0.2s;
}

.sim-presets button:hover {
  background: rgba(123,170,247,0.1);
  color: var(--text-accent, #7baaf7);
  border-color: var(--text-accent, #7baaf7);
}

/* Results Card */
.sim-results-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.sim-results-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 40px 20px;
  text-align: center;
  color: var(--text-muted, #7f8ca3);
  font-size: 14px;
}

.sim-result-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px;
  border-radius: 16px;
  background: rgba(94,237,166,0.06);
  border: 1px solid rgba(94,237,166,0.15);
  margin-bottom: 16px;
}

.sim-result-hero--amber {
  background: rgba(255,196,100,0.06);
  border-color: rgba(255,196,100,0.15);
}

.sim-result-hero-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #a5b2c6);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.sim-result-hero-value {
  font-size: 28px;
  font-weight: 800;
  color: var(--success, #5eeda6);
  letter-spacing: -0.5px;
}

.sim-result-hero--amber .sim-result-hero-value {
  color: var(--warning, #ffc464);
}

.sim-result-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.sim-metric {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  border-radius: 12px;
  background: var(--bg-tertiary, #272d3b);
}

.sim-metric-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted, #7f8ca3);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.sim-metric-value {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary, #e4e9f1);
}

.sim-metric-value--green { color: var(--success, #5eeda6); }
.sim-metric-value--red   { color: var(--danger, #ff8080); }
.sim-metric-value--blue  { color: var(--info, #6cb8ff); }
.sim-metric-value--amber { color: var(--warning, #ffc464); }

/* Tax info */
.sim-tax-info { margin-top: 12px; }

.sim-tax-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255,196,100,0.06);
  border: 1px solid rgba(255,196,100,0.12);
  font-size: 13px;
  color: var(--warning, #ffc464);
}

.sim-tax-row--green {
  background: rgba(94,237,166,0.06);
  border-color: rgba(94,237,166,0.12);
  color: var(--success, #5eeda6);
}

/* Chart Card */
.sim-chart-card { margin-bottom: 20px; }

.sim-chart-card > div > svg,
#simInvChart svg,
#simPurchaseChart svg {
  width: 100% !important;
  height: auto !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: none !important;
  box-shadow: none !important;
}

/* Reset stat-card SVG overrides for simulator */
.sim-results-card svg,
.sim-comparison-card svg,
.sim-tax-info svg,
.sim-result-hero svg {
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: none !important;
  box-shadow: none !important;
}

.sim-chart-legend {
  display: flex;
  gap: 20px;
  justify-content: center;
  margin-top: 12px;
}

.sim-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #a5b2c6);
}

.sim-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}

.sim-legend-dot--blue  { background: #6cb8ff; }
.sim-legend-dot--green { background: #5eeda6; }
.sim-legend-dot--red   { background: #ff8080; }

/* Comparison */
.sim-comparison-card { margin-bottom: 20px; }

.sim-comparison-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sim-comp-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--bg-tertiary, #272d3b);
  transition: all 0.2s;
}

.sim-comp-item--active {
  background: rgba(123,170,247,0.07);
  border: 1px solid rgba(123,170,247,0.2);
}

.sim-comp-rank {
  width: 28px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-muted, #7f8ca3);
  flex-shrink: 0;
}

.sim-comp-item:first-child .sim-comp-rank { color: #ffc464; }

.sim-comp-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

.sim-comp-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary, #e4e9f1);
}

.sim-comp-values {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  flex-shrink: 0;
}

.sim-comp-net {
  font-size: 15px;
  font-weight: 800;
  color: var(--text-primary, #e4e9f1);
}

.sim-comp-rent {
  font-size: 12px;
  font-weight: 700;
}

.sim-comp-rent--up { color: var(--success, #5eeda6); }
.sim-comp-rent--down { color: var(--danger, #ff8080); }

/* Purchase Comparison */
.sim-comp-purchase {
  padding: 16px;
  border-radius: 14px;
  background: var(--bg-tertiary, #272d3b);
  border: 1px solid var(--border-color, rgba(255,255,255,0.07));
}

.sim-comp-purchase-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-color, rgba(255,255,255,0.07));
}

.sim-comp-purchase-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sim-comp-purchase-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--text-secondary, #a5b2c6);
}

.sim-comp-purchase-row strong { color: var(--text-primary, #e4e9f1); }

.sim-comp-purchase--danger {
  border-color: rgba(255, 80, 80, 0.25);
  background: rgba(255, 80, 80, 0.04);
}

.sim-pct--safe    { color: var(--success, #5eeda6); font-weight: 700; }
.sim-pct--warning { color: var(--warning, #ffc464); font-weight: 700; }
.sim-pct--danger  { color: var(--danger, #ff8080); font-weight: 700; }

/* Purchase Comparison Grid */
#simPurchaseComparisonGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}

/* ======== Financial Snapshot Card ======== */
.sim-snapshot-card {
  margin-bottom: 20px;
}

.sim-snapshot-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.sim-snapshot-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.sim-snapshot-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px;
  border-radius: 12px;
  background: var(--bg-tertiary, #272d3b);
  border: 1px solid var(--border-color, rgba(255,255,255,0.07));
}

.sim-snapshot-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted, #7f8ca3);
}

.sim-snapshot-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary, #e4e9f1);
}

.sim-snapshot-value--green { color: var(--success, #5eeda6); }
.sim-snapshot-value--red   { color: var(--danger, #ff8080); }

.sim-snapshot-note {
  margin-top: 12px;
  font-size: 11px;
  color: var(--text-muted, #7f8ca3);
  text-align: center;
}

/* ======== Verdict Card ======== */
.sim-verdict-card {
  margin-top: 20px;
}

.sim-verdict-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  border-radius: 14px;
  margin-bottom: 18px;
}

.sim-verdict-header--safe {
  background: rgba(94, 237, 166, 0.08);
  border: 1px solid rgba(94, 237, 166, 0.25);
}

.sim-verdict-header--caution {
  background: rgba(255, 196, 100, 0.08);
  border: 1px solid rgba(255, 196, 100, 0.25);
}

.sim-verdict-header--danger {
  background: rgba(255, 80, 80, 0.08);
  border: 1px solid rgba(255, 80, 80, 0.25);
}

.sim-verdict-icon {
  font-size: 28px;
  line-height: 1;
}

.sim-verdict-subtitle {
  font-size: 13px;
  color: var(--text-secondary, #a5b2c6);
  margin-top: 2px;
}

/* Verdict Flow: Before → After */
.sim-verdict-flow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 20px;
  padding: 16px;
  background: var(--bg-tertiary, #272d3b);
  border-radius: 14px;
}

.sim-verdict-flow-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.sim-verdict-flow-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted, #7f8ca3);
}

.sim-verdict-flow-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-primary, #e4e9f1);
}

.sim-verdict-flow-value--green { color: var(--success, #5eeda6); }
.sim-verdict-flow-value--red   { color: var(--danger, #ff8080); }

.sim-verdict-flow-arrow {
  font-size: 24px;
  color: var(--text-muted, #7f8ca3);
  padding-top: 14px;
}

/* Verdict Detail Items */
.sim-verdict-details {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}

.sim-verdict-detail {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--bg-tertiary, #272d3b);
  border: 1px solid var(--border-color, rgba(255,255,255,0.07));
}

.sim-verdict-detail--danger {
  border-color: rgba(255, 80, 80, 0.2);
  background: rgba(255, 80, 80, 0.05);
}

.sim-verdict-detail--warning {
  border-color: rgba(255, 196, 100, 0.2);
  background: rgba(255, 196, 100, 0.05);
}

.sim-verdict-detail--safe {
  border-color: rgba(94, 237, 166, 0.2);
  background: rgba(94, 237, 166, 0.05);
}

.sim-verdict-detail-label {
  font-size: 12px;
  color: var(--text-secondary, #a5b2c6);
}

.sim-verdict-detail-value {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary, #e4e9f1);
}

.sim-verdict-detail--danger .sim-verdict-detail-value { color: var(--danger, #ff8080); }
.sim-verdict-detail--warning .sim-verdict-detail-value { color: var(--warning, #ffc464); }
.sim-verdict-detail--safe .sim-verdict-detail-value { color: var(--success, #5eeda6); }

/* Responsive */
@media (max-width: 768px) {
  .sim-type-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }

  .sim-layout {
    grid-template-columns: 1fr;
  }

  .sim-form-grid {
    grid-template-columns: 1fr;
  }

  .sim-result-metrics {
    grid-template-columns: 1fr;
  }

  .sim-result-hero-value {
    font-size: 22px;
  }

  .sim-tabs {
    width: 100%;
  }

  .sim-tab {
    flex: 1;
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
  }

  #simPurchaseComparisonGrid {
    grid-template-columns: 1fr;
  }

  .sim-snapshot-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .sim-snapshot-value {
    font-size: 15px;
  }

  .sim-verdict-flow {
    flex-direction: column;
    gap: 10px;
  }

  .sim-verdict-flow-arrow {
    transform: rotate(90deg);
    padding-top: 0;
  }

  .sim-verdict-flow-value {
    font-size: 18px;
  }

  .sim-verdict-details {
    grid-template-columns: 1fr;
  }
}

/* =============================================
   ONBOARDING / TUTORIAL SYSTEM
   ============================================= */

/* Overlay layer */
.onboarding-layer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  pointer-events: none;
}

.onboarding-layer.active {
  display: block;
  pointer-events: auto;
}

body.onboarding-active {
  overflow: hidden;
}

/* Spotlight cutout — box-shadow acts as the full-screen dark overlay */
.onboarding-spotlight {
  position: fixed;
  z-index: 10001;
  border-radius: 12px;
  background: transparent;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.6);
  transition: left 0.35s cubic-bezier(0.4, 0, 0.2, 1),
              top 0.35s cubic-bezier(0.4, 0, 0.2, 1),
              width 0.35s cubic-bezier(0.4, 0, 0.2, 1),
              height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

/* When no target: zero-size spotlight = full dark overlay (no cutout) */
.onboarding-spotlight-hidden {
  left: 50vw !important;
  top: 50vh !important;
  width: 0 !important;
  height: 0 !important;
  border-radius: 0 !important;
}

/* Target element — visible above the dark overlay */
.onboarding-target {
  position: relative;
  z-index: 10002 !important;
  pointer-events: none;
  box-shadow: 0 0 0 4px rgba(0, 200, 83, 0.5), 0 0 20px rgba(0, 200, 83, 0.25);
  border-radius: 12px;
}

/* Card — rendered as direct child of body, above everything */
.onboarding-card {
  position: fixed;
  z-index: 10010;
  background: var(--bg-secondary, #fff);
  border: 1px solid var(--border-color, rgba(255,255,255,0.08));
  border-radius: 18px;
  padding: 22px 24px 18px;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.28), 0 0 0 1px rgba(255,255,255,0.06);
  pointer-events: auto;
  animation: onboardingCardIn 0.35s cubic-bezier(0.22, 1, 0.36, 1);
  max-width: 420px;
  overflow-y: auto;
  display: none;
}

body.onboarding-active .onboarding-card {
  display: block;
}

@keyframes onboardingCardIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Intro variant */
.onboarding-card-intro {
  text-align: center;
  padding: 32px 28px 24px;
}

.onboarding-card-intro .onboarding-intro-hero {
  margin-bottom: 18px;
}

.onboarding-card-intro .onboarding-title {
  font-size: 1.35rem;
  margin-bottom: 8px;
}

.onboarding-card-intro .onboarding-description {
  font-size: 0.92rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 0;
}

.onboarding-intro-meta {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin: 14px 0;
  font-size: 0.78rem;
  color: var(--text-muted, var(--text-secondary));
  opacity: 0.7;
}

.onboarding-intro-list {
  text-align: left;
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 10px auto 20px;
  max-width: 300px;
}

.onboarding-intro-list div {
  padding: 3px 0;
}

/* Card header */
.onboarding-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.onboarding-step-badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 10px;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(0, 200, 83, 0.15), rgba(0, 230, 118, 0.1));
  color: var(--success, #00c853);
}

.onboarding-skip-btn {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 0.82rem;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.2s, color 0.2s;
}

.onboarding-skip-btn:hover {
  background: var(--bg-tertiary, rgba(255,255,255,0.06));
  color: var(--text-primary);
}

/* Title & text */
.onboarding-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 6px;
  line-height: 1.3;
}

.onboarding-description {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.55;
  margin: 0 0 4px;
}

.onboarding-helper {
  font-size: 0.78rem;
  color: var(--text-muted, var(--text-secondary));
  opacity: 0.6;
  line-height: 1.4;
  margin: 0 0 14px;
}

/* Progress bar */
.onboarding-progress {
  height: 4px;
  border-radius: 4px;
  background: var(--bg-tertiary, rgba(255,255,255,0.08));
  margin-bottom: 10px;
  overflow: hidden;
}

.onboarding-progress span {
  display: block;
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--success, #00c853), #00e676);
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Step dots */
.onboarding-step-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: 14px;
}

.onboarding-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--border-color, rgba(255,255,255,0.12));
  transition: background 0.3s, transform 0.3s;
}

.onboarding-dot.active {
  background: var(--success, #00c853);
  transform: scale(1.35);
}

/* Action buttons */
.onboarding-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.onboarding-primary-btn {
  padding: 10px 22px;
  border: none;
  border-radius: 12px;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  background: linear-gradient(135deg, #00c853, #00e676);
  color: #fff;
  box-shadow: 0 4px 14px rgba(0, 200, 83, 0.3);
  transition: transform 0.2s, box-shadow 0.2s;
}

.onboarding-primary-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 200, 83, 0.4);
}

.onboarding-back-btn {
  padding: 10px 18px;
  border: 1px solid var(--border-color, rgba(255,255,255,0.12));
  border-radius: 12px;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  background: var(--bg-tertiary, rgba(255,255,255,0.04));
  color: var(--text-secondary);
  transition: background 0.2s, color 0.2s;
}

.onboarding-back-btn:hover:not(:disabled) {
  background: var(--bg-primary);
  color: var(--text-primary);
}

.onboarding-back-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

/* Mobile adjustments */
@media (max-width: 768px) {
  .onboarding-card {
    padding: 18px 18px 14px;
    border-radius: 16px;
    max-width: calc(100vw - 32px);
  }

  .onboarding-card-intro {
    padding: 24px 20px 18px;
  }

  .onboarding-title {
    font-size: 1rem;
  }

  .onboarding-description {
    font-size: 0.85rem;
  }

  .onboarding-primary-btn {
    padding: 10px 18px;
    font-size: 0.85rem;
  }

  .onboarding-back-btn {
    padding: 10px 14px;
    font-size: 0.82rem;
  }

  .onboarding-spotlight {
    border-radius: 8px;
  }
}

/* ============================================= */
/*   ONBOARDING — LIGHT THEME OVERRIDES          */
/* ============================================= */
:root:not([data-theme="dark"]) .onboarding-card {
  background: #ffffff;
  border: 1px solid #d1d9e6;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.14), 0 0 0 1px rgba(0,0,0,0.04);
}

:root:not([data-theme="dark"]) .onboarding-title {
  color: #1e293b;
}

:root:not([data-theme="dark"]) .onboarding-description {
  color: #374151;
  opacity: 1;
}

:root:not([data-theme="dark"]) .onboarding-helper {
  color: #6b7280;
  opacity: 1;
}

:root:not([data-theme="dark"]) .onboarding-intro-meta {
  color: #6b7280;
  opacity: 1;
}

:root:not([data-theme="dark"]) .onboarding-intro-list {
  color: #374151;
}

:root:not([data-theme="dark"]) .onboarding-step-badge {
  color: #047857;
  background: rgba(16, 185, 129, 0.12);
}

:root:not([data-theme="dark"]) .onboarding-skip-btn {
  color: #4b5563;
}

:root:not([data-theme="dark"]) .onboarding-skip-btn:hover {
  background: #f3f4f6;
  color: #1e293b;
}

:root:not([data-theme="dark"]) .onboarding-progress {
  background: #e5e7eb;
}

:root:not([data-theme="dark"]) .onboarding-dot {
  background: #d1d5db;
}

:root:not([data-theme="dark"]) .onboarding-dot.active {
  background: var(--success, #10b981);
}

/* ── Onboarding buttons – light theme hard fix ─────────────────────────
   High-specificity selectors override:
     • button.btn-secondary { background: inherit !important } (line ~999)
     • button:hover { background: transparent !important }    (line ~1071)
   Both use !important, so we need specificity > 0,0,1,1 to win.
   :root:not([data-theme="dark"]) .onboarding-card button.X  = 0,0,5,1 ✓
──────────────────────────────────────────────────────────────────────── */

/* Back / Cancel button (Voltar, Agora não) — rest state */
:root:not([data-theme="dark"]) .onboarding-card button.onboarding-back-btn,
:root:not([data-theme="dark"]) .onboarding-card .onboarding-back-btn {
  background: #e2e8f0 !important;
  border: 1.5px solid #94a3b8 !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08) !important;
  color: #1e293b !important;
  opacity: 1 !important;
}

/* Back / Cancel button — hover */
:root:not([data-theme="dark"]) .onboarding-card button.onboarding-back-btn:hover:not(:disabled),
:root:not([data-theme="dark"]) .onboarding-card .onboarding-back-btn:hover:not(:disabled) {
  background: #cbd5e1 !important;
  border-color: #64748b !important;
  color: #0f172a !important;
}

/* Primary button (Começar tutorial, Próximo, Concluir) — rest state */
:root:not([data-theme="dark"]) .onboarding-card button.onboarding-primary-btn,
:root:not([data-theme="dark"]) .onboarding-card .onboarding-primary-btn {
  background: linear-gradient(135deg, #00c853, #00e676) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 14px rgba(0,200,83,0.35) !important;
  opacity: 1 !important;
}

/* Primary button — hover (beats the global button:hover { transparent !important }) */
:root:not([data-theme="dark"]) .onboarding-card button.onboarding-primary-btn:hover,
:root:not([data-theme="dark"]) .onboarding-card .onboarding-primary-btn:hover {
  background: linear-gradient(135deg, #00b84a, #00c853) !important;
  color: #fff !important;
  box-shadow: 0 6px 20px rgba(0,200,83,0.45) !important;
}

/* ═══════════════════════════════════════════════════════════════
   SOLUX CHATBOT – Assistente Financeiro IA
   ═══════════════════════════════════════════════════════════════ */

/* Wrapper */
#chatbotWrapper {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9990;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  pointer-events: none;
}
#chatbotWrapper > * { pointer-events: all; }

/* ── FAB Button ── */
.chatbot-fab {
  width: 58px !important;
  height: 58px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #00b84a, #00e676) !important;
  color: white !important;
  border: none !important;
  box-shadow: 0 6px 24px rgba(0,200,83,0.5), 0 2px 8px rgba(0,0,0,0.15) !important;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
  animation: cfab-in 0.55s cubic-bezier(0.34,1.56,0.64,1) both;
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s !important;
}
@keyframes cfab-in {
  from { transform: scale(0) rotate(-180deg); opacity: 0; }
  to   { transform: scale(1) rotate(0deg);   opacity: 1; }
}
  from { transform: scale(0) rotate(-180deg); opacity: 0; }
  to   { transform: scale(1) rotate(0deg);   opacity: 1; }
}
/* ── App Theme FAB ── */
.app-theme-fab {
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  background: var(--card-bg, #ffffff) !important;
  color: var(--text-primary, #1a1a1a) !important;
  border: 1.5px solid var(--border-color, #e0e0e0) !important;
  box-shadow: 0 3px 14px rgba(0,0,0,0.18), 0 1px 4px rgba(0,0,0,0.10) !important;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.22s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.22s !important;
}
.app-theme-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 5px 22px rgba(0,0,0,0.25) !important;
}
[data-theme="dark"] .app-theme-fab {
  background: var(--card-bg, #1e1e2e) !important;
  color: var(--text-primary, #e0e0e0) !important;
  border-color: var(--border-color, #333) !important;
  box-shadow: 0 3px 14px rgba(0,0,0,0.40), 0 1px 4px rgba(0,0,0,0.20) !important;
}
.chatbot-fab::before {
  content: '';
  position: absolute;
  inset: -7px;
  border-radius: 50%;
  background: rgba(0,200,83,0.22);
  animation: cfab-pulse 2.8s ease-in-out infinite;
  pointer-events: none;
}
@keyframes cfab-pulse {
  0%,100% { transform: scale(1);    opacity: 0.7; }
  50%      { transform: scale(1.22); opacity: 0;   }
}
.chatbot-fab:hover {
  transform: scale(1.1) translateY(-2px) !important;
  box-shadow: 0 10px 32px rgba(0,200,83,0.6), 0 4px 12px rgba(0,0,0,0.2) !important;
}
.chatbot-fab:active { transform: scale(0.95) !important; }

/* Notification dot */
.chatbot-notif {
  position: absolute;
  top: 3px; right: 3px;
  width: 13px; height: 13px;
  background: #ef4444;
  border-radius: 50%;
  border: 2.5px solid var(--bg-primary, #e3e8f0);
  animation: cbadge-pop 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes cbadge-pop {
  from { transform: scale(0); }
  to   { transform: scale(1); }
}

/* ── Panel ── */
.chatbot-panel {
  width: 360px;
  max-height: 545px;
  min-height: 200px;
  background: var(--bg-secondary, #f0f4fb);
  border-radius: 20px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.18), 0 4px 16px rgba(0,0,0,0.08), 0 0 0 1px rgba(0,0,0,0.04);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform-origin: bottom right;
  transform: scale(0.85) translateY(20px);
  opacity: 0;
  pointer-events: none !important;
  transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1), opacity 0.25s ease;
  overscroll-behavior: contain;
  touch-action: pan-y;
}
.chatbot-panel--open {
  transform: scale(1) translateY(0) !important;
  opacity: 1 !important;
  pointer-events: all !important;
}

/* ── Header ── */
.chatbot-header {
  background: linear-gradient(135deg, #00a040 0%, #00c853 55%, #00e676 100%);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.chatbot-hdr-left {
  display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0;
}
.chatbot-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.2);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative;
  border: 2px solid rgba(255,255,255,0.4);
}
.chatbot-online-dot {
  position: absolute; bottom: 1px; right: 1px;
  width: 10px; height: 10px;
  background: #fff; border-radius: 50%;
  border: 2px solid #00c853;
  animation: cdot-pulse 2.2s ease-in-out infinite;
}
@keyframes cdot-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,255,255,0.7); }
  50%      { box-shadow: 0 0 0 4px rgba(255,255,255,0); }
}
.chatbot-name {
  font-size: 0.95rem; font-weight: 800; color: #fff;
  letter-spacing: 0.3px; display: flex; align-items: center; gap: 5px;
}
.chatbot-ai-tag {
  font-size: 0.6rem; font-weight: 800;
  background: rgba(255,255,255,0.25); color: #fff;
  padding: 1px 5px; border-radius: 4px; letter-spacing: 0.5px;
}
.chatbot-subname { font-size: 0.72rem; color: rgba(255,255,255,0.85); font-weight: 500; }
.chatbot-hdr-right { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.chatbot-icon-btn {
  width: 30px !important; height: 30px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,0.2) !important;
  color: #fff !important;
  border: none !important; box-shadow: none !important;
  display: flex !important; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 0.15s !important;
}
.chatbot-icon-btn:hover { background: rgba(255,255,255,0.35) !important; }

/* ── Messages ── */
.chatbot-messages {
  flex: 1; overflow-y: auto;
  padding: 14px 13px;
  display: flex; flex-direction: column; gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: var(--border-color, rgba(0,0,0,0.1)) transparent;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}
.chatbot-messages::-webkit-scrollbar { width: 4px; }
.chatbot-messages::-webkit-scrollbar-thumb { background: var(--border-color, rgba(0,0,0,0.12)); border-radius: 4px; }

/* ── Bubbles ── */
.cb-msg {
  display: flex; flex-direction: column; gap: 6px;
  animation: cmsg-in 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes cmsg-in {
  from { opacity: 0; transform: translateY(10px) scale(0.95); }
  to   { opacity: 1; transform: none; }
}
.cb-msg--user { align-items: flex-end; }
.cb-msg--bot  { align-items: flex-start; }
.cb-bubble {
  max-width: 88%; padding: 10px 13px;
  border-radius: 16px; font-size: 0.84rem; line-height: 1.5; word-wrap: break-word;
}
.cb-msg--user .cb-bubble {
  background: linear-gradient(135deg, #00c853, #00e676);
  color: #fff; border-radius: 16px 16px 4px 16px;
}
.cb-bubble--bot {
  background: var(--bg-primary, #e3e8f0);
  color: var(--text-primary, #1e293b);
  border-radius: 16px 16px 16px 4px;
  max-width: 100%; padding: 12px 14px;
}
[data-theme="dark"] .cb-bubble--bot {
  background: var(--bg-tertiary, #272d3b);
  color: var(--text-primary, #e2e8f0);
}

/* Typing */
.cb-typing { padding: 12px 16px !important; display: flex !important; align-items: center; gap: 5px; }
.cb-typing span:not(.cb-typing-label) {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-secondary, #64748b);
  animation: cb-bounce 1.2s ease-in-out infinite; display: inline-block;
}
.cb-typing span:not(.cb-typing-label):nth-child(2) { animation-delay: 0.2s; }
.cb-typing span:not(.cb-typing-label):nth-child(3) { animation-delay: 0.4s; }
@keyframes cb-bounce {
  0%,60%,100% { transform: translateY(0);  opacity: 0.4; }
  30%          { transform: translateY(-6px); opacity: 1;   }
}

/* Quick chips */
.cb-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 3px; }
.cb-chip {
  font-size: 0.73rem; font-weight: 600;
  padding: 4px 10px; border-radius: 20px;
  background: var(--bg-primary, #e3e8f0) !important;
  color: var(--text-primary, #1e293b) !important;
  border: 1px solid var(--border-color, rgba(0,0,0,0.09)) !important;
  box-shadow: none !important; cursor: pointer; white-space: nowrap;
  transition: all 0.18s;
}
.cb-chip:hover {
  background: #10b981 !important; color: #fff !important;
  border-color: #10b981 !important; transform: translateY(-1px) !important;
}
[data-theme="dark"] .cb-chip {
  background: var(--bg-tertiary, #272d3b) !important;
  color: var(--text-primary, #e2e8f0) !important;
  border-color: var(--border-color, rgba(255,255,255,0.08)) !important;
}

/* Footer */
.chatbot-footer {
  padding: 11px 13px;
  border-top: 1px solid var(--border-color, rgba(0,0,0,0.07));
  flex-shrink: 0;
  background: var(--bg-secondary, #f0f4fb);
}
.chatbot-input-row { display: flex; gap: 8px; align-items: center; }
.chatbot-input {
  flex: 1; padding: 9px 13px;
  border-radius: 12px;
  border: 1.5px solid var(--border-color, rgba(0,0,0,0.1)) !important;
  background: var(--bg-primary, #e3e8f0) !important;
  color: var(--text-primary, #1e293b) !important;
  font-size: 0.83rem; outline: none;
  font-family: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.chatbot-input:focus {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.13) !important;
}
.chatbot-input::placeholder { color: var(--text-secondary, #94a3b8); }
.chatbot-send-btn {
  width: 38px !important; height: 38px !important; border-radius: 10px !important;
  background: linear-gradient(135deg, #00c853, #00e676) !important;
  color: #fff !important; border: none !important;
  box-shadow: 0 3px 10px rgba(0,200,83,0.3) !important;
  display: flex !important; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  transition: transform 0.15s, box-shadow 0.15s !important;
}
.chatbot-send-btn:hover {
  transform: translateY(-1px) scale(1.06) !important;
  box-shadow: 0 5px 16px rgba(0,200,83,0.45) !important;
}

/* ── Bot message content ── */
.cb-card-title { font-weight: 700; font-size: 0.88rem; margin-bottom: 10px; color: var(--text-primary,#1e293b); }
.cb-card-subtitle { font-weight: 600; font-size: 0.76rem; color: var(--text-secondary,#64748b); margin-bottom: 7px; }
.cb-card-meta { font-size: 0.72rem; color: var(--text-secondary,#64748b); margin-top: 2px; }
.cb-big-num { font-size: 1.5rem; font-weight: 800; letter-spacing: -0.5px; margin: 4px 0; }
.cb-divider { height: 1px; background: var(--border-color,rgba(0,0,0,0.07)); margin: 10px 0; }
.cb-more { font-size: 0.72rem; color: var(--text-secondary,#64748b); text-align: center; margin-top: 6px; }

.cb-alert { border-radius: 8px; padding: 7px 10px; font-size: 0.77rem; font-weight: 600; margin-top: 8px; }
.cb-alert--warn { background: rgba(245,158,11,0.12); color: #92400e; border-left: 3px solid #f59e0b; }
.cb-alert--ok   { background: rgba(16,185,129,0.1);  color: #065f46; border-left: 3px solid #10b981; }
[data-theme="dark"] .cb-alert--warn { color: #fcd34d; background: rgba(245,158,11,0.15); }
[data-theme="dark"] .cb-alert--ok   { color: #6ee7b7; background: rgba(16,185,129,0.15); }

.cb-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin: 8px 0; }
.cb-stats-3    { grid-template-columns: 1fr 1fr 1fr; }
.cb-stat-item  { background: var(--bg-secondary,#f0f4fb); border-radius: 10px; padding: 8px 10px; }
[data-theme="dark"] .cb-stat-item { background: rgba(255,255,255,0.05); }
.cb-stat-label { font-size: 0.68rem; color: var(--text-secondary,#64748b); font-weight: 600; margin-bottom: 3px; }
.cb-stat-value { font-size: 0.86rem; font-weight: 800; }

.cb-bars { display: flex; flex-direction: column; gap: 7px; }
.cb-bar-row { display: grid; grid-template-columns: 78px 1fr 70px; align-items: center; gap: 7px; }
.cb-bar-label { font-size: 0.71rem; font-weight: 600; color: var(--text-primary,#1e293b); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cb-bar-track { height: 6px; border-radius: 3px; background: var(--bg-primary,#e3e8f0); overflow: hidden; }
[data-theme="dark"] .cb-bar-track { background: rgba(255,255,255,0.08); }
.cb-bar-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg,#ef4444,#f97316); transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }
.cb-bar-val { font-size: 0.7rem; font-weight: 700; color: var(--text-primary,#1e293b); text-align: right; }

.cb-rows { display: flex; flex-direction: column; gap: 6px; }
.cb-row-item { display: flex; align-items: center; gap: 8px; font-size: 0.8rem; }
.cb-row-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.cb-row-val { margin-left: auto; font-weight: 700; }

.cb-goals-list { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.cb-goal-item { display: flex; flex-direction: column; gap: 5px; }
.cb-goal-header { display: flex; justify-content: space-between; align-items: center; }
.cb-goal-name { font-size: 0.82rem; font-weight: 700; color: var(--text-primary,#1e293b); }
.cb-goal-pct { font-size: 0.78rem; font-weight: 800; }
.cb-goal-bar { height: 6px; border-radius: 3px; background: var(--bg-primary,#e3e8f0); overflow: hidden; }
[data-theme="dark"] .cb-goal-bar { background: rgba(255,255,255,0.08); }
.cb-goal-fill { height: 100%; border-radius: 3px; transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }
.cb-goal-vals { display: flex; justify-content: space-between; font-size: 0.67rem; color: var(--text-secondary,#64748b); }

.cb-cards-list { display: flex; flex-direction: column; gap: 9px; margin-top: 8px; }
.cb-card-item { display: flex; gap: 10px; align-items: flex-start; background: var(--bg-secondary,#f0f4fb); border-radius: 10px; padding: 9px 11px; }
[data-theme="dark"] .cb-card-item { background: rgba(255,255,255,0.05); }
.cb-card-icon { font-size: 1.3rem; }
.cb-card-info { flex: 1; min-width: 0; }
.cb-card-cname { font-size: 0.82rem; font-weight: 700; color: var(--text-primary,#1e293b); margin-bottom: 5px; }
.cb-card-limit-bar { height: 5px; border-radius: 3px; background: var(--bg-primary,#e3e8f0); overflow: hidden; margin-bottom: 4px; }
[data-theme="dark"] .cb-card-limit-bar { background: rgba(255,255,255,0.08); }
.cb-card-limit-fill { height: 100%; border-radius: 3px; transition: width 0.5s; }
.cb-card-limit-txt { display: flex; justify-content: space-between; font-size: 0.68rem; font-weight: 600; color: var(--text-secondary,#64748b); }

.cb-tips { display: flex; flex-direction: column; gap: 9px; margin-top: 6px; }
.cb-tip-item { display: flex; gap: 9px; align-items: flex-start; padding: 9px 11px; background: var(--bg-secondary,#f0f4fb); border-radius: 10px; }
[data-theme="dark"] .cb-tip-item { background: rgba(255,255,255,0.05); }
.cb-tip-emoji { font-size: 1.15rem; flex-shrink: 0; margin-top: 1px; }
.cb-tip-title { font-size: 0.79rem; font-weight: 700; color: var(--text-primary,#1e293b); margin-bottom: 3px; }
.cb-tip-text  { font-size: 0.74rem; color: var(--text-secondary,#64748b); line-height: 1.4; }

.cb-health-score { display: flex; align-items: center; gap: 14px; padding: 6px 0; }
.cb-health-ring  { position: relative; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cb-health-num   { position: absolute; font-size: 1.1rem; font-weight: 900; }
.cb-health-label { font-size: 0.94rem; font-weight: 800; }
.cb-health-desc  { font-size: 0.73rem; color: var(--text-secondary,#64748b); margin-top: 3px; }

.cb-summary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 10px; }
.cb-summary-item { background: var(--bg-secondary,#f0f4fb); border-radius: 8px; padding: 7px 10px; font-size: 0.74rem; font-weight: 600; color: var(--text-primary,#1e293b); }
[data-theme="dark"] .cb-summary-item { background: rgba(255,255,255,0.05); }

.cb-help-list { display: flex; flex-direction: column; gap: 7px; margin-top: 8px; }
.cb-help-item { font-size: 0.78rem; color: var(--text-secondary,#64748b); display: flex; align-items: center; gap: 8px; }
.cb-help-key  { font-weight: 700; color: var(--text-primary,#1e293b); flex-shrink: 0; min-width: 90px; }

.cb-welcome { display: flex; gap: 10px; align-items: flex-start; }
.cb-welcome-icon { font-size: 1.5rem; flex-shrink: 0; }
.cb-welcome-text { font-size: 0.82rem; line-height: 1.55; color: var(--text-primary,#1e293b); }

.cb-empty { font-size: 0.82rem; color: var(--text-secondary,#64748b); text-align: center; padding: 8px 0; line-height: 1.55; }

/* AI chat specific */
.cb-ai-text { display: block; }
.cb-ai-text strong { font-weight: 700; }
.cb-ai-text em { font-style: italic; }
.cb-ai-text code { background: rgba(0,0,0,0.07); border-radius: 4px; padding: 1px 5px; font-family: monospace; font-size: 0.82em; }
[data-theme="dark"] .cb-ai-text code { background: rgba(255,255,255,0.1); }

.cb-typing-label { font-size: 0.72rem; color: var(--text-secondary,#94a3b8); margin-left: 6px; font-style: italic; }

.cb-powered { font-size: 0.67rem; color: var(--text-secondary,#94a3b8); text-align: center; margin-top: 10px; opacity: 0.75; }

.cb-welcome-snap { margin-top: 7px; font-size: 0.75rem; opacity: 0.92; line-height: 1.6; }

/* ═══════════════════════════════════════════════════════════════
   UPDATE ANNOUNCEMENT MODAL
   ═══════════════════════════════════════════════════════════════ */
.upd-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: updFadeIn 0.4s ease both;
}
.upd-modal-overlay.active {
  display: flex;
}
@keyframes updFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.upd-modal {
  position: relative;
  width: 100%;
  max-width: 420px;
  background: var(--bg-secondary, #f0f4fb);
  border-radius: 24px;
  padding: 36px 28px 28px;
  text-align: center;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,0.25), 0 0 0 1px rgba(255,255,255,0.08);
  animation: updSlideUp 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
  animation-delay: 0.1s;
}
[data-theme="dark"] .upd-modal {
  background: var(--bg-secondary, #1e2235);
  box-shadow: 0 24px 80px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04);
}
@keyframes updSlideUp {
  from { opacity: 0; transform: translateY(40px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.upd-modal-glow {
  position: absolute;
  top: -60px; left: 50%;
  transform: translateX(-50%);
  width: 260px; height: 180px;
  background: radial-gradient(ellipse, rgba(16,185,129,0.25) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
[data-theme="dark"] .upd-modal-glow {
  background: radial-gradient(ellipse, rgba(0,200,83,0.18) 0%, transparent 70%);
}
.upd-modal-badge {
  display: inline-block;
  position: relative;
  z-index: 1;
  background: linear-gradient(135deg, #00c853, #00e676);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 1.5px;
  padding: 4px 14px;
  border-radius: 20px;
  margin-bottom: 16px;
}
.upd-modal-icon {
  position: relative;
  z-index: 1;
  width: 80px; height: 80px;
  margin: 0 auto 18px;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(16,185,129,0.12), rgba(0,230,118,0.08));
  display: flex; align-items: center; justify-content: center;
  color: #10b981;
}
[data-theme="dark"] .upd-modal-icon {
  background: linear-gradient(135deg, rgba(0,200,83,0.15), rgba(0,230,118,0.08));
  color: #00e676;
}
.upd-modal-title {
  position: relative; z-index: 1;
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--text-primary, #1e293b);
  margin: 0 0 4px;
  line-height: 1.3;
}
.upd-modal-subtitle {
  position: relative; z-index: 1;
  font-size: 0.78rem;
  color: var(--text-secondary, #64748b);
  font-weight: 600;
  margin: 0 0 22px;
}
.upd-modal-features {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 12px;
  text-align: left;
  margin-bottom: 24px;
}
.upd-feature {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 14px;
  background: var(--bg-primary, #e3e8f0);
  border-radius: 14px;
  transition: transform 0.2s;
}
[data-theme="dark"] .upd-feature {
  background: rgba(255,255,255,0.04);
}
.upd-feature:hover { transform: translateX(4px); }
.upd-feature-icon {
  flex-shrink: 0;
  width: 40px; height: 40px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
}
.upd-feature strong {
  display: block;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-primary, #1e293b);
  margin-bottom: 2px;
}
.upd-feature span {
  font-size: 0.72rem;
  color: var(--text-secondary, #64748b);
  line-height: 1.45;
}
.upd-modal-btn {
  position: relative; z-index: 1;
  width: 100%;
  padding: 14px 20px !important;
  border: none !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #00c853, #00e676) !important;
  color: #fff !important;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  display: flex !important; align-items: center; justify-content: center; gap: 8px;
  box-shadow: 0 6px 24px rgba(0,200,83,0.35);
  transition: transform 0.2s, box-shadow 0.2s;
}
.upd-modal-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 32px rgba(0,200,83,0.45) !important;
  background: linear-gradient(135deg, #00c853, #00e676) !important;
}
.upd-modal-btn:active { transform: scale(0.97) !important; }
.upd-modal-dismiss {
  position: relative; z-index: 1;
  font-size: 0.68rem;
  color: var(--text-secondary, #94a3b8);
  margin: 12px 0 0;
}

/* Mobile */
/* ═══════════════════════════════════════════════════════════════
   MOBILE BOTTOM NAV + HUB + CONTEXTUAL FAB
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── HIDE old mobile elements ── */
  .sidebar,
  .mobile-menu-toggle,
  .mobile-menu-overlay,
  .mobile-top-bar,
  #fabButton {
    display: none !important;
    transform: none !important;
    visibility: hidden !important;
  }

  .main-content {
    margin-left: 0 !important;
    width: 100% !important;
  }

  .page > div {
    padding: 20px 16px 140px !important; /* extra bottom for bottom nav + safe area */
  }

  /* ── Hide all mobile chrome while landing page is active ── */
  body:has(#landingPage:not(.hidden)) #mobileBottomNav,
  body:has(#landingPage:not(.hidden)) #mobileCtxFab,
  body:has(#landingPage:not(.hidden)) #chatbotWrapper,
  body:has(#landingPage:not(.hidden)) #fabButton {
    display: none !important;
  }

  /* ── Bottom Navigation Bar ── */
  .m-bnav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 64px;
    background: var(--bg-secondary, #f0f4fb);
    display: none;
    align-items: stretch;
    justify-content: space-around;
    z-index: 9980;
    border-top: 1px solid var(--border-color, rgba(0,0,0,0.06));
    box-shadow: 0 -4px 20px rgba(0,0,0,0.06);
    padding-bottom: env(safe-area-inset-bottom, 0px);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  [data-theme="dark"] .m-bnav {
    background: rgba(30,35,50,0.92);
    border-top-color: rgba(255,255,255,0.06);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.25);
  }

  .m-bnav-item {
    flex: 1;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    cursor: pointer;
    color: var(--text-secondary, #94a3b8);
    transition: color 0.2s;
    -webkit-tap-highlight-color: transparent;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 6px 0 !important;
    position: relative;
  }
  .m-bnav-item span {
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.2px;
  }
  .m-bnav-item svg {
    transition: transform 0.2s;
  }
  .m-bnav-item.active {
    color: #10b981;
  }
  .m-bnav-item.active::before {
    content: '';
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    width: 28px; height: 3px;
    border-radius: 0 0 3px 3px;
    background: #10b981;
  }
  .m-bnav-item.active svg {
    transform: scale(1.12);
  }

  /* ── Hub center button ── */
  .m-bnav-hub {
    flex: 1.1;
    position: relative;
  }
  .m-bnav-hub-btn {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, #00c853, #00e676) !important;
    color: #fff !important;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(0,200,83,0.4);
    margin-top: -18px;
    transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s;
  }
  .m-bnav-hub-btn svg { stroke: #fff; }
  .m-bnav-hub:active .m-bnav-hub-btn {
    transform: scale(0.92);
  }

  /* ── Hub Panel ── */
  .m-hub-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 9995;
    opacity: 0;
    transition: opacity 0.3s ease;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
  }
  .m-hub-overlay.active { opacity: 1; }

  .m-hub-panel {
    display: none;
    position: fixed;
    bottom: 72px;
    left: 12px; right: 12px;
    z-index: 9996;
    background: var(--bg-secondary, #fff);
    border-radius: 20px;
    box-shadow: 0 -8px 40px rgba(0,0,0,0.15), 0 0 0 1px rgba(0,0,0,0.04);
    flex-direction: column;
    overflow: hidden;
    transform: translateY(30px);
    opacity: 0;
    transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1), opacity 0.25s ease;
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  [data-theme="dark"] .m-hub-panel {
    background: var(--bg-secondary, #1e2235);
    box-shadow: 0 -8px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04);
  }
  .m-hub-panel.active {
    transform: translateY(0) !important;
    opacity: 1 !important;
  }
  .m-hub-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 18px 10px;
  }
  .m-hub-title {
    font-size: 0.95rem; font-weight: 800;
    color: var(--text-primary, #1e293b);
  }
  .m-hub-close {
    width: 32px !important; height: 32px !important;
    border-radius: 10px !important;
    background: var(--bg-primary, #e3e8f0) !important;
    color: var(--text-secondary, #64748b) !important;
    border: none !important; box-shadow: none !important;
    display: flex !important; align-items: center; justify-content: center;
    cursor: pointer;
  }
  .m-hub-close:hover { background: var(--bg-tertiary, #d9dee8) !important; }

  .m-hub-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    padding: 8px 14px 18px;
  }
  .m-hub-item {
    display: flex; flex-direction: column;
    align-items: center; gap: 6px;
    padding: 12px 6px;
    border-radius: 14px;
    cursor: pointer;
    transition: background 0.15s;
    -webkit-tap-highlight-color: transparent;
  }
  .m-hub-item:active { background: var(--bg-primary, #e3e8f0); }
  .m-hub-icon {
    width: 44px; height: 44px;
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
  }
  .m-hub-item span {
    font-size: 0.68rem; font-weight: 600;
    color: var(--text-primary, #1e293b);
    text-align: center;
  }
  .m-hub-item--logout:active { background: rgba(239,68,68,0.08); }
  .m-hub-item--logout span { color: #ef4444; }

  /* ── Contextual FAB ── */
  .m-ctx-fab {
    position: fixed !important;
    bottom: 80px !important; /* above bottom nav */
    right: 20px !important;
    width: 52px !important; height: 52px !important;
    border-radius: 16px !important;
    background: linear-gradient(135deg, #00c853, #00e676) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 6px 22px rgba(0,200,83,0.45), 0 2px 6px rgba(0,0,0,0.1) !important;
    display: none;
    align-items: center; justify-content: center;
    z-index: 9970;
    cursor: pointer;
    transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s !important;
  }
  .m-ctx-fab.fab-enter {
    animation: cfab-in 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
  }
  .m-ctx-fab:hover {
    transform: translateY(-2px) scale(1.08) !important;
    box-shadow: 0 10px 28px rgba(0,200,83,0.55) !important;
  }
  .m-ctx-fab:active {
    transform: scale(0.92) !important;
  }

  /* ── Chatbot repositioned above bottom nav ── */
  #chatbotWrapper {
    bottom: 80px !important;
    right: auto !important;
    left: 16px !important;
    align-items: flex-start;
  }
  .chatbot-panel {
    transform-origin: bottom left;
    width: calc(100vw - 32px);
    max-height: 60vh;
  }
  .chatbot-fab {
    width: 48px !important;
    height: 48px !important;
  }
  .chatbot-fab::before {
    display: none !important; /* no pulse ring on mobile — cleaner */
  }

  /* ── Hide mobile chrome when modal is open ── */
  body.modal-open .m-bnav,
  body.modal-open .m-ctx-fab,
  body.modal-open #chatbotWrapper {
    display: none !important;
  }

} /* end @media max-width: 768px */

/* Desktop: hide mobile-only elements */
@media (min-width: 769px) {
  .m-bnav, .m-hub-overlay, .m-hub-panel, .m-ctx-fab {
    display: none !important;
  }
}

/* ============================================================ */
/*   LANDING PAGE V2 — PREMIUM LIGHT REDESIGN                  */
/* ============================================================ */

.lp-root {
  position: fixed;
  inset: 0;
  z-index: 45;
  background: #f0f4f8;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  font-family: 'Quicksand', -apple-system, BlinkMacSystemFont, sans-serif;
  color: #0f172a;
  scroll-behavior: smooth;
}

/* ---- NAVBAR ---- */
.lp-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(240, 244, 248, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(226, 232, 240, 0.8);
}

.lp-nav-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 14px 24px;
  display: flex;
  align-items: center;
  gap: 32px;
}

.lp-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.lp-brand-img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  border-radius: 10px;
}

.lp-brand-text {
  font-size: 1.1rem;
  font-weight: 600;
  color: #0f172a;
}

.lp-brand-text strong {
  font-weight: 800;
  color: #10b981;
}

.lp-nav-links {
  display: flex;
  gap: 28px;
  flex: 1;
}

.lp-nav-links a {
  color: #475569;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 600;
  transition: color 0.2s;
}

.lp-nav-links a:hover {
  color: #10b981;
}

.lp-nav-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-shrink: 0;
}

/* ---- BUTTONS ---- */
.lp-btn-ghost {
  background: transparent;
  border: none;
  color: #475569;
  font-size: 0.9rem;
  font-weight: 600;
  padding: 9px 16px;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  font-family: inherit;
}

.lp-btn-ghost:hover {
  background: #e8edf3;
  color: #0f172a;
}

.lp-btn-primary {
  background: #10b981;
  border: none;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  padding: 9px 20px;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
}

.lp-btn-primary:hover {
  background: #059669;
  transform: translateY(-1px);
}

.lp-btn-hero {
  background: linear-gradient(135deg, #10b981, #059669);
  border: none;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: 14px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 4px 20px rgba(16, 185, 129, 0.35);
  font-family: inherit;
}

.lp-btn-hero:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(16, 185, 129, 0.50);
}

.lp-btn-outline {
  background: transparent;
  border: 2px solid #94a3b8;
  color: #334155;
  font-size: 1rem;
  font-weight: 600;
  padding: 12px 24px;
  border-radius: 14px;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
  font-family: inherit;
}

.lp-btn-outline:hover {
  border-color: #10b981;
  color: #10b981;
  background: rgba(16, 185, 129, 0.05);
}

.lp-btn-white {
  background: #fff !important;
  color: #10b981 !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
}

.lp-btn-white:hover {
  background: #f0fdf4 !important;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2) !important;
}

.lp-btn-outline-white {
  border-color: rgba(255, 255, 255, 0.5) !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

.lp-btn-outline-white:hover {
  border-color: #fff !important;
  color: #fff !important;
  background: rgba(255, 255, 255, 0.12) !important;
}

/* ---- BADGE ---- */
.lp-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 14px;
  background: rgba(16, 185, 129, 0.10);
  color: #059669;
  border: 1px solid rgba(16, 185, 129, 0.22);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.lp-badge-gray {
  background: #f1f5f9;
  color: #64748b;
  border-color: #e2e8f0;
}

/* ---- HERO ---- */
.lp-hero {
  max-width: 1180px;
  margin: 0 auto;
  padding: 72px 24px 64px;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: center;
}

.lp-hero-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.lp-hero-title {
  font-size: clamp(2.3rem, 4.2vw, 3.5rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #0f172a;
  margin: 0 0 18px;
}

.lp-accent {
  background: linear-gradient(135deg, #10b981, #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.lp-hero-desc {
  color: #475569;
  font-size: 1.08rem;
  line-height: 1.7;
  margin: 0 0 30px;
  max-width: 520px;
}

.lp-hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.lp-trust-bar {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.lp-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #64748b;
  font-size: 0.84rem;
  font-weight: 600;
}

/* ---- HERO VISUAL (mock card) ---- */
.lp-hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 340px;
}

.lp-mock-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.10), 0 2px 10px rgba(15, 23, 42, 0.05);
}

.lp-mock-main {
  padding: 26px;
  width: 290px;
  position: relative;
  z-index: 2;
}

.lp-mock-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.lp-mock-label {
  font-size: 0.72rem;
  color: #94a3b8;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.lp-mock-dot-green {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #10b981;
  box-shadow: 0 0 7px rgba(16, 185, 129, 0.55);
}

.lp-mock-balance {
  font-size: 1.9rem;
  font-weight: 800;
  color: #0f172a;
  margin-bottom: 14px;
  letter-spacing: -0.02em;
}

.lp-mock-row {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}

.lp-mock-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 700;
}

.lp-pill-green { background: #d1fae5; color: #059669; }
.lp-pill-red   { background: #fee2e2; color: #dc2626; }

.lp-mock-bar-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}

.lp-mock-bar-track {
  height: 7px;
  background: #f1f5f9;
  border-radius: 99px;
  overflow: hidden;
}

.lp-mock-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #10b981, #059669);
  border-radius: 99px;
}

.lp-mock-bar-label {
  font-size: 0.72rem;
  color: #94a3b8;
  font-weight: 600;
}

.lp-mock-categories {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 4px;
  border-top: 1px solid #f1f5f9;
}

.lp-mock-cat {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
}

.lp-mock-cat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.lp-mock-cat span {
  color: #64748b;
  flex: 1;
  font-weight: 600;
}

.lp-mock-cat strong {
  color: #0f172a;
  font-weight: 700;
}

.lp-mock-mini {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  width: 172px;
  position: absolute;
}

.lp-mock-mini-1 {
  top: -10px;
  right: -10px;
  transform: rotate(2deg);
  z-index: 3;
}

.lp-mock-mini-2 {
  bottom: 10px;
  right: -20px;
  transform: rotate(-1.5deg);
  z-index: 3;
}

.lp-mock-mini-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.lp-icon-blue   { background: #dbeafe; color: #3b82f6; }
.lp-icon-purple { background: #ede9fe; color: #7c3aed; }

.lp-mock-mini-title {
  font-size: 0.7rem;
  color: #94a3b8;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.lp-mock-mini-val {
  font-size: 0.9rem;
  color: #0f172a;
  font-weight: 700;
  margin-top: 1px;
}

/* ---- SECTIONS ---- */
.lp-section {
  padding: 80px 24px;
}

.lp-section-inner {
  max-width: 1180px;
  margin: 0 auto;
}

.lp-section-head {
  text-align: center;
  margin-bottom: 52px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.lp-section-title {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #0f172a;
  margin: 0 0 12px;
  line-height: 1.2;
}

.lp-section-sub {
  font-size: 1rem;
  color: #64748b;
  line-height: 1.65;
  max-width: 520px;
  margin: 0;
}

/* ---- FEATURES ---- */
.lp-features-section {
  background: #fff;
}

.lp-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.lp-feature-card {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 18px;
  padding: 28px 24px;
  transition: transform 0.22s, box-shadow 0.22s, border-color 0.22s;
}

.lp-feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
  border-color: #10b981;
}

.lp-feature-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}

.lp-fi-green  { background: #d1fae5; color: #059669; }
.lp-fi-blue   { background: #dbeafe; color: #3b82f6; }
.lp-fi-purple { background: #ede9fe; color: #7c3aed; }
.lp-fi-orange { background: #ffedd5; color: #ea580c; }
.lp-fi-teal   { background: #ccfbf1; color: #0d9488; }
.lp-fi-pink   { background: #fce7f3; color: #db2777; }

.lp-feature-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 8px;
}

.lp-feature-card p {
  font-size: 0.88rem;
  color: #64748b;
  line-height: 1.6;
  margin: 0;
}

/* ---- STATS ---- */
.lp-stats-section {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  padding: 52px 24px;
}

.lp-stats-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.lp-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex: 1;
}

.lp-stat-num {
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  color: #10b981;
  letter-spacing: -0.02em;
}

.lp-stat-label {
  font-size: 0.82rem;
  color: #94a3b8;
  font-weight: 600;
  text-align: center;
}

.lp-stat-divider {
  width: 1px;
  height: 52px;
  background: rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}

/* ---- TESTIMONIALS ---- */
.lp-testimonials-section {
  background: #f8fafc;
}

.lp-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.lp-testimonial {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: transform 0.22s, box-shadow 0.22s;
}

.lp-testimonial:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
}

.lp-testimonial-stars {
  color: #f59e0b;
  font-size: 0.95rem;
  letter-spacing: 2px;
}

.lp-testimonial p {
  color: #475569;
  font-size: 0.9rem;
  line-height: 1.7;
  margin: 0;
  flex: 1;
}

.lp-testimonial footer {
  display: flex;
  align-items: center;
  gap: 12px;
}

.lp-testimonial-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #d1fae5;
  color: #059669;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1rem;
  flex-shrink: 0;
}

.lp-avatar-blue   { background: #dbeafe; color: #3b82f6; }
.lp-avatar-purple { background: #ede9fe; color: #7c3aed; }

.lp-testimonial strong {
  display: block;
  color: #0f172a;
  font-size: 0.88rem;
  font-weight: 700;
}

.lp-testimonial span {
  color: #94a3b8;
  font-size: 0.78rem;
}

/* ---- FAQ ---- */
.lp-faq-section {
  background: #fff;
}

.lp-faq-inner {
  max-width: 760px;
}

.lp-faq-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lp-faq-item {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 16px 20px;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: #fff;
}

.lp-faq-item[open] {
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.08);
}

.lp-faq-item summary {
  cursor: pointer;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 700;
  list-style: none;
  position: relative;
  padding-right: 28px;
  user-select: none;
  font-family: inherit;
}

.lp-faq-item summary::-webkit-details-marker {
  display: none;
}

.lp-faq-item summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #10b981;
  font-size: 1.3rem;
  font-weight: 300;
  line-height: 1;
  transition: transform 0.2s;
}

.lp-faq-item[open] summary::after {
  content: '−';
}

.lp-faq-item p {
  margin: 12px 0 0;
  color: #64748b;
  font-size: 0.9rem;
  line-height: 1.65;
}

/* ---- FINAL CTA ---- */
.lp-cta-section {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  padding: 80px 24px;
  position: relative;
  overflow: hidden;
}

.lp-cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.08), transparent 40%),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.06), transparent 35%);
  pointer-events: none;
}

.lp-cta-inner {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  position: relative;
  z-index: 1;
}

.lp-cta-title {
  font-size: clamp(1.9rem, 3.5vw, 2.7rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.12;
  letter-spacing: -0.025em;
  margin: 0;
}

.lp-cta-sub {
  color: rgba(255, 255, 255, 0.85);
  font-size: 1.02rem;
  line-height: 1.65;
  margin: 0;
}

.lp-cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 8px;
}

/* ---- FOOTER ---- */
.lp-footer {
  background: #0f172a;
  padding: 28px 24px;
}

.lp-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.lp-footer-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.lp-footer-logo {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  object-fit: contain;
}

.lp-footer-brand-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: #e2e8f0;
}

.lp-footer-brand-name strong {
  color: #10b981;
  font-weight: 800;
}

.lp-footer-copy {
  color: #64748b;
  font-size: 0.82rem;
  margin: 0;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 960px) {
  .lp-hero {
    grid-template-columns: 1fr;
    padding: 52px 24px 44px;
    gap: 44px;
  }

  .lp-hero-visual {
    display: none;
  }

  .lp-features-grid,
  .lp-testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .lp-nav-links {
    display: none;
  }
}

@media (max-width: 600px) {
  .lp-features-grid,
  .lp-testimonials-grid {
    grid-template-columns: 1fr;
  }

  .lp-stats-inner {
    flex-direction: column;
    gap: 20px;
  }

  .lp-stat-divider {
    width: 40px;
    height: 1px;
  }

  .lp-hero-title {
    font-size: 2.1rem;
  }

  .lp-hero-ctas {
    flex-direction: column;
    width: 100%;
  }

  .lp-btn-hero,
  .lp-btn-outline {
    width: 100%;
    justify-content: center;
  }

  .lp-cta-actions {
    flex-direction: column;
    width: 100%;
  }

  .lp-btn-white,
  .lp-btn-outline-white {
    width: 100%;
    justify-content: center;
  }

  .lp-footer-inner {
    flex-direction: column;
    text-align: center;
  }

  .lp-nav-inner {
    padding: 12px 16px;
  }

  .lp-btn-ghost {
    display: none;
  }

  .lp-section {
    padding: 56px 16px;
  }
}

/* ============================================================ */
/*   LANDING PAGE — THEME TOGGLE BUTTON                        */
/* ============================================================ */

.lp-theme-toggle {
  background: transparent;
  border: 1px solid rgba(15, 23, 42, 0.18);
  border-radius: 10px;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
  color: inherit;
}

.lp-theme-toggle:hover {
  background: rgba(15, 23, 42, 0.07);
}

/* ============================================================ */
/*   LANDING PAGE — BUTTON RESET OVERRIDES                      */
/*   The global `button { background: transparent !important }` */
/*   rule wipes LP button styles. These rules use .lp-root      */
/*   parent selector for higher specificity to win the cascade. */
/* ============================================================ */

.lp-root .lp-btn-primary {
  background: #10b981 !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
}

.lp-root .lp-btn-primary:hover {
  background: #059669 !important;
}

.lp-root .lp-btn-hero {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 20px rgba(16, 185, 129, 0.35), 0 1px 3px rgba(0, 0, 0, 0.12) !important;
}

.lp-root .lp-btn-hero:hover {
  box-shadow: 0 8px 30px rgba(16, 185, 129, 0.50) !important;
}

.lp-root .lp-btn-outline {
  background: transparent !important;
  border: 2px solid #94a3b8 !important;
  color: #334155 !important;
  box-shadow: none !important;
}

.lp-root .lp-btn-outline:hover {
  background: rgba(16, 185, 129, 0.05) !important;
  border-color: #10b981 !important;
  color: #10b981 !important;
}

.lp-root .lp-btn-ghost {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.lp-root .lp-theme-toggle {
  background: transparent !important;
  border: 1px solid rgba(15, 23, 42, 0.25) !important;
  box-shadow: none !important;
}

.lp-root .lp-theme-toggle:hover {
  background: rgba(15, 23, 42, 0.07) !important;
}

[data-theme="dark"] .lp-root .lp-btn-outline {
  border: 2px solid rgba(255, 255, 255, 0.20) !important;
  color: #a5b2c6 !important;
}

[data-theme="dark"] .lp-root .lp-btn-ghost {
  color: #a5b2c6 !important;
}

[data-theme="dark"] .lp-root .lp-btn-ghost:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  color: #e4e9f1 !important;
}

[data-theme="dark"] .lp-root .lp-theme-toggle {
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

[data-theme="dark"] .lp-root .lp-theme-toggle:hover {
  background: rgba(255, 255, 255, 0.07) !important;
}

/* ============================================================ */
/*   LANDING PAGE — DARK MODE                                   */
/* ============================================================ */

[data-theme="dark"] .lp-root {
  background: #1a1f2e;
  color: #e4e9f1;
}

[data-theme="dark"] .lp-nav {
  background: rgba(26, 31, 46, 0.95);
  border-bottom-color: rgba(255, 255, 255, 0.07);
}

[data-theme="dark"] .lp-brand-text {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-nav-links a {
  color: #a5b2c6;
}

[data-theme="dark"] .lp-nav-links a:hover {
  color: #5eeda6;
}

[data-theme="dark"] .lp-btn-ghost {
  color: #a5b2c6;
}

[data-theme="dark"] .lp-btn-ghost:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #e4e9f1;
}

[data-theme="dark"] .lp-theme-toggle {
  border-color: rgba(255, 255, 255, 0.15);
}

[data-theme="dark"] .lp-theme-toggle:hover {
  background: rgba(255, 255, 255, 0.07);
}

[data-theme="dark"] .lp-hero-title {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-hero-desc {
  color: #a5b2c6;
}

[data-theme="dark"] .lp-trust-item {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-btn-outline {
  border-color: rgba(255, 255, 255, 0.20);
  color: #a5b2c6;
}

[data-theme="dark"] .lp-btn-outline:hover {
  border-color: #5eeda6;
  color: #5eeda6;
  background: rgba(94, 237, 166, 0.07);
}

[data-theme="dark"] .lp-badge {
  background: rgba(94, 237, 166, 0.10);
  color: #5eeda6;
  border-color: rgba(94, 237, 166, 0.22);
}

[data-theme="dark"] .lp-badge-gray {
  background: rgba(255, 255, 255, 0.06);
  color: #7f8ca3;
  border-color: rgba(255, 255, 255, 0.08);
}

/* Hero mock cards */
[data-theme="dark"] .lp-mock-card {
  background: #272d3b;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.50), 0 2px 10px rgba(0, 0, 0, 0.30);
}

[data-theme="dark"] .lp-mock-label {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-mock-balance {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-mock-bar-track {
  background: #1f2430;
}

[data-theme="dark"] .lp-mock-bar-label {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-mock-categories {
  border-top-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .lp-mock-cat span {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-mock-cat strong {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-mock-mini-title {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-mock-mini-val {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-pill-green { background: rgba(94, 237, 166, 0.12); color: #5eeda6; }
[data-theme="dark"] .lp-pill-red   { background: rgba(255, 128, 128, 0.12); color: #ff8080; }
[data-theme="dark"] .lp-icon-blue   { background: rgba(107, 184, 255, 0.15); color: #6cb8ff; }
[data-theme="dark"] .lp-icon-purple { background: rgba(167, 139, 250, 0.15); color: #a78bfa; }

/* Section titles */
[data-theme="dark"] .lp-section-title {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-section-sub {
  color: #a5b2c6;
}

/* Features section */
[data-theme="dark"] .lp-features-section {
  background: #1f2430;
}

[data-theme="dark"] .lp-feature-card {
  background: #272d3b;
  border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .lp-feature-card:hover {
  border-color: #5eeda6;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.30);
}

[data-theme="dark"] .lp-feature-card h3 {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-feature-card p {
  color: #a5b2c6;
}

[data-theme="dark"] .lp-fi-green  { background: rgba(94, 237, 166, 0.12); color: #5eeda6; }
[data-theme="dark"] .lp-fi-blue   { background: rgba(107, 184, 255, 0.12); color: #6cb8ff; }
[data-theme="dark"] .lp-fi-purple { background: rgba(167, 139, 250, 0.12); color: #a78bfa; }
[data-theme="dark"] .lp-fi-orange { background: rgba(251, 146, 60, 0.12);  color: #fb923c; }
[data-theme="dark"] .lp-fi-teal   { background: rgba(45, 212, 191, 0.12);  color: #2dd4bf; }
[data-theme="dark"] .lp-fi-pink   { background: rgba(244, 114, 182, 0.12); color: #f472b6; }

/* Testimonials section */
[data-theme="dark"] .lp-testimonials-section {
  background: #1a1f2e;
}

[data-theme="dark"] .lp-testimonial {
  background: #272d3b;
  border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .lp-testimonial:hover {
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.30);
}

[data-theme="dark"] .lp-testimonial p {
  color: #a5b2c6;
}

[data-theme="dark"] .lp-testimonial strong {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-testimonial span {
  color: #7f8ca3;
}

[data-theme="dark"] .lp-testimonial-avatar      { background: rgba(94, 237, 166, 0.15); color: #5eeda6; }
[data-theme="dark"] .lp-avatar-blue             { background: rgba(107, 184, 255, 0.15); color: #6cb8ff; }
[data-theme="dark"] .lp-avatar-purple           { background: rgba(167, 139, 250, 0.15); color: #a78bfa; }

/* FAQ section */
[data-theme="dark"] .lp-faq-section {
  background: #1f2430;
}

[data-theme="dark"] .lp-faq-item {
  background: #272d3b;
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .lp-faq-item[open] {
  border-color: #5eeda6;
  box-shadow: 0 0 0 3px rgba(94, 237, 166, 0.10);
}

[data-theme="dark"] .lp-faq-item summary {
  color: #e4e9f1;
}

[data-theme="dark"] .lp-faq-item p {
  color: #a5b2c6;
}

/* Footer */
[data-theme="dark"] .lp-footer {
  background: #0d1117;
}
