body.page-cash-flow .wrap { max-width:920px; }

.page-head { padding:2.5rem 0 1.2rem; }
.hl { background:var(--c-green); }

.win { margin-bottom:1.6rem; }
.win-body { padding:1.3rem 1.4rem 1.4rem; }

.summary-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1rem;
  margin-bottom:1.6rem;
}
.stat {
  background:var(--win);
  border:2.5px solid var(--ink);
  border-radius:var(--radius);
  box-shadow:4px 4px 0 var(--shadow);
  padding:0.9rem 1rem;
}
.stat .k {
  font-family:var(--mono);
  font-size:0.64rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.stat .v {
  font-size:1.25rem;
  font-weight:800;
  letter-spacing:-0.02em;
  margin-top:2px;
}
.stat .v.bad { color:var(--c-red); }
.stat .v.good { color:var(--c-green); }
.stat .sub {
  font-family:var(--mono);
  font-size:0.68rem;
  color:var(--text-dim);
  margin-top:3px;
}

.income-row {
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:0.8rem;
  align-items:center;
}
.income-row + .income-row { margin-top:0.9rem; }
.income-row.schedule-opt[hidden] { display:none; }

.schedule-select,
.date-input,
.day-input {
  border:2.5px solid var(--ink);
  border-radius:9px;
  background:var(--win-2);
  color:var(--text-hi);
  font-size:0.92rem;
  font-weight:600;
  padding:0.55rem 0.75rem;
  width:100%;
  outline:none;
}
.schedule-select:focus,
.date-input:focus,
.day-input:focus { border-color:var(--c-green); }
.day-input {
  font-family:var(--mono);
  font-size:0.95rem;
  max-width:88px;
}
.date-input { font-family:var(--mono); font-size:0.88rem; }
.field-label {
  font-family:var(--mono);
  font-size:0.72rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.money-wrap {
  display:flex;
  align-items:center;
  gap:8px;
  border:2.5px solid var(--ink);
  border-radius:9px;
  background:var(--win-2);
  padding:0.5rem 0.8rem;
}
.money-wrap:focus-within { border-color:var(--c-green); }
.money-wrap .prefix { font-size:1.2rem; font-weight:700; color:var(--text-mid); }
.money-input {
  flex:1;
  border:none;
  background:transparent;
  color:var(--text-hi);
  font-size:1.35rem;
  font-weight:800;
  letter-spacing:-0.02em;
  outline:none;
  width:100%;
}
.money-input::-webkit-outer-spin-button,
.money-input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.money-input { -moz-appearance:textfield; }
.cadence {
  font-family:var(--mono);
  font-size:0.68rem;
  color:var(--text-dim);
  white-space:nowrap;
}
.cadence.hint { color:var(--text-dim); opacity:0.85; }

.bill-toolbar { margin-bottom:0.7rem; }
.kbd-hint {
  font-family:var(--mono);
  font-size:0.66rem;
  color:var(--text-dim);
}
.kbd-hint kbd {
  display:inline-block;
  border:1.5px solid var(--ink);
  border-radius:4px;
  background:var(--win-2);
  padding:0 5px;
  font-size:0.62rem;
  line-height:1.5;
}

.bill-table { border:2.5px solid var(--ink); border-radius:9px; overflow:hidden; background:var(--win-2); }
.bill-head,
.bill-row {
  display:grid;
  grid-template-columns:1fr 110px 72px 130px 32px;
  gap:0.5rem;
  align-items:center;
  padding:0.55rem 0.7rem;
}
.bill-head {
  font-family:var(--mono);
  font-size:0.62rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--text-dim);
  border-bottom:2px solid var(--ink);
  background:var(--win);
}
.bill-head-btn {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:0;
  border:none;
  background:transparent;
  font:inherit;
  color:inherit;
  cursor:pointer;
  text-align:left;
}
.bill-head-btn:hover { color:var(--text-hi); }
.bill-head-btn:focus-visible {
  outline:2px solid var(--c-green);
  outline-offset:2px;
  border-radius:3px;
}
.bill-head-sort {
  font-size:0.55rem;
  line-height:1;
  opacity:0;
}
.bill-head-btn[aria-sort="ascending"] .bill-head-sort,
.bill-head-btn[aria-sort="descending"] .bill-head-sort {
  opacity:1;
  color:var(--c-blue);
}
.bill-row { border-bottom:2px solid var(--ink); }
.bill-row:last-child { border-bottom:none; }
.bill-row:focus-within { background:color-mix(in srgb, var(--c-green) 8%, var(--win-2)); }

.bill-in {
  border:2px solid transparent;
  background:transparent;
  color:var(--text-hi);
  font-size:0.9rem;
  font-weight:600;
  padding:4px 6px;
  border-radius:6px;
  width:100%;
  outline:none;
}
.bill-in:hover { border-color:var(--ink); }
.bill-in:focus { border-color:var(--c-green); background:var(--win); }
.bill-in.amt,
.bill-in.day {
  font-family:var(--mono);
  font-size:0.85rem;
  text-align:right;
}
.bill-in.amt::-webkit-outer-spin-button,
.bill-in.amt::-webkit-inner-spin-button,
.bill-in.day::-webkit-outer-spin-button,
.bill-in.day::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.bill-in.amt,
.bill-in.day { -moz-appearance:textfield; }

.bill-cat {
  border:2px solid var(--ink);
  background:var(--win);
  color:var(--text-hi);
  font-size:0.82rem;
  font-weight:600;
  padding:4px 6px;
  border-radius:6px;
  width:100%;
  outline:none;
  cursor:pointer;
}
.bill-cat:focus { border-color:var(--c-green); }

.bill-rm {
  border:2px solid var(--ink);
  background:var(--win);
  color:var(--text-mid);
  width:28px;
  height:28px;
  border-radius:6px;
  cursor:pointer;
  font-size:0.9rem;
  line-height:1;
  display:grid;
  place-items:center;
  transition:color .12s, border-color .12s;
}
.bill-rm:hover { color:var(--c-red); border-color:var(--c-red); }

/* Titlebar — bills accent + compact Backup control */
#bills-win .bills-titlebar {
  background:var(--c-blue);
}
#bills-win .bills-titlebar .dot-close {
  background:#fff;
  border-color:var(--ink);
}
#bills-win .bills-titlebar .tname {
  color:#0c1322;
  font-weight:700;
}
.titlebar-grip--grow { flex:1; }
.titlebar-btn {
  font-family:var(--mono);
  font-size:0.65rem;
  font-weight:600;
  letter-spacing:0.02em;
  line-height:1.2;
  padding:2px 7px;
  border:2px solid var(--ink);
  border-radius:5px;
  background:var(--win);
  color:var(--text-hi);
  cursor:pointer;
  box-shadow:2px 2px 0 var(--ink);
  flex-shrink:0;
  transition:transform 0.1s, box-shadow 0.1s;
}
.titlebar-btn:hover {
  transform:translate(1px, 1px);
  box-shadow:1px 1px 0 var(--ink);
}
.titlebar-btn:active {
  transform:translate(2px, 2px);
  box-shadow:0 0 0 var(--ink);
}

