/* ============================================================
   LAKFINTER — main.css
   Design language: a working ledger book, not a fintech dashboard.
   Ink-on-paper warmth, tabular numerals for money, a single deep
   accent (ledger-red) reserved for debits/alerts only — everything
   else stays quiet so numbers are what catches the eye.
   ============================================================ */

:root {
  /* Palette */
  --paper:        #FAF6EE;   /* page background — warm, not stark white */
  --paper-raised: #FFFFFF;   /* cards/panels sitting "on top of" the page */
  --ink:          #2B2620;   /* primary text — soft black, not pure #000 */
  --ink-muted:    #6B6356;   /* secondary text */
  --rule:         #DDD3C0;   /* hairline rules, table borders */
  --rule-strong:  #B9AD92;
  --ledger-green: #2F5D45;   /* credits, positive balances, primary action */
  --ledger-green-dim: #DCE8DF;
  --ledger-red:   #8C2F2F;   /* debits, negative balances, destructive action */
  --ledger-red-dim: #F1DEDE;
  --gold:         #9C7A2E;   /* savings / net worth accent */
  --gold-dim:     #F1E6CC;

  /* Type */
  --font-display: "Source Serif 4", "Iowan Old Style", "Georgia", serif;
  --font-body:    "Inter", "Helvetica Neue", Arial, sans-serif;
  --font-mono:    "IBM Plex Mono", "SF Mono", ui-monospace, monospace;

  /* Scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;

  --radius-sm: 4px;
  --radius-md: 8px;

  color-scheme: light;
}

* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

#app {
  min-height: 100vh;
}

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 600;
  margin: 0;
  color: var(--ink);
}

a {
  color: var(--ledger-green);
  text-decoration: none;
}
a:hover { text-decoration: underline; }

button {
  font-family: var(--font-body);
  cursor: pointer;
}

/* Money values everywhere use tabular figures so columns of numbers align */
.num, .money, td.amount, .closing-balance {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.money.credit, .num.positive { color: var(--ledger-green); }
.money.debit, .num.negative  { color: var(--ledger-red); }

/* Visible keyboard focus ring everywhere — never suppressed */
:focus-visible {
  outline: 2px solid var(--ledger-green);
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}

/* ------------------------------------------------------------
   Boot screen (Phase 1 placeholder — replaced by login in Phase 2)
   ------------------------------------------------------------ */
.boot-screen {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: var(--space-5);
}

.boot-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-7) var(--space-6);
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: 0 1px 2px rgba(43, 38, 32, 0.04);
}

.boot-mark {
  font-size: 28px;
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.boot-title {
  font-size: 32px;
  letter-spacing: 0.01em;
}

.boot-sub {
  color: var(--ink-muted);
  font-size: 14px;
  margin: var(--space-2) 0 var(--space-5) 0;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.boot-status {
  font-size: 14px;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--paper);
  border: 1px solid var(--rule);
  color: var(--ink-muted);
}

.boot-status[data-kind="ok"] {
  background: var(--ledger-green-dim);
  border-color: var(--ledger-green);
  color: var(--ledger-green);
}

.boot-status[data-kind="error"] {
  background: var(--ledger-red-dim);
  border-color: var(--ledger-red);
  color: var(--ledger-red);
}

/* ------------------------------------------------------------
   Login screen
   ------------------------------------------------------------ */
.login-screen {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: var(--space-5);
}

.login-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-7) var(--space-6);
  max-width: 380px;
  width: 100%;
  text-align: center;
  box-shadow: 0 1px 2px rgba(43, 38, 32, 0.04);
}

.login-mark {
  font-size: 28px;
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.login-title {
  font-size: 28px;
}

.login-sub {
  color: var(--ink-muted);
  font-size: 14px;
  margin: var(--space-2) 0 var(--space-6) 0;
}

.field-label {
  display: block;
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-2);
}

#login-username {
  width: 100%;
  padding: var(--space-3);
  margin-bottom: var(--space-5);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  font-size: 16px;
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
}

#login-username:focus {
  border-color: var(--ledger-green);
}

.pin-pad {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  margin-bottom: var(--space-5);
}

