@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@300;400;500;600;700&display=swap');

/* ─── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
button { cursor: pointer; font: inherit; }
input, select { font: inherit; }

/* ─── EZO Tokens ──────────────────────────────────────────── */
:root {
  --bg:          #080e14;
  --bg2:         #0d1520;
  --surface:     #111d2a;
  --border:      #1e2d3e;
  --border-dim:  #172233;
  --text:        #dde8f0;
  --text2:       #7a9ab0;
  --text3:       #4a6478;
  --accent:      #5ab4d8;
  --accent-bg:   rgba(90,180,216,.1);
  --accent-text: #dde8f0;
  --pos:         #3aaa70;
  --pos-bg:      rgba(58,170,112,.1);
  --neg:         #d05040;
  --neg-bg:      rgba(208,80,64,.1);
  --gold:        #5ab4d8;
  --gold-bg:     rgba(90,180,216,.1);
  --shadow-sm:   0 1px 3px rgba(0,0,0,.5);
  --shadow-md:   0 4px 20px rgba(0,0,0,.6);
  --shadow-lg:   0 12px 48px rgba(0,0,0,.8);
  --r:           0px;
  --r-lg:        0px;
  --r-xl:        0px;
  --sidebar-w:   240px;
  --nav-h:       60px;
  --serif:       'DM Serif Display', serif;
  --mono:        'Inter', sans-serif;
  --ease:        cubic-bezier(.22,1,.36,1);
  --display:     'DM Serif Display', serif;
  --body:        'Inter', sans-serif;
}

/* ─── Light theme ─────────────────────────────────────────── */
[data-theme="light"] {
  --bg:          #f0f5f8;
  --bg2:         #ffffff;
  --surface:     #e4ecf2;
  --border:      #c0d0dc;
  --border-dim:  #d4e0e8;
  --text:        #0e1820;
  --text2:       #3a5468;
  --text3:       #7090a4;
  --accent:      #1e7a9a;
  --accent-bg:   rgba(30,122,154,.1);
  --accent-text: #0e1820;
  --pos:         #207a50;
  --pos-bg:      rgba(32,122,80,.1);
  --neg:         #a03020;
  --neg-bg:      rgba(160,48,32,.1);
  --gold:        #1e7a9a;
  --gold-bg:     rgba(30,122,154,.1);
  --shadow-sm:   0 1px 3px rgba(0,0,0,.1);
  --shadow-md:   0 4px 20px rgba(0,0,0,.12);
  --shadow-lg:   0 12px 48px rgba(0,0,0,.18);
}
[data-theme="light"] .toggle { background: var(--border); }
[data-theme="light"] .toggle::after { transform: translateX(0); background: var(--bg2); }

/* Dark theme explicit */
[data-theme="dark"] {
  --bg:          #080e14;
  --bg2:         #0d1520;
  --surface:     #111d2a;
  --border:      #1e2d3e;
  --border-dim:  #172233;
  --text:        #dde8f0;
  --text2:       #7a9ab0;
  --text3:       #4a6478;
  --accent:      #5ab4d8;
  --accent-bg:   rgba(90,180,216,.1);
  --accent-text: #dde8f0;
  --pos:         #3aaa70;
  --pos-bg:      rgba(58,170,112,.1);
  --neg:         #d05040;
  --neg-bg:      rgba(208,80,64,.1);
  --gold:        #5ab4d8;
  --gold-bg:     rgba(90,180,216,.1);
  --shadow-sm:   0 1px 3px rgba(0,0,0,.5);
  --shadow-md:   0 4px 20px rgba(0,0,0,.6);
  --shadow-lg:   0 12px 48px rgba(0,0,0,.8);
}

/* ─── Base ────────────────────────────────────────────────── */
html { height: 100%; background: #040a10; }
body {
  font-family: var(--serif);
  background: var(--bg);
  color: var(--text);
  height: 100%;
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  position: relative; z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
}

/* grain */
body::after {
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='280' height='280' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:180px;
}


/* ── BACK LINK (sidebar) ── */
.sidebar-back {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--text3); text-decoration: none;
  padding: 13px 18px; border-bottom: 1px solid var(--border);
  transition: color .15s; flex-shrink: 0;
}
.sidebar-back:hover { color: var(--text2); }
.sidebar-back::before { content: "←"; font-size: 12px; }

/* ─── Layout ──────────────────────────────────────────────── */
.app { display: flex; height: 100vh; overflow: hidden; }

