/* ============================================================
   ROCA BUDGET — styles.css
   Matches Roca Bod aesthetic exactly
   ============================================================ */

:root{
  --bg:#0a0a0a;--surface:#141414;--surface2:#1e1e1e;--border:#2a2a2a;
  --accent:#e8ff47;--accent2:#ff4757;--text:#f0f0f0;--text2:#888;--text3:#555;
  --green:#2ecc71;--blue:#3498db;--orange:#f39c12;--purple:#9b59b6;--teal:#1abc9c;
  --radius:4px;--font-display:'Barlow Condensed',sans-serif;--font-body:'Barlow',sans-serif;
}

/* ── Reset ── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;background:#050505;color:var(--text);font-family:var(--font-body);overflow:hidden;}
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg);}

/* ── Screens ── */
.screen{display:none;flex:1;flex-direction:column;overflow:hidden;}
.screen.active{display:flex;}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
.scroll::-webkit-scrollbar{width:2px;}
.scroll::-webkit-scrollbar-thumb{background:var(--border);}

/* ── Header ── */
.header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg);z-index:10;flex-shrink:0;}
.header-title{font-family:var(--font-display);font-size:22px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:var(--accent);}
.header-sub{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:1px;}
.global-header-actions{display:flex;gap:6px;align-items:center;}
.icon-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:6px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;}
.icon-btn:active{background:var(--surface2);}

/* ── Bottom Nav ── */
.bottom-nav{display:flex;border-top:1px solid var(--border);background:var(--bg);padding-bottom:env(safe-area-inset-bottom);flex-shrink:0;}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 0 7px;background:none;border:none;color:var(--text3);cursor:pointer;font-family:var(--font-display);font-size:8px;letter-spacing:.5px;text-transform:uppercase;transition:color .15s;}
.nav-btn.active{color:var(--accent);}
.nav-btn svg{width:18px;height:18px;}

/* ── Buttons ── */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;transition:opacity .15s,transform .1s;}
.btn:active{opacity:.85;transform:scale(.98);}
.btn-primary{background:var(--accent);color:#0a0a0a;}
.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);}
.btn-danger{background:transparent;color:var(--accent2);border:1px solid var(--accent2);}
.btn-sm{padding:8px 14px;font-size:13px;}
.btn-full{width:100%;}

/* ── Cards ── */
.card{margin:0 16px 10px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);}
.card-row{display:flex;align-items:center;justify-content:space-between;}

/* ── Section Headers ── */
.section-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 8px;position:sticky;top:0;background:var(--bg);z-index:5;}
.section-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text2);}

/* ── Modals ── */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:500;align-items:flex-end;overflow:hidden;}
.modal-backdrop.show{display:flex;}
.modal{width:100%;background:var(--surface);border-top:1px solid var(--border);border-radius:12px 12px 0 0;padding:20px 16px calc(20px + env(safe-area-inset-bottom));animation:slideUp .25s ease;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.modal-title{font-family:var(--font-display);font-size:20px;font-weight:900;letter-spacing:1px;margin-bottom:16px;flex-shrink:0;}
.modal-input{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:15px;outline:none;margin-bottom:12px;transition:border-color .15s;}
.modal-input:focus{border-color:var(--accent);}
.modal-select{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:15px;outline:none;margin-bottom:12px;appearance:none;}
.modal-row{display:flex;gap:8px;flex-shrink:0;margin-top:4px;}
.modal-section-label{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-weight:600;flex-shrink:0;}
.modal-label{font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:500;}

/* ── Stat Grid ── */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 16px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 12px;}
.stat-val{font-family:var(--font-display);font-size:24px;font-weight:900;color:var(--accent);letter-spacing:0;line-height:1.1;word-break:break-all;}
.stat-val.negative{color:var(--accent2);}
.stat-val.positive{color:var(--green);}
.stat-lbl{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text2);margin-top:5px;}

/* ── Charts ── */
.chart-area{margin:0 16px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;}
.chart-title{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text2);margin-bottom:12px;}
canvas{width:100%!important;display:block;}

