/* =============================================
   UP Budget Dashboard — Design System v2
   Sidebar nav + bottom tabs, multi-page layout
   ============================================= */

/* --- Custom Properties (Apple Cupertino HIG Design System) --- */
:root {
  --bg-base: #000000;                     /* Deep OLED Black */
  --bg-surface: #1C1C1E;                  /* iOS Secondary System Background */
  --bg-elevated: #2C2C2E;                 /* iOS Tertiary System Background */
  --bg-card: rgba(28, 28, 30, 0.75);     /* iOS Translucent Glassmorphic Card */
  --bg-card-hover: rgba(44, 44, 46, 0.85);

  --accent: #0A84FF;                      /* iOS systemBlue */
  --accent-light: #30D158;                /* iOS systemGreen */
  --accent-glow: rgba(10, 132, 255, 0.15);
  --accent-gradient: linear-gradient(135deg, #0A84FF, #64D2FF); /* systemBlue to systemTeal */

  --text-primary: #FFFFFF;                /* iOS System White */
  --text-secondary: #8E8E93;              /* iOS systemGray */
  --text-muted: #AEAEB2;                  /* iOS systemGray2 */
  --credit-green: #30D158;                /* iOS systemGreen */
  --credit-green-dim: rgba(48, 209, 88, 0.12);
  --expense-red: #FF453A;                 /* iOS systemRed */
  --expense-red-dim: rgba(255, 69, 58, 0.12);
  --savings-blue: #64D2FF;                /* iOS systemTeal */

  --border-subtle: rgba(255, 255, 255, 0.08);
  --border-medium: rgba(255, 255, 255, 0.15);
  --border-accent: rgba(10, 132, 255, 0.35);

  --radius-sm: 8px;                       /* Small squircle */
  --radius-md: 12px;                      /* Cupertino medium squircle */
  --radius-lg: 20px;                      /* Cupertino large card squircle */

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.6);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.8);

  --transition-fast: 120ms cubic-bezier(0.25, 1, 0.5, 1);
  --transition-base: 320ms cubic-bezier(0.16, 1, 0.3, 1); /* Cupertino Springy Easing */

  --font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "SF Compact Text", "Helvetica Neue", Helvetica, sans-serif;

  /* Layout */
  --sidebar-w: 240px;
  --mobile-header-h: 56px;
  --mobile-nav-h: 64px;
}

/* --- Reset --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  font-size: 14px;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  touch-action: manipulation;
  overscroll-behavior: none;
  -webkit-text-size-adjust: 100%;
}
body {
  font-family: var(--font);
  background: var(--bg-base);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
}

/* Ambient glow */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse at 15% 0%, rgba(255,122,100,0.04) 0%, transparent 55%),
              radial-gradient(ellipse at 85% 100%, rgba(96,165,250,0.03) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

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

/* --- Utility --- */
.text-muted { color: var(--text-muted); font-size: 0.85rem; }
.credit-value { color: var(--credit-green) !important; }
.expense-value { color: var(--expense-red) !important; }
.savings-value { color: var(--savings-blue) !important; }
.fixed-color { color: #818CF8 !important; }
.variable-color { color: #FBBF24 !important; }
.discretionary-color { color: #F472B6 !important; }
.joint-color { color: #34D399 !important; }
.credit-color { color: #60A5FA !important; }
.hide-mobile { }

/* ========================================
   SKELETON LOADING
   ======================================== */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.03) 25%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(255, 255, 255, 0.03) 75%
  );
  background-size: 800px 100%;
  animation: shimmer 1.8s ease-in-out infinite;
  border-radius: var(--radius-sm);
  pointer-events: none;
}

.skeleton-text {
  height: 14px;
  width: 100%;
  margin-bottom: 8px;
}

.skeleton-text-sm {
  height: 11px;
  width: 60%;
  margin-bottom: 6px;
}

.skeleton-heading {
  height: 22px;
  width: 45%;
  margin-bottom: 12px;
}

.skeleton-card {
  height: 70px;
  border-radius: var(--radius-md);
  margin-bottom: 8px;
}

.skeleton-bar {
  height: 40px;
  border-radius: var(--radius-md);
  width: 100%;
}

.skeleton-circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  flex-shrink: 0;
}

.skeleton-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
}

.skeleton-row-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.skeleton-donut {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  margin: 0 auto;
}

.skeleton-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* ========================================
   SIDEBAR NAVIGATION (Desktop)
   ======================================== */
.nav-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--sidebar-w);
  height: 100vh;
  height: 100dvh;
  background: var(--bg-surface);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  z-index: 100;
  padding: 20px 12px;
}

.nav-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 8px 24px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 16px;
}

.nav-brand-logo {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  flex-shrink: 0;
  object-fit: cover;
}

.nav-brand-text {
  font-size: 1.15rem;
  font-weight: 800;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.nav-links {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  font-family: var(--font);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-align: left;
  width: 100%;
}

.nav-link:hover {
  background: var(--bg-elevated);
  color: var(--text-primary);
}

.nav-link.active {
  background: var(--accent-glow);
  color: var(--accent);
}

.nav-link.active svg {
  stroke: var(--accent);
}

.nav-footer {
  padding-top: 16px;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

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

/* Connection status */
.connection-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.connection-status-sm { gap: 0; }

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.status-dot.connected {
  background: var(--credit-green);
  box-shadow: 0 0 6px rgba(74,222,128,0.5);
  animation: pulse-dot 2s ease-in-out infinite;
}
.status-dot.disconnected { background: var(--text-muted); }
.status-dot.error { background: var(--expense-red); }

@keyframes pulse-dot { 0%,100%{opacity:1} 50%{opacity:.5} }

/* --- Sidebar User Menu --- */
.sidebar-user-menu {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sidebar-user-info {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sidebar-user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--accent-gradient);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.sidebar-user-details {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

.sidebar-user-name {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-email {
  font-size: 0.7rem;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-status {
  display: flex;
  align-items: center;
  gap: 8px;
}

.btn-logout {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 12px;
  font-size: 0.78rem;
  font-weight: 500;
  font-family: var(--font);
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  width: 100%;
}

.btn-logout:hover {
  color: var(--expense-red);
  border-color: rgba(248, 113, 113, 0.3);
  background: rgba(248, 113, 113, 0.06);
}

/* --- Mobile Header --- */
.mobile-header {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: calc(var(--mobile-header-h) + env(safe-area-inset-top, 0px));
  padding-top: env(safe-area-inset-top, 0px);
  background: rgba(11, 11, 16, 0.9);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-subtle);
  z-index: 100;
  padding-left: 20px;
  padding-right: 20px;
  align-items: center;
  justify-content: space-between;
}

.mobile-header-title {
  font-size: 1.1rem;
  font-weight: 700;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.mobile-header-right {
  display: flex;
  align-items: center;
  gap: 6px;
  position: relative;
}

.mobile-user-btn {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
}

.mobile-user-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: var(--bg-surface);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  padding: 14px;
  min-width: 200px;
  box-shadow: var(--shadow-lg);
  z-index: 300;
  flex-direction: column;
  gap: 10px;
}

.mobile-user-dropdown.visible {
  display: flex;
}

.mobile-user-dropdown-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-subtle);
}

/* ========================================
   PAGE CONTAINER
   ======================================== */
.page-container {
  position: relative;
  z-index: 1;
  margin-left: var(--sidebar-w);
  padding: 24px;
  min-height: 100vh;
}

.page {
  display: none;
  flex-direction: column;
  gap: 20px;
  animation: pageIn 0.3s ease-out;
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
}

.page.active {
  display: flex;
}

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

/* ========================================
   SECTION CARDS
   ======================================== */
.section-card {
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 20px;
  transition: border-color var(--transition-base);
}

.section-card:hover {
  border-color: var(--border-medium);
}

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

.section-heading {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 1rem;
  font-weight: 600;
}

.section-heading-sm {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
  text-align: center;
}

/* ========================================
   BUTTONS
   ======================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}
.btn-sm { padding: 5px 10px; font-size: 0.8rem; }
.btn-outline {
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--border-accent);
}
.btn-outline:hover { background: var(--accent-glow); }
.btn-accent {
  background: var(--accent-gradient);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(255,122,100,0.2);
}
.btn-accent:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(255,122,100,0.3); }
.btn-danger {
  background: transparent;
  color: var(--expense-red);
  padding: 4px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}
.btn-danger:hover { background: var(--expense-red-dim); }

.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.btn-icon:hover { background: var(--bg-elevated); color: var(--text-primary); }

.row-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}
.row-actions .btn-icon,
.row-actions .btn-danger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  background: transparent !important;
  color: var(--text-secondary) !important;
  cursor: pointer !important;
  transition: all var(--transition-fast) !important;
  vertical-align: middle !important;
}

.row-actions .btn-icon:hover {
  background: var(--bg-elevated) !important;
  color: var(--text-primary) !important;
}

.row-actions .btn-danger {
  color: var(--expense-red) !important;
}

.row-actions .btn-danger:hover {
  background: var(--expense-red-dim) !important;
  color: var(--expense-red) !important;
}

.row-actions .btn-bill-toggle.excluded {
  color: var(--text-muted) !important;
}
.row-actions .btn-bill-toggle:not(.excluded) {
  color: var(--credit-green) !important;
}
.row-actions .btn-bill-toggle:not(.excluded):hover {
  background: var(--credit-green-dim) !important;
}

/* ========================================
   ACCOUNTS
   ======================================== */
.accounts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
}

.account-card {
  padding: 16px;
  background: var(--bg-elevated);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  transition: all var(--transition-base);
}
.account-card:hover { border-color: var(--border-accent); box-shadow: 0 0 16px var(--accent-glow); }
.account-card-name { font-size: 0.75rem; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.5px; font-weight: 500; margin-bottom: 4px; }
.account-card-balance { font-size: 1.3rem; font-weight: 700; }
.account-card-type { font-size: 0.7rem; color: var(--text-muted); margin-top: 4px; }
.account-placeholder { text-align: center; padding: 20px; color: var(--text-muted); grid-column: 1 / -1; }
.account-placeholder code { font-family: 'Consolas', monospace; background: var(--bg-elevated); padding: 2px 6px; border-radius: 4px; font-size: 0.85rem; }

/* ========================================
   SUMMARY STRIP (Overview)
   ======================================== */
.summary-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.summary-card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  transition: border-color var(--transition-base);
}
.summary-card:hover { border-color: var(--border-medium); }

.summary-card-highlight {
  background: linear-gradient(135deg, rgba(96,165,250,0.08), rgba(74,222,128,0.06));
  border-color: rgba(96,165,250,0.15);
}

.summary-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.income-icon { background: rgba(255,122,100,0.12); color: var(--accent); }
.expense-icon { background: var(--expense-red-dim); color: var(--expense-red); }
.credit-icon { background: var(--credit-green-dim); color: var(--credit-green); }
.savings-icon { background: rgba(96,165,250,0.12); color: var(--savings-blue); }

.summary-card-body { flex: 1; min-width: 0; }
.summary-label { font-size: 0.72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; font-weight: 500; display: block; }
.summary-value { font-size: 1.35rem; font-weight: 800; font-variant-numeric: tabular-nums; display: block; margin-top: 2px; }

/* Overview bottom row */
.overview-bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.savings-ring-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px;
}

