/* ═══════════════════════════════════════════════════════════════
    BlueLedger — Premium Fintech CSS
    Palette: Deep Navy-Black + Violet-Blue glow + Platinum accents
    ═══════════════════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap");

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes bl-verify-pulse {
  0%,
  100% {
    box-shadow: 0 0 40px rgba(79, 110, 247, 0.2);
  }
  50% {
    box-shadow: 0 0 60px rgba(79, 110, 247, 0.45);
  }
}

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

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

input,
select,
textarea {
  font-family: inherit;
}

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

img {
  max-width: 100%;
}

/* ── Tokens ─────────────────────────────────────────────────── */

:root {
  /* ── Graphite Obsidian — Option A ─────────────────────────── */
  --bg: #0e1117;
  --bg2: #131720;
  --bg3: #161b22;
  --bg-card: #161b22;
  --bg-card-hi: #1c2128;
  --bg-surface: #0d1017;

  --t1: #e6edf3;
  --t2: rgba(230, 237, 243, 0.58);
  --t3: rgba(230, 237, 243, 0.34);
  --t4: rgba(230, 237, 243, 0.16);

  --border: rgba(255, 255, 255, 0.06);
  --border-md: rgba(255, 255, 255, 0.09);
  --border-hi: rgba(255, 255, 255, 0.14);

  --accent: #4f6ef7;
  --accent-deep: #3b5bdb;
  --accent-dim: rgba(79, 110, 247, 0.09);
  --accent-glow: rgba(79, 110, 247, 0.14);

  --inc: #22c55e;
  --inc-dim: rgba(34, 197, 94, 0.08);

  --exp: #f43f5e;
  --exp-dim: rgba(244, 63, 94, 0.08);

  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 6px 24px rgba(0, 0, 0, 0.48);
  --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.56);
  --shadow-xl: 0 28px 72px rgba(0, 0, 0, 0.64);
  --glow-accent: none;

  --glass: rgba(14, 17, 23, 0.85);
  --glass-blur: 24px;

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 20px;
  --r-xl: 26px;

  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;

  --y: 50%;
}

/* ── Light theme ────────────────────────────────────────────── */

[data-theme="light"] {
  /* ── Backgrounds & Surfaces (Lumina Finance tokens) ── */
  --bg: #f7f9fb;
  --bg2: #ffffff;
  --bg3: #f2f4f6;
  --bg-card: #ffffff;
  --bg-card-hi: #f2f4f6;
  --bg-surface: #eceef0;
  --surface-1: #ffffff;
  --surface-2: #f2f4f6;
  --surface-3: #eceef0;
  --t1: #191c1e;
  --t2: #464555;
  --t3: #777587;
  --t4: #c7c4d8;

  /* ── Text ── */

  /* ── Borders ── */
  --border: #c7c4d8;
  --border-md: #c7c4d8;
  --border-hi: #777587;

  /* ── Accent (Indigo primary) ── */
  --accent: #4f46e5;
  --accent-deep: #3525cd;
  --accent-dim: #e2dfff;
  --accent-glow: rgba(77, 68, 227, 0.08);
  --glow-accent: none;

  /* ── Glass ── */
  --glass: rgba(255, 255, 255, 0.8);
  --glass-blur: 24px;

  /* ── Semantic ── */
  --inc: #059669;
  --inc-dim: rgba(5, 150, 105, 0.1);
  --exp: #ba1a1a;
  --exp-dim: rgba(186, 26, 26, 0.1);
  --shadow-sm: 0 2px 8px rgba(77, 68, 227, 0.05), 0 1px 2px rgba(0, 0, 0, 0.03);
  --shadow-md: 0 4px 20px rgba(0, 0, 0, 0.04), 0 2px 4px rgba(0, 0, 0, 0.02);
  --shadow-lg:
    0 8px 40px rgba(77, 68, 227, 0.08), 0 4px 8px rgba(0, 0, 0, 0.04);
  --shadow-xl:
    0 16px 56px rgba(77, 68, 227, 0.1), 0 6px 12px rgba(0, 0, 0, 0.05);

  /* ── Shadows (Lumina ambient, indigo-tinted) ── */

  /* ── Radii ── */
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 16px;
  --r-xl: 24px;
}
/* ── Base ───────────────────────────────────────────────────── */

html {
  height: 100%;
}

body {
  font-family: "DM Sans", system-ui, sans-serif;
  background: var(--bg);
  color: var(--t1);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  height: 100vh;
  overflow: hidden;
}

/* Ambient background glow */

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background:
    radial-gradient(
      ellipse 90% 55% at -5% -5%,
      rgba(59, 91, 219, 0.14) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 60% 45% at 105% 0%,
      rgba(139, 92, 246, 0.11) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 55% 55% at 50% 105%,
      rgba(34, 197, 94, 0.06) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 40% 35% at 80% 60%,
      rgba(79, 110, 247, 0.07) 0%,
      transparent 50%
    ),
    linear-gradient(180deg, var(--bg) 0%, var(--bg) 100%);
}

/* Cursor radial */

body::after {
  content: "";
  position: fixed;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(79, 110, 247, 0.04) 0%,
    transparent 65%
  );
  transform: translate(-50%, -50%);
  left: var(--x, 50%);
  top: var(--y, 50%);
  pointer-events: none;
  z-index: 0;
  transition:
    left 0.1s,
    top 0.1s;
}

/* ════════════════════════════════════════════════════════════
    APP LAYOUT
    ════════════════════════════════════════════════════════════ */

.app-layout {
  display: flex;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
  flex-direction: row;
}

/* ════════════════════════════════════════════════════════════
    SIDEBAR
    ════════════════════════════════════════════════════════════ */

.sidebar {
  width: 72px !important;
  flex-shrink: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 0 20px;
  background: var(--bg2);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  border-right: 1px solid var(--border);
  z-index: 100;
  gap: 0;
  min-width: 72px;
  max-width: 72px;
  overflow: hidden;
}

.sidebar-logo {
  width: 40px;
  height: 40px;
  border-radius: 13px;
  background: linear-gradient(135deg, #3b5bdb 0%, #4f6ef7 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  box-shadow:
    0 4px 24px rgba(79, 110, 247, 0.4),
    0 0 0 1px rgba(147, 180, 255, 0.2) inset;
  flex-shrink: 0;
  overflow: hidden;
}

.sidebar-logo img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.sb-letter {
  font-size: 0.9rem;
  font-weight: 900;
  color: white;
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  flex: 1;
  width: 100%;
  padding: 0 10px;
}

.sb-btn {
  width: 48px;
  height: 44px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--t3);
  font-size: 1rem;
  transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
}

.sb-btn:hover {
  background: rgba(79, 110, 247, 0.08);
  color: var(--t2);
  transform: translateX(1px);
}

.sb-btn.active,
.sb-btn.bn-tab--active {
  background: rgba(79, 110, 247, 0.12);
  color: var(--accent);
  box-shadow: 0 0 20px rgba(79, 110, 247, 0.14);
}

.sb-btn.active::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 22px;
  background: linear-gradient(180deg, var(--accent-deep), var(--accent));
  border-radius: 0 4px 4px 0;
  box-shadow: 2px 0 12px rgba(79, 110, 247, 0.5);
}

.sidebar-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  border-top: 1px solid var(--border);
  padding-top: 0.8rem;
  width: 100%;
  padding: 12px 10px 0;
}

/* ════════════════════════════════════════════════════════════
    MAIN AREA
    ════════════════════════════════════════════════════════════ */

.main-area {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

/* ════════════════════════════════════════════════════════════
    TOPBAR
    ════════════════════════════════════════════════════════════ */

.topbar {
  height: 64px !important;
  display: grid;
  grid-template-columns: auto 1fr auto !important;
  align-items: center;
  padding: 0 var(--space-lg) !important;
  justify-content: space-between;
  flex-shrink: 0;
  background: var(--glass);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
  z-index: 50;
  position: relative;
  gap: var(--space-md);
}

.topbar-left {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-width: 0;
}

.topbar-title {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--t1);
  white-space: nowrap;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.01em;
}

.topbar-search {
  display: none !important;
  align-items: center;
  gap: 0.6rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 50px;
  padding: 0.52rem 1.1rem;
  width: 380px !important;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  max-width: 100%;
  box-shadow: 0 0 0 0 transparent;
}

.topbar-search:focus-within {
  border-color: rgba(79, 110, 247, 0.35);
  background: rgba(79, 110, 247, 0.05);
  width: 420px;
  box-shadow:
    0 0 0 3px rgba(79, 110, 247, 0.08),
    0 4px 20px rgba(0, 0, 0, 0.3);
}

.topbar-search i {
  color: rgba(79, 110, 247, 0.5);
  font-size: 0.82rem;
}

.topbar-search input {
  background: transparent;
  border: none;
  outline: none;
  color: var(--t1);
  font-size: 0.84rem;
  width: 100%;
  pointer-events: auto !important;
  cursor: text !important;
  font-family: "DM Sans", sans-serif;
}

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

.topbar-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
}

/* Topbar buttons */

.tb-btn {
  display: flex;
  align-items: center;
  gap: 0.38rem;
  padding: 0.36rem 0.8rem;
  border-radius: 50px;
  font-size: 0.76rem;
  font-weight: 700;
  transition: all 0.18s;
  white-space: nowrap;
}

.tb-income {
  background: var(--inc-dim);
  border: 1px solid rgba(34, 197, 94, 0.25);
  color: var(--inc);
}

.tb-income:hover {
  background: rgba(34, 197, 94, 0.2);
  box-shadow: 0 3px 12px rgba(34, 197, 94, 0.2);
}

.tb-expense {
  background: var(--exp-dim);
  border: 1px solid rgba(244, 63, 94, 0.25);
  color: var(--exp);
}

.tb-expense:hover {
  background: rgba(244, 63, 94, 0.2);
}

.tb-ghost {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
}

.tb-ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.tb-icon,
.tb-icon-sm {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  position: relative;
  top: 0;
  right: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(6px);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.84rem;
  transition: all 0.18s;
}

.tb-icon:hover,
.tb-icon-sm:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.topbar-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3b5bdb, #4f6ef7);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.82rem;
  color: white;
  border: 2px solid rgba(79, 110, 247, 0.35);
  box-shadow: 0 0 18px rgba(79, 110, 247, 0.22);
  flex-shrink: 0;
  font-family: "Syne", sans-serif;
}

/* ════════════════════════════════════════════════════════════
    SETTINGS DROPDOWN
    ════════════════════════════════════════════════════════════ */

.settings-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.settings-menu {
  display: none;
  position: fixed !important;
  top: calc(100% + 8px);
  right: 16px !important;
  left: auto !important;
  transform: translateX(-50%);
  background: var(--bg-card);
  border: 1px solid var(--border-md);
  border-radius: var(--r-lg);
  box-shadow:
    var(--shadow-xl),
    0 0 0 1px rgba(79, 110, 247, 0.05) inset;
  width: 240px !important;
  min-width: unset !important;
  max-width: 240px !important;
  max-height: calc(100vh - 80px) !important;
  overflow-y: auto !important;
  z-index: 9999 !important;
  padding: 0.3rem;
  overflow: hidden;
}

.settings-menu.open {
  display: block;
}

.settings-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0.7rem;
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--t1);
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.25rem;
}

.settings-close-btn {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.72rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s;
}

.settings-close-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--t1);
}

.settings-sync-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.42rem 0.7rem;
  font-size: 0.77rem;
  cursor: pointer;
  border-radius: 7px;
  transition: background 0.15s;
}

.settings-sync-row:hover {
  background: rgba(255, 255, 255, 0.04);
}

.sync-live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

.settings-menu-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.52rem 0.75rem;
  font-size: 0.8rem;
  color: var(--t2);
  cursor: pointer;
  border-radius: 9px;
  transition: all 0.15s;
}

.settings-menu-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--t1);
}

.settings-menu-item--danger {
  color: #fca5a5;
}

.settings-menu-item--danger:hover {
  background: rgba(239, 68, 68, 0.08);
  color: #ef4444;
}

.settings-menu-divider {
  height: 1px;
  background: var(--border);
  margin: 0.25rem 0.35rem;
}

.glass-slider-wrap {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.glass-slider-wrap input[type="range"] {
  flex: 1;
  accent-color: var(--accent);
}

/* ════════════════════════════════════════════════════════════
    DASHBOARD BODY
    ════════════════════════════════════════════════════════════ */

.db-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 1.4rem 1.5rem;
  scrollbar-width: thin;
  scrollbar-color: var(--t4) transparent;
  animation: fadeUp 0.28s ease;
}

.db-body::-webkit-scrollbar {
  width: 4px;
}

.db-body::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.2);
  border-radius: 4px;
}

/* .main-content dissolves */

.main-content {
  display: contents;
}

/* Title row */

.db-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
  gap: 0.75rem;
  flex-wrap: wrap;
}

.db-title {
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--t1);
  font-family: "Syne", sans-serif;
}

.db-pills {
  display: flex;
  gap: 6px;
}

.db-pill {
  padding: 0.34rem 0.9rem;
  border-radius: 50px;
  font-size: 0.74rem;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t2);
  cursor: pointer;
  transition: all 0.18s;
}

.db-pill:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.db-pill.active {
  background: var(--accent-dim);
  border-color: rgba(79, 110, 247, 0.28);
  color: var(--accent);
}

/* ════════════════════════════════════════════════════════════
    GRID
    ════════════════════════════════════════════════════════════ */

.db-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-lg);
  align-items: start;
}

.db-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  min-width: 0;
}

.db-right {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* ════════════════════════════════════════════════════════════
    STAT CARDS
    ════════════════════════════════════════════════════════════ */

.db-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

.db-stat-card {
  padding: 1.25rem 1.35rem 1.1rem;
  border-radius: var(--r-xl);
  background: var(--bg-card);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border-md);
  box-shadow:
    var(--shadow-md),
    0 1px 0 rgba(255, 255, 255, 0.04) inset;
  position: relative;
  overflow: hidden;
  transition:
    transform 0.22s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.22s;
  cursor: pointer;
  animation: fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.db-stat-card:hover {
  transform: translateY(-4px);
  box-shadow:
    var(--shadow-lg),
    0 0 0 1px rgba(79, 110, 247, 0.12);
}

.db-stat-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.03) 0%,
    transparent 55%
  );
  pointer-events: none;
}

.dsc-icon {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  margin-bottom: var(--space-sm);
}

.dsc-icon--income {
  background: var(--inc-dim);
  color: var(--inc);
}

.dsc-icon--expense {
  background: var(--exp-dim);
  color: var(--exp);
}

.dsc-icon--net {
  background: var(--accent-dim);
  color: var(--accent);
}

.dsc-label {
  font-size: 0.67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3);
  margin-bottom: 0.4rem;
}

/* Override .amount inside stat cards */

.db-stat-card .amount {
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1 !important;
  margin-bottom: 0.5rem !important;
  display: block !important;
  font-family: "Syne", sans-serif !important;
}

.db-stat-card .change {
  font-size: 0.7rem !important;
  color: var(--t3) !important;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.income-amount {
  color: var(--inc) !important;
}

.expense-amount {
  color: var(--exp) !important;
}

.net-positive {
  color: var(--t1) !important;
}

.net-negative {
  color: #ef4444 !important;
}

/* ════════════════════════════════════════════════════════════
    CHART CARD
    ════════════════════════════════════════════════════════════ */

.db-chart-card {
  padding: 1.35rem 1.4rem 1.15rem;
  border-radius: var(--r-xl);
  background: var(--bg-card);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border-md);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
  animation: fadeInUp 0.4s 0.22s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.db-chart-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(79, 110, 247, 0.03) 0%,
    transparent 50%
  );
  pointer-events: none;
}

.dcc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.dcc-title {
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--t1);
  font-family: "Syne", sans-serif;
  letter-spacing: -0.01em;
}

.dcc-legend {
  display: flex;
  gap: 0.85rem;
  font-size: 0.72rem;
  color: var(--t2);
}

.dcc-legend span {
  display: flex;
  align-items: center;
  gap: 0.32rem;
}

.leg-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
}

#chartContainer {
  min-height: 200px;
  position: relative;
}

/* Chart period controls (injected by charts.js) */

.chart-period-controls {
  display: flex;
  gap: 0.25rem;
}

.cpc-btn {
  padding: 0.24rem 0.65rem;
  border-radius: 50px;
  font-size: 0.69rem;
  font-weight: 700;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t3);
  cursor: pointer;
  transition: all 0.17s;
}

.cpc-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t2);
}

.cpc-btn--active {
  background: var(--accent-dim) !important;
  border-color: rgba(79, 110, 247, 0.3) !important;
  color: var(--accent) !important;
}

/* Chart labels (fallback) */

#chartLabels {
  display: none !important;
}

/* ════════════════════════════════════════════════════════════
    BOTTOM ROW
    ════════════════════════════════════════════════════════════ */

.db-bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

/* ════════════════════════════════════════════════════════════
    GENERIC PANEL
    ════════════════════════════════════════════════════════════ */

.db-panel {
  padding: 1.25rem 1.35rem;
  border-radius: var(--r-xl);
  background: var(--bg-card);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid var(--border-md);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}

.db-panel:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.db-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.02) 0%,
    transparent 60%
  );
  pointer-events: none;
}

.db-panel-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 20;
  margin-bottom: var(--space-md);
}

.db-panel-title {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--t1);
  font-family: "Syne", sans-serif;
  letter-spacing: -0.01em;
}

.db-panel-sub {
  font-size: 0.7rem;
  color: var(--t3);
  margin-bottom: 0.6rem;
}

.db-view-all {
  font-size: 0.73rem;
  font-weight: 600;
  color: var(--accent);
  opacity: 0.8;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.28rem;
  transition: opacity 0.15s;
  white-space: nowrap;
}

.db-view-all:hover {
  opacity: 1;
}

/* Expenses numbers */

.total-expenses {
  font-size: 1.65rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--t1);
  margin-bottom: 0.5rem;
}

.period-values-row {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 0.8rem;
}

.period-val-item {
  flex: 1;
}

.pv-label {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--t3);
  margin-bottom: 0.18rem;
}

.pv-value {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--t1);
}

.color-bar {
  display: none;
}

.set-budgets-btn {
  padding: 0.24rem 0.6rem;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.17s;
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.set-budgets-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

/* Category list */

.expense-categories {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-top: 0.65rem;
}

.expense-categories li {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-size: 0.78rem;
  padding: 0.5rem 0.7rem;
  border-radius: 10px;
  transition: background 0.15s;
}

/* ════════════════════════════════════════════════════════════
    MY CARD STACK (right panel)
    ════════════════════════════════════════════════════════════ */

.db-card-panel {
  padding-bottom: 1rem;
  overflow: visible !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border-md) !important;
  box-shadow:
    var(--shadow-lg),
    0 0 0 1px rgba(79, 110, 247, 0.08) inset,
    var(--glow-accent) !important;
  padding: 1.3rem 1.35rem 1.15rem !important;
  min-height: unset !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  animation: fadeInUp 0.4s 0.1s cubic-bezier(0.4, 0, 0.2, 1) both;
  position: relative !important;
}

.card-stack {
  position: relative;
  height: 170px;
  margin-top: 0.25rem;
}

.cs-back {
  position: absolute;
  border-radius: var(--r-lg);
  height: 148px;
}

.cs-back-2 {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 88%;
  background: linear-gradient(135deg, #131525 0%, #1a1c35 100%);
  border: 1px solid rgba(79, 110, 247, 0.12);
  z-index: 1;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.cs-back-1 {
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 94%;
  background: linear-gradient(135deg, #181a2e 0%, #1e2040 100%);
  border: 1px solid rgba(79, 110, 247, 0.18);
  z-index: 2;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

.cs-main {
  position: absolute;
  bottom: 18px;
  left: 0;
  right: 0;
  z-index: 3;
  border-radius: var(--r-lg);
  padding: 1.1rem 1.2rem 0.95rem;
  background: linear-gradient(135deg, #1a1c3e 0%, #252756 45%, #2d1f5e 100%);
  border: 1px solid rgba(79, 110, 247, 0.3);
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.5),
    0 0 60px rgba(79, 110, 247, 0.12),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
  overflow: hidden;
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}

.cs-main:hover {
  transform: translateY(-3px);
  box-shadow:
    0 18px 50px rgba(0, 0, 0, 0.55),
    0 0 80px rgba(79, 110, 247, 0.18);
}

.cs-main::before {
  content: "";
  position: absolute;
  top: -40px;
  right: -40px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(79, 110, 247, 0.18) 0%,
    transparent 65%
  );
  pointer-events: none;
}

.cs-main::after {
  content: "";
  position: absolute;
  bottom: -25px;
  left: 10px;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(79, 110, 247, 0.12) 0%,
    transparent 65%
  );
  pointer-events: none;
}

.csm-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.csm-nick {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.45);
}

.csm-chip {
  width: 26px;
  height: 19px;
  border-radius: 4px;
  background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

.card-number {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 0.6rem;
  font-family: "Courier New", monospace;
}

.card-holder-name {
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.8);
  text-transform: uppercase;
}

.my-card-dots {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  color: rgba(255, 255, 255, 0.45);
  font-size: 0.8rem;
  padding: 0.22rem;
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.15s;
}

.my-card-dots:hover {
  color: white;
}

.spending-section {
  margin-top: 0.5rem;
}

.csm-spend-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.28rem;
}

.spending-label {
  font-size: 0.61rem;
  color: rgba(255, 255, 255, 0.38);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.spending-limit-val {
  font-size: 0.77rem;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.85);
}

.spending-used-val {
  font-size: 0.62rem;
  color: rgba(255, 255, 255, 0.38);
  margin-bottom: 0.28rem;
}

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

.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-deep) 0%, var(--accent) 100%);
  border-radius: 4px;
  transition: width 0.5s ease;
  box-shadow: 0 0 8px rgba(79, 110, 247, 0.5);
}

/* ════════════════════════════════════════════════════════════
    RIGHT PANEL TXN LIST
    ════════════════════════════════════════════════════════════ */

.rp-txn-list {
  display: flex;
  flex-direction: column;
  gap: 0.08rem;
}

.rp-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 2rem 0;
  font-size: 0.78rem;
  color: var(--t3);
  justify-content: center;
}

.rp-empty i {
  font-size: 1.4rem;
  opacity: 0.4;
}

.rp-txn-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0.65rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  transition: background 0.15s;
  border-radius: 8px;
  padding-left: 4px;
  padding-right: 4px;
}

.rp-txn-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.78rem;
}

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

.rp-txn-desc {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rp-txn-cat {
  font-size: 0.68rem;
  color: var(--t3);
  margin-top: 1px;
}

.rp-txn-amt {
  font-size: 0.82rem;
  font-weight: 700;
  white-space: nowrap;
  font-family: "Syne", sans-serif;
  flex-shrink: 0;
}

/* Quick Actions */

.db-qa-panel {
  padding: 1rem 1.15rem;
  display: none !important;
}

.qa-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.55rem;
}

.qa-btn {
  padding: 0.58rem 0.5rem;
  border-radius: 11px;
  font-size: 0.78rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  transition: all 0.18s;
  cursor: pointer;
}

.qa-income {
  background: var(--inc-dim);
  border: 1px solid rgba(34, 197, 94, 0.25);
  color: var(--inc);
}

.qa-income:hover {
  background: rgba(34, 197, 94, 0.2);
  box-shadow: 0 4px 14px rgba(34, 197, 94, 0.18);
}

.qa-expense {
  background: var(--exp-dim);
  border: 1px solid rgba(244, 63, 94, 0.25);
  color: var(--exp);
}

.qa-expense:hover {
  background: rgba(244, 63, 94, 0.2);
}

.qa-ghost {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
}

.qa-ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

/* ════════════════════════════════════════════════════════════
    LEGACY .card (keep for insights, dashboardTxnCard, etc)
    ════════════════════════════════════════════════════════════ */

.card {
  padding: 1.15rem 1.25rem;
  border-radius: var(--r-lg);
  background: var(--glass);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.28);
  position: relative;
  overflow: hidden;
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.38);
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.02) 0%,
    transparent 55%
  );
  pointer-events: none;
}

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

.card-title {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--t1);
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.8rem;
}

.card-menu-btn {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.75rem;
  transition: all 0.17s;
}

.card-menu-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

/* ════════════════════════════════════════════════════════════
    TXN TABLE
    ════════════════════════════════════════════════════════════ */

.filters {
  display: flex;
  gap: 0.35rem;
}

.filter-btn {
  padding: 0.26rem 0.62rem;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.73rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.28rem;
  transition: all 0.17s;
}

.filter-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.txn-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0.85rem;
  padding: 0 1.5rem;
  margin-top: 10px;
}

.search-wrapper {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 0.36rem 0.7rem;
  width: 100%;
  transition: all 0.2s ease;
}

.search-wrapper i {
  color: var(--t3);
  font-size: 0.76rem;
}

.search-input {
  background: none;
  border: none;
  outline: none;
  color: var(--t1);
  font-size: 0.78rem;
  width: 100%;
}

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

.txn-count-badge {
  font-size: 0.69rem;
  font-weight: 700;
  color: var(--t3);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 0.18rem 0.52rem;
  white-space: nowrap;
}

.table-wrapper {
  overflow-x: auto;
}

.transaction-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.79rem;
}

.transaction-table thead th {
  padding: 0.42rem 0.68rem;
  text-align: left;
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--t3);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  background: transparent;
}

.transaction-table tbody tr {
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  transition: background 0.15s;
}

.transaction-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.03);
}

.transaction-table tbody td {
  padding: 0.5rem 0.68rem;
  color: var(--t2);
  vertical-align: middle;
}

.amount-income {
  color: var(--inc) !important;
  font-weight: 700;
}

.amount-expense {
  color: var(--exp) !important;
  font-weight: 700;
}

.txn-list-footer {
  margin-top: 0.7rem;
  text-align: center;
  font-size: 0.77rem;
  color: var(--t3);
}

.txn-mobile-list {
  display: none;
}

/* ════════════════════════════════════════════════════════════
    INSIGHTS
    ════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════
   PREMIUM INSIGHTS — BENTO GRID REDESIGN
   ════════════════════════════════════════════════════════════ */

.insights-card {
  padding: 1.35rem 1.4rem 1.4rem;
  background: var(--bg-card);
  border: 1px solid var(--border-md);
  box-shadow: var(--shadow-md);
}

/* Header */
.insights-card .card-header {
  margin-bottom: 1.1rem;
  padding-bottom: 0;
  border: none;
}

.insights-card .card-title {
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--t1);
}

/* AI Button */
.ai-insights-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.32rem 0.85rem;
  border-radius: 50px;
  background: rgba(139, 92, 246, 0.1);
  border: 1px solid rgba(139, 92, 246, 0.25);
  color: #c4b5fd;
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.01em;
  transition: all 0.2s ease;
  box-shadow: 0 0 12px rgba(139, 92, 246, 0.08);
}
.ai-insights-btn:hover {
  background: rgba(139, 92, 246, 0.2);
  border-color: rgba(139, 92, 246, 0.45);
  box-shadow: 0 0 20px rgba(139, 92, 246, 0.2);
  transform: translateY(-1px);
}

.insights-badge {
  font-size: 0.66rem;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 50px;
  padding: 0.18rem 0.6rem;
  color: var(--t3);
  letter-spacing: 0.02em;
}

/* ── AI Panel ── */
.ai-insights-panel {
  background: linear-gradient(
    135deg,
    rgba(139, 92, 246, 0.07) 0%,
    rgba(79, 110, 247, 0.04) 100%
  );
  border: 1px solid rgba(139, 92, 246, 0.15);
  border-radius: 14px;
  padding: 1rem 1.1rem;
  margin-bottom: 1rem;
  font-size: 0.8rem;
  color: var(--t2);
  line-height: 1.65;
}

/* Anomaly alerts */
#anomalyAlerts {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-bottom: 0.8rem;
}
#anomalyAlerts .anomaly-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  background: rgba(239, 68, 68, 0.06);
  border: 1px solid rgba(239, 68, 68, 0.15);
  border-radius: 10px;
  padding: 0.65rem 0.85rem;
  font-size: 0.77rem;
  color: #fca5a5;
  line-height: 1.5;
}
#anomalyAlerts .anomaly-alert i {
  color: #ef4444;
  margin-top: 0.1rem;
  flex-shrink: 0;
  font-size: 0.8rem;
}

/* ── Bento Grid ── */
.insights-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
  margin-bottom: 0.9rem;
}

/* First card spans full width as hero */
.insights-grid .insight-card:first-child {
  grid-column: 1 / -1;
  background: linear-gradient(
    135deg,
    rgba(244, 63, 94, 0.07) 0%,
    rgba(244, 63, 94, 0.03) 100%
  );
  border-color: rgba(244, 63, 94, 0.2);
  padding: 1rem 1.1rem;
}
.insights-grid .insight-card:first-child .insight-value {
  font-size: 1.1rem;
}

.insight-card {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: var(--bg-card-hi);
  border: 1px solid var(--border);
  border-radius: 13px;
  padding: 0.85rem 0.9rem;
  transition: all 0.22s ease;
  cursor: default;
}
.insight-card:hover {
  background: var(--bg-surface);
  border-color: var(--border-md);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.insight-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  flex-shrink: 0;
  margin-top: 0.05rem;
}

.insight-body {
  flex: 1;
  min-width: 0;
}

.insight-value {
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 0.22rem;
  letter-spacing: -0.02em;
}

.insight-label {
  font-size: 0.7rem;
  color: var(--t3);
  font-weight: 500;
  line-height: 1.4;
}

/* ── Prediction Bar (thin glow style) ── */
.prediction-bar {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 13px;
  padding: 0.9rem 1rem;
  margin-top: 0;
  margin-bottom: 0.9rem;
}

.prediction-label-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.65rem;
}

.prediction-title {
  font-size: 0.72rem;
  color: var(--t3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.prediction-amount {
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.prediction-track {
  height: 3px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 99px;
  overflow: hidden;
  display: flex;
  margin-bottom: 0.5rem;
}

.prediction-actual {
  height: 100%;
  background: linear-gradient(90deg, #22c55e, #22c55e);
  border-radius: 99px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 8px rgba(34, 197, 94, 0.5);
}

.prediction-projected {
  height: 100%;
  background: linear-gradient(
    90deg,
    rgba(244, 63, 94, 0.6),
    rgba(244, 63, 94, 0.3)
  );
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.prediction-sublabel {
  font-size: 0.68rem;
  color: var(--t3);
  line-height: 1.5;
}

/* ── Day of Week ── */
.insights-section-title {
  font-size: 0.64rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3);
  margin-bottom: 0.7rem;
}

.dow-section {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 13px;
  padding: 0.9rem 1rem 0.75rem;
}

.dow-bars {
  display: flex;
  align-items: flex-end;
  gap: 0;
  height: 52px;
}

.dow-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}

.dow-bar-wrap {
  width: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 40px;
}

.dow-bar {
  width: 70%;
  border-radius: 3px 3px 0 0;
  min-height: 3px;
  transition: height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.dow-label {
  font-size: 0.58rem;
  font-weight: 600;
  color: var(--t3);
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  text-align: center;
}

/* ── AI Insights result (panel content) ── */
.ai-insights-result {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.ai-insights-summary {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.82rem;
  color: var(--t2);
  line-height: 1.6;
}

.ai-prediction-row {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 11px;
  padding: 0.7rem 0.85rem;
}

.ai-prediction-label {
  font-size: 0.7rem;
  color: var(--t3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.ai-prediction-amount {
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 0.3rem;
}

.ai-prediction-reason {
  font-size: 0.73rem;
  color: var(--t3);
  line-height: 1.5;
}

.ai-alerts-section {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.ai-alert-item {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  background: rgba(245, 158, 11, 0.05);
  border: 1px solid rgba(245, 158, 11, 0.15);
  border-radius: 10px;
  padding: 0.6rem 0.8rem;
}

.ai-alert-title {
  font-size: 0.77rem;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 0.15rem;
}

.ai-alert-body {
  font-size: 0.72rem;
  color: var(--t3);
  line-height: 1.5;
}

.ai-tips-grid {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.ai-tip-card {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 11px;
  padding: 0.7rem 0.85rem;
  transition: background 0.18s;
}
.ai-tip-card:hover {
  background: rgba(255, 255, 255, 0.04);
}

.ai-tip-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  flex-shrink: 0;
}

.ai-tip-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 0.15rem;
}

.ai-tip-body {
  font-size: 0.72rem;
  color: var(--t3);
  line-height: 1.5;
}

.ai-insights-footer {
  display: flex;
  gap: 0.5rem;
  padding-top: 0.2rem;
}

.ai-refresh-btn,
.ai-dismiss-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.9rem;
  border-radius: 8px;
  font-size: 0.73rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.18s;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t2);
}
.ai-refresh-btn:hover {
  background: rgba(139, 92, 246, 0.12);
  border-color: rgba(139, 92, 246, 0.3);
  color: #c4b5fd;
}
.ai-dismiss-btn:hover {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.25);
  color: #fca5a5;
}

.ai-insights-error {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.78rem;
  color: var(--t3);
  padding: 0.5rem 0;
}

.ai-insights-loading {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.3rem 0;
}

/* Mobile responsive */
@media (max-width: 640px) {
  .insights-grid {
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
  }
  .insights-grid .insight-card:first-child {
    grid-column: 1 / -1;
  }
  .insight-card {
    padding: 0.75rem 0.8rem;
  }
  .insight-value {
    font-size: 0.82rem;
  }
  .dow-label {
    font-size: 0.52rem;
  }
}

/* ════════════════════════════════════════════════════════════
    HIDE ORIGINAL HEADER & CARD-SWITCHER-BAR
    ════════════════════════════════════════════════════════════ */

.header,
.card-switcher-bar {
  display: none !important;
}

/* ════════════════════════════════════════════════════════════
    MODALS
    ════════════════════════════════════════════════════════════ */

.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 2000;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  overflow-y: auto;
}

.modal[style*="flex"],
.modal[style*="block"] {
  display: flex !important;
}

.modal-content {
  background: var(--bg-card);
  border: 1px solid var(--border-md);
  border-radius: var(--r-xl);
  box-shadow:
    var(--shadow-xl),
    0 0 0 1px rgba(79, 110, 247, 0.06) inset;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
}

.modal-content::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(79, 110, 247, 0.025) 0%,
    transparent 40%
  );
  pointer-events: none;
  border-radius: inherit;
}

.modal-content--sm {
  max-width: 400px;
}

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

.modal-content--xl {
  max-width: 680px;
}

.modal-header {
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.modal-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--t1);
  font-family: "Syne", sans-serif;
  letter-spacing: -0.02em;
}