/* ── Transaction Items ── */
.txn-item{margin:0 16px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .15s;}
.txn-item:active{border-color:var(--accent);}
.txn-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.txn-info{flex:1;min-width:0;}
.txn-name{font-family:var(--font-display);font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.txn-meta{font-size:11px;color:var(--text2);margin-top:2px;}
.txn-amount{font-family:var(--font-display);font-size:18px;font-weight:700;flex-shrink:0;}
.txn-amount.income{color:var(--green);}
.txn-amount.expense{color:var(--text);}

/* ── Budget — shared column definition ──
   COL WIDTHS: Budgeted=72px  Spent=76px  Balance=68px
   The same grid is used on the sticky header, group rows, and sub rows
   so every value lines up perfectly regardless of left-side content.
─────────────────────────────────────────────────────────────── */
:root{ --bc1:54px; --bc2:58px; --bc3:58px; --bc4:56px; }

/* Sticky column header */
.budget-col-header{
  display:flex;align-items:center;
  padding:6px 14px 4px;
  background:var(--bg);
  position:sticky;top:0;z-index:4;
}
.budget-col-header-spacer{flex:1;}
.budget-col-header-labels{
  display:grid;
  grid-template-columns:var(--bc1) var(--bc2) var(--bc3) var(--bc4);
  text-align:right;
  flex-shrink:0;
}
.budget-col-header-lbl{
  font-family:var(--font-display);font-size:9px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);
}

/* ── Parent Group ── */
.budget-group{
  margin:0 16px 8px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:box-shadow .15s, opacity .15s;
}
.budget-group.drag-over{ box-shadow:0 0 0 2px var(--accent); }
.budget-group.dragging { opacity:.4; }

.budget-group-header{
  display:flex;align-items:center;
  padding:11px 14px;
  background:var(--surface2);
  gap:0;                       /* no gap — spacing is explicit below */
  transition:background .15s;
  user-select:none;
  -webkit-user-select:none;
}
.budget-group-header:active{background:var(--border);}

/* drag handle — sits at far left, no tap confusion */
.budget-drag-handle{
  color:var(--text3);
  cursor:grab;
  padding:2px 8px 2px 0;
  font-size:14px;
  line-height:1;
  flex-shrink:0;
  touch-action:none;
}
.budget-drag-handle:active{ cursor:grabbing; }

.budget-group-chevron{
  font-size:13px;color:var(--text3);
  transition:transform .2s;
  flex-shrink:0;
  margin-right:6px;
  cursor:pointer;
}
.budget-group-chevron.open{transform:rotate(90deg);}

.budget-group-icon{font-size:16px;flex-shrink:0;margin-right:6px;}

.budget-group-main{
  flex:1;min-width:0;margin-right:6px;cursor:pointer;
}
.budget-group-name{
  font-family:var(--font-display);font-size:16px;font-weight:700;
  letter-spacing:.5px;
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;
}
.budget-mobile-meta{
  display:none;font-size:11px;color:var(--text2);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.budget-group-menu-btn{
  background:none;border:none;color:var(--text3);cursor:pointer;
  padding:2px 6px;border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-right:4px;
}
.budget-group-menu-btn:active{color:var(--text);}

/* The three value columns — identical grid on both group and sub rows */
.budget-group-cols,
.budget-sub-cols{
  display:grid;
  grid-template-columns:var(--bc1) var(--bc2) var(--bc3) var(--bc4);
  text-align:right;
  flex-shrink:0;
  align-items:center;
}
.budget-sub-cols-2{
  grid-template-columns:var(--bc1) var(--bc2);
}

.budget-group-col{
  font-family:var(--font-display);font-size:13px;font-weight:700;
  color:var(--text2);
  padding:0 2px;
}
.budget-group-col.spent{ color:var(--accent2); }   /* overridden by inline style when zero */
.budget-group-col.pending,.budget-sub-col.pending{ color:var(--orange); }
.budget-group-col.balance.ok{color:var(--green);}
.budget-group-col.balance.warn{color:var(--orange);}
.budget-group-col.balance.over{color:var(--accent2);}
.budget-sub-col.spent{   color:var(--text); }        /* overridden by inline style when zero */

/* ── Sub-category rows ── */
.budget-sub-list{background:var(--surface);}

.budget-sub-row{
  display:flex;align-items:center;
  padding:10px 14px 10px 14px;
  border-top:1px solid var(--border);
  cursor:default;
  transition:background .15s;
  gap:0;
}
.budget-sub-row:active{background:var(--surface2);}

.budget-sub-main{
  flex:1;min-width:0;margin-right:6px;cursor:pointer;
}
.budget-sub-name{
  font-size:15px;font-weight:600;color:var(--text);
  min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;
}

.budget-sub-col{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text2);padding:0 2px;}
.budget-sub-col.spent{color:var(--text);}
.budget-sub-col.balance.ok{color:var(--green);}
.budget-sub-col.balance.warn{color:var(--orange);}
.budget-sub-col.balance.over{color:var(--accent2);}

