/* ── Home ──────────────────────────────────────────────────── */
.home-screen {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  -webkit-font-smoothing: antialiased;
  padding-bottom: 24px;
  overflow: visible;
}

.home-head {
  --progress: 0;
  --home-glow-opacity: 1;
  position: sticky;
  top: 0;
  z-index: 5;
  flex-shrink: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

.home-head .home-top-glow {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: min(300px, 44vh);
  overflow: visible;
  pointer-events: none;
  z-index: 0;
  transform: translateY(-50%);
  opacity: var(--home-glow-opacity);
}

.home-head .home-morph-shell {
  position: relative;
  z-index: 1;
}

.home-head.is-expanded .home-morph-shell {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.home-top-glow .card-glow__spots {
  inset: 0;
}

.home-top-glow.card-glow.is-active .card-glow-spot--1,
.home-top-glow.card-glow.is-active .card-glow-spot--2,
.home-top-glow.card-glow.is-active .card-glow-spot--3,
.home-top-glow.card-glow.is-active .card-glow-spot--4 {
  filter: blur(calc(var(--card-glow-blur-a) + 6px));
}

[data-theme="light"] .home-top-glow.card-glow.is-active .card-glow-spot--1,
[data-theme="light"] .home-top-glow.card-glow.is-active .card-glow-spot--2 {
  filter: blur(calc(var(--card-glow-blur-a) + 8px));
}

.home-head.is-negative-balance {
  --card-glow-spot: #d66a6a;
  --card-glow-spot-bright: #ff9a9a;
}

[data-theme="light"] .home-head.is-negative-balance {
  --card-glow-spot: #e85c5c;
  --card-glow-spot-bright: #ffb3b3;
}

[data-theme="light"] .home-head.is-negative-balance .home-top-glow.card-glow.is-active .card-glow-spot--2 {
  background: radial-gradient(
    ellipse at center,
    color-mix(in srgb, #fff0f0 88%, transparent) 0%,
    color-mix(in srgb, var(--card-glow-spot-bright) 64%, transparent) 46%,
    color-mix(in srgb, var(--card-glow-spot) 14%, transparent) 72%,
    transparent 86%
  );
}

html[data-card-glow="off"] .home-morph-shell {
  background: color-mix(
    in srgb,
    var(--surface) calc(var(--progress) * 100%),
    transparent
  );
  border-color: color-mix(
    in srgb,
    var(--border-strong) calc(var(--progress) * 100%),
    transparent
  );
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

html[data-card-glow="off"] .home-morph-balance.panel {
  background: var(--surface);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

html[data-card-glow="off"] .home-morph-balance.panel .home-balance-chip {
  background: var(--surface-2);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.home-head.is-collapsed {
  padding-bottom: 2px;
}

.home-head.is-dragging {
  will-change: height, box-shadow;
}

.home-head.is-dragging .home-morph-shell,
.home-head.is-dragging .home-morph-part,
.home-head.is-dragging .home-morph-cell-content,
.home-head.is-dragging .home-morph-num,
.home-head.is-dragging .home-morph-goal,
.home-head.is-dragging .home-goal {
  will-change: transform, opacity, padding, max-height, font-size;
}

.home-head.is-dragging,
.home-head.is-dragging .home-morph-shell,
.home-head.is-dragging .home-morph,
.home-head.is-dragging .home-morph-part,
.home-head.is-dragging .home-morph-fold,
.home-head.is-dragging .home-morph-metric-fold,
.home-head.is-dragging .home-morph-cell-content,
.home-head.is-dragging .home-morph-rule,
.home-head.is-dragging .home-morph-num,
.home-head.is-dragging .home-morph-goal,
.home-head.is-dragging .home-goal {
  transition: none !important;
}

.home-head.is-snapping {
  transition:
    height 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    box-shadow 0.95s cubic-bezier(0.08, 1, 0.22, 1);
}

.home-head.is-snapping .home-morph-shell,
.home-head.is-snapping .home-morph,
.home-head.is-snapping .home-morph-part,
.home-head.is-snapping .home-morph-balance-head,
.home-head.is-snapping .home-morph-balance-main,
.home-head.is-snapping .home-morph-duo,
.home-head.is-snapping .home-morph-fold,
.home-head.is-snapping .home-morph-metric-fold,
.home-head.is-snapping .home-morph-aside,
.home-head.is-snapping .home-morph-cell-content,
.home-head.is-snapping .home-morph-rule,
.home-head.is-snapping .home-morph-num,
.home-head.is-snapping .home-morph-goal,
.home-head.is-snapping .home-morph-metric.panel {
  transition:
    max-height 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    opacity 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    transform 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    padding 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    margin 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    font-size 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    border-color 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    background 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    box-shadow 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    gap 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    width 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    left 0.95s cubic-bezier(0.08, 1, 0.22, 1),
    column-gap 0.95s cubic-bezier(0.08, 1, 0.22, 1);
}

.home-morph-shell {
  container-type: inline-size;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: color-mix(
    in srgb,
    color-mix(in srgb, var(--surface) var(--card-glow-glass-mix), transparent) calc(var(--progress) * 100%),
    transparent
  );
  border: 1px solid color-mix(
    in srgb,
    color-mix(in srgb, var(--border-strong) 80%, transparent) calc(var(--progress) * 100%),
    transparent
  );
  box-shadow:
    0 1px 0 rgba(0, 0, 0, calc(0.04 * var(--progress))),
    0 6px 20px rgba(0, 0, 0, calc(0.07 * var(--progress)));
  padding:
    calc(14px * var(--progress))
    calc(14px * var(--progress))
    calc(13px * var(--progress));
  transform: perspective(880px) rotateX(calc(1.2deg * (1 - var(--progress))));
  transform-origin: top center;
  backdrop-filter: blur(calc(10px * var(--progress)));
  -webkit-backdrop-filter: blur(calc(10px * var(--progress)));
}

.home-head.is-collapsed .home-morph-shell {
  padding: 14px 14px 13px;
  transform: none;
  box-shadow:
    var(--panel-line),
    var(--shadow-md);
}

.home-morph {
  display: flex;
  flex-direction: column;
  gap: calc(10px * (1 - var(--progress)));
}

.home-morph-part.panel {
  border-color: color-mix(in srgb, var(--border-strong) calc((1 - var(--progress)) * 100%), transparent);
  background: transparent;
  box-shadow: 0 1px 0 rgba(0, 0, 0, calc(0.04 * (1 - var(--progress))));
}

.home-morph-balance.panel {
  padding:
    calc(18px * (1 - var(--progress)))
    calc(16px * (1 - var(--progress)))
    calc(16px * (1 - var(--progress)));
  border-radius: calc(var(--radius-lg) * (1 - var(--progress) * 0.85));
  background: color-mix(
    in srgb,
    color-mix(in srgb, var(--surface) var(--card-glow-glass-mix), transparent) calc((1 - var(--progress)) * 100%),
    transparent
  );
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.home-morph-balance.panel .home-balance-chip {
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.home-morph-balance-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, calc(var(--progress) * 50cqw));
  column-gap: calc(16px * var(--progress));
  align-items: center;
}

.home-morph-balance-main {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  min-width: 0;
  z-index: 1;
}

.home-morph-aside {
  grid-column: 2;
  grid-row: 1;
  position: relative;
  overflow: hidden;
  min-width: 0;
  max-height: calc(40px * var(--progress));
  opacity: var(--progress);
  transform: translateY(calc(4px * (1 - var(--progress))));
}

.home-morph-cell-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: fit-content;
  max-width: 100%;
  position: relative;
}

.home-morph-cell-content--from-left {
  left: calc(var(--progress) * 50%);
  transform: translateX(calc(var(--progress) * -50%));
  align-items: flex-start;
  text-align: left;
}

.home-morph-cell-content--from-right {
  left: calc(100% - var(--progress) * 50%);
  transform: translateX(calc(-100% + var(--progress) * 50%));
  align-items: flex-end;
  text-align: right;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-2);
  line-height: 1.25;
}

.home-morph-fold,
.home-morph-metric-fold {
  overflow: hidden;
  border-top-style: solid;
  border-top-color: var(--border);
  max-height: calc(var(--fold-max, 100px) * (1 - var(--progress)));
  opacity: calc(1 - var(--progress));
  margin-top: calc(var(--fold-mt, 0px) * (1 - var(--progress)));
  padding-top: calc(var(--fold-pt, 0px) * (1 - var(--progress)));
  border-top-width: calc(var(--fold-bt, 0px) * (1 - var(--progress)));
  transform: translateY(calc(-6px * var(--progress))) scaleY(calc(1 - 0.12 * var(--progress)));
  transform-origin: top center;
}

.home-morph-fold .home-period-line {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.home-morph-rule {
  height: 1px;
  background: var(--border);
  margin:
    calc(8px * var(--progress) + 3px * var(--progress))
    0
    calc(2px * var(--progress) + 8px * var(--progress));
  opacity: var(--progress);
  transform: scaleX(var(--progress));
  transform-origin: center top;
}

.home-morph-duo {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: calc(8px * (1 - var(--progress)) + 16px * var(--progress));
}

.home-morph-metric.panel {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  position: relative;
  min-width: 0;
  margin-top: 0;
  padding:
    calc(14px * (1 - var(--progress)))
    calc(12px * (1 - var(--progress)));
  border-radius: calc(var(--radius-lg) * (1 - var(--progress)));
  border-width: calc(1px * (1 - var(--progress)));
  transform-origin: top center;
}

.home-morph-balance-main .home-kicker,
.home-morph-metric .home-kicker {
  font-size: calc(11px * (1 - var(--progress)) + 10px * var(--progress));
  letter-spacing: calc(0.06em * (1 - var(--progress)) + 0.05em * var(--progress));
}

.home-head.is-collapsed .home-morph-balance.panel,
.home-head.is-collapsed .home-morph-metric.panel {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.home-head.is-collapsed .home-morph-part.panel {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.home-morph-spacer {
  flex: 1 1 auto;
  min-height: 0;
  max-height: calc(28px * (1 - var(--progress)));
}

.home-morph-metric-foot {
  flex: 0 0 auto;
  padding-top: calc(12px * (1 - var(--progress)));
  min-height: calc(6px * (1 - var(--progress)));
}

.home-morph-num {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  white-space: nowrap;
}

.home-morph-num.accent { color: var(--accent-hover); }

.home-morph-num--balance {
  margin-top: calc(8px * (1 - var(--progress)) + 2px * var(--progress));
  font-size: calc(18px + 20px * (1 - var(--progress)));
  letter-spacing: calc(-0.04em + 0.01em * var(--progress));
  line-height: calc(1 + 0.1 * var(--progress));
}

.home-morph-num--metric {
  margin-top: calc(6px * (1 - var(--progress)) + 2px * var(--progress));
  font-size: calc(18px + 6px * (1 - var(--progress)));
  letter-spacing: -0.03em;
  line-height: 1.1;
}

.home-morph-num--forecast {
  margin-top: calc(6px * (1 - var(--progress)) + 2px * var(--progress));
  font-size: calc(18px + 10px * (1 - var(--progress)));
  letter-spacing: calc(-0.035em + 0.005em * var(--progress));
  line-height: 1.1;
}

.home-morph-goal {
  overflow: hidden;
  flex: 0 0 auto;
  min-height: 0;
  max-height: calc(260px * (1 - var(--progress)));
  opacity: calc(1 - var(--progress));
  margin-top: calc(10px * (1 - var(--progress)));
  transform: translateY(calc(-12px * var(--progress))) scale(calc(1 - 0.05 * var(--progress)));
  transform-origin: top center;
  pointer-events: none;
}

.home-head.is-expanded .home-morph-goal {
  pointer-events: auto;
}

.home-overspend-block,
.home-budget-block {
  animation: home-rise 0.55s cubic-bezier(0.32, 0.72, 0, 1) 210ms both;
}

@media (prefers-reduced-motion: reduce) {
  .home-head.is-snapping,
  .home-head.is-snapping .home-morph-shell,
  .home-head.is-snapping .home-morph-part,
  .home-head.is-snapping .home-morph-balance-head,
  .home-head.is-snapping .home-morph-balance-main,
  .home-head.is-snapping .home-morph-duo,
  .home-head.is-snapping .home-morph-fold,
  .home-head.is-snapping .home-morph-metric-fold,
  .home-head.is-snapping .home-morph-aside,
  .home-head.is-snapping .home-morph-rule,
  .home-head.is-snapping .home-morph-num,
  .home-head.is-snapping .home-morph-goal,
  .home-head.is-snapping .home-morph-cell-content,
  .home-head.is-dragging,
  .home-head.is-dragging .home-morph-shell,
  .home-head.is-dragging .home-morph-part {
    transition: none;
  }

  .home-morph-shell {
    transform: none;
  }
}

.home-screen .panel {
  border-color: var(--border-strong);
  box-shadow: var(--panel-line);
}

.home-block {
  animation: home-rise 0.55s cubic-bezier(0.32, 0.72, 0, 1) both;
}

.home-morph-balance { animation: home-rise 0.55s cubic-bezier(0.32, 0.72, 0, 1) both; }
.home-morph-duo { animation: home-rise 0.55s cubic-bezier(0.32, 0.72, 0, 1) 70ms both; }
.home-morph-goal { animation: home-rise 0.55s cubic-bezier(0.32, 0.72, 0, 1) 140ms both; }

@media (prefers-reduced-motion: reduce) {
  .home-block { animation: none; }
  .home-morph-balance,
  .home-morph-duo,
  .home-morph-goal { animation: none; }
}

.home-kicker {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-2);
}

.home-balance {
  padding: 18px 16px 16px;
  background: var(--surface);
  border-color: var(--border-strong);
}

.home-balance-val {
  margin-top: 8px;
  font-size: 38px;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.home-balance-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}

.home-balance-split > span:not(.home-balance-chip) {
  display: none;
}

.home-balance-chip {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-3);
  line-height: 1.3;
}

.home-balance-chip strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.02em;
}

.home-period-line {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.home-period-line-meta {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-2);
  margin-bottom: 8px;
}

.home-period-line-bar,
.home-mini-bar,
.home-goal-track {
  height: 6px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--border);
}

.home-period-line-bar .fill,
.home-mini-bar-fill,
.home-goal-track-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  width: 0;
  transition: width 0.85s cubic-bezier(0.32, 0.72, 0, 1);
}

.home-period-line-bar .fill { background: var(--accent); }
.home-mini-bar-fill { background: var(--accent); }
.home-goal-track-fill { background: var(--accent); }

.home-duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  align-items: stretch;
}

.home-duo .home-duo-card.panel {
  margin-top: 0;
}

.home-duo-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%;
  padding: 14px 12px;
}

