/* ─────────────────────────────────────────────────────────────
   CashInOut — structural styles.
   Colors, fonts, radii & shadows live in themes.css (as CSS
   variables); everything here references them via var(). Change
   the look there, not here.
   ───────────────────────────────────────────────────────────── */

* { margin: 0; padding: 0; box-sizing: border-box; }

/* Global scale: 1rem = 10px × this factor. Everything is authored in rem,
   so the whole app scales from this ONE number (12px = 120%). */
html { font-size: 12px; }

body {
  font-family: var(--sans);
  font-size: 1.4rem;
  line-height: 1.5;
  color: var(--ink);
  background: var(--bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* Atmosphere: top glow + grain */
body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(90rem 42rem at 18% -8%, rgba(78, 209, 149, 0.07), transparent 60%),
    radial-gradient(70rem 38rem at 85% -12%, rgba(232, 188, 94, 0.045), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
body::after {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 100;
}

::selection { background: rgba(78, 209, 149, 0.28); }

h1, h2, h3 { font-weight: 500; }

button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
input, select, textarea { font: inherit; color: var(--ink); }
a { color: var(--green); text-decoration: none; }

.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }

/* ── Layout ─────────────────────────────────────────────── */

#app { display: flex; min-height: 100vh; position: relative; z-index: 1; }

.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  border-right: 1px solid var(--line);
  padding: 2rem 1.2rem;
  display: flex; flex-direction: column; gap: 0.4rem;
  position: sticky; top: 0; height: 100vh;
}

.wordmark {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.4rem 1rem 1.8rem;
  font-family: var(--serif);
  font-size: 1.9rem; letter-spacing: 0.01em;
}
.wordmark .mark {
  width: 3rem; height: 3rem; border-radius: 0.9rem;
  background: linear-gradient(145deg, #1c2b22, #101812);
  border: 1px solid var(--line-strong);
  display: grid; place-items: center;
  box-shadow: var(--shadow);
}
.wordmark em { font-style: italic; color: var(--green); }

.nav-item {
  display: flex; align-items: center; gap: 1.1rem;
  padding: 0.8rem 1rem;
  border-radius: var(--r-sm);
  color: var(--ink-2);
  font-weight: 400;
  transition: background 0.15s, color 0.15s;
  width: 100%;
  text-align: left;
}
.nav-item svg { width: 1.7rem; height: 1.7rem; flex-shrink: 0; opacity: 0.85; }
.nav-item:hover { background: var(--panel); color: var(--ink); }
.nav-item.active {
  background: var(--panel-2);
  color: var(--ink);
  box-shadow: inset 0.2rem 0 0 var(--green);
}
.nav-item .badge {
  margin-left: auto;
  font-family: var(--mono); font-size: 1.1rem;
  background: var(--gold-dim); color: var(--gold);
  padding: 1px 0.7rem; border-radius: 2rem;
}

.sidebar-foot {
  margin-top: auto; padding: 1rem;
  font-size: 1.15rem; color: var(--ink-3);
  border-top: 1px solid var(--line);
}
.user-foot { display: flex; align-items: center; gap: 0.8rem; min-width: 0; }
.user-foot .user-name {
  flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--ink-2);
}
.user-foot .user-admin {
  font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.07em;
  color: var(--gold); background: var(--gold-dim);
  padding: 0.1rem 0.6rem; border-radius: 2rem; margin-left: 0.3rem;
}
.user-foot .signout {
  background: none; border: none; padding: 0; cursor: pointer;
  font: inherit; font-size: 1.1rem; color: var(--ink-3); white-space: nowrap;
}
.user-foot .signout:hover { color: var(--red); }

.main { flex: 1; min-width: 0; padding: 0 3rem 6rem; }

.topbar {
  display: flex; align-items: center; gap: 1.4rem;
  padding: 2.2rem 0 2rem;
  position: sticky; top: 0; z-index: 20;
  background: linear-gradient(var(--bg) 78%, transparent);
}
.topbar h1 {
  font-family: var(--serif);
  font-size: 2.6rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  margin-right: auto;
}
.topbar h1 small { font-family: var(--sans); font-size: 1.3rem; color: var(--ink-3); margin-left: 1.2rem; font-weight: 400; }

.kebab-btn {
  width: 3.2rem; height: 3.2rem; border-radius: 0.9rem;
  display: grid; place-items: center;
  font-size: 1.7rem; color: var(--ink-2);
  border: 1px solid var(--line);
  background: var(--panel);
  transition: all 0.15s;
}
.kebab-btn:hover { color: var(--ink); border-color: var(--line-strong); background: var(--panel-hover); }

.load-more-row td { text-align: center; padding: 1.2rem; border-bottom: none; }

.year-pills { display: flex; gap: 0.4rem; background: var(--panel); border: 1px solid var(--line); border-radius: 2rem; padding: 0.3rem; }
.year-pills button {
  padding: 0.3rem 1.3rem; border-radius: 2rem;
  font-family: var(--mono); font-size: 1.25rem; color: var(--ink-2);
  transition: all 0.15s;
}
.year-pills button.active { background: var(--green-dim); color: var(--green-bright); }
.year-pills button:hover:not(.active) { color: var(--ink); }

/* ── Cards & grid ───────────────────────────────────────── */

.grid { display: grid; gap: 1.4rem; }

.card {
  background: linear-gradient(160deg, var(--panel-2), var(--panel) 55%);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 1.8rem 2rem;
  box-shadow: var(--shadow);
}
.card h3 {
  font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.09em;
  color: var(--ink-3); font-weight: 500; margin-bottom: 1.2rem;
  display: flex; align-items: center; gap: 0.8rem;
}
.card h3 .spacer { margin-left: auto; }

/* Page-load reveal */
@keyframes rise { from { opacity: 0; transform: translateY(1rem); } to { opacity: 1; transform: none; } }
.view > * { animation: rise 0.45s cubic-bezier(0.2, 0.7, 0.3, 1) both; }
.view > *:nth-child(2) { animation-delay: 0.05s; }
.view > *:nth-child(3) { animation-delay: 0.1s; }
.view > *:nth-child(4) { animation-delay: 0.15s; }
.view > *:nth-child(5) { animation-delay: 0.2s; }

/* ── KPIs ───────────────────────────────────────────────── */

.kpis { grid-template-columns: repeat(4, 1fr); }
.kpi { position: relative; overflow: hidden; }
.kpi .label { font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.09em; color: var(--ink-3); font-weight: 500; }
.kpi .value {
  font-family: var(--serif);
  font-size: 3.3rem; font-weight: 500;
  margin-top: 0.6rem; line-height: 1.1;
  font-variant-numeric: lining-nums;
}
.kpi .value .cents { font-size: 1.8rem; opacity: 0.55; }
.kpi .sub { font-size: 1.2rem; color: var(--ink-3); margin-top: 0.5rem; }
.kpi .sub b { color: var(--ink-2); font-weight: 500; }
.kpi.green .value { color: var(--green-bright); }
.kpi.red .value { color: var(--red); }
.kpi.gold .value { color: var(--gold); }
.kpi::after {
  content: ''; position: absolute; left: 0; right: 0; top: 0; height: 0.2rem;
  background: linear-gradient(90deg, transparent, var(--kpi-glow, transparent), transparent);
  opacity: 0.7;
}
.kpi.green { --kpi-glow: var(--green); }
.kpi.red { --kpi-glow: var(--red); }
.kpi.gold { --kpi-glow: var(--gold); }

/* ── Tables ─────────────────────────────────────────────── */

table { width: 100%; border-collapse: collapse; }
thead th {
  font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--ink-3); font-weight: 500; text-align: left;
  padding: 0.8rem 1rem; border-bottom: 1px solid var(--line-strong);
  white-space: nowrap;
}
thead th.sortable { cursor: pointer; user-select: none; transition: color 0.15s; }
thead th.sortable:hover { color: var(--ink); }
.sort-ind { color: var(--green); font-size: 0.9rem; }
tr.ws-row { cursor: pointer; }
tbody td { padding: 0.9rem 1rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
tbody tr { transition: background 0.12s; }
tbody tr:hover { background: rgba(255, 255, 255, 0.022); }
tbody tr.selected { background: var(--green-dim); }
td.num, th.num { text-align: right; font-family: var(--mono); font-variant-numeric: tabular-nums; white-space: nowrap; }
.amount.pos { color: var(--green-bright); }
.amount.neg { color: var(--ink); }
.amount.neg.big { color: var(--red); }

.tx-merchant { font-weight: 500; max-width: 34rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tx-desc { font-size: 1.15rem; color: var(--ink-3); max-width: 34rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: var(--mono); }
.tx-date { font-family: var(--mono); font-size: 1.25rem; color: var(--ink-2); white-space: nowrap; }

.chip {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 1.15rem; color: var(--ink-2);
  background: var(--panel-2); border: 1px solid var(--line);
  padding: 0.2rem 0.9rem; border-radius: 2rem;
  white-space: nowrap; max-width: 17rem; overflow: hidden; text-overflow: ellipsis;
}

.cat-pill {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-size: 1.2rem; padding: 0.3rem 1rem;
  background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 2rem; cursor: pointer; white-space: nowrap;
  transition: border-color 0.15s, background 0.15s;
}
.cat-pill:hover { border-color: var(--line-strong); background: var(--panel-hover); }
.cat-pill.uncat { border-style: dashed; color: var(--gold); border-color: rgba(232,188,94,0.4); }

.biz-chip {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 1.1rem; color: var(--ink-2);
  background: var(--panel-2); border: 1px solid var(--line);
  padding: 1px 0.8rem; border-radius: 2rem;
  white-space: nowrap; vertical-align: middle;
  max-width: 15rem; overflow: hidden; text-overflow: ellipsis;
}
.biz-chip .dot { width: 0.7rem; height: 0.7rem; border-radius: 0.3rem; flex-shrink: 0; }
button.biz-chip { cursor: pointer; transition: border-color 0.15s, color 0.15s; }
button.biz-chip:hover { border-color: var(--line-strong); color: var(--ink); }
/* Unassigned rows get a quiet "+" that firms up on row hover */
.row-bizadd { opacity: 0.25; }
tbody tr:hover .row-bizadd { opacity: 1; }

/* One toggle component for both concepts: ✦ (write-off) and eye (hidden). */
.icon-toggle {
  width: 2.6rem; height: 2.6rem; border-radius: 0.7rem;
  display: inline-grid; place-items: center; vertical-align: middle;
  color: var(--ink-3); font-size: 1.4rem;
  border: 1px solid transparent;
  transition: all 0.15s;
}
.icon-toggle .ic { width: 1.5rem; height: 1.5rem; }
.icon-toggle.inactive { opacity: 0.25; }
#clear-filters:hover { border-color: var(--line-strong); color: var(--red); opacity: 1; }
.toggle-chip .ic, .btn .ic { width: 1.3rem; height: 1.3rem; vertical-align: -0.2rem; margin-right: 0.4rem; }
thead th .ic { width: 1.3rem; height: 1.3rem; vertical-align: -0.2rem; }
.icon-toggle.star:hover { border-color: var(--line-strong); color: var(--gold); }
.icon-toggle.star.on { color: var(--gold); background: var(--gold-dim); border-color: rgba(232,188,94,0.35); }
.icon-toggle.eye:hover { border-color: var(--line-strong); color: var(--blue); }
.icon-toggle.eye.on { color: var(--blue); background: var(--blue-dim); border-color: var(--line-strong); }

/* ── Buttons & inputs ───────────────────────────────────── */

.btn {
  display: inline-flex; align-items: center; gap: 0.7rem;
  padding: 0.7rem 1.4rem; border-radius: var(--r-sm);
  background: var(--panel-2); border: 1px solid var(--line-strong);
  font-size: 1.3rem; font-weight: 500; color: var(--ink);
  transition: all 0.15s;
}
.btn:hover { background: var(--panel-hover); border-color: rgba(228,234,223,0.25); }
.btn.primary { background: var(--green); border-color: var(--green); color: #08130d; }
.btn.primary:hover { background: var(--green-bright); }
.btn.gold { background: var(--gold-dim); border-color: rgba(232,188,94,0.4); color: var(--gold); }
.btn.gold:hover { background: rgba(232,188,94,0.2); }
.btn.danger { color: var(--red); border-color: rgba(255,124,102,0.3); }
.btn.danger:hover { background: var(--red-dim); }
.btn.sm { padding: 0.4rem 1rem; font-size: 1.2rem; border-radius: 0.7rem; }
.btn.ghost { border-color: transparent; background: transparent; color: var(--ink-2); }
.btn.ghost:hover { color: var(--ink); background: var(--panel-2); }
.btn:disabled { opacity: 0.45; cursor: default; pointer-events: none; }

.input, select.input {
  background: var(--bg); border: 1px solid var(--line-strong);
  border-radius: var(--r-sm); padding: 0.7rem 1.1rem;
  font-size: 1.3rem; outline: none;
  transition: border-color 0.15s;
}
.input:focus { border-color: rgba(78, 209, 149, 0.5); }
.input::placeholder { color: var(--ink-3); }
select.input { appearance: none; padding-right: 2.6rem; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2366746a' fill='none' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; }

.checkbox { accent-color: var(--green); width: 1.4rem; height: 1.4rem; cursor: pointer; }

.filters { display: flex; gap: 0.8rem; flex-wrap: wrap; align-items: center; margin-bottom: 1.4rem; }
.filters .input { min-width: 0; }
.filters .search { flex: 1; min-width: 18rem; }

.toggle-chip {
  padding: 0.6rem 1.3rem; border-radius: 2rem; font-size: 1.25rem;
  border: 1px solid var(--line-strong); color: var(--ink-2);
  transition: all 0.15s;
}
.toggle-chip:hover { color: var(--ink); }
.toggle-chip.on { background: var(--green-dim); border-color: rgba(78,209,149,0.4); color: var(--green-bright); }
.toggle-chip.on.gold { background: var(--gold-dim); border-color: rgba(232,188,94,0.4); color: var(--gold); }

/* ── Bulk bar ───────────────────────────────────────────── */

@keyframes bulk-rise {
  from { opacity: 0; transform: translate(-50%, 1.2rem); }
  to { opacity: 1; transform: translate(-50%, 0); }
}
.bulkbar {
  position: fixed; bottom: 2.2rem; left: calc(50% + var(--sidebar-w) / 2);
  transform: translate(-50%, 0);
  display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap;
  max-width: min(92vw, 72rem);
  background: var(--panel-float); border: 1px solid var(--line-strong);
  border-radius: 1.4rem; padding: 0.9rem 1.4rem;
  box-shadow: 0 1.8rem 5rem -1.2rem rgba(0,0,0,0.85);
  z-index: 60;
  /* own keyframes — the shared `rise` animation would clobber the -50% centering */
  animation: bulk-rise 0.25s cubic-bezier(0.2, 0.7, 0.3, 1) both;
}
.bulkbar .count { font-family: var(--mono); font-size: 1.25rem; color: var(--green-bright); padding-right: 0.6rem; border-right: 1px solid var(--line-strong); margin-right: 0.4rem; }

/* ── Popover (category picker) ──────────────────────────── */

.popover {
  position: fixed; z-index: 80;
  background: var(--panel-float); border: 1px solid var(--line-strong);
  border-radius: 1.2rem; box-shadow: 0 2.4rem 6rem -1.2rem rgba(0,0,0,0.9);
  width: 27rem; max-height: 38rem;
  display: flex; flex-direction: column;
  animation: rise 0.18s ease both;
}
.popover .input { margin: 1rem 1rem 0.6rem; }
.popover .list { overflow-y: auto; padding: 0.4rem 0.6rem 0.8rem; }
.popover .group-label { font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.09em; color: var(--ink-3); padding: 0.8rem 1rem 0.3rem; }
.popover .opt {
  display: flex; align-items: center; gap: 0.9rem; width: 100%;
  padding: 0.6rem 1rem; border-radius: 0.7rem; font-size: 1.3rem; text-align: left;
}
.popover .opt:hover, .popover .opt.hl { background: var(--panel-hover); }
.popover .opt .sched { margin-left: auto; font-size: 1rem; color: var(--ink-3); }

/* ── Drawer ─────────────────────────────────────────────── */

.drawer-veil { position: fixed; inset: 0; background: rgba(5, 8, 6, 0.55); z-index: 70; animation: fade 0.2s both; }
@keyframes fade { from { opacity: 0; } }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: 42rem; max-width: 92vw;
  background: var(--panel-float); border-left: 1px solid var(--line-strong);
  z-index: 71; padding: 2.6rem;
  overflow-y: auto;
  animation: slide 0.25s cubic-bezier(0.2, 0.7, 0.3, 1) both;
}
@keyframes slide { from { transform: translateX(4rem); opacity: 0; } }
.drawer .amount-big { font-family: var(--serif); font-size: 3.8rem; margin: 0.6rem 0 0.2rem; }
.drawer .field { margin-top: 1.8rem; }
.drawer .field label { display: block; font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); margin-bottom: 0.6rem; }
.drawer .meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.6rem; margin-top: 1.6rem; font-size: 1.25rem; }
.drawer .meta-grid dt { color: var(--ink-3); font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.07em; }
.drawer .meta-grid dd { margin-top: 0.2rem; word-break: break-word; }

/* ── Charts ─────────────────────────────────────────────── */

.chart-cashflow svg { width: 100%; height: auto; display: block; }
.bar-in { fill: var(--green); }
.bar-out { fill: var(--red); opacity: 0.85; }
.bar-in, .bar-out { transition: opacity 0.15s; rx: 3; }
.chart-cashflow g.month:hover .bar-in, .chart-cashflow g.month:hover .bar-out { opacity: 1; filter: brightness(1.15); }
.axis-label { fill: var(--ink-3); font-size: 1rem; font-family: var(--mono); }

.donut-wrap { display: flex; gap: 2rem; align-items: center; }
.donut-wrap svg { width: 14rem; height: 14rem; } /* scale with the root, not the 140 attr */
.donut-legend { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.7rem; }
.legend-row { display: flex; align-items: center; gap: 0.9rem; font-size: 1.25rem; }
.legend-row .dot { width: 0.8rem; height: 0.8rem; border-radius: 0.3rem; flex-shrink: 0; }
.legend-row .name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink-2); }
.legend-row .val { margin-left: auto; font-family: var(--mono); font-size: 1.2rem; }
.donut-hole-label { font-family: var(--serif); font-size: 1.7rem; fill: var(--ink); }
.donut-hole-sub { font-size: 0.9rem; fill: var(--ink-3); text-transform: uppercase; letter-spacing: 0.1em; }