.pin-digit {
  width: 44px;
  height: 52px;
  text-align: center;
  font-size: 24px;
  font-family: var(--font-mono);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  background: var(--paper);
  color: var(--ink);
}

.pin-digit:focus {
  border-color: var(--ledger-green);
  background: var(--paper-raised);
}

.login-error {
  background: var(--ledger-red-dim);
  border: 1px solid var(--ledger-red);
  color: var(--ledger-red);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  font-size: 14px;
  margin: 0 0 var(--space-4) 0;
  text-align: left;
}

.btn-primary {
  width: 100%;
  padding: var(--space-4);
  background: var(--ledger-green);
  color: var(--paper-raised);
  border: none;
  border-radius: var(--radius-sm);
  font-size: 16px;
  font-weight: 600;
  transition: background 0.15s ease;
}

.btn-primary:hover { background: #244A37; }
.btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }

.btn-secondary {
  padding: var(--space-3) var(--space-5);
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  font-size: 14px;
}
.btn-secondary:hover { background: var(--paper); }

.login-footnote {
  font-size: 12px;
  color: var(--ink-muted);
  margin: var(--space-5) 0 0 0;
  line-height: 1.5;
}

/* ------------------------------------------------------------
   App shell — layout skeleton shared by desktop and mobile.
   desktop.css / mobile.css decide where the sidebar/bottom-nav
   actually sit; this just defines the pieces and their resting state.
   ------------------------------------------------------------ */

.app-shell {
  display: flex;
  min-height: 100vh;
}

.content-area {
  flex: 1;
  min-width: 0;
  background: var(--paper);
}

.tab-loading {
  padding: var(--space-6);
  color: var(--ink-muted);
  font-size: 14px;
}

.tab-content {
  padding: var(--space-6) var(--space-5);
  max-width: 1100px;
  margin: 0 auto;
}

.tab-header {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--rule);
}

.tab-header h1 {
  font-size: 26px;
}

.tab-sub {
  color: var(--ink-muted);
  font-size: 14px;
  margin: var(--space-2) 0 0 0;
}

.placeholder-panel {
  border: 1px dashed var(--rule-strong);
  border-radius: var(--radius-md);
  padding: var(--space-7);
  text-align: center;
  color: var(--ink-muted);
  font-size: 14px;
}

/* Nav items — shared markup between sidebar (desktop) and bottom nav (mobile);
   each stylesheet positions/sizes the container differently. */
.nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  color: var(--ink-muted);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 500;
}

.nav-item:hover {
  background: var(--paper);
  text-decoration: none;
  color: var(--ink);
}

.nav-item.is-active {
  background: var(--ledger-green-dim);
  color: var(--ledger-green);
  font-weight: 600;
}

.nav-icon {
  font-size: 16px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

/* ------------------------------------------------------------
   Home tab
   ------------------------------------------------------------ */
.home-header {
  margin-bottom: var(--space-6);
}

.home-greeting {
  color: var(--ink-muted);
  font-size: 14px;
  margin: 0;
}

.home-username {
  font-size: 32px;
  margin: var(--space-1) 0 var(--space-2) 0;
}

.home-date {
  color: var(--ink-muted);
  font-size: 14px;
  margin: 0 0 var(--space-3) 0;
}

.device-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 12px;
  color: var(--ledger-green);
  background: var(--ledger-green-dim);
  border-radius: 999px;
  padding: var(--space-1) var(--space-3);
}

.device-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ledger-green);
  display: inline-block;
}

.home-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.home-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-4);
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  color: var(--ink);
  text-align: center;
  transition: border-color 0.15s ease, transform 0.1s ease;
}

.home-card:hover {
  border-color: var(--ledger-green);
  text-decoration: none;
  transform: translateY(-1px);
}

.home-card-icon {
  font-size: 26px;
  color: var(--gold);
}

.home-card-label {
  font-size: 14px;
  font-weight: 600;
}

/* ------------------------------------------------------------
   Settings — shared section chrome
   ------------------------------------------------------------ */