.savings-ring-container { width: 130px; height: 130px; }
.savings-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke: var(--bg-elevated); stroke-width: 8; }
.ring-fill {
  fill: none;
  stroke: url(#ringGradient);
  stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 326.73;
  stroke-dashoffset: 326.73;
  transition: stroke-dashoffset 1s ease-out;
}
.ring-text { fill: var(--text-primary); font-size: 24px; font-weight: 800; text-anchor: middle; dominant-baseline: middle; transform: rotate(90deg); transform-origin: 60px 60px; font-family: var(--font); }
.ring-subtext { fill: var(--text-muted); font-size: 11px; font-weight: 500; text-anchor: middle; transform: rotate(90deg); transform-origin: 60px 60px; font-family: var(--font); }

.income-card { padding: 24px; text-align: center; }

.income-input-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.currency-symbol { font-size: 1.4rem; font-weight: 700; color: var(--accent); }
.income-input {
  font-family: var(--font);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--border-subtle);
  padding: 4px 6px;
  width: 160px;
  outline: none;
  transition: border-color var(--transition-fast);
  text-align: center;
}
.income-input:focus { border-color: var(--accent); }
.income-input::-webkit-inner-spin-button,
.income-input::-webkit-outer-spin-button { -webkit-appearance: none; }
.income-input { -moz-appearance: textfield; }

.quick-stats {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border-subtle);
}
.quick-stat { flex: 1; text-align: center; }
.quick-stat-label { display: block; font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.quick-stat-value { display: block; font-size: 0.95rem; font-weight: 700; color: var(--text-secondary); margin-top: 2px; font-variant-numeric: tabular-nums; }

/* ========================================
   BUDGET TABLES
   ======================================== */
.budget-table-wrap { overflow-x: auto; margin: 0 -8px; padding: 0 8px; }

.budget-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.85rem;
}

.budget-table thead th {
  text-align: left;
  padding: 6px 8px;
  color: var(--text-muted);
  font-weight: 500;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border-subtle);
  white-space: nowrap;
}

.budget-table tbody tr { transition: background var(--transition-fast); }
.budget-table tbody tr:hover { background: var(--bg-card-hover); }
.budget-table td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  vertical-align: middle;
}

.col-name { min-width: 120px; }
.col-amount { min-width: 80px; width: 90px; }
.col-freq { min-width: 100px; width: 110px; }
.col-monthly { min-width: 80px; width: 90px; }
.col-comment { min-width: 80px; }
.col-actions { min-width: 90px; width: 100px; }

.budget-table input[type="text"],
.budget-table input[type="number"] {
  font-family: var(--font);
  font-size: 0.85rem;
  color: var(--text-primary);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 4px 6px;
  width: 100%;
  outline: none;
  transition: all var(--transition-fast);
}
.budget-table input:hover { border-color: var(--border-medium); }
.budget-table input:focus { border-color: var(--accent); background: var(--bg-elevated); }
.budget-table input[type="number"] { text-align: right; font-variant-numeric: tabular-nums; }
.budget-table input[type="number"]::-webkit-inner-spin-button,
.budget-table input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; }
.budget-table input[type="number"] { -moz-appearance: textfield; }

.budget-table select,
.select-input {
  font-family: var(--font);
  font-size: 0.85rem;
  color: var(--text-primary);
  background: var(--bg-elevated);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  padding: 8px 28px 8px 10px;
  cursor: pointer;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239898AA' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.select-input:focus, .budget-table select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 122, 100, 0.1);
}
.budget-table select option { background: var(--bg-elevated); color: var(--text-primary); }

.monthly-cost {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: right;
  padding-right: 12px !important;
}

.subtotal-row td { border-top: 1px solid var(--border-medium); border-bottom: none; padding-top: 12px; }
.subtotal-label { text-align: right; font-weight: 600; color: var(--text-secondary); padding-right: 12px !important; }
.subtotal-value { font-weight: 700; font-variant-numeric: tabular-nums; text-align: right; padding-right: 12px !important; font-size: 0.95rem; }

.budget-table tbody tr { animation: rowIn 0.25s ease-out; }
@keyframes rowIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

/* ========================================
   TRANSACTIONS
   ======================================== */
.txn-header-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.transactions-search {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  margin-bottom: 12px;
  color: var(--text-muted);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.transactions-search:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 122, 100, 0.1);
}
.search-input { font-family: var(--font); font-size: 0.9rem; color: var(--text-primary); background: transparent; border: none; outline: none; width: 100%; }
.search-input::placeholder { color: var(--text-muted); }

.transactions-month-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 12px;
}
.month-label { font-size: 0.95rem; font-weight: 600; min-width: 120px; text-align: center; }

.transactions-summary-bar {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 12px;
  padding: 8px;
  background: var(--bg-elevated);
  border-radius: var(--radius-md);
}
.txn-summary-item { text-align: center; }
.txn-summary-label { display: block; font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.txn-summary-value { display: block; font-size: 0.95rem; font-weight: 700; font-variant-numeric: tabular-nums; }

.transactions-list {
  max-height: calc(100vh - 340px);
  max-height: calc(100dvh - 340px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.transactions-list-compact { max-height: 320px; }

.transactions-placeholder {
  text-align: center;
  padding: 32px 16px;
  color: var(--text-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.txn-day-group { margin-bottom: 6px; }
.txn-day-header {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 8px 4px;
  position: sticky;
  top: 0;
  background: var(--bg-card);
  backdrop-filter: blur(8px);
  z-index: 1;
}

.txn-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
  animation: txnIn 0.25s ease-out;
}
.txn-item:hover { background: var(--bg-card-hover); }
@keyframes txnIn { from { opacity:0; transform:translateX(-6px); } to { opacity:1; transform:translateX(0); } }

.txn-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  background: var(--bg-elevated);
}
.txn-details { flex: 1; min-width: 0; }
.txn-description { font-size: 0.85rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.txn-category { display: inline-block; font-size: 0.68rem; color: var(--text-muted); background: var(--bg-elevated); padding: 1px 6px; border-radius: 100px; margin-top: 2px; }
.txn-amount { font-size: 0.9rem; font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; flex-shrink: 0; }
.txn-amount.debit { color: var(--text-primary); }
.txn-amount.credit { color: var(--credit-green); }

/* Internal transfers — visually dimmed so they don't look like real spending */
.txn-transfer { opacity: 0.45; }
.txn-transfer:hover { opacity: 0.7; }
.txn-category-transfer { background: rgba(255,255,255,0.06); color: var(--text-muted); font-style: italic; }
.txn-amount-transfer { color: var(--text-muted) !important; }

.transactions-load-more { padding: 12px; text-align: center; }

/* ========================================
   ANALYTICS PAGE
   ======================================== */

/* Analytics Header */
.analytics-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  margin-bottom: 4px;
  flex-wrap: wrap;
}

.analytics-header-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.analytics-title {
  font-size: 1.15rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-primary);
  margin: 0;
}

.analytics-subtitle {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-glow);
  padding: 3px 10px;
  border-radius: 100px;
  border: 1px solid var(--border-accent);
}

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

.analytics-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 6px 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  min-width: 70px;
}

.analytics-pill-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-muted);
}