.close-btn {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.85rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.17s;
}

.close-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--t1);
}

.modal-body {
  padding: 1.2rem 1.45rem;
}

.modal-footer {
  padding: 0 1.45rem 1.3rem;
  display: flex;
  justify-content: flex-end;
  gap: 0.55rem;
  flex-wrap: wrap;
}

/* ── Form elements ─────────────────────────────────────────── */

.form-group {
  margin-bottom: 0.95rem;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}

.form-label {
  display: block;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--t3);
  margin-bottom: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.form-input,
.form-select {
  width: 100%;
  padding: 0.65rem 0.9rem;
  background: var(--bg-card-hi);
  border: 1px solid var(--border-md);
  border-radius: 12px;
  color: var(--t1);
  font-size: 0.83rem;
  transition: all 0.18s;
  outline: none;
  font-family: "DM Sans", sans-serif;
}

.form-input:focus,
.form-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  background: var(--bg-card);
  outline: none;
}

.form-input::placeholder {
  color: var(--t3);
}

textarea.form-input {
  resize: vertical;
  min-height: 58px;
}

select.form-input option,
.form-select option {
  background: var(--bg-card);
  color: var(--t1);
}

.form-hint {
  font-size: 0.71rem;
  color: var(--t3);
  margin-top: 0.32rem;
  line-height: 1.5;
}

.recurring-toggle {
  display: flex;
  align-items: center;
  gap: 0.48rem;
  font-size: 0.81rem;
  color: var(--t2);
  margin-bottom: 0.7rem;
}

.recurring-toggle input {
  accent-color: var(--accent);
}

/* ── Buttons ───────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  padding: 0.58rem 1.15rem;
  border-radius: 9px;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid transparent;
}

.btn-primary {
  background: linear-gradient(135deg, #3b5bdb 0%, #4f6ef7 100%);
  color: white;
  box-shadow: 0 4px 14px rgba(79, 110, 247, 0.32);
  border: 1px solid rgba(147, 180, 255, 0.2);
  font-family: "DM Sans", sans-serif;
  font-weight: 700;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(79, 110, 247, 0.42);
  background: linear-gradient(135deg, #6080f8 0%, #6080f8 100%);
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--border);
  color: var(--t2);
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  transition: all 0.18s;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.btn-danger {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.28);
  color: #fca5a5;
}

.btn-danger:hover {
  background: rgba(239, 68, 68, 0.22);
}

/* ════════════════════════════════════════════════════════════
    AUTH & LOCK
    ════════════════════════════════════════════════════════════ */

.lock-screen {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.lock-screen,
.auth-screen {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(
      ellipse 70% 55% at 10% 10%,
      rgba(79, 110, 247, 0.14) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 60% 50% at 90% 15%,
      rgba(139, 92, 246, 0.12) 0%,
      transparent 50%
    ),
    linear-gradient(160deg, #0e1117 0%, #13161c 100%);
  z-index: 5000;
  padding: 1rem;
}

.lock-card,
.auth-card {
  background: rgba(13, 14, 28, 0.9);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(79, 110, 247, 0.18);
  border-radius: var(--r-xl);
  padding: 2.5rem 1.9rem 2.1rem;
  width: 100%;
  max-width: 380px;
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.6),
    0 0 60px rgba(79, 110, 247, 0.1);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.lock-card::before,
.auth-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(79, 110, 247, 0.04) 0%,
    transparent 50%
  );
  pointer-events: none;
}

.auth-brand {
  font-size: 1.45rem;
  font-weight: 900;
  text-align: center;
  margin-bottom: 0.25rem;
}

.auth-brand span {
  color: var(--accent);
}

.auth-tagline,
.lock-subtitle {
  text-align: center;
  font-size: 0.81rem;
  color: var(--t3);
  margin-bottom: 1.4rem;
  width: 100%;
}

.lock-header {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 0;
  text-align: center;
}

.lock-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 0.5rem;
}

.lock-logo img {
  width: 260px;
  height: auto;
  object-fit: contain;
  object-position: center;
  padding: 0;
}

.lock-error,
.auth-error {
  font-size: 0.77rem;
  color: #fca5a5;
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.22);
  border-radius: 8px;
  padding: 0.48rem 0.72rem;
  margin-bottom: 0.72rem;
}

.lock-error:empty,
.auth-error:empty {
  display: none;
}

.lock-attempts {
  font-size: 0.72rem;
  color: var(--t3);
  text-align: center;
  margin-top: 0.45rem;
}

/* PIN */

.pin-dots {
  display: flex;
  justify-content: center;
  gap: 0.72rem;
  margin-bottom: 1.4rem;
}

.pin-dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  border: 2px solid rgba(79, 110, 247, 0.2);
  transition: background 0.18s;
}

.pin-dot.filled {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(79, 110, 247, 0.5);
}

.pin-pad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
}

.pin-key {
  aspect-ratio: 1;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t1);
  font-size: 1.25rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s;
}

.pin-key:hover {
  background: rgba(79, 110, 247, 0.12);
  border-color: rgba(79, 110, 247, 0.25);
}

.pin-key:active {
  transform: scale(0.95);
}

.pin-key--empty {
  background: transparent;
  border-color: transparent;
  pointer-events: none;
}

.pin-key--del {
  color: var(--t3);
}

/* Auth buttons */

.auth-popup-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(6px);
  z-index: 6000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.auth-popup-overlay[style*="flex"] {
  display: flex !important;
}

.auth-popup-overlay.open {
  display: flex;
}

.auth-popup {
  background: #161b22;
  border: 1px solid rgba(79, 110, 247, 0.18);
  border-radius: var(--r-xl);
  padding: 1.65rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.65);
  position: relative;
}

.auth-popup::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(79, 110, 247, 0.025) 0%,
    transparent 40%
  );
  pointer-events: none;
  border-radius: inherit;
}

.auth-popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.2rem;
}

.auth-popup-title {
  font-size: 0.97rem;
  font-weight: 800;
  color: var(--t1);
}

.auth-popup-close {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.17s;
}

.auth-popup-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--t1);
}

.auth-action-btns {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-top: 1.2rem;
}

.auth-action-btn {
  width: 100%;
  padding: 0.82rem;
  border-radius: 11px;
  font-size: 0.88rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.48rem;
  cursor: pointer;
  transition: all 0.2s;
}

.auth-btn-login {
  background: linear-gradient(
    135deg,
    var(--accent-deep) 0%,
    var(--accent) 100%
  );
  color: white;
  border: none;
  box-shadow: 0 4px 16px rgba(79, 110, 247, 0.3);
}

.auth-btn-login:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(79, 110, 247, 0.4);
}

.auth-btn-signup {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t1);
}

.auth-btn-signup:hover {
  background: rgba(255, 255, 255, 0.09);
}

.auth-or-divider {
  text-align: center;
  font-size: 0.74rem;
  color: var(--t3);
  margin: 0.55rem 0;
}

.auth-submit {
  width: 100%;
  justify-content: center;
  font-size: 0.88rem;
  padding: 0.72rem;
  border-radius: 11px;
}

.biometric-btn {
  width: 100%;
  padding: 0.68rem;
  border-radius: 11px;
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.25);
  color: #93c5fd;
  font-size: 0.83rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.48rem;
  margin-bottom: 0.72rem;
  cursor: pointer;
  transition: all 0.2s;
}

.biometric-btn:hover {
  background: rgba(59, 130, 246, 0.18);
}

/* ════════════════════════════════════════════════════════════
    BOTTOM NAV (mobile)
    ════════════════════════════════════════════════════════════ */

.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 62px;
  background: var(--bg2);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 0 0.5rem;
  padding-bottom: env(safe-area-inset-bottom, 0);
  z-index: 200;
}

.bn-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.16rem;
  font-size: 0.58rem;
  font-weight: 600;
  color: var(--t3);
  padding: 0.38rem 0.8rem;
  border-radius: 11px;
  transition: all 0.17s;
  cursor: pointer;
  border: none;
  background: none;
}

.bn-tab i {
  font-size: 1.05rem;
}

.bn-tab.bn-tab--active {
  color: var(--accent);
}

.bn-tab.bn-tab--active i {
  filter: drop-shadow(0 0 5px rgba(79, 110, 247, 0.55));
}

.bn-add-ring {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: linear-gradient(
    135deg,
    var(--accent-deep) 0%,
    var(--accent) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  color: white;
  box-shadow: 0 4px 14px rgba(79, 110, 247, 0.4);
  margin-bottom: -3px;
}

/* ════════════════════════════════════════════════════════════
    BOTTOM SHEETS
    ════════════════════════════════════════════════════════════ */

.bn-sheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 300;
  display: none;
  backdrop-filter: blur(4px);
}

.bn-sheet-overlay.open {
  display: block;
}

.bn-sheet {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #161b22;
  border: 1px solid rgba(79, 110, 247, 0.12);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  z-index: 400;
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.34, 1.4, 0.64, 1);
  padding: 0 1.2rem 1.4rem;
  max-height: 80vh;
  overflow-y: auto;
}

.bn-sheet.open {
  transform: translateY(0);
}

.bn-sheet--auto {
  padding-bottom: max(1.4rem, env(safe-area-inset-bottom, 1.4rem));
}

.bn-sheet-handle {
  width: 34px;
  height: 4px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  margin: 0.7rem auto 0.9rem;
}

.bn-sheet-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.72rem;
}

.bn-sheet-title {
  font-size: 0.93rem;
  font-weight: 800;
  color: var(--t1);
}

.bn-sheet-cancel {
  font-size: 0.81rem;
  font-weight: 600;
  color: var(--accent);
  cursor: pointer;
}

.bn-sheet-account {
  font-size: 0.77rem;
  color: var(--t3);
  margin-bottom: 0.9rem;
}

.bn-ring-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}

.bn-ring-card {
  padding: 1.2rem 0.95rem;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}

.bn-ring-card:hover {
  background: rgba(255, 255, 255, 0.08);
  transform: translateY(-2px);
}

.bn-ring-income {
  border-color: rgba(34, 197, 94, 0.22);
}

.bn-ring-expense {
  border-color: rgba(244, 63, 94, 0.22);
}

.bn-ring-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0.55rem;
  font-size: 1.05rem;
}

.bn-ring-income .bn-ring-icon {
  background: var(--inc-dim);
  color: var(--inc);
}

.bn-ring-expense .bn-ring-icon {
  background: var(--exp-dim);
  color: var(--exp);
}

.bn-ring-label {
  font-size: 0.83rem;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 0.18rem;
}

.bn-ring-sub {
  font-size: 0.71rem;
  color: var(--t3);
}

.bn-sheet-btn {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  width: 100%;
  padding: 0.82rem;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
  cursor: pointer;
  transition: all 0.17s;
  margin-bottom: 0.48rem;
  text-align: left;
}

.bn-sheet-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.bn-sheet-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.bn-sheet-label {
  font-size: 0.83rem;
  font-weight: 700;
  color: var(--t1);
}

.bn-sheet-sub {
  font-size: 0.7rem;
  color: var(--t3);
  margin-top: 0.08rem;
}

.bn-account-list {
  display: flex;
  flex-direction: column;
  gap: 0.48rem;
}

.bn-settings-panel {
  position: fixed;
  bottom: 16px;
  left: 80px;
  width: 280px;
  background: #161b22;
  border: 1px solid rgba(79, 110, 247, 0.18);
  border-radius: 14px;
  z-index: 2000;
  padding: 0.6rem 0.9rem 0.9rem;
  max-height: 80vh;
  overflow-y: auto;
  transform: translateX(-8px) scale(0.97);
  opacity: 0;
  pointer-events: none;
  transition:
    transform 0.2s cubic-bezier(0.34, 1.4, 0.64, 1),
    opacity 0.18s ease;
  box-shadow:
    0 8px 40px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(79, 110, 247, 0.08);
}

.bn-settings-panel.open {
  transform: translateX(0) scale(1);
  opacity: 1;
  pointer-events: auto;
}

.bn-settings-panel .bn-sheet-handle {
  display: none;
}

.bn-settings-panel .bn-sheet-title {
  font-size: 0.82rem;
  margin-bottom: 0.3rem;
}

.bn-settings-panel > div:first-of-type {
  margin-bottom: 0.4rem !important;
}

.bn-settings-section {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3);
  padding: 0.4rem 0 0.15rem;
}

.bn-settings-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.3rem;
  font-size: 0.78rem;
  color: var(--t2);
  cursor: pointer;
  border-radius: 7px;
  transition:
    background 0.12s,
    color 0.12s;
}

.bn-settings-row:hover {
  color: var(--t1);
  background: rgba(255, 255, 255, 0.05);
}

.bn-settings-danger {
  color: #fca5a5;
}

.bn-settings-danger:hover {
  color: #ef4444;
}

/* ════════════════════════════════════════════════════════════
    FULL TXN PAGE
    ════════════════════════════════════════════════════════════ */

#txnFullPage {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 2500;
  overflow: hidden;
  display: none;
  flex-direction: column;
}

#txnFullPage[style*="flex"],
#txnFullPage.open,
#txnFullPage.txn-page-open {
  display: flex;
}

.txn-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.95rem 1.45rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  backdrop-filter: blur(12px);
  flex-shrink: 0;
}

.txn-page-title {
  font-size: 0.97rem;
  font-weight: 800;
  color: var(--t1);
}

.txn-page-close {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.88rem;
  transition: all 0.17s;
}

.txn-page-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--t1);
}

.txn-page-body {
  flex: 1;
  overflow-y: auto;
  padding: 1.2rem 1.45rem;
  scrollbar-width: thin;
  scrollbar-color: var(--t4) transparent;
}

/* ════════════════════════════════════════════════════════════
    FULL TXN PAGE — ROW STYLES
    ════════════════════════════════════════════════════════════ */

.txn-month-group {
  margin-bottom: 1.5rem;
}

.txn-month-label {
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--t3);
  padding: 0.5rem 0 0.6rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 0.25rem;
}

.txn-full-row {
  display: grid;
  grid-template-columns: 52px 1fr auto auto;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 0.75rem;
  border-radius: 10px;
  transition: background 0.14s;
  cursor: default;
}

.txn-full-row:hover {
  background: rgba(255, 255, 255, 0.04);
}

.txn-full-date {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--t3);
  white-space: nowrap;
}

.txn-full-desc {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.txn-full-cat {
  font-size: 0.68rem;
  color: var(--t3);
  margin-top: 0.1rem;
}

.txn-full-account {
  font-size: 0.68rem;
  color: var(--t3);
  white-space: nowrap;
  text-align: right;
}

.txn-full-amt {
  font-size: 0.85rem;
  font-weight: 700;
  white-space: nowrap;
  min-width: 72px;
  text-align: right;
}

.txn-full-amt.pos {
  color: #22c55e;
}

.txn-full-amt.neg {
  color: #f43f5e;
}

/* Animate in */

#txnFullPage.txn-page-open .txn-month-group {
  animation: txnFadeUp 0.22s ease both;
}

#txnFullPage.txn-page-open .txn-month-group:nth-child(2) {
  animation-delay: 0.04s;
}

#txnFullPage.txn-page-open .txn-month-group:nth-child(3) {
  animation-delay: 0.08s;
}

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

/* ════════════════════════════════════════════════════════════
    ASK BLUELEDGER
    ════════════════════════════════════════════════════════════ */

.ask-bl-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  z-index: 1800;
  display: none;
}

.ask-bl-overlay.open {
  display: block;
}

.ask-bl-panel {
  position: fixed;
  bottom: 0;
  right: 0;
  width: 375px;
  height: 68vh;
  max-height: 580px;
  background: rgba(9, 10, 22, 0.97);
  border: 1px solid rgba(79, 110, 247, 0.18);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  z-index: 1900;
  display: none;
  flex-direction: column;
  box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.5);
  overflow: hidden;
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.34, 1.4, 0.64, 1);
  border-left: 1px solid rgba(79, 110, 247, 0.14);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
}

.ask-bl-panel.open {
  display: flex;
  transform: translateY(0);
}

.ask-bl-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
  background: rgba(11, 12, 26, 0.8);
}

.ask-bl-title {
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--t1);
  font-family: "Syne", sans-serif;
  letter-spacing: -0.01em;
}

.ask-bl-close {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.78rem;
}

.ask-bl-messages {
  flex: 1;
  overflow-y: auto;
  padding: 0.95rem;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  scrollbar-width: thin;
  scrollbar-color: var(--t4) transparent;
}

.ask-bl-welcome {
  text-align: center;
  padding: 0.9rem 0.45rem;
}

.ask-bl-welcome-icon {
  font-size: 1.9rem;
  margin-bottom: 0.45rem;
  color: var(--accent);
}

.ask-bl-welcome-text {
  font-size: 0.83rem;
  color: var(--t2);
  margin-bottom: 0.7rem;
}

.ask-bl-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.32rem;
  justify-content: center;
}

.ask-bl-chip {
  padding: 0.28rem 0.68rem;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}

.ask-bl-chip:hover {
  background: rgba(79, 110, 247, 0.1);
  color: var(--accent);
  border-color: rgba(79, 110, 247, 0.25);
}

.ask-bl-input-row {
  display: flex;
  gap: 0.6rem;
  padding: 0.85rem 1.1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
  background: rgba(9, 10, 22, 0.9);
}

.ask-bl-input {
  flex: 1;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 0.62rem 0.9rem;
  color: var(--t1);
  font-size: 0.84rem;
  outline: none;
  font-family: "DM Sans", sans-serif;
  transition: all 0.2s;
}

.ask-bl-input:focus {
  border-color: rgba(79, 110, 247, 0.3);
  outline: none;
  background: rgba(79, 110, 247, 0.05);
  box-shadow: 0 0 0 3px rgba(79, 110, 247, 0.08);
}

.ask-bl-input::placeholder {
  color: var(--t3);
}

.ask-bl-send {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  background: linear-gradient(135deg, #3b5bdb, #4f6ef7);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
  border: none;
}

.ask-bl-send:hover {
  transform: scale(1.08);
  box-shadow: 0 4px 14px rgba(79, 110, 247, 0.4);
}

.ask-bl-fab {
  position: fixed;
  bottom: 1.45rem;
  right: 1.45rem;
  display: none !important;
  align-items: center;
  gap: 0.42rem;
  padding: 0.62rem 1.05rem;
  border-radius: 50px;
  background: linear-gradient(135deg, #7c3aed 0%, var(--accent) 100%);
  color: white;
  font-size: 0.8rem;
  font-weight: 700;
  box-shadow: 0 4px 22px rgba(79, 110, 247, 0.42);
  z-index: 1700;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid rgba(147, 180, 255, 0.3);
}

.ask-bl-fab:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 30px rgba(79, 110, 247, 0.52);
}

.ask-bl-fab-label {
  display: none;
}

@media (min-width: 640px) {
  .ask-bl-fab-label {
    display: inline;
  }
}

/* ════════════════════════════════════════════════════════════
    AI + VOICE
    ════════════════════════════════════════════════════════════ */

.ai-cat-badge {
  margin-top: 0.48rem;
  padding: 0.38rem 0.72rem;
  border-radius: 50px;
  background: rgba(139, 92, 246, 0.1);
  border: 1px solid rgba(139, 92, 246, 0.24);
  font-size: 0.74rem;
  color: #c4b5fd;
  font-weight: 600;
}

.voice-status {
  font-size: 0.74rem;
  color: var(--t3);
  margin-top: 0.32rem;
}

.btn-voice-lg {
  padding: 0.58rem 0.72rem;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
  cursor: pointer;
  transition: all 0.17s;
}

.btn-voice-lg:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

/* ════════════════════════════════════════════════════════════
    CONTEXT MENUS
    ════════════════════════════════════════════════════════════ */

#contextMenu,
#cardOptionsMenu {
  position: fixed;
  background: #161b22;
  border: 1px solid rgba(79, 110, 247, 0.15);
  border-radius: 11px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.55);
  z-index: 3000;
  min-width: 145px;
  padding: 0.28rem;
}

.ctx-item {
  display: flex;
  align-items: center;
  gap: 0.48rem;
  padding: 0.48rem 0.72rem;
  font-size: 0.79rem;
  color: var(--t2);
  cursor: pointer;
  border-radius: 7px;
  transition: background 0.14s;
}

.ctx-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--t1);
}

.ctx-item.danger {
  color: #fca5a5;
}

.ctx-item.danger:hover {
  background: rgba(239, 68, 68, 0.08);
}

/* ════════════════════════════════════════════════════════════
    MONTH PICKER & SUMMARY
    ════════════════════════════════════════════════════════════ */

.mp-nav-btn {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t2);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.17s;
}

.mp-nav-btn:hover {
  background: rgba(255, 255, 255, 0.09);
  color: var(--t1);
}

.mp-year {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--t1);
}

.mp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.48rem;
}

.mp-cell {
  cursor: pointer;
}

.mp-month-btn {
  padding: 0.52rem 0.22rem;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
  font-size: 0.79rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.17s;
  text-align: center;
}

.mp-month-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}

.mp-month-btn.mp-selected {
  background: var(--accent-dim);
  border-color: rgba(79, 110, 247, 0.3);
  color: var(--accent);
}

.mp-month-btn.mp-current {
  border-color: rgba(79, 110, 247, 0.35);
}

.summary-month-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.95rem;
}

.summary-month-btn {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border);
  color: var(--t2);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.17s;
}

.summary-month-btn:hover {
  background: rgba(255, 255, 255, 0.09);
}

.summary-month-title {
  font-size: 0.93rem;
  font-weight: 700;
  color: var(--t1);
}

.summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
  margin-bottom: 0.7rem;
}

.summary-stat {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 0.72rem;
}

.summary-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--t3);
  margin-bottom: 0.28rem;
}

.summary-value {
  font-size: 1.02rem;
  font-weight: 800;
  color: var(--t1);
}

.summary-value.positive {
  color: var(--inc);
}

.summary-value.negative {
  color: var(--exp);
}

/* Sort/Filter */

.sf-content {
  padding: 0.48rem 1.45rem 0.72rem;
}

.sf-section-title {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--t3);
  margin: 0.72rem 0 0.38rem;
}

.sf-option {
  display: flex;
  align-items: center;
  gap: 0.48rem;
  padding: 0.32rem 0;
  font-size: 0.82rem;
  color: var(--t2);
  cursor: pointer;
}

.sf-option input {
  accent-color: var(--accent);
}

/* Sync */

.sync-status-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 0.82rem;
}

.sync-status-top {
  display: flex;
  align-items: center;
  gap: 0.58rem;
  margin-bottom: 0.38rem;
}

.sync-status-badge {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--t3);
}

.sync-status-meta {
  font-size: 0.7rem;
  color: var(--t4);
  margin-left: auto;
}

.sync-status-text {
  font-size: 0.79rem;
  color: var(--t2);
}

.sync-footer {
  justify-content: space-between;
}

.import-dropzone {
  border: 2px dashed rgba(79, 110, 247, 0.2);
  border-radius: var(--r-md);
  padding: 1.9rem;
  text-align: center;
  cursor: pointer;
  transition:
    border-color 0.2s,
    background 0.2s;
}

.import-dropzone:hover {
  border-color: rgba(79, 110, 247, 0.4);
  background: rgba(79, 110, 247, 0.04);
}

/* Budget list */

#budgetList .budget-row {
  display: flex;
  align-items: center;
  gap: 0.72rem;
  padding: 0.58rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

#budgetList .budget-cat {
  flex: 1;
  font-size: 0.81rem;
  color: var(--t2);
  font-weight: 500;
}

#budgetList .budget-input {
  width: 100px;
}

#customCatList .custom-cat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.42rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  font-size: 0.81rem;
  color: var(--t2);
}

.builtin-cat-badge {
  padding: 0.24rem 0.58px;
  border-radius: 50px;
  font-size: 0.7rem;
  font-weight: 700;
  color: white;
}

/* ════════════════════════════════════════════════════════════
    TOAST
    ════════════════════════════════════════════════════════════ */

#toastContainer {
  position: fixed;
  top: 0.95rem;
  right: 0.95rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: 0.58rem;
  padding: 0.68rem 0.95rem;
  border-radius: 9px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  font-size: 0.8rem;
  color: var(--t2);
  min-width: 230px;
  animation: toastIn 0.22s ease;
  pointer-events: auto;
}

.toast.success {
  border-color: rgba(34, 197, 94, 0.35);
  color: var(--inc);
}

.toast.error {
  border-color: rgba(239, 68, 68, 0.35);
  color: #fca5a5;
}

.toast.warn {
  border-color: rgba(245, 158, 11, 0.35);
  color: #fcd34d;
}

@keyframes toastIn {
  from {
    opacity: 0;
    transform: translateX(16px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

/* ════════════════════════════════════════════════════════════
    MISC LEGACY + COMPAT
    ════════════════════════════════════════════════════════════ */

.desktop-only {
  display: inline-flex;
}

.hidden {
  display: none !important;
}

.hdr-income-btn {
  background: var(--inc-dim);
  border: 1px solid rgba(34, 197, 94, 0.24);
  color: var(--inc);
  border-radius: 8px;
  font-weight: 700;
}

.hdr-expense-btn {
  background: var(--exp-dim);
  border: 1px solid rgba(244, 63, 94, 0.24);
  color: var(--exp);
  border-radius: 8px;
  font-weight: 700;
}

.hdr-cat-btn {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
  border-radius: 8px;
}

.header-brand {
  font-size: 1.05rem;
  font-weight: 900;
}

.header-brand-accent {
  color: var(--accent);
}

/* Scrollbars */

* {
  scrollbar-width: thin;
  scrollbar-color: var(--t4) transparent;
}

*::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

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

*::-webkit-scrollbar-thumb {
  background: var(--t4);
  border-radius: 4px;
}

/* Animations */

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

/* ════════════════════════════════════════════════════════════
    LIGHT THEME
    ════════════════════════════════════════════════════════════ */

[data-theme="light"] body {
  background-color: #f8fafc !important;
  color: #0f172a !important;
}

[data-theme="light"] body::before {
  background:
    radial-gradient(
      ellipse 60% 50% at 0% 0%,
      rgba(79, 70, 229, 0.06) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 50% 40% at 100% 0%,
      rgba(99, 102, 241, 0.05) 0%,
      transparent 55%
    ),
    linear-gradient(180deg, #f7f9fb 0%, #eceef0 100%);
}
[data-theme="light"] .db-panel,
[data-theme="light"] .db-stat-card,
[data-theme="light"] .db-chart-card,
[data-theme="light"] .card,
[data-theme="light"] #dashboardTxnCard {
  background: #ffffff;
  border: 1px solid rgba(119, 117, 135, 0.12);
  box-shadow:
    0 4px 20px rgba(25, 28, 30, 0.06),
    0 2px 4px rgba(25, 28, 30, 0.03);
}

[data-theme="light"] .cs-back-2 {
  background: linear-gradient(135deg, #e0e4f8, #dde4f4);
}

[data-theme="light"] .cs-back-1 {
  background: linear-gradient(135deg, #d4daf5, #d8e0f2);
}

[data-theme="light"] .cs-main {
  background: linear-gradient(135deg, #3730a3, #4338ca, #4f6ef7);
}

[data-theme="light"] .modal-content,
[data-theme="light"] .auth-popup,
[data-theme="light"] .lock-card,
[data-theme="light"] .auth-card {
  background: #ffffff;
  border: 1px solid rgba(119, 117, 135, 0.16);
  box-shadow: 0 20px 60px rgba(25, 28, 30, 0.14);
}

[data-theme="light"] .settings-menu,
[data-theme="light"] #contextMenu,
[data-theme="light"] #cardOptionsMenu {
  background: #ffffff;
  border: 1px solid rgba(119, 117, 135, 0.16);
  box-shadow: 0 8px 24px rgba(25, 28, 30, 0.12);
}

[data-theme="light"] .bn-sheet,
[data-theme="light"] .bn-settings-panel,
[data-theme="light"] .ask-bl-panel {
  background: #ffffff;
  border-top: 1px solid rgba(119, 117, 135, 0.14);
  box-shadow: 0 -8px 32px rgba(25, 28, 30, 0.1);
}

[data-theme="light"] .topbar-search {
  background: #f2f4f6;
  border-color: rgba(119, 117, 135, 0.2);
  color: #191c1e;
}

[data-theme="light"] #txnFullPage {
  background: #f1f5f9;
}

[data-theme="light"] .transaction-table tbody tr:hover {
  background: rgba(79, 110, 247, 0.04);
}

[data-theme="light"] .toast {
  background: #f1f5f9;
}

[data-theme="light"] .sidebar {
  background: rgba(255, 255, 255, 0.95) !important;
  border-right-color: rgba(119, 117, 135, 0.14) !important;
  box-shadow: 2px 0 16px rgba(25, 28, 30, 0.06) !important;
}

[data-theme="light"] .topbar {
  background: rgba(255, 255, 255, 0.88) !important;
  border-bottom-color: rgba(119, 117, 135, 0.12) !important;
  box-shadow: 0 1px 8px rgba(25, 28, 30, 0.06) !important;
}

[data-theme="light"] .sb-btn {
  color: #777587 !important;
}

[data-theme="light"] .sb-btn:hover {
  background: rgba(79, 70, 229, 0.07) !important;
  color: #4f46e5 !important;
}

[data-theme="light"] .sb-btn.active,
[data-theme="light"] .sb-btn.bn-tab--active {
  background: rgba(79, 70, 229, 0.1) !important;
  color: #4f46e5 !important;
}

[data-theme="light"] .sidebar-bottom {
  border-top-color: rgba(119, 117, 135, 0.12) !important;
}

[data-theme="light"] body::before {
  background:
    radial-gradient(
      ellipse 60% 50% at 0% 0%,
      rgba(79, 70, 229, 0.06) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 50% 40% at 100% 0%,
      rgba(99, 102, 241, 0.05) 0%,
      transparent 55%
    ),
    linear-gradient(180deg, #f7f9fb 0%, #eceef0 100%) !important;
}

[data-theme="light"] .bottom-nav {
  background: rgba(255, 255, 255, 0.95);
  border-top-color: rgba(119, 117, 135, 0.14);
  box-shadow: 0 -4px 16px rgba(25, 28, 30, 0.08);
}

[data-theme="light"] .bn-tab {
  color: #a09eb8;
}
[data-theme="light"] .bn-tab.bn-tab--active {
  color: #4f46e5;
}

[data-theme="light"] .income-amount {
  color: #059669 !important;
}
[data-theme="light"] .expense-amount {
  color: #ba1a1a !important;
}

/* ════════════════════════════════════════════════════════════
    MISSING COMPAT — biometric setup, card-switcher, receipt, etc.
    ════════════════════════════════════════════════════════════ */

.biometric-setup-content {
  max-width: 340px;
}

.biometric-setup-footer {
  justify-content: space-between;
}

.biometric-setup-btn {
  flex: 1;
  justify-content: center;
}

/* Card switcher in topbar */

.card-switcher {
  display: none !important;
  align-items: center;
  gap: 0.38rem;
}

.card-switcher-btn {
  padding: 0.22rem 0.62rem;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t3);
  font-size: 0.71rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.17s;
  white-space: nowrap;
}

.card-switcher-btn.active,
.card-switcher-btn:hover {
  background: var(--accent-dim);
  border-color: rgba(79, 110, 247, 0.28);
  color: var(--accent);
}

/* AI chat messages */

.ask-bl-msg {
  max-width: 88%;
  padding: 0.55rem 0.82rem;
  border-radius: 12px;
  font-size: 0.81rem;
  line-height: 1.6;
}

.ask-bl-msg--user {
  align-self: flex-end;
  background: var(--accent-dim);
  border: 1px solid rgba(79, 110, 247, 0.2);
  color: var(--t1);
}

.ask-bl-msg--ai {
  align-self: flex-start;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--t2);
}

.ask-bl-typing {
  display: flex;
  gap: 0.28rem;
  align-items: center;
  padding: 0.48rem 0.72rem;
}

.ask-bl-typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.5;
  animation: blTyping 0.9s ease-in-out infinite;
}

.ask-bl-typing span:nth-child(2) {
  animation-delay: 0.18s;
}

.ask-bl-typing span:nth-child(3) {
  animation-delay: 0.36s;
}

@keyframes blTyping {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.4;
  }
  50% {
    transform: translateY(-5px);
    opacity: 1;
  }
}

/* QR code modal */

#qrCodeModal .modal-content {
  max-width: 340px;
  text-align: center;
}