.settings-subnav {
  display: flex;
  gap: var(--space-2);
  border-bottom: 1px solid var(--rule);
  margin-bottom: var(--space-5);
  overflow-x: auto;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}

.settings-subnav-btn {
  background: none;
  border: none;
  padding: var(--space-3) var(--space-3);
  font-size: 14px;
  color: var(--ink-muted);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}

.settings-subnav-btn.is-active {
  color: var(--ledger-green);
  border-bottom-color: var(--ledger-green);
  font-weight: 600;
}

.section-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.section-hint {
  color: var(--ink-muted);
  font-size: 13px;
  margin: 0;
  max-width: 560px;
}

.btn-small {
  width: auto;
  padding: var(--space-2) var(--space-4);
  font-size: 13px;
  flex-shrink: 0;
}

.tree-loading, .tree-empty {
  color: var(--ink-muted);
  font-size: 14px;
  padding: var(--space-4) 0;
}

.form-error {
  color: var(--ledger-red);
  font-size: 14px;
}

/* ------------------------------------------------------------
   Groups Master — tree view
   ------------------------------------------------------------ */
.tree-view {
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  background: var(--paper-raised);
}

.tree-node {
  margin-bottom: var(--space-1);
}

.tree-node-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-2);
  border-radius: var(--radius-sm);
}

.tree-node-row:hover {
  background: var(--paper);
}

.tree-node-label {
  font-size: 14px;
  font-weight: 500;
}

.tree-children {
  margin-left: var(--space-5);
  padding-left: var(--space-3);
  border-left: 1px solid var(--rule);
}

.tree-node-actions {
  display: flex;
  gap: var(--space-1);
  opacity: 0;
  transition: opacity 0.1s ease;
}

.tree-node-row:hover .tree-node-actions {
  opacity: 1;
}

/* Touch devices have no hover state, so action buttons must stay visible —
   detected via (hover: none) rather than viewport width, since some large
   touchscreens are wider than the mobile breakpoint. */
@media (hover: none) {
  .tree-node-actions {
    opacity: 1;
  }
}

.tree-action-btn {
  background: none;
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  padding: var(--space-1) var(--space-2);
  font-size: 11px;
  color: var(--ink-muted);
  white-space: nowrap;
}

.tree-action-btn:hover {
  background: var(--paper);
  color: var(--ink);
}

.tree-action-danger:hover {
  background: var(--ledger-red-dim);
  color: var(--ledger-red);
  border-color: var(--ledger-red);
}

/* ------------------------------------------------------------
   Subcode Master — category chips + tag pills
   ------------------------------------------------------------ */
.subcode-category-tabs {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.chip {
  background: var(--paper-raised);
  border: 1px solid var(--rule-strong);
  border-radius: 999px;
  padding: var(--space-2) var(--space-4);
  font-size: 13px;
  color: var(--ink-muted);
}

.chip.is-active {
  background: var(--ledger-green);
  border-color: var(--ledger-green);
  color: var(--paper-raised);
  font-weight: 600;
}

.add-inline-row {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.add-inline-row input {
  flex: 1;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  font-size: 14px;
  background: var(--paper-raised);
  color: var(--ink);
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.tag-pill {
  background: var(--gold-dim);
  color: var(--gold);
  border-radius: 999px;
  padding: var(--space-1) var(--space-3);
  font-size: 13px;
  font-weight: 500;
}

/* ------------------------------------------------------------
   Data tables (Accounts, Devices, Import preview)
   ------------------------------------------------------------ */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.data-table th {
  text-align: left;
  color: var(--ink-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--rule-strong);
}

.data-table td {
  padding: var(--space-3);
  border-bottom: 1px solid var(--rule);
}

.data-table tr.row-duplicate {
  opacity: 0.5;
}

.table-scroll {
  overflow-x: auto;
  max-width: 100%;
}

.status-pill {
  display: inline-block;
  border-radius: 999px;
  padding: 2px var(--space-2);
  font-size: 11px;
  font-weight: 600;
}

.status-active {
  background: var(--ledger-green-dim);
  color: var(--ledger-green);
}

.status-inactive {
  background: var(--rule);
  color: var(--ink-muted);
}

/* ------------------------------------------------------------
   Import flow
   ------------------------------------------------------------ */
.import-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  border: 2px dashed var(--rule-strong);
  border-radius: var(--radius-md);
  padding: var(--space-7);
  text-align: center;
  cursor: pointer;
  color: var(--ink-muted);
}

.import-dropzone:hover {
  border-color: var(--ledger-green);
  color: var(--ledger-green);
}

.import-dropzone-icon {
  font-size: 28px;
}

.import-hint {
  color: var(--ink-muted);
  font-size: 12px;
  margin-top: var(--space-3);
}

.mapping-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin: var(--space-4) 0;
}

.mapping-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.mapping-field-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-muted);
}