.analytics-pill-value {
  font-size: 1rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

/* Side-by-side duo row */
.analytics-duo-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.analytics-chart-card {
  display: flex;
  flex-direction: column;
}

.analytics-merchants-card {
  display: flex;
  flex-direction: column;
}

/* ========================================
   CHARTS
   ======================================== */
.chart-container { display: flex; justify-content: center; align-items: center; min-height: 180px; }
.chart-placeholder { text-align: center; padding: 32px; }
.donut-chart { width: 220px; height: 220px; }

.chart-legend {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  padding: 4px 0;
}
.legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.legend-value {
  margin-left: auto;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

/* Budget vs Actual */
.bva-container { display: flex; flex-direction: column; gap: 8px; }
.bva-row { display: grid; grid-template-columns: 90px 1fr 65px; gap: 8px; align-items: center; font-size: 0.8rem; }
.bva-label { color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bva-bar-track { height: 18px; background: var(--bg-elevated); border-radius: 4px; overflow: hidden; position: relative; }
.bva-bar-budget { position: absolute; top: 0; left: 0; height: 100%; background: rgba(255,122,100,0.15); border-right: 2px dashed var(--accent); transition: width 0.6s ease; }
.bva-bar-actual { position: absolute; top: 0; left: 0; height: 100%; border-radius: 4px; transition: width 0.6s ease; }
.bva-bar-actual.under { background: linear-gradient(90deg, rgba(74,222,128,0.25), rgba(74,222,128,0.45)); }
.bva-bar-actual.over { background: linear-gradient(90deg, rgba(248,113,113,0.25), rgba(248,113,113,0.45)); }
.bva-amount { text-align: right; font-weight: 600; font-variant-numeric: tabular-nums; color: var(--text-secondary); }

/* ========================================
   RESPONSIVE — Mobile
   ======================================== */
@media (max-width: 768px) {
  /* Hide desktop sidebar */
  .nav-sidebar {
    position: fixed;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: calc(var(--mobile-nav-h) + env(safe-area-inset-bottom, 0px));
    padding-bottom: env(safe-area-inset-bottom, 0px);
    flex-direction: row;
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
    border-right: none;
    border-top: 1px solid var(--border-medium);
    background: rgba(11,11,16,0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 200;
  }

  .nav-brand,
  .nav-footer { display: none; }

  .nav-links {
    flex-direction: row;
    width: 100%;
    justify-content: space-around;
    padding: 0 8px;
    gap: 0;
  }

  .nav-link {
    flex-direction: column;
    gap: 3px;
    padding: 8px 4px;
    font-size: 0.65rem;
    justify-content: center;
    align-items: center;
    border-radius: 0;
    flex: 1;
  }

  .nav-link svg { width: 20px; height: 20px; }

  .nav-link.active {
    background: transparent;
    position: relative;
  }
  .nav-link.active::after {
    content: '';
    position: absolute;
    top: 0;
    left: 30%;
    right: 30%;
    height: 2px;
    background: var(--accent-gradient);
    border-radius: 0 0 2px 2px;
  }

  /* Show mobile header */
  .mobile-header { display: flex; }

  /* Adjust page container */
  .page-container {
    margin-left: 0;
    padding: calc(var(--mobile-header-h) + env(safe-area-inset-top, 0px) + 12px) 12px calc(var(--mobile-nav-h) + env(safe-area-inset-bottom, 0px) + 12px);
  }

  /* Summary strip — stack 2x2 */
  .summary-strip {
    grid-template-columns: 1fr 1fr;
  }

  .summary-card { padding: 12px; }
  .summary-icon { width: 32px; height: 32px; }
  .summary-icon svg { width: 16px; height: 16px; }
  .summary-value { font-size: 1.15rem; }

  /* Overview bottom row — stack */
  .overview-bottom-row {
    grid-template-columns: 1fr;
  }

  /* Hide notes column */
  .hide-mobile { display: none; }

  /* Analytics mobile */
  .analytics-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 14px;
  }

  .analytics-header-left {
    flex-wrap: wrap;
    gap: 8px;
  }

  .analytics-title {
    font-size: 1rem;
  }

  .analytics-summary-pills {
    width: 100%;
    justify-content: space-between;
  }

  .analytics-pill {
    padding: 5px 8px;
    min-width: 0;
    flex: 1;
  }

  .analytics-pill-value {
    font-size: 0.88rem;
  }

  .analytics-duo-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .page {
    gap: 12px !important;
  }

  /* Section card padding & margins */
  .section-card { 
    padding: 14px !important; 
    border-radius: var(--radius-md) !important; 
  }

  .section-card-header {
    margin-bottom: 12px !important;
  }

  /* Collapsible Accordion Cards for Mobile */
  .collapsible-card.collapsed > :not(.section-card-header) {
    display: none !important;
  }

  .collapsible-card.collapsed {
    padding-bottom: 14px !important;
  }

  .collapsible-card.collapsed .section-card-header {
    margin-bottom: 0 !important;
  }

  .collapsible-card .section-card-header {
    cursor: pointer;
    position: relative;
    padding-right: 28px !important;
    width: 100%;
  }

  .collapsible-card .section-card-header::after {
    content: '';
    position: absolute;
    right: 4px;
    top: 50%;
    width: 6px;
    height: 6px;
    border-right: 2px solid var(--text-muted);
    border-bottom: 2px solid var(--text-muted);
    transform: translateY(-70%) rotate(-135deg); /* Chevron Up */
    transition: transform var(--transition-base);
    pointer-events: none;
  }

  .collapsible-card.collapsed .section-card-header::after {
    transform: translateY(-70%) rotate(45deg); /* Chevron Down */
  }

  /* Budget table font */
  .budget-table { font-size: 0.8rem; }
  .budget-table thead th { font-size: 0.68rem; padding: 4px 6px; }
  .budget-table td { padding: 5px 6px; }

  /* Transaction list full height on mobile */
  .transactions-list {
    max-height: calc(100vh - 380px);
    max-height: calc(100dvh - 380px);
  }

  /* Accounts grid */
  .accounts-grid {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 8px;
  }
  .account-card { padding: 12px; }
  .account-card-balance { font-size: 1.1rem; }
}

@media (max-width: 380px) {
  .summary-strip { grid-template-columns: 1fr; }
  .summary-value { font-size: 1.3rem; }
}

/* ========================================
   MISC
   ======================================== */
.value-updating { animation: valFlash 0.3s ease; }
@keyframes valFlash { 0% { opacity: 0.5; transform: scale(0.98); } 100% { opacity: 1; transform: scale(1); } }

.spinner { width: 20px; height: 20px; border: 2px solid var(--border-subtle); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

.toast-container { position: fixed; bottom: 80px; right: 16px; z-index: 1000; display: flex; flex-direction: column; gap: 8px; }
@media (min-width: 769px) { .toast-container { bottom: 24px; right: 24px; } }
.toast { padding: 12px 16px; border-radius: var(--radius-md); background: var(--bg-elevated); border: 1px solid var(--border-medium); color: var(--text-primary); font-size: 0.85rem; box-shadow: var(--shadow-lg); animation: toastIn 0.3s ease-out; max-width: 320px; }
.toast.success { border-color: rgba(74,222,128,0.3); background: linear-gradient(135deg, var(--bg-elevated), rgba(74,222,128,0.05)); }
.toast.error { border-color: rgba(248,113,113,0.3); background: linear-gradient(135deg, var(--bg-elevated), rgba(248,113,113,0.05)); }
@keyframes toastIn { from { opacity:0; transform:translateY(10px) scale(0.95); } to { opacity:1; transform:translateY(0) scale(1); } }

/* ========================================
   PHASE 2 - COMPONENT STYLES
   ======================================== */

/* --- Bill Tracker --- */
.bill-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  transition: all var(--transition-fast);
}
.bill-item:hover {
  background: var(--bg-card-hover);
  border-color: var(--border-medium);
}
.bill-icon {
  font-size: 1.2rem;
  width: 28px;
  text-align: center;
}
.bill-details {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.bill-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
}
.bill-meta {
  font-size: 0.75rem;
  color: var(--text-secondary);
}
.bill-status-info {
  text-align: right;
}
.bill-status-label {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bill-paid-info {
  font-size: 0.8rem;
  color: var(--credit-green);
  font-weight: 500;
}

/* Status variants */
.bill-paid { border-left: 3px solid var(--credit-green); }
.bill-partially { border-left: 3px solid #FBBF24; }
.bill-partially .bill-status-label { background: rgba(251, 191, 36, 0.12); color: #FBBF24; }
.bill-partially .bill-paid-info { color: #FBBF24; }
.bill-overdue { border-left: 3px solid var(--expense-red); }
.bill-overdue .bill-status-label { background: var(--expense-red-dim); color: var(--expense-red); }
.bill-due-soon { border-left: 3px solid var(--accent); }
.bill-due-soon .bill-status-label { background: var(--accent-glow); color: var(--accent); }
.bill-upcoming { border-left: 3px solid var(--savings-blue); }
.bill-upcoming .bill-status-label { background: rgba(96, 165, 250, 0.12); color: var(--savings-blue); }
.bill-pending { border-left: 3px solid var(--text-muted); }
.bill-pending .bill-status-label { background: rgba(255, 255, 255, 0.05); color: var(--text-secondary); }

/* --- Daily Allowance --- */
.allowance-card {
  background: linear-gradient(135deg, rgba(255, 122, 100, 0.08), rgba(25, 25, 38, 0.8));
  border-color: rgba(255, 122, 100, 0.15);
}
.allowance-main {
  text-align: center;
  padding: 12px 0;
}
.allowance-daily {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
}
.allowance-currency {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--accent);
  margin-right: 2px;
}
.allowance-amount {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -1px;
}
.allowance-unit {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-left: 2px;
}
.allowance-sublabel {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: 4px;
}
.allowance-today {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  margin: 12px 0;
  font-size: 0.85rem;
}
.allowance-today-label {
  font-weight: 600;
  color: var(--text-secondary);
}
.allowance-today-value {
  color: var(--text-primary);
}
.allowance-today-remaining {
  font-weight: 700;
}

/* Progress bar */
.allowance-progress {
  margin-top: 14px;
}
.allowance-bar-track {
  height: 8px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 4px;
  position: relative;
  overflow: visible;
}
.allowance-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s ease;
}
.allowance-bar-marker {
  position: absolute;
  top: -3px;
  width: 4px;
  height: 14px;
  background: #FFF;
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(255,255,255,0.8);
  transform: translateX(-50%);
  z-index: 2;
}
.allowance-bar-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 6px;
  font-weight: 500;
}

/* --- Sidebar Pay Period Tracker --- */
.sidebar-pay-period {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: var(--radius-md);
  padding: 10px;
  margin: 12px 8px;
}

.sidebar-period-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.72rem;
  margin-bottom: 6px;
}

.sidebar-period-label {
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sidebar-period-dates {
  color: var(--text-secondary);
  font-weight: 500;
}

.sidebar-period-track {
  height: 5px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 100px;
  overflow: hidden;
}

.sidebar-period-fill {
  height: 100%;
  background: var(--accent-gradient);
  border-radius: 100px;
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 0 6px rgba(255, 122, 100, 0.4);
}

@media (max-width: 768px) {
  .sidebar-pay-period {
    display: none !important;
  }
}

/* Pay period sidebar settings panel */
.pay-settings {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 10px;
  margin: 8px 0;
  font-size: 0.82rem;
}
.pay-settings-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pay-settings-label {
  font-weight: 600;
  color: var(--text-secondary);
}
.pay-settings-fields {
  margin-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.04);
  padding-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pay-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pay-field label {
  font-size: 0.72rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.pay-input {
  width: 100%;
  background: var(--bg-elevated);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-family: var(--font);
  font-size: 0.92rem;
  padding: 10px 12px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  -webkit-appearance: none;
}
.pay-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 122, 100, 0.1);
}

/* Toggle switch stylings */
.toggle-switch {
  position: relative;
  display: inline-block;
  width: 32px;
  height: 18px;
  flex-shrink: 0;
}
.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.toggle-slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background-color: var(--text-muted);
  transition: .3s;
  border-radius: 34px;
}
.toggle-slider:before {
  position: absolute;
  content: "";
  height: 12px;
  width: 12px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: .3s;
  border-radius: 50%;
}
.toggle-switch input:checked + .toggle-slider {
  background-image: var(--accent-gradient);
}
.toggle-switch input:checked + .toggle-slider:before {
  transform: translateX(14px);
}

/* --- Recurring Alert --- */
.recurring-ok {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: rgba(74, 222, 128, 0.05);
  border: 1px solid rgba(74, 222, 128, 0.15);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: 0.85rem;
}
.recurring-ok-icon {
  font-size: 1.1rem;
}
.recurring-alert-header {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
}
.recurring-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 4px;
  font-size: 0.85rem;
}
.recurring-unbudgeted {
  border-left: 3px solid var(--expense-red);
}
.recurring-price-change {
  border-left: 3px solid var(--savings-blue);
}
.recurring-item-info {
  display: flex;
  flex-direction: column;
}
.recurring-item-name {
  font-weight: 600;
  color: var(--text-primary);
}
.recurring-item-meta {
  font-size: 0.72rem;
  color: var(--text-muted);
}
.recurring-item-amount {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* --- Merchants list --- */
.merchant-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  font-size: 0.85rem;
  transition: background 0.15s ease;
}
.merchant-row:hover {
  background: rgba(255, 255, 255, 0.02);
}
.merchant-row:last-child {
  border-bottom: none;
}
.merchant-rank {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--accent);
  background: var(--accent-glow);
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.merchant-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.merchant-name {
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.merchant-bar-track {
  height: 5px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 3px;
  margin: 5px 0;
}
.merchant-bar-fill {
  height: 100%;
  background: var(--accent-gradient);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.merchant-meta {
  font-size: 0.72rem;
  color: var(--text-muted);
}
.merchant-total {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
  font-size: 0.9rem;
}

/* --- Forecast SVG chart --- */
.forecast-chart {
  width: 100%;
  height: auto;
  display: block;
}

/* ========================================
   PHASE 3 - NEW UX RE-ARCHITECTING STYLES
   ======================================== */

/* --- Due Day column --- */
.col-due {
  width: 70px !important;
  min-width: 60px !important;
  text-align: center;
}
.budget-table td:nth-child(5) input {
  text-align: center !important;
}

/* --- Compact Accounts Row layout --- */
.accounts-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.account-card-compact {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  transition: all var(--transition-base);
}
.account-card-compact:hover {
  border-color: var(--border-accent);
  box-shadow: 0 0 12px var(--accent-glow);
}
.account-compact-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.account-compact-icon {
  font-size: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-sm);
}
.account-compact-name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary);
}
.account-compact-right {
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: right;
}
.account-compact-balance {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.account-compact-change {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 100px;
  font-variant-numeric: tabular-nums;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.account-compact-change.credit {
  background: var(--credit-green-dim);
  color: var(--credit-green);
}
.account-compact-change.debit {
  background: var(--expense-red-dim);
  color: var(--expense-red);
}

/* --- Premium Unified Allowance Dashboard Widget --- */
.allowance-dashboard-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

/* Dashboard Header */
.allowance-dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  padding-bottom: 12px;
}

.allowance-header-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.period-dates-pill {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
}

.period-subtitle-label {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.allowance-pace-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 100px;
  border: 1px solid;
  transition: all var(--transition-base);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.pace-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  animation: pulse-dot-anim 1.8s ease-in-out infinite;
}

@keyframes pulse-dot-anim {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.8); }
}