#qrCodeCanvas {
  border-radius: 10px;
}

/* Frequency select */

.frequency-select {
  margin-top: -0.25rem;
}

/* Auth divider */

.auth-divider {
  text-align: center;
  font-size: 0.73rem;
  color: var(--t3);
  margin: 0.5rem 0;
  position: relative;
}

.auth-divider::before,
.auth-divider::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 38%;
  height: 1px;
  background: var(--border);
}

.auth-divider::before {
  left: 0;
}

.auth-divider::after {
  right: 0;
}

/* Txn mobile cards */

.txn-mobile-card {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 0.22rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.txn-mobile-card:last-child {
  border-bottom: none;
}

.txn-mobile-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.76rem;
}

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

.txn-mobile-desc {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.txn-mobile-cat {
  font-size: 0.7rem;
  color: var(--t3);
  margin-top: 0.06rem;
}

.txn-mobile-meta {
  text-align: right;
  flex-shrink: 0;
}

.txn-mobile-amt {
  font-size: 0.82rem;
  font-weight: 700;
}

.txn-mobile-date {
  font-size: 0.67rem;
  color: var(--t3);
  margin-top: 0.08rem;
}

/* Action badge on type column */

.txn-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.16rem 0.48rem;
  border-radius: 50px;
  font-size: 0.67rem;
  font-weight: 700;
}

.txn-type-income {
  background: rgba(34, 197, 94, 0.1);
  color: var(--inc);
}

.txn-type-expense {
  background: rgba(244, 63, 94, 0.1);
  color: var(--exp);
}

/* Chart empty state */

.chart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 2.8rem 1rem;
  color: var(--t3);
  text-align: center;
}

.chart-empty i {
  font-size: 2.2rem;
  opacity: 0.3;
}

.chart-empty p {
  font-size: 0.82rem;
}

/* Progress fill danger state */

.progress-fill--danger {
  background: linear-gradient(90deg, #ef4444 0%, #fca5a5 100%);
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.45);
}

/* Sync status colors */

.sync-dot-live {
  background: var(--inc);
  box-shadow: 0 0 6px rgba(34, 197, 94, 0.6);
}

.sync-dot-pending {
  background: #f59e0b;
}

.sync-dot-offline {
  background: var(--t3);
}

/* Category list items (expense breakdown) */

.cat-row {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.38rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.025);
}

.cat-row:last-child {
  border-bottom: none;
}

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

.cat-name {
  flex: 1;
  font-size: 0.78rem;
  color: var(--t2);
}

.cat-pct {
  font-size: 0.7rem;
  color: var(--t3);
  margin-right: 0.38rem;
}

.cat-amt {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--t1);
}

.cat-budget-bar {
  height: 3px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 0.22rem;
}

.cat-budget-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease;
}

/* DOW bars — see premium insights block above */

/* Insight items — see premium insights block above */

.insight-item .insight-label {
  font-size: 0.67rem;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.2rem;
  font-weight: 700;
}

.insight-item .insight-value {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--t1);
}

.insight-item .insight-sub {
  font-size: 0.69rem;
  color: var(--t3);
  margin-top: 0.1rem;
}

/* Recurring badge */

.recurring-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.22rem;
  font-size: 0.65rem;
  padding: 0.1rem 0.42rem;
  border-radius: 50px;
  background: rgba(79, 110, 247, 0.1);
  color: var(--accent);
  border: 1px solid rgba(79, 110, 247, 0.2);
  font-weight: 600;
}

/* QR export */

#qrWrap {
  display: flex;
  justify-content: center;
  padding: 1.2rem;
  background: white;
  border-radius: 12px;
  margin: 1rem auto;
  width: fit-content;
}

/* Loading spinner inside buttons */

.btn-loading {
  opacity: 0.7;
  pointer-events: none;
}

.btn-loading::after {
  content: "";
  width: 13px;
  height: 13px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: white;
  animation: spin 0.65s linear infinite;
  display: inline-block;
  margin-left: 0.42rem;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* ═══ PREMIUM GLOW EFFECTS ═══════════════════════════════════ */

/* Glowing accent on hover for panels */

.db-stat-card:hover::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 0 1px rgba(79, 110, 247, 0.18) inset;
  pointer-events: none;
}

/* Chart card subtle shimmer */

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

/* Topbar gradient underline */

.topbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 68px;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(79, 110, 247, 0.15) 40%,
    rgba(79, 110, 247, 0.08) 80%,
    transparent 100%
  );
  pointer-events: none;
}

/* Sidebar active indicator glow */

.sb-btn.active {
  box-shadow:
    0 0 16px rgba(79, 110, 247, 0.2),
    0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Card stack depth shadow enhancement */

/* Input glow on focus — premium feel */

/* ═══ MIGRATION MODAL ═══════════════════════════════════════ */

#migrationModal .modal-content {
  max-width: 440px;
}

/* ═══ CUSTOM SCROLLBAR for db-body — refined ════════════════ */

.db-body::-webkit-scrollbar-track {
  background: transparent;
}

.db-body::-webkit-scrollbar-thumb:hover {
  background: rgba(79, 110, 247, 0.38);
}

/* ═══ LIGHT THEME ADDITIONS ══════════════════════════════════ */

[data-theme="light"] .rp-txn-row {
  border-bottom-color: rgba(79, 110, 247, 0.06);
}

[data-theme="light"] .cat-row {
  border-bottom-color: rgba(79, 110, 247, 0.06);
}

[data-theme="light"] .txn-count-badge {
  background: rgba(79, 110, 247, 0.06);
}

[data-theme="light"] .ask-bl-msg--user {
  border-color: rgba(79, 110, 247, 0.2);
}

[data-theme="light"] .biometric-btn {
  background: rgba(59, 130, 246, 0.08);
}

/* ══════════════════════════════════════════════════════════════════
    PREMIUM CARD STACK v2
    Append this block to style.css
    ══════════════════════════════════════════════════════════════════ */

/* ── Container ─────────────────────────────────────────────────── */

.card-stack-v2 {
  position: relative !important;
  height: auto !important;
  z-index: 5;
  cursor: default !important;
  overflow: visible !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  margin-top: 8px !important;
  flex-shrink: 0 !important;
  min-height: unset !important;
  perspective: 1000px !important;
  perspective-origin: 50% 50% !important;
}

/* ── Each card item ─────────────────────────────────────────────── */

.card-item {
  position: absolute;
  left: 0;
  right: 0;
  border-radius: 20px !important;
  padding: 1.4rem 1.5rem 1.3rem !important;
  overflow: hidden;
  will-change: transform, box-shadow, opacity;
  border: 1px solid rgba(79, 110, 247, 0.22);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 0.4s cubic-bezier(0.34, 1.28, 0.64, 1),
    box-shadow 0.38s ease,
    opacity 0.3s ease,
    filter 0.3s ease,
    border-color 0.3s ease !important;
}

/* ── Shine overlay (pseudo, non-interactive) ────────────────────── */

.card-item::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.13) 0%,
    rgba(255, 255, 255, 0) 50%,
    rgba(255, 255, 255, 0.06) 100%
  );
  pointer-events: none;
  transition: opacity 0.3s ease;
  opacity: 0;
}

.card-item.is-top::before {
  opacity: 1;
}

.card-item.is-hovered::before {
  opacity: 1;
}

/* ── Glow ring (pseudo) ─────────────────────────────────────────── */

.card-item::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 20px;
  background: transparent;
  box-shadow: 0 0 0 0 transparent;
  pointer-events: none;
  transition: box-shadow 0.38s ease;
}

.card-item.is-hovered::after {
  box-shadow: none !important;
  animation: none !important;
}

.card-item.is-active::after {
  box-shadow: 0 0 0 1.5px var(--card-accent, rgba(79, 110, 247, 0.35));
}

/* ── Per-card gradient themes (driven by CARD_ACCENT_COLORS) ─────── */

/* card-theme-0  emerald */

.card-item[data-theme="0"] {
  background: linear-gradient(135deg, #0d2b20 0%, #133828 45%, #1a4a30 100%);
  --card-accent: rgba(34, 197, 94, 0.7);
  --card-accent-glow: rgba(34, 197, 94, 0.2);
  border-color: rgba(34, 197, 94, 0.2);
}

/* card-theme-1  blue */

.card-item[data-theme="1"] {
  background: linear-gradient(135deg, #0d1a35 0%, #152240 45%, #1a2d52 100%);
  --card-accent: rgba(59, 130, 246, 0.7);
  --card-accent-glow: rgba(59, 130, 246, 0.2);
  border-color: rgba(59, 130, 246, 0.2);
}

/* card-theme-2  amber */

.card-item[data-theme="2"] {
  background: linear-gradient(135deg, #2b1d08 0%, #3a2510 45%, #4a2e12 100%);
  --card-accent: rgba(245, 158, 11, 0.7);
  --card-accent-glow: rgba(245, 158, 11, 0.2);
  border-color: rgba(245, 158, 11, 0.2);
}

/* card-theme-3  pink */

.card-item[data-theme="3"] {
  background: linear-gradient(135deg, #2b0d20 0%, #3a1228 45%, #4a163a 100%);
  --card-accent: rgba(236, 72, 153, 0.7);
  --card-accent-glow: rgba(236, 72, 153, 0.2);
  border-color: rgba(236, 72, 153, 0.2);
}

/* ── Stacking positions (bottom → top, 4 cards max) ─────────────── */

/*  z-index driven by JS .style.zIndex; transforms below are BASE    */

/* Position class set by JS depending on rank from top              */

/* rank-0 = top card, rank-1 = one below, etc.                      */

.card-item.rank-0 {
  bottom: 28px !important;
  transform: translateY(0px) scale(1) rotateX(0deg);
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.55),
    0 0 70px rgba(79, 110, 247, 0.1),
    0 1px 0 rgba(255, 255, 255, 0.08) inset;
  opacity: 1;
}

.card-item.rank-1 {
  bottom: 16px !important;
  transform: translateY(0px) scale(0.95) rotateX(1.5deg);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.4);
  opacity: 0.82;
  filter: brightness(0.82);
}

.card-item.rank-2 {
  bottom: 6px !important;
  transform: translateY(0px) scale(0.905) rotateX(3deg);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
  opacity: 0.62;
  filter: brightness(0.62);
}

.card-item.rank-3 {
  bottom: 0px !important;
  transform: translateY(0px) scale(0.865) rotateX(4.5deg);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  opacity: 0.44;
  filter: brightness(0.44);
}

/* ── Hover override: the hovered card ───────────────────────────── */

.card-item.is-hovered {
  transform: translateY(-14px) scale(1.04) rotateX(-1deg) !important;
  opacity: 1 !important;
  filter: brightness(1.08) !important;
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.6),
    0 0 90px var(--card-accent-glow, rgba(79, 110, 247, 0.25)),
    0 1px 0 rgba(255, 255, 255, 0.12) inset !important;
}

/* ── Sibling fade-back when any card is hovered ─────────────────── */

.card-stack-v2.hovering .card-item:not(.is-hovered) {
  opacity: calc(var(--base-opacity, 0.82) * 0.65);
  filter: brightness(0.6);
}

/* ── Inner card contents ────────────────────────────────────────── */

.ci-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.9rem !important;
}

.ci-nick {
  font-size: 0.72rem !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em !important;
  color: rgba(255, 255, 255, 0.42);
  transition: color 0.3s ease;
}

.card-item.is-hovered .ci-nick,
.card-item.is-top .ci-nick {
  color: rgba(255, 255, 255, 0.75);
}

.ci-chip {
  width: 26px;
  height: 19px;
  border-radius: 4px;
  background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
  transition: box-shadow 0.3s ease;
}

.card-item.is-hovered .ci-chip {
  box-shadow: 0 3px 12px rgba(245, 158, 11, 0.5);
}

.ci-number {
  font-size: 0.88rem !important;
  font-weight: 400;
  letter-spacing: 0.2em !important;
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: 0.8rem !important;
  font-family: "DM Sans", sans-serif;
  transition: color 0.3s ease;
  opacity: 0.75;
  margin: 0.55rem 0;
}

.card-item.is-hovered .ci-number,
.card-item.is-top .ci-number {
  color: rgba(255, 255, 255, 0.92);
}

.ci-holder {
  font-size: 0.78rem !important;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.65);
  text-transform: uppercase;
  transition: color 0.3s ease;
  margin-bottom: 0.2rem !important;
}

.card-item.is-hovered .ci-holder,
.card-item.is-top .ci-holder {
  color: rgba(255, 255, 255, 0.88);
}

.ci-bank {
  font-size: 0.64rem !important;
  color: rgba(255, 255, 255, 0.35);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 0.15rem;
  transition: color 0.3s ease;
  font-family: "Syne", sans-serif;
  font-weight: 800;
  margin-bottom: 0.75rem !important;
}

.card-item.is-hovered .ci-bank {
  color: rgba(255, 255, 255, 0.55);
}

.ci-spending {
  margin-top: 0.85rem !important;
  padding-top: 0.7rem !important;
  border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.ci-spend-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.68rem !important;
  color: rgba(255, 255, 255, 0.45);
  margin-bottom: 0.3rem !important;
}

.ci-spend-limit {
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
}

.ci-spend-used {
  font-size: 0.62rem;
  color: rgba(255, 255, 255, 0.38);
  margin-top: 0.22rem !important;
  margin-bottom: 0.4rem !important;
}

.ci-progress {
  height: 3px !important;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 99px;
  margin-top: 0.4rem !important;
  overflow: hidden;
}

.ci-progress-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(
    90deg,
    var(--card-accent, rgba(79, 110, 247, 0.8)),
    rgba(255, 255, 255, 0.35)
  );
  transition: width 0.6s ease;
}

/* ci-active-badge removed */

/* ── Click ripple animation ─────────────────────────────────────── */

@keyframes ci-ripple {
  0% {
    transform: scale(0);
    opacity: 0.35;
  }
  80% {
    transform: scale(2.5);
    opacity: 0.1;
  }
  100% {
    transform: scale(3);
    opacity: 0;
  }
}

.ci-ripple {
  position: absolute;
  border-radius: 50%;
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.18);
  pointer-events: none;
  animation: ci-ripple 0.55s ease-out forwards;
  transform-origin: center;
  margin-top: -40px;
  margin-left: -40px;
}

/* ── Dot indicators ─────────────────────────────────────────────── */

.card-stack-dots {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  flex-shrink: 0 !important;
  min-height: 14px !important;
  max-width: 340px !important;
  margin: 8px auto 0 !important;
}

.cs-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.18) !important;
  transition:
    background 0.25s ease,
    width 0.25s ease !important;
  cursor: pointer !important;
  border: none !important;
  padding: 0 !important;
}

.cs-dot.is-active {
  background: rgba(255, 255, 255, 0.72) !important;
  width: 18px !important;
  border-radius: 4px !important;
  transform: scaleY(1);
}

/* ── Placeholder shimmer ────────────────────────────────────────── */

.csv2-placeholder {
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.csv2-shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.05) 50%,
    transparent 100%
  );
  animation: shimmer 1.8s ease-in-out infinite;
}

@keyframes shimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(200%);
  }
}

/* ── Empty state (no cards added yet) ──────────────────────────── */

.csv2-empty-state {
  position: relative !important;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  border-radius: 18px;
  border: 1.5px dashed rgba(79, 110, 247, 0.25);
  background: rgba(79, 110, 247, 0.04);
  cursor: pointer;
  transition:
    border-color 0.25s ease,
    background 0.25s ease;
  height: 190px !important;
}

.csv2-empty-state:hover {
  border-color: rgba(79, 110, 247, 0.5);
  background: rgba(79, 110, 247, 0.08);
}

.csv2-empty-icon {
  font-size: 1.6rem;
  color: rgba(79, 110, 247, 0.4);
  margin-bottom: 0.2rem;
  transition:
    color 0.25s ease,
    transform 0.25s ease;
}

.csv2-empty-state:hover .csv2-empty-icon {
  color: rgba(79, 110, 247, 0.75);
  transform: translateY(-3px);
}

.csv2-empty-title {
  font-size: 0.8rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.55);
}

.csv2-empty-sub {
  font-size: 0.7rem;
  color: rgba(255, 255, 255, 0.28);
}

.csv2-empty-btn {
  margin-top: 0.6rem;
  padding: 0.4rem 1.1rem;
  border-radius: 50px;
  background: rgba(79, 110, 247, 0.15);
  border: 1px solid rgba(79, 110, 247, 0.3);
  color: rgba(79, 110, 247, 0.9);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  transition:
    background 0.2s ease,
    border-color 0.2s ease;
}

.csv2-empty-state:hover .csv2-empty-btn {
  background: rgba(79, 110, 247, 0.28);
  border-color: rgba(79, 110, 247, 0.55);
}

/* ── Hide the topbar card switcher — stack in "My Card" replaces it ─ */

/* The #cardSwitcher pill tabs in the topbar are not needed anymore.   */

/* The legacy .card-switcher-bar (already display:none in HTML) stays. */

#cardSwitcher .card-tab,
#cardSwitcher .card-ring-row {
  display: none !important;
}

/* Keep the element itself but make it zero-width so it doesn't push layout */

#cardSwitcher {
  width: 0;
  overflow: hidden;
  gap: 0;
  padding: 0;
  display: none !important;
}

/* ── Light theme overrides ──────────────────────────────────────── */

[data-theme="light"] .card-item[data-theme="0"] {
  background: linear-gradient(135deg, #065f46 0%, #047857 45%, #16a34a 100%);
}

[data-theme="light"] .card-item[data-theme="1"] {
  background: linear-gradient(135deg, #1e3a5f 0%, #1d4ed8 45%, #2563eb 100%);
}

[data-theme="light"] .card-item[data-theme="2"] {
  background: linear-gradient(135deg, #78350f 0%, #b45309 45%, #d97706 100%);
}

[data-theme="light"] .card-item[data-theme="3"] {
  background: linear-gradient(135deg, #831843 0%, #be185d 45%, #db2777 100%);
}

/* ── Mobile adjustments ─────────────────────────────────────────── */

@media (max-width: 640px) {
  .card-stack-v2 {
    height: 176px;
  }
  .card-item.rank-0 {
    bottom: 18px;
  }
  .card-item.rank-1 {
    bottom: 9px;
  }
  .card-item.rank-2 {
    bottom: 2px;
  }
  .card-item.is-hovered {
    transform: translateY(-10px) scale(1.03) rotateX(-1deg) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
    CARD STACK — Horizontal Fan Interaction (Option 2)
    Append these rules to style.css (after existing card-stack rules)
    ═══════════════════════════════════════════════════════════════════ */

/* ── Container grows taller when fan is open ─────────────────────── */

/* Make space for the fan to breathe vertically */

.card-stack-v2.fan-open {
  height: auto !important;
}

/* ── Base transition is already in .card-item —
    Add rotateZ to the transition list ────────────────────────────── */

/* ── Extra inner layout elements (expiry column) ─────────────────── */

.ci-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: 0.75rem !important;
}

.ci-expiry-col {
  text-align: right;
  flex-shrink: 0;
}

.ci-exp-label {
  font-size: 0.58rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.28);
  margin-bottom: 2px;
}

.ci-exp-val {
  font-family: "Courier New", monospace;
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 600;
}

/* ── Fan-open: non-hovered siblings dim ─────────────────────────── */

.card-stack-v2.fan-open .card-item:not(.is-hovered) {
  opacity: 0.55;
  filter: brightness(0.8) grayscale(0.12);
  transition:
    opacity 0.24s ease,
    filter 0.24s ease;
}

/* ── Hovered card in fan: additional glow ring pulse ─────────────── */

@keyframes fan-glow-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}

/* ── Dot indicator hover state ────────────────────────────────────── */

.cs-dot.is-hovered {
  background: rgba(255, 255, 255, 0.42);
  transform: scale(1.2);
}

/* ── ci-progress danger state ─────────────────────────────────────── */

.ci-progress-fill.ci-progress-danger {
  background: linear-gradient(90deg, #ef4444, #fca5a5);
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.45);
}

/* ── Card nickname visibility during fan ─────────────────────────── */

.card-stack-v2.fan-open .card-item .ci-nick {
  color: rgba(255, 255, 255, 0.65);
}

.card-stack-v2.fan-open .card-item.is-hovered .ci-nick {
  color: rgba(255, 255, 255, 0.9);
}

/* ── Card number: show last 4 only for non-top fanned cards ─────── */

.card-stack-v2.fan-open .card-item:not(.is-top):not(.is-hovered) .ci-number {
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  opacity: 0.7;
}

/* ── Subtle label on fanned cards ───────────────────────────────── */

.ci-fan-hint {
  position: absolute;
  bottom: 0.6rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.32);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}

.card-stack-v2.fan-open .card-item.is-hovered .ci-fan-hint {
  opacity: 1;
}

/* ── Panel height: give the fan room on smaller screens ─────────── */

/* ── Light theme adjustments ─────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════
    CARD ACTION BUTTONS (Add / Remove below card stack)
    ═══════════════════════════════════════════════════════════════════ */

.card-action-row {
  display: flex !important;
  gap: 10px !important;
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
  flex-shrink: 0 !important;
}

.card-action-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.58rem 0;
  border-radius: 12px;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.card-action-btn i {
  font-size: 0.7rem;
}

.card-action-btn:active {
  transform: scale(0.97);
}

/* Add button — indigo tinted */

.card-action-add {
  background: rgba(79, 110, 247, 0.08);
  border-color: rgba(79, 110, 247, 0.22);
  color: #4f6ef7;
  border: 1px solid rgba(79, 110, 247, 0.2);
}

.card-action-add:hover {
  background: rgba(79, 110, 247, 0.15);
  border-color: rgba(79, 110, 247, 0.35);
  box-shadow: 0 0 20px rgba(79, 110, 247, 0.18);
  color: #93b4ff;
  transform: translateY(-1px);
}

/* Remove button — red tinted */

.card-action-remove {
  background: rgba(239, 68, 68, 0.06);
  border-color: rgba(239, 68, 68, 0.18);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.15);
}

.card-action-remove:hover {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.28);
  box-shadow: 0 0 20px rgba(239, 68, 68, 0.12);
  color: #fca5a5;
  transform: translateY(-1px);
}

/* Light theme */

[data-theme="light"] .card-action-add {
  background: rgba(79, 110, 247, 0.07);
  color: #3b5bdb;
}

[data-theme="light"] .card-action-add:hover {
  background: rgba(79, 110, 247, 0.14);
}

[data-theme="light"] .card-action-remove {
  background: rgba(239, 68, 68, 0.06);
  color: #dc2626;
}

[data-theme="light"] .card-action-remove:hover {
  background: rgba(239, 68, 68, 0.12);
}

/* ═══════════════════════════════════════════════════════════════════
    SET AS PRIMARY TOGGLE — inside card setup modal
    ═══════════════════════════════════════════════════════════════════ */

.cs-primary-row {
  margin-top: 0.25rem;
}

.cs-primary-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  cursor: pointer;
  transition:
    background 0.18s,
    border-color 0.18s;
}

.cs-primary-label:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(79, 110, 247, 0.2);
}

.cs-primary-text {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}

.cs-primary-title {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--t1, #e2e8f0);
}

.cs-primary-sub {
  font-size: 0.7rem;
  color: var(--t3, #64748b);
  line-height: 1.4;
}

/* Hidden native checkbox */

.cs-toggle-input {
  display: none;
}

/* Toggle track */

.cs-toggle-wrap {
  flex-shrink: 0;
}

.cs-toggle-track {
  display: block;
  width: 40px;
  height: 22px;
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.12);
  position: relative;
  cursor: pointer;
  transition:
    background 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease;
  flex-shrink: 0;
}

.cs-toggle-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  transition:
    transform 0.22s cubic-bezier(0.34, 1.3, 0.64, 1),
    background 0.22s ease;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

/* Checked state */

.cs-toggle-input:checked ~ .cs-toggle-track,
.cs-toggle-input:checked + .cs-toggle-track {
  background: rgba(79, 110, 247, 0.7);
  border-color: rgba(79, 110, 247, 0.5);
  box-shadow: 0 0 12px rgba(79, 110, 247, 0.3);
}

.cs-toggle-input:checked ~ .cs-toggle-track .cs-toggle-thumb,
.cs-toggle-input:checked + .cs-toggle-track .cs-toggle-thumb {
  transform: translateX(18px);
  background: #fff;
}

/* Light theme modal toggle */

[data-theme="light"] .cs-primary-label {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .cs-primary-title {
  color: #1e293b;
}

[data-theme="light"] .cs-toggle-track {
  background: rgba(0, 0, 0, 0.1);
  border-color: rgba(0, 0, 0, 0.12);
}

[data-theme="light"] .cs-toggle-thumb {
  background: rgba(0, 0, 0, 0.35);
}

/* ═══════════════════════════════════════════════════════════════════
    SIDEBAR — Income / Expense accent buttons
    ═══════════════════════════════════════════════════════════════════ */

.sb-income {
  color: #22c55e !important;
}

.sb-income:hover,
.sb-income:focus {
  background: rgba(34, 197, 94, 0.12) !important;
  color: #6ee7b7 !important;
  box-shadow: 0 0 14px rgba(34, 197, 94, 0.18);
}

.sb-expense {
  color: #f43f5e !important;
}

.sb-expense:hover,
.sb-expense:focus {
  background: rgba(244, 63, 94, 0.12) !important;
  color: #fdba74 !important;
  box-shadow: 0 0 14px rgba(244, 63, 94, 0.18);
}

/* AI button accent */

.sb-ai {
  color: #4f6ef7 !important;
}

.sb-ai:hover,
.sb-ai:focus {
  background: rgba(79, 110, 247, 0.15) !important;
  color: #93b4ff !important;
  box-shadow: 0 0 14px rgba(79, 110, 247, 0.2);
}

/* ═══════════════════════════════════════════════════════════════════
    TOPBAR SEARCH — live input (remove readonly proxy)
    ═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════
    RECENT TRANSACTIONS SLIDE PANEL
    ═══════════════════════════════════════════════════════════════════ */

/* Overlay */

.rtp-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  z-index: 1100;
  pointer-events: none;
  transition: background 0.28s ease;
}

.rtp-overlay.rtp-overlay--open {
  background: rgba(0, 0, 0, 0.48);
  pointer-events: auto;
}

/* Panel */

.rtp-panel {
  position: fixed;
  top: 0;
  left: 64px;
  max-width: calc(100vw - 64px);
  height: 100vh;
  background: var(--glass-bg, rgba(12, 14, 28, 0.96));
  border-right: 1px solid rgba(79, 110, 247, 0.12);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 1101;
  display: flex;
  flex-direction: column;
  transform: translateX(-110%);
  transition: transform 0.34s cubic-bezier(0.34, 1.08, 0.64, 1);
  box-shadow: 8px 0 40px rgba(0, 0, 0, 0.45);
}

.rtp-panel.rtp-panel--open {
  transform: translateX(0);
}

/* Header */

.rtp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.25rem 0.9rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
}

.rtp-title {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--t1, #e2e8f0);
  letter-spacing: -0.01em;
}

.rtp-close {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--t3, #64748b);
  cursor: pointer;
  font-size: 0.72rem;
  transition: all 0.15s;
}

.rtp-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--t1, #e2e8f0);
}

/* Search */

.rtp-search {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  max-width: 420px;
  margin: 0 auto;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  flex-shrink: 0;
}

.rtp-search i {
  font-size: 0.75rem;
  color: var(--t3, #64748b);
  flex-shrink: 0;
}

.rtp-search input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: 0.82rem;
  color: var(--t1, #e2e8f0);
}

.rtp-search input::placeholder {
  color: var(--t3, #475569);
}

/* Body / list */

.rtp-body {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem 0;
}

.rtp-body::-webkit-scrollbar {
  width: 3px;
}

.rtp-body::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.2);
  border-radius: 3px;
}

/* Transaction rows */

.rtp-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  transition: background 0.14s;
}

.rtp-row:last-child {
  border-bottom: none;
}

.rtp-row:hover {
  background: rgba(255, 255, 255, 0.025);
}

.rtp-icon {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  flex-shrink: 0;
}

.rtp-icon--inc {
  background: rgba(34, 197, 94, 0.12);
  color: #22c55e;
}

.rtp-icon--exp {
  background: rgba(244, 63, 94, 0.12);
  color: #f43f5e;
}

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

.rtp-desc {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--t1, #e2e8f0);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rtp-cat {
  font-size: 0.68rem;
  color: var(--t3, #64748b);
  margin-top: 0.12rem;
}

.rtp-amt {
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
}

.rtp-amt--inc {
  color: #22c55e;
}

.rtp-amt--exp {
  color: #f43f5e;
}

/* Empty state */

.rtp-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 3rem 1rem;
  color: var(--t3, #475569);
  text-align: center;
}

.rtp-empty i {
  font-size: 2rem;
  opacity: 0.25;
}

.rtp-empty span {
  font-size: 0.8rem;
}

/* Footer */

.rtp-footer {
  padding: 0.85rem 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
}

.rtp-view-all {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.65rem 0;
  border-radius: 12px;
  background: rgba(79, 110, 247, 0.1);
  border: 1px solid rgba(79, 110, 247, 0.2);
  color: #4f6ef7;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.18s;
  letter-spacing: 0.02em;
}

.rtp-view-all:hover {
  background: rgba(79, 110, 247, 0.18);
  border-color: rgba(79, 110, 247, 0.38);
  color: #93b4ff;
}

/* Light theme */

[data-theme="light"] .rtp-panel {
  background: rgba(248, 249, 252, 0.97);
  border-right-color: rgba(79, 110, 247, 0.1);
}

[data-theme="light"] .rtp-row:hover {
  background: rgba(79, 110, 247, 0.04);
}

/* Mobile: panel takes full width */

@media (max-width: 640px) {
  .rtp-panel {
    left: 0;
    width: 100vw;
    max-width: 100vw;
  }
}

/* ═══════════════════════════════════════════════════════════════════
    QUICK ACTIONS — hide if not removed from HTML (belt+braces)
    ═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    BlueLedger — Premium Fintech UI Overrides
    Complete redesign: hierarchy · spacing · visual quality
    ═══════════════════════════════════════════════════════════════ */

/* ─── Design Tokens (premium refinement) ──────────────────────── */

/* Font override */

/* ═══════════════════════════════════════════════════════════════
    AMBIENT BACKGROUND — richer depth
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    SIDEBAR — intentional navigation system
    ═══════════════════════════════════════════════════════════════ */

/* Nav grouping via padding */

/* Sidebar button — polished states */

/* Group separators in sidebar */

.sb-btn.sb-income {
  margin-top: 8px;
  color: rgba(34, 197, 94, 0.5);
}

.sb-btn.sb-income:hover {
  color: var(--inc);
  background: var(--inc-dim);
}

.sb-btn.sb-expense {
  color: rgba(244, 63, 94, 0.5);
}

.sb-btn.sb-expense:hover {
  color: var(--exp);
  background: var(--exp-dim);
}

/* Sidebar bottom — anchored AI + Settings */

.sb-btn.sb-ai {
  color: rgba(167, 139, 250, 0.55);
}

.sb-btn.sb-ai:hover {
  color: #c4b5fd;
  background: rgba(139, 92, 246, 0.1);
  box-shadow: 0 0 20px rgba(139, 92, 246, 0.15);
}

/* Hide floating FAB — AI is in sidebar */

/* ═══════════════════════════════════════════════════════════════
    TOPBAR — single clean horizontal bar
    ═══════════════════════════════════════════════════════════════ */

/* Hide date next to title — cleaner */

#headerDate {
  display: none;
}

/* Hide card switcher in topbar */

