:root{--bg:#f6f7f9;--surface:#fff;--surface-soft:#f0f3f7;--text:#1d2733;--muted:#667085;--line:#d9e0ea;--primary:#2563eb;--primary-strong:#1d4ed8;--success:#0f8f68;--danger:#dc4a3d;--warning:#b7791f;--shadow:0 18px 42px #202b3a14;--font-xs:12px;--font-sm:13px;--font-md:14px;--font-lg:16px;--font-xl:20px;--font-2xl:28px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:var(--font-md);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}*{box-sizing:border-box}html{min-width:320px;min-height:100%}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}#root{min-height:100vh}.app-shell{grid-template-columns:244px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#f8fafc;background:#102a43;height:100vh;padding:22px 16px;position:sticky;top:0}.brand{align-items:center;gap:12px;margin-bottom:24px;display:flex}.brand-mark{color:#082032;background:#3ddc97;border-radius:8px;place-items:center;width:44px;height:44px;font-weight:800;display:grid}.brand strong,.brand span{display:block}.brand span{color:#a9c3d7;font-size:var(--font-sm)}.nav-list{gap:6px;display:grid}.nav-list button{color:#c9d7e3;width:100%;min-height:42px;font-size:var(--font-md);background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:0 12px;display:flex}.nav-list button:hover,.nav-list button.active{color:#fff;background:#ffffff1f}.workspace{min-width:0;padding:28px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;display:flex}.topbar-actions{align-items:center;gap:10px;min-width:0;display:flex}.icon-action{width:38px;min-width:38px;padding:0}.eyebrow{color:var(--muted);font-size:var(--font-sm);margin:0 0 4px}h1,h2,p{margin:0}h1{font-size:var(--font-2xl);font-weight:800;line-height:1.2}h2{font-size:var(--font-lg);margin-bottom:14px;line-height:1.3}.status-pill{border:1px solid var(--line);max-width:42vw;color:var(--muted);background:var(--surface);text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-md);border-radius:8px;padding:8px 12px;overflow:hidden}.content-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.content-grid.two-column{grid-template-columns:minmax(320px,.9fr) minmax(0,1.35fr)}.panel,.metric{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:8px}.panel{min-width:0;padding:18px}.panel.wide{grid-column:1/-1}.overview-month-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.overview-month-row strong{font-size:var(--font-lg);margin-bottom:4px;display:block}.month-input{max-width:180px}.overview-foldout-toggle{text-align:left;justify-content:space-between;width:100%;min-height:74px;padding:14px}.overview-foldout-toggle strong,.overview-foldout-toggle small{display:block}.overview-foldout-toggle strong{color:var(--text);font-size:var(--font-lg);margin-bottom:4px}.overview-foldout-toggle small{color:var(--muted);font-size:var(--font-sm);line-height:1.45}.overview-foldout-meta{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.overview-foldout-meta span{background:var(--surface-soft);color:var(--muted);font-size:var(--font-sm);white-space:nowrap;border-radius:8px;padding:5px 8px;font-weight:700}.overview-foldout-content{gap:18px;margin-top:16px;display:grid}.overview-section h3{font-size:var(--font-md);margin:0 0 12px;line-height:1.3}.metric{padding:18px}.metric span{color:var(--muted);font-size:var(--font-md);margin-bottom:10px;display:block}.metric strong{color:#182230;font-size:var(--font-2xl);line-height:1.15;display:block}.metric.compact{box-shadow:none;margin-top:14px}.metric.expense strong,.expense-text{color:var(--danger)}.metric.income strong,.income-text{color:var(--success)}.metric.neutral strong,.neutral-text{color:var(--muted)}.metric.business strong{color:#146c94}.metric.rent strong{color:#7c3aed}.metric-button{border-color:var(--line);text-align:left;cursor:pointer;align-items:stretch;width:100%;min-height:0;display:block}.business-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px;display:grid}.input,select,.search-box input,.category-editor input[type=text]{border:1px solid var(--line);width:100%;min-height:38px;color:var(--text);font-size:var(--font-md);background:#fff;border-radius:8px}.input,select{padding:0 10px}.toolbar,.actions,.backup-actions,.preview-summary{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-box{border:1px solid var(--line);background:#fff;border-radius:8px;flex:260px;align-items:center;gap:8px;min-height:40px;padding:0 10px;display:flex}.search-box input{border:0;outline:0;min-width:0}button,.file-button{border:1px solid var(--line);min-height:38px;color:var(--text);font-size:var(--font-md);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 14px;display:inline-flex}button.primary,.file-button{border-color:var(--primary);color:#fff;background:var(--primary)}button.primary:hover,.file-button:hover{background:var(--primary-strong)}button.danger{color:var(--danger);border-color:#dc4a3d3d}.file-button input,.drop-zone input{display:none}.drop-zone{color:#284967;cursor:pointer;text-align:center;background:#f2f7fb;border:1px dashed #8aa4c2;border-radius:8px;place-items:center;gap:8px;min-height:154px;padding:24px;transition:border-color .2s,background .2s,box-shadow .2s,transform .2s;display:grid}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary);background:#eaf2ff;box-shadow:inset 0 0 0 1px #2563eb33}.drop-zone.dragging{transform:translateY(-1px)}.drop-zone strong{color:#183b56;font-size:var(--font-lg);line-height:1.35}.drop-zone span{color:var(--muted);font-size:var(--font-md)}.preview-summary{margin-bottom:12px}.preview-summary span,.tag{background:var(--surface-soft);color:var(--muted);font-size:var(--font-sm);border-radius:8px;padding:5px 8px}.tag.new{color:var(--success);background:#e8f7f0}.tag.duplicate{color:var(--warning);background:#fff4dc}.direction-badge{background:var(--surface-soft);min-width:42px;min-height:26px;color:var(--muted);font-size:var(--font-sm);border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-weight:700;display:inline-flex}.direction-badge.expense{color:var(--danger);background:#fff0ee}.direction-badge.income,.direction-badge.refund{color:var(--success);background:#e8f7f0}.direction-badge.transfer{color:#6b4aa0;background:#f1ecfb}.direction-badge.neutral{color:#5f6673;background:#edf1f7}.direction-badge.rent_expense{color:#7c3aed;background:#f3eefe}.direction-badge.business_expense,.direction-badge.business_reimbursement,.direction-badge.business_reversal{color:#146c94;background:#e8f4f8}.table-wrap{width:100%;overflow-x:auto}.transaction-card-list{display:none}.transaction-card{border:1px solid var(--line);background:#fff;border-radius:8px;gap:10px;padding:12px;display:grid}.transaction-card-main{grid-template-columns:minmax(0,1fr) auto;gap:12px;display:grid}.transaction-card-main strong,.transaction-card-main p{text-overflow:ellipsis;min-width:0;display:block;overflow:hidden}.transaction-card-main strong{white-space:nowrap}.transaction-card-main p{color:var(--muted);font-size:var(--font-sm);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;line-height:1.35;display:-webkit-box}.card-amount{font-size:var(--font-lg);white-space:nowrap;font-weight:800}.card-chips{flex-wrap:wrap;gap:6px;display:flex}.card-chips>span:not(.direction-badge):not(.tag){min-height:24px;color:var(--muted);background:var(--surface-soft);font-size:var(--font-sm);border-radius:8px;align-items:center;padding:0 8px;font-weight:700;display:inline-flex}.card-category-select{min-height:34px}table{border-collapse:collapse;width:100%;min-width:1000px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:12px 10px}th{color:var(--muted);font-size:var(--font-sm);font-weight:700}td{font-size:var(--font-md)}td.amount{text-align:right;font-weight:700}td select{max-width:150px}.refund-notes{gap:2px;margin-top:4px;display:grid}.refund-notes small{color:var(--success);font-size:var(--font-xs);font-weight:700}.reversal-select{width:150px;min-height:30px;font-size:var(--font-xs);margin-top:6px;margin-left:auto;font-weight:500;display:block}.calendar{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin-top:14px;display:grid}.weekday{color:var(--muted);font-size:var(--font-xs);text-align:center}.day{border:1px solid var(--line);background:#fff;border-radius:8px;align-content:start;justify-items:start;gap:8px;min-height:68px;padding:8px;display:grid}.day strong{font-size:var(--font-md)}.day span.expense{color:var(--danger);font-size:var(--font-xs)}.day span.income{color:var(--success);font-size:var(--font-xs)}.day span.neutral{color:var(--muted);font-size:var(--font-xs)}.day.selected{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary)}.pie-chart,.empty-chart{width:100%;height:360px}.empty-chart,.empty-state{min-height:120px;color:var(--muted);background:#f7f9fc;border-radius:8px;place-items:center;display:grid}.rank-list{gap:14px;display:grid}.rank-item{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px 12px;display:grid}.rank-button{text-align:left;background:0 0;border:0;width:100%;min-height:0;padding:0}.rank-button:hover,.rank-button.selected{background:#f7f9fc;border-radius:8px}.rank-button.selected{box-shadow:inset 0 0 0 1px var(--primary)}.rank-item div{align-items:center;gap:8px;min-width:0;display:flex}.rank-item small{color:var(--muted);font-size:var(--font-sm)}.rank-item progress{border:0;border-radius:999px;grid-column:1/-1;width:100%;height:8px;overflow:hidden}.rank-item progress::-webkit-progress-bar{background:#edf1f7}.rank-item progress::-webkit-progress-value{background:var(--primary)}.swatch{border-radius:3px;flex:0 0 12px;width:12px;height:12px}.category-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px;display:grid}.category-editor{border:1px solid var(--line);border-radius:8px;grid-template-columns:42px minmax(0,1fr);gap:10px;padding:10px;display:grid}.category-editor input[type=color]{background:0 0;border:0;border-radius:8px;width:42px;height:38px;padding:0}.category-editor input:not([type=color]){border:0;outline:0;min-width:0}.backup-actions{margin-bottom:14px}.mobile-tabbar{display:none}.sheet-layer{z-index:20;position:fixed;inset:0}.sheet-scrim{background:#0f172a61;border:0;border-radius:0;width:100%;height:100%;min-height:0;padding:0;position:absolute;inset:0}.backup-sheet{border:1px solid var(--line);background:#fff;border-radius:8px;gap:14px;max-width:520px;margin:0 auto;padding:16px;display:grid;position:absolute;bottom:12px;left:12px;right:12px;box-shadow:0 24px 58px #0f172a3d}.sheet-head{justify-content:space-between;gap:14px;display:flex}.sheet-head h2{margin-bottom:4px}.backup-sheet-actions{gap:10px;display:grid}.manual-fab{display:none}.manual-sheet{max-width:640px}.manual-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.manual-form label{color:var(--muted);font-size:var(--font-sm);gap:6px;font-weight:700;display:grid}.manual-form .actions{grid-column:1/-1}.segmented-control{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:12px;display:grid}.segmented-control button{min-height:34px;color:var(--muted);background:var(--surface-soft);padding:0 8px}.segmented-control button.active{border-color:var(--primary);color:var(--primary);background:#eef4ff}.muted{color:var(--muted)}@media (width<=980px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;padding:14px;position:static}.brand{margin-bottom:12px}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr))}.nav-list button{justify-content:center;padding:0 8px}.workspace{padding:18px}.content-grid,.content-grid.two-column{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{justify-content:space-between;width:100%}.overview-month-row{flex-direction:column;align-items:stretch}.month-input{max-width:none}.overview-foldout-toggle{flex-direction:column;align-items:stretch}.overview-foldout-meta{justify-content:flex-start}.status-pill{max-width:100%}}@media (width<=560px){.app-shell{padding-bottom:78px;display:block}.sidebar{display:none}.workspace{padding:14px 12px 18px}.topbar{z-index:5;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f6f7f9f5;margin:-14px -12px 12px;padding:12px;position:sticky;top:0}.eyebrow{font-size:var(--font-xs)}.status-pill{flex:1}.content-grid{gap:12px}.panel,.metric{box-shadow:none}.panel{padding:14px}.panel h2{font-size:var(--font-lg)}.metric{padding:14px}.toolbar{grid-template-columns:1fr;display:grid}.business-summary,.manual-form{grid-template-columns:1fr}.table-wrap{display:none}.transaction-card-list{gap:10px;display:grid}.calendar{gap:5px}.day{gap:4px;min-height:54px;padding:6px}.day strong{font-size:var(--font-sm)}.day span{font-size:11px}.pie-chart,.empty-chart{height:280px}.mobile-tabbar{z-index:10;min-height:68px;padding:7px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;grid-template-columns:repeat(4,1fr);display:grid;position:fixed;bottom:0;left:0;right:0}.manual-fab{right:18px;bottom:calc(84px + env(safe-area-inset-bottom));z-index:11;color:#fff;background:var(--primary);border:0;border-radius:50%;width:50px;min-width:50px;height:50px;padding:0;display:inline-flex;position:fixed;box-shadow:0 14px 28px #2563eb42}.topbar-actions .icon-action:first-of-type{display:none}.segmented-control{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-tabbar button{min-height:48px;color:var(--muted);font-size:var(--font-xs);background:0 0;border:0;flex-direction:column;gap:3px;padding:0}.mobile-tabbar button.active{color:var(--primary);background:#eef4ff}.sheet-layer{display:block}.nav-list{grid-template-columns:repeat(3,minmax(0,1fr))}.nav-list button{min-height:50px;font-size:var(--font-xs);flex-direction:column;gap:3px}h1,.metric strong{font-size:var(--font-xl)}}