/* ─── Sidebar ─────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  flex-shrink: 0; height: 100vh; overflow-y: auto;
}
.logo {
  padding: 20px 18px 16px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
}
.logo-mark {
  width: 30px; height: 30px;
  background: var(--bg); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; flex-shrink: 0;
}
.logo-mark img { width: 22px; height: 22px; display: block; }
.logo-name {
  font-family: var(--serif);
  font-size: 24px; font-weight: 400; letter-spacing: -.5px;
  color: var(--text);
}
.nav { padding: 12px 8px; flex: 1; }
.nav-section {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  color: var(--text3); letter-spacing: 3px; text-transform: uppercase;
  padding: 10px 10px 4px;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  color: var(--text3);
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  letter-spacing: .3px; text-transform: none;
  transition: all .12s; user-select: none;
  border: none; background: none; width: 100%; text-align: left;
}
.nav-item:hover { background: rgba(90,180,216,.04); color: var(--text2); }
.nav-item.active {
  background: var(--accent-bg);
  color: var(--accent);
  border-left: 2px solid var(--accent);
  padding-left: 8px;
}
.nav-icon { font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; }

.sidebar-foot {
  padding: 14px 18px; border-top: 1px solid var(--border); flex-shrink: 0;
}
.sb-month {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--text3); margin-bottom: 6px;
}
.sb-stats {
  font-family: var(--mono); font-size: 12px; font-weight: 400;
  line-height: 1.85; color: var(--text2); white-space: pre;
}
.theme-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 10px; margin-top: 10px;
  cursor: pointer; transition: background .1s;
  color: var(--text3);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  border: none; background: none; width: 100%;
}
.theme-row:hover { background: rgba(90,180,216,.04); color: var(--text2); }
.toggle {
  width: 34px; height: 18px;
  background: var(--border); position: relative;
  transition: background .2s; flex-shrink: 0; pointer-events: none;
}
[data-theme="dark"] .toggle { background: var(--accent); }
.toggle::after {
  content: ''; width: 12px; height: 12px;
  background: var(--bg2); position: absolute;
  top: 3px; left: 3px; transition: transform .2s;
}
[data-theme="dark"] .toggle::after { transform: translateX(16px); }

/* ─── Main ────────────────────────────────────────────────── */
.main { flex: 1; display: flex; flex-direction: column; min-width: 0; height: 100vh; overflow: hidden; }
.topbar {
  background: var(--bg2); border-bottom: 1px solid var(--border);
  padding: 12px clamp(20px,4vw,48px);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.topbar-title {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -.3px; color: var(--text);
}
.topbar-right { display: flex; gap: 8px; align-items: center; }
.content { flex: 1; overflow-y: auto; padding: clamp(24px,4vw,52px); scroll-behavior: smooth; }

/* ─── Mobile top bar ──────────────────────────────────────── */
.mob-top {
  display: none;
  background: var(--bg2); border-bottom: 1px solid var(--border);
  padding: 12px 16px; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.mob-title {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -.3px;
}

/* ─── Bottom nav (mobile) ─────────────────────────────────── */
.mob-nav {
  display: none; position: fixed;
  bottom: 0; left: 0; right: 0; z-index: 60;
  background: var(--bg2); border-top: 1px solid var(--border);
  height: var(--nav-h); justify-content: space-around; align-items: center;
  padding-bottom: env(safe-area-inset-bottom);
}
.mob-item {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  flex: 1; padding: 6px 4px;
  color: var(--text3);
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  border: none; background: none; cursor: pointer; transition: color .1s;
}
.mob-item .mi { font-size: 18px; line-height: 1; }
.mob-item.active { color: var(--accent); }

/* ─── FAB ─────────────────────────────────────────────────── */
.fab {
  display: none; position: fixed;
  bottom: calc(var(--nav-h) + 14px); right: 16px; z-index: 55;
  width: 50px; height: 50px;
  background: var(--accent); color: var(--bg);
  border: none; font-size: 26px; line-height: 1;
  align-items: center; justify-content: center;
  box-shadow: var(--shadow-lg);
  transition: transform .15s, opacity .15s;
}
.fab:active { transform: scale(.95); }

/* ─── Buttons ─────────────────────────────────────────────── */
.btn {
  padding: 7px 16px;
  border: 1px solid var(--border);
  background: var(--bg2); color: var(--text2);
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  transition: background .12s, border-color .12s, color .12s;
  white-space: nowrap;
}
.btn:hover { background: var(--surface); color: var(--text); border-color: var(--text3); }
.btn-primary {
  background: var(--accent); color: var(--bg); border-color: var(--accent);
  font-size: 13px; letter-spacing: 1.5px;
}
.btn-primary:hover { background: #fff; border-color: #fff; color: var(--bg); }
.btn-danger { border-color: rgba(208,64,48,.3); color: var(--neg); background: transparent; }
.btn-danger:hover { background: var(--neg-bg); }
.btn-sm { padding: 4px 10px; font-size: 10px; }
.btn-icon {
  width: 32px; height: 32px;
  border: 1px solid var(--border); background: var(--bg2); color: var(--text3);
  font-size: 14px; display: flex; align-items: center; justify-content: center;
  transition: background .1s, color .1s;
}
.btn-icon:hover { background: var(--surface); color: var(--text2); border-color: var(--text3); }

/* ─── Cards ───────────────────────────────────────────────── */
.card {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 18px 20px; box-shadow: var(--shadow-sm);
}
.card + .card { margin-top: 14px; }

/* ─── Summary grid ────────────────────────────────────────── */
.sum-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 24px; }
.sum-card {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 16px 18px; border-top: 2px solid var(--border);
  box-shadow: var(--shadow-sm); transition: border-color .2s;
}
.sum-card:hover { border-top-color: var(--accent); }
.sum-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 8px;
}
.sum-value {
  font-family: var(--serif); font-size: 28px; font-weight: 400;
  letter-spacing: -1px; line-height: 1;
}
.sum-value.pos { color: var(--pos); }
.sum-value.neg { color: var(--neg); }
.sum-tag {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 2px 8px; margin-top: 8px;
}
.tag-up { background: var(--pos-bg); color: var(--pos); }
.tag-dn { background: var(--neg-bg); color: var(--neg); }
.tag-nt { background: var(--surface); color: var(--text3); }

/* ─── Section header ──────────────────────────────────────── */
.sec-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.sec-title {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase; color: var(--text2);
}
.sec-sub { font-family: var(--mono); font-size: 10px; font-weight: 400; color: var(--text3); }

/* ─── Week grid ───────────────────────────────────────────── */
.week-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.week-label {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--text2);
}
.week-btns { display: flex; gap: 4px; }
.week-grid {
  display: grid; grid-template-columns: repeat(7,1fr);
  border: 1px solid var(--border);
  overflow: hidden; background: var(--bg2);
  margin-bottom: 22px; box-shadow: var(--shadow-sm);
}
.wday { border-right: 1px solid var(--border-dim); min-height: 148px; display: flex; flex-direction: column; }
.wday:last-child { border-right: none; }
.wday-hd {
  padding: 8px 8px 6px; border-bottom: 1px solid var(--border-dim);
  display: flex; align-items: baseline; justify-content: space-between;
}
.wday-name {
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  color: var(--text3); text-transform: uppercase; letter-spacing: 1.5px;
}
.wday-num { font-family: var(--mono); font-size: 12px; font-weight: 700; color: var(--text3); }
.wday-num.today {
  width: 20px; height: 20px;
  background: var(--accent); color: var(--bg);
  display: flex; align-items: center; justify-content: center; font-size: 10px;
}
.wday-body { padding: 5px; flex: 1; display: flex; flex-direction: column; gap: 2px; overflow: hidden; }
.wday-foot {
  padding: 2px 8px 6px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: .5px; color: var(--text3);
  border-top: 1px solid var(--border-dim); margin-top: auto;
}
.pill {
  padding: 3px 6px; font-size: 10px;
  display: flex; align-items: center; justify-content: space-between; gap: 3px;
  cursor: pointer; transition: opacity .1s; overflow: hidden;
  border: none; width: 100%; text-align: left;
}
.pill:hover { opacity: .72; }
.pill.income { background: var(--pos-bg); color: var(--pos); }
.pill.expense { background: var(--surface); color: var(--text3); }
.pill.bill { background: var(--neg-bg); color: var(--neg); }
.pill-name {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-family: var(--serif); font-weight: 700; max-width: 60px;
}
.pill-amt { font-family: var(--mono); font-size: 9px; font-weight: 400; flex-shrink: 0; }
.add-day {
  padding: 2px 6px; font-size: 10px; color: var(--text3);
  cursor: pointer; font-family: var(--serif); font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase; font-size: 9px;
  border: none; background: none; text-align: left; transition: color .1s;
}
.add-day:hover { color: var(--text2); background: var(--surface); }

