:root{--color-primary: oklch(.55 .2 260);--color-primary-hover: color-mix(in oklch, var(--color-primary), black 15%);--color-primary-subtle: color-mix(in oklch, var(--color-primary), transparent 88%);--color-bg: oklch(.97 .005 250);--color-surface: #ffffff;--color-border: oklch(.91 .01 250);--color-text: oklch(.15 .02 260);--color-text-muted: oklch(.55 .03 250);--color-income: oklch(.55 .18 155);--color-income-subtle: color-mix(in oklch, var(--color-income), transparent 85%);--color-expense: oklch(.53 .2 25);--color-expense-subtle: color-mix(in oklch, var(--color-expense), transparent 85%);--color-warning: oklch(.6 .17 70);--color-warning-subtle: color-mix(in oklch, var(--color-warning), transparent 85%);--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px oklch(0 0 0 / .08), 0 1px 2px oklch(0 0 0 / .04);--shadow-md: 0 4px 12px oklch(0 0 0 / .1), 0 2px 4px oklch(0 0 0 / .06);--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}:is(h1,h2,h3,h4){font-weight:600;line-height:1.25;text-wrap:balance}h1{font-size:1.625rem}h2{font-size:1.25rem}h3{font-size:1.0625rem}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}p{margin:0}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap;line-height:1.4;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);text-decoration:none}.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);text-decoration:none}.btn-danger{background:var(--color-expense);color:#fff}.btn-danger:hover:not(:disabled){background:color-mix(in oklch,var(--color-expense),black 15%)}.btn-sm{padding:.3rem .625rem;font-size:.8125rem}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--space-xl);container-type:inline-size}.form-group{display:flex;flex-direction:column;gap:.3rem}label{font-size:.8125rem;font-weight:600;color:var(--color-text)}:is(input,select,textarea){width:100%;padding:var(--space-sm) .6875rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);line-height:1.4}:is(input,select,textarea):focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}input::placeholder{color:#9a9fa5}.alert{padding:.6875rem var(--space-lg);border-radius:var(--radius);font-size:.875rem;line-height:1.5;&-error{background:var(--color-expense-subtle);color:#6c1517;border:1px solid color-mix(in oklch,var(--color-expense),transparent 70%)}&-success{background:var(--color-income-subtle);color:#004725;color:oklch(.35 .12 155);border:1px solid color-mix(in oklch,var(--color-income),transparent 70%)}}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:.6875rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;padding:.625rem .875rem;border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:.8125rem .875rem;border-bottom:1px solid var(--color-border);font-size:.875rem;vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:color-mix(in oklch,var(--color-primary),transparent 96%)}.text-income{color:var(--color-income)}.text-expense{color:var(--color-expense)}.text-muted{color:var(--color-text-muted)}.text-right{text-align:right}.font-mono{font-family:SF Mono,Fira Code,Cascadia Mono,Consolas,monospace}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-xl);gap:var(--space-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem var(--space-2xl);gap:var(--space-md);color:var(--color-text-muted)}.empty-state h3{color:var(--color-text);margin-bottom:0}.empty-state p{font-size:.9rem;max-width:360px;text-wrap:pretty}.subtitle{color:var(--color-text-muted);font-size:.9rem;margin-top:.25rem}.form-card{margin-bottom:var(--space-xl)}.form-card h3{margin-bottom:var(--space-lg)}.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.form-actions{display:flex;gap:var(--space-sm)}.summary-bar{display:flex;gap:var(--space-2xl);flex-wrap:wrap;margin-bottom:var(--space-xl)}.summary-item{display:flex;flex-direction:column;gap:var(--space-xs)}.summary-item .summary-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.summary-item .summary-value{font-size:1.25rem;font-weight:700}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--space-lg);container-type:inline-size}.stat-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-xs)}.stat-card .stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.stat-card .stat-value{font-size:1.375rem;font-weight:700}.stat-card .stat-sub{font-size:.8125rem;color:var(--color-text-muted)}@container (max-width: 500px){.stat-grid{grid-template-columns:1fr}}.chart-title{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.health-badge{padding:.2rem .625rem;border-radius:9999px;font-size:.8125rem;font-weight:600}.health-badge.good{background:var(--color-income-subtle);color:var(--color-income)}.health-badge.ok{background:var(--color-primary-subtle);color:var(--color-primary)}.health-badge.warning{background:var(--color-warning-subtle);color:var(--color-warning)}.health-badge.danger{background:var(--color-expense-subtle);color:var(--color-expense)}.row-actions{display:flex;gap:var(--space-xs);justify-content:flex-end}.edit-row td{padding:var(--space-lg);background:color-mix(in oklch,var(--color-primary),transparent 96%)}.auth-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-2xl);width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--space-lg)}.auth-card .auth-logo{display:flex;align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--space-xs)}.auth-card .auth-sub{color:var(--color-text-muted);font-size:.9rem;margin-top:calc(-1 * var(--space-sm))}.btn-block{width:100%;justify-content:center;padding:.625rem var(--space-lg);font-size:.9375rem}.auth-link{text-align:center;font-size:.875rem;color:var(--color-text-muted)}.app-shell.svelte-12qhfyh{display:flex;min-height:100vh}.sidebar.svelte-12qhfyh{width:230px;flex-shrink:0;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;height:100vh;z-index:200;transition:transform .2s ease}.sidebar-header.svelte-12qhfyh{padding:1.25rem 1rem;border-bottom:1px solid var(--color-border)}.logo.svelte-12qhfyh{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:var(--color-primary);letter-spacing:-.02em}.sidebar-nav.svelte-12qhfyh{flex:1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-link.svelte-12qhfyh{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;transition:background .15s,color .15s}.nav-link.svelte-12qhfyh:hover{background:var(--color-bg);color:var(--color-text);text-decoration:none}.nav-link.active.svelte-12qhfyh{background:#eff6ff;color:var(--color-primary)}.sidebar-footer.svelte-12qhfyh{padding:.75rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem}.user-info.svelte-12qhfyh{display:flex;align-items:center;gap:.625rem;padding:.375rem .25rem}.user-avatar.svelte-12qhfyh{width:30px;height:30px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;flex-shrink:0}.user-details.svelte-12qhfyh{min-width:0}.user-name.svelte-12qhfyh{font-size:.8125rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email.svelte-12qhfyh{font-size:.75rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn.svelte-12qhfyh{width:100%;justify-content:center;color:var(--color-text-muted)}.mobile-header.svelte-12qhfyh{display:none;position:fixed;top:0;left:0;right:0;height:52px;background:var(--color-surface);border-bottom:1px solid var(--color-border);align-items:center;justify-content:space-between;padding:0 1rem;z-index:150}.hamburger.svelte-12qhfyh{background:none;border:none;cursor:pointer;padding:6px;color:var(--color-text);border-radius:var(--radius)}.hamburger.svelte-12qhfyh:hover{background:var(--color-bg)}.overlay.svelte-12qhfyh{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:190}.main-content.svelte-12qhfyh{margin-left:230px;flex:1;padding:2rem 2.5rem;max-width:1330px;container-type:inline-size;container-name:main}.auth-shell.svelte-12qhfyh{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}@media (max-width: 768px){.sidebar.svelte-12qhfyh{transform:translate(-100%)}.sidebar.open.svelte-12qhfyh{transform:translate(0)}.mobile-header.svelte-12qhfyh{display:flex}.main-content.svelte-12qhfyh{margin-left:0;padding:1rem;padding-top:calc(52px + 1rem)}}