/* 3-Column Stats Grid */
.allowance-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.allowance-stat-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-md);
  padding: 14px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 6px;
  transition: all var(--transition-base);
  min-width: 0;
}

.allowance-stat-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  transform: translateY(-1px);
}

.stat-card-label {
  font-size: 0.72rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.stat-card-value {
  display: flex;
  align-items: baseline;
  line-height: 1.1;
  font-weight: 800;
  color: var(--text-primary);
}

.stat-card-value.rate-value {
  color: var(--text-primary);
}

.stat-card-value .currency {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--accent-light);
  margin-right: 1px;
}

.stat-card-value .number {
  font-size: 1.8rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.5px;
}

.stat-card-value .sub {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-left: 2px;
}

.stat-card-value.positive {
  color: var(--credit-green);
  text-shadow: 0 0 10px rgba(74, 222, 128, 0.15);
}

.stat-card-value.negative {
  color: var(--expense-red);
  text-shadow: 0 0 10px rgba(248, 113, 113, 0.15);
}

.stat-card-footer {
  font-size: 0.82rem;
  color: var(--text-secondary);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Dual Progress Tracks Section */
.allowance-tracks-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: rgba(0, 0, 0, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-md);
  padding: 16px;
}

.allowance-track-wrapper {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.track-labels {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.85rem;
  font-weight: 600;
}

.track-label-left {
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 6px;
}

.track-icon {
  font-size: 0.95rem;
}

.track-label-right {
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}

.track-progress-bar {
  height: 8px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 100px;
  position: relative;
  overflow: visible;
}

.track-fill {
  height: 100%;
  border-radius: 100px;
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.time-fill {
  background: linear-gradient(90deg, #FF7A64, #FF9E53);
  box-shadow: 0 0 8px rgba(255, 122, 100, 0.3);
}

.budget-fill {
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.3s ease;
}

.track-marker {
  position: absolute;
  top: -4px;
  width: 4px;
  height: 16px;
  background: #FFF;
  border-radius: 2px;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.9);
  transform: translateX(-50%);
  z-index: 5;
  animation: pulse-marker-anim 2s ease-in-out infinite;
}

@keyframes pulse-marker-anim {
  0%, 100% { opacity: 0.85; }
  50% { opacity: 0.45; }
}

/* Mobile responsive adjustments for Allowance */
@media (max-width: 768px) {
  .allowance-dashboard-container {
    gap: 14px;
  }

  .allowance-dashboard-header {
    gap: 6px;
    padding-bottom: 10px;
  }

  .period-badge {
    font-size: 0.62rem;
    padding: 2px 6px;
  }

  .period-dates-pill {
    font-size: 0.75rem;
  }

  .allowance-pace-badge {
    font-size: 0.72rem;
    padding: 3px 8px;
  }

  .allowance-stats-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .allowance-stat-card {
    padding: 12px;
  }

  .stat-card-value {
    font-size: 1.3rem;
  }

  .allowance-tracks-section {
    padding: 12px;
    gap: 12px;
  }

  .track-labels {
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
    font-size: 0.92rem;
  }

  .track-label-right {
    font-size: 0.85rem;
  }
}

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

/* Full-width token card with accent border glow */
.settings-card-highlight {
  border: 1px solid var(--border-accent);
  background: linear-gradient(135deg, rgba(255,122,100,0.04), rgba(255,158,83,0.02));
}

.settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.settings-column {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Token card layout */
.settings-token-layout {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.settings-token-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
}

.settings-token-dot-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.settings-token-status-text {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-secondary);
}

.settings-token-masked {
  font-size: 0.78rem;
  color: var(--text-muted);
  font-family: 'Courier New', monospace;
  background: var(--bg-elevated);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-subtle);
  word-break: break-all;
}

.settings-token-input-row {
  display: flex;
  align-items: flex-end;
  gap: 12px;
}

.settings-token-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.settings-token-actions .btn {
  padding: 10px 16px;
}

.settings-btn-danger {
  color: #f87171 !important;
  border-color: rgba(248, 113, 113, 0.3) !important;
}
.settings-btn-danger:hover {
  background: rgba(248, 113, 113, 0.08) !important;
}

/* Form elements */
.settings-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.settings-input {
  width: 100%;
  padding: 10px 12px;
  font-size: 0.92rem;
  font-family: var(--font);
  background: var(--bg-elevated);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
  -webkit-appearance: none;
}

.settings-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 122, 100, 0.1);
}