/* Mobile week list */
.mob-week { display: none; }
.mob-day-card {
  background: var(--bg2); border: 1px solid var(--border);
  overflow: hidden; margin-bottom: 10px; box-shadow: var(--shadow-sm);
}
.mob-day-hd {
  padding: 10px 14px; border-bottom: 1px solid var(--border-dim);
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
}
.mob-day-hd.today-hd { color: var(--accent); }
.mob-day-body { padding: 8px 10px; display: flex; flex-direction: column; gap: 3px; }
.mob-tx {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 8px; background: var(--surface);
  cursor: pointer; transition: opacity .1s; border: none; width: 100%; text-align: left;
}
.mob-tx:hover { opacity: .8; }
.mob-tx-l { display: flex; align-items: center; gap: 8px; }
.mob-dot { width: 6px; height: 6px; flex-shrink: 0; }
.mob-tx-name { font-family: var(--mono); font-size: 14px; font-weight: 500; }
.mob-tx-cat {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--text3);
}
.mob-tx-amt { font-family: var(--mono); font-size: 14px; font-weight: 500; }
.mob-tx-amt.pos { color: var(--pos); }
.mob-tx-amt.neg { color: var(--text2); }
.mob-add {
  padding: 8px; color: var(--text3);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  cursor: pointer; border: none; background: none; transition: color .1s;
}
.mob-add:hover { color: var(--text2); background: var(--surface); }