.hbar-row { display: grid; grid-template-columns: 2.2rem 1fr auto; gap: 1rem; align-items: center; padding: 0.5rem 0; font-size: 1.3rem; }
.hbar-row .track { position: relative; height: 2rem; display: flex; align-items: center; }
.hbar-row .fill {
  position: absolute; left: 0; top: 0.3rem; bottom: 0.3rem;
  background: linear-gradient(90deg, rgba(78,209,149,0.25), rgba(78,209,149,0.5));
  border-radius: 0.4rem; min-width: 0.2rem;
  animation: grow 0.7s cubic-bezier(0.2, 0.7, 0.3, 1) both;
}
@keyframes grow { from { transform: scaleX(0); transform-origin: left; } }
.hbar-row .name { position: relative; z-index: 1; padding-left: 0.8rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hbar-row .val { font-family: var(--mono); font-size: 1.25rem; color: var(--ink-2); }

/* ── Write-off radar ────────────────────────────────────── */

.radar-item {
  display: flex; align-items: center; gap: 1.1rem;
  padding: 0.9rem 0; border-bottom: 1px solid var(--line);
}
.radar-item:last-child { border-bottom: none; }
.radar-item .info { flex: 1; min-width: 0; }
.radar-item .m { font-weight: 500; font-size: 1.3rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.radar-item .why { font-size: 1.15rem; color: var(--gold); }
.radar-item .amt { font-family: var(--mono); font-size: 1.3rem; white-space: nowrap; }
.radar-item .acts { display: flex; gap: 0.5rem; }
.radar-act {
  width: 2.7rem; height: 2.7rem; border-radius: 0.8rem;
  display: grid; place-items: center; font-size: 1.3rem;
  border: 1px solid var(--line-strong); color: var(--ink-2);
  transition: all 0.15s;
}
.radar-act.yes:hover { background: var(--green-dim); color: var(--green-bright); border-color: rgba(78,209,149,0.4); }
.radar-act.no:hover { background: var(--red-dim); color: var(--red); border-color: rgba(255,124,102,0.35); }

/* ── Import view ────────────────────────────────────────── */

.dropzone {
  border: 0.15rem dashed var(--line-strong);
  border-radius: var(--r);
  padding: 4.2rem 2rem;
  text-align: center;
  color: var(--ink-2);
  transition: all 0.2s;
  cursor: pointer;
}
.dropzone:hover, .dropzone.over {
  border-color: rgba(78, 209, 149, 0.55);
  background: var(--green-dim);
  color: var(--ink);
}
.dropzone .big { font-family: var(--serif); font-size: 1.9rem; color: var(--ink); margin-bottom: 0.4rem; }
.fmt-chips { display: flex; gap: 0.6rem; justify-content: center; margin-top: 1.4rem; flex-wrap: wrap; }

.file-row {
  display: flex; align-items: center; gap: 1.2rem;
  padding: 1rem 0.4rem; border-bottom: 1px solid var(--line);
}
.file-row:last-child { border-bottom: none; }
.file-row .name { font-family: var(--mono); font-size: 1.25rem; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-row .meta { font-size: 1.15rem; color: var(--ink-3); white-space: nowrap; }

.import-result {
  display: flex; gap: 1.8rem; align-items: baseline;
  padding: 1.2rem 1.6rem; border-radius: var(--r-sm);
  background: var(--green-dim); border: 1px solid rgba(78,209,149,0.25);
  margin-top: 1rem; font-size: 1.3rem;
  animation: rise 0.3s both;
}
.import-result .n { font-family: var(--mono); font-weight: 600; color: var(--green-bright); }
.import-result .d { font-family: var(--mono); color: var(--ink-2); }

/* ── Reports ────────────────────────────────────────────── */

.report-total-row td { border-top: 1px solid var(--line-strong); font-weight: 600; }
.tax-cards { grid-template-columns: repeat(3, 1fr); }
.disclaimer { font-size: 1.15rem; color: var(--ink-3); margin-top: 1.4rem; line-height: 1.55; }

/* ── Toast ──────────────────────────────────────────────── */

.toasts { position: fixed; bottom: 2.2rem; right: 2.2rem; z-index: 90; display: flex; flex-direction: column; gap: 0.8rem; }
.toast {
  background: var(--panel-float); border: 1px solid var(--line-strong);
  border-left: 0.3rem solid var(--green);
  border-radius: 1rem; padding: 1.1rem 1.6rem;
  font-size: 1.3rem; max-width: 34rem;
  box-shadow: 0 1.4rem 4rem -1rem rgba(0,0,0,0.8);
  animation: rise 0.25s both;
}
.toast.err { border-left-color: var(--red); }

/* ── Misc ───────────────────────────────────────────────── */

.empty {
  text-align: center; padding: 4.4rem 2rem; color: var(--ink-3);
}
.empty .art { font-size: 3.4rem; margin-bottom: 1rem; opacity: 0.8; }
.empty .hint { font-size: 1.25rem; margin-top: 0.5rem; }
.empty .big { font-family: var(--serif); font-size: 1.8rem; color: var(--ink-2); }

.two-col { grid-template-columns: 1.6fr 1fr; align-items: start; }
.three-col { grid-template-columns: repeat(3, 1fr); align-items: start; }

.kbd {
  font-family: var(--mono); font-size: 1.05rem;
  border: 1px solid var(--line-strong); border-bottom-width: 0.2rem;
  padding: 0 0.5rem; border-radius: 0.4rem; color: var(--ink-3);
}

.dot-sep { color: var(--ink-3); padding: 0 0.4rem; }

.form-row { display: flex; gap: 0.8rem; flex-wrap: wrap; align-items: end; }
.form-row .fld { display: flex; flex-direction: column; gap: 0.5rem; }
.form-row .fld label { font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--ink-3); }

.settings-grid { grid-template-columns: repeat(2, 1fr); align-items: start; }

.scroll-x { overflow-x: auto; }

/* Spreadsheet-style: the table scrolls inside its card with BOTH header rows
   pinned — sort headers, then the per-column filter row. Exact heights are
   measured by fitTable() in transactions.js (--head-h + max-height). */
.table-scroll { overflow: auto; max-height: 42rem; /* replaced by fitTable() */ }
.table-scroll thead tr:first-child th {
  position: sticky; top: 0; z-index: 6;
  background: var(--panel-float);
}
.table-scroll thead tr.filter-row th {
  position: sticky; top: var(--head-h, 3.8rem); z-index: 5;
  background: var(--panel-float);
  box-shadow: 0 1px 0 var(--line-strong);
  padding: 0.4rem 0.6rem 1rem;
}
.filter-row .input {
  width: 100%; min-width: 0;
  padding: 0.4rem 0.8rem; font-size: 1.2rem;
  background: var(--panel);
}
.filter-row select.input { padding-right: 2.2rem; background-position: right 0.7rem center; }
/* Filter cells that are picker buttons dressed as selects (category, account). */
.filter-picker {
  cursor: pointer; padding-right: 2.2rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2366746a' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.7rem center;
}

/* ── Playbook — scorecards & plays ──────────────────────── */

.score-strip { grid-template-columns: repeat(3, 1fr); }
.score-card { position: relative; overflow: hidden; }
.score-card .label { font-size: 1.15rem; text-transform: uppercase; letter-spacing: 0.09em; color: var(--ink-3); font-weight: 500; }
.score-card .value {
  font-family: var(--serif); font-size: 3.6rem; font-weight: 500;
  margin-top: 0.6rem; line-height: 1.1; font-variant-numeric: lining-nums;
}
.score-card .value .cents { font-size: 1.9rem; opacity: 0.55; }
.score-card .sub { font-size: 1.2rem; color: var(--ink-3); margin-top: 0.5rem; }
.score-card.banked .value { color: var(--green-bright); }
.score-card.table .value { color: var(--gold); }
.score-card::after {
  content: ''; position: absolute; left: 0; right: 0; top: 0; height: 0.2rem;
  background: linear-gradient(90deg, transparent, var(--kpi-glow, transparent), transparent);
  opacity: 0.7;
}
.score-card.banked { --kpi-glow: var(--green); }
.score-card.table { --kpi-glow: var(--gold); }

/* Thin progress meter — the core game element. */
.meter {
  height: 0.6rem; border-radius: 0.4rem; overflow: hidden;
  background: var(--panel-hover);
  border: 1px solid var(--line);
}
.meter > i {
  display: block; height: 100%; border-radius: 0.4rem;
  background: var(--green);
  animation: grow 0.8s cubic-bezier(0.2, 0.7, 0.3, 1) both;
}
.meter.gold > i { background: var(--gold); }
.meter.red > i { background: var(--red); }
.meter.blue > i { background: var(--blue); }
.meter-row { display: flex; align-items: center; gap: 1rem; }
.meter-row .meter { flex: 1; }
.meter-row .meter-cap { font-family: var(--mono); font-size: 1.15rem; color: var(--ink-3); white-space: nowrap; }

.season-days { font-family: var(--mono); font-size: 1.2rem; color: var(--ink-2); }

.play-grid { grid-template-columns: 1fr 1fr; align-items: start; }
.play-card { cursor: pointer; transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s; }
.play-card:hover { border-color: var(--line-strong); transform: translateY(-0.2rem); }
.play-head { display: flex; align-items: center; gap: 1rem; }
.play-head .p-ic { width: 2rem; height: 2rem; color: var(--ink-3); flex-shrink: 0; }
.play-head .p-ic svg { width: 100%; height: 100%; }
.play-head .p-title { font-weight: 500; font-size: 1.45rem; flex: 1; min-width: 0; }
.play-line { font-size: 1.25rem; color: var(--ink-2); margin-top: 0.7rem; }
.play-card .meter-row { margin-top: 1.1rem; }
.play-foot { display: flex; align-items: center; gap: 1rem; margin-top: 1.2rem; min-height: 2.2rem; }
.play-value { font-family: var(--mono); font-size: 1.3rem; }
.play-value.banked { color: var(--green-bright); }
.play-value.potential { color: var(--gold); }
.play-foot .spacer { margin-left: auto; }

.play-tag {
  font-size: 1.02rem; text-transform: uppercase; letter-spacing: 0.09em;
  padding: 0.25rem 0.9rem; border-radius: 2rem; white-space: nowrap;
  border: 1px solid var(--line-strong); color: var(--ink-2);
}
.play-tag.attention { color: var(--red); border-color: rgba(255,124,102,0.4); background: var(--red-dim); }
.play-tag.live { color: var(--green-bright); border-color: rgba(78,209,149,0.4); background: var(--green-dim); }
.play-tag.banked { color: var(--green); border-color: transparent; background: var(--green-dim); opacity: 0.8; }
.play-tag.info { color: var(--blue); border-color: transparent; background: var(--blue-dim); }
.play-tag.new {
  color: var(--gold); border-color: rgba(232,188,94,0.45); background: var(--gold-dim);
  animation: tag-glow 2.6s ease-in-out infinite alternate;
}
@keyframes tag-glow {
  from { box-shadow: 0 0 0 0 transparent; }
  to { box-shadow: 0 0 1.2rem -0.2rem var(--gold); }
}

.deadline-chip {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--mono); font-size: 1.12rem; color: var(--ink-3);
  border: 1px solid var(--line); border-radius: 2rem; padding: 0.2rem 0.9rem;
  white-space: nowrap;
}

.combo-chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: var(--mono); font-size: 1.08rem; color: var(--ink-3);
  border: 1px dashed var(--line-strong); border-radius: 2rem; padding: 0.2rem 0.9rem;
  white-space: nowrap; max-width: 18rem; overflow: hidden; text-overflow: ellipsis;
}
.combo-chip.on {
  color: var(--gold); border-style: solid; border-color: rgba(232,188,94,0.45);
  background: var(--gold-dim);
}