.mapping-row select {
  padding: var(--space-2);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  background: var(--paper-raised);
  font-size: 14px;
}

.import-actions {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.import-actions .btn-primary,
.import-actions .btn-secondary {
  width: auto;
  padding: var(--space-3) var(--space-5);
}

.progress-bar {
  height: 8px;
  background: var(--rule);
  border-radius: 999px;
  overflow: hidden;
  margin: var(--space-4) 0;
}

.progress-bar-fill {
  height: 100%;
  background: var(--ledger-green);
  width: 0%;
  transition: width 0.2s ease;
}

/* ============================================================
   PHASE 5 — Ledger tab
   ============================================================ */

/* ----- Filter bar ----- */
.ledger-filters {
  background: var(--paper-raised);
  border-bottom: 1px solid var(--rule);
  padding: var(--space-3) var(--space-5);
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.filter-label {
  font-size: 12px;
  color: var(--ink-muted);
  white-space: nowrap;
}

.filter-input {
  font-size: 13px;
  padding: var(--space-1) var(--space-2);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  background: var(--paper);
  color: var(--ink);
  min-width: 80px;
  max-width: 180px;
}

.filter-input:focus {
  outline: 2px solid var(--ledger-green);
  outline-offset: 1px;
}

.ledger-stats {
  margin-top: var(--space-2);
  font-size: 12px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
}

/* ----- Table ----- */
.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ledger-table {
  min-width: 900px;
}

.ledger-row.is-transfer td {
  color: var(--ink-muted);
  font-style: italic;
}

.transfer-badge {
  font-style: normal;
  font-size: 11px;
  background: var(--gold-dim);
  color: var(--gold);
  padding: 1px 4px;
  border-radius: 3px;
  margin-left: var(--space-1);
}

.col-date    { width: 100px; white-space: nowrap; }
.col-details { min-width: 200px; }
.col-group   { width: 90px; }
.col-code    { width: 80px; }
.col-subcode { width: 90px; }
.col-amount  { width: 110px; }
.col-account { width: 90px; }
.col-actions { width: 70px; text-align: right; }

.closing-balance { font-weight: 600; }
.closing-balance.positive { color: var(--ledger-green); }
.closing-balance.negative { color: var(--ledger-red); }

/* Action buttons in table rows */
.action-btn {
  background: none;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 2px 6px;
  font-size: 13px;
  color: var(--ink-muted);
  cursor: pointer;
}
.action-btn:hover { background: var(--paper); border-color: var(--rule-strong); color: var(--ink); }
.delete-btn:hover { color: var(--ledger-red); border-color: var(--ledger-red-dim); }

.table-loading, .empty-state {
  text-align: center;
  padding: var(--space-7);
  color: var(--ink-muted);
  font-style: italic;
}

/* ----- Pagination ----- */
.pagination-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--rule);
}
.page-info {
  font-size: 13px;
  color: var(--ink-muted);
}

/* ----- Modal ----- */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(43, 38, 32, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  padding: var(--space-4);
}

.modal-card {
  background: var(--paper-raised);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 32px rgba(43, 38, 32, 0.18);
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--rule);
}

.modal-header h2 {
  font-size: 18px;
}

.modal-close-btn {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--ink-muted);
  cursor: pointer;
  padding: var(--space-1);
  line-height: 1;
}
.modal-close-btn:hover { color: var(--ink); }

.modal-body {
  padding: var(--space-4) var(--space-5);
  overflow-y: auto;
  flex: 1;
}