/* ─── Bar chart ───────────────────────────────────────────── */
.bar-chart { display: flex; align-items: flex-end; gap: 4px; height: 84px; }
.bar-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.bar { width: 100%; min-height: 2px; transition: opacity .15s; cursor: default; }
.bar-lbl {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: .5px; color: var(--text3);
}

/* ─── Calendar ────────────────────────────────────────────── */
.cal-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.cal-title {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -1px; text-transform: uppercase;
}
.cal-grid {
  border: 1px solid var(--border);
  overflow: hidden; background: var(--bg2);
  margin-bottom: 20px; box-shadow: var(--shadow-sm);
}
.cal-dow-row { display: grid; grid-template-columns: repeat(7,1fr); border-bottom: 1px solid var(--border); }
.cal-dow {
  padding: 8px 0; text-align: center;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 1.5px;
}
.cal-body { display: grid; grid-template-columns: repeat(7,1fr); }
.cal-cell {
  border-right: 1px solid var(--border-dim); border-bottom: 1px solid var(--border-dim);
  min-height: 84px; padding: 5px 6px;
  display: flex; flex-direction: column; gap: 2px;
  cursor: pointer; transition: background .1s; position: relative;
}
.cal-cell:hover { background: var(--surface); }
.cal-cell:nth-child(7n) { border-right: none; }
.cal-cell.other { background: var(--bg); }
.cal-cell.other .cal-dn { opacity: .2; }
.cal-cell.is-today { background: var(--accent-bg); }
.cal-cell.is-sel:not(.is-today) { outline: 2px solid var(--accent); outline-offset: -2px; }
.cal-dn {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  color: var(--text2); align-self: flex-end; margin-bottom: 1px;
}
.is-today .cal-dn {
  width: 20px; height: 20px;
  background: var(--accent); color: var(--bg);
  display: flex; align-items: center; justify-content: center; font-size: 10px;
}
.cal-dots { display: flex; gap: 2px; flex-wrap: wrap; }
.cal-dot { width: 4px; height: 4px; flex-shrink: 0; }
.cal-sum {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: .5px; margin-top: auto; padding-top: 2px;
}
.cal-sum.pos { color: var(--pos); }
.cal-sum.neg { color: var(--neg); }
.cal-detail {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 16px 20px; box-shadow: var(--shadow-sm);
}
.cal-detail-date {
  font-family: var(--serif); font-size: 14px; font-weight: 900;
  letter-spacing: -.5px; text-transform: uppercase; margin-bottom: 12px;
}
.cal-tx-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid var(--border-dim);
  cursor: pointer; transition: opacity .1s;
}
.cal-tx-row:last-child { border-bottom: none; }
.cal-tx-row:hover { opacity: .72; }
.cal-tx-l { display: flex; align-items: center; gap: 8px; }
.cal-tx-dot { width: 7px; height: 7px; flex-shrink: 0; }
.cal-tx-name { font-family: var(--mono); font-size: 14px; font-weight: 500; }
.cal-tx-cat {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--text3); margin-top: 1px;
}
.cal-tx-amt { font-family: var(--mono); font-size: 14px; font-weight: 500; }
.cal-tx-amt.pos { color: var(--pos); }
.cal-tx-amt.neg { color: var(--text2); }
.cal-empty {
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--text3);
}