.settings-hint {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 4px;
}
.settings-hint a {
  color: var(--accent);
  text-decoration: none;
}
.settings-hint a:hover {
  text-decoration: underline;
}

.settings-field-group {
  display: flex;
  flex-direction: column;
}

.settings-fields-group {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border-subtle);
}

.settings-toggle-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.settings-toggle-label {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--text-primary);
}

.settings-checkbox-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 360px;
  overflow-y: auto;
  padding: 14px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(8px);
}

.settings-btn-row {
  display: flex;
  gap: 10px;
}

.settings-btn-row .btn {
  padding: 10px 16px;
}

/* Mobile responsive */
@media (max-width: 992px) {
  .settings-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .settings-token-status-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .settings-token-input-row {
    flex-direction: column;
    align-items: stretch;
  }

  .settings-token-actions {
    display: flex;
    width: 100%;
  }

  .settings-token-actions .btn {
    flex: 1;
    justify-content: center;
  }
}

/* ========================================
   SAVINGS GOALS VIEW STYLES
   ======================================== */

.goals-stats-card {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.08), rgba(25, 25, 38, 0.8));
  border-color: rgba(16, 185, 129, 0.15);
  margin-bottom: 24px;
}

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

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

.goals-stat-label {
  font-size: 0.72rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.goals-stat-value {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}

.goals-progress-overview {
  margin-bottom: 20px;
}

.goals-progress-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.goals-progress-bar-wrap {
  height: 8px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 100px;
  overflow: hidden;
}

.goals-progress-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #10B981, #3B82F6);
  border-radius: 100px;
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 0 8px rgba(16, 185, 129, 0.4);
}

.goals-feasibility-bar {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-md);
}

.feasibility-status-icon {
  font-size: 1.2rem;
  line-height: 1;
}

.feasibility-status-details {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.feasibility-status-title {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-primary);
}

.feasibility-status-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

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

.goals-grid-title {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--text-primary);
}

.goals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
}

/* Individual Goal Cards */
.goal-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all var(--transition-base);
  overflow: hidden;
}

.goal-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.3), 0 0 20px rgba(255, 255, 255, 0.02);
}

.goal-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.goal-card-icon-title {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.goal-card-emoji {
  font-size: 1.8rem;
  width: 44px;
  height: 44px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.05);
  flex-shrink: 0;
}

.goal-card-meta {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.goal-card-name {
  font-size: 1.05rem;
  font-weight: 750;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.goal-card-date {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 2px;
}

/* Status Badges */
.goal-badge {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.goal-badge.completed {
  background: var(--credit-green-dim);
  color: var(--credit-green);
  border: 1px solid rgba(74, 222, 128, 0.2);
}

.goal-badge.on-track {
  background: rgba(16, 185, 129, 0.1);
  color: #10B981;
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.goal-badge.behind {
  background: rgba(248, 113, 113, 0.1);
  color: #F87171;
  border: 1px solid rgba(248, 113, 113, 0.2);
}

.goal-card-balance-block {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.goal-card-saved {
  font-size: 1.4rem;
  font-weight: 850;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}

.goal-card-target {
  font-size: 0.82rem;
  color: var(--text-muted);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* Timeline & Required Contribution section */
.goal-timeline-block {
  background: rgba(0, 0, 0, 0.12);
  border-radius: var(--radius-md);
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.02);
}

.goal-timeline-title {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}

.goal-timeline-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.goal-timeline-box {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: center;
}

.goal-timeline-box:not(:last-child) {
  border-right: 1px solid rgba(255, 255, 255, 0.04);
}

.goal-timeline-box-value {
  font-size: 0.88rem;
  font-weight: 750;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}

.goal-timeline-box-label {
  font-size: 0.65rem;
  color: var(--text-muted);
}

.goal-card-actions {
  display: flex;
  gap: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  padding-top: 12px;
  margin-top: 4px;
}

.goal-card-actions .btn {
  flex: 1;
  justify-content: center;
  gap: 6px;
  padding: 8px 12px;
  font-size: 0.8rem;
}

.goal-link-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  color: var(--text-secondary);
}

.goal-link-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-muted);
}

.goal-link-dot.active {
  background: #3B82F6;
  box-shadow: 0 0 6px rgba(59, 130, 246, 0.6);
  animation: pulse-dot-anim 2s ease-in-out infinite;
}

/* Modal Overlay Styling */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(5, 5, 8, 0.65);
  backdrop-filter: blur(10px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fadeIn 0.2s ease;
}

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

.modal-card {
  background: rgba(20, 20, 30, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-lg);
  max-width: 460px;
  width: 100%;
  padding: 24px;
  box-shadow: 0 20px 50px -12px rgba(0, 0, 0, 0.5);
  animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

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

.modal-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  padding-bottom: 12px;
}

.modal-card-title {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--text-primary);
}

.modal-close-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s ease;
  border-radius: 50%;
}

.modal-close-btn:hover {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.form-group {
  margin-bottom: 16px;
}

.form-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.goal-icon-picker {
  display: flex;
  justify-content: space-between;
  background: rgba(0, 0, 0, 0.15);
  padding: 8px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
}

.icon-option {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 6px;
  transition: all 0.15s ease;
}

.icon-option input {
  display: none;
}

.icon-option span {
  font-size: 1.3rem;
  opacity: 0.65;
  transition: transform 0.15s ease, opacity 0.15s ease;
}

.icon-option:hover span {
  transform: scale(1.15);
  opacity: 1;
}

.icon-option span:hover {
  transform: scale(1.15);
  opacity: 1;
}

.icon-option input:checked + span {
  opacity: 1;
  transform: scale(1.25);
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

.icon-option:has(input:checked) {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.goals-empty-card {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 40px 24px;
  background: rgba(255, 255, 255, 0.01);
  border: 2px dashed rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
}

.goals-empty-icon {
  font-size: 2.5rem;
  margin-bottom: 12px;
  opacity: 0.7;
}

.goals-empty-title {
  font-size: 1.1rem;
  font-weight: 750;
  color: var(--text-primary);
  margin-bottom: 6px;
}

.goals-empty-desc {
  font-size: 0.85rem;
  color: var(--text-muted);
  max-width: 380px;
  line-height: 1.5;
  margin-bottom: 20px;
}

/* Glassmorphism Goal Action Add Card */
.goal-add-card-placeholder {
  background: rgba(255, 255, 255, 0.01);
  border: 2px dashed rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 30px 20px;
  cursor: pointer;
  transition: all var(--transition-base);
  min-height: 240px;
}

.goal-add-card-placeholder:hover {
  background: rgba(255, 255, 255, 0.02);
  border-color: var(--border-accent);
  box-shadow: 0 0 16px var(--accent-glow);
}

.goal-add-card-icon {
  font-size: 2rem;
  margin-bottom: 10px;
  color: var(--text-muted);
  transition: transform 0.2s ease, color 0.2s ease;
}

.goal-add-card-placeholder:hover .goal-add-card-icon {
  transform: scale(1.15);
  color: var(--accent);
}

.goal-add-card-text {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-secondary);
}

/* Mobile responsive for Goals */
@media (max-width: 768px) {
  .goals-stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .goals-stat-value {
    font-size: 1.3rem;
  }

  .goals-grid {
    grid-template-columns: 1fr;
  }
}

/* Smart Insights Styles */
.goals-insights-card {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.05), rgba(25, 25, 38, 0.95));
  border-color: rgba(99, 102, 241, 0.15);
  margin-bottom: 24px;
  box-shadow: 0 10px 30px -10px rgba(99, 102, 241, 0.1);
}

.insights-content-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.insight-box {
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-md);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: all var(--transition-base);
}

.insight-box:hover {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(255, 255, 255, 0.05);
}

.insight-box-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-primary);
}

.insight-box-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.insight-box-desc strong {
  color: var(--text-primary);
}

.insight-accent-blue { color: var(--savings-blue) !important; }
.insight-accent-yellow { color: #FBBF24 !important; }
.insight-accent-red { color: #F87171 !important; }
.insight-accent-green { color: #10B981 !important; }

/* Goal Modal Premium Forms Overrides */
.modal-card .text-input {
  width: 100%;
  background: var(--bg-elevated);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-family: var(--font);
  font-size: 0.92rem;
  padding: 10px 12px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.modal-card .text-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255, 122, 100, 0.1);
}

.modal-card .select-input {
  width: 100%;
  font-size: 0.92rem;
  padding: 10px 28px 10px 12px;
  background-position: right 12px center;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
}

/* Style calendar indicators for date input */
.modal-card input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.65) sepia(1) saturate(5) hue-rotate(320deg); /* Accent glow indicator calendar icon */
  cursor: pointer;
  opacity: 0.75;
  transition: opacity 0.15s ease;
}