/* CENTER: search bar — dominant, pill-shaped */

/* RIGHT: avatar only — settings already in sidebar */

/* Settings icon button — subtle */

.settings-dropdown .tb-icon {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  width: 34px;
  height: 34px;
}

/* ═══════════════════════════════════════════════════════════════
    DB BODY + SCROLLABLE AREA
    ══════════════════════════════════════
    flex: 1;

  /* ── Dashboard title row ──────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════
    GRID LAYOUT
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    STAT CARDS — elevated, distinct hierarchy
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    CHART CARD
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    GENERIC PANEL — consistent surfaces
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    MY CARD PANEL — visually dominant, premium
    ═══════════════════════════════════════════════════════════════ */

.db-card-panel .db-panel-hdr {
  position: relative !important;
  z-index: 10 !important;
  background: transparent !important;
  border: none !important;
  padding-bottom: 6px !important;
  margin-bottom: 10px !important;
  box-shadow: none !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.db-card-panel .tb-icon-sm {
  position: static !important;
  z-index: auto !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: var(--t3) !important;
}

.db-card-panel:hover {
  transform: translateY(-3px);
  box-shadow:
    var(--shadow-xl),
    0 0 50px rgba(79, 110, 247, 0.12) !important;
}

.db-card-panel .db-panel-title {
  font-size: 0.92rem;
  letter-spacing: 0.01em;
}

/* Taller card stack for prominence */

/* Card items — more padding, richer */

/* ─── Card action buttons — BELOW card, secondary style ──────── */

/* Card dots pagination */

/* ═══════════════════════════════════════════════════════════════
    TRANSACTIONS MINI LIST (right panel)
    ═══════════════════════════════════════════════════════════════ */

.rp-txn-row:last-child {
  border-bottom: none;
}

.rp-txn-row:hover {
  background: rgba(255, 255, 255, 0.025);
}

/* ═══════════════════════════════════════════════════════════════
    BUTTONS — premium polish
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    SEARCH — debounced live filter (also applied via JS patch)
    ═══════════════════════════════════════════════════════════════ */

/* Apply topbar search styling fixes at larger scale */

@media (min-width: 1200px) {
  .topbar-search {
    width: 440px;
  }
  .topbar-search:focus-within {
    width: 480px;
  }
}

/* ═══════════════════════════════════════════════════════════════
    ASK AI PANEL — refined
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    MODALS — premium feel
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    SETTINGS MENU — polished dropdown
    ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
    TRANSACTIONS TABLE — clean
    ═══════════════════════════════════════════════════════════════ */

.transaction-table th {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--t3);
  padding: 0.6rem 0.85rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.transaction-table td {
  padding: 0.75rem 0.85rem;
  font-size: 0.82rem;
  color: var(--t2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

/* ═══════════════════════════════════════════════════════════════
    SCROLLBAR — subtle premium
    ═══════════════════════════════════════════════════════════════ */

::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

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

::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.18);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(79, 110, 247, 0.32);
}

/* ═══════════════════════════════════════════════════════════════
    CARD INNER CONTENT — better typography
    ═══════════════════════════════════════════════════════════════ */

.ci-name {
  font-family: "Syne", sans-serif;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════════
    EXPENSE CATEGORY LIST
    ═══════════════════════════════════════════════════════════════ */

.expense-categories li:hover {
  background: rgba(255, 255, 255, 0.03);
}

/* ═══════════════════════════════════════════════════════════════
    RECENT TXN SLIDE PANEL — refined
    ═══════════════════════════════════════════════════════════════ */

/* .rtp-panel {
    background: rgba(9, 10, 22, 0.97);
    border-left: 1px solid rgba(255, 255, 255, 0.07);
    backdrop-filter: blur(28px);
    -webkit-backdrop-filter: blur(28px);
  }

  .rtp-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    padding: 1.1rem 1.25rem;
  }

  .rtp-title {
    font-family: "Syne", sans-serif;
    font-weight: 800;
    font-size: 0.95rem;
  }

  .rtp-search {
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding: 0.7rem 1.1rem;
    gap: 0.6rem;
  }

  .rtp-search input {
    font-family: "DM Sans", sans-serif;
    font-size: 0.84rem;
    background: none;
    border: none;
    color: var(--t1);
    width: 100%;
    outline: none;
  }

  .rtp-header,
  .rtp-search {
    all: unset;
    display: contents;
  }

  .rtp-view-all {
    all: unset; 
  } */

/* ═══════════════════════════════════════════════════════════════
    LIGHT THEME ADJUSTMENTS
    ═══════════════════════════════════════════════════════════════ */

[data-theme="light"] .db-stat-card,
[data-theme="light"] .db-chart-card,
[data-theme="light"] .db-panel {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.08);
  box-shadow: 0 2px 8px rgba(25, 28, 30, 0.06);
}

/* Kill dark shimmer pseudo-element on cards */
[data-theme="light"] .db-stat-card::before,
[data-theme="light"] .db-chart-card::before,
[data-theme="light"] .db-panel::before {
  background: none !important;
}

/* Card text colours */
[data-theme="light"] .dsc-label {
  color: #64748b;
}
[data-theme="light"] .db-panel-title,
[data-theme="light"] .db-panel-sub,
[data-theme="light"] .dcc-title {
  color: #191c1e;
}
[data-theme="light"] .db-panel-sub {
  color: #64748b;
}

[data-theme="light"] .modal-content {
  background: #fff;
  border-color: rgba(79, 110, 247, 0.12);
}

/* ═══════════════════════════════════════════════════════════════
    MICRO-INTERACTIONS
    ═══════════════════════════════════════════════════════════════ */

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

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

.db-stat-card:nth-child(1) {
  animation-delay: 0.05s;
}

.db-stat-card:nth-child(2) {
  animation-delay: 0.12s;
}

.db-stat-card:nth-child(3) {
  animation-delay: 0.18s;
}

/* FIX: Sidebar containment */

/* ═══════════════════════════════════════════════
    MY CARD — PREMIUM SPACING & HEIGHT FIX
    ═══════════════════════════════════════════════ */

/* 1. Card stack container — taller, no clipping */

/* 2. Card items — breathable internal height */

/* 3. Top section: bank name → chip */

/* 4. Bank name: stronger presence */

/* 5. Card number: more breathing room */

/* 6. Cardholder name */

/* 7. Bank label below name */

/* 8. Spending section — clear separation */

/* 9. Spend row typography */

/* 10. Progress bar */

/* 11. Bottom section: expiry alignment */

/* 12. Stacking positions — adjusted for taller cards */

/* 13. Panel header — always above card */

/* 14. Dots sit cleanly below */

/* 15. Action row — clear separation from dots */

/* ═══════════════════════════════════════════════════════════════════
    BlueLedger — Card Flip Interaction CSS
    Paste at the VERY END of style.css
    Replaces: hover/stack system → click 3D flip
    ═══════════════════════════════════════════════════════════════════ */

/* ── 1. KILL ALL HOVER STACK RULES ─────────────────────────────── */

/* Remove all rank-based stacking transforms */

.card-item.rank-0,
.card-item.rank-1,
.card-item.rank-2,
.card-item.rank-3 {
  bottom: auto !important;
  transform: none !important;
  opacity: 1 !important;
  filter: none !important;
  box-shadow: none !important;
}

/* Remove hover state classes */

.card-item.is-hovered,
.card-item.is-top,
.card-item.is-active {
  transform: none !important;
  opacity: 1 !important;
  filter: none !important;
  box-shadow: none !important;
}

/* Kill hover-driven sibling fade */

.card-stack-v2.hovering .card-item:not(.is-hovered),
.card-stack-v2.fan-open .card-item:not(.is-hovered) {
  opacity: 1 !important;
  filter: none !important;
}

/* Remove fan-open height change */

/* Kill glow-ring pulse on hover */

/* ── 2. CARD STACK CONTAINER — clean slate ──────────────────────── */

/* ── 3. FLIP SCENE ──────────────────────────────────────────────── */

.cs-flip-scene {
  width: 100% !important;
  perspective: 1000px;
  perspective-origin: 50% 50%;
  max-width: 340px !important;
  margin: 0 auto !important;
}

/* ── 4. THE FLIP CARD ───────────────────────────────────────────── */

.cs-flip-card {
  position: relative;
  width: 100%;
  border-radius: 20px;
  padding: 1.2rem 1.3rem 1.1rem !important;
  overflow: hidden;
  cursor: pointer;
  will-change: transform;
  transform: rotateY(0deg) scale(1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(79, 110, 247, 0.2);
}

/* Per-theme gradients (reuse existing data-theme system) */

.cs-flip-card[data-theme="0"] {
  background: linear-gradient(135deg, #0d2b20 0%, #133828 45%, #1a4a30 100%);
  --card-accent: rgba(34, 197, 94, 0.7);
  --card-accent-glow: rgba(34, 197, 94, 0.2);
  border-color: rgba(34, 197, 94, 0.22) !important;
}

.cs-flip-card[data-theme="1"] {
  background: linear-gradient(135deg, #0d1a35 0%, #152240 45%, #1a2d52 100%);
  --card-accent: rgba(59, 130, 246, 0.7);
  --card-accent-glow: rgba(59, 130, 246, 0.2);
  border-color: rgba(59, 130, 246, 0.22) !important;
}

.cs-flip-card[data-theme="2"] {
  background: linear-gradient(135deg, #2b1d08 0%, #3a2510 45%, #4a2e12 100%);
  --card-accent: rgba(245, 158, 11, 0.7);
  --card-accent-glow: rgba(245, 158, 11, 0.2);
  border-color: rgba(245, 158, 11, 0.22) !important;
}

.cs-flip-card[data-theme="3"] {
  background: linear-gradient(135deg, #2b0d20 0%, #3a1228 45%, #4a163a 100%);
  --card-accent: rgba(236, 72, 153, 0.7);
  --card-accent-glow: rgba(236, 72, 153, 0.2);
  border-color: rgba(236, 72, 153, 0.22) !important;
}

/* Subtle lift on hover (not stacking — just depth signal) */

.cs-flip-card:hover {
  box-shadow:
    0 28px 70px rgba(0, 0, 0, 0.65),
    0 0 100px var(--card-accent-glow, rgba(79, 110, 247, 0.25));
}

/* ── 5. CARD FACE CONTENTS ──────────────────────────────────────── */

.cs-flip-card__face {
  position: relative;
  z-index: 1;
  width: 100%;
}

/* Shine overlay — disabled, was causing white fog */

.cs-flip-card__shine {
  display: none;
}

/* Ambient glow blobs */

.cs-flip-card__blob {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}

.cs-flip-card__blob--tl {
  top: -40px;
  right: -30px;
  width: 120px;
  height: 120px;
  background: radial-gradient(
    circle,
    var(--card-accent-glow, rgba(255, 255, 255, 0.04)) 0%,
    transparent 65%
  );
}

.cs-flip-card__blob--br {
  bottom: -25px;
  left: 10px;
  width: 100px;
  height: 100px;
  background: radial-gradient(
    circle,
    var(--card-accent-glow, rgba(255, 255, 255, 0.03)) 0%,
    transparent 65%
  );
}

/* ── 6. CARD INNER TYPOGRAPHY ───────────────────────────────────── */

.cs-flip-card .ci-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem !important;
  position: relative;
  z-index: 3;
}

.cs-flip-card .ci-nick {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.65);
}

.cs-flip-card .ci-chip {
  width: 28px;
  height: 20px;
  border-radius: 5px;
  background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

.cs-flip-card .ci-number {
  font-size: 0.84rem !important;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.82);
  margin-bottom: 0.7rem !important;
  font-family: "Courier New", monospace;
  position: relative;
  z-index: 3;
}

.cs-flip-card .ci-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 0.1rem;
  position: relative;
  z-index: 3;
}

.cs-flip-card .ci-holder {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}

.cs-flip-card .ci-bank {
  font-size: 0.58rem;
  color: rgba(255, 255, 255, 0.35);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 3px;
}

.cs-flip-card .ci-expiry-col {
  text-align: right;
  flex-shrink: 0;
}

.cs-flip-card .ci-exp-label {
  font-size: 0.55rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.28);
  margin-bottom: 3px;
}

.cs-flip-card .ci-exp-val {
  font-family: "Courier New", monospace;
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.75);
}

.cs-flip-card .ci-spending {
  margin-top: 0.75rem !important;
  padding: 0.55rem 0.7rem 0.6rem;
  position: relative;
  z-index: 3;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 10px;
}

.cs-flip-card .ci-spending::before {
  display: none;
}

.cs-flip-card .ci-spend-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.64rem;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.36);
  margin-bottom: 0.18rem;
}

.cs-flip-card .ci-spend-limit {
  font-weight: 700;
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.88);
  letter-spacing: 0.01em;
}

.cs-flip-card .ci-spend-used {
  font-size: 0.6rem;
  color: rgba(255, 255, 255, 0.3);
  margin-bottom: 0.45rem;
  letter-spacing: 0.015em;
}

.cs-flip-card .ci-progress {
  height: 2px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 99px;
  overflow: visible;
  position: relative;
}

.cs-flip-card .ci-progress-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(
    90deg,
    var(--card-accent, rgba(79, 110, 247, 0.9)),
    rgba(255, 255, 255, 0.45)
  );
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

/* Glow dot at the progress tip */

.cs-flip-card .ci-progress-fill::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 0 6px var(--card-accent, rgba(79, 110, 247, 0.8));
}

.cs-flip-card .ci-progress-danger {
  background: linear-gradient(90deg, #ef4444cc, #fca5a5aa) !important;
  box-shadow: 0 0 6px rgba(239, 68, 68, 0.35);
}

.cs-flip-card .ci-progress-danger::after {
  background: #fca5a5 !important;
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.6) !important;
}

/* ── 7. NAVIGATION ARROWS ───────────────────────────────────────── */

.cs-flip-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  padding: 0 4px !important;
  max-width: 340px !important;
  margin: 8px auto 0 !important;
}

.cs-flip-arrow {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: rgba(255, 255, 255, 0.35) !important;
  font-size: 0.68rem !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.18s;
  flex-shrink: 0;
}

.cs-flip-arrow:hover {
  background: rgba(79, 110, 247, 0.1) !important;
  border-color: rgba(79, 110, 247, 0.22) !important;
  color: rgba(255, 255, 255, 0.75) !important;
  transform: scale(1.06) !important;
}

.cs-flip-arrow:active {
  transform: scale(0.95);
}

/* ── 8. DOTS ────────────────────────────────────────────────────── */

/* Override existing dot styles to work with new layout */

.cs-dot:hover:not(.is-active) {
  background: rgba(255, 255, 255, 0.35) !important;
}

/* ── 9. MY CARD PANEL — final layout ───────────────────────────── */

.db-card-panel .db-card-title {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--t1);
  letter-spacing: -0.01em;
}

/* Card action buttons */

/* ── 10. EMPTY STATE ────────────────────────────────────────────── */

/* ── 11. LIGHT THEME ────────────────────────────────────────────── */

[data-theme="light"] .cs-flip-card[data-theme="0"] {
  background: linear-gradient(135deg, #065f46 0%, #047857 45%, #16a34a 100%);
}

[data-theme="light"] .cs-flip-card[data-theme="1"] {
  background: linear-gradient(135deg, #1e3a5f 0%, #1d4ed8 45%, #2563eb 100%);
}

[data-theme="light"] .cs-flip-card[data-theme="2"] {
  background: linear-gradient(135deg, #78350f 0%, #b45309 45%, #d97706 100%);
}

[data-theme="light"] .cs-flip-card[data-theme="3"] {
  background: linear-gradient(135deg, #831843 0%, #be185d 45%, #db2777 100%);
}

/* ── 12. RESPONSIVE ─────────────────────────────────────────────── */

@media (max-width: 900px) {
  .cs-flip-card {
    padding: 1.2rem 1.25rem 1.1rem !important;
  }
  .cs-flip-card .ci-number {
    font-size: 0.82rem !important;
  }
}

@media (max-width: 640px) {
  .cs-flip-card {
    padding: 1.1rem 1.15rem 1rem !important;
    border-radius: 18px !important;
  }
  .cs-flip-card .ci-number {
    font-size: 0.78rem !important;
    letter-spacing: 0.14em !important;
  }
  .cs-flip-arrow {
    width: 32px !important;
    height: 32px !important;
    font-size: 0.7rem !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
    ADAPTIVE LAYOUT — STATE-DRIVEN DASHBOARD GRID
    ═══════════════════════════════════════════════════════════════ */

/* ── DEFAULT state: db-grid is already 2-col (left + right).
        db-left = flex-col: stats → chart → txns
        db-right = flex-col: card → expenses
        Inline report hidden. Insights hidden (< 3 txns).
    ─────────────────────────────────────────────────────────────── */

/* Smooth layout transitions for key sections */

.db-chart-card,
#insightsSection,
.section-expenses,
#inlineSummaryPanel {
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
}

/* ── INSIGHTS ACTIVE state:
        db-grid switches to 2fr 1fr ratio (wider left col).
        db-right shows inline report below expenses.
    ─────────────────────────────────────────────────────────────── */

#dashboardGrid.insights-active {
  grid-template-columns: 2fr 360px;
}

/* ── Inline Monthly Report Panel ──────────────────────────────── */

.inline-report-month {
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 9px;
  background: var(--accent-dim);
  border-radius: 20px;
  border: 1px solid rgba(79, 110, 247, 0.2);
  white-space: nowrap;
}

.inline-report-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.55rem;
  margin: 0.85rem 0 0;
}

.inline-report-stat {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0.55rem 0.65rem;
  transition: background 0.2s;
}

.inline-report-stat:hover {
  background: rgba(79, 110, 247, 0.06);
}

.inline-report-label {
  font-size: 0.63rem;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.22rem;
}

.inline-report-value {
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--t1);
  font-family: "DM Sans", sans-serif;
  letter-spacing: -0.01em;
}

.inline-report-value.positive {
  color: var(--inc);
}

.inline-report-value.negative {
  color: var(--exp);
}

.inline-report-divider {
  height: 1px;
  background: var(--border);
  margin: 0.8rem 0 0.65rem;
}

.inline-report-cats {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-height: 130px;
  overflow-y: auto;
  scrollbar-width: none;
}

.inline-report-cats::-webkit-scrollbar {
  display: none;
}

.irc-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.74rem;
}

.irc-name {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--t2);
  font-weight: 500;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.irc-amount {
  color: var(--exp);
  font-weight: 700;
  font-size: 0.72rem;
  flex-shrink: 0;
  margin-left: 0.5rem;
}

.inline-report-full-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  width: 100%;
  margin-top: 0.75rem;
  padding: 0.52rem;
  border-radius: var(--r-sm);
  border: 1px solid rgba(79, 110, 247, 0.2);
  background: rgba(79, 110, 247, 0.06);
  color: var(--accent);
  font-size: 0.74rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: "DM Sans", sans-serif;
  letter-spacing: 0.01em;
}

.inline-report-full-btn:hover {
  background: rgba(79, 110, 247, 0.14);
  border-color: rgba(79, 110, 247, 0.45);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(79, 110, 247, 0.15);
}

/* ── Mobile: always single column, hide inline report ─────────── */

@media (max-width: 1080px) {
  #dashboardGrid.insights-active {
    grid-template-columns: 1fr;
  }
  #inlineSummaryPanel {
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
    TRANSACTIONS PANEL WITH SEARCH
    Paste at the very end of style.css
    ═══════════════════════════════════════════════════════════════════ */

/* ── Hide topbar search completely ─────────────────────────────── */

/* Topbar: reclaim the space, keep it balanced */

/* ── Transactions panel wrapper ─────────────────────────────────── */

.rp-txn-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding: 1.2rem 1.25rem 1.1rem !important;
  overflow: hidden !important;
}

.rp-txn-panel .db-panel-hdr {
  flex-shrink: 0;
  margin-bottom: 10px !important;
}

/* ── Search bar ─────────────────────────────────────────────────── */

.rp-search-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 0.52rem 0.85rem;
  margin-bottom: 8px;
  transition:
    border-color 0.2s,
    background 0.2s,
    box-shadow 0.2s;
  flex-shrink: 0;
}

.rp-search-bar:focus-within {
  border-color: rgba(79, 110, 247, 0.35);
  background: rgba(79, 110, 247, 0.05);
  box-shadow: 0 0 0 3px rgba(79, 110, 247, 0.08);
}

.rp-search-icon {
  color: rgba(79, 110, 247, 0.5);
  font-size: 0.75rem;
  flex-shrink: 0;
}

.rp-search-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--t1, #f0f4ff);
  font-size: 0.8rem;
  font-family: "DM Sans", system-ui, sans-serif;
  min-width: 0;
}

.rp-search-input::placeholder {
  color: var(--t3, #3d4466);
  font-size: 0.78rem;
}

.rp-search-clear {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  color: var(--t3, #3d4466);
  font-size: 0.62rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition:
    background 0.15s,
    color 0.15s;
}

.rp-search-clear:hover {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
}

/* ── Filter chips ───────────────────────────────────────────────── */

.rp-filter-chips {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
  flex-shrink: 0;
}

.rp-chip {
  padding: 0.25rem 0.75rem;
  border-radius: 50px;
  font-size: 0.7rem;
  font-weight: 700;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t2, #8892b0);
  cursor: pointer;
  transition: all 0.18s;
  font-family: "DM Sans", system-ui, sans-serif;
  letter-spacing: 0.02em;
}

.rp-chip:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1, #f0f4ff);
}

.rp-chip--active {
  background: rgba(79, 110, 247, 0.12) !important;
  border-color: rgba(79, 110, 247, 0.28) !important;
  color: #4f6ef7 !important;
}

/* Income chip active */

.rp-chip[data-filter="income"].rp-chip--active {
  background: rgba(34, 197, 94, 0.1) !important;
  border-color: rgba(34, 197, 94, 0.25) !important;
  color: #22c55e !important;
}

/* Expense chip active */

.rp-chip[data-filter="expense"].rp-chip--active {
  background: rgba(244, 63, 94, 0.1) !important;
  border-color: rgba(244, 63, 94, 0.25) !important;
  color: #f43f5e !important;
}

/* ── Transaction list ───────────────────────────────────────────── */

.rp-txn-panel .rp-txn-list {
  flex: 1;
  overflow-y: auto;
  max-height: 320px;
  scrollbar-width: thin;
  scrollbar-color: rgba(79, 110, 247, 0.15) transparent;
}

.rp-txn-panel .rp-txn-list::-webkit-scrollbar {
  width: 3px;
}

.rp-txn-panel .rp-txn-list::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.2);
  border-radius: 3px;
}

/* ── Search match highlight ─────────────────────────────────────── */

mark.rp-hl {
  background: rgba(79, 110, 247, 0.25);
  color: #b8d0ff;
  border-radius: 3px;
  padding: 0 2px;
  font-style: normal;
}

/* ── Empty state ────────────────────────────────────────────────── */

.rp-txn-panel .rp-empty {
  padding: 2rem 0.5rem;
  text-align: center;
  color: var(--t3, #3d4466);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.rp-txn-panel .rp-empty i {
  font-size: 1.6rem;
  opacity: 0.25;
}

.rp-txn-panel .rp-empty span {
  font-size: 0.78rem;
  font-weight: 500;
}

/* ── Light theme ────────────────────────────────────────────────── */

[data-theme="light"] .rp-search-bar {
  background: rgba(79, 110, 247, 0.05);
  border-color: rgba(79, 110, 247, 0.15);
}

[data-theme="light"] .rp-search-bar:focus-within {
  border-color: rgba(79, 110, 247, 0.35);
  background: rgba(79, 110, 247, 0.08);
}

[data-theme="light"] .rp-search-input {
  color: #0f172a;
}

[data-theme="light"] mark.rp-hl {
  background: rgba(79, 110, 247, 0.18);
  color: #3b5bdb;
}

/* ================================
    TABLET (≤1024px)
  ================================ */

@media (max-width: 1024px) {
  .txn-meta {
    padding: 0 1rem;
  }

  .search-wrapper {
    padding: 0.4rem 0.7rem;
  }

  .search-input {
    font-size: 0.85rem;
  }
}

/* ================================
    MOBILE (≤768px)
  ================================ */

@media (max-width: 768px) {
  .txn-meta {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 0 0.9rem;
  }

  .search-wrapper {
    width: 100%;
    border-radius: 12px;
    padding: 0.45rem 0.75rem;
  }

  .search-input {
    font-size: 0.9rem;
  }
}

/* ================================
    SMALL MOBILE (≤480px)
  ================================ */

@media (max-width: 480px) {
  .txn-meta {
    padding: 0 0.75rem;
  }

  .search-wrapper {
    padding: 0.5rem 0.8rem;
  }

  .search-input {
    font-size: 0.95rem;
  }
}

.txn-highlight {
  background: rgba(79, 110, 247, 0.25);
  color: #b8d0ff;
  padding: 0 2px;
  border-radius: 4px;
  font-weight: 600;
}
/* ════════════════════════════════════════════════════════════
    BUDGET MODAL — unified input rows
    ════════════════════════════════════════════════════════════ */

.budget-input-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.budget-input-row:last-child {
  border-bottom: none;
}

.budget-input-label {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--t1);
  font-weight: 500;
  min-width: 0;
}

.budget-cat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

.budget-amt-input {
  width: 120px !important;
  min-width: 120px !important;
  max-width: 120px !important;
  text-align: right !important;
  padding: 0.42rem 0.65rem !important;
  font-size: 0.83rem !important;
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════
    MANAGE CATEGORIES MODAL — redesigned
    ════════════════════════════════════════════════════════════ */

.cat-modal-body {
  padding: 1.25rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cat-add-row {
  display: flex;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}

.cat-add-input {
  flex: 1;
  min-width: 0;
}

.cat-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0 1.1rem;
  height: 42px;
  border-radius: var(--r-md, 10px);
  background: var(--accent, #4f6ef7);
  border: none;
  color: #fff;
  font-size: 0.83rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition:
    opacity 0.15s,
    transform 0.12s;
  font-family: inherit;
  flex-shrink: 0;
}

.cat-add-btn:hover {
  opacity: 0.88;
}
.cat-add-btn:active {
  transform: scale(0.97);
}

.cat-section-label {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3, #64748b);
  margin-bottom: 0.55rem;
}

.custom-cat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.52rem 0.75rem;
  border-radius: var(--r-md, 10px);
  background: rgba(255, 255, 255, 0.03);
  border: 0.5px solid rgba(255, 255, 255, 0.07);
  margin-bottom: 0.35rem;
  transition: background 0.14s;
}

.custom-cat-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.custom-cat-info {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

.custom-cat-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

.custom-cat-name {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--t1);
}

.btn-cat-remove {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  background: rgba(239, 68, 68, 0.08);
  border: 0.5px solid rgba(239, 68, 68, 0.18);
  color: #ef4444;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.68rem;
  transition:
    background 0.14s,
    border-color 0.14s;
  flex-shrink: 0;
}

.btn-cat-remove:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.4);
}

.cat-empty-state {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 0.75rem;
  border-radius: var(--r-md, 10px);
  background: rgba(255, 255, 255, 0.02);
  border: 0.5px dashed rgba(255, 255, 255, 0.1);
  color: var(--t3);
  font-size: 0.8rem;
  margin-bottom: 0.35rem;
}

.cat-empty-state i {
  font-size: 0.75rem;
  opacity: 0.5;
}

.builtin-cat-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.25rem;
}

.builtin-cat-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.75rem;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--cat-bg, #4f6ef7);
  color: #fff;
  letter-spacing: 0.01em;
  opacity: 0.92;
}

/* ════════════════════════════════════════════════════════════
    FULL-PAGE TRANSACTIONS — search bar & highlight
    ════════════════════════════════════════════════════════════ */