/* ─── Table ───────────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; }
thead th {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 2px; font-weight: 700;
  padding: 0 0 10px; text-align: left; border-bottom: 1px solid var(--border);
}
thead th:last-child { text-align: right; }
tbody tr { border-bottom: 1px solid var(--border-dim); cursor: pointer; transition: background .1s; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover td { background: var(--surface); }
tbody td { padding: 11px 6px 11px 0; font-size: 14px; font-family: var(--mono); vertical-align: middle; }
tbody td:first-child { padding-left: 2px; }
.td-mono {
  font-family: var(--mono); font-size: 11px; font-weight: 400;
  color: var(--text2);
}
.td-right {
  text-align: right; font-family: var(--mono); font-size: 14px; font-weight: 500;
}
.td-right.pos { color: var(--pos); }
.td-right.neg { color: var(--text2); }
.badge {
  display: inline-block; padding: 2px 8px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  background: var(--surface); color: var(--text3);
}
.cat-badge {
  display: inline-block; padding: 2px 8px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
}

/* ─── Budget bars ─────────────────────────────────────────── */
.budget-row { padding: 12px 0; border-bottom: 1px solid var(--border-dim); }
.budget-row:last-child { border-bottom: none; }
.budget-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 7px; }
.budget-name {
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  display: flex; align-items: center; gap: 7px;
}
.budget-amts {
  font-family: var(--mono); font-size: 11px; font-weight: 400; color: var(--text2);
}
.btrack { height: 3px; background: var(--border); overflow: hidden; }
.bfill { height: 100%; transition: width .5s var(--ease); }

/* ─── Accounts ────────────────────────────────────────────── */
.acc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 12px; margin-bottom: 20px; }
.acc-card {
  padding: 18px 20px; min-height: 126px;
  display: flex; flex-direction: column; justify-content: space-between;
  cursor: pointer; transition: transform .15s, box-shadow .15s;
  position: relative; overflow: hidden; border: none;
}
.acc-card::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.06) 0%, transparent 55%);
  pointer-events: none;
}
.acc-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.acc-top { display: flex; align-items: flex-start; justify-content: space-between; }
.acc-icon { font-size: 20px; }
.acc-edit-btn {
  width: 24px; height: 24px; border: none;
  background: rgba(255,255,255,.12); cursor: pointer; font-size: 12px;
  display: flex; align-items: center; justify-content: center; transition: background .1s;
}
.acc-edit-btn:hover { background: rgba(255,255,255,.24); }
.acc-name { font-family: var(--serif); font-size: 14px; font-weight: 700; margin-top: 8px; }
.acc-type {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; opacity: .55; margin-top: 2px;
}
.acc-bal {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -1px; margin-top: 8px;
}
.acc-add {
  border: 1px dashed var(--border);
  min-height: 126px; display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text3); transition: all .15s; background: none;
}
.acc-add:hover { border-color: var(--text2); color: var(--text2); background: var(--surface); }
.nw-bar { height: 4px; background: var(--border); display: flex; gap: 2px; overflow: hidden; margin: 10px 0 12px; }
.nw-seg { height: 100%; transition: flex .4s; }
.nw-legend { display: flex; flex-wrap: wrap; gap: 8px 14px; }
.nw-item {
  display: flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: .5px; color: var(--text2);
}
.nw-dot { width: 7px; height: 7px; flex-shrink: 0; }

/* ─── Goals ───────────────────────────────────────────────── */
.goals-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 12px; }
.goal-card {
  background: var(--bg2); border: 1px solid var(--border);
  padding: 16px 18px; box-shadow: var(--shadow-sm);
}
.goal-name {
  font-family: var(--serif); font-size: 14px; font-weight: 700;
  letter-spacing: .2px; display: flex; align-items: center; gap: 7px; margin-bottom: 10px;
}
.goal-amts {
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 11px; font-weight: 400; margin-bottom: 7px;
}
.gtrack { height: 3px; background: var(--border); overflow: hidden; }
.gfill { height: 100%; transition: width .5s var(--ease); }
.goal-sub {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--text3); margin-top: 5px;
}

/* ─── Cdot ────────────────────────────────────────────────── */
.cdot { display: inline-block; width: 6px; height: 6px; flex-shrink: 0; }

/* ─── Toast ───────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 20px; left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--acc, var(--accent)); color: var(--bg);
  padding: 10px 20px;
  font-family: var(--mono); font-size: 11px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  opacity: 0; transition: all .22s; z-index: 300; pointer-events: none; white-space: nowrap;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ─── Modals ──────────────────────────────────────────────── */