.home-duo-card .home-kicker {
  flex: 0 0 28px;
  height: 28px;
  line-height: 28px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-duo-val {
  flex: 0 0 auto;
  margin: 6px 0 0;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-duo-val.accent { color: var(--accent-hover); }

.home-duo-val--forecast {
  font-size: 28px;
  letter-spacing: -0.035em;
}

.home-duo-spacer {
  flex: 1 1 auto;
  min-height: 0;
}

.home-duo-foot {
  flex: 0 0 auto;
  padding-top: 12px;
  min-height: 6px;
  box-sizing: content-box;
}

.home-mini-bar {
  height: 6px;
}

.home-goal {
  display: block;
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  background: var(--surface);
  text-align: left;
  cursor: pointer;
  font-family: var(--font);
  color: inherit;
  box-shadow: var(--panel-line);
  transition: background 0.15s ease;
}

.home-goal:active { background: var(--surface-2); }

.home-goal-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}

.home-goal-target {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.home-goal-nums {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  align-items: stretch;
  margin-top: 14px;
}

.home-stat-cell {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 64px;
  padding: 10px 12px;
  border-radius: var(--radius);
  background: var(--surface-2);
  border: 1px solid var(--border);
}

.home-goal-lbl {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-3);
  margin-bottom: 6px;
}

.home-goal-num {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.15;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

.home-goal-gap.ok .home-goal-gap-text { color: var(--income); }
.home-goal-gap.warn .home-goal-gap-text { color: var(--warn); }

.home-goal-gap .home-goal-gap-text {
  font-size: 15px;
  line-height: 1.25;
}

.home-goal-track {
  margin-top: 14px;
}

.home-goal-title {
  display: block;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-2);
}

.home-screen .section-label {
  color: var(--text-2);
  font-size: 11px;
}

.home-over-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 99px;
  background: var(--danger-bg);
  border: 1px solid color-mix(in srgb, var(--danger) 25%, var(--mix-base));
  color: var(--danger);
  font-size: 11px;
  font-weight: 600;
}

