@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg:#fafbff;--card:#fff;--border:#e9ecf4;--soft:#f6f7fb;--text:#111827;--muted:#64748b;--faint:#94a3b8;--primary:#5b3ff2;--danger:#ef3340;--green:#18b66a;--shadow:0 10px 28px #0f172a09;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.dashboard-shell{background:var(--bg);min-height:100vh;color:var(--text)}.sidebar{z-index:10;background:#fff;border-right:1px solid #eef1f7;flex-direction:column;gap:22px;width:232px;padding:34px 30px 28px;display:flex;position:fixed;inset:0 auto 0 0}.brand{gap:9px;margin-bottom:8px;display:grid}.brand b{letter-spacing:-.05em;font-size:22px;line-height:1}.brand span{color:#334155;align-items:center;gap:7px;font-size:12px;font-weight:500;display:inline-flex}.brand i{background:#10b981;border-radius:999px;width:7px;height:7px}.sidebar nav{gap:8px;display:grid}.secondary-nav{border-top:1px solid #f1f3f8;margin-top:20px;padding-top:22px}.sidebar a{color:#1f2937;border-radius:9px;align-items:center;gap:13px;height:44px;padding:0 14px;font-size:13px;font-weight:700;text-decoration:none;transition:all .18s;display:flex;position:relative}.sidebar a:hover{background:#f7f7ff}.sidebar a.active{color:#3823d9;background:#eeeafe}.nav-icon,.panel-icon{stroke-width:2.25px;width:17px;height:17px}.chevron{color:#9ca3af;margin-left:auto;font-size:19px;line-height:1}.help-card{color:#4f46e5;background:#fff;border:1px solid #eef1f7;border-radius:10px;align-items:center;gap:10px;min-height:52px;margin-top:auto;padding:12px 14px;display:flex;box-shadow:0 8px 24px #0f172a06}.help-card div{flex:1;min-width:0}.help-card b{color:#111827;font-size:12px;display:block}.help-card p{color:#64748b;margin:2px 0 0;font-size:11px}.help-card>span{color:#94a3b8;font-size:18px}.month-selector{display:none}.page{width:min(1260px,100vw - 232px);margin-left:232px;padding:32px 22px 44px}.topbar{grid-template-columns:1fr auto;align-items:start;gap:18px;margin-bottom:22px;display:grid}.overview-title h1{letter-spacing:-.045em;margin:0;font-size:22px;line-height:1.1}.overview-title p{color:#64748b;margin:8px 0 0;font-size:13px}.toolbar{justify-content:flex-end;align-items:center;gap:14px;display:flex}.status{letter-spacing:.07em;text-transform:uppercase;border-radius:7px;justify-content:center;align-items:center;min-width:98px;height:34px;padding:0 14px;font-size:10px;font-weight:800;display:inline-flex}.status-loading{border:2px solid #cbd5e1;border-top-color:#4f46e5;border-radius:50%;width:15px;height:15px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.safe{color:#047857;background:#ecfdf5}.watch{color:#a16207;background:#fef3c7}.danger{color:var(--danger);background:#ffecef}.top-month{border:1px solid var(--border);background:#fff;border-radius:8px;align-items:center;gap:9px;height:36px;padding:0 12px;display:inline-flex}.top-month select{color:#111827;background:0 0;border:0;outline:0;min-width:142px;font-size:12px;font-weight:700}.neg{color:var(--danger)!important;font-weight:800!important}.dashboard-grid{grid-template-columns:repeat(12,minmax(0,1fr));align-items:stretch;gap:12px;display:grid}.dashboard-grid>.sheet-panel,.dashboard-grid>.chart-panel{min-width:0}.dashboard-grid>.sheet-panel:first-child,.dashboard-grid>.sheet-panel:nth-child(2),.dashboard-grid>.sheet-panel:nth-child(3){grid-column:span 4;height:auto}.dashboard-grid>.sheet-panel:nth-child(4),.dashboard-grid>.sheet-panel:nth-child(5),.dashboard-grid>.sheet-panel:nth-child(6),.dashboard-grid>.sheet-panel:nth-child(7){grid-column:span 3;height:auto}.dashboard-grid>.sheet-panel:nth-child(8),.dashboard-grid>.sheet-panel:nth-child(9),.dashboard-grid>.sheet-panel:nth-child(10){grid-column:span 4;height:auto}.balance-chart{grid-column:span 8;height:auto}.spending-chart{grid-column:span 4;height:auto}.bottom-three{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;gap:14px;display:grid}.bottom-three .sheet-panel{height:auto}.bottom-three .scrollable-list{flex:1;min-height:0;overflow-y:auto}.sheet-panel,.chart-panel{border:1px solid var(--border);background:var(--card);max-height:600px;box-shadow:var(--shadow);border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.sheet-panel>.sheet-table,.sheet-panel>.breakdown-table,.sheet-panel>.breakdown-visual,.sheet-panel>.donut-wrap,.sheet-panel>.request-list,.sheet-panel>.review-transaction-list{min-height:0;overflow-y:auto}.panel-title{flex:none;justify-content:space-between;align-items:flex-start;gap:10px;padding:18px 18px 8px;display:flex}.panel-heading{align-items:flex-start;gap:13px;min-width:0;display:flex}.icon-badge{color:#4f46e5;background:#eef2ff;border-radius:999px;flex:none;place-items:center;width:32px;height:32px;display:grid}.sheet-panel h2,.chart-panel h2{color:#0f172a;letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:11px;font-weight:800;line-height:1.15}.panel-heading p,.panel-note{color:#64748b;max-width:250px;margin:7px 0 0;font-size:10.5px;line-height:1.35}.tone-blue .icon-badge{color:#5b3ff2;background:#ede9fe}.tone-peach .icon-badge{color:#f97316;background:#fff0e5}.tone-pink .icon-badge{color:#db2777;background:#ffe5f1}.tone-lavender .icon-badge,.tone-purple .icon-badge{color:#5b3ff2;background:#eeeafe}.tone-green .icon-badge{color:#16a34a;background:#e7f9ef}.tone-amber .icon-badge{color:#d97706;background:#fff4d6}.tone-teal .icon-badge{color:#0d9488;background:#e2faf5}.tone-red .icon-badge{color:#ef3340;background:#ffecef}.panel-footer{background:0 0;border-top:1px solid #f3f4f8;flex:none;margin-top:auto;padding:12px 20px 16px}.footer-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.footer-actions button,.modal-actions button,.deleted-row button,.login button{color:#5b3ff2;background:#fff;border:1px solid #e7eaf2;border-radius:6px;justify-content:center;align-items:center;height:30px;padding:0 12px;font-size:11px;font-weight:800;display:inline-flex}.footer-actions button:first-child:before{content:"+";margin-right:6px}.sheet-table,.breakdown-table{width:100%;padding:0 12px 6px;font-size:10.5px}.sheet-row{border-bottom:1px solid #f2f4f8;grid-template-columns:minmax(96px,1fr) minmax(62px,auto) minmax(62px,auto);align-items:center;min-height:30px;display:grid}.sheet-row.with-left{grid-template-columns:minmax(112px,1fr) minmax(64px,auto) minmax(54px,auto) minmax(70px,auto)}.sheet-row.with-action{grid-template-columns:24px minmax(54px,1fr) minmax(50px,auto) minmax(50px,auto)}.sheet-row>*{min-width:0;padding:7px 3px}.sheet-row span{text-overflow:ellipsis;white-space:nowrap;color:#111827;font-weight:600;overflow:hidden}.sheet-row .payment-date{color:#94a3b8;margin-top:2px;font-size:9px;font-weight:500;display:block}.sheet-row b,.sheet-row em{text-align:right;color:#111827;white-space:nowrap;font-style:normal;font-weight:700}.sheet-head{border-bottom-color:#edf0f6;min-height:28px}.sheet-head b,.sheet-head span{color:#64748b;letter-spacing:.07em;text-transform:uppercase;font-size:9px;font-weight:800}.row-icon{color:#64748b;background:#fff;border:1px solid #e7eaf2;border-radius:7px;place-items:center;width:22px;height:22px;padding:0;display:grid}.row-icon-svg{width:12px;height:12px}.compact .cash{grid-template-columns:1fr auto}.compact .cash span:first-child{padding-left:5px}.compact .total{text-transform:uppercase;border-top:1px solid #e7eaf2;border-bottom:0;margin-top:4px}.compact .total b{color:var(--danger)}.donut-wrap{min-height:196px;padding:0 12px 14px;position:relative}.left-donut strong{text-align:center;letter-spacing:-.06em;white-space:nowrap;font-size:30px;font-weight:800;line-height:1;position:absolute;inset:49% 10px auto;transform:translateY(-50%)}.left-donut strong small{color:#111827;letter-spacing:.08em;margin-top:10px;font-size:13px;display:block}.breakdown-visual{flex:1;grid-template-columns:minmax(0,1.25fr) 96px;align-items:center;gap:8px;padding:0 18px 12px 12px;display:grid}.breakdown-pie-wrap{min-height:200px;position:relative}.pie-center{background:#fff;border-radius:999px;align-content:center;place-items:center;width:68px;height:68px;display:grid;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #eef0f4}.pie-center b{font-size:20px;line-height:1}.pie-center span{color:#64748b;margin-top:4px;font-size:10px}.breakdown-legend{gap:9px;display:grid}.breakdown-legend div{grid-template-columns:9px auto;align-items:center;column-gap:8px;display:grid}.breakdown-legend i{border-radius:999px;width:8px;height:8px}.breakdown-legend b{color:#ef3340;font-size:11px}.breakdown-legend span{color:#64748b;grid-column:2;font-size:9px}.breakdown-head,.breakdown-row{border-bottom:1px solid #f2f4f8;grid-template-columns:minmax(100px,1fr) minmax(76px,auto) 46px;align-items:center;min-height:27px;display:grid}.breakdown-head{color:#64748b;letter-spacing:.07em;text-transform:uppercase;font-size:9px;font-weight:800}.breakdown-head span,.breakdown-row>*{padding:6px 2px}.breakdown-row span{text-overflow:ellipsis;white-space:nowrap;color:#111827;font-weight:600;overflow:hidden}.breakdown-row b{text-align:right;font-weight:700}.breakdown-row em{color:#111827;text-align:right;font-style:normal;font-weight:700}.list-total{color:#111827;text-transform:uppercase;grid-template-columns:1fr auto;font-size:11px;font-weight:800;display:grid}.chart-panel{padding:18px 20px 10px;overflow-y:auto}.chart-panel h2{padding:0}.chart-panel>.panel-note{margin:7px 0 5px}.balance-chart .recharts-wrapper{margin-top:-4px}.spending-chart .recharts-wrapper{margin-top:-10px}.recharts-wrapper text{font-family:Inter,system-ui,sans-serif;font-size:10px}.recharts-tooltip-wrapper .recharts-default-tooltip{border-radius:10px!important}.request-head,.review-head{color:#64748b;letter-spacing:.07em;text-transform:uppercase;border-bottom:1px solid #eef1f7;align-items:center;min-height:27px;font-size:9px;font-weight:800;display:grid}.request-head,.request{grid-template-columns:minmax(72px,.8fr) minmax(0,1.2fr) minmax(78px,auto);gap:8px}.request-head>*,.review-head>*{padding:6px 14px}.request-list,.review-transaction-list{padding:0 14px 10px}.request{border-bottom:1px solid #f2f4f8;align-items:center;padding:9px 0;font-size:10.5px;display:grid}.request span,.request small,.muted{color:#64748b}.review-head,.review-transaction{width:100%;color:inherit;text-align:left;border:0;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.review-head.resolved,.review-transaction.resolved{grid-template-columns:minmax(0,1fr) minmax(80px,.8fr)}.review-transaction{background:0 0;border-bottom:1px solid #f2f4f8;padding:8px 0;font-size:10.5px}.review-transaction span{gap:2px;min-width:0;display:grid}.review-transaction b{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.review-transaction small{color:#64748b;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.review-transaction em{color:#111827;white-space:nowrap;font-style:normal;font-weight:800}.muted{text-align:center;margin:0;padding:14px 0 16px;font-size:11px}.inline-empty{padding-left:0}.login{background:var(--bg);place-items:center;min-height:100vh;padding:18px;display:grid}.login form{border:1px solid var(--border);width:min(410px,100%);box-shadow:var(--shadow);background:#fff;border-radius:12px;gap:14px;padding:28px;display:grid}.login h1{letter-spacing:-.04em;margin:0;font-size:30px}.login p{color:#64748b;margin:0}.login input,.modal-card input,.modal-card textarea{color:#0f172a;background:#fff;border:1px solid #e5e7eb;border-radius:10px;outline:none;min-height:40px;padding:0 12px}.error,pre{color:var(--danger);white-space:pre-wrap}.modal-backdrop{z-index:20;background:#0f172a5c;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;gap:14px;width:min(560px,100%);max-height:min(92vh,760px);padding:22px;display:grid;overflow:auto;box-shadow:0 24px 80px #0f172a3d}.modal-card.review-modal{width:min(1196px,100vw - 32px)}.modal-card h2{letter-spacing:-.02em;margin:0;font-size:16px;font-weight:800}.modal-card label{color:#475569;letter-spacing:.06em;text-transform:uppercase;gap:6px;font-size:12px;font-weight:800;display:grid}.modal-card textarea{resize:vertical;min-height:82px;padding-top:10px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.modal-actions{grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px;display:grid}.modal-actions button:disabled{opacity:.45;cursor:not-allowed}.modal-actions button[type=submit],.login button{color:#fff;background:#5b3ff2;border-color:#5b3ff2}.modal-actions .danger{color:#dc2626;background:#fee2e2;border-color:#fee2e2}.deleted-list{gap:8px;display:grid}.deleted-row{border:1px solid #e5e7eb;border-radius:14px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.deleted-row span{gap:3px;display:grid}.deleted-row small{color:#64748b}.transaction-detail{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.transaction-detail div{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;gap:4px;padding:10px 12px;display:grid}.transaction-detail span{color:#64748b;letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:800}.transaction-detail b{overflow-wrap:anywhere}.inline-note{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;padding:12px}.category-actions{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:18px;display:grid}.category-group{grid-template-rows:auto minmax(0,1fr);gap:7px;min-width:0;display:grid}.category-group>b{color:#475569;letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid #e5e7eb;padding-bottom:8px;font-size:11px}.category-group div{gap:2px;max-height:220px;padding-right:6px;display:grid;overflow-y:auto}.category-group button{color:#334155;text-align:left;background:0 0;border:0;border-bottom:1px solid #eef0f4;padding:8px 2px;font-weight:500}.category-group button.selected{color:#0f172a;padding-left:10px;font-weight:700;box-shadow:inset 3px 0 #4f46e5}@media (width<=1220px){.page{width:calc(100vw - 232px)}.dashboard-grid>.sheet-panel:first-child,.dashboard-grid>.sheet-panel:nth-child(2),.dashboard-grid>.sheet-panel:nth-child(3),.dashboard-grid>.sheet-panel:nth-child(8),.dashboard-grid>.sheet-panel:nth-child(9),.dashboard-grid>.sheet-panel:nth-child(10){grid-column:span 6;height:auto;min-height:260px}.dashboard-grid>.sheet-panel:nth-child(4),.dashboard-grid>.sheet-panel:nth-child(5),.dashboard-grid>.sheet-panel:nth-child(6),.dashboard-grid>.sheet-panel:nth-child(7){grid-column:span 6}.balance-chart,.spending-chart{grid-column:1/-1}.bottom-three{grid-template-columns:1fr}}@media (width<=860px){.sidebar{display:none}.page{width:100%;margin-left:0;padding:18px}.topbar{grid-template-columns:1fr}.toolbar{flex-wrap:wrap;justify-content:flex-start}.dashboard-grid>.sheet-panel,.dashboard-grid>.chart-panel{min-height:220px;grid-column:1/-1!important;height:auto!important}.breakdown-visual,.category-actions,.transaction-detail,.form-grid{grid-template-columns:1fr}}@media (width<=640px){.sheet-row,.sheet-row.with-left,.sheet-row.with-action{grid-template-columns:1fr auto}.sheet-row.with-left em,.sheet-head{display:none}.request-head,.request{grid-template-columns:1fr}}