.overlay {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.75); backdrop-filter: blur(4px);
  align-items: center; justify-content: center; padding: 16px;
}
.overlay.open { display: flex; }
.modal {
  background: var(--bg2); border: 1px solid var(--border); border-top: 2px solid var(--accent);
  padding: 24px 26px; width: 100%; max-width: 390px;
  box-shadow: var(--shadow-lg);
  animation: popIn .18s var(--ease);
  max-height: 90vh; overflow-y: auto;
}
.modal-wide { max-width: 440px; }
@keyframes popIn {
  from { opacity: 0; transform: scale(.96) translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.modal-title {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -1px; text-transform: uppercase; margin-bottom: 18px;
}
.fl { margin-bottom: 14px; }
.fl label {
  display: block; font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 6px;
}
.fi {
  width: 100%; padding: 10px 12px;
  border: none; border-bottom: 2px solid var(--border);
  background: var(--surface); color: var(--text); outline: none;
  font-family: var(--serif); font-size: 18px; font-weight: 700; letter-spacing: -.3px;
  transition: border-color .12s, background .12s;
}
.fi:focus { border-bottom-color: var(--accent); background: var(--bg2); }
.fl2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.modal-actions {
  display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; align-items: center;
}
.modal-actions-left { margin-right: auto; }
.cswatch-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.cswatch {
  width: 24px; height: 24px; cursor: pointer;
  border: 2px solid transparent; transition: all .12s;
}
.cswatch.sel { border-color: var(--text); transform: scale(1.12); }
.iswatch-grid { display: flex; flex-wrap: wrap; gap: 4px; }
.iswatch {
  width: 32px; height: 32px; cursor: pointer;
  font-size: 17px; display: flex; align-items: center; justify-content: center;
  border: 1px solid transparent; transition: all .12s;
}
.iswatch.sel { background: var(--surface); border-color: var(--border); }
.iswatch:hover:not(.sel) { background: var(--surface); }
.acc-prev-card {
  padding: 13px 15px;
  display: flex; align-items: center; justify-content: space-between; margin-top: 4px;
}

/* ─── Empty state ─────────────────────────────────────────── */
.empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 60px 24px; text-align: center;
}
.empty-icon { font-size: 36px; margin-bottom: 14px; opacity: .3; }
.empty-title {
  font-family: var(--serif); font-size: 20px; font-weight: 900;
  letter-spacing: -1px; text-transform: uppercase; color: var(--text2); margin-bottom: 6px;
}
.empty-sub {
  font-family: var(--mono); font-size: 12px; font-weight: 300;
  color: var(--text3); line-height: 1.7; max-width: 260px; margin-bottom: 20px;
}
.empty-btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--accent); color: var(--bg);
  padding: 12px 24px;
  font-family: var(--mono); font-size: 11px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  border: none; cursor: pointer; transition: opacity .15s;
}
.empty-btn:hover { opacity: .88; background: #fff; }

/* ─── Data IO ─────────────────────────────────────────────── */
.data-btns { display: flex; gap: 5px; margin-top: 8px; }
.data-btn {
  flex: 1; padding: 6px 8px;
  border: 1px solid var(--border); background: none;
  color: var(--text3);
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; transition: all .12s; text-align: center;
}
.data-btn:hover { background: var(--surface); color: var(--text2); border-color: var(--text3); }

/* ─── Greeting ────────────────────────────────────────────── */
.greeting {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--text3); margin-bottom: 16px;
}

/* ─── Onboarding ──────────────────────────────────────────── */
.ob-overlay {
  position: fixed; inset: 0; z-index: 500;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center; padding: 24px;
  transition: opacity .4s var(--ease);
}
.ob-overlay.hiding { opacity: 0; pointer-events: none; }
.ob-overlay.gone { display: none; }
.ob-splash {
  text-align: center; max-width: 440px; width: 100%;
  animation: fadeUp .55s var(--ease) both;
}
.ob-logo {
  width: 60px; height: 60px;
  margin: 0 auto 26px; background: var(--bg2); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.ob-logo img { width: 44px; height: 44px; display: block; }
.ob-hed {
  font-family: var(--serif); font-size: clamp(38px,6vw,60px);
  font-weight: 900; letter-spacing: -2px; line-height: .9;
  text-transform: uppercase; margin-bottom: 14px;
}
.ob-hed em { color: var(--accent); font-style: normal; }
.ob-sub {
  font-family: var(--serif); font-size: 14px; font-weight: 300;
  color: var(--text2); line-height: 1.7; max-width: 360px; margin: 0 auto 32px;
}
.ob-cta {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--accent); color: var(--bg);
  padding: 14px 34px;
  font-family: var(--mono); font-size: 12px; font-weight: 800;
  letter-spacing: 2.5px; text-transform: uppercase;
  border: none; cursor: pointer; box-shadow: var(--shadow-md);
  transition: background .14s;
}
.ob-cta:hover { background: #fff; }
.ob-skip {
  display: block; margin-top: 16px;
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text3); cursor: pointer; border: none; background: none;
  transition: color .15s;
}
.ob-skip:hover { color: var(--text2); }