.modal-footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--rule);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  justify-content: flex-end;
}

/* ----- Form elements ----- */
.form-row {
  margin-bottom: var(--space-4);
}

.form-row-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.form-label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: var(--space-1);
  color: var(--ink);
}

.form-label .required {
  color: var(--ledger-red);
  margin-left: 2px;
}

.form-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  background: var(--paper);
  color: var(--ink);
  font-size: 14px;
  font-family: var(--font-body);
}
.form-input:focus {
  outline: 2px solid var(--ledger-green);
  outline-offset: 1px;
  border-color: var(--ledger-green);
}
.form-input.num {
  font-family: var(--font-mono);
  text-align: right;
}
.form-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.form-error {
  color: var(--ledger-red);
  font-size: 13px;
  margin: 0;
  flex: 1;
}

/* ----- Segmented control (entry type) ----- */
.segmented-control {
  display: inline-flex;
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.seg-btn {
  padding: var(--space-1) var(--space-4);
  background: none;
  border: none;
  font-size: 13px;
  color: var(--ink-muted);
  cursor: pointer;
  border-right: 1px solid var(--rule-strong);
}
.seg-btn:last-child { border-right: none; }
.seg-btn.is-active {
  background: var(--ledger-green);
  color: #fff;
  font-weight: 500;
}

/* ----- Subcode combo ----- */
.subcode-combo {
  position: relative;
}

.subcode-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--paper-raised);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(43, 38, 32, 0.1);
  z-index: 50;
  max-height: 200px;
  overflow-y: auto;
}

.subcode-option {
  padding: var(--space-2) var(--space-3);
  font-size: 13px;
  cursor: pointer;
  color: var(--ink);
}
.subcode-option:hover { background: var(--paper); }
.subcode-add-new {
  color: var(--ledger-green);
  font-style: italic;
  border-top: 1px solid var(--rule);
}

/* ============================================================
   PHASE 6 — Live Balance & Suspense
   ============================================================ */

/* ----- Balance cards ----- */
.balance-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-3);
  padding: var(--space-5);
  border-bottom: 1px solid var(--rule);
}

.balance-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.balance-card--suspense {
  border-style: dashed;
  border-color: var(--gold);
  background: var(--gold-dim);
}

.balance-card--total {
  border-color: var(--ledger-green);
  background: var(--ledger-green-dim);
}

.balance-card-label {
  font-size: 12px;
  color: var(--ink-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.balance-card-value {
  font-size: 20px;
  font-weight: 700;
  font-family: var(--font-mono);
}

.balance-card-sub {
  font-size: 11px;
  color: var(--ink-muted);
}

/* ----- Balance detail table ----- */
.balance-summary-wrap {
  padding: var(--space-5);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Running balance table — sticky date column, accounts as columns */
.balance-running-table {
  min-width: 600px;
  border-collapse: collapse;
  font-size: 13px;
}

.balance-running-table th,
.balance-running-table td {
  padding: 6px 10px;
  white-space: nowrap;
}

.balance-running-table thead th {
  background: var(--paper);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-muted);
  border-bottom: 2px solid var(--rule-strong);
  position: sticky;
  top: 0;
  z-index: 1;
}

.balance-running-table tbody tr:nth-child(even) {
  background: var(--paper-raised);
}

.balance-running-table tbody tr:hover {
  background: var(--gold-dim);
}

/* Suspense column — italic, muted */
.balance-running-table .bal-suspense {
  color: var(--ink-muted);
  font-style: italic;
}
.balance-running-table .bal-suspense.negative { color: var(--ledger-red); font-style: italic; }
.balance-running-table .bal-suspense.positive { color: var(--ledger-green); font-style: italic; }

/* Summary column — bold */
.balance-running-table .bal-summary {
  font-weight: 700;
  border-left: 1px solid var(--rule);
}

/* Sticky date column */
.balance-running-table .col-date {
  position: sticky;
  left: 0;
  background: var(--paper);
  z-index: 1;
  font-size: 12px;
  color: var(--ink-muted);
  border-right: 1px solid var(--rule);
}

.balance-running-table tbody tr:nth-child(even) .col-date {
  background: var(--paper-raised);
}

.balance-running-table tbody tr:hover .col-date {
  background: var(--gold-dim);
}

/* Footer current-balance row */
.grand-total-row th {
  background: var(--paper);
  font-weight: 700;
  border-top: 2px solid var(--rule-strong);
  position: sticky;
  bottom: 0;
}

.balance-note {
  padding: 0 var(--space-5) var(--space-5);
  font-size: 12px;
  color: var(--ink-muted);
}

/* ----- Suspense tab ----- */
.suspense-tab .ledger-stats .positive { color: var(--ledger-green); }
.suspense-tab .ledger-stats .negative { color: var(--ledger-red); }

/* ============================================================
   PHASE 7 — Dashboard
   ============================================================ */

/* ----- Filter bar ----- */
.dashboard-filters {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--paper-raised);
  border-bottom: 1px solid var(--rule);
  flex-wrap: wrap;
}

/* ----- Section headings ----- */
.dash-section {
  padding: var(--space-5);
  border-bottom: 1px solid var(--rule);
}

.dash-section:last-child {
  border-bottom: none;
}

.dash-section-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.pivot-badge {
  font-size: 11px;
  font-weight: 400;
  color: var(--ink-muted);
  background: var(--paper);
  border: 1px solid var(--rule-strong);
  border-radius: 20px;
  padding: 2px 8px;
  font-family: var(--font-mono);
}

/* ----- Charts grid ----- */
.charts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-4);
}