.modal-card input[type="date"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}

/* Mobile adjustments for modal form rows */
@media (max-width: 480px) {
  .modal-form .form-row {
    flex-direction: column !important;
    gap: 12px !important;
  }
}
/* ========================================
   DAILY ALLOWANCE SWEEP ADVISOR STYLES
   ======================================== */
.allowance-sweep-advisor {
  margin-top: 16px;
  padding: 16px;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.08), rgba(25, 25, 38, 0.85));
  border: 1px solid rgba(16, 185, 129, 0.18);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: 0 10px 30px -10px rgba(16, 185, 129, 0.08);
  transition: all var(--transition-base);
}

.allowance-sweep-advisor:hover {
  border-color: rgba(16, 185, 129, 0.35);
  box-shadow: 0 12px 36px -8px rgba(16, 185, 129, 0.14);
  transform: translateY(-1px);
}

.allowance-sweep-advisor.ending-soon {
  background: linear-gradient(135deg, rgba(255, 122, 100, 0.08), rgba(25, 25, 38, 0.85));
  border-color: rgba(255, 122, 100, 0.25);
  box-shadow: 0 10px 30px -10px rgba(255, 122, 100, 0.08);
}

.allowance-sweep-advisor.ending-soon:hover {
  border-color: rgba(255, 122, 100, 0.45);
  box-shadow: 0 12px 36px -8px rgba(255, 122, 100, 0.14);
}

.allowance-sweep-advisor.warning {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.05), rgba(25, 25, 38, 0.85));
  border-color: rgba(251, 191, 36, 0.15);
  box-shadow: 0 10px 30px -10px rgba(251, 191, 36, 0.04);
}

.allowance-sweep-advisor.warning:hover {
  border-color: rgba(251, 191, 36, 0.25);
  box-shadow: 0 12px 36px -8px rgba(251, 191, 36, 0.08);
}

.allowance-sweep-advisor .sweep-icon {
  font-size: 1.8rem;
  line-height: 1;
  background: rgba(255, 255, 255, 0.03);
  padding: 10px;
  border-radius: 50%;
  animation: sweep-bounce-subtle 3.5s ease-in-out infinite;
  flex-shrink: 0;
}

.allowance-sweep-advisor.ending-soon .sweep-icon {
  background: rgba(255, 122, 100, 0.08);
}

.allowance-sweep-advisor.warning .sweep-icon {
  background: rgba(251, 191, 36, 0.06);
}

.allowance-sweep-advisor .sweep-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.allowance-sweep-advisor .sweep-title {
  font-size: 0.88rem;
  font-weight: 850;
  color: #10B981;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.allowance-sweep-advisor.ending-soon .sweep-title {
  color: var(--accent);
}

.allowance-sweep-advisor.warning .sweep-title {
  color: #FBBF24;
}

.allowance-sweep-advisor .sweep-text {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.45;
}

.allowance-sweep-advisor .sweep-text strong {
  color: var(--text-primary);
  font-weight: 700;
}

.allowance-sweep-advisor .sweep-actions {
  margin-top: 8px;
}

.allowance-sweep-advisor .sweep-btn {
  background: var(--accent);
  color: #FFF;
  border: none;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.74rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-base);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.allowance-sweep-advisor .sweep-btn:hover {
  background: var(--accent-light);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(255, 122, 100, 0.2);
}

@keyframes sweep-bounce-subtle {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

@media (max-width: 576px) {
  .allowance-sweep-advisor {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .allowance-sweep-advisor .sweep-icon {
    align-self: center;
  }
}

/* ========================================
   SAVINGS GOALS DEFICIT PROJECTION STYLES
   ======================================== */
.goals-deficit-section {
  margin-top: 16px;
  background: linear-gradient(135deg, rgba(248, 113, 113, 0.04), rgba(25, 25, 38, 0.85));
  border: 1px solid rgba(248, 113, 113, 0.15);
  border-radius: var(--radius-md);
  padding: 16px;
  box-shadow: 0 10px 30px -10px rgba(248, 113, 113, 0.05);
}

.goals-deficit-title {
  font-size: 0.88rem;
  font-weight: 850;
  color: #F87171;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 12px;
}

.goals-deficit-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  margin-bottom: 8px;
}

.goals-deficit-table th, .goals-deficit-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.goals-deficit-table th {
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.5px;
}

.goals-deficit-table td {
  color: var(--text-primary);
}

.goals-deficit-table .shortfall-text {
  color: #F87171;
  font-weight: 700;
}

.goals-deficit-summary-row {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(248, 113, 113, 0.15);
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--text-secondary);
}

/* Premium styling for new edit action icons */
.btn-edit-row {
  background: transparent;
  color: var(--savings-blue);
  padding: 4px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}
.btn-edit-row:hover {
  background: rgba(96, 165, 250, 0.12);
  color: #93C5FD;
}

/* Static desktop text styling */
.budget-table td span.cell-text {
  font-size: 0.85rem;
  color: var(--text-primary);
  display: inline-block;
  padding: 4px 6px;
}
.budget-table td span.cell-text-muted {
  font-size: 0.85rem;
  color: var(--text-muted);
  display: inline-block;
  padding: 4px 6px;
}

/* Responsive Budget Cards on Mobile */
@media (max-width: 768px) {
  .budget-table-wrap {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
  }
  
  .budget-table, 
  .budget-table thead, 
  .budget-table tbody, 
  .budget-table tr, 
  .budget-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }
  
  .budget-table thead {
    display: none; /* Hide header columns */
  }
  
  .budget-table tbody {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  
  .budget-table tr {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.015), rgba(25, 25, 38, 0.9));
    border: 1px solid rgba(255, 255, 255, 0.04);
    border-radius: var(--radius-md);
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    transition: all var(--transition-base);
  }
  
  .budget-table tr:hover {
    border-color: rgba(255, 255, 255, 0.08);
    transform: translateY(-1px);
  }

  .budget-table td {
    border: none !important;
    padding: 0 !important;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8rem;
  }

  .budget-table td.hide-mobile {
    display: none !important;
  }

  /* Prevent allowance stats cards from stacking vertically on mobile */
  .allowance-dashboard-header {
    gap: 6px !important;
    padding-bottom: 10px !important;
  }
  .period-dates-pill {
    font-size: 0.85rem !important;
  }
  .period-subtitle-label {
    font-size: 0.62rem !important;
  }
  .allowance-pace-badge {
    font-size: 0.72rem !important;
    padding: 3px 8px !important;
  }
  .allowance-stats-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
  }
  .allowance-stat-card {
    padding: 12px 6px !important;
    gap: 6px !important;
    align-items: center !important;
    text-align: center !important;
    min-height: 98px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
  }
  .allowance-stat-card .stat-card-label {
    font-size: 0.65rem !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    width: 100% !important;
    line-height: 1.2 !important;
    min-height: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
  .allowance-stat-card .stat-card-value {
    font-size: 1.35rem !important;
    justify-content: center !important;
    margin: 2px 0 !important;
  }
  .allowance-stat-card .stat-card-value .number {
    font-size: 1.35rem !important;
  }
  .allowance-stat-card .stat-card-value .currency {
    font-size: 0.9rem !important;
  }
  .allowance-stat-card .stat-card-value .sub {
    font-size: 0.75rem !important;
  }
  .allowance-stat-card .stat-card-footer {
    font-size: 0.65rem !important;
    width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    color: var(--text-muted) !important;
  }

  .budget-table td::before {
    content: attr(data-label);
    font-size: 0.72rem;
    color: var(--text-muted);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.5px;
  }

  /* Exclude item title from data-labels */
  .budget-table td.col-item-title {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--text-primary);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
    padding-bottom: 8px !important;
    margin-bottom: 4px;
    display: block;
    text-align: left;
  }
  .budget-table td.col-item-title::before {
    display: none;
  }
  
  .budget-table td span.cell-text,
  .budget-table td span.cell-text-muted {
    padding: 0;
    text-align: right;
  }

  .budget-table td.row-actions {
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.04) !important;
    padding-top: 10px !important;
    margin-top: 4px;
  }

  .row-actions .btn-icon,
  .row-actions .btn-danger {
    width: 38px !important;
    height: 38px !important;
    border-radius: 50% !important;
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-subtle) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: transform var(--transition-fast) !important;
  }

  .row-actions .btn-icon:active,
  .row-actions .btn-danger:active {
    transform: scale(0.88) !important;
  }

  .row-actions .btn-danger {
    border-color: rgba(248, 113, 113, 0.15) !important;
  }
  .row-actions .btn-danger:hover,
  .row-actions .btn-danger:active {
    background: var(--expense-red-dim) !important;
    border-color: rgba(248, 113, 113, 0.3) !important;
  }

  .row-actions .btn-bill-toggle:not(.excluded) {
    border-color: rgba(74, 222, 128, 0.15) !important;
    background: var(--credit-green-dim) !important;
  }
  .row-actions .btn-bill-toggle:not(.excluded):hover,
  .row-actions .btn-bill-toggle:not(.excluded):active {
    border-color: rgba(74, 222, 128, 0.3) !important;
    background: rgba(74, 222, 128, 0.18) !important;
  }

  /* Table footers */
  .budget-table tfoot {
    display: block;
    margin-top: 14px;
  }
  .budget-table tfoot tr {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: var(--radius-md);
    padding: 12px;
  }
  .budget-table tfoot td {
    display: block;
    width: auto !important;
    border: none !important;
    padding: 0 !important;
  }
  .budget-table tfoot td.subtotal-label {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
  }
  .budget-table tfoot td.subtotal-value {
    font-size: 1rem;
    font-weight: 850;
    color: var(--text-primary);
  }
}