.txnfp-search-bar {
  padding: 0.75rem 1.45rem 0;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.txnfp-search-inner {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  padding: 0.52rem 0.75rem;
  transition:
    border-color 0.18s,
    background 0.18s;
}

.txnfp-search-inner:focus-within {
  border-color: rgba(79, 110, 247, 0.45);
  background: rgba(79, 110, 247, 0.06);
  box-shadow: 0 0 0 3px rgba(79, 110, 247, 0.08);
}

.txnfp-search-icon {
  color: var(--t3, #475569);
  font-size: 0.78rem;
  flex-shrink: 0;
}

.txnfp-search-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--t1, #e2e8f0);
  font-size: 0.84rem;
  font-family: inherit;
  min-width: 0;
}

.txnfp-search-input::placeholder {
  color: var(--t3, #475569);
}

.txnfp-search-clear {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.07);
  border: none;
  color: var(--t3, #94a3b8);
  cursor: pointer;
  font-size: 0.65rem;
  flex-shrink: 0;
  transition:
    background 0.15s,
    color 0.15s;
}

.txnfp-search-clear:hover {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}

.txnfp-chips {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.txnfp-chip {
  padding: 0.28rem 0.75rem;
  border-radius: 20px;
  font-size: 0.73rem;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t3, #94a3b8);
  cursor: pointer;
  transition: all 0.15s;
  font-family: inherit;
}

.txnfp-chip:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1, #e2e8f0);
}

.txnfp-chip--active {
  background: rgba(79, 110, 247, 0.18);
  border-color: rgba(79, 110, 247, 0.4);
  color: #93b4ff;
}

.txnfp-count {
  display: none;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--t3, #64748b);
  padding-bottom: 0.15rem;
}

.txnfp-search-bar + .txn-page-body {
  padding-top: 0.75rem;
}

mark.txn-fp-hl {
  background: rgba(79, 110, 247, 0.3);
  color: #b8d0ff;
  border-radius: 3px;
  padding: 0 2px;
  font-style: normal;
  font-weight: 700;
  text-decoration: none;
}

.txnfp-empty {
  text-align: center;
  padding: 3.5rem 1rem;
  color: #475569;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.txnfp-empty i {
  font-size: 2rem;
  opacity: 0.4;
}

.txnfp-empty-msg {
  font-size: 0.9rem;
  font-weight: 600;
  color: #64748b;
}

.txnfp-empty-hint {
  font-size: 0.78rem;
  color: #475569;
  margin-top: 0.1rem;
}

/* ════════════════════════════════════════════════════════════
    DYNAMIC DASHBOARD GREETING
    ════════════════════════════════════════════════════════════ */

.db-greeting-block {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
}

.db-greeting-eyebrow {
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--t3, #475569);
  opacity: 0.75;
  margin-bottom: 0.05rem;
}

.db-greeting-name {
  font-family: "Syne", sans-serif;
  font-size: 6rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--t1, #f0f4ff);
  line-height: 1.15;
  background: linear-gradient(
    100deg,
    var(--t1, #f0f4ff) 0%,
    rgba(147, 180, 255, 0.92) 55%,
    var(--t1, #f0f4ff) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.db-greeting-sub {
  font-size: 1rem;
  font-weight: 400;
  color: var(--t3, #64748b);
  opacity: 0.8;
  margin: 0;
  letter-spacing: 0.01em;
}

@media (max-width: 640px) {
  .db-greeting-name {
    font-size: 1.2rem;
  }
  .db-greeting-eyebrow {
    font-size: 0.62rem;
  }
  .db-greeting-sub {
    font-size: 0.7rem;
  }
}

[data-theme="light"] .db-greeting-name {
  background: linear-gradient(100deg, #0f172a 0%, #3b5bdb 55%, #0f172a 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

[data-theme="light"] .db-greeting-eyebrow,
[data-theme="light"] .db-greeting-sub {
  color: #64748b;
}

/* ════════════════════════════════════════════════════════════
    TXN FULL PAGE — SEARCH + FILTER CHIPS
    ════════════════════════════════════════════════════════════ */

.txn-page-search-area {
  flex-shrink: 0;
  padding: 0.75rem 1.45rem 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  background: rgba(8, 9, 15, 0.5);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 0.75rem;
}

.txn-page-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.txn-page-search-icon {
  position: absolute;
  left: 0.85rem;
  color: var(--t3, #64748b);
  font-size: 0.78rem;
  pointer-events: none;
}

.txn-page-search-input {
  width: 100%;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  color: var(--t1, #f0f4ff);
  font-size: 0.83rem;
  padding: 0.55rem 2.4rem 0.55rem 2.2rem;
  outline: none;
  transition:
    border-color 0.2s,
    background 0.2s;
  font-family: inherit;
}

.txn-page-search-input::placeholder {
  color: var(--t4, #334155);
}

.txn-page-search-input:focus {
  border-color: rgba(79, 110, 247, 0.5);
  background: rgba(79, 110, 247, 0.06);
}

.txn-page-search-clear {
  position: absolute;
  right: 0.6rem;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  color: var(--t3, #64748b);
  font-size: 0.68rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s;
}

.txn-page-search-clear:hover {
  background: rgba(255, 255, 255, 0.15);
  color: var(--t1);
}

/* Filter chips */
.txn-page-chips {
  display: flex;
  gap: 0.4rem;
}

.txn-page-chip {
  padding: 0.28rem 0.85rem;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: transparent;
  color: var(--t3, #64748b);
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  font-family: inherit;
}

.txn-page-chip:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--t1);
}

.txn-page-chip--active {
  background: rgba(79, 110, 247, 0.18);
  border-color: rgba(79, 110, 247, 0.45);
  color: #b8d0ff;
}

/* Highlight mark */
mark.txn-page-hl {
  background: rgba(79, 110, 247, 0.3);
  color: #b8d0ff;
  border-radius: 3px;
  padding: 0 2px;
  font-style: normal;
  font-weight: 700;
  text-decoration: none;
}

/* Light theme overrides */
[data-theme="light"] .txn-page-search-input {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.12);
  color: var(--t1);
}

[data-theme="light"] .txn-page-search-input:focus {
  border-color: rgba(79, 110, 247, 0.5);
  background: rgba(79, 110, 247, 0.05);
}

[data-theme="light"] mark.txn-page-hl {
  background: rgba(79, 110, 247, 0.2);
  color: #4338ca;
}

[data-theme="light"] .txn-page-chip--active {
  background: rgba(79, 110, 247, 0.12);
  border-color: rgba(79, 110, 247, 0.4);
  color: #4338ca;
}

/* Pills row — sits at top of content when greeting block is removed */
.db-pills-row {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 0.6rem 0 0.25rem;
}

/* ── Topbar: date-only block ─────────────────────────────────── */
.topbar-date-block {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.topbar-date-day {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--t3, #64748b);
}

.topbar-date-full {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--t1, #f0f4ff);
}

/* Mobile: hide desktop greeting on mobile, show mobile greeting above My Card */
@media (max-width: 768px) {
  .db-left-greeting {
    display: none;
  }
}

/* Mobile-only greeting above My Card */
.db-mobile-greeting {
  display: none; /* hidden on desktop */
  padding: 0.5rem 0.1rem 0.9rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 1rem;
}

.db-mobile-greeting .db-greeting-name {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--t1, #f0f4ff);
  margin: 0 0 0.2rem;
  line-height: 1.2;
  background: linear-gradient(
    100deg,
    var(--t1, #f0f4ff) 0%,
    rgba(147, 180, 255, 0.92) 55%,
    var(--t1, #f0f4ff) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.db-mobile-greeting .db-greeting-sub {
  font-size: 0.75rem;
  color: var(--t3, #64748b);
  margin: 0;
}

@media (max-width: 768px) {
  .db-mobile-greeting {
    display: block;
  }
}

[data-theme="light"] .db-mobile-greeting {
  border-bottom-color: rgba(0, 0, 0, 0.07);
}

[data-theme="light"] .db-mobile-greeting .db-greeting-name {
  background: linear-gradient(100deg, #0f172a 0%, #3b5bdb 55%, #0f172a 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Mobile: hide original stat cards, show mobile-positioned ones instead */
@media (max-width: 768px) {
  .db-left .db-stats {
    display: none;
  }
}

/* Mobile stat cards block (between My Card and All Expenses) */
.db-mobile-stats {
  display: none; /* hidden on desktop */
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md, 1rem);
}

.db-mobile-stats .db-stat-card:last-child {
  grid-column: 1 / -1; /* Net Balance spans full width like on desktop mobile */
}

@media (max-width: 768px) {
  .db-mobile-stats {
    display: grid;
  }
}

/* ── Greeting above the full grid (desktop) ──────────────────── */
.db-above-grid-greeting {
  padding: 0.25rem 0.1rem 0.85rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 0.15rem;
}

.db-above-grid-greeting .db-greeting-name {
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--t1, #f0f4ff);
  margin: 0 0 0.2rem;
  line-height: 1.15;
  background: linear-gradient(
    100deg,
    var(--t1, #f0f4ff) 0%,
    rgba(147, 180, 255, 0.92) 55%,
    var(--t1, #f0f4ff) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.db-above-grid-greeting .db-greeting-sub {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--t3, #64748b);
  margin: 0;
}

/* Hidden on mobile — mobile uses db-mobile-greeting inside db-right */
@media (max-width: 768px) {
  .db-above-grid-greeting {
    display: none;
  }
}

[data-theme="light"] .db-above-grid-greeting {
  border-bottom-color: rgba(0, 0, 0, 0.07);
}
[data-theme="light"] .db-above-grid-greeting .db-greeting-name {
  background: linear-gradient(100deg, #0f172a 0%, #3b5bdb 55%, #0f172a 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* db-left-greeting no longer used — hidden */
.db-left-greeting {
  display: none !important;
}

/* ── Greeting block above My Card (db-right) — DEPRECATED, greeting moved to db-left ─ */
.db-right-greeting {
  display: none;
  padding: 0.5rem 0.1rem 0.9rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 1rem;
}

.db-right-greeting .db-greeting-eyebrow {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #4f6ef7;
  margin-bottom: 0.15rem;
  text-transform: uppercase;
}

.db-right-greeting .db-greeting-name {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--t1, #f0f4ff);
  margin: 0 0 0.2rem;
  line-height: 1.2;
}

.db-right-greeting .db-greeting-sub {
  font-size: 0.75rem;
  color: var(--t3, #64748b);
  margin: 0;
}

/* Mobile: greeting sits above the card stack naturally */
@media (max-width: 768px) {
  .db-right-greeting {
    padding: 0.4rem 0.25rem 0.75rem;
    margin-bottom: 0.75rem;
  }
  .db-right-greeting .db-greeting-name {
    font-size: 1.15rem;
  }
}

/* Light theme */
[data-theme="light"] .db-right-greeting {
  border-bottom-color: rgba(0, 0, 0, 0.07);
}
[data-theme="light"] .topbar-date-full {
  color: var(--t1);
}

/* ════════════════════════════════════════════════════════════
   DEDICATED SETTINGS PAGE
   Full-screen overlay page. Slides in over the app layout.
   ════════════════════════════════════════════════════════════ */

.settings-page {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  flex-direction: row;
  background: var(--bg, #0e1117);
  opacity: 0;
  pointer-events: none;
  transform: translateX(24px);
  transition:
    opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  /* Guarantee full viewport coverage — no inherited constraints */
  width: 100vw;
  height: 100vh;
}

.settings-page.sp-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

/* Sidebar spacer — matches sidebar width on desktop */
.sp-sidebar-spacer {
  display: none;
}

/* Body — must fill all remaining width after sidebar spacer */
.sp-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
  width: 100%;
}

/* ── Header ──────────────────────────────────────────────── */

.sp-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 2.5rem;
  height: 72px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--bg2);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.sp-back-btn {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--t2);
  font-size: 0.82rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.16s ease;
  flex-shrink: 0;
}

.sp-back-btn:hover {
  background: rgba(79, 110, 247, 0.09);
  border-color: rgba(79, 110, 247, 0.22);
  color: var(--accent);
}

.sp-header-text {
  flex: 1;
  min-width: 0;
}

.sp-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--t1);
  letter-spacing: -0.025em;
  line-height: 1.2;
  margin: 0;
}

.sp-subtitle {
  font-size: 0.73rem;
  color: var(--t3);
  margin: 0.15rem 0 0;
  font-weight: 400;
  opacity: 0.8;
}

.sp-header-badge {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.32rem 0.9rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 50px;
  cursor: pointer;
  transition: all 0.16s ease;
}

.sp-header-badge:hover {
  background: rgba(79, 110, 247, 0.06);
  border-color: rgba(79, 110, 247, 0.16);
}

.sp-sync-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #475569;
  flex-shrink: 0;
  transition: background 0.3s;
}

.sp-sync-dot.synced {
  background: #22c55e;
  box-shadow: 0 0 6px rgba(34, 197, 94, 0.5);
}

.sp-sync-label {
  font-size: 0.71rem;
  color: var(--t3);
  white-space: nowrap;
  font-weight: 500;
}

/* ════════════════════════════════════════════════════════════
   SETTINGS PAGE — Premium Redesign
   Stripe · Linear · Arc · Fintech-grade
   ════════════════════════════════════════════════════════════ */

/* ── Groups scroll wrapper ───────────────────────────────── */

.sp-groups {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  /* Flush to left edge of sp-body — no centering, no max-width cap */
  padding: 2rem 2.5rem 4rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(79, 110, 247, 0.15) transparent;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  align-self: stretch;
}

.sp-groups::-webkit-scrollbar {
  width: 3px;
}

.sp-groups::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.18);
  border-radius: 3px;
}

/* ── Group ───────────────────────────────────────────────── */

.sp-group {
  display: flex;
  flex-direction: column;
  gap: 0;
  /* Full-width — grows with the container, no centering */
  width: 100%;
  max-width: 100%;
}

.sp-group-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--t3);
  padding: 0 0.5rem 0.85rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.sp-group-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.04);
  max-width: 200px;
}

.sp-group-body {
  background: var(--bg3, #161b22);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 14px;
  overflow: hidden;
  width: 100%;
  /* Layered depth — no glass, just solid surface */
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

/* ── Row ─────────────────────────────────────────────────── */

.sp-row {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  padding: 0 1.4rem;
  cursor: pointer;
  transition: background 0.14s ease;
  min-height: 80px;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}

.sp-row:hover {
  background: rgba(255, 255, 255, 0.028);
}

.sp-row:hover .sp-row-chevron {
  opacity: 1;
  transform: translateX(2px);
}

.sp-row:active {
  background: rgba(79, 110, 247, 0.045);
}

/* Inset dividers — clean thin line */
.sp-row--divider {
  border-top: 1px solid rgba(255, 255, 255, 0.055);
}

/* Remove old pseudo-element divider */
.sp-row--divider::before {
  display: none;
}

/* Row icon — slightly larger, better weight */
.sp-row-icon {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
  /* Subtle inner border for depth */
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.sp-icon--blue {
  background: rgba(59, 130, 246, 0.13);
  color: #60a5fa;
}
.sp-icon--purple {
  background: rgba(79, 110, 247, 0.13);
  color: #93b4ff;
}
.sp-icon--teal {
  background: rgba(20, 184, 166, 0.13);
  color: #2dd4bf;
}
.sp-icon--green {
  background: rgba(34, 197, 94, 0.13);
  color: #22c55e;
}
.sp-icon--orange {
  background: rgba(244, 63, 94, 0.13);
  color: #f43f5e;
}
.sp-icon--red {
  background: rgba(239, 68, 68, 0.11);
  color: #f87171;
}

/* Row content — improved hierarchy */
.sp-row-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.sp-row-title {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--t1);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.sp-row-sub {
  font-size: 0.76rem;
  color: var(--t2);
  opacity: 0.65;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 400;
  line-height: 1.4;
}

/* Chevron — refined */
.sp-row-chevron {
  font-size: 0.6rem;
  color: var(--t3);
  flex-shrink: 0;
  opacity: 0.45;
  transition:
    opacity 0.14s ease,
    transform 0.14s ease;
}

/* Danger rows */
.sp-row--danger .sp-row-title {
  color: #fca5a5;
}

.sp-row--danger:hover {
  background: rgba(239, 68, 68, 0.04);
}

.sp-row--danger:hover .sp-row-title {
  color: #f87171;
}

/* Danger zone group */
.sp-group--danger-zone .sp-group-body {
  border-color: rgba(239, 68, 68, 0.12);
  background: color-mix(in srgb, var(--bg2) 90%, #ff0000 10%);
}

/* ── Toggle switch — premium feel ────────────────────────── */

.sp-toggle-wrap {
  flex-shrink: 0;
}

.sp-toggle {
  position: relative;
  display: inline-block;
  cursor: pointer;
}

.sp-toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.sp-toggle-track {
  display: block;
  width: 48px;
  height: 28px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50px;
  position: relative;
  transition:
    background 0.22s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.22s;
}

.sp-toggle input:checked + .sp-toggle-track {
  background: var(--accent, #4f6ef7);
  border-color: var(--accent, #4f6ef7);
}

.sp-toggle-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
  transition: transform 0.24s cubic-bezier(0.34, 1.4, 0.64, 1);
}

.sp-toggle input:checked + .sp-toggle-track .sp-toggle-thumb {
  transform: translateX(20px);
}

/* ── Light theme overrides ───────────────────────────────── */

[data-theme="light"] .settings-page {
  background: #f4f6fb;
}

[data-theme="light"] .sp-header {
  background: rgba(255, 255, 255, 0.97);
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .sp-title {
  color: #191c1e;
}

[data-theme="light"] .sp-subtitle {
  color: #64748b;
}

[data-theme="light"] .sp-sidebar-spacer {
  display: none;
}

[data-theme="light"] .sp-group-body {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.07);
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

[data-theme="light"] .sp-row-title {
  color: #191c1e;
}

[data-theme="light"] .sp-row-sub {
  color: #64748b;
  opacity: 1;
}

[data-theme="light"] .sp-row--divider {
  border-top-color: rgba(0, 0, 0, 0.06);
}

[data-theme="light"] .sp-back-btn {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.09);
  color: #464555;
}

[data-theme="light"] .sp-header-badge {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .sp-sync-label {
  color: #64748b;
}

[data-theme="light"] .sp-toggle-track {
  background: rgba(0, 0, 0, 0.1);
  border-color: rgba(0, 0, 0, 0.1);
}

[data-theme="light"] .sp-group-label {
  color: #94a3b8;
}

[data-theme="light"] .sp-group-label::after {
  background: rgba(0, 0, 0, 0.07);
}

[data-theme="light"] .sp-row-chevron {
  color: #94a3b8;
  opacity: 0.7;
}

[data-theme="light"] .sp-row:hover {
  background: rgba(0, 0, 0, 0.025);
}

[data-theme="light"] .sp-group--danger-zone .sp-group-body {
  background: #fff8f8;
  border-color: rgba(239, 68, 68, 0.12);
}

[data-theme="light"] .sp-row--danger .sp-row-title {
  color: #dc2626;
}

/* ── Responsive — Wide Desktop ───────────────────────────── */

@media (min-width: 1200px) {
  .sp-groups {
    /* Keep horizontal rhythm — no extra left drift on wide screens */
    padding: 2.5rem 3rem 5rem 2.5rem;
  }
}

/* ── Animate rows on open ────────────────────────────────── */

.settings-page.sp-open .sp-group {
  animation: sp-row-in 0.3s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.settings-page.sp-open .sp-group:nth-child(1) {
  animation-delay: 0.03s;
}
.settings-page.sp-open .sp-group:nth-child(2) {
  animation-delay: 0.08s;
}
.settings-page.sp-open .sp-group:nth-child(3) {
  animation-delay: 0.13s;
}
.settings-page.sp-open .sp-group:nth-child(4) {
  animation-delay: 0.18s;
}
.settings-page.sp-open .sp-group:nth-child(5) {
  animation-delay: 0.23s;
}

@keyframes sp-row-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ════════════════════════════════════════════════════════════
   SETTINGS MODULE — New Modals
   Separate overlay layer (z-index 4000) — sits above settings page
   ════════════════════════════════════════════════════════════ */

/* ── Base settings-modal overlay ────────────────────────────── */

.blsm {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 4000; /* above settings-page (3000) and app modals (2000) */
  align-items: center;
  justify-content: center;
  padding: 1rem;
  overflow-y: auto;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.blsm--open {
  opacity: 1;
}

/* ── Modal content box ───────────────────────────────────────── */

.blsm-content {
  background: var(--bg2);
  border: 1px solid var(--border-md);
  border-radius: 18px;
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 480px;
  max-height: 88vh;
  overflow-y: auto;
  position: relative;
  transform: translateY(8px);
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  scrollbar-width: thin;
  scrollbar-color: rgba(79, 110, 247, 0.15) transparent;
}

.blsm--open .blsm-content {
  transform: translateY(0);
}

.blsm-content--sm {
  max-width: 420px;
}
.blsm-content--lg {
  max-width: 560px;
}

/* Section label inside modal body */
.blsm-section-label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--t3);
  margin-bottom: 0.6rem;
}

/* ── Appearance — theme picker ───────────────────────────────── */

.bltheme-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
}

.bltheme-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.02);
  cursor: pointer;
  transition: all 0.16s ease;
}

.bltheme-item:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(79, 110, 247, 0.2);
}

.bltheme-item--active {
  border-color: rgba(79, 110, 247, 0.45);
  background: rgba(79, 110, 247, 0.08);
  box-shadow: 0 0 0 1px rgba(79, 110, 247, 0.15) inset;
}

.bltheme-icon {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--t2);
}

.bltheme-item--active .bltheme-icon {
  background: rgba(79, 110, 247, 0.14);
  color: #93b4ff;
}

.bltheme-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--t2);
}

.bltheme-item--active .bltheme-label {
  color: #93b4ff;
}

/* ── Currency list ───────────────────────────────────────────── */

.blcurr-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  overflow: hidden;
}

.blcurr-item {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.8rem 1rem;
  cursor: pointer;
  transition: background 0.13s ease;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  width: 100%;
  text-align: left;
  background: transparent;
  border-radius: 0;
}

.blcurr-item:first-child {
  border-top: none;
}

.blcurr-item:hover {
  background: rgba(255, 255, 255, 0.03);
}

.blcurr-item--active {
  background: rgba(79, 110, 247, 0.06);
}

.blcurr-sym {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: rgba(79, 110, 247, 0.1);
  color: #93b4ff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 800;
  flex-shrink: 0;
}

.blcurr-name {
  flex: 1;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--t1);
}

.blcurr-code {
  font-size: 0.72rem;
  color: var(--t3);
  font-weight: 500;
}

.blcurr-check {
  font-size: 0.72rem;
  color: #22c55e;
  opacity: 0;
  transition: opacity 0.15s;
  margin-left: 0.4rem;
}

.blcurr-item--active .blcurr-check {
  opacity: 1;
}

/* ── Export / Backup buttons ─────────────────────────────────── */

.blexport-btn {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
  cursor: pointer;
  transition: all 0.15s ease;
  text-align: left;
  width: 100%;
}

.blexport-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.12);
  transform: translateY(-1px);
}

.blexport-btn:active {
  transform: translateY(0);
}

.blexport-icon {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  flex-shrink: 0;
}

.blexport-title {
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--t1);
  line-height: 1.25;
}

.blexport-sub {
  font-size: 0.72rem;
  color: var(--t3);
  margin-top: 0.15rem;
  line-height: 1.4;
}

/* ── FAQ accordion ───────────────────────────────────────────── */

.blfaq-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  overflow: hidden;
}

.blfaq-item {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.blfaq-item:first-child {
  border-top: none;
}

.blfaq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding: 0.95rem 1rem;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--t1);
  background: transparent;
  cursor: pointer;
  text-align: left;
  transition: background 0.13s;
  line-height: 1.4;
  border-radius: 0;
}

.blfaq-q:hover {
  background: rgba(255, 255, 255, 0.03);
}

.blfaq-chevron {
  font-size: 0.62rem;
  color: var(--t3);
  flex-shrink: 0;
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

.blfaq-item--open .blfaq-chevron {
  transform: rotate(180deg);
}

.blfaq-a {
  display: none;
  padding: 0 1rem 1rem;
  font-size: 0.8rem;
  color: var(--t3);
  line-height: 1.7;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.blfaq-item--open .blfaq-a {
  display: block;
}

/* ── About rows ──────────────────────────────────────────────── */

.blabout-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.65rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  gap: 1rem;
}

.blabout-key {
  font-size: 0.78rem;
  color: var(--t3);
  font-weight: 500;
}

.blabout-val {
  font-size: 0.8rem;
  color: var(--t1);
  font-weight: 700;
  text-align: right;
}

/* ── Light theme overrides ───────────────────────────────────── */

[data-theme="light"] .blsm-content {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.08);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.14);
}

[data-theme="light"] .blcurr-item:hover,
[data-theme="light"] .blfaq-q:hover {
  background: rgba(0, 0, 0, 0.03);
}

[data-theme="light"] .blcurr-item--active {
  background: rgba(79, 110, 247, 0.06);
}

[data-theme="light"] .bltheme-item {
  border-color: rgba(0, 0, 0, 0.09);
  background: rgba(0, 0, 0, 0.02);
}

[data-theme="light"] .bltheme-item--active {
  border-color: rgba(79, 110, 247, 0.4);
  background: rgba(79, 110, 247, 0.06);
}

[data-theme="light"] .blexport-btn {
  border-color: rgba(0, 0, 0, 0.09);
  background: rgba(0, 0, 0, 0.02);
}

[data-theme="light"] .blcurr-list,
[data-theme="light"] .blfaq-list {
  border-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .blcurr-item,
[data-theme="light"] .blfaq-item {
  border-top-color: rgba(0, 0, 0, 0.06);
}

/* ═══════════════════════════════════════════════════════════════
   BlueLedger — Light Mode Premium Refinement
   Drop this AFTER the main style.css link tag.
   Targets only [data-theme="light"] so dark mode is untouched.
   ═══════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────────
   CORE TOKEN OVERRIDES
   Replaces the existing [data-theme="light"] block with a richer,
   more balanced palette.
   ──────────────────────────────────────────────────────────────── */

/* ────────────────────────────────────────────────────────────────
   AMBIENT BACKGROUND — Remove the dark radial glows in light mode
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] body::before {
  background:
    radial-gradient(
      ellipse 70% 50% at -5% -5%,
      rgba(79, 110, 247, 0.05) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 50% 40% at 105% 0%,
      rgba(139, 92, 246, 0.04) 0%,
      transparent 55%
    ),
    linear-gradient(180deg, #f3f4f6 0%, #eef0f5 100%);
}

[data-theme="light"] body::after {
  background: radial-gradient(
    circle,
    rgba(91, 94, 246, 0.02) 0%,
    transparent 65%
  );
}

/* ────────────────────────────────────────────────────────────────
   SIDEBAR
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .sidebar {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(24px);
  border-right: 1px solid rgba(119, 117, 135, 0.14);
  box-shadow: 2px 0 16px rgba(25, 28, 30, 0.06);
}

[data-theme="light"] .sidebar-bottom {
  border-top-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .sb-btn {
  color: var(--t3);
}

[data-theme="light"] .sb-btn:hover {
  background: rgba(91, 94, 246, 0.07);
  color: var(--t2);
}

[data-theme="light"] .sb-btn.active,
[data-theme="light"] .sb-btn.bn-tab--active {
  background: rgba(91, 94, 246, 0.1);
  color: var(--accent);
  box-shadow: none;
}

[data-theme="light"] .sb-btn.active::before {
  background: linear-gradient(180deg, var(--accent-deep), var(--accent));
  box-shadow: none;
}

/* ────────────────────────────────────────────────────────────────
   TOPBAR
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .sidebar {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(24px);
  border-right: 1px solid rgba(119, 117, 135, 0.14);
  box-shadow: 2px 0 16px rgba(25, 28, 30, 0.06);
}

[data-theme="light"] .tb-icon,
[data-theme="light"] .tb-icon-sm {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.08);
  color: var(--t3);
}

[data-theme="light"] .tb-icon:hover,
[data-theme="light"] .tb-icon-sm:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

[data-theme="light"] .tb-ghost {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.1);
  color: var(--t2);
}

[data-theme="light"] .tb-ghost:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

/* ────────────────────────────────────────────────────────────────
   SETTINGS DROPDOWN MENU
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .settings-menu {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
}

[data-theme="light"] .settings-menu-item {
  color: var(--t2);
}

[data-theme="light"] .settings-menu-item:hover {
  background: rgba(15, 23, 42, 0.04);
  color: var(--t1);
}

[data-theme="light"] .settings-close-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .settings-close-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

[data-theme="light"] .settings-menu-divider {
  background: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .settings-sync-row:hover {
  background: rgba(15, 23, 42, 0.04);
}

/* ────────────────────────────────────────────────────────────────
   DASHBOARD — STAT CARDS
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-stat-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .db-stat-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(91, 94, 246, 0.15);
}

[data-theme="light"] .db-stat-card::before {
  background: linear-gradient(
    135deg,
    rgba(91, 94, 246, 0.02) 0%,
    transparent 55%
  );
}

/* ────────────────────────────────────────────────────────────────
   CHART CARD
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-chart-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .db-chart-card::before {
  background: none;
}

[data-theme="light"] .cpc-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .cpc-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t2);
}

[data-theme="light"] .cpc-btn--active {
  background: rgba(91, 94, 246, 0.08) !important;
  border-color: rgba(91, 94, 246, 0.2) !important;
  color: var(--accent) !important;
}

/* ────────────────────────────────────────────────────────────────
   GENERIC PANELS
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-panel {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .db-panel:hover {
  box-shadow: var(--shadow-md);
}

[data-theme="light"] .db-panel::before {
  background: none;
}

/* ────────────────────────────────────────────────────────────────
   LEGACY .card (used by Insights, txn panels)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .card:hover {
  box-shadow: var(--shadow-md);
}

[data-theme="light"] .card::before {
  background: none;
}

[data-theme="light"] .card-menu-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .card-menu-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

/* ────────────────────────────────────────────────────────────────
   DASHBOARD — PILLS
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-pill {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t2);
}

[data-theme="light"] .db-pill:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

[data-theme="light"] .db-pill.active {
  background: rgba(91, 94, 246, 0.08);
  border-color: rgba(91, 94, 246, 0.22);
  color: var(--accent);
}

/* ────────────────────────────────────────────────────────────────
   MY CARD PANEL (right column)
   Keep the gradient card itself dark (it's a debit card visual),
   but theme the surrounding panel.
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-card-panel {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.07) !important;
  box-shadow: var(--shadow-md) !important;
}

[data-theme="light"] .set-budgets-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .set-budgets-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

/* Transaction rows within right panel */
[data-theme="light"] .rp-txn-row {
  border-bottom-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .rp-txn-row:hover {
  background: rgba(15, 23, 42, 0.03);
}

[data-theme="light"] .cs-flip-arrow,
[data-theme="light"] .cs-flip-arrow--prev,
[data-theme="light"] .cs-flip-arrow--next,
[data-theme="light"] button.cs-flip-arrow {
  color: rgba(255, 255, 255, 0.85) !important;
  background: rgba(0, 0, 0, 0.18) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

[data-theme="light"] .cs-flip-arrow:hover,
[data-theme="light"] .cs-flip-arrow--prev:hover,
[data-theme="light"] .cs-flip-arrow--next:hover,
[data-theme="light"] button.cs-flip-arrow:hover {
  background: rgba(0, 0, 0, 0.28) !important;
  color: #ffffff !important;
}

/* ────────────────────────────────────────────────────────────────
   EXPENSE CATEGORY LIST
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .expense-categories li:hover {
  background: rgba(15, 23, 42, 0.03);
}

/* ────────────────────────────────────────────────────────────────
   INSIGHTS CARD — Fix the harsh dark background
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .insights-card {
  background: #f8f9fb !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* Individual insight bento cards */
[data-theme="light"] .insight-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .insights-grid .insight-card:first-child {
  background: linear-gradient(
    135deg,
    rgba(244, 63, 94, 0.05) 0%,
    rgba(244, 63, 94, 0.02) 100%
  );
  border-color: rgba(244, 63, 94, 0.14);
}

[data-theme="light"] .insights-badge {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.08);
  color: var(--t3);
}

[data-theme="light"] .ai-insights-btn {
  background: rgba(91, 94, 246, 0.07);
  border-color: rgba(91, 94, 246, 0.18);
  color: var(--accent-deep);
  box-shadow: none;
}

[data-theme="light"] .ai-insights-btn:hover {
  background: rgba(91, 94, 246, 0.12);
  border-color: rgba(91, 94, 246, 0.28);
  box-shadow: none;
}

/* Month-end prediction bar area */
[data-theme="light"] .ai-prediction-section,
[data-theme="light"] .insights-prediction {
  background: rgba(15, 23, 42, 0.03);
  border-color: rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .ai-alert-item {
  background: rgba(245, 158, 11, 0.05);
  border-color: rgba(245, 158, 11, 0.14);
}

[data-theme="light"] .ai-tip-card {
  background: rgba(15, 23, 42, 0.03);
  border-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .ai-tip-card:hover {
  background: rgba(15, 23, 42, 0.05);
}

[data-theme="light"] .ai-refresh-btn,
[data-theme="light"] .ai-dismiss-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t2);
}

[data-theme="light"] .ai-refresh-btn:hover {
  background: rgba(91, 94, 246, 0.08);
  border-color: rgba(91, 94, 246, 0.2);
  color: var(--accent-deep);
}

[data-theme="light"] .ai-dismiss-btn:hover {
  background: rgba(239, 68, 68, 0.06);
  border-color: rgba(239, 68, 68, 0.18);
  color: #dc2626;
}

[data-theme="light"] .ai-insights-panel {
  background: rgba(91, 94, 246, 0.04);
  border-color: rgba(91, 94, 246, 0.12);
}

[data-theme="light"] #anomalyAlerts .anomaly-alert {
  background: rgba(239, 68, 68, 0.04);
  border-color: rgba(239, 68, 68, 0.12);
  color: #dc2626;
}

[data-theme="light"] #anomalyAlerts .anomaly-alert i {
  color: #dc2626;
}

/* ────────────────────────────────────────────────────────────────
   TRANSACTION SEARCH & TABLE
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .search-wrapper {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .search-wrapper:focus-within {
  background: #ffffff;
  border-color: rgba(91, 94, 246, 0.28);
  box-shadow: 0 0 0 3px rgba(91, 94, 246, 0.07);
}

[data-theme="light"] .txn-count-badge {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .filter-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .filter-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

[data-theme="light"] .transaction-table thead th {
  color: var(--t3);
  border-bottom-color: rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .transaction-table tbody tr {
  border-bottom-color: rgba(15, 23, 42, 0.05);
}

[data-theme="light"] .transaction-table tbody tr:hover {
  background: rgba(15, 23, 42, 0.025);
}

[data-theme="light"] .transaction-table tbody td {
  color: var(--t2);
}

/* ────────────────────────────────────────────────────────────────
   FULL TRANSACTION PAGE (#txnFullPage)
   Currently has a hardcoded dark background — fix it.
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] #txnFullPage {
  background: var(--bg);
}

[data-theme="light"] .txn-page-header {
  background: rgba(255, 255, 255, 0.9);
  border-bottom-color: rgba(15, 23, 42, 0.07);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05);
}

[data-theme="light"] .txn-page-close {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .txn-page-close:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

[data-theme="light"] .txn-month-label {
  border-bottom-color: rgba(15, 23, 42, 0.07);
  color: var(--t3);
}

[data-theme="light"] .txn-full-row:hover {
  background: rgba(15, 23, 42, 0.025);
}

/* ────────────────────────────────────────────────────────────────
   MODALS — Core surfaces (Add Income, Add Expense, etc.)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .modal {
  background: rgba(15, 23, 42, 0.35);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

[data-theme="light"] .modal-content {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
}

[data-theme="light"] .modal-content::before {
  background: none;
}

[data-theme="light"] .modal-header {
  border-bottom-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .close-btn {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .close-btn:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

/* Form inputs inside modals */
[data-theme="light"] .form-input,
[data-theme="light"] .form-select {
  background: #f2f4f6;
  border: 1px solid rgba(119, 117, 135, 0.22);
  color: #191c1e;
}

[data-theme="light"] .form-input:focus,
[data-theme="light"] .form-select:focus {
  background: #ffffff;
  border-color: rgba(91, 94, 246, 0.3);
  box-shadow: 0 0 0 3px rgba(91, 94, 246, 0.07);
}

[data-theme="light"] select.form-input option,
[data-theme="light"] .form-select option {
  background: #ffffff;
  color: var(--t1);
}

/* Card selector widget in modals (Axis / Switch row) */
[data-theme="light"] .card-selector,
[data-theme="light"] .modal-card-row,
[data-theme="light"] [class*="card-select"],
[data-theme="light"] [class*="switch-card"] {
  background: #f3f4f6;
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t2);
}

/* Secondary button in modals */
[data-theme="light"] .btn-secondary {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.12);
  color: var(--t2);
}

[data-theme="light"] .btn-secondary:hover {
  background: rgba(15, 23, 42, 0.08);
  color: var(--t1);
}

/* ────────────────────────────────────────────────────────────────
   SETTINGS MODAL (blsm — BlueLedger Settings Modal)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .blsm {
  background: rgba(15, 23, 42, 0.3);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

[data-theme="light"] .blsm-content {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
  scrollbar-color: rgba(15, 23, 42, 0.15) transparent;
}

[data-theme="light"] .blcurr-list,
[data-theme="light"] .blfaq-list {
  border-color: rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .blcurr-item,
[data-theme="light"] .blfaq-item {
  border-top-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .blcurr-item:hover,
[data-theme="light"] .blfaq-q:hover {
  background: rgba(15, 23, 42, 0.03);
}

[data-theme="light"] .blcurr-item--active {
  background: rgba(91, 94, 246, 0.05);
}

[data-theme="light"] .bltheme-item {
  background: rgba(15, 23, 42, 0.03);
  border-color: rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .bltheme-item:hover {
  background: rgba(15, 23, 42, 0.05);
  border-color: rgba(91, 94, 246, 0.18);
}

[data-theme="light"] .bltheme-item--active {
  background: rgba(91, 94, 246, 0.06);
  border-color: rgba(91, 94, 246, 0.3);
  box-shadow: 0 0 0 1px rgba(91, 94, 246, 0.12) inset;
}

[data-theme="light"] .bltheme-icon {
  background: rgba(15, 23, 42, 0.05);
  color: var(--t2);
}

[data-theme="light"] .bltheme-item--active .bltheme-icon {
  background: rgba(91, 94, 246, 0.1);
  color: var(--accent);
}

[data-theme="light"] .bltheme-label {
  color: var(--t2);
}

[data-theme="light"] .bltheme-item--active .bltheme-label {
  color: var(--accent-deep);
}

[data-theme="light"] .blexport-btn {
  background: rgba(15, 23, 42, 0.03);
  border-color: rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .blexport-btn:hover {
  background: rgba(15, 23, 42, 0.06);
  border-color: rgba(15, 23, 42, 0.14);
  transform: translateY(-1px);
}

[data-theme="light"] .blfaq-a {
  border-top-color: rgba(15, 23, 42, 0.06);
  color: var(--t3);
}

[data-theme="light"] .blabout-row {
  border-bottom-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .blcurr-sym {
  background: rgba(91, 94, 246, 0.08);
  color: var(--accent-deep);
}

/* ────────────────────────────────────────────────────────────────
   SETTINGS PAGE (full-screen overlay)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .settings-page,
[data-theme="light"] #settingsPage {
  background: var(--bg);
}

[data-theme="light"] .settings-page-header,
[data-theme="light"] #settingsPage .page-header {
  background: rgba(255, 255, 255, 0.9);
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05);
}

[data-theme="light"] .settings-section-card,
[data-theme="light"] .settings-group-card,
[data-theme="light"] .settings-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--shadow-sm);
}

[data-theme="light"] .settings-row,
[data-theme="light"] .settings-item {
  border-bottom-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .settings-row:hover,
[data-theme="light"] .settings-item:hover {
  background: rgba(15, 23, 42, 0.02);
}

[data-theme="light"] .settings-section-label,
[data-theme="light"] .settings-label-group {
  color: var(--t3);
}

/* ────────────────────────────────────────────────────────────────
   MONTHLY REPORT MODAL
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .report-modal-content,
[data-theme="light"] [class*="monthly-report"] .modal-content,
[data-theme="light"] #monthlyReportModal .modal-content {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
}

[data-theme="light"] .report-stat-cell,
[data-theme="light"] [class*="report-stat"] {
  background: #f8f9fb;
  border: 1px solid rgba(15, 23, 42, 0.07);
}

/* Donut chart modal overlay */
[data-theme="light"] .donut-modal,
[data-theme="light"] [class*="donut-overlay"] {
  background: rgba(15, 23, 42, 0.3);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Monthly report modal — text fixes */
[data-theme="light"] .report-stat-cell .pv-label,
[data-theme="light"] [class*="report"] .form-label,
[data-theme="light"] #monthlyReportModal .dsc-label,
[data-theme="light"] #monthlyReportModal [class*="label"],
[data-theme="light"] #monthlyReportModal [class*="-label"] {
  color: #334155 !important;
}

[data-theme="light"] #monthlyReportModal [class*="value"],
[data-theme="light"] #monthlyReportModal [class*="-val"],
[data-theme="light"] #monthlyReportModal p,
[data-theme="light"] #monthlyReportModal span {
  color: #0f172a !important;
}