.chart-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  min-height: 300px;
  display: flex;
  flex-direction: column;
}

.chart-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-muted);
  margin-bottom: var(--space-3);
  font-family: var(--font-body);
}

.chart-card canvas {
  flex: 1;
  max-height: 260px;
}

/* ----- Pivot tables ----- */
.pivot-table {
  font-size: 13px;
  min-width: 600px;
}

.pivot-table thead th {
  background: var(--paper);
  font-weight: 600;
  font-size: 12px;
  white-space: nowrap;
}

.pivot-row-label {
  font-weight: 500;
  white-space: nowrap;
  padding-right: var(--space-4);
}

.pivot-row-total {
  font-weight: 600;
  border-left: 1px solid var(--rule);
}

.pivot-grand {
  font-weight: 700;
  background: var(--paper);
}

/* Savings pivot net row */
.savings-net-row td {
  font-weight: 700;
  border-top: 2px solid var(--rule-strong);
  background: var(--paper);
}

/* ================================================================
   Phase 8 — Net Worth
   ================================================================ */

/* ── Total banner ─────────────────────────────────────────────── */
.nw-total-banner {
  background: var(--ledger-green-dim);
  border-bottom: 1px solid var(--ledger-green);
  padding: var(--space-5) var(--space-6);
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
}

.nw-total-label {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-muted);
}

.nw-total-value {
  font-size: 28px;
  font-weight: 700;
  font-family: var(--font-mono);
  color: var(--ledger-green);
}

/* ── Sections ─────────────────────────────────────────────────── */
.nw-section {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--rule);
}

.nw-section-title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-muted);
  margin: 0 0 var(--space-3);
}

.nw-section-hint {
  font-size: 12px;
  color: var(--ink-muted);
  margin: 0 0 var(--space-4);
}

/* ── Summary cards (per L1) ───────────────────────────────────── */
.nw-summary-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-3);
}

.nw-summary-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.nw-card-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-muted);
  margin-bottom: var(--space-1);
}

.nw-card-value {
  font-size: 17px;
  font-weight: 700;
  font-family: var(--font-mono);
}

/* ── Category cards grid ──────────────────────────────────────── */
.nw-categories-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-4);
}

.nw-cat-card {
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.nw-cat-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  flex-wrap: wrap;
}

.nw-cat-icon {
  font-size: 16px;
  color: var(--ledger-green);
}

.nw-cat-l1 {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-muted);
}

.nw-cat-sep {
  color: var(--ink-muted);
  font-size: 11px;
}

.nw-cat-l2 {
  font-size: 13px;
  font-weight: 600;
}

