@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@500;600&display=swap";@layer components,utilities;@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--page:#f6f7fb;--sidebar:#fff;--sidebar-muted:#6b7280;--surface:#fff;--surface-muted:#f6f7fb;--ink:#1a1a2e;--muted:#6b7280;--line:#eceef3;--line-strong:#dfe2ea;--accent:#7c3aed;--income:#059669;--income-soft:#ecfdf5;--expense:#dc2626;--expense-soft:#fef2f2;--balance:#7c3aed;--balance-soft:#f3effe;--savings:#7c3aed;--savings-soft:#f3effe;--shadow:0 1px 3px #1018280f, 0 1px 2px #1018280a;--radius:8px;--font-sans:"Inter", sans-serif;--font-mono:"IBM Plex Mono", monospace;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--ink);font-family:var(--font-sans);background:radial-gradient(circle at top left, #7c3aed0d, transparent 38vw), var(--page);margin:0}button,input,select{font:inherit}button{cursor:pointer}#root{min-height:100vh}.app-shell{grid-template-columns:276px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{height:100vh;color:var(--ink);background:var(--sidebar);border-right:1px solid var(--line);flex-direction:column;gap:22px;padding:22px;display:flex;position:sticky;top:0}.brand-block{border-bottom:1px solid #94a3b838;align-items:center;gap:12px;padding-bottom:18px;display:flex}.brand-mark{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#7c3aed,#d946ef);place-items:center;width:42px;height:42px;font-weight:800;display:grid}.brand-block strong,.brand-block small{display:block}.brand-block small,.sidebar-card p,.sidebar-card span{color:var(--sidebar-muted)}.side-nav{gap:6px;display:grid}.side-nav button{border-radius:var(--radius);width:100%;color:var(--muted);background:0 0;border:0;align-items:center;gap:10px;padding:11px 12px;font-size:.92rem;font-weight:700;text-decoration:none;transition:color .16s,background .16s;display:flex}.side-nav button:hover,.side-nav button.is-active{color:var(--accent);background:var(--balance-soft)}.sidebar-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-muted);margin-top:auto;padding:16px}.sidebar-card span,.sidebar-card p{font-size:.82rem;line-height:1.45}.sidebar-card strong{margin:8px 0;font-size:1.05rem;display:block}.app-content{align-content:start;gap:18px;width:min(100%,1520px);padding:22px;display:grid}.app-topbar,.metrics-panel,.metric-card,.panel-card,.transactions-panel,.activity-panel,.modal-card,.notice{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.app-topbar{justify-content:space-between;align-items:center;gap:18px;padding:16px 18px;display:flex}.app-topbar h1,.section-heading h2{letter-spacing:0;color:var(--ink);margin:0}.app-topbar h1{margin-top:3px;font-size:clamp(1.55rem,2.5vw,2.15rem);line-height:1}.header-period{color:var(--muted);margin:8px 0 0;font-size:.92rem;font-weight:700}.header-controls,.filters-bar{flex-wrap:wrap;justify-content:flex-end;align-items:end;gap:10px;display:flex}.eyebrow,.field-group span{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.7rem;font-weight:800}.notice{padding:12px 16px;font-weight:700}.notice.is-error{color:var(--expense);background:var(--expense-soft);border-color:#fecaca}.notice.is-success{color:var(--income);background:var(--income-soft);border-color:#bbf7d0}.metric-card span,.signal-card span{color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;font-size:.72rem;font-weight:700}.progress-track{background:#edeef3;border-radius:999px;height:8px;overflow:hidden}.workspace-grid{grid-template-columns:1fr;align-items:start;gap:18px;display:grid}.metrics-panel{padding:18px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.metric-card{min-height:128px;box-shadow:none;padding:14px}.metric-card strong{margin-top:14px;font-size:clamp(1.35rem,2vw,1.95rem);line-height:1;display:block}.metric-card p{color:var(--muted);margin:12px 0 0;font-size:.9rem}.metric-topline{justify-content:space-between;align-items:center;gap:10px;display:flex}.metric-topline svg{color:var(--muted)}.metric-card.is-income{background:var(--income-soft);border-color:#05966938}.metric-card.is-expense{background:var(--expense-soft);border-color:#dc26262e}.metric-card.is-balance{background:var(--balance-soft);border-color:#7c3aed33}.metric-card.is-savings{background:var(--savings-soft);border-color:#7c3aed33}.chart-grid{grid-template-columns:1fr;align-items:start;gap:18px;display:grid}.chart-card{min-height:360px}.chart-frame{min-width:0;height:274px}.recharts-default-tooltip{border:1px solid var(--line)!important;border-radius:var(--radius)!important;color:var(--ink)!important;background:#fff!important;box-shadow:0 8px 24px #1018281a!important}.analytics-grid{grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:start;gap:18px;display:grid}.panel-card,.transactions-panel,.activity-panel,.modal-card{padding:18px}.section-heading{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}.section-heading h2{margin-top:4px;font-size:clamp(1.05rem,1.5vw,1.35rem);line-height:1}.section-heading>span{border:1px solid var(--line);background:var(--surface-muted);color:var(--muted);font-family:var(--font-mono);white-space:nowrap;border-radius:999px;padding:7px 10px;font-size:.76rem}.category-stack{gap:10px;display:grid}.category-row{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-muted);padding:12px}.category-row-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.category-row-top span,.transaction-row strong,.category-list-row strong{font-weight:750}.category-row small,.transaction-row small,.category-list-row small,.activity-item small{color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;margin-top:5px;font-size:.72rem;display:block}.progress-track{margin-top:10px}.progress-fill{border-radius:inherit;height:100%}.tone-forest{background:var(--income)}.tone-accent{background:var(--expense)}.tone-neutral{background:var(--balance)}.signal-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.signal-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-muted);min-height:138px;padding:14px}.signal-card strong{margin-top:14px;font-size:clamp(1.25rem,1.8vw,1.7rem);line-height:1;display:block}.signal-card p{color:var(--muted);margin:10px 0 0;font-size:.86rem;line-height:1.4}.transactions-panel{gap:14px;display:grid}.filters-bar{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-muted);justify-content:flex-start;padding:12px}.transactions-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:18px;display:grid}.transactions-table{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden}.transaction-row{border-top:1px solid var(--line);grid-template-columns:1fr auto auto;align-items:center;gap:16px;padding:14px 16px;display:grid}.transaction-row:first-child{border-top:0}.transaction-row:hover{background:var(--surface-muted)}.tx-info{min-width:0}.tx-info strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-weight:750;display:block;overflow:hidden}.tx-info small{color:var(--muted);font-family:var(--font-sans);text-transform:none;margin-top:4px;font-size:.8rem;display:block}.tx-amount{white-space:nowrap;font-size:.98rem;font-weight:750}.amount-income{color:var(--income)}.amount-expense{color:var(--expense)}.activity-panel{box-shadow:none}.compact-heading{margin-bottom:8px}.activity-list{gap:8px;display:grid}.activity-item{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-muted);grid-template-columns:10px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.activity-item strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;display:block;overflow:hidden}.activity-item em{white-space:nowrap;font-size:.82rem;font-style:normal;font-weight:800}.dot-income,.dot-expense{border-radius:999px;width:8px;height:8px}.dot-income{background:var(--income)}.dot-expense{background:var(--expense)}.transaction-form,.category-form,.category-manager{gap:12px;display:grid}.category-list{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);max-height:320px;display:grid;overflow:auto}.category-list-row{border-top:1px solid var(--line);grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.category-list-row:first-child{border-top:0}.field-group{gap:6px;display:grid}.full-field{grid-column:1/-1}.compact-field{min-width:180px}.control-field{border:1px solid var(--line-strong);border-radius:var(--radius);width:100%;min-height:40px;color:var(--ink);background:#fff;outline:none;padding:.62rem .72rem;font-size:.9rem;transition:border-color .16s,box-shadow .16s}.control-field:focus{border-color:var(--balance);box-shadow:0 0 0 3px var(--balance-soft)}.control-field::placeholder{color:#9aa1ad}.form-pair,.form-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.primary-action,.secondary-action,.danger-action{border-radius:var(--radius);letter-spacing:.05em;text-transform:uppercase;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:.62rem .82rem;font-size:.76rem;font-weight:800;transition:transform .16s,opacity .16s,border-color .16s,background .16s;display:inline-flex}.primary-action{border:1px solid var(--accent);background:var(--accent);color:#fff}.primary-action:hover:not(:disabled){background:#6d28d9;border-color:#6d28d9}.secondary-action{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink)}.danger-action{background:var(--expense-soft);color:var(--expense);border:1px solid #fb71854d}.page-section{display:none}.page-section.is-current{display:grid}.page-category-manager{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start}.primary-action:hover:not(:disabled),.secondary-action:hover:not(:disabled),.danger-action:hover:not(:disabled){transform:translateY(-1px)}.primary-action:disabled,.secondary-action:disabled,.danger-action:disabled{cursor:not-allowed;opacity:.55}.row-actions{justify-content:flex-end;gap:8px;display:flex}.compact-action{min-height:32px;padding:.42rem .56rem;font-size:.66rem}.empty-state{color:var(--muted);margin:0;padding:18px;line-height:1.5}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a2e66;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-card{width:min(640px,100%);max-height:calc(100vh - 40px);overflow:auto}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:min(380px,100%);box-shadow:var(--shadow);gap:16px;padding:26px;display:grid}.login-brand{align-items:center;gap:12px;margin-bottom:4px;display:flex}.login-brand strong{font-size:1.1rem;display:block}.login-brand small{color:var(--muted);font-size:.85rem;display:block}.sidebar-logout{border:1px solid var(--line);border-radius:var(--radius);width:100%;color:var(--muted);background:0 0;align-items:center;gap:10px;padding:11px 12px;font-size:.9rem;font-weight:700;transition:color .16s,border-color .16s,background .16s;display:flex}.sidebar-logout:hover{color:var(--expense);background:var(--expense-soft);border-color:#dc262647}.mobile-topbar,.drawer-close,.menu-backdrop{display:none}@media (width<=1240px){.analytics-grid,.chart-grid,.page-category-manager,.transactions-layout{grid-template-columns:1fr}.activity-panel{display:none}}@media (width<=980px){.app-shell{grid-template-columns:1fr}.app-sidebar{height:auto;padding:14px;position:static}.side-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.sidebar-card{display:none}.app-topbar{flex-direction:column;align-items:stretch}.workspace-grid{grid-template-columns:1fr}.header-controls{justify-content:stretch}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.table-header{display:none}.transaction-row{grid-template-columns:1fr;gap:8px}.row-actions{justify-content:flex-start}}@media (width<=640px){.app-content{padding:12px}.side-nav,.metric-grid,.signal-grid,.form-pair,.form-actions,.category-list-row{grid-template-columns:1fr}.filters-bar,.header-controls{flex-direction:column;align-items:stretch}.compact-field{width:100%}}@media (width<=768px){.app-shell{grid-template-columns:1fr}.mobile-topbar{background:var(--accent);color:#fff;z-index:20;align-items:center;gap:10px;height:56px;padding:0 14px;display:flex;position:sticky;top:0}.mobile-menu-toggle{border-radius:var(--radius);color:#fff;background:0 0;border:0;justify-content:center;align-items:center;width:40px;height:40px;margin-left:-8px;display:inline-flex}.mobile-topbar strong{letter-spacing:.01em;font-size:1.05rem;font-weight:700}.app-content{padding:18px 16px calc(22px + env(safe-area-inset-bottom))}.app-topbar{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;flex-direction:column;align-items:stretch;gap:16px;padding:0}.page-title{display:none}.app-sidebar{z-index:40;width:min(280px,84vw);height:100dvh;padding-bottom:calc(22px + env(safe-area-inset-bottom));transition:transform .22s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 10px 40px #1018282e}.app-sidebar.is-open{transform:translate(0)}.side-nav{grid-template-columns:1fr}.drawer-close{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:34px;height:34px;color:var(--muted);justify-content:center;align-items:center;margin-left:auto;display:inline-flex}.menu-backdrop{z-index:35;opacity:0;pointer-events:none;background:#1a1a2e66;transition:opacity .2s;display:block;position:fixed;inset:0}.menu-backdrop.is-open{opacity:1;pointer-events:auto}.primary-action,.secondary-action,.danger-action,.control-field{min-height:44px}.hide-on-mobile{display:none!important}.transaction-row{grid-template-columns:1fr auto;grid-template-areas:"info amount""actions actions";gap:4px 12px;padding:14px}.tx-info{grid-area:info}.tx-amount{grid-area:amount;align-self:center;font-size:1.05rem}.transaction-row .row-actions{grid-area:actions;margin-top:10px}.transaction-row .compact-action{flex:1;min-height:38px}.category-list-row{grid-template-columns:1fr auto;align-items:center}.category-list-row>div:first-child{min-width:0}.category-list-row strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.modal-backdrop{padding:16px}.modal-card{max-height:calc(100dvh - 32px)}}