.home-over-panel {
  padding: 2px 0;
}

.home-budget-panel {
  padding: 2px 14px;
}

.home-budget-panel .budget-row {
  padding: 10px 0;
}

.home-over-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--border);
}

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

.home-over-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  flex-shrink: 0;
}

.home-over-name {
  flex: 1;
  min-width: 0;
  font-size: 14px;
  font-weight: 500;
}

.home-over-amt {
  font-size: 14px;
  font-weight: 600;
  color: var(--danger);
  flex-shrink: 0;
}

.home-budget-empty,
.home-over-empty {
  padding: 14px 16px;
  font-size: 13px;
  color: var(--text-3);
  text-align: center;
}

.budget-nums {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.35;
}

.budget-nums-item strong {
  font-weight: 600;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}

@keyframes home-rise {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Goal block ────────────────────────────────────────────── */
.goal-block {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  min-width: 0;
}

.goal-text { min-width: 0; flex: 1; }

.goal-meter {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  position: relative;
}

.goal-meter svg { width: 64px; height: 64px; transform: rotate(-90deg); }

.goal-meter .track {
  fill: none;
  stroke: var(--surface-2);
  stroke-width: 5;
}

.goal-meter .fill {
  fill: none;
  stroke: var(--accent);
  stroke-width: 5;
  stroke-linecap: butt;
}

.goal-meter .pct {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
}

.goal-text h2 {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 2px;
}

.goal-text p {
  font-size: 13px;
  color: var(--text-2);
}

.forecast {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--warn-bg);
  border: 1px solid color-mix(in srgb, var(--warn) 35%, var(--mix-base));
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--text-2);
  overflow-wrap: anywhere;
}