/* Add sub-category button row */
.budget-add-sub-row{
  display:flex;align-items:center;gap:6px;
  padding:10px 14px 10px 38px;
  border-top:1px solid var(--border);
  cursor:pointer;
  color:var(--accent);font-size:13px;font-weight:600;
  transition:background .15s;
}
.budget-add-sub-row:active{background:var(--surface2);}

/* Sub drag handle */
.budget-sub-drag-handle{
  color:var(--text3);cursor:grab;
  padding:2px 8px 2px 0;font-size:13px;line-height:1;
  flex-shrink:0;touch-action:none;
  user-select:none;-webkit-user-select:none;
}
.budget-sub-drag-handle:active{cursor:grabbing;}
.budget-sub-row.dragging{opacity:.4;}
.budget-sub-row.drag-over{box-shadow:inset 0 0 0 2px var(--accent);}

/* Progress strip */
.budget-group-bar-wrap{height:3px;background:var(--surface2);}
.budget-group-bar{height:100%;transition:width .4s ease;}

/* Budget summary bar */
.budget-summary{margin:12px 16px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;}
.budget-summary-row{display:flex;justify-content:space-between;margin-bottom:10px;}
.budget-summary-item{text-align:center;}
.budget-summary-val{font-family:var(--font-display);font-size:22px;font-weight:900;line-height:1;}
.budget-summary-lbl{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text2);margin-top:3px;}
.budget-summary-track{height:5px;background:var(--surface2);border-radius:3px;overflow:hidden;}
.budget-summary-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .4s ease;}
.budget-savings{display:flex;align-items:center;justify-content:space-between;margin:8px 16px 0;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);}
.budget-savings-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text2);}
.budget-savings-val{font-family:var(--font-display);font-size:20px;font-weight:900;}

/* ── Accounts Screen ── */
.account-section-header{padding:12px 16px 6px;display:flex;align-items:center;justify-content:space-between;}
.account-section-title{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text2);}
.account-section-total{font-family:var(--font-display);font-size:14px;font-weight:700;}
.acct-section-rename-btn{background:none;border:none;padding:2px;cursor:pointer;color:var(--text3);opacity:0.6;display:flex;align-items:center;transition:opacity .15s;}
.acct-section-rename-btn:active{opacity:1;color:var(--accent);}
.account-item{margin:0 16px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .15s;gap:16px;}
.account-item:active{border-color:var(--accent);}
.account-item.dragging{opacity:.4;}
.account-item.drag-over{box-shadow:0 0 0 2px var(--accent);}
.acct-drag-handle{display:flex;align-items:center;padding:0 4px 0 0;color:var(--text3);cursor:grab;font-size:16px;line-height:1;flex-shrink:0;touch-action:none;user-select:none;}
.acct-drag-handle:active{cursor:grabbing;color:var(--accent);}
.account-info{flex:1;}
.account-name{font-family:var(--font-display);font-size:16px;font-weight:700;}
.account-type-label{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;}
.account-bal{font-family:var(--font-display);font-size:22px;font-weight:900;}
.account-bal.asset{color:var(--green);}
.account-bal.debt{color:var(--accent2);}

/* Net Worth hero */
.nw-hero{margin:14px 16px 8px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;}
.nw-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text2);margin-bottom:8px;}
.nw-value{font-family:var(--font-display);font-size:38px;font-weight:900;color:var(--accent);letter-spacing:0;line-height:1.1;word-break:break-all;}
.nw-value.negative{color:var(--accent2);}
.nw-delta{font-size:12px;color:var(--text3);margin-top:8px;}