/* Backup dialog */
.cf-dialog-overlay {
  position:fixed;
  inset:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  background:color-mix(in srgb, var(--bg) 58%, transparent);
}
.cf-dialog-overlay[hidden] { display:none; }
.cf-dialog {
  width:100%;
  max-width:520px;
  margin:0;
  animation:cf-dialog-in 0.14s ease-out;
}
@keyframes cf-dialog-in {
  from { opacity:0; transform:translate(4px, 4px); }
  to { opacity:1; transform:translate(0, 0); }
}
.cf-dialog-titlebar { background:var(--c-silver); }
.cf-dialog-titlebar .tname {
  color:#0c1322;
  font-weight:700;
}
html[data-theme="dark"] .cf-dialog-titlebar .tname { color:#0c1322; }
.dot-close--btn {
  cursor:pointer;
  padding:0;
  background:var(--win-2);
  transition:background 0.1s;
}
.cf-dialog-titlebar .dot-close--btn {
  background:#fff;
  border-color:var(--ink);
}
.dot-close--btn:hover { background:var(--c-red); }
.dialog-lead {
  font-size:0.88rem;
  color:var(--text-mid);
  margin-bottom:1rem;
  line-height:1.5;
}
body.cf-dialog-open { overflow:hidden; }

.backup-actions {
  display:flex;
  flex-wrap:wrap;
  gap:0.6rem;
  margin-bottom:0.9rem;
}
.backup-foot {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  gap:0.6rem;
  margin-top:0.75rem;
  padding-top:0.75rem;
  border-top:2px solid color-mix(in srgb, var(--ink) 20%, transparent);
}
.backup-foot .import-status {
  flex:1 1 100%;
  text-align:left;
  margin-top:0.25rem;
}
#dismiss-backup-btn { cursor:pointer; }
.import-text {
  display:block;
  width:100%;
  margin-top:0.45rem;
  border:2.5px solid var(--ink);
  border-radius:9px;
  background:var(--win-2);
  color:var(--text-hi);
  font-family:var(--mono);
  font-size:0.78rem;
  line-height:1.5;
  padding:0.7rem 0.8rem;
  resize:vertical;
  min-height:96px;
  outline:none;
}
.import-text:focus { border-color:var(--c-green); }
.import-text::placeholder { color:var(--text-dim); }
.import-status {
  font-family:var(--mono);
  font-size:0.72rem;
  color:var(--text-dim);
}
.import-status.ok { color:var(--c-green); }
.import-status.err { color:var(--c-red); }

.btn {
  font-size:0.82rem;
  color:var(--text-hi);
  border-radius:8px;
  padding:0.4rem 0.85rem;
  box-shadow:3px 3px 0 var(--ink);
  background:var(--win-2);
  border:2.5px solid var(--ink);
  margin-top:0;
  cursor:pointer;
}
.btn-add { margin-top:0.8rem; }
.btn-primary {
  background:color-mix(in srgb, var(--c-green) 20%, var(--win-2));
}
.btn:hover { transform:translate(1px,1px); box-shadow:2px 2px 0 var(--ink); }
.btn:active { transform:translate(3px,3px); box-shadow:0 0 0 var(--ink); }

.section-note {
  font-size:0.88rem;
  color:var(--text-mid);
  margin-bottom:1rem;
}

.envelope-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:1rem;
}
.envelope {
  border:2.5px solid var(--ink);
  border-radius:10px;
  background:var(--win-2);
  box-shadow:4px 4px 0 var(--shadow);
  overflow:hidden;
}
.envelope.tight { border-color:var(--c-gold); }
.envelope.danger { border-color:var(--c-red); }
.env-head {
  padding:0.75rem 0.9rem;
  border-bottom:2px solid var(--ink);
  background:var(--win);
}
.env-date {
  font-family:var(--mono);
  font-size:0.68rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.env-pay {
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:-0.02em;
  margin-top:2px;
}
.env-body { padding:0.5rem 0.9rem 0.75rem; }
.env-line {
  display:flex;
  justify-content:space-between;
  gap:0.5rem;
  padding:0.35rem 0;
  font-size:0.86rem;
  border-bottom:1px dashed color-mix(in srgb, var(--ink) 40%, transparent);
}
.env-line:last-of-type { border-bottom:none; }
.env-line .nm {
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
}
.env-line .nm span {
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.env-dot {
  width:8px;
  height:8px;
  border-radius:3px;
  border:1.5px solid var(--ink);
  flex:none;
}
.env-line .amt {
  font-family:var(--mono);
  font-size:0.82rem;
  color:var(--text-mid);
  flex:none;
}
.env-subtotal {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:0.5rem;
  margin-top:0.35rem;
  padding-top:0.45rem;
  font-weight:700;
}
.env-subtotal .lbl {
  font-family:var(--mono);
  font-size:0.68rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--text-dim);
}
.env-subtotal .amt {
  font-family:var(--mono);
  font-size:0.88rem;
}
.env-foot {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:0.55rem;
  padding-top:0.55rem;
  border-top:2px solid var(--ink);
  font-weight:700;
}
.env-foot .rem { font-family:var(--mono); font-size:0.95rem; }
.env-foot .tag {
  font-family:var(--mono);
  font-size:0.62rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  padding:2px 7px;
  border-radius:5px;
  border:1.5px solid var(--ink);
}
.env-foot .tag.ok { background:color-mix(in srgb, var(--c-green) 22%, var(--win)); }
.env-foot .tag.tight { background:color-mix(in srgb, var(--c-gold) 22%, var(--win)); }
.env-foot .tag.bad { background:color-mix(in srgb, var(--c-red) 18%, var(--win)); color:var(--c-red); }
.env-empty {
  font-size:0.84rem;
  color:var(--text-dim);
  padding:0.4rem 0;
}

.timeline-wrap { overflow-x:auto; padding-bottom:0.4rem; }
.timeline-chart {
  position:relative;
  min-width:640px;
  height:220px;
  border:2.5px solid var(--ink);
  border-radius:9px;
  background:var(--win-2);
}
.timeline-svg { display:block; width:100%; height:100%; }
.tl-balance {
  fill:none;
  stroke:var(--c-blue);
  stroke-width:2.5;
  stroke-linejoin:round;
  stroke-linecap:round;
}
.tl-zero {
  stroke:var(--ink);
  stroke-width:1;
  stroke-dasharray:4 4;
  opacity:0.55;
}
.tl-income-line {
  stroke:var(--c-green);
  stroke-width:1.5;
  opacity:0.45;
}
.tl-income-dot {
  fill:var(--c-green);
  stroke:var(--ink);
  stroke-width:1.2;
}
.tl-label,
.tl-y {
  font-family:var(--mono);
  font-size:9px;
  fill:var(--text-dim);
}
.timeline-legend {
  display:flex;
  flex-wrap:wrap;
  gap:1rem 1.4rem;
  margin-top:0.8rem;
  font-family:var(--mono);
  font-size:0.66rem;
  color:var(--text-dim);
}
.tl-leg { display:flex; align-items:center; gap:6px; }
.tl-swatch {
  width:14px;
  height:4px;
  border-radius:2px;
  border:1.5px solid var(--ink);
}
.tl-swatch.income { background:var(--c-green); height:10px; width:10px; border-radius:3px; }
.tl-swatch.balance { background:var(--c-blue); }
.tl-swatch.danger { background:var(--c-red); }

.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

body.page-cash-flow .footbar { margin-top:1.4rem; }

@media (max-width:720px){
  .summary-grid { grid-template-columns:repeat(2, 1fr); }
  .income-row { grid-template-columns:1fr; }
  .cadence { margin-top:-0.3rem; }
  .bill-head { display:none; }
  .bill-row {
    grid-template-columns:1fr 90px 60px 28px;
    grid-template-areas:
      "name name name rm"
      "amt day cat cat";
    gap:0.4rem;
    padding:0.7rem;
  }
  .bill-row .nm { grid-area:name; }
  .bill-row .amt { grid-area:amt; }
  .bill-row .day { grid-area:day; }
  .bill-row .bill-cat { grid-area:cat; }
  .bill-row .bill-rm { grid-area:rm; justify-self:end; }
}

@media (max-width:420px){
  .summary-grid { grid-template-columns:1fr; }
  .envelope-grid { grid-template-columns:1fr; }
}