/* ── Returning user drop zone on splash ── */
.ob-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 28px auto 0; max-width: 380px; width: 100%;
}
.ob-divider::before, .ob-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.ob-divider span {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; color: var(--text3);
}
.ob-return {
  margin: 16px auto 0; max-width: 380px; width: 100%;
}
.ob-return-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase; color: var(--text3);
  margin-bottom: 10px;
}
.ob-drop {
  border: 1px dashed var(--border);
  padding: 22px 20px; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  transition: border-color .15s, background .15s;
  position: relative;
}
.ob-drop:hover, .ob-drop.drag-over {
  border-color: var(--accent); background: var(--accent-bg);
}
.ob-drop.drag-over { border-style: solid; }
.ob-drop-icon {
  font-size: 22px; color: var(--text3); line-height: 1;
  margin-bottom: 4px; transition: color .15s;
}
.ob-drop:hover .ob-drop-icon, .ob-drop.drag-over .ob-drop-icon { color: var(--accent); }
.ob-drop-text {
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: .3px; color: var(--text2);
}
.ob-drop-text em { color: var(--accent); font-style: normal; }
.ob-drop-hint {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--text3);
}
.ob-drop-status {
  margin-top: 8px; min-height: 18px; text-align: center;
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
}
.ob-drop-status.ok  { color: var(--pos); }
.ob-drop-status.err { color: var(--neg); }

.ob-card {
  background: var(--bg2); border: 1px solid var(--border); border-top: 2px solid var(--accent);
  padding: 32px 36px; max-width: 460px; width: 100%;
  box-shadow: var(--shadow-lg);
  animation: fadeUp .3s var(--ease) both;
}
.ob-pips { display: flex; gap: 5px; margin-bottom: 28px; }
.ob-pip { flex: 1; height: 2px; background: var(--border); transition: background .3s; }
.ob-pip.done { background: var(--accent); }
.ob-pip.cur  { background: var(--accent); opacity: .35; }
.ob-step-tag {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase; color: var(--accent); margin-bottom: 8px;
}
.ob-step-title {
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  letter-spacing: -1px; margin-bottom: 5px;
}
.ob-step-sub {
  font-family: var(--mono); font-size: 13px; font-weight: 300;
  color: var(--text2); line-height: 1.65; margin-bottom: 22px;
}
.ob-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.ob-chip {
  padding: 6px 16px; border: 1px solid var(--border); background: var(--bg2);
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: .5px; cursor: pointer; transition: all .12s; user-select: none;
}
.ob-chip:hover { border-color: var(--text2); }
.ob-chip.on { background: var(--accent-bg); border-color: var(--accent); color: var(--accent); }
.ob-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 26px; }
.ob-back {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text3); background: none; border: none; cursor: pointer; transition: color .15s;
}
.ob-back:hover { color: var(--text2); }
.ob-next {
  display: flex; align-items: center; gap: 7px;
  background: var(--accent); color: var(--bg);
  padding: 10px 22px;
  font-family: var(--mono); font-size: 11px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  border: none; cursor: pointer; transition: background .12s;
}
.ob-next:hover { background: #fff; }
.ob-done { text-align: center; animation: fadeUp .3s var(--ease) both; }
.ob-done-check {
  width: 56px; height: 56px;
  background: var(--accent-bg); border: 1px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; margin: 0 auto 18px; color: var(--accent);
}
.ob-done-title {
  font-family: var(--serif); font-size: 26px; font-weight: 900;
  letter-spacing: -1px; text-transform: uppercase; margin-bottom: 8px;
}
.ob-done-sub {
  font-family: var(--mono); font-size: 13px; font-weight: 300;
  color: var(--text2); line-height: 1.65; margin-bottom: 24px;
}

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

/* ─── CSV Import Modal ────────────────────────────────────── */
.csv-modal { max-width: 640px; }
.csv-step { display: none; }
.csv-step.active { display: block; }
.csv-step-tag {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase; color: var(--accent); margin-bottom: 6px;
}
.csv-step-title {
  font-family: var(--serif); font-size: 20px; font-weight: 900;
  letter-spacing: -.5px; margin-bottom: 4px;
}
.csv-step-sub {
  font-family: var(--mono); font-size: 12px; font-weight: 300;
  color: var(--text2); margin-bottom: 18px; line-height: 1.6;
}
.csv-pips { display: flex; gap: 5px; margin-bottom: 22px; }
.csv-pip { flex: 1; height: 2px; background: var(--border); transition: background .3s; }
.csv-pip.done { background: var(--accent); }
.csv-pip.cur  { background: var(--accent); opacity: .35; }

.col-map-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.col-map-row { display: flex; flex-direction: column; gap: 4px; }
.col-map-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--text2); text-transform: uppercase; letter-spacing: 1.5px;
}
.col-map-req { color: var(--accent); }
.csv-preview-wrap { margin-top: 14px; }
.csv-preview-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.5px; color: var(--text3); margin-bottom: 6px;
}
.csv-preview-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--mono); font-size: 10px; font-weight: 400;
  max-height: 120px; overflow: auto; display: block;
}
.csv-preview-table th {
  font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text3); padding: 3px 6px 5px 0;
  border-bottom: 1px solid var(--border); text-align: left; white-space: nowrap;
}
.csv-preview-table td {
  padding: 3px 6px 3px 0; color: var(--text2); white-space: nowrap;
  border-bottom: 1px solid var(--border-dim);
}