/* Expense breakdown legend text */
[data-theme="light"] .expense-breakdown-label,
[data-theme="light"] [class*="breakdown"] span,
[data-theme="light"] [class*="legend"] span,
[data-theme="light"] .dcc-legend span {
  color: #334155 !important;
}

/* ────────────────────────────────────────────────────────────────
   ASK BLUELEDGER PANEL
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .ask-bl-overlay {
  background: rgba(15, 23, 42, 0.25);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

[data-theme="light"] .ask-bl-panel {
  background: rgba(255, 255, 255, 0.97);
  border: 1px solid rgba(15, 23, 42, 0.09);
  border-left-color: rgba(91, 94, 246, 0.14);
  box-shadow:
    -4px 0 32px rgba(15, 23, 42, 0.1),
    0 -4px 20px rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .ask-bl-header {
  background: rgba(248, 249, 251, 0.9);
  border-bottom-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .ask-bl-close {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t3);
}

[data-theme="light"] .ask-bl-chip {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.09);
  color: var(--t2);
}

[data-theme="light"] .ask-bl-chip:hover {
  background: rgba(91, 94, 246, 0.07);
  border-color: rgba(91, 94, 246, 0.2);
  color: var(--accent-deep);
}

[data-theme="light"] .ask-bl-input-row {
  background: rgba(248, 249, 251, 0.95);
  border-top-color: rgba(15, 23, 42, 0.07);
}

[data-theme="light"] .ask-bl-input {
  background: #f3f4f6;
  border-color: rgba(15, 23, 42, 0.1);
  color: var(--t1);
}

[data-theme="light"] .ask-bl-input:focus {
  background: #ffffff;
  border-color: rgba(91, 94, 246, 0.28);
  box-shadow: 0 0 0 3px rgba(91, 94, 246, 0.06);
}

/* ────────────────────────────────────────────────────────────────
   BN NAVIGATION SHEET (bottom mobile sheet)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .bn-sheet {
  background: #ffffff;
  border-top: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: 0 -4px 24px rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .bn-sheet-btn {
  color: var(--t2);
}

[data-theme="light"] .bn-sheet-btn:hover {
  background: rgba(15, 23, 42, 0.04);
  color: var(--t1);
}

[data-theme="light"] .bn-settings-panel {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
}

[data-theme="light"] .bn-settings-row:hover {
  background: rgba(15, 23, 42, 0.04);
  color: var(--t1);
}

[data-theme="light"] .bn-settings-danger {
  color: #dc2626;
}

[data-theme="light"] .bn-settings-danger:hover {
  color: #b91c1c;
}

/* ────────────────────────────────────────────────────────────────
   PROGRESS BAR (card spending)
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .progress-bar {
  background: rgba(15, 23, 42, 0.08);
}

/* ────────────────────────────────────────────────────────────────
   CHART — Grid lines, tooltips (Recharts / Chart.js canvas)
   These target injected styles or wrapper classes.
   ──────────────────────────────────────────────────────────────── */

/* Chart tooltip box */
[data-theme="light"] .chart-tooltip,
[data-theme="light"] .recharts-tooltip-wrapper .recharts-default-tooltip,
[data-theme="light"] [class*="chartjs-tooltip"] {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.1) !important;
  box-shadow: var(--shadow-md) !important;
  color: var(--t1) !important;
  border-radius: 10px !important;
}

/* Recharts axis text */
[data-theme="light"] .recharts-cartesian-axis-tick text,
[data-theme="light"] .recharts-text {
  fill: var(--t3) !important;
}

/* Recharts grid lines */
[data-theme="light"] .recharts-cartesian-grid line {
  stroke: rgba(15, 23, 42, 0.06) !important;
}

/* ────────────────────────────────────────────────────────────────
   SCROLLBARS — Light-themed thin scrollbars
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .db-body {
  scrollbar-color: rgba(15, 23, 42, 0.15) transparent;
}

[data-theme="light"] .db-body::-webkit-scrollbar-thumb {
  background: rgba(15, 23, 42, 0.15);
}

[data-theme="light"] .txn-page-body {
  scrollbar-color: rgba(15, 23, 42, 0.15) transparent;
}

[data-theme="light"] .ask-bl-messages {
  scrollbar-color: rgba(15, 23, 42, 0.12) transparent;
}

[data-theme="light"] .blsm-content {
  scrollbar-color: rgba(15, 23, 42, 0.12) transparent;
}

/* ────────────────────────────────────────────────────────────────
   LOCK SCREEN — Keep card light, darken the backdrop slightly
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .lock-screen-overlay,
[data-theme="light"] #lockScreen {
  background: #f3f4f6;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

[data-theme="light"] .lock-card,
[data-theme="light"] .lock-content {
  background: #f8f9fb;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
}

/* ────────────────────────────────────────────────────────────────
   FILTER BUTTONS active state
   ──────────────────────────────────────────────────────────────── */

[data-theme="light"] .filter-btn.active,
[data-theme="light"] .filter-btn--active {
  background: rgba(91, 94, 246, 0.08);
  border-color: rgba(91, 94, 246, 0.22);
  color: var(--accent-deep);
}

/* Tab-style filters in Transaction page header */
[data-theme="light"] .txn-filter-tab {
  color: var(--t3);
  border-color: rgba(15, 23, 42, 0.09);
  background: rgba(15, 23, 42, 0.04);
}

[data-theme="light"] .txn-filter-tab.active,
[data-theme="light"] .txn-filter-tab--active {
  background: rgba(91, 94, 246, 0.08);
  border-color: rgba(91, 94, 246, 0.22);
  color: var(--accent-deep);
}

/* ────────────────────────────────────────────────────────────────
   GENERIC: Any element that still hardcodes dark backgrounds
   Catch-all for components that embed inline or JS-injected styles.
   ──────────────────────────────────────────────────────────────── */

/* Injected dropdown / picker panels */
[data-theme="light"] .dropdown-panel,
[data-theme="light"] [class*="dropdown-content"],
[data-theme="light"] [class*="picker-panel"] {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
  color: var(--t1);
}

/* Month picker nav */
[data-theme="light"] .month-picker-modal,
[data-theme="light"] [class*="month-picker"] {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.09);
  box-shadow: var(--shadow-xl);
}

/* Generic overlay backgrounds */
[data-theme="light"]
  [class*="-overlay"]:not(.blsm):not(.modal):not(.ask-bl-overlay):not(
    .lock-screen-overlay
  ) {
  background: rgba(15, 23, 42, 0.28);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* ═══════════════════════════════════════════════════════════════
   END OF LIGHT MODE REFINEMENT
   ════════════════════════════════════*/

/* ─────────────────────────────────────────────────────────────
   TRANSACTION PAGE: Premium dark-mode background
   ───────────────────────────────────────────────────────────── */

/* Replace the flat #0e1117 with a layered deep-navy surface */
#txnFullPage {
  background:
    radial-gradient(
      ellipse 80% 40% at 15% 0%,
      rgba(59, 91, 219, 0.07) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 60% 35% at 90% 100%,
      rgba(79, 110, 247, 0.05) 0%,
      transparent 55%
    ),
    linear-gradient(180deg, #090b17 0%, #0b0d1e 40%, #080a15 100%);
}

/* Header — semi-frosted so it reads as a separate layer */
.txn-page-header {
  background: rgba(10, 11, 22, 0.82) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.055) !important;
  box-shadow: 0 1px 0 rgba(79, 110, 247, 0.06) !important;
}

/* Month section label — slightly elevated strip */
.txn-month-label {
  font-size: 0.68rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  color: rgba(79, 110, 247, 0.55) !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
  padding-bottom: 0.55rem !important;
  margin-bottom: 0.2rem !important;
}

/* Individual transaction rows — subtle elevated cards */
.txn-full-row {
  border-radius: 12px !important;
  padding: 0.7rem 0.85rem !important;
  transition:
    background 0.16s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease !important;
  position: relative;
}

.txn-full-row:hover {
  background: rgba(255, 255, 255, 0.038) !important;
  transform: translateX(2px) !important;
  box-shadow: inset 3px 0 0 rgba(79, 110, 247, 0.25) !important;
}

/* Description text — stronger presence */
.txn-full-desc {
  font-weight: 600 !important;
  color: rgba(240, 244, 255, 0.9) !important;
}

/* Category text — softer muted */
.txn-full-cat {
  color: rgba(136, 146, 176, 0.7) !important;
}

/* Date column — de-emphasised */
.txn-full-date {
  color: rgba(100, 116, 139, 0.75) !important;
}

/* Account column */
.txn-full-account {
  color: rgba(100, 116, 139, 0.65) !important;
}

/* Positive/negative amounts — same colour but now more vivid */
.txn-full-amt.pos {
  color: #22c55e !important;
  text-shadow: 0 0 12px rgba(34, 197, 94, 0.22);
}

.txn-full-amt.neg {
  color: #f43f5e !important;
  text-shadow: 0 0 12px rgba(244, 63, 94, 0.18);
}

/* Page body scrollbar — accent tinted */
.txn-page-body {
  scrollbar-color: rgba(79, 110, 247, 0.2) transparent !important;
}

.txn-page-body::-webkit-scrollbar-thumb {
  background: rgba(79, 110, 247, 0.2) !important;
}

/* Search wrapper inside transaction page */
[id="txnFullPage"] .search-wrapper,
[id="txnFullPage"] .txn-meta .search-wrapper {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(79, 110, 247, 0.14) !important;
}

[id="txnFullPage"] .search-wrapper:focus-within {
  background: rgba(79, 110, 247, 0.06) !important;
  border-color: rgba(79, 110, 247, 0.32) !important;
}

/* Filter chips inside transaction page */
[id="txnFullPage"] .filter-btn,
[id="txnFullPage"] .txn-filter-tab {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.07) !important;
  color: rgba(136, 146, 176, 0.85) !important;
}

/* Close button */
.txn-page-close {
  background: rgba(255, 255, 255, 0.05) !important;
  border-color: rgba(255, 255, 255, 0.09) !important;
  color: rgba(100, 116, 139, 0.85) !important;
  transition:
    background 0.17s,
    color 0.17s !important;
}

.txn-page-close:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  color: rgba(240, 244, 255, 0.95) !important;
}

/* Light mode — keep the existing #f3f4f6 but improve rows */
[data-theme="light"] #txnFullPage {
  background: var(--bg, #f3f4f6) !important;
}

[data-theme="light"] .txn-page-header {
  background: rgba(255, 255, 255, 0.92) !important;
  border-bottom-color: rgba(15, 23, 42, 0.07) !important;
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05) !important;
}

[data-theme="light"] .txn-month-label {
  color: rgba(91, 94, 246, 0.55) !important;
  border-bottom-color: rgba(15, 23, 42, 0.07) !important;
}

[data-theme="light"] .txn-full-row:hover {
  background: rgba(15, 23, 42, 0.025) !important;
  box-shadow: inset 3px 0 0 rgba(91, 94, 246, 0.18) !important;
}

[data-theme="light"] .txn-full-amt.pos {
  text-shadow: none !important;
}

[data-theme="light"] .txn-full-amt.neg {
  text-shadow: none !important;
}

/* Fix transaction page search area dark background in light mode */
[data-theme="light"] .txn-page-search-area,
[data-theme="light"] [class*="txn-page-search"],
[data-theme="light"] #txnFullPage [class*="search-area"],
[data-theme="light"] #txnFullPage [class*="search-bar"],
[data-theme="light"] #txnFullPage [class*="filter"] {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Fix invisible transaction description text in light mode */
[data-theme="light"] .txn-full-desc {
  color: #0f172a !important;
}

[data-theme="light"] .txn-full-cat {
  color: #64748b !important;
}

[data-theme="light"] .txn-full-date {
  color: #64748b !important;
}

[data-theme="light"] .txn-full-account {
  color: #94a3b8 !important;
}

/* Top spending / biggest expense values in report modal */
[data-theme="light"] .summary-stat p,
[data-theme="light"] .summary-stat span,
[data-theme="light"] .summary-stat div:not(.summary-label) {
  color: #1e293b !important;
  font-weight: 600 !important;
}

/* ─────────────────────────────────────────────────────────────
   MY CARD PANEL: Premium hover micro-interactions
   ───────────────────────────────────────────────────────────── */

/* Panel — smooth transition, subtle lift on hover */
.db-card-panel {
  transition:
    transform 0.26s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.26s ease !important;
}

.db-card-panel:hover {
  transform: translateY(-4px) !important;
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(79, 110, 247, 0.12) inset !important;
}

/* Light mode panel hover */
[data-theme="light"] .db-card-panel:hover {
  transform: translateY(-4px) !important;
  box-shadow:
    0 12px 32px rgba(15, 23, 42, 0.1),
    0 0 0 1px rgba(91, 94, 246, 0.12) inset !important;
}

/* Flip card — hover lift & glow (already has :hover but let's sharpen it) */
.cs-flip-card {
  transition:
    transform 0.24s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.24s ease !important;
}

.cs-flip-card:hover {
  transform: translateY(-6px) scale(1.012) !important;
  box-shadow:
    0 32px 72px rgba(0, 0, 0, 0.62),
    0 0 80px var(--card-accent-glow, rgba(79, 110, 247, 0.22)) !important;
}

/* Navigation arrows — more visible and tactile */
.cs-flip-arrow {
  transition:
    background 0.18s,
    border-color 0.18s,
    color 0.18s,
    transform 0.18s !important;
}

.cs-flip-arrow:hover {
  background: rgba(79, 110, 247, 0.14) !important;
  border-color: rgba(79, 110, 247, 0.3) !important;
  color: rgba(255, 255, 255, 0.9) !important;
  transform: scale(1.1) !important;
}

.cs-flip-arrow:active {
  transform: scale(0.92) !important;
}

/* Light-mode arrows — dark tinted so they're visible on white panel bg */
[data-theme="light"] .cs-flip-arrow {
  background: rgba(0, 0, 0, 0.12) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: rgba(255, 255, 255, 0.8) !important;
}

[data-theme="light"] .cs-flip-arrow:hover {
  background: rgba(0, 0, 0, 0.24) !important;
  color: #ffffff !important;
  transform: scale(1.1) !important;
}

/* Dots — smoother active pill expansion */
.cs-dot {
  transition:
    background 0.22s ease,
    width 0.22s ease,
    transform 0.22s ease !important;
}

.cs-dot:hover:not(.is-active) {
  background: rgba(255, 255, 255, 0.42) !important;
  transform: scale(1.25) !important;
}

/* Add Card button — more tactile */
.card-action-add {
  transition:
    background 0.2s,
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.2s !important;
}

.card-action-add:hover {
  background: rgba(79, 110, 247, 0.16) !important;
  border-color: rgba(79, 110, 247, 0.38) !important;
  box-shadow: 0 4px 18px rgba(79, 110, 247, 0.16) !important;
  color: #93b4ff !important;
  transform: translateY(-2px) !important;
}

.card-action-add:active {
  transform: scale(0.97) translateY(0) !important;
}

/* Remove button */
.card-action-remove {
  transition:
    background 0.2s,
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.2s !important;
}

.card-action-remove:hover {
  background: rgba(239, 68, 68, 0.14) !important;
  border-color: rgba(239, 68, 68, 0.32) !important;
  box-shadow: 0 4px 18px rgba(239, 68, 68, 0.1) !important;
  color: #fca5a5 !important;
  transform: translateY(-2px) !important;
}

.card-action-remove:active {
  transform: scale(0.97) translateY(0) !important;
}

/* Light mode button overrides — keep readable contrast */
[data-theme="light"] .card-action-add:hover {
  background: rgba(79, 110, 247, 0.12) !important;
  box-shadow: 0 4px 14px rgba(79, 110, 247, 0.12) !important;
  color: #4338ca !important;
}

[data-theme="light"] .card-action-remove:hover {
  background: rgba(239, 68, 68, 0.1) !important;
  box-shadow: 0 4px 14px rgba(239, 68, 68, 0.08) !important;
  color: #b91c1c !important;
}

/* Card action row separator — slightly more visible in dark */
.card-action-row {
  border-top-color: rgba(255, 255, 255, 0.07) !important;
}

[data-theme="light"] .card-action-row {
  border-top-color: rgba(15, 23, 42, 0.08) !important;
}

/* ─────────────────────────────────────────────────────────────
   MONTHLY REPORT MODAL: Light-mode readability
   ───────────────────────────────────────────────────────────── */

/* ── Summary stat cells (Total Income, Total Expenses, etc.) ── */

[data-theme="light"] .summary-stat,
[data-theme="light"] .inline-report-stat {
  background: #f8f9fb !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
}

[data-theme="light"] .summary-label,
[data-theme="light"] .inline-report-label {
  color: #475569 !important; /* visible slate, not washed-out */
  font-weight: 700 !important;
}

[data-theme="light"] .summary-value,
[data-theme="light"] .inline-report-value {
  color: #0f172a !important;
  font-weight: 800 !important;
}

/* ── "Top Spending Category" & "Biggest Single Expense" ── */

/* These come from the modal's summary-grid or equivalent cells */
[data-theme="light"] .modal-content .summary-stat .summary-label,
[data-theme="light"] #monthlyReportModal .summary-label,
[data-theme="light"] [class*="report"] .summary-label,
[data-theme="light"] [class*="report"] .pv-label,
[data-theme="light"] [class*="report"] .dsc-label {
  color: #475569 !important;
  letter-spacing: 0.05em !important;
}

/* Values inside those cells — investment name, expense name */
[data-theme="light"] #monthlyReportModal .summary-value,
[data-theme="light"] [class*="report"] .summary-value,
[data-theme="light"] [class*="report"] .pv-value {
  color: #1e293b !important;
  font-weight: 700 !important;
}

/* ── "EXPENSE BREAKDOWN" heading ── */
[data-theme="light"] #monthlyReportModal [class*="breakdown"],
[data-theme="light"] [class*="report"] [class*="breakdown-title"],
[data-theme="light"] [class*="report"] [class*="section-title"],
[data-theme="light"] [class*="report"] .sf-section-title {
  color: #334155 !important;
  font-weight: 800 !important;
}

/* ── Legend items (Investment · Transport · Food …) ── */
[data-theme="light"] .dcc-legend span,
[data-theme="light"] [class*="legend"] span,
[data-theme="light"] #monthlyReportModal .dcc-legend,
[data-theme="light"] [class*="report"] [class*="legend"] {
  color: #334155 !important;
  font-weight: 600 !important;
}

/* ── Category breakdown rows ── */
[data-theme="light"] .cat-name,
[data-theme="light"] .irc-name {
  color: #334155 !important;
  font-weight: 600 !important;
}

[data-theme="light"] .cat-pct {
  color: #64748b !important;
}

[data-theme="light"] .cat-amt {
  color: #0f172a !important;
  font-weight: 700 !important;
}

[data-theme="light"] .cat-row {
  border-bottom-color: rgba(15, 23, 42, 0.06) !important;
}

/* ── Report modal header / close button ── */
[data-theme="light"] #monthlyReportModal .modal-header {
  border-bottom-color: rgba(15, 23, 42, 0.08) !important;
}

/* ── Month nav buttons (< May 2026 >) ── */
[data-theme="light"] .summary-month-btn,
[data-theme="light"] .mp-nav-btn {
  background: rgba(15, 23, 42, 0.05) !important;
  border-color: rgba(15, 23, 42, 0.1) !important;
  color: #334155 !important;
}

[data-theme="light"] .summary-month-btn:hover,
[data-theme="light"] .mp-nav-btn:hover {
  background: rgba(15, 23, 42, 0.09) !important;
  color: #0f172a !important;
}

[data-theme="light"] .summary-month-title,
[data-theme="light"] .mp-year {
  color: #0f172a !important;
}

/* ── Month picker buttons ── */
[data-theme="light"] .mp-month-btn {
  background: rgba(15, 23, 42, 0.04) !important;
  border-color: rgba(15, 23, 42, 0.09) !important;
  color: #334155 !important;
}

[data-theme="light"] .mp-month-btn:hover {
  background: rgba(15, 23, 42, 0.08) !important;
  color: #0f172a !important;
}

[data-theme="light"] .mp-month-btn.mp-selected {
  background: rgba(91, 94, 246, 0.08) !important;
  border-color: rgba(91, 94, 246, 0.24) !important;
  color: #4338ca !important;
}

/* ── Donut chart — remove segment borders ── */
/* borderWidth must be set to 0 in JS chart config (see note below).
   These CSS rules handle the wrapper/border fallbacks. */
[data-theme="light"] canvas {
  border: none !important;
  outline: none !important;
}

/* ── Color bar (category strip) ── */
[data-theme="light"] .color-bar {
  opacity: 0.85 !important;
}

/* ── Full report view-all button ── */
[data-theme="light"] .inline-report-full-btn {
  background: rgba(91, 94, 246, 0.06) !important;
  border-color: rgba(91, 94, 246, 0.18) !important;
  color: #4338ca !important;
}

[data-theme="light"] .inline-report-full-btn:hover {
  background: rgba(91, 94, 246, 0.12) !important;
  border-color: rgba(91, 94, 246, 0.32) !important;
  box-shadow: 0 4px 12px rgba(91, 94, 246, 0.1) !important;
}

/* ── Inline report stat cards ── */
[data-theme="light"] .inline-report-stat {
  background: #ffffff !important;
  border-color: rgba(15, 23, 42, 0.08) !important;
}

[data-theme="light"] .inline-report-stat:hover {
  background: #f8f9fb !important;
}

[data-theme="light"] .irc-amount {
  color: #f43f5e !important;
  font-weight: 700 !important;
}

/* ═══════════════════════════════════════════════════════════════
   END OF POLISH PACK
   ═══════════════════════════════════════════════════════════════ */

/* ══ Add Transaction Modal Redesign ══════════════════════════ */

.add-txn-modal {
  border-radius: 20px !important;
  overflow: hidden !important;
  padding: 0 !important;
}

.add-txn-modal .modal-header {
  border-bottom: none !important;
}

.add-txn-modal .modal-title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

.add-txn-modal .modal-body {
  padding: 1.25rem 1.4rem !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.85rem !important;
}

.add-txn-modal .modal-footer {
  display: flex !important;
  gap: 0.75rem !important;
  border-top: 1px solid var(--border) !important;
  padding: 1rem 1.4rem !important;
  background: transparent !important;
}

.add-txn-modal .modal-footer .btn {
  flex: 1 !important;
  justify-content: center !important;
  border-radius: 12px !important;
  padding: 0.75rem !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
}

/* Account row pill */
.add-txn-account-row {
  background: var(--bg-card-hi) !important;
  border: 1px solid var(--border-md) !important;
  border-radius: 12px !important;
  padding: 0.65rem 1rem !important;
}

/* Labels uppercase */
.add-txn-modal .form-label {
  font-size: 0.7rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  margin-bottom: 0.4rem !important;
  color: var(--t3) !important;
}

/* Inputs */
.add-txn-modal .form-input,
.add-txn-modal .form-select {
  border-radius: 10px !important;
  background: var(--bg-card-hi) !important;
  border: 1px solid var(--border-md) !important;
  padding: 0.7rem 0.9rem !important;
  font-size: 0.88rem !important;
  color: var(--t1) !important;
  transition: border-color 0.15s !important;
}

.add-txn-modal .form-input:focus,
.add-txn-modal .form-select:focus {
  border-color: var(--accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

/* Textarea notes */
.add-txn-modal textarea.form-input {
  resize: none !important;
  line-height: 1.55 !important;
  min-height: 90px !important;
}

/* Amount input larger */
.add-txn-modal #incomeAmount,
.add-txn-modal #expenseAmount {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

/* Close button */
.add-txn-modal .close-btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  border: 1px solid var(--border-md) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--t3) !important;
  font-size: 1.1rem !important;
  background: transparent !important;
  transition: all 0.15s !important;
}

.add-txn-modal .close-btn:hover {
  background: var(--bg-card-hi) !important;
  color: var(--t1) !important;
}

/* ── AI Suggestion Badge — redesigned ─────────────────────── */
.ai-cat-badge {
  margin-top: 0.4rem;
  padding: 0.3rem 0.55rem 0.3rem 0.45rem;
  border-radius: 8px;
  background: rgba(139, 92, 246, 0.08);
  border: 1px solid rgba(139, 92, 246, 0.2);
  font-size: 0.73rem;
  color: #c4b5fd;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  animation: ai-badge-in 0.2s ease;
}

@keyframes ai-badge-in {
  from {
    opacity: 0;
    transform: translateY(-3px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.ai-cat-badge .ai-badge-icon {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  background: rgba(139, 92, 246, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.65rem;
}

.ai-cat-badge .ai-badge-text {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ai-cat-badge .ai-badge-text strong {
  color: #e2e8f0;
  font-weight: 700;
}

.ai-cat-badge .ai-badge-status {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.68rem;
  white-space: nowrap;
}

.ai-cat-badge .ai-badge-status.pending {
  color: #f59e0b;
}

.ai-cat-badge .ai-badge-status.applied {
  color: #22c55e;
  font-weight: 600;
}

.ai-cat-apply {
  padding: 0.15rem 0.45rem;
  border-radius: 5px;
  background: rgba(139, 92, 246, 0.25);
  border: 1px solid rgba(139, 92, 246, 0.35);
  color: #c4b5fd;
  font-size: 0.68rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
  font-family: inherit;
}
.ai-cat-apply:hover {
  background: rgba(139, 92, 246, 0.38);
}

.ai-cat-dismiss {
  background: none;
  border: none;
  color: #475569;
  cursor: pointer;
  padding: 0.1rem 0.2rem;
  font-size: 0.65rem;
  border-radius: 4px;
  flex-shrink: 0;
  transition: color 0.15s;
  font-family: inherit;
}
.ai-cat-dismiss:hover {
  color: #94a3b8;
}

/* remove old form-hint (no longer needed) */
.form-hint {
  display: none !important;
}

/* ══  5 tabs, proper FAB center ══════════════ */
.bottom-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-around !important;
  padding: 0 8px !important;
  height: 62px !important;
  gap: 0 !important;
}

.bn-tab {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  font-size: 0.6rem !important;
  font-weight: 500 !important;
  color: var(--t4) !important;
  min-height: 44px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 6px 0 !important;
  letter-spacing: 0.01em !important;
}

.bn-tab i {
  font-size: 1.1rem !important;
  line-height: 1 !important;
}

.bn-tab.bn-tab--active {
  color: #4f6ef7 !important;
}

/* FAB center tab — no flex stretch */
.bn-tab.bn-tab--fab {
  flex: 0 0 72px !important;
}

.bn-add-ring {
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  background: #4f6ef7 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.15rem !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(79, 110, 247, 0.32) !important;
  margin-bottom: 2px !important;
  transition:
    transform 0.18s cubic-bezier(0.34, 1.3, 0.64, 1),
    box-shadow 0.18s !important;
}

.bn-add-ring:hover,
.bn-tab.bn-tab--fab:hover .bn-add-ring {
  transform: scale(1.07) !important;
  box-shadow: 0 6px 22px rgba(79, 110, 247, 0.42) !important;
}

.bn-tab.bn-tab--fab span {
  font-size: 0.58rem !important;
  color: var(--t4) !important;
}

/* ══ Recent Transactions — home screen inline card ══════════ */
.db-recent-card {
  background: #161b22;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  overflow: hidden;
  margin-top: 10px;
}

.db-recent-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.db-recent-title {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--t1);
  letter-spacing: -0.01em;
}

.db-recent-all {
  font-size: 0.68rem;
  font-weight: 500;
  color: #4f6ef7;
  opacity: 0.7;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.db-recent-all:hover {
  opacity: 1;
}

.db-recent-list {
  display: flex;
  flex-direction: column;
}

.db-recent-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  transition: background 0.12s;
}
.db-recent-row:last-child {
  border-bottom: none;
}
.db-recent-row:hover {
  background: rgba(255, 255, 255, 0.02);
}

.db-recent-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  flex-shrink: 0;
}

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

.db-recent-desc {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: capitalize;
}

.db-recent-meta {
  font-size: 0.62rem;
  color: var(--t3);
  margin-top: 2px;
}

.db-recent-amt {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  flex-shrink: 0;
  font-family: "Outfit", sans-serif;
}

.db-recent-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 28px 16px;
  color: var(--t4);
  font-size: 0.75rem;
}
.db-recent-empty i {
  font-size: 1.2rem;
}

@media (min-width: 768px) {
  #dbRecentCard {
    display: none !important;
  }
}

/* Light mode */
[data-theme="light"] .db-recent-card {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.07);
}
[data-theme="light"] .db-recent-hdr {
  border-bottom-color: rgba(15, 23, 42, 0.06);
}
[data-theme="light"] .db-recent-row {
  border-bottom-color: rgba(15, 23, 42, 0.05);
}
[data-theme="light"] .db-recent-row:hover {
  background: rgba(15, 23, 42, 0.02);
}
/* ═══════════════════════════════════════════════════════════════
   BlueLedger — Premium Fintech Glass System OVERRIDES
   Matches reference design from screenshots exactly.
   Load AFTER style.css  OR  prepend as :root override block.
   ═══════════════════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap");

/* ─────────────────────────────────────────────────────────────
   1. DESIGN TOKENS — replaces the existing :root block
   ─────────────────────────────────────────────────────────────*/