.forecast strong { color: var(--text); font-weight: 600; }

/* ── Summary ───────────────────────────────────────────────── */
.summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  min-width: 0;
}

.stat-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 12px 14px;
}

.stat-box .lbl {
  font-size: 12px;
  color: var(--text-3);
  font-weight: 500;
}

.stat-box .val {
  font-size: 20px;
  font-weight: 600;
  margin-top: 2px;
  letter-spacing: -0.02em;
}

.stat-box .val.inc { color: var(--income); }
.stat-box .val.exp { color: var(--expense); }

.stat-box .sub {
  font-size: 12px;
  color: var(--text-3);
  margin-top: 2px;
}

/* ── Category progress ─────────────────────────────────────── */
.budget-row {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  min-width: 0;
}

.budget-info {
  min-width: 0;
}

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

.budget-row--action {
  width: 100%;
  text-align: left;
  border: none;
  background: none;
  font: inherit;
  color: inherit;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.budget-row--action:hover .budget-info .name {
  color: var(--accent);
}

.budget-row--action:active {
  opacity: 0.85;
}

.budget-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.budget-info .name {
  font-size: 14px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.budget-bar-wrap {
  position: relative;
  margin-top: 6px;
  min-width: 0;
}

.budget-bar {
  height: 5px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.budget-bar .fill {
  display: block;
  height: 100%;
  border-radius: 3px;
  max-width: 100%;
  transition: width 0.2s ease;
}

.budget-bar .fill.ok { background: var(--accent); }
.budget-bar .fill.locked { background: var(--locked); }
.budget-bar .fill.over { background: var(--danger); }

.budget-over-pct {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--danger);
  white-space: nowrap;
  line-height: 1;
  text-align: right;
  margin-bottom: 3px;
}

/* ── Category lock icon ────────────────────────────────────── */
.cat-lock {
  display: inline-flex;
  align-items: center;
  color: var(--accent);
  flex-shrink: 0;
}

.cat-lock svg {
  width: 11px;
  height: 11px;
}