/* ── Sandbox ────────────────────────────────────────────── */

.sb-row {
  display: grid; grid-template-columns: 2.4rem 1fr 12rem 11rem;
  gap: 1.2rem; align-items: center;
  padding: 0.9rem 0; border-bottom: 1px solid var(--line);
  opacity: 0.72; transition: opacity 0.15s;
}
.sb-row.on, .sb-row:hover { opacity: 1; }
.sb-row:last-child { border-bottom: none; }
.sb-label .note { font-size: 1.1rem; color: var(--ink-3); }
.sb-amt { text-align: right; font-family: var(--mono); }
.sb-save { text-align: right; font-size: 1.3rem; color: var(--ink-3); }
.sb-save.on { color: var(--green-bright); }
@media (max-width: 800px) {
  .sb-row { grid-template-columns: 2.4rem 1fr; }
  .sb-amt, .sb-save { grid-column: 2; }
}

.plays-head { display: flex; align-items: baseline; gap: 1.2rem; margin: 2.2rem 0 1.2rem; }
.plays-head h2 { font-family: var(--serif); font-size: 1.9rem; font-weight: 500; }
.plays-head .running { font-family: var(--mono); font-size: 1.2rem; color: var(--ink-3); }

/* ── People ─────────────────────────────────────────────── */