/* ── Filter Chips ── */
.chip-row{display:flex;gap:8px;padding:0 16px 12px;overflow-x:auto;}
.chip-row::-webkit-scrollbar{display:none;}
.chip{flex-shrink:0;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;}
.chip.active{background:var(--accent);color:#0a0a0a;border-color:var(--accent);}

/* ── Search ── */
.search-bar{margin:12px 16px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:15px;outline:none;width:calc(100% - 32px);}
.search-bar:focus{border-color:var(--accent);}
.search-bar::placeholder{color:var(--text3);}

/* ── Toggle Group ── */
.toggle-group{display:flex;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex-shrink:0;}
.toggle-btn{padding:7px 12px;background:none;border:none;border-right:1px solid var(--border);color:var(--text2);cursor:pointer;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:all .15s;}
.toggle-btn:last-child{border-right:none;}
.toggle-btn.active{background:var(--accent);color:#0a0a0a;}

/* ── Recurring Badge ── */
.recur-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.5px;background:rgba(52,152,219,.15);color:var(--blue);border:1px solid rgba(52,152,219,.3);}

/* ── Safety Banner ── */
#safety-banner{display:none;align-items:center;justify-content:space-between;padding:6px 14px;font-size:11px;font-weight:600;letter-spacing:.3px;flex-shrink:0;gap:8px;border-bottom:1px solid var(--border);}
#safety-banner.status-good{background:rgba(46,204,113,.08);color:#2ecc71;}
#safety-banner.status-warn{background:rgba(243,156,18,.08);color:#f39c12;}
#safety-banner.status-none{background:rgba(255,71,87,.08);color:#ff4757;}
.safety-banner-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.safety-banner-dismiss{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:14px;padding:0 2px;line-height:1;flex-shrink:0;}

/* ── Month Nav ── */
.month-nav{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.month-nav-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);cursor:pointer;padding:4px 14px;font-family:var(--font-display);font-size:16px;font-weight:700;}
.month-nav-btn:active{background:var(--surface2);}
.month-label{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:1px;min-width:130px;text-align:center;}

/* ── Toast ── */
#toast-container{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:600;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;width:calc(100% - 32px);max-width:360px;}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:6px;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;animation:toastIn .25s ease both;pointer-events:auto;width:100%;box-shadow:0 4px 24px rgba(0,0,0,.5);}
.toast.info{background:#1e2a1e;border:1px solid var(--green);color:var(--green);}
.toast.error{background:#2a1e1e;border:1px solid var(--accent2);color:var(--accent2);}
.toast.warning{background:#2a261e;border:1px solid #f39c12;color:#f39c12;}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Empty State ── */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 32px;text-align:center;}
.empty-icon{font-size:48px;opacity:.3;}
.empty-title{font-family:var(--font-display);font-size:22px;font-weight:900;letter-spacing:1px;color:var(--text2);}
.empty-sub{font-size:13px;color:var(--text3);line-height:1.6;}

/* ── Confirm Dialog ── */
#confirm-dialog{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:700;align-items:center;justify-content:center;padding:32px;}
#confirm-dialog.show{display:flex;}
.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px 20px;width:100%;max-width:320px;text-align:center;}
.confirm-title{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--accent2);margin-bottom:8px;}
.confirm-msg{font-size:14px;color:var(--text2);margin-bottom:20px;line-height:1.5;}
.confirm-row{display:flex;gap:10px;}

/* ── Drive Buttons ── */
.drive-btn{width:100%;padding:10px 14px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px;transition:opacity .15s;}
.drive-btn:last-child{margin-bottom:0;}
.drive-btn:active{opacity:.75;}
.drive-btn:disabled{opacity:.4;cursor:not-allowed;}
.drive-btn.connect{background:rgba(66,133,244,.15);color:#4285f4;border:1px solid rgba(66,133,244,.3);}
.drive-btn.backup{background:rgba(52,168,83,.15);color:#34a853;border:1px solid rgba(52,168,83,.3);}
.drive-btn.logout{background:rgba(255,71,87,.08);color:var(--accent2);border:1px solid rgba(255,71,87,.25);}

/* ── Data section block (Settings) ── */
.data-block{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.data-block-header{padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--border);}
.data-block-header span{font-family:var(--font-display);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text2);}
.data-block-row{padding:12px 14px;border-bottom:1px solid var(--border);}
.data-block-row:last-child{border-bottom:none;}
.data-block-row-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;}

/* ── Animations ── */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.animated{animation:fadeIn .3s ease both;}

/* ── Dashboard specific ── */
.dash-cashflow-card{margin:0 16px 10px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);}
.dash-cf-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text2);margin-bottom:8px;}
.dash-cf-bar-track{height:4px;background:var(--surface2);border-radius:2px;overflow:hidden;margin-top:10px;}
.dash-cf-bar-fill{height:100%;border-radius:2px;transition:width .4s ease;}