:root:not([data-theme="light"]) {
  /* Core surfaces */
  --bg: #0b1326;
  --bg2: #0f1a30;
  --bg3: #131b2e;
  --bg-card: rgba(30, 41, 59, 0.5);
  --bg-card-hi: rgba(34, 42, 61, 0.7);
  --bg-surface: #060e20;

  /* Text */
  --t1: #dae2fd;
  --t2: #c4c5d7;
  --t3: #8e90a0;
  --t4: rgba(218, 226, 253, 0.16);

  /* Borders */
  --border: rgba(255, 255, 255, 0.1);
  --border-md: rgba(255, 255, 255, 0.15);
  --border-hi: rgba(255, 255, 255, 0.25);

  /* Brand accents */
  --accent: #b9c3ff; /* primary */
  --accent-deep: #6e88ff; /* primary-container */
  --accent-dim: rgba(110, 136, 255, 0.1);
  --accent-glow: rgba(79, 110, 247, 0.18);

  --inc: #4edea3; /* secondary */
  --inc-dim: rgba(78, 222, 163, 0.1);

  --exp: #ffb4ab; /* error */
  --exp-dim: rgba(255, 180, 171, 0.1);

  --tertiary: #d2bbff;

  /* Glass surfaces */
  --glass: rgba(30, 41, 59, 0.5);
  --glass-blur: 24px;

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.45);
  --shadow-md:
    0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 20px 48px rgba(0, 0, 0, 0.55);
  --shadow-xl: 0 28px 72px rgba(0, 0, 0, 0.64);
  --glow-accent: 0 0 48px rgba(110, 136, 255, 0.1);

  /* Radius */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;

  /* Spacing */
  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;

  /* Sidebar width */
  --sidebar-w: 280px;
}

/* Light mode keeps existing approach — no changes needed */

/* ─────────────────────────────────────────────────────────────
   2. BASE
   ─────────────────────────────────────────────────────────────*/
body {
  font-family: "Inter", system-ui, sans-serif !important;
  background: var(--bg) !important;
  color: var(--t1) !important;
}

body::before {
  background:
    radial-gradient(
      ellipse 70% 55% at 15% 10%,
      rgba(110, 136, 255, 0.12) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 50% 45% at 85% 0%,
      rgba(78, 222, 163, 0.07) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 55% 55% at 50% 110%,
      rgba(78, 222, 163, 0.05) 0%,
      transparent 60%
    ),
    linear-gradient(180deg, #060e20 0%, #0b1326 100%) !important;
}

/* ─────────────────────────────────────────────────────────────
   3. SIDEBAR — expand to 280px with labels (matches reference)
   ─────────────────────────────────────────────────────────────*/
.sidebar {
  width: var(--sidebar-w) !important;
  min-width: var(--sidebar-w) !important;
  max-width: var(--sidebar-w) !important;
  background: rgba(6, 14, 32, 0.92) !important;
  backdrop-filter: blur(32px) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.06) !important;
  align-items: flex-start !important;
  padding: 24px 0 20px !important;
}

.sidebar-logo {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #3b5bdb 0%, #6e88ff 100%) !important;
  box-shadow:
    0 4px 24px rgba(110, 136, 255, 0.4),
    0 0 0 1px rgba(185, 195, 255, 0.2) inset !important;
  margin: 0 0 32px 20px !important;
}

/* Brand name next to logo */
.sidebar-logo-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  margin-bottom: 32px;
}

.sidebar-brand-name {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -0.01em;
}

.sidebar-brand-sub {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--t3);
  margin-top: 1px;
}

/* Nav items — show labels */
.sidebar-nav {
  align-items: stretch !important;
  padding: 0 12px !important;
  width: 100% !important;
}

.sb-btn {
  width: 100% !important;
  height: 46px !important;
  border-radius: 12px !important;
  padding: 0 16px !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: var(--t3) !important;
  letter-spacing: 0 !important;
}

.sb-btn::after {
  content: attr(title);
  font-size: 0.8rem;
  font-weight: 600;
  font-family: "Inter", sans-serif;
  white-space: nowrap;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.sb-btn:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: var(--t1) !important;
  transform: none !important;
}

.sb-btn.active,
.sb-btn.bn-tab--active {
  background: rgba(110, 136, 255, 0.12) !important;
  color: var(--accent) !important;
  box-shadow: none !important;
  border-right: 3px solid var(--accent) !important;
  border-radius: 12px 0 0 12px !important;
}

.sb-btn.active::before {
  display: none !important;
}

.sb-btn.active::after,
.sb-btn.bn-tab--active::after {
  color: var(--accent) !important;
}

/* Remove icon-only tooltip */
#sb-tooltip {
  display: none !important;
}

/* Sidebar bottom */
.sidebar-bottom {
  width: 100% !important;
  padding: 12px 12px 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
}

/* Premium upgrade card at bottom of sidebar */
.sidebar-upgrade-card {
  margin: 16px 12px 12px;
  padding: 14px 16px;
  border-radius: 16px;
  background: linear-gradient(
    135deg,
    rgba(110, 136, 255, 0.15),
    rgba(210, 187, 255, 0.08)
  );
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar-upgrade-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
}

.sidebar-upgrade-sub {
  font-size: 0.7rem;
  color: var(--t3);
  line-height: 1.5;
  margin-bottom: 10px;
}

.sidebar-upgrade-btn {
  width: 100%;
  padding: 8px 0;
  border-radius: 8px;
  background: var(--accent);
  color: #00228a;
  font-size: 0.78rem;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  border: none;
  font-family: "Inter", sans-serif;
  transition: filter 0.2s;
}

.sidebar-upgrade-btn:hover {
  filter: brightness(1.08);
}

/* ─────────────────────────────────────────────────────────────
   4. MAIN AREA — shift right by sidebar width
   ─────────────────────────────────────────────────────────────*/
.main-area {
  /* sidebar is now 280px not 72px */
}

/* ─────────────────────────────────────────────────────────────
   5. TOPBAR
   ─────────────────────────────────────────────────────────────*/
.topbar {
  background: rgba(6, 14, 32, 0.8) !important;
  backdrop-filter: blur(24px) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  height: 68px !important;
}

.topbar-date-block {
  display: flex;
  flex-direction: column;
}

.topbar-date-day {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--t1);
}

.topbar-date-full {
  font-size: 0.72rem;
  color: var(--t3);
}

.topbar-avatar {
  background: linear-gradient(135deg, #3b5bdb, #6e88ff) !important;
  border: 2px solid rgba(185, 195, 255, 0.3) !important;
  box-shadow: 0 0 16px rgba(110, 136, 255, 0.2) !important;
}

/* ─────────────────────────────────────────────────────────────
   6. GLASS CARD BASE — the foundational bento card
   ─────────────────────────────────────────────────────────────*/
.db-stat-card,
.db-chart-card,
.db-panel,
.db-card-panel,
.db-recent-card,
.insights-card,
.card {
  background: var(--glass) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  transition:
    border-color 0.3s ease,
    box-shadow 0.3s ease !important;
}

.db-stat-card:hover,
.db-chart-card:hover,
.db-panel:hover,
.db-card-panel:hover,
.db-recent-card:hover {
  border-color: var(--border-hi) !important;
  box-shadow: var(--shadow-md) !important;
  transform: none !important;
}

/* ─────────────────────────────────────────────────────────────
   7. STAT CARDS — match reference (icon + badge + amount + mini bars)
   ─────────────────────────────────────────────────────────────*/
.db-stats {
  gap: 16px !important;
}

.db-stat-card {
  padding: 1.4rem 1.5rem 1.2rem !important;
  position: relative !important;
  overflow: hidden !important;
}

.db-stat-card::before {
  display: none !important; /* remove old gradient */
}

.dsc-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 10px !important;
  margin-bottom: 10px !important;
}

.dsc-icon--income {
  background: rgba(78, 222, 163, 0.12) !important;
  color: var(--inc) !important;
}
.dsc-icon--expense {
  background: rgba(255, 180, 171, 0.12) !important;
  color: var(--exp) !important;
}
.dsc-icon--net {
  background: rgba(185, 195, 255, 0.12) !important;
  color: var(--accent) !important;
}

.dsc-label {
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--t3) !important;
  margin-bottom: 2px !important;
}

.db-stat-card .amount {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1.45rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.15 !important;
  margin-bottom: 8px !important;
}

.income-amount {
  color: var(--inc) !important;
}
.expense-amount {
  color: var(--exp) !important;
}
.net-positive {
  color: var(--t1) !important;
}

/* Change badge — absolute top-right */
.db-stat-card .change {
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   8. CHART CARD
   ─────────────────────────────────────────────────────────────*/
.db-chart-card {
  padding: 1.4rem 1.5rem 1.2rem !important;
}

.db-chart-card::before {
  display: none !important;
}

.dcc-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

/* Chart period buttons */
.cpc-btn {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t3) !important;
  border-radius: 8px !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  padding: 0.3rem 0.85rem !important;
}

.cpc-btn--active {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #00228a !important;
}

/* ─────────────────────────────────────────────────────────────
   9. PANEL (All Expenses, My Card panel)
   ─────────────────────────────────────────────────────────────*/
.db-panel {
  padding: 1.4rem 1.5rem !important;
}
.db-panel::before {
  display: none !important;
}

.db-panel-title,
.db-card-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-panel-sub {
  color: var(--t3) !important;
  font-size: 0.72rem !important;
}

/* ─────────────────────────────────────────────────────────────
   10. MY CARD PANEL
   ─────────────────────────────────────────────────────────────*/
.db-card-panel {
  border-color: rgba(110, 136, 255, 0.18) !important;
  padding: 1.4rem 1.5rem 1.2rem !important;
}

/* Card stack dot indicators */
.cs-dot {
  background: rgba(255, 255, 255, 0.18) !important;
}
.cs-dot.is-active {
  background: var(--accent) !important;
  width: 18px !important;
  border-radius: 4px !important;
}

/* Card action row */
.card-action-row {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.card-action-btn {
  flex: 1;
  padding: 8px 0;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t3);
  cursor: pointer;
  transition: all 0.2s;
}

.card-action-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}
.card-action-add {
  color: var(--inc) !important;
  border-color: rgba(78, 222, 163, 0.2) !important;
}
.card-action-remove {
  color: var(--exp) !important;
  border-color: rgba(255, 180, 171, 0.2) !important;
}

/* Monthly limit row */
.card-limit-row {
  display: flex;
  justify-content: space-between;
  margin-top: 12px;
  margin-bottom: 6px;
}

.card-limit-label {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3);
}

.card-limit-val {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--t1);
}

/* ─────────────────────────────────────────────────────────────
   11. RECENT TRANSACTIONS CARD
   ─────────────────────────────────────────────────────────────*/
.db-recent-card {
  padding: 1.2rem 1.4rem !important;
}

.db-recent-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-recent-all {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  color: var(--accent) !important;
}

.db-recent-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.db-recent-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
}

.db-recent-desc {
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-recent-meta {
  font-size: 0.68rem !important;
  color: var(--t3) !important;
}

.db-recent-amt {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
}

/* ─────────────────────────────────────────────────────────────
   12. GREETING
   ─────────────────────────────────────────────────────────────*/
.db-greeting-name {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: var(--t1) !important;
  line-height: 1.15 !important;
}

.db-greeting-sub {
  font-size: 0.88rem !important;
  color: var(--t3) !important;
  margin-top: 4px !important;
}

/* ─────────────────────────────────────────────────────────────
   13. INSIGHTS CARD
   ─────────────────────────────────────────────────────────────*/
.insights-card {
  padding: 1.4rem 1.5rem !important;
}
.insights-card::before {
  display: none !important;
}
.card-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

/* ─────────────────────────────────────────────────────────────
   14. EXPENSE CATEGORIES
   ─────────────────────────────────────────────────────────────*/
.total-expenses {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em !important;
  color: var(--t1) !important;
}

.expense-categories li {
  border-radius: 10px !important;
  padding: 0.5rem 0.6rem !important;
}

/* ─────────────────────────────────────────────────────────────
   15. FORMS & INPUTS
   ─────────────────────────────────────────────────────────────*/
.form-input,
.form-select,
textarea.form-input {
  background: rgba(6, 14, 32, 0.7) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--t1) !important;
  font-family: "Inter", sans-serif !important;
}

.form-input:focus,
.form-select:focus,
textarea.form-input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 4px rgba(110, 136, 255, 0.12) !important;
  outline: none !important;
}

.form-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   16. BUTTONS
   ─────────────────────────────────────────────────────────────*/
.btn-primary {
  background: var(--accent) !important;
  color: #00228a !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  border: none !important;
  box-shadow: 0 2px 12px rgba(110, 136, 255, 0.25) !important;
  font-family: "Inter", sans-serif !important;
}

.btn-primary:hover {
  filter: brightness(1.08) !important;
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t2) !important;
  border-radius: 8px !important;
  font-family: "Inter", sans-serif !important;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.btn-danger {
  background: rgba(255, 180, 171, 0.15) !important;
  border: 1px solid rgba(255, 180, 171, 0.3) !important;
  color: var(--exp) !important;
  border-radius: 8px !important;
  font-family: "Inter", sans-serif !important;
}

/* Income button in modals */
.btn[onclick*="addIncome"] {
  background: var(--inc) !important;
  color: #002113 !important;
  box-shadow: 0 2px 12px rgba(78, 222, 163, 0.25) !important;
}

/* ─────────────────────────────────────────────────────────────
   17. MODALS
   ─────────────────────────────────────────────────────────────*/
.modal-content {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(32px) !important;
}

.modal-content::before {
  display: none !important;
}

.modal-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
  padding: 1.2rem 1.5rem !important;
}

.modal-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.modal-body {
  padding: 1.5rem !important;
}
.modal-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
  padding: 1rem 1.5rem !important;
}

/* ─────────────────────────────────────────────────────────────
   18. BOTTOM NAV — matches reference (DASH/TRANS/AI/SET)
   ─────────────────────────────────────────────────────────────*/
.bottom-nav {
  background: rgba(6, 14, 32, 0.92) !important;
  backdrop-filter: blur(24px) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  height: 72px !important;
}

@media (min-width: 768px) {
  .bottom-nav {
    display: none !important;
  }
}

.bn-tab {
  color: var(--t3) !important;
  font-family: "Inter", sans-serif !important;
  font-size: 0.62rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  gap: 4px !important;
}

.bn-tab i {
  font-size: 1.1rem !important;
  margin-bottom: 2px !important;
}

.bn-tab.bn-tab--active {
  color: var(--accent) !important;
}

.bn-tab.bn-tab--active i {
  color: var(--accent) !important;
}

/* FAB center button */
.bn-tab--fab .bn-add-ring {
  background: var(--accent) !important;
  color: #00228a !important;
  box-shadow: 0 4px 20px rgba(110, 136, 255, 0.4) !important;
}

/* ─────────────────────────────────────────────────────────────
   19. AUTH SCREENS
   ─────────────────────────────────────────────────────────────*/
.lock-screen,
.auth-screen {
  background: var(--bg) !important;
}

.lock-card,
.auth-card {
  background: rgba(19, 27, 46, 0.95) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  backdrop-filter: blur(24px) !important;
  border-radius: 24px !important;
}

.auth-brand {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

.auth-brand span {
  color: var(--accent) !important;
}

.auth-action-btn.auth-btn-login {
  background: var(--accent) !important;
  color: #00228a !important;
}

.auth-action-btn.auth-btn-signup {
  background: rgba(110, 136, 255, 0.12) !important;
  border: 1px solid rgba(185, 195, 255, 0.25) !important;
  color: var(--accent) !important;
}

.auth-popup {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px !important;
}

/* ─────────────────────────────────────────────────────────────
   20. AI ASSISTANT
   ─────────────────────────────────────────────────────────────*/
.ask-bl-panel {
  background: #131b2e !important;
  border-left: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.ask-bl-header {
  background: rgba(6, 14, 32, 0.8) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.ask-bl-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.ask-bl-send {
  background: var(--accent) !important;
  color: #00228a !important;
}

.ask-bl-chip {
  background: rgba(110, 136, 255, 0.1) !important;
  border: 1px solid rgba(185, 195, 255, 0.15) !important;
  color: var(--accent) !important;
}

/* ─────────────────────────────────────────────────────────────
   21. SETTINGS PAGE
   ─────────────────────────────────────────────────────────────*/
.settings-page {
  background: var(--bg) !important;
}

.sp-header {
  background: rgba(6, 14, 32, 0.8) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.sp-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

.sp-group-body {
  background: rgba(30, 41, 59, 0.5) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(24px) !important;
}

.sp-row:hover {
  background: rgba(255, 255, 255, 0.04) !important;
}
.sp-row-title {
  font-weight: 600 !important;
  color: var(--t1) !important;
}
.sp-row-sub {
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   22. SYNC INDICATOR
   ─────────────────────────────────────────────────────────────*/
.bl-sync-indicator {
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: 50px !important;
  border: 1px solid rgba(78, 222, 163, 0.25) !important;
  background: rgba(78, 222, 163, 0.08) !important;
  color: var(--inc) !important;
}

/* ─────────────────────────────────────────────────────────────
   23. TRANSACTIONS FULL PAGE
   ─────────────────────────────────────────────────────────────*/
#txnFullPage {
  background: var(--bg) !important;
}

.txn-page-header {
  background: rgba(6, 14, 32, 0.9) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.txn-page-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.txn-page-search-input {
  background: rgba(30, 41, 59, 0.7) !important;
  border: 1px solid var(--border) !important;
  color: var(--t1) !important;
  border-radius: 10px !important;
}

.txn-page-search-input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(110, 136, 255, 0.12) !important;
}

.txn-page-chip {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t3) !important;
  border-radius: 50px !important;
}

.txn-page-chip--active {
  background: rgba(110, 136, 255, 0.14) !important;
  border-color: rgba(185, 195, 255, 0.25) !important;
  color: var(--accent) !important;
}

/* ─────────────────────────────────────────────────────────────
   24. SHEET / DRAWER
   ─────────────────────────────────────────────────────────────*/
.bn-sheet {
  background: #131b2e !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px 20px 0 0 !important;
}

.bn-sheet-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.bn-ring-card {
  background: rgba(30, 41, 59, 0.8) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
}

.bn-ring-income {
  border-color: rgba(78, 222, 163, 0.25) !important;
}
.bn-ring-expense {
  border-color: rgba(255, 180, 171, 0.25) !important;
}

.bn-ring-label {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.bn-settings-panel {
  background: #131b2e !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.bn-settings-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  color: var(--t2) !important;
}

.bn-settings-row:hover {
  background: rgba(255, 255, 255, 0.04) !important;
}
.bn-settings-danger {
  color: var(--exp) !important;
}

/* ─────────────────────────────────────────────────────────────
   26. NEON GLOW EFFECTS on key cards
   ─────────────────────────────────────────────────────────────*/
.db-card-panel::after,
.db-chart-card::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(110, 136, 255, 0.12) 0%,
    transparent 70%
  );
  top: -40px;
  right: -40px;
  pointer-events: none;
  z-index: 0;
}

/* ─────────────────────────────────────────────────────────────
   27. SCROLLBARS — subtle premium look
   ─────────────────────────────────────────────────────────────*/
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.18);
}

/* ─────────────────────────────────────────────────────────────
   28. CONTEXT MENU, TOAST
   ─────────────────────────────────────────────────────────────*/
#contextMenu {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 12px !important;
  box-shadow: var(--shadow-lg) !important;
}

.ctx-item {
  color: var(--t2) !important;
}
.ctx-item:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}
.ctx-item.danger {
  color: var(--exp) !important;
}

/* ─────────────────────────────────────────────────────────────
   29. LOCK SCREEN PIN KEYS
   ─────────────────────────────────────────────────────────────*/
.pin-key {
  background: rgba(30, 41, 59, 0.7) !important;
  border: 1px solid var(--border) !important;
  color: var(--t1) !important;
  border-radius: 50% !important;
}

.pin-key:hover {
  background: rgba(110, 136, 255, 0.15) !important;
}

/* ─────────────────────────────────────────────────────────────
   30. ANIMATIONS — subtle fade-in for premium feel
   ─────────────────────────────────────────────────────────────*/
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.db-stat-card {
  animation: fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.db-stat-card:nth-child(1) {
  animation-delay: 0.05s;
}
.db-stat-card:nth-child(2) {
  animation-delay: 0.1s;
}
.db-stat-card:nth-child(3) {
  animation-delay: 0.15s;
}

.db-chart-card {
  animation: fadeInUp 0.4s 0.12s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.db-card-panel {
  animation: fadeInUp 0.4s 0.08s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* ═══════════════════════════════════════════════════════════════
   BlueLedger — Premium Fintech Glass System OVERRIDES
   Matches reference design from screenshots exactly.
   Load AFTER style.css  OR  prepend as :root override block.
   ═══════════════════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap");

/* ─────────────────────────────────────────────────────────────
   1. DESIGN TOKENS — replaces the existing :root block
   ─────────────────────────────────────────────────────────────*/
:root:not([data-theme="light"]) {
  /* Core surfaces */
  --bg: #0b1326;
  --bg2: #0f1a30;
  --bg3: #131b2e;
  --bg-card: rgba(30, 41, 59, 0.5);
  --bg-card-hi: rgba(34, 42, 61, 0.7);
  --bg-surface: #060e20;

  /* Text */
  --t1: #dae2fd;
  --t2: #c4c5d7;
  --t3: #8e90a0;
  --t4: rgba(218, 226, 253, 0.16);

  /* Borders */
  --border: rgba(255, 255, 255, 0.1);
  --border-md: rgba(255, 255, 255, 0.15);
  --border-hi: rgba(255, 255, 255, 0.25);

  /* Brand accents */
  --accent: #b9c3ff; /* primary */
  --accent-deep: #6e88ff; /* primary-container */
  --accent-dim: rgba(110, 136, 255, 0.1);
  --accent-glow: rgba(79, 110, 247, 0.18);

  --inc: #4edea3; /* secondary */
  --inc-dim: rgba(78, 222, 163, 0.1);

  --exp: #ffb4ab; /* error */
  --exp-dim: rgba(255, 180, 171, 0.1);

  --tertiary: #d2bbff;

  /* Glass surfaces */
  --glass: rgba(30, 41, 59, 0.5);
  --glass-blur: 24px;

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.45);
  --shadow-md:
    0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 20px 48px rgba(0, 0, 0, 0.55);
  --shadow-xl: 0 28px 72px rgba(0, 0, 0, 0.64);
  --glow-accent: 0 0 48px rgba(110, 136, 255, 0.1);

  /* Radius */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;

  /* Spacing */
  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;

  /* Sidebar width */
  --sidebar-w: 280px;
}

/* Light mode keeps existing approach — no changes needed */

/* ─────────────────────────────────────────────────────────────
   2. BASE
   ─────────────────────────────────────────────────────────────*/
body {
  font-family: "Inter", system-ui, sans-serif !important;
  background: var(--bg) !important;
  color: var(--t1) !important;
}

body::before {
  background:
    radial-gradient(
      ellipse 70% 55% at 15% 10%,
      rgba(110, 136, 255, 0.12) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 50% 45% at 85% 0%,
      rgba(78, 222, 163, 0.07) 0%,
      transparent 55%
    ),
    radial-gradient(
      ellipse 55% 55% at 50% 110%,
      rgba(78, 222, 163, 0.05) 0%,
      transparent 60%
    ),
    linear-gradient(180deg, #060e20 0%, #0b1326 100%) !important;
}

/* ─────────────────────────────────────────────────────────────
   3. SIDEBAR — expand to 280px with labels (matches reference)
   ─────────────────────────────────────────────────────────────*/
.sidebar {
  width: var(--sidebar-w) !important;
  min-width: var(--sidebar-w) !important;
  max-width: var(--sidebar-w) !important;
  background: rgba(6, 14, 32, 0.92) !important;
  backdrop-filter: blur(32px) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.06) !important;
  align-items: flex-start !important;
  padding: 24px 0 20px !important;
}

.sidebar-logo {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #3b5bdb 0%, #6e88ff 100%) !important;
  box-shadow:
    0 4px 24px rgba(110, 136, 255, 0.4),
    0 0 0 1px rgba(185, 195, 255, 0.2) inset !important;
  margin: 0 0 32px 20px !important;
}

/* Brand name next to logo */
.sidebar-logo-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  margin-bottom: 32px;
}

.sidebar-brand-name {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -0.01em;
}

.sidebar-brand-sub {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--t3);
  margin-top: 1px;
}

/* Nav items — show labels */
.sidebar-nav {
  align-items: stretch !important;
  padding: 0 12px !important;
  width: 100% !important;
}

.sb-btn {
  width: 100% !important;
  height: 46px !important;
  border-radius: 12px !important;
  padding: 0 16px !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: var(--t3) !important;
  letter-spacing: 0 !important;
}

.sb-btn::after {
  content: attr(title);
  font-size: 0.8rem;
  font-weight: 600;
  font-family: "Inter", sans-serif;
  white-space: nowrap;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.sb-btn:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: var(--t1) !important;
  transform: none !important;
}

.sb-btn.active,
.sb-btn.bn-tab--active {
  background: rgba(110, 136, 255, 0.12) !important;
  color: var(--accent) !important;
  box-shadow: none !important;
  border-right: 3px solid var(--accent) !important;
  border-radius: 12px 0 0 12px !important;
}

.sb-btn.active::before {
  display: none !important;
}

.sb-btn.active::after,
.sb-btn.bn-tab--active::after {
  color: var(--accent) !important;
}

/* Remove icon-only tooltip */
#sb-tooltip {
  display: none !important;
}

/* Sidebar bottom */
.sidebar-bottom {
  width: 100% !important;
  padding: 12px 12px 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
}

/* Premium upgrade card at bottom of sidebar */
.sidebar-upgrade-card {
  margin: 16px 12px 12px;
  padding: 14px 16px;
  border-radius: 16px;
  background: linear-gradient(
    135deg,
    rgba(110, 136, 255, 0.15),
    rgba(210, 187, 255, 0.08)
  );
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar-upgrade-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
}

.sidebar-upgrade-sub {
  font-size: 0.7rem;
  color: var(--t3);
  line-height: 1.5;
  margin-bottom: 10px;
}

.sidebar-upgrade-btn {
  width: 100%;
  padding: 8px 0;
  border-radius: 8px;
  background: var(--accent);
  color: #00228a;
  font-size: 0.78rem;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  border: none;
  font-family: "Inter", sans-serif;
  transition: filter 0.2s;
}

.sidebar-upgrade-btn:hover {
  filter: brightness(1.08);
}

/* ─────────────────────────────────────────────────────────────
   4. MAIN AREA — shift right by sidebar width
   ─────────────────────────────────────────────────────────────*/
.main-area {
  /* sidebar is now 280px not 72px */
}

/* ─────────────────────────────────────────────────────────────
   5. TOPBAR
   ─────────────────────────────────────────────────────────────*/
.topbar {
  background: rgba(6, 14, 32, 0.8) !important;
  backdrop-filter: blur(24px) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  height: 68px !important;
}

.topbar-date-block {
  display: flex;
  flex-direction: column;
}

.topbar-date-day {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--t1);
}

.topbar-date-full {
  font-size: 0.72rem;
  color: var(--t3);
}

.topbar-avatar {
  background: linear-gradient(135deg, #3b5bdb, #6e88ff) !important;
  border: 2px solid rgba(185, 195, 255, 0.3) !important;
  box-shadow: 0 0 16px rgba(110, 136, 255, 0.2) !important;
}

/* ─────────────────────────────────────────────────────────────
   6. GLASS CARD BASE — the foundational bento card
   ─────────────────────────────────────────────────────────────*/
.db-stat-card,
.db-chart-card,
.db-panel,
.db-card-panel,
.db-recent-card,
.insights-card,
.card {
  background: var(--glass) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  transition:
    border-color 0.3s ease,
    box-shadow 0.3s ease !important;
}

.db-stat-card:hover,
.db-chart-card:hover,
.db-panel:hover,
.db-card-panel:hover,
.db-recent-card:hover {
  border-color: var(--border-hi) !important;
  box-shadow: var(--shadow-md) !important;
  transform: none !important;
}

/* ─────────────────────────────────────────────────────────────
   7. STAT CARDS — match reference (icon + badge + amount + mini bars)
   ─────────────────────────────────────────────────────────────*/
.db-stats {
  gap: 16px !important;
}

.db-stat-card {
  padding: 1.4rem 1.5rem 1.2rem !important;
  position: relative !important;
  overflow: hidden !important;
}

.db-stat-card::before {
  display: none !important; /* remove old gradient */
}

.dsc-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 10px !important;
  margin-bottom: 10px !important;
}

.dsc-icon--income {
  background: rgba(78, 222, 163, 0.12) !important;
  color: var(--inc) !important;
}
.dsc-icon--expense {
  background: rgba(255, 180, 171, 0.12) !important;
  color: var(--exp) !important;
}
.dsc-icon--net {
  background: rgba(185, 195, 255, 0.12) !important;
  color: var(--accent) !important;
}

.dsc-label {
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--t3) !important;
  margin-bottom: 2px !important;
}

.db-stat-card .amount {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1.45rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.15 !important;
  margin-bottom: 8px !important;
}

.income-amount {
  color: var(--inc) !important;
}
.expense-amount {
  color: var(--exp) !important;
}
.net-positive {
  color: var(--t1) !important;
}

/* Change badge — absolute top-right */
.db-stat-card .change {
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   8. CHART CARD
   ─────────────────────────────────────────────────────────────*/
.db-chart-card {
  padding: 1.4rem 1.5rem 1.2rem !important;
}

.db-chart-card::before {
  display: none !important;
}

.dcc-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

/* Chart period buttons */
.cpc-btn {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t3) !important;
  border-radius: 8px !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  padding: 0.3rem 0.85rem !important;
}

.cpc-btn--active {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #00228a !important;
}

/* ─────────────────────────────────────────────────────────────
   9. PANEL (All Expenses, My Card panel)
   ─────────────────────────────────────────────────────────────*/
.db-panel {
  padding: 1.4rem 1.5rem !important;
}
.db-panel::before {
  display: none !important;
}

.db-panel-title,
.db-card-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-panel-sub {
  color: var(--t3) !important;
  font-size: 0.72rem !important;
}

/* ─────────────────────────────────────────────────────────────
   10. MY CARD PANEL
   ─────────────────────────────────────────────────────────────*/
.db-card-panel {
  border-color: rgba(110, 136, 255, 0.18) !important;
  padding: 1.4rem 1.5rem 1.2rem !important;
}

/* Card stack dot indicators */
.cs-dot {
  background: rgba(255, 255, 255, 0.18) !important;
}
.cs-dot.is-active {
  background: var(--accent) !important;
  width: 18px !important;
  border-radius: 4px !important;
}

/* Card action row */
.card-action-row {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.card-action-btn {
  flex: 1;
  padding: 8px 0;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--t3);
  cursor: pointer;
  transition: all 0.2s;
}

.card-action-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--t1);
}
.card-action-add {
  color: var(--inc) !important;
  border-color: rgba(78, 222, 163, 0.2) !important;
}
.card-action-remove {
  color: var(--exp) !important;
  border-color: rgba(255, 180, 171, 0.2) !important;
}

/* Monthly limit row */
.card-limit-row {
  display: flex;
  justify-content: space-between;
  margin-top: 12px;
  margin-bottom: 6px;
}

.card-limit-label {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--t3);
}

.card-limit-val {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--t1);
}

/* ─────────────────────────────────────────────────────────────
   11. RECENT TRANSACTIONS CARD
   ─────────────────────────────────────────────────────────────*/
.db-recent-card {
  padding: 1.2rem 1.4rem !important;
}

.db-recent-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-recent-all {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  color: var(--accent) !important;
}

.db-recent-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.db-recent-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
}

.db-recent-desc {
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.db-recent-meta {
  font-size: 0.68rem !important;
  color: var(--t3) !important;
}

.db-recent-amt {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
}

/* ─────────────────────────────────────────────────────────────
   12. GREETING
   ─────────────────────────────────────────────────────────────*/
.db-greeting-name {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: var(--t1) !important;
  line-height: 1.15 !important;
}

.db-greeting-sub {
  font-size: 0.88rem !important;
  color: var(--t3) !important;
  margin-top: 4px !important;
}

/* ─────────────────────────────────────────────────────────────
   13. INSIGHTS CARD
   ─────────────────────────────────────────────────────────────*/
.insights-card {
  padding: 1.4rem 1.5rem !important;
}
.insights-card::before {
  display: none !important;
}
.card-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

/* ─────────────────────────────────────────────────────────────
   14. EXPENSE CATEGORIES
   ─────────────────────────────────────────────────────────────*/
.total-expenses {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em !important;
  color: var(--t1) !important;
}

.expense-categories li {
  border-radius: 10px !important;
  padding: 0.5rem 0.6rem !important;
}

/* ─────────────────────────────────────────────────────────────
   15. FORMS & INPUTS
   ─────────────────────────────────────────────────────────────*/
.form-input,
.form-select,
textarea.form-input {
  background: rgba(6, 14, 32, 0.7) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--t1) !important;
  font-family: "Inter", sans-serif !important;
}