.nw-cat-xirr-badge {
  margin-left: auto;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-mono);
  color: var(--ink-muted);
}

.nw-xirr-value.positive { color: var(--ledger-green); }
.nw-xirr-value.negative { color: var(--ledger-red, #8C2F2F); }
.nw-xirr-pending        { color: var(--ink-muted); font-style: italic; font-family: var(--font-body, inherit); font-weight: 400; }

/* ── Card body (inputs) ───────────────────────────────────────── */
.nw-cat-body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.nw-input-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.nw-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.nw-value-input,
.nw-target-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-family: var(--font-mono);
  background: var(--paper);
  color: var(--ink);
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.nw-value-input:focus,
.nw-target-input:focus {
  outline: none;
  border-color: var(--ledger-green);
}

/* ── Cash-flow stat pills ─────────────────────────────────────── */
.nw-stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.nw-stat {
  font-size: 11px;
  color: var(--ink-muted);
}

.nw-stat-label { margin-right: 2px; }

.nw-stat-val.credit { color: var(--ledger-green); font-family: var(--font-mono); font-weight: 600; }
.nw-stat-val.debit  { color: var(--ledger-red, #8C2F2F); font-family: var(--font-mono); font-weight: 600; }

/* ── Save button + status ─────────────────────────────────────── */
.nw-save-btn {
  align-self: flex-start;
  padding: var(--space-2) var(--space-5);
  font-size: 13px;
}

.nw-save-status {
  font-size: 12px;
  font-weight: 600;
}

.nw-save-status.ok      { color: var(--ledger-green); }
.nw-save-status.saving  { color: var(--ink-muted); }
.nw-save-status.error   { color: var(--ledger-red, #8C2F2F); }

/* ── Allocation table ─────────────────────────────────────────── */
.nw-allocation-table th,
.nw-allocation-table td {
  padding: var(--space-2) var(--space-3);
  font-size: 13px;
}

.alloc-ok       { color: var(--ledger-green); font-weight: 600; }
.alloc-mismatch { color: var(--ledger-red, #8C2F2F); font-weight: 700; }

/* ── Mobile adjustments ───────────────────────────────────────── */
@media (max-width: 768px) {
  .nw-total-banner {
    flex-direction: column;
    gap: var(--space-1);
    padding: var(--space-4);
  }
  .nw-total-value { font-size: 22px; }
  .nw-section { padding: var(--space-4); }
  .nw-categories-wrap { grid-template-columns: 1fr; }
  .nw-cat-header { gap: var(--space-1); }
}

/* ================================================================
   Phase 9 — Export, Help & Troubleshoot
   ================================================================ */

/* ── Export panel ─────────────────────────────────────────────── */
.export-panel {
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 420px;
}

/* ── Help accordion ───────────────────────────────────────────── */
.help-section {
  padding: var(--space-5) var(--space-6);
}

.help-intro {
  margin-bottom: var(--space-5);
  color: var(--ink-muted);
  font-size: 13px;
}

.help-accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.help-accordion-btn {
  width: 100%;
  text-align: left;
  background: var(--paper-raised);
  border: none;
  border-bottom: 1px solid var(--rule);
  padding: var(--space-4) var(--space-5);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--ink);
  transition: background 0.15s;
}

.help-accordion-btn:last-of-type {
  border-bottom: none;
}

.help-accordion-btn:hover {
  background: var(--paper);
}

.help-accordion-btn[aria-expanded="true"] {
  background: var(--paper);
  color: var(--ledger-green);
}

.help-accordion-btn::after {
  content: "›";
  font-size: 16px;
  transition: transform 0.2s;
  color: var(--ink-muted);
}

.help-accordion-btn[aria-expanded="true"]::after {
  transform: rotate(90deg);
}

.help-accordion-panel {
  background: var(--paper);
  padding: var(--space-4) var(--space-5) var(--space-5);
  font-size: 13px;
  line-height: 1.65;
  border-bottom: 1px solid var(--rule);
}

.help-accordion-panel p { margin: 0 0 var(--space-3); }
.help-accordion-panel p:last-child { margin-bottom: 0; }

.help-code {
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--paper-raised);
  border: 1px solid var(--rule);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  margin: var(--space-2) 0;
  display: block;
  overflow-x: auto;
}

/* ── Troubleshoot cards ───────────────────────────────────────── */
.ts-card {
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ts-card-title {
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 var(--space-1);
}

.ts-card-desc {
  font-size: 12px;
  color: var(--ink-muted);
  margin: 0;
  line-height: 1.55;
}

.ts-result {
  font-size: 13px;
  line-height: 1.6;
}

.ts-ok       { color: var(--ledger-green); font-weight: 600; }
.ts-mismatch { color: var(--ledger-red, #8C2F2F); font-weight: 600; }

.ts-detail-table {
  margin-top: var(--space-3);
  font-size: 12px;
}

.ts-detail-table th,
.ts-detail-table td {
  padding: var(--space-1) var(--space-3);
}

@media (max-width: 768px) {
  .help-section { padding: var(--space-4); }
  .export-panel { padding: var(--space-4); max-width: 100%; }
  .ts-card { padding: var(--space-4); }
}

/* ============================================================
   PHASE 10 — PWA polish, loading indicators, empty states,
   mobile touch targets, PIN change form
   ============================================================ */

/* ── Loading spinner ─────────────────────────────────────── */
.tab-loading {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-7) var(--space-5);
  color: var(--ink-muted);
  font-size: 0.9rem;
}

.tab-spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--rule);
  border-top-color: var(--ledger-green);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  flex-shrink: 0;
}

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

/* ── Empty states ────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: var(--space-7) var(--space-5);
  color: var(--ink-muted);
}
.empty-state-icon {
  font-size: 2.5rem;
  opacity: 0.3;
  margin-bottom: var(--space-4);
}
.empty-state h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--ink-muted);
  margin-bottom: var(--space-2);
}
.empty-state p {
  font-size: 0.9rem;
  line-height: 1.6;
  max-width: 340px;
  margin: 0 auto;
}

/* ── Mobile touch target sizing (min 44×44px per WCAG) ──── */
@media (max-width: 768px) {
  button,
  .btn-primary,
  .btn-secondary,
  .nav-item,
  .bottom-nav .nav-item {
    min-height: 44px;
    min-width: 44px;
  }

  /* Larger tap targets on bottom nav icons */
  .bottom-nav .nav-item {
    padding: 10px 6px;
    font-size: 0.75rem;
  }

  /* Card-style forms on mobile */
  .ledger-form,
  .suspense-form,
  #pin-change-form {
    background: var(--paper-raised);
    border: 1px solid var(--rule);
    border-radius: var(--radius-md);
    padding: var(--space-5);
  }

  /* Full-width inputs on mobile */
  .form-input,
  select,
  input[type="text"],
  input[type="number"],
  input[type="date"],
  input[type="password"] {
    width: 100%;
    font-size: 16px; /* prevents iOS zoom */
  }

  /* Stack filter rows on mobile */
  .filter-row {
    flex-direction: column;
    gap: var(--space-2);
  }

  /* Make tables horizontally scrollable on small screens */
  .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* ── PWA standalone mode adjustments ─────────────────────── */
@media (display-mode: standalone) {
  /* Add safe area padding for notched phones */
  .bottom-nav {
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  .sidebar {
    padding-top: env(safe-area-inset-top, 0px);
  }
}

/* ── PIN change form ─────────────────────────────────────── */
.form-label {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ink);
}

/* ── Network / error banner ──────────────────────────────── */
.network-banner {
  position: fixed;
  bottom: 64px;   /* above bottom nav */
  left: 50%;
  transform: translateX(-50%);
  background: var(--ledger-red-dim);
  color: var(--ledger-red);
  border: 1px solid var(--ledger-red);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-4);
  font-size: 0.85rem;
  font-weight: 600;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.network-banner.visible { opacity: 1; }

@media (min-width: 769px) {
  .network-banner { bottom: 16px; }
}
/* Ensure hidden attribute always wins over display:flex on modals */
.modal-backdrop[hidden] {
  display: none !important;
}