.review-wrap { max-height: 320px; overflow-y: auto; border: 1px solid var(--border); }
.review-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.review-table thead th {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.5px; color: var(--text3);
  padding: 8px 8px; border-bottom: 1px solid var(--border);
  position: sticky; top: 0; background: var(--bg2); text-align: left; white-space: nowrap;
}
.review-table tbody tr { border-bottom: 1px solid var(--border-dim); transition: background .1s; }
.review-table tbody tr:last-child { border-bottom: none; }
.review-table tbody tr.excluded { opacity: .3; }
.review-table tbody td { padding: 7px 8px; vertical-align: middle; }
.review-table tbody td:last-child { text-align: right; }
.rv-amt { font-family: var(--mono); font-size: 12px; font-weight: 700; }
.rv-amt.pos { color: var(--pos); }
.rv-amt.neg { color: var(--text2); }
.rv-date { font-family: var(--mono); font-size: 10px; color: var(--text2); }
.rv-cat select {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); padding: 2px 6px;
}
.rv-type select {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); padding: 2px 6px;
}
.rv-toggle { width: 14px; height: 14px; cursor: pointer; accent-color: var(--accent); }
.review-summary {
  display: flex; gap: 16px; padding: 10px 0 4px;
  font-family: var(--mono); font-size: 10px; font-weight: 400;
  color: var(--text2); flex-wrap: wrap;
}
.review-summary strong { color: var(--text); font-weight: 700; }
.drop-zone {
  border: 1px dashed var(--border);
  padding: 36px 24px; text-align: center; cursor: pointer;
  transition: all .15s;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--text3);
}
.drop-zone:hover, .drop-zone.drag-over {
  border-color: var(--accent); color: var(--cream2); background: var(--accent-bg);
}
.drop-zone-icon { font-size: 28px; display: block; margin-bottom: 10px; opacity: .4; }
.drop-note {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text3); margin-top: 8px; display: block;
}

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .sidebar { display: none; }
  .topbar { display: none; }
  .mob-top { display: flex; }
  .mob-nav { display: flex; }
  .fab { display: flex; }
  .content { padding: 14px 14px calc(var(--nav-h) + 20px); }
  .sum-grid { grid-template-columns: repeat(2,1fr); gap: 9px; margin-bottom: 16px; }
  .sum-value { font-size: 20px; }
  .week-grid { display: none; }
  .mob-week { display: block; }
  .week-nav { display: none; }
  .cal-cell { min-height: 60px; }
  .acc-grid { grid-template-columns: repeat(2,1fr); }
  .goals-grid { grid-template-columns: 1fr; }
  .fl2 { grid-template-columns: 1fr; }
  .ob-card { padding: 24px 20px; }
}
@media (max-width: 480px) {
  .sum-grid { grid-template-columns: 1fr 1fr; }
  .acc-grid { grid-template-columns: 1fr; }
  .cal-cell { min-height: 46px; padding: 3px 4px; }
  .cal-dn { font-size: 10px; }
  .modal { padding: 20px 16px; }
  .toast { bottom: calc(var(--nav-h) + 10px); }
}