.form-input:focus,
.form-select:focus,
textarea.form-input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 4px rgba(110, 136, 255, 0.12) !important;
  outline: none !important;
}

.form-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   16. BUTTONS
   ─────────────────────────────────────────────────────────────*/
.btn-primary {
  background: var(--accent) !important;
  color: #00228a !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  border: none !important;
  box-shadow: 0 2px 12px rgba(110, 136, 255, 0.25) !important;
  font-family: "Inter", sans-serif !important;
}

.btn-primary:hover {
  filter: brightness(1.08) !important;
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t2) !important;
  border-radius: 8px !important;
  font-family: "Inter", sans-serif !important;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.btn-danger {
  background: rgba(255, 180, 171, 0.15) !important;
  border: 1px solid rgba(255, 180, 171, 0.3) !important;
  color: var(--exp) !important;
  border-radius: 8px !important;
  font-family: "Inter", sans-serif !important;
}

/* Income button in modals */
.btn[onclick*="addIncome"] {
  background: var(--inc) !important;
  color: #002113 !important;
  box-shadow: 0 2px 12px rgba(78, 222, 163, 0.25) !important;
}

/* ─────────────────────────────────────────────────────────────
   17. MODALS
   ─────────────────────────────────────────────────────────────*/
.modal-content {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(32px) !important;
}

.modal-content::before {
  display: none !important;
}

.modal-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
  padding: 1.2rem 1.5rem !important;
}

.modal-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.modal-body {
  padding: 1.5rem !important;
}
.modal-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
  padding: 1rem 1.5rem !important;
}

/* ─────────────────────────────────────────────────────────────
   18. BOTTOM NAV — matches reference (DASH/TRANS/AI/SET)
   ─────────────────────────────────────────────────────────────*/
.bottom-nav {
  background: rgba(6, 14, 32, 0.92) !important;
  backdrop-filter: blur(24px) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  height: 72px !important;
}

.bn-tab {
  color: var(--t3) !important;
  font-family: "Inter", sans-serif !important;
  font-size: 0.62rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  gap: 4px !important;
}

.bn-tab i {
  font-size: 1.1rem !important;
  margin-bottom: 2px !important;
}

.bn-tab.bn-tab--active {
  color: var(--accent) !important;
}

.bn-tab.bn-tab--active i {
  color: var(--accent) !important;
}

/* FAB center button */
.bn-tab--fab .bn-add-ring {
  background: var(--accent) !important;
  color: #00228a !important;
  box-shadow: 0 4px 20px rgba(110, 136, 255, 0.4) !important;
}

/* ─────────────────────────────────────────────────────────────
   19. AUTH SCREENS
   ─────────────────────────────────────────────────────────────*/
.lock-screen,
.auth-screen {
  background: var(--bg) !important;
}

.lock-card,
.auth-card {
  background: rgba(19, 27, 46, 0.95) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  backdrop-filter: blur(24px) !important;
  border-radius: 24px !important;
}

.auth-brand {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

.auth-brand span {
  color: var(--accent) !important;
}

.auth-action-btn.auth-btn-login {
  background: var(--accent) !important;
  color: #00228a !important;
}

.auth-action-btn.auth-btn-signup {
  background: rgba(110, 136, 255, 0.12) !important;
  border: 1px solid rgba(185, 195, 255, 0.25) !important;
  color: var(--accent) !important;
}

.auth-popup {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px !important;
}

/* ─────────────────────────────────────────────────────────────
   20. AI ASSISTANT
   ─────────────────────────────────────────────────────────────*/
.ask-bl-panel {
  background: #131b2e !important;
  border-left: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.ask-bl-header {
  background: rgba(6, 14, 32, 0.8) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.ask-bl-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.ask-bl-send {
  background: var(--accent) !important;
  color: #00228a !important;
}

.ask-bl-chip {
  background: rgba(110, 136, 255, 0.1) !important;
  border: 1px solid rgba(185, 195, 255, 0.15) !important;
  color: var(--accent) !important;
}

/* ─────────────────────────────────────────────────────────────
   21. SETTINGS PAGE
   ─────────────────────────────────────────────────────────────*/
.settings-page {
  background: var(--bg) !important;
}

.sp-header {
  background: rgba(6, 14, 32, 0.8) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.sp-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}

.sp-group-body {
  background: rgba(30, 41, 59, 0.5) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(24px) !important;
}

.sp-row:hover {
  background: rgba(255, 255, 255, 0.04) !important;
}
.sp-row-title {
  font-weight: 600 !important;
  color: var(--t1) !important;
}
.sp-row-sub {
  color: var(--t3) !important;
}

/* ─────────────────────────────────────────────────────────────
   22. SYNC INDICATOR
   ─────────────────────────────────────────────────────────────*/
.bl-sync-indicator {
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: 50px !important;
  border: 1px solid rgba(78, 222, 163, 0.25) !important;
  background: rgba(78, 222, 163, 0.08) !important;
  color: var(--inc) !important;
}

/* ─────────────────────────────────────────────────────────────
   23. TRANSACTIONS FULL PAGE
   ─────────────────────────────────────────────────────────────*/
#txnFullPage {
  background: var(--bg) !important;
}

.txn-page-header {
  background: rgba(6, 14, 32, 0.9) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.txn-page-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.txn-page-search-input {
  background: rgba(30, 41, 59, 0.7) !important;
  border: 1px solid var(--border) !important;
  color: var(--t1) !important;
  border-radius: 10px !important;
}

.txn-page-search-input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(110, 136, 255, 0.12) !important;
}

.txn-page-chip {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--border) !important;
  color: var(--t3) !important;
  border-radius: 50px !important;
}

.txn-page-chip--active {
  background: rgba(110, 136, 255, 0.14) !important;
  border-color: rgba(185, 195, 255, 0.25) !important;
  color: var(--accent) !important;
}

/* ─────────────────────────────────────────────────────────────
   24. SHEET / DRAWER
   ─────────────────────────────────────────────────────────────*/
.bn-sheet {
  background: #131b2e !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px 20px 0 0 !important;
}

.bn-sheet-title {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.bn-ring-card {
  background: rgba(30, 41, 59, 0.8) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
}

.bn-ring-income {
  border-color: rgba(78, 222, 163, 0.25) !important;
}
.bn-ring-expense {
  border-color: rgba(255, 180, 171, 0.25) !important;
}

.bn-ring-label {
  font-family: "Space Grotesk", sans-serif !important;
  font-weight: 600 !important;
  color: var(--t1) !important;
}

.bn-settings-panel {
  background: #131b2e !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.bn-settings-row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  color: var(--t2) !important;
}

.bn-settings-row:hover {
  background: rgba(255, 255, 255, 0.04) !important;
}
.bn-settings-danger {
  color: var(--exp) !important;
}

/* ─────────────────────────────────────────────────────────────
   25. MOBILE RESPONSIVE — stat cards & grid below 768px
   ─────────────────────────────────────────────────────────────*/
@media (max-width: 768px) {
  .sidebar {
    display: none !important;
  }

  .main-area {
    margin-left: 0 !important;
  }

  .db-grid {
    grid-template-columns: 1fr !important;
  }

  .db-stats {
    grid-template-columns: 1fr !important;
  }

  .db-greeting-name {
    font-size: 1.5rem !important;
  }
}

/* ─────────────────────────────────────────────────────────────
   26. NEON GLOW EFFECTS on key cards
   ─────────────────────────────────────────────────────────────*/
.db-card-panel::after,
.db-chart-card::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(110, 136, 255, 0.12) 0%,
    transparent 70%
  );
  top: -40px;
  right: -40px;
  pointer-events: none;
  z-index: 0;
}

/* ─────────────────────────────────────────────────────────────
   27. SCROLLBARS — subtle premium look
   ─────────────────────────────────────────────────────────────*/
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.18);
}

/* ─────────────────────────────────────────────────────────────
   28. CONTEXT MENU, TOAST
   ─────────────────────────────────────────────────────────────*/
#contextMenu {
  background: #131b2e !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 12px !important;
  box-shadow: var(--shadow-lg) !important;
}

.ctx-item {
  color: var(--t2) !important;
}
.ctx-item:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}
.ctx-item.danger {
  color: var(--exp) !important;
}

/* ─────────────────────────────────────────────────────────────
   29. LOCK SCREEN PIN KEYS
   ─────────────────────────────────────────────────────────────*/
.pin-key {
  background: rgba(30, 41, 59, 0.7) !important;
  border: 1px solid var(--border) !important;
  color: var(--t1) !important;
  border-radius: 50% !important;
}

.pin-key:hover {
  background: rgba(110, 136, 255, 0.15) !important;
}

/* ─────────────────────────────────────────────────────────────
   30. ANIMATIONS — subtle fade-in for premium feel
   ─────────────────────────────────────────────────────────────*/
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.db-stat-card {
  animation: fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.db-stat-card:nth-child(1) {
  animation-delay: 0.05s;
}
.db-stat-card:nth-child(2) {
  animation-delay: 0.1s;
}
.db-stat-card:nth-child(3) {
  animation-delay: 0.15s;
}

.db-chart-card {
  animation: fadeInUp 0.4s 0.12s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.db-card-panel {
  animation: fadeInUp 0.4s 0.08s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* ═══════════════════════════════════════════════════════════════
   LIGHT MODE — TEXT READABILITY & SURFACE FIXES  (final pass)
   ═══════════════════════════════════════════════════════════════ */

/* ── Settings sidebar spacer: gone in ALL modes ───────────── */
.sp-sidebar-spacer {
  display: none !important;
}

/* ── Settings page text ───────────────────────────────────── */
[data-theme="light"] .sp-title {
  color: #191c1e !important;
}
[data-theme="light"] .sp-subtitle {
  color: #64748b !important;
}
[data-theme="light"] .sp-row-title {
  color: #191c1e !important;
}
[data-theme="light"] .sp-row-sub {
  color: #64748b !important;
  opacity: 1 !important;
}
[data-theme="light"] .sp-group-label {
  color: #94a3b8 !important;
}
[data-theme="light"] .sp-row-chevron {
  color: #94a3b8 !important;
}
[data-theme="light"] .sp-sync-label {
  color: #64748b !important;
}

/* ── Dashboard stat card text ─────────────────────────────── */
[data-theme="light"] .dsc-label {
  color: #64748b !important;
}
[data-theme="light"] .db-stat-card .amount {
  color: #191c1e !important;
}
[data-theme="light"] .db-stat-card .change {
  color: #64748b !important;
}
[data-theme="light"] .income-amount {
  color: #059669 !important;
}
[data-theme="light"] .expense-amount {
  color: #ba1a1a !important;
}

/* ── Chart card text ──────────────────────────────────────── */
[data-theme="light"] .dcc-title {
  color: #191c1e !important;
}
[data-theme="light"] .dcc-legend span {
  color: #464555 !important;
}

/* ── Panel text (My Card / All Expenses / Monthly Report) ─── */
[data-theme="light"] .db-panel-title {
  color: #191c1e !important;
}
[data-theme="light"] .db-panel-sub {
  color: #64748b !important;
}
[data-theme="light"] .rp-txn-desc {
  color: #191c1e !important;
}
[data-theme="light"] .rp-txn-cat {
  color: #64748b !important;
}
[data-theme="light"] .rp-txn-amt {
  color: #191c1e !important;
}

/* ── Insights card text ───────────────────────────────────── */
[data-theme="light"] .insights-card .card-title {
  color: #191c1e !important;
}
[data-theme="light"] .insight-value {
  color: #191c1e !important;
}
[data-theme="light"] .insight-label {
  color: #64748b !important;
}
[data-theme="light"] .insights-badge {
  background: rgba(15, 23, 42, 0.05) !important;
  color: #64748b !important;
}

/* ── Add Income / Add Expense modal text ──────────────────── */
[data-theme="light"] .modal-title,
[data-theme="light"] .modal-content h2,
[data-theme="light"] .modal-content h3 {
  color: #191c1e !important;
}
[data-theme="light"] .form-label,
[data-theme="light"] .modal-content label {
  color: #464555 !important;
}
[data-theme="light"] .form-input,
[data-theme="light"] .form-select,
[data-theme="light"] .modal-content input:not([type="checkbox"]),
[data-theme="light"] .modal-content select,
[data-theme="light"] .modal-content textarea {
  background: #f2f4f6 !important;
  border: 1px solid rgba(119, 117, 135, 0.22) !important;
  color: #191c1e !important;
}
[data-theme="light"] .modal-content input::placeholder,
[data-theme="light"] .modal-content textarea::placeholder {
  color: #94a3b8 !important;
}

/* Card selector row */
[data-theme="light"] [id*="CardIndicator"],
[data-theme="light"] .card-indicator,
[data-theme="light"] .modal-card-row {
  background: #f3f4f6 !important;
  color: #191c1e !important;
  border-color: rgba(15, 23, 42, 0.09) !important;
}

/* Recurring label */
[data-theme="light"] .modal-content label {
  color: #464555 !important;
}

/* ── Set Budgets modal (blsm) ─────────────────────────────── */
[data-theme="light"] .blsm-content {
  background: #ffffff !important;
  border-color: rgba(15, 23, 42, 0.09) !important;
}
[data-theme="light"] .blsm-header *,
[data-theme="light"] [class*="blsm-title"] {
  color: #191c1e !important;
}
[data-theme="light"] .blsm-section-label {
  color: #94a3b8 !important;
}
[data-theme="light"] .blsm-content .bl-cat-name,
[data-theme="light"] .blsm-content span,
[data-theme="light"] .blsm-content p {
  color: #191c1e !important;
}
[data-theme="light"] .blsm-content input[type="number"],
[data-theme="light"] .blsm-content input[type="text"] {
  background: #f2f4f6 !important;
  border-color: rgba(119, 117, 135, 0.22) !important;
  color: #191c1e !important;
}

/* ── All Transactions page ────────────────────────────────── */
[data-theme="light"] #txnFullPage {
  background: #f4f6fb !important;
}
[data-theme="light"] .txn-page-title {
  color: #191c1e !important;
}
[data-theme="light"] .txn-month-label {
  color: #64748b !important;
  border-bottom-color: rgba(15, 23, 42, 0.07) !important;
}
[data-theme="light"] .txn-full-desc {
  color: #191c1e !important;
  font-weight: 600 !important;
}
[data-theme="light"] .txn-full-cat {
  color: #64748b !important;
}
[data-theme="light"] .txn-full-account {
  color: #64748b !important;
}
[data-theme="light"] .txn-full-row:hover {
  background: rgba(15, 23, 42, 0.025) !important;
  transform: none !important;
  box-shadow: none !important;
}
[data-theme="light"] .txn-page-search-input {
  background: #f2f4f6 !important;
  color: #191c1e !important;
}
[data-theme="light"] .txn-page-chip {
  background: #f2f4f6 !important;
  color: #464555 !important;
  border-color: rgba(15, 23, 42, 0.1) !important;
}
[data-theme="light"] .txn-page-chip--active {
  background: rgba(79, 70, 229, 0.1) !important;
  color: #4f46e5 !important;
  border-color: rgba(79, 70, 229, 0.25) !important;
}

/* ── Monthly Report modal ─────────────────────────────────── */
[data-theme="light"] .summary-label {
  color: #64748b !important;
}
[data-theme="light"] .summary-value {
  color: #191c1e !important;
}
[data-theme="light"] .summary-value.positive {
  color: #059669 !important;
}
[data-theme="light"] .summary-value.negative {
  color: #ba1a1a !important;
}
[data-theme="light"] .summary-stat {
  background: #f8f9fb !important;
  border-color: rgba(15, 23, 42, 0.07) !important;
}

/* ═══════════════════════════════════════════════════════════════
   END LIGHT MODE TEXT READABILITY FIXES
   ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
   LIGHT MODE FIX PATCH — appended, layout-safe
   Does NOT change: --bg, --glass-blur, sidebar width, any layout
   Only fixes: backdrop-filter bleed, invisible buttons/borders,
   context menu, settings icons, txn text colors, scrollbars
   ═══════════════════════════════════════════════════════════════ */

/* 2. Ghost/icon buttons — rgba(255,255,255,0.04) invisible on white */
[data-theme="light"] .tb-ghost {
  background: #edeff4 !important;
  border-color: rgba(15, 23, 42, 0.1) !important;
  color: #475569 !important;
}
[data-theme="light"] .tb-ghost:hover {
  background: #e2e5ee !important;
  color: #1e293b !important;
}
[data-theme="light"] .tb-icon,
[data-theme="light"] .tb-icon-sm {
  background: #edeff4 !important;
  border: 0.5px solid rgba(15, 23, 42, 0.1) !important;
  color: #475569 !important;
}
[data-theme="light"] .tb-icon:hover,
[data-theme="light"] .tb-icon-sm:hover {
  background: #e2e5ee !important;
  color: #1e293b !important;
}

/* 3. Sidebar active glow — dissolves on white, replace with solid tint */
[data-theme="light"] .sb-btn.active,
[data-theme="light"] .sb-btn.bn-tab--active {
  box-shadow: none !important;
}
[data-theme="light"] .sb-btn.active::before {
  box-shadow: none !important;
}

/* 4. Context menu — hardcoded #131b2e dark background */
[data-theme="light"] #contextMenu,
[data-theme="light"] #cardOptionsMenu {
  background: #ffffff !important;
  border: 0.5px solid rgba(15, 23, 42, 0.1) !important;
  box-shadow:
    0 6px 24px rgba(15, 23, 42, 0.1),
    0 2px 8px rgba(15, 23, 42, 0.06) !important;
}
[data-theme="light"] .ctx-item {
  color: #3d4252 !important;
}
[data-theme="light"] .ctx-item:hover {
  background: #f1f5f9 !important;
  color: #1a1d23 !important;
}

/* 5. Pin keys — rgba(30,41,59,0.7) = near-black on white lock screen */
[data-theme="light"] .pin-key {
  background: #edeff4 !important;
  border: 0.5px solid rgba(15, 23, 42, 0.12) !important;
  color: #1a1d23 !important;
}
[data-theme="light"] .pin-key:hover {
  background: rgba(79, 70, 229, 0.1) !important;
  color: #4f46e5 !important;
}

/* 6. Scrollbars — rgba(255,255,255,0.1) invisible on white */
[data-theme="light"] ::-webkit-scrollbar-thumb {
  background: rgba(15, 23, 42, 0.15) !important;
}
[data-theme="light"] ::-webkit-scrollbar-thumb:hover {
  background: rgba(15, 23, 42, 0.24) !important;
}

/* 7. Transaction row text colors — dark-mode values not overridden */
[data-theme="light"] .txn-full-desc {
  color: #1a1d23 !important;
}
[data-theme="light"] .txn-full-cat {
  color: #64748b !important;
}
[data-theme="light"] .txn-full-date {
  color: #94a3b8 !important;
}
[data-theme="light"] .txn-full-account {
  color: #94a3b8 !important;
}
[data-theme="light"] .txn-full-amt.pos {
  color: #059669 !important;
}
[data-theme="light"] .txn-full-amt.neg {
  color: #dc2626 !important;
}
[data-theme="light"] .txn-full-row:hover {
  background: rgba(79, 70, 229, 0.04) !important;
}

/* 8. Settings page — icon colors + toggle + label contrast */
[data-theme="light"] .sp-icon--blue {
  background: rgba(59, 130, 246, 0.1) !important;
  color: #3b82f6 !important;
}
[data-theme="light"] .sp-icon--purple {
  background: rgba(79, 70, 229, 0.1) !important;
  color: #4f46e5 !important;
}
[data-theme="light"] .sp-icon--teal {
  background: rgba(20, 184, 166, 0.12) !important;
  color: #0d9488 !important;
}
[data-theme="light"] .sp-icon--green {
  background: rgba(5, 150, 105, 0.12) !important;
  color: #059669 !important;
}
[data-theme="light"] .sp-icon--orange {
  background: rgba(234, 88, 12, 0.1) !important;
  color: #ea580c !important;
}
[data-theme="light"] .sp-icon--red {
  background: rgba(220, 38, 38, 0.1) !important;
  color: #dc2626 !important;
}
[data-theme="light"] .sp-group-label {
  color: #64748b !important;
}
[data-theme="light"] .sp-toggle-track {
  background: #cbd5e1 !important;
}
[data-theme="light"] .sp-toggle-track.on {
  background: #4f46e5 !important;
}
[data-theme="light"] .sp-row:hover {
  background: rgba(79, 70, 229, 0.04) !important;
}
[data-theme="light"] .sp-row-chevron {
  color: #94a3b8 !important;
  opacity: 0.8 !important;
}
[data-theme="light"] .sp-row:hover .sp-row-chevron {
  color: #4f46e5 !important;
  opacity: 1 !important;
}

/* 9. Chart period buttons — already partially fixed, reinforce */
[data-theme="light"] .cpc-btn {
  background: #edeff4 !important;
  border-color: rgba(15, 23, 42, 0.12) !important;
  color: #475569 !important;
}
[data-theme="light"] .cpc-btn:hover {
  background: #e2e5ee !important;
  color: #1e293b !important;
}
[data-theme="light"] .cpc-btn--active {
  background: rgba(79, 70, 229, 0.1) !important;
  border-color: rgba(79, 70, 229, 0.28) !important;
  color: #4f46e5 !important;
}

/* 10. Neon glow orbs — suppress ::after glows on light bg */
[data-theme="light"] .db-stat-card::after,
[data-theme="light"] .db-chart-card::after,
[data-theme="light"] .db-card-panel::after {
  display: none !important;
}
[data-theme="light"] .db-stat-card::before,
[data-theme="light"] .db-chart-card::before {
  background: none !important;
}

/* 11. Sidebar upgrade card */
[data-theme="light"] .sidebar-upgrade-card {
  background: rgba(79, 70, 229, 0.07) !important;
  border: 0.5px solid rgba(79, 70, 229, 0.18) !important;
}

/* END LIGHT MODE FIX PATCH */

/* ═══════════════════════════════════════════════════════════════
   LIGHT MODE MASTER OVERRIDES
   Lumina Finance — "Quietly Powerful" Glassmorphism Design System
   ═══════════════════════════════════════════════════════════════ */

/* ── Body & App Shell ──────────────────────────────────────── */
[data-theme="light"] body {
  background-color: #f7f9fb;
  color: #191c1e;
  font-family: "Inter", sans-serif;
}
[data-theme="light"] .app-container,
[data-theme="light"] .main-content {
  background-color: #f7f9fb;
}

/* ── Sidebar ────────────────────────────────────────────────── */
[data-theme="light"] .sidebar {
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-right: 1px solid rgba(255, 255, 255, 0.4);
  box-shadow: 4px 0 24px rgba(77, 68, 227, 0.04);
}

/* ── Cards (Level 2 elevation) ──────────────────────────────── */
[data-theme="light"] .card {
  background: #ffffff;
  border: 1px solid rgba(199, 196, 216, 0.5);
  border-radius: 1rem;
  box-shadow:
    0px 4px 20px rgba(0, 0, 0, 0.04),
    0px 2px 4px rgba(0, 0, 0, 0.02);
}

/* ── Modals & Overlays (Level 3 — glass) ───────────────────── */
[data-theme="light"] .modal-content {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-radius: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.4);
  border-left: 1px solid rgba(255, 255, 255, 0.4);
  border-right: 1px solid rgba(199, 196, 216, 0.3);
  border-bottom: 1px solid rgba(199, 196, 216, 0.3);
  box-shadow:
    0px 8px 40px rgba(77, 68, 227, 0.08),
    0px 2px 8px rgba(0, 0, 0, 0.04);
}

/* ── Dropdowns ──────────────────────────────────────────────── */
[data-theme="light"] .dropdown-menu {
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(199, 196, 216, 0.5);
  border-radius: 0.75rem;
  box-shadow:
    0px 8px 32px rgba(77, 68, 227, 0.08),
    0px 2px 6px rgba(0, 0, 0, 0.04);
}

/* ── Typography & Text Contrast ─────────────────────────────── */
[data-theme="light"] h1,
[data-theme="light"] h2,
[data-theme="light"] h3,
[data-theme="light"] .card-title {
  font-family: "Space Grotesk", sans-serif;
  color: #191c1e;
  letter-spacing: -0.01em;
}
[data-theme="light"] h1 {
  letter-spacing: -0.02em;
}

[data-theme="light"] p,
[data-theme="light"] .text-muted,
[data-theme="light"] .rtp-cat,
[data-theme="light"] .rtp-desc {
  color: #464555;
}

/* ── Inputs & Forms ─────────────────────────────────────────── */
[data-theme="light"] .form-input,
[data-theme="light"] input,
[data-theme="light"] select,
[data-theme="light"] textarea {
  background-color: #f2f4f6;
  color: #191c1e;
  border: 1px solid #c7c4d8;
  border-radius: 0.5rem;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}
[data-theme="light"] .form-input::placeholder,
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder {
  color: #777587;
}
[data-theme="light"] .form-input:focus,
[data-theme="light"] input:focus,
[data-theme="light"] select:focus,
[data-theme="light"] textarea:focus {
  border-color: #4f46e5;
  box-shadow: 0 0 0 3px rgba(77, 68, 227, 0.1);
  outline: none;
}

/* ── List Rows & Hover States ───────────────────────────────── */
[data-theme="light"] .rtp-row,
[data-theme="light"] .sp-row {
  border-bottom: 1px solid #e0e3e5;
  transition:
    background 0.12s ease,
    box-shadow 0.12s ease,
    transform 0.12s ease;
}
[data-theme="light"] .rtp-row:hover,
[data-theme="light"] .sp-row:hover {
  background: rgba(77, 68, 227, 0.04);
  box-shadow: 0 2px 8px rgba(77, 68, 227, 0.06);
  transform: translateY(-1px);
}

/* ── Buttons ────────────────────────────────────────────────── */
[data-theme="light"] .btn-primary,
[data-theme="light"] .button-primary {
  background: linear-gradient(135deg, #4f46e5 0%, #3525cd 100%);
  color: #ffffff;
  border: none;
  border-radius: 0.5rem;
  box-shadow:
    0 2px 8px rgba(77, 68, 227, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
  transition:
    box-shadow 0.15s ease,
    transform 0.15s ease;
}
[data-theme="light"] .btn-primary:hover,
[data-theme="light"] .button-primary:hover {
  box-shadow:
    0 4px 16px rgba(77, 68, 227, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
  transform: translateY(-1px);
}

[data-theme="light"] .btn-ghost,
[data-theme="light"] .button-ghost {
  background: transparent;
  color: #4f46e5;
  border: 1px solid rgba(77, 68, 227, 0.3);
  border-radius: 0.5rem;
  transition:
    background 0.15s ease,
    border-color 0.15s ease;
}
[data-theme="light"] .btn-ghost:hover,
[data-theme="light"] .button-ghost:hover {
  background: rgba(77, 68, 227, 0.08);
  border-color: rgba(77, 68, 227, 0.5);
}

/* ── Chips & Badges ─────────────────────────────────────────── */
[data-theme="light"] .badge,
[data-theme="light"] .chip {
  font-family: "Inter", sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  border-radius: 9999px;
  padding: 2px 10px;
}
[data-theme="light"] .badge-success {
  background: rgba(16, 185, 129, 0.1);
  color: #065f46;
}
[data-theme="light"] .badge-error {
  background: rgba(186, 26, 26, 0.1);
  color: #93000a;
}
[data-theme="light"] .badge-primary {
  background: rgba(77, 68, 227, 0.1);
  color: #3525cd;
}

/* ── Surface Containers ─────────────────────────────────────── */
[data-theme="light"] .surface-low {
  background-color: #f2f4f6;
}
[data-theme="light"] .surface-container {
  background-color: #eceef0;
}
[data-theme="light"] .surface-high {
  background-color: #e6e8ea;
}

/* ── Outline / Dividers ─────────────────────────────────────── */
[data-theme="light"] hr,
[data-theme="light"] .divider {
  border-color: #e0e3e5;
}

/* Light mode repair: late dark rebuild rules above use important dark surfaces. */
[data-theme="light"] .settings-page,
[data-theme="light"] #settingsPage {
  background: #f7f9fb !important;
  color: #191c1e !important;
}

[data-theme="light"] .sp-header {
  background: rgba(255, 255, 255, 0.8) !important;
  border-bottom: 1px solid rgba(199, 196, 216, 0.55) !important;
  box-shadow: 0 4px 20px rgba(77, 68, 227, 0.05) !important;
}

[data-theme="light"] .sp-group-body {
  background: rgba(255, 255, 255, 0.82) !important;
  border: 1px solid rgba(199, 196, 216, 0.65) !important;
  box-shadow: var(--shadow-md) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
}

[data-theme="light"] .sp-row {
  background: transparent !important;
  color: #191c1e !important;
}

[data-theme="light"] .sp-row:hover {
  background: rgba(77, 68, 227, 0.06) !important;
}

[data-theme="light"] .sp-row--divider,
[data-theme="light"] .sp-row--divider::before {
  border-color: rgba(199, 196, 216, 0.55) !important;
  background-color: rgba(199, 196, 216, 0.55) !important;
}

[data-theme="light"] .sp-title,
[data-theme="light"] .sp-row-title,
[data-theme="light"] .modal-title,
[data-theme="light"] .modal-content h2,
[data-theme="light"] .modal-content h3,
[data-theme="light"] .blsm-content h2,
[data-theme="light"] .blsm-content h3 {
  color: #191c1e !important;
}

[data-theme="light"] .sp-subtitle,
[data-theme="light"] .sp-row-sub,
[data-theme="light"] .sp-group-label,
[data-theme="light"] .modal-body,
[data-theme="light"] .modal-body p,
[data-theme="light"] .blsm-content p {
  color: #464555 !important;
}

[data-theme="light"] .sp-row-chevron {
  color: #4f46e5 !important;
}

[data-theme="light"] .modal {
  background: rgba(15, 23, 42, 0.28) !important;
}

[data-theme="light"] .modal-content,
[data-theme="light"] .blsm-content,
[data-theme="light"] .auth-popup {
  background: rgba(255, 255, 255, 0.9) !important;
  color: #191c1e !important;
  border: 1px solid rgba(199, 196, 216, 0.6) !important;
  box-shadow: var(--shadow-xl) !important;
  backdrop-filter: blur(var(--glass-blur)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
}

[data-theme="light"] .modal-header,
[data-theme="light"] .modal-footer {
  background: rgba(255, 255, 255, 0.35) !important;
  border-color: rgba(199, 196, 216, 0.5) !important;
}

[data-theme="light"] .form-label,
[data-theme="light"] .modal-content label,
[data-theme="light"] .blsm-section-label {
  color: #777587 !important;
}

[data-theme="light"] .form-input,
[data-theme="light"] .form-select,
[data-theme="light"] .modal-content input:not([type="checkbox"]),
[data-theme="light"] .modal-content select,
[data-theme="light"] .modal-content textarea,
[data-theme="light"] .blsm-content input,
[data-theme="light"] .blsm-content textarea {
  background: #f2f4f6 !important;
  color: #191c1e !important;
  border-color: rgba(199, 196, 216, 0.8) !important;
}

[data-theme="light"] .form-input::placeholder,
[data-theme="light"] .modal-content input::placeholder,
[data-theme="light"] .modal-content textarea::placeholder,
[data-theme="light"] .blsm-content input::placeholder {
  color: rgba(70, 69, 85, 0.55) !important;
}

[data-theme="light"] .add-txn-account-row,
[data-theme="light"] .card-selector,
[data-theme="light"] .modal-card-row,
[data-theme="light"] [class*="card-select"],
[data-theme="light"] [class*="switch-card"] {
  background: #f2f4f6 !important;
  border-color: rgba(199, 196, 216, 0.75) !important;
  color: #191c1e !important;
}

[data-theme="light"] .add-txn-account-row span,
[data-theme="light"] #incomeAccountName,
[data-theme="light"] #expenseAccountName {
  color: #191c1e !important;
}

[data-theme="light"] .lock-screen,
[data-theme="light"] #lockScreen {
  background: #f7f9fb !important;
}

[data-theme="light"] .lock-card,
[data-theme="light"] .lock-screen--password .lock-card {
  background: rgba(255, 255, 255, 0.9) !important;
  color: #191c1e !important;
  border: 1px solid rgba(199, 196, 216, 0.65) !important;
  box-shadow: var(--shadow-xl) !important;
}

[data-theme="light"] .lock-subtitle,
[data-theme="light"] .auth-divider {
  color: #464555 !important;
}

[data-theme="light"] #lockScreen button[onclick*="doSignOut"] {
  color: #4f46e5 !important;
}

/* ═══════════════════════════════════════════════════════════════
   END LIGHT MODE MASTER OVERRIDES
   ═══════════════════════════════════════════════════════════════ */