/* ========================================================
   PRIVACY MODE & BLUR STYLES
   ======================================================== */
.btn-privacy-toggle {
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  border-radius: var(--radius-md);
  padding: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  width: 100%;
}
.btn-privacy-toggle:hover {
  background: var(--bg-elevated);
  color: var(--accent-light);
  border-color: rgba(255, 158, 83, 0.2);
}
.btn-privacy-toggle.active {
  color: var(--accent);
  background: var(--accent-glow);
  border-color: var(--border-accent);
}
.btn-privacy-toggle svg {
  transition: transform 0.2s ease;
}
.btn-privacy-toggle:active svg {
  transform: scale(0.85);
}

/* Selector to blur exact dollar amounts while maintaining layout */
body.privacy-active .summary-value,
body.privacy-active .account-card-balance,
body.privacy-active .account-compact-balance,
body.privacy-active .account-compact-change,
body.privacy-active .goals-stat-value,
body.privacy-active .goal-card-saved,
body.privacy-active .goal-card-target,
body.privacy-active .goal-timeline-box-value,
body.privacy-active .stat-card-value,
body.privacy-active .rate-value,
body.privacy-active .monthly-cost,
body.privacy-active .subtotal-value,
body.privacy-active .quick-stat-value,
body.privacy-active .txn-amount,
body.privacy-active .txn-summary-value,
body.privacy-active .analytics-pill-value,
body.privacy-active .income-input-row input,
body.privacy-active .allowance-amount,
body.privacy-active .privacy-blur {
  filter: blur(8px) !important;
  user-select: none !important;
  pointer-events: none !important;
  transition: filter 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ========================================================
   NATIVE APPLE IOS (CUPERTINO) HIG DESIGN OVERRIDES
   ======================================================== */

/* OLED Pure Black Backgrounds & Ambient Glow */
body {
  background-color: var(--bg-base) !important;
}
body::before {
  background: radial-gradient(ellipse at 15% 0%, rgba(10, 132, 255, 0.05) 0%, transparent 55%),
              radial-gradient(ellipse at 85% 100%, rgba(48, 209, 88, 0.03) 0%, transparent 55%) !important;
}

/* Cupertino Squircle Cards */
.section-card {
  background: var(--bg-card) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border-radius: var(--radius-lg) !important; /* 20px squircle */
  border: 1px solid var(--border-subtle) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: all var(--transition-base) !important;
}
.section-card:hover {
  border-color: rgba(255, 255, 255, 0.12) !important;
  box-shadow: var(--shadow-md) !important;
}

/* Translucent iOS Header & Bottom Tab Bar */
.mobile-header {
  background: rgba(0, 0, 0, 0.72) !important;
  backdrop-filter: blur(28px) -webkit-backdrop-filter(28px) !important;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.08) !important;
}

/* iOS Bottom Sheet Modals (Drawer Transition) */
@media (max-width: 768px) {
  .modal-overlay {
    align-items: flex-end !important; /* Align drawer to bottom */
    justify-content: center !important;
    background-color: rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    transition: opacity 0.3s ease !important;
  }

  .modal-overlay .modal-card {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    border-radius: 24px 24px 0 0 !important;
    border: none !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: rgba(28, 28, 30, 0.94) !important;
    backdrop-filter: blur(35px) -webkit-backdrop-filter(35px) !important;
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.5) !important;
    padding-top: 10px !important;
    padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px)) !important;
    animation: slideUpSheet 0.38s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
  }

  /* Grab handle indicator */
  .ios-sheet-handle {
    display: block !important;
    width: 36px !important;
    height: 5px !important;
    border-radius: 3px !important;
    background-color: rgba(255, 255, 255, 0.22) !important;
    margin: 0 auto 16px auto !important;
    flex-shrink: 0 !important;
  }

  .nav-sidebar {
    background: rgba(0, 0, 0, 0.72) !important;
    backdrop-filter: blur(28px) -webkit-backdrop-filter(28px) !important;
    border-top: 0.5px solid rgba(255, 255, 255, 0.08) !important;
    height: calc(60px + env(safe-area-inset-bottom, 0px)) !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  }
}

@keyframes slideUpSheet {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}

/* iOS-Style Switches (Globally Styles all Checkboxes) */
/* Refactored: checkbox styling is now unified under standard .toggle-switch elements for perfect HIG compliance */

/* Elastic Springs on Tap (Haptic Feel) */
.btn, 
.btn-icon, 
.account-card-compact, 
.goal-card, 
.bill-item,
.allowance-stat-card,
.row-actions button,
.nav-link,
.section-card-header,
.settings-toggle-row {
  transition: all var(--transition-base) !important;
}
.btn:active, 
.btn-icon:active, 
.account-card-compact:active, 
.goal-card:active, 
.bill-item:active,
.allowance-stat-card:active,
.row-actions button:active,
.nav-link:active {
  transform: scale(0.96) !important;
}

/* High-End Outline Inputs (Apple HIG Form Style) */
.form-group input,
.form-group select,
.form-group textarea,
.settings-card input[type="text"],
.settings-card input[type="password"],
.settings-input,
.select-input,
.text-input {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: var(--radius-md) !important;
  color: var(--text-primary) !important;
  padding: 10px 14px !important;
  font-size: 0.92rem !important;
  font-family: var(--font) !important;
  transition: all var(--transition-fast) !important;
  outline: none !important;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus,
.settings-card input[type="text"]:focus,
.settings-card input[type="password"]:focus,
.settings-input:focus,
.select-input:focus,
.text-input:focus {
  background: rgba(255, 255, 255, 0.07) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.15) !important;
}

/* Clean list separator styling in lists */
.account-card-compact,
.bill-item,
.recurring-item {
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.05) !important;
}

/* Cupertino Sliding Segment Controls styling for Settings buttons & Transaction Month nav */
.settings-btn-row,
.transactions-month-nav {
  background: rgba(118, 118, 128, 0.16) !important;
  border-radius: 12px !important;
  padding: 3px !important;
  gap: 2px !important;
  display: flex !important;
  align-items: center !important;
  position: relative !important;
  border: none !important;
}
.settings-btn-row .btn,
.transactions-month-nav button,
.transactions-month-nav .month-label {
  flex: 1 !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 9px !important;
  padding: 8px 12px !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  background: transparent !important;
  color: var(--text-secondary) !important;
  text-align: center !important;
  justify-content: center !important;
  transition: all var(--transition-fast) !important;
  box-shadow: none !important;
}
.settings-btn-row .btn-accent,
.transactions-month-nav button:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  color: var(--text-primary) !important;
}
.settings-btn-row .btn-outline {
  background: transparent !important;
  color: var(--text-secondary) !important;
}
.settings-btn-row #btnExport,
.settings-btn-row #btnImport {
  background: transparent !important;
  border-radius: 9px !important;
}
.settings-btn-row .btn-accent {
  background: #FFFFFF !important;
  color: #000000 !important;
  font-weight: 600 !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15) !important;
}

/* iOS Settings Grouped Cell Styling inside pageSettings */
#pageSettings .section-card {
  background: var(--bg-card) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  margin-bottom: 24px !important;
  padding: 16px 18px 18px !important;
  box-shadow: var(--shadow-md) !important;
  backdrop-filter: blur(20px) !important;
}

/* ==========================================================================
   PREMIUM APPLE iOS COPPERTONE SETTINGS SECTION refactoring
   ========================================================================== */

/* Unified iOS Grouped Lists */
.ios-settings-group {
  display: flex !important;
  flex-direction: column !important;
  background: rgba(255, 255, 255, 0.035) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  border: 0.5px solid rgba(255, 255, 255, 0.08) !important;
  margin-top: 8px !important;
  margin-bottom: 8px !important;
  backdrop-filter: blur(20px) !important;
}

/* Individual list cells */
.ios-settings-row {
  display: flex !important;
  flex-direction: row !important; /* text on left, widget on right */
  align-items: center !important;
  justify-content: space-between !important;
  padding: 12px 16px !important;
  min-height: 48px !important;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.06) !important;
  background: transparent !important;
  transition: background-color var(--transition-fast) !important;
  box-sizing: border-box !important;
  gap: 16px !important;
}

.ios-settings-row:last-child {
  border-bottom: none !important;
}

/* Label on the left of the cell */
.ios-settings-label {
  font-family: var(--font) !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  color: var(--text-primary) !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  margin: 0 !important;
}