/* ── Reports ── */
.filter-row{display:flex;gap:8px;padding:0 16px 12px;overflow-x:auto;align-items:center;}
.filter-row::-webkit-scrollbar{display:none;}

/* ── Manual Spend Adjustment ── */
.adj-tappable{cursor:pointer;position:relative;display:flex;align-items:center;justify-content:flex-end;gap:3px;}
.adj-tappable:active{opacity:.7;}
.adj-dot{font-size:9px;color:var(--orange);line-height:1;flex-shrink:0;}

/* ── Projected Savings bar in budget summary ── */
.budget-proj-savings{display:flex;align-items:center;justify-content:space-between;padding:7px 14px 8px;border-top:1px solid var(--border);}
.budget-proj-lbl{font-family:var(--font-display);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);}
.budget-proj-val{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.3px;}

/* ── Pending / recurring transactions ── */
.txn-pending{opacity:.75;border-left:3px solid var(--orange) !important;}
.pending-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--orange);background:rgba(243,156,18,.12);border:1px solid rgba(243,156,18,.3);border-radius:3px;padding:1px 5px;margin-left:4px;vertical-align:middle;}


/* ── Phone portrait budget layout ────────────────────────────
   Three-column mobile view: Category | Budgeted | Left.
   Spent/Pending move into the compact subline under the category name. */
@media (max-width: 480px) {
  .budget-col-header-labels{
    grid-template-columns:var(--bc1) var(--bc4);
  }
  .budget-col-header-lbl:nth-child(2),
  .budget-col-header-lbl:nth-child(3){ display:none; }

  .budget-group-cols,
  .budget-sub-cols:not(.budget-sub-cols-2){
    grid-template-columns:var(--bc1) var(--bc4);
  }
  .budget-group-col:nth-child(2),
  .budget-group-col:nth-child(3),
  .budget-sub-cols:not(.budget-sub-cols-2) .budget-sub-col:nth-child(2),
  .budget-sub-cols:not(.budget-sub-cols-2) .budget-sub-col:nth-child(3){ display:none; }

  .budget-mobile-meta{ display:block; }
  .budget-group-header{ padding:11px 12px; }
  .budget-sub-row{ padding:10px 12px; align-items:flex-start; }
  .budget-group-cols,
  .budget-sub-cols{ padding-top:1px; }
  .budget-group-menu-btn{ margin-right:2px; padding-left:4px; padding-right:4px; }
}

/* ============================================================
   DESKTOP LAYOUT  (≥ 768px) — top nav bar
   ============================================================ */
/* Nav brand — desktop only */
.nav-brand { display: none; }

/* Multi-month toggle hidden by default on mobile */
.budget-multi-toggle { display: none; }