.kind-chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.07em;
  padding: 0.15rem 0.8rem; border-radius: 2rem;
  border: 1px solid var(--line); color: var(--ink-3); white-space: nowrap;
}
.kind-chip.child { color: var(--gold); border-color: rgba(232,188,94,0.35); }
.kind-chip.contractor { color: var(--green); border-color: rgba(78,209,149,0.3); }
.kind-chip.client { color: var(--blue); border-color: var(--line-strong); }

.doc-chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 1.08rem; font-family: var(--mono);
  padding: 0.15rem 0.8rem; border-radius: 0.6rem; white-space: nowrap;
  border: 1px solid var(--line); color: var(--ink-3);
}
.doc-chip.due { color: var(--red); border-color: rgba(255,124,102,0.4); background: var(--red-dim); }
.doc-chip.ok { color: var(--green); border-color: rgba(78,209,149,0.3); }
.doc-chip.warn { color: var(--gold); border-color: rgba(232,188,94,0.4); }

.person-meter { min-width: 17rem; }
.person-meter .note { font-size: 1.08rem; color: var(--ink-3); margin-top: 0.4rem; }

.year-chips { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.year-chips .chip b { color: var(--ink); font-weight: 500; }

@media (max-width: 1100px) {
  .kpis, .tax-cards { grid-template-columns: repeat(2, 1fr); }
  .two-col, .three-col, .settings-grid { grid-template-columns: 1fr; }
  .score-strip { grid-template-columns: 1fr; }
  .play-grid { grid-template-columns: 1fr; }
}
/* Collapsed to an icon rail — via the manual toggle OR the mobile breakpoint. */
.sidebar.is-collapsed { width: 6rem; padding: 2rem 0.8rem; }
.sidebar.is-collapsed .label,
.sidebar.is-collapsed .wordmark span,
.sidebar.is-collapsed .sidebar-foot { display: none; }
.sidebar.is-collapsed .nav-item,
.sidebar.is-collapsed .wordmark { justify-content: center; }
.sidebar.is-collapsed .nav-item .badge {
  position: absolute; margin: 0; transform: translate(1rem, -1rem);
}
.sidebar.is-collapsed .nav-item { position: relative; }
.nav-collapse svg { transition: transform 0.2s; }
.sidebar.is-collapsed .nav-collapse svg { transform: rotate(180deg); }

@media (max-width: 800px) {
  .sidebar { width: 6rem; padding: 2rem 0.8rem; }
  .sidebar .label, .wordmark span, .sidebar-foot { display: none; }
  .sidebar .nav-item, .sidebar .wordmark { justify-content: center; }
  .nav-collapse { display: none; }
  .main { padding: 0 1.6rem 4rem; }
  .bulkbar { left: 50%; }
}