/* Inline Inputs on the right of the cell */
.ios-settings-input-inline,
.ios-settings-select-inline {
  background: transparent !important;
  border: none !important;
  color: var(--text-secondary) !important;
  font-family: var(--font) !important;
  font-size: 0.95rem !important;
  text-align: right !important;
  outline: none !important;
  padding: 4px 0 !important;
  cursor: pointer !important;
  transition: color var(--transition-fast) !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.ios-settings-input-inline:focus,
.ios-settings-select-inline:focus {
  color: var(--text-primary) !important;
}

/* Specific styling for inline date input picker icon */
.ios-settings-input-inline::-webkit-calendar-picker-indicator {
  filter: invert(1) opacity(0.5);
  margin-left: 8px;
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.ios-settings-input-inline::-webkit-calendar-picker-indicator:hover {
  opacity: 0.9;
}

/* Custom wrapper for selects to support a subtle dropdown chevron on the right */
.ios-select-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.ios-select-wrapper::after {
  content: "▾" !important;
  font-size: 0.75rem !important;
  color: var(--text-secondary) !important;
  position: absolute !important;
  right: 0 !important;
  pointer-events: none !important;
  opacity: 0.6 !important;
  transition: opacity var(--transition-fast) !important;
}

.ios-select-wrapper:hover::after {
  opacity: 1 !important;
}

.ios-settings-select-inline {
  padding-right: 14px !important; /* Make room for the custom chevron */
}

/* Native Center-Aligned iOS Action Cells */
.ios-settings-action-row {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 14px 16px !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.06) !important;
  background: rgba(255, 255, 255, 0.015) !important;
  transition: background-color var(--transition-fast), opacity var(--transition-fast) !important;
  box-sizing: border-box !important;
}

.ios-settings-action-row:last-child {
  border-bottom: none !important;
}

.ios-settings-action-row:hover {
  background-color: rgba(255, 255, 255, 0.05) !important;
}

.ios-settings-action-row:active {
  background-color: rgba(255, 255, 255, 0.08) !important;
}

.ios-settings-action-row.destructive {
  color: var(--expense-red) !important;
}

/* Section Sub-labels inside input rows */
.ios-settings-row-input {
  display: flex !important;
  flex-direction: column !important;
  padding: 14px 16px !important;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.06) !important;
  box-sizing: border-box !important;
}

.ios-settings-row-input:last-child {
  border-bottom: none !important;
}

.ios-settings-label-sub {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: var(--text-secondary) !important;
  margin-bottom: 4px !important;
}

/* Ensure all switch containers and slider knobs use perfect, standardized iOS dimensions */
.toggle-switch {
  width: 51px !important;
  height: 31px !important;
  position: relative !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
  margin: 0 !important;
}

.toggle-switch input {
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  position: absolute !important;
}

.toggle-slider {
  position: absolute !important;
  inset: 0 !important;
  background-color: rgba(120, 120, 128, 0.28) !important;
  border-radius: 100px !important;
  border: none !important;
  transition: background-color var(--transition-base) !important;
}

.toggle-slider:before {
  position: absolute !important;
  content: "" !important;
  height: 27px !important;
  width: 27px !important;
  left: 2px !important;
  bottom: 2px !important;
  background-color: #FFFFFF !important;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15), 0 3px 1px rgba(0, 0, 0, 0.06) !important;
  transition: transform var(--transition-base) !important;
  border-radius: 50% !important;
}

.toggle-switch input:checked + .toggle-slider {
  background-color: #34C759 !important; /* iOS systemGreen */
}

.toggle-switch input:checked + .toggle-slider:before {
  transform: translateX(20px) !important;
}

/* Account Visibility checklist Grouped layout overrides */
#accountCheckboxList {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  background: rgba(255, 255, 255, 0.035) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  border: 0.5px solid rgba(255, 255, 255, 0.08) !important;
  margin-top: 10px !important;
  padding: 0 !important;
  max-height: 360px !important;
  overflow-y: auto !important;
}

#accountCheckboxList .ios-settings-row {
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.06) !important;
}

#accountCheckboxList .ios-settings-row:last-child {
  border-bottom: none !important;
}

#accountCheckboxList .ios-settings-row:hover {
  background-color: rgba(255, 255, 255, 0.04) !important;
}

#accountCheckboxList .ios-settings-row:active {
  background-color: rgba(255, 255, 255, 0.08) !important;
}

/* iOS Grouped settings lists generic rules */
.ios-grouped-list {
  display: flex !important;
  flex-direction: column !important;
  background: rgba(255, 255, 255, 0.035) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  border: 0.5px solid rgba(255, 255, 255, 0.08) !important;
  margin-top: 10px !important;
  box-sizing: border-box !important;
}
.ios-list-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 12px 16px !important;
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.06) !important;
  font-size: 0.95rem !important;
  color: var(--text-primary) !important;
  cursor: pointer !important;
  transition: background-color var(--transition-fast) !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}
.ios-list-row:last-child {
  border-bottom: none !important;
}
.ios-list-row:hover {
  background-color: rgba(255, 255, 255, 0.04) !important;
}
.ios-list-row:active {
  background-color: rgba(255, 255, 255, 0.08) !important;
}
.ios-list-row-chevron::after {
  content: "" !important;
  display: inline-block !important;
  width: 7px !important;
  height: 7px !important;
  border-top: 1.5px solid var(--text-muted) !important;
  border-right: 1.5px solid var(--text-muted) !important;
  transform: rotate(45deg) !important;
  margin-left: 8px !important;
  flex-shrink: 0 !important;
}

/* iOS System Search Bar Override */
.transactions-search {
  background: rgba(118, 118, 128, 0.22) !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 8px 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 16px !important;
  transition: all var(--transition-fast) !important;
}
.transactions-search svg {
  color: var(--text-secondary) !important;
  flex-shrink: 0 !important;
}
.transactions-search input {
  font-family: var(--font) !important;
  font-size: 0.95rem !important;
  color: var(--text-primary) !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  width: 100% !important;
  padding: 0 !important;
}
.transactions-search input::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
}
.transactions-search:focus-within {
  background: rgba(118, 118, 128, 0.32) !important;
  box-shadow: none !important;
}

/* HUD Apple-Style Pill Toast Overlay (Dynamic Island Style) */
.toast-container {
  position: fixed !important;
  top: 16px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  bottom: auto !important;
  right: auto !important;
  z-index: 2000 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  width: auto !important;
  max-width: 90% !important;
  pointer-events: none !important;
}
.toast {
  padding: 10px 22px !important;
  border-radius: 100px !important; /* Pill shape */
  background: rgba(30, 30, 30, 0.8) !important;
  backdrop-filter: blur(24px) saturate(180%) -webkit-backdrop-filter(24px) saturate(180%) !important;
  border: 0.5px solid rgba(255, 255, 255, 0.12) !important;
  color: #FFFFFF !important;
  font-weight: 500 !important;
  font-size: 0.88rem !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5) !important;
  text-align: center !important;
  animation: hudIn 0.45s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards !important;
  margin-bottom: 8px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
@keyframes hudIn {
  from { opacity: 0; transform: translateY(-40px) scale(0.85); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Native iOS-style Slider Thumb Override */
input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255, 255, 255, 0.12) !important;
  height: 6px !important;
  border-radius: 3px !important;
  outline: none !important;
}
input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px !important;
  height: 22px !important;
  border-radius: 50% !important;
  background: #FFFFFF !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.4) !important;
  cursor: pointer !important;
  transition: transform var(--transition-fast) !important;
}
input[type="range"]::-webkit-slider-thumb:active {
  transform: scale(1.15) !important;
}

/* --- Cupertino Unified Profile Widget --- */
.sidebar-user-card {
  background: rgba(255, 255, 255, 0.035) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 16px !important;
  padding: 12px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  margin: 8px 4px !important;
}

.sidebar-user-profile-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  position: relative !important;
}

.sidebar-avatar-wrapper {
  position: relative !important;
  width: 32px !important;
  height: 32px !important;
  flex-shrink: 0 !important;
}

.sidebar-avatar-wrapper .sidebar-user-avatar {
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
}

/* Positioning connection status dot as a tiny dynamic badge overlay on avatar! */
.sidebar-avatar-wrapper .status-dot {
  position: absolute !important;
  bottom: -2px !important;
  right: -2px !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  border: 2px solid #000000 !important; /* matches dark sidebar background */
  z-index: 10 !important;
}

.sidebar-user-details {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  flex: 1 !important;
}

.sidebar-user-name {
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.sidebar-user-email {
  font-size: 0.72rem !important;
  color: var(--text-muted) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.sidebar-status-label {
  font-size: 0.72rem !important;
  color: var(--text-muted) !important;
  font-weight: 500 !important;
  background: rgba(255, 255, 255, 0.05) !important;
  padding: 2px 6px !important;
  border-radius: 6px !important;
  border: 0.5px solid rgba(255, 255, 255, 0.05) !important;
  flex-shrink: 0 !important;
}

/* Cohesive inside-card divider */
.sidebar-card-divider {
  height: 0.5px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  margin: 0 !important;
  border: none !important;
}

/* Horizontal Actions row inside user widget */
.sidebar-actions-row {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  margin: 0 !important;
}

.btn-sidebar-action {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 6px 4px !important;
  color: var(--text-secondary) !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all var(--transition-fast) !important;
}

.btn-sidebar-action svg {
  color: var(--text-secondary) !important;
  transition: transform var(--transition-fast) !important;
}

.btn-sidebar-action:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--text-primary) !important;
}

.btn-sidebar-action:hover svg {
  color: var(--text-primary) !important;
}

.btn-sidebar-action:active {
  transform: scale(0.96) !important;
}

/* Red alert on hover for Sign Out */
.btn-logout-action:hover {
  background: rgba(255, 69, 58, 0.1) !important;
  color: var(--expense-red) !important;
}
.btn-logout-action:hover svg {
  color: var(--expense-red) !important;
}

.sidebar-actions-vertical-divider {
  width: 0.5px !important;
  height: 14px !important;
  background: rgba(255, 255, 255, 0.12) !important;
  flex-shrink: 0 !important;
}