@media (min-width: 768px) {

  /* ── Root shell: column, full height, centered ── */
  html, body { overflow: hidden; }

  #app {
    flex-direction: column;
    max-width: 1280px;
    margin: 0 auto;
    height: 100vh;
    height: 100dvh;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
  }

  /* ── Top nav bar — replaces bottom nav ── */
  .bottom-nav {
    flex-direction: row;
    order: -1;                        /* push above screens */
    border-top: none;
    border-bottom: 1px solid var(--border);
    padding: 0 16px;
    height: 52px;
    flex-shrink: 0;
    align-items: center;
    gap: 0;
    justify-content: flex-start;
  }

  /* Brand lockup on the left of desktop nav */
  .nav-brand {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    margin-right: 28px;
    flex-shrink: 0;
    line-height: 1.1;
  }
  .nav-brand-mark {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 900;
    letter-spacing: 2px;
    color: var(--accent);
  }
  .nav-brand-name {
    font-family: var(--font-display);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text3);
    white-space: nowrap;
  }

  .nav-btn {
    flex-direction: row;
    gap: 7px;
    padding: 0 16px;
    height: 100%;
    font-size: 11px;
    letter-spacing: 1px;
    border-radius: 0;
    border-bottom: 2px solid transparent;
    color: var(--text2);
    transition: color .15s, border-color .15s;
  }

  .nav-btn svg { width: 16px; height: 16px; flex-shrink: 0; }

  .nav-btn.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
    background: none;
    border-left: none;
    border-right: none;
    border-top: none;
  }

  /* ── Screens fill remaining height ── */
  .screen { flex: 1; min-width: 0; overflow: hidden; }

  /* ── Per-screen headers — slim subheader, hide title (nav bar shows active tab) ── */
  .screen > .header {
    padding: 8px 24px;
    min-height: 0;
    border-bottom: 1px solid var(--border);
  }
  .header-title { display: none; }
  .header-sub   { display: none; }

  /* ── Scroll areas ── */
  .scroll { padding-bottom: 24px; }
  .scroll::-webkit-scrollbar { width: 4px; }

  /* ── Month nav ── */
  .month-nav { padding: 10px 24px; }

  /* ── Content — wider side padding ── */
  .card                   { margin: 0 24px 12px; }
  .txn-item               { margin: 0 24px 8px; }
  .budget-group           { margin: 0 24px 8px; }
  .budget-summary         { margin: 12px 24px 0; }
  .chart-area             { margin: 0 24px 16px; }
  .account-item           { margin: 0 24px 8px; }
  .acct-drag-handle       { font-size: 18px; }
  .nw-hero                { margin: 16px 24px 10px; }
  .account-section-header { padding: 14px 24px 6px; }
  .stats-grid             { padding: 0 24px 16px; }
  .section-hd             { padding: 16px 24px 8px; }
  .search-bar             { margin: 12px 24px; width: calc(100% - 48px); }
  .chip-row               { padding: 0 24px 12px; }
  .dash-cashflow-card     { margin: 0 24px 12px; }
  #dash-categories        { padding: 0 24px 4px; }
  #budget-income-summary  { margin-left: 24px; margin-right: 24px; }
  #budget-copy-banner     { margin-left: 24px; margin-right: 24px; }
  .budget-col-header      { padding: 10px 24px 4px; }

  /* ── Wider budget columns ── */
  :root { --bc1: 74px; --bc2: 78px; --bc3: 78px; --bc4: 74px; }

  /* ── Multi-month budget toggle ── */
  .budget-multi-toggle {
    display: flex;
    gap: 2px;
  }
  .budget-multi-toggle .toggle-btn {
    padding: 4px 10px;
    font-size: 11px;
  }

  /* ── Modals — centered dialog ── */
  .modal-backdrop { align-items: center; justify-content: center; padding: 24px; }
  .modal {
    border-radius: 10px;
    border: 1px solid var(--border);
    max-width: 480px;
    max-height: 88vh;
    padding: 28px;
    animation: modalFadeIn .2s ease;
  }
  @keyframes modalFadeIn {
    from { opacity: 0; transform: scale(.97) translateY(6px); }
    to   { opacity: 1; transform: scale(1)   translateY(0); }
  }

  /* ── Toast — no bottom nav offset ── */
  #toast-container { bottom: 24px; }

  /* ── Reports charts ── */
  #screen-reports .chart-area canvas { max-height: 200px; }

  /* ── Net worth ── */
  .nw-value { font-size: 44px; }

  /* ── Safety banner ── */
  #safety-banner { padding: 7px 24px; }
}

/* ── Balance column states ── */
.budget-sub-col.balance.zero  { color: var(--text3); }
.budget-sub-col.balance.none  { color: var(--text3); }
.budget-group-col.balance.zero { color: var(--text3); }
.budget-group-col.balance.none { color: var(--text3); }

/* ── Rollover indicator ── */
.rollover-dot { font-size: 10px; color: var(--blue); margin-right: 4px; vertical-align: middle; }

/* ── Toggle switch (iOS-style) ── */
.toggle-switch { position: relative; display: inline-block; width: 44px; height: 26px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 26px;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  left: 3px; top: 3px;
  background: var(--text3);
  border-radius: 50%;
  transition: transform .2s, background .2s;
}
.toggle-switch input:checked + .toggle-slider { background: rgba(52,152,219,.2); border-color: var(--blue); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(18px); background: var(--blue); }

