:root{color-scheme:light;--bg: #f6f1e8;--surface: #fffaf2;--surface-strong: #ffffff;--surface-muted: #eee8dd;--text: #1e293b;--muted: #667085;--border: #ddd3c4;--shadow: 0 22px 60px rgba(44, 38, 28, .12);--input: #fffdf8;--positive: #087f5b;--positive-soft: #d9f4e8;--warning: #a15c07;--warning-soft: #fff0cc;--danger: #b42318;--danger-soft: #ffe4df;--neutral-soft: #e6edf7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-theme=dark]{color-scheme:dark;--bg: #171512;--surface: #22201b;--surface-strong: #2c2923;--surface-muted: #343027;--text: #f4efe6;--muted: #b5aa9b;--border: #474033;--shadow: 0 24px 70px rgba(0, 0, 0, .4);--input: #1b1915;--positive: #6ee7b7;--positive-soft: #123a2c;--warning: #facc15;--warning-soft: #3d310f;--danger: #fca5a5;--danger-soft: #441c1c;--neutral-soft: #273447}*{box-sizing:border-box}body{margin:0;min-width:360px;background:radial-gradient(circle at top left,rgba(20,184,166,.16),transparent 30rem),linear-gradient(135deg,var(--bg),var(--surface-muted));color:var(--text)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}.motion-ambient{display:none}}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{position:relative;display:grid;grid-template-columns:300px minmax(0,1fr);min-height:100vh;overflow:hidden}.motion-ambient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.motion-ambient span{position:absolute;width:36rem;height:36rem;border-radius:999px;opacity:.14;filter:blur(44px);animation:ambient-drift 18s ease-in-out infinite alternate}.motion-ambient span:first-child{right:-12rem;top:8rem;background:#1f8a70}.motion-ambient span:last-child{left:18rem;bottom:-18rem;background:#f59e0b;animation-delay:-7s}@keyframes ambient-drift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(2rem,-1.5rem,0) scale(1.08)}}.sidebar{position:sticky;z-index:1;top:0;height:100vh;padding:24px;overflow:auto;background:color-mix(in srgb,var(--surface) 92%,transparent);border-right:1px solid var(--border)}.brand-block{display:flex;align-items:center;gap:14px;margin-bottom:32px}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:#1f8a70;color:#fff;box-shadow:0 12px 26px #1f8a7047}.eyebrow,.section-label{margin:0;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}.brand-block h1,.topbar h2,.band-heading h3{margin:0}.brand-block h1{font-size:26px;line-height:1.1}.month-list,.analysis-panel,.template-panel{display:grid;gap:10px}.analysis-panel,.template-panel{margin-top:28px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong)}.section-label{display:flex;align-items:center;justify-content:space-between;gap:10px}.month-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;align-items:center;gap:8px}.month-button{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:52px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);color:var(--text);text-align:left;transition:transform .16s ease,border-color .16s ease,background .16s ease}.month-row:hover .month-button{transform:translate(2px)}.month-row.active .month-button{border-color:#1f8a70;background:color-mix(in srgb,#1f8a70 13%,var(--surface-strong))}.month-button strong{white-space:nowrap}.template-panel select{margin-top:4px}.template-create{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:8px}.template-actions{display:flex;align-items:center;gap:6px}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.48}.mini-chart{display:grid;gap:12px;margin-top:14px}.mini-bar-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;font-size:12px}.mini-bar-track{height:8px;overflow:hidden;border-radius:999px;background:var(--surface-muted)}.mini-bar-track div{height:100%;border-radius:inherit;background:linear-gradient(90deg,#1f8a70,#f59e0b)}.workspace{position:relative;z-index:1;min-width:0;padding:28px}.topbar,.control-band{display:flex;align-items:center;justify-content:space-between;gap:18px}.topbar{margin-bottom:22px}.topbar h2{margin-top:2px;font-size:34px;line-height:1.15}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.select-wrap{position:relative;display:flex;align-items:center;gap:8px;min-height:42px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong)}.select-wrap span{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}.select-wrap select{padding-right:18px;border:0;outline:0;background:transparent;color:var(--text);-webkit-appearance:none;-moz-appearance:none;appearance:none}.select-wrap svg{pointer-events:none}.theme-toggle,.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 14px;border:1px solid var(--border);border-radius:8px;background:#1f8a70;color:#fff;font-weight:700}.theme-toggle{background:var(--surface-strong);color:var(--text)}.sync-pill{display:inline-flex;align-items:center;min-height:34px;padding:0 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface-strong);color:var(--muted);font-size:12px;font-weight:800;white-space:nowrap}.sync-pill.synced{border-color:color-mix(in srgb,var(--positive) 35%,var(--border));background:var(--positive-soft);color:var(--positive)}.sync-pill.loading{border-color:color-mix(in srgb,var(--warning) 35%,var(--border));background:var(--warning-soft);color:var(--warning)}.sync-pill.error{border-color:color-mix(in srgb,var(--danger) 35%,var(--border));background:var(--danger-soft);color:var(--danger)}.secondary-button{background:var(--surface-strong);color:var(--text)}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.metric-card{min-height:118px;padding:18px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}.metric-card:hover{transform:translateY(-2px)}.metric-card span{display:block;margin-bottom:18px;color:var(--muted);font-size:13px;font-weight:700}.metric-card strong{display:block;overflow-wrap:anywhere;font-size:27px;line-height:1.12}.metric-card.positive{background:linear-gradient(180deg,var(--positive-soft),var(--surface-strong))}.metric-card.warning{background:linear-gradient(180deg,var(--warning-soft),var(--surface-strong))}.metric-card.danger{background:linear-gradient(180deg,var(--danger-soft),var(--surface-strong))}.metric-card.neutral{background:linear-gradient(180deg,var(--neutral-soft),var(--surface-strong))}.control-band{align-items:stretch;margin-bottom:18px}.income-editor,.rate-editor,.category-panel{border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface-strong) 96%,transparent);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.income-editor:hover,.rate-editor:hover,.category-panel:hover{border-color:color-mix(in srgb,#1f8a70 24%,var(--border))}.income-editor{flex:1 1 640px;padding:18px}.rate-editor{flex:0 1 420px;padding:18px}.band-heading{display:flex;align-items:center;gap:9px;margin-bottom:12px}.band-heading h3{font-size:16px}.income-grid{display:grid;gap:8px}.income-row{display:grid;grid-template-columns:36px minmax(140px,1fr) 132px 92px 34px;align-items:center;gap:8px}.income-color-picker{position:relative;display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong)}.income-color-picker span{width:20px;height:20px;border-radius:999px;background:var(--income-color);box-shadow:inset 0 0 0 2px #ffffff6b}.income-color-picker input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;min-height:100%;padding:0;border:0;opacity:0;cursor:pointer}.income-breakdown{display:grid;gap:6px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.income-breakdown-heading,.income-breakdown-row{display:grid;grid-template-columns:minmax(110px,1fr) repeat(3,minmax(74px,auto));align-items:center;gap:10px;font-size:12px}.income-breakdown-heading{color:var(--muted);font-weight:800;text-transform:uppercase}.income-breakdown-row{min-height:36px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--input);color:var(--text);text-align:left}.income-breakdown-row.collapsible{width:100%;cursor:pointer}.income-breakdown-row strong{display:flex;align-items:center;gap:8px;min-width:0;color:var(--text)}.income-breakdown-row strong svg{flex:0 0 auto;color:var(--muted)}.income-breakdown-row strong span{flex:0 0 auto;width:10px;height:10px;border-radius:999px;background:var(--income-color)}.income-breakdown-row>span{text-align:right;font-weight:800;white-space:nowrap}.income-breakdown-row.over{border-color:color-mix(in srgb,var(--danger) 40%,var(--border));background:var(--danger-soft)}.income-breakdown-row.over>span:last-child{color:var(--danger)}.income-breakdown-row.unassigned strong span{background:var(--muted)}.comparison-page,.template-editor-page{display:grid;gap:18px}.template-editor-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);box-shadow:var(--shadow)}.template-name-input{min-height:42px;padding:0;border:0;background:transparent;color:var(--text);font-size:26px;font-weight:800}.template-name-input:focus{box-shadow:none}.comparison-header{display:grid;gap:16px;padding:20px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);box-shadow:var(--shadow)}.comparison-header h3{margin:2px 0 0;font-size:24px}.comparison-totals{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.comparison-totals .metric-card{min-height:92px;box-shadow:none}.comparison-totals .metric-card strong{font-size:22px}.comparison-table{margin-top:0;padding:18px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);box-shadow:var(--shadow)}.comparison-table .income-breakdown-heading,.comparison-table .income-breakdown-row{grid-template-columns:minmax(180px,1fr) repeat(3,minmax(110px,auto));font-size:14px}.income-source-group{display:grid;gap:6px}.income-contributions{display:grid;gap:6px;margin:0 0 12px 18px;padding-left:14px;border-left:2px solid var(--border)}.income-contributions p{margin:0;padding:8px 0;color:var(--muted);font-size:13px}.income-contribution-row{display:grid;grid-template-columns:minmax(110px,.85fr) minmax(160px,1fr) 80px minmax(90px,auto);align-items:center;gap:10px;min-height:34px;padding:7px 10px;border:1px solid var(--border);border-radius:7px;background:color-mix(in srgb,var(--input) 82%,transparent);font-size:13px}.income-contribution-row strong,.income-contribution-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.income-contribution-row>span:first-child{color:var(--muted)}.income-contribution-row>span:last-child{text-align:right;font-weight:800}.income-contribution-row .paid{color:var(--positive);font-weight:800}.income-contribution-row .pending{color:var(--warning);font-weight:800}.rate-editor p{margin:0 0 12px;color:var(--muted);font-size:13px}.rate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.rate-grid label{display:grid;gap:4px}.rate-grid span{color:var(--muted);font-size:12px;font-weight:700}input,select,textarea{width:100%;min-height:36px;border:1px solid var(--border);border-radius:7px;background:var(--input);color:var(--text);outline:0}input,select{padding:0 10px}textarea{min-height:34px;max-height:96px;padding:8px 10px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:#1f8a70;box-shadow:0 0 0 3px #1f8a702e}.icon-button{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);color:var(--text)}.icon-button.compact{width:34px;height:34px;border-radius:7px}.item-row .icon-button.compact{width:28px;height:28px}.item-row .icon-button.compact svg{width:14px;height:14px}.category-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.category-panel{overflow:hidden}.category-panel:before{content:"";display:block;height:5px;background:var(--accent)}.category-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.category-header>div:first-child{flex:1 1 190px;min-width:0}.category-header p{margin:5px 0 0;color:var(--muted);font-size:13px}.category-header select{max-width:110px}.category-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.category-name{min-height:30px;padding:0;border:0;background:transparent;color:var(--text);font-size:18px;font-weight:800}.category-name:focus{box-shadow:none}.item-list{display:grid}.item-row{display:grid;grid-template-columns:26px minmax(76px,1fr) minmax(58px,auto) 28px 28px 28px;gap:6px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);transition:background .16s ease,transform .16s ease}.item-row:hover{transform:translate(2px)}.item-row.done{background:color-mix(in srgb,var(--positive-soft) 36%,transparent)}.item-row.over-budget{background:color-mix(in srgb,var(--danger-soft) 52%,transparent)}.item-row.over-budget .line-amount{background:var(--danger-soft);color:var(--danger)}.check-button{grid-column:1;grid-row:1;display:grid;place-items:center;width:24px;height:24px;border:1px solid var(--border);border-radius:7px;background:var(--surface-strong);color:#fff}.item-row.done .check-button{border-color:#1f8a70;background:#1f8a70}.line-name{grid-column:2;grid-row:1;min-width:0;min-height:30px;display:block;padding:6px 9px;border:1px solid var(--border);border-radius:6px;background:var(--input);color:var(--line-text-color, var(--text));font-size:12px;line-height:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-amount{grid-column:3;grid-row:1;justify-self:stretch;min-height:30px;display:inline-flex;align-items:center;justify-content:flex-end;min-width:58px;padding:0 7px;border-radius:6px;background:color-mix(in srgb,var(--positive-soft) 42%,var(--surface-strong));color:var(--text);font-size:12px;font-weight:800;white-space:nowrap}.line-comment-button{grid-column:4;grid-row:1}.line-delete-button{grid-column:5;grid-row:1}.line-edit-button{grid-column:6;grid-row:1}.button-badge{position:absolute;right:-5px;top:-6px;min-width:17px;height:17px;padding:0 5px;border-radius:999px;background:#1f8a70;color:#fff;font-size:10px;font-weight:800;line-height:17px}.icon-button{position:relative}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:24px;background:#12121085}.modal-panel{width:min(720px,100%);max-height:min(760px,calc(100vh - 48px));overflow:auto;border:1px solid var(--border);border-radius:10px;background:var(--surface-strong);color:var(--text);box-shadow:0 30px 90px #00000057}.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-bottom:1px solid var(--border)}.modal-header h3{margin:2px 0 4px;font-size:22px}.modal-header span{color:var(--muted);font-size:13px;font-weight:700}.modal-footer{justify-content:flex-end;border-top:1px solid var(--border);border-bottom:0}.comments-list,.edit-form{display:grid;gap:10px;padding:18px}.spend-status{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:18px 18px 0;padding:14px;border:1px solid var(--border);border-radius:8px}.spend-status strong,.spend-status span{overflow-wrap:anywhere}.spend-status.within{background:var(--positive-soft);color:var(--positive)}.spend-status.over{background:var(--danger-soft);color:var(--danger)}.comment-row{display:grid;grid-template-columns:minmax(0,1fr) 120px 88px 34px;gap:8px;align-items:start}.empty-state{margin:0;padding:18px;border:1px dashed var(--border);border-radius:8px;color:var(--muted);text-align:center}.edit-form label{display:grid;gap:6px}.edit-form label>span{color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.paid-toggle{display:flex!important;grid-template-columns:none;align-items:center;gap:10px;min-height:42px}.paid-toggle input{width:18px;min-height:18px}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--border)}.month-list{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-panel{display:none}.summary-grid{grid-template-columns:1fr}.category-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.workspace,.sidebar{padding:18px}.topbar,.control-band,.template-editor-header{align-items:stretch;flex-direction:column}.topbar h2{font-size:28px}.summary-grid,.month-list,.category-grid,.income-row,.income-breakdown-heading,.income-breakdown-row,.comparison-table .income-breakdown-heading,.comparison-table .income-breakdown-row,.income-contribution-row{grid-template-columns:1fr}.income-breakdown-row>span,.income-contribution-row>span:last-child{text-align:left}.comparison-totals,.item-row{grid-template-columns:1fr}.check-button{grid-column:auto;grid-row:auto;width:100%}.line-name,.line-amount,.line-comment-button,.line-delete-button,.line-edit-button{grid-column:auto;grid-row:auto}.line-amount{justify-content:flex-start;width:100%}.comment-row{grid-template-columns:1fr}.topbar-actions{align-items:stretch;flex-direction:column}}