/* ── Zero value neutral states ── */
.nw-value.zero { color: var(--text3); }
.stat-val:not(.positive):not(.negative) { color: var(--text3); }

/* ── Transfer transactions ── */
.txn-transfer { border-left: 3px solid var(--blue) !important; }
.reimb-badge  { display:inline-block;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);background:rgba(52,152,219,.12);border:1px solid rgba(52,152,219,.3);border-radius:3px;padding:1px 5px;margin-left:4px;vertical-align:middle; }

/* ── Multi-month budget ── */
.budget-multi-grid { display: flex; flex-direction: column; }

/* Sticky column-label header */
.budget-multi-header-row {
  display: grid;
  align-items: center;
  column-gap: 0;
  border-bottom: 2px solid var(--border);
  background: var(--surface2);
  padding: 0 24px;
  position: sticky;
  top: 0;
  z-index: 5;
}
.budget-multi-month-label {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-align: center;
  padding: 6px 0 2px;
}
.budget-multi-month-label.current { color: var(--text); }
.budget-multi-month-label.prior   { color: var(--text2); }
.budget-multi-col-lbl {
  font-family: var(--font-display);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text3);
  text-align: right;
  padding: 3px 10px 6px 0;
}

/* Group card */
.budget-multi-group {
  margin: 0 24px 8px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.budget-multi-group-header {
  display: grid;
  align-items: stretch;
  column-gap: 0;
  background: var(--surface2);
  border-bottom: 1px solid var(--border);
}
.budget-multi-group-info {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  overflow: hidden;
  padding: 9px 12px;
}
.budget-multi-group-name {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Data cells */
.budget-multi-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  padding: 9px 10px 9px 0;
}
.budget-multi-cell-val {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
}

/* Sub rows */
.budget-multi-sub {
  display: grid;
  align-items: stretch;
  column-gap: 0;
  border-bottom: 1px solid var(--border);
}
.budget-multi-sub:last-child { border-bottom: none; }
.budget-multi-sub-name {
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 7px 8px 7px 12px;
  align-self: center;
}
.budget-multi-sub-name:hover { color: var(--accent); }

/* Balance colors */
.budget-multi-bal.ok   { color: var(--green); }
.budget-multi-bal.warn { color: var(--orange); }
.budget-multi-bal.over { color: var(--accent2); }
.budget-multi-bal.zero { color: var(--text3); }
.budget-multi-bal.none { color: var(--text3); }

/* Summary cards */
.bmsc {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 14px;
  background: var(--surface);
  min-width: 0;
  margin: 0 4px;
}
.bmsc-label {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 4px;
}
.bmsc-tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text2);
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1px 6px;
  margin-bottom: 10px;
}
.bmsc-tag-actual { color: var(--text2); }
.bmsc-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}
.bmsc-key { font-size: 11px; color: var(--text3); white-space: nowrap; }
.bmsc-key-bold { font-weight: 700; color: var(--text2); }
.bmsc-val { font-family: var(--font-display); font-size: 13px; font-weight: 700; text-align: right; }
.bmsc-saved { font-size: 15px; font-weight: 900; }
.bmsc-divider { height: 1px; background: var(--border); margin: 6px 0; }

/* ── Budget overflow menu ── */
.budget-overflow-wrap {
  position: relative;
}
.budget-overflow-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  min-width: 210px;
  z-index: 200;
  box-shadow: 0 8px 24px rgba(0,0,0,.5);
  overflow: hidden;
  animation: menuFadeIn .12s ease;
}
.budget-overflow-menu.open { display: block; }
@keyframes menuFadeIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.budget-overflow-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: none;
  border: none;
  color: var(--text);
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .5px;
  text-align: left;
  white-space: nowrap;
  transition: background .1s;
}
.budget-overflow-item:active { background: var(--border); }
.budget-overflow-item svg { color: var(--text2); flex-shrink: 0; }

/* ── Owed / reimbursement budget section ───────────────────── */
.owed-budget-group{border-color:rgba(52,152,219,.35);}
.owed-group-header{background:rgba(52,152,219,.08);}
.owed-sub-row{background:rgba(52,152,219,.025);}
.owed-dot{font-size:11px;margin-right:4px;vertical-align:1px;}
.owed-budget-group .budget-group-col.balance,
.owed-budget-group .budget-sub-col.balance{color:var(--blue) !important;}
