@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f8f9fb;--color-surface: #ffffff;--color-surface-2: #f3f4f6;--color-border: #e5e7eb;--color-border-light: #f0f0f0;--color-border-focus: #6366f1;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-light: #eef2ff;--color-primary-text: #3730a3;--color-accent: #4f46e5;--color-text: #111827;--color-text-secondary: #374151;--color-text-muted: #9ca3af;--color-positive: #059669;--color-positive-bg: #ecfdf5;--color-negative: #dc2626;--color-negative-bg: #fef2f2;--color-header-bg: #1e1b4b;--color-header-text: #a5b4fc;--color-row-hover: #f5f3ff;--color-category-bg: #f5f3ff;--color-category-text: #3730a3;--color-category-border: #ddd6fe;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 16px 48px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.06);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}body{font-family:var(--font);font-size:13px;background:var(--color-bg);background-image:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(99,102,241,.08) 0%,transparent 70%);background-attachment:fixed;color:var(--color-text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:var(--font);font-size:13px}input,select,textarea{font-family:var(--font);font-size:13px}.budget-table{width:100%;border-collapse:collapse;font-size:12px;font-variant-numeric:tabular-nums}.budget-table th{background:linear-gradient(180deg,#252160,#1e1b4b);color:#a5b4fc;padding:11px 12px;text-align:right;white-space:nowrap;font-weight:600;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;position:sticky;top:0;z-index:10}.budget-table th:first-child{text-align:left;position:sticky;left:0;z-index:11;background:linear-gradient(180deg,#252160,#1e1b4b)}.budget-table td{padding:6px 12px;text-align:right;border-bottom:1px solid var(--color-border);white-space:nowrap;transition:background .08s}.budget-table td:first-child{text-align:left;position:sticky;left:0;background:var(--color-surface);z-index:5;min-width:170px;max-width:220px;border-right:1px solid var(--color-border-light)}.budget-table tbody tr:last-child td{border-bottom:none}.budget-table tr:hover td,.budget-table tr:hover td:first-child{background:var(--color-row-hover)}.table-scroll{overflow-x:auto;border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow),0 0 0 1px #0000000a}.amount-positive{color:var(--color-positive);font-weight:500}.amount-negative{color:var(--color-negative)}.amount-zero{color:#d1d5db}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:8px;border:1px solid transparent;font-size:12.5px;font-weight:500;transition:all .15s;white-space:nowrap;letter-spacing:.01em}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 3px #4f46e54d}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 3px 10px #4f46e559;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:var(--color-text-secondary);border-color:var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--color-surface-2);border-color:#d1d5db}.btn-danger{background:var(--color-negative);color:#fff;box-shadow:0 1px 3px #dc262640}.btn-danger:hover{background:#b91c1c;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--color-primary);border-color:transparent;padding:4px 8px}.btn-ghost:hover{background:var(--color-primary-light)}.btn-icon{padding:3px 7px;font-size:11px;border-radius:5px}.segment-toggle{display:inline-flex;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:8px;padding:3px;gap:2px}.segment-toggle button{padding:5px 14px;border-radius:6px;border:none;background:transparent;color:var(--color-text-muted);font-size:12px;font-weight:500;transition:all .15s}.segment-toggle button.active{background:#fff;color:var(--color-primary-text);box-shadow:var(--shadow-sm);font-weight:600}.modal-overlay{position:fixed;inset:0;background:#11182780;backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius-lg);padding:28px;min-width:420px;max-width:600px;width:100%;box-shadow:var(--shadow-lg);animation:slide-up .18s cubic-bezier(.16,1,.3,1)}@keyframes slide-up{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:16px;font-weight:700;margin-bottom:20px;color:var(--color-text);letter-spacing:-.01em}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-label{font-size:11px;font-weight:600;color:var(--color-text-secondary);letter-spacing:.06em;text-transform:uppercase}.form-input{padding:8px 11px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;background:#fff;color:var(--color-text)}.form-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #6366f11f}.form-input::placeholder{color:var(--color-text-muted)}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.text-muted{color:var(--color-text-muted)}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-8{gap:8px}.gap-4{gap:4px}.mt-12{margin-top:12px}.mb-12{margin-bottom:12px}.stat-card{background:#fff;border:1px solid rgba(229,231,235,.7);border-top:3px solid var(--card-accent, var(--color-border));border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow)}.stat-card .stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:6px}.stat-card .stat-value{font-size:24px;font-weight:700;letter-spacing:-.04em;color:var(--color-text);line-height:1.1}.row-category td{background:var(--color-category-bg)!important;font-weight:600;color:var(--color-primary-text)!important;border-bottom:1px solid var(--color-category-border)!important;cursor:pointer}.row-category:hover td{background:#ede9fe!important}.row-category td:first-child{background:var(--color-category-bg)!important}.row-category:hover td:first-child{background:#ede9fe!important}.row-section td{background:#f8fafc!important;font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;border-top:2px solid #e2e8f0!important;border-bottom:1px solid #e2e8f0!important}.row-section td:first-child{background:#f8fafc!important}.row-forskel td{background:var(--color-positive-bg)!important;font-weight:700;border-top:2px solid #6ee7b7!important}.row-forskel.negative td{background:var(--color-negative-bg)!important;border-top-color:#fca5a5!important}.row-forskel td:first-child{background:inherit!important}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:10.5px;font-weight:600}.badge-income{background:var(--color-positive-bg);color:var(--color-positive)}.badge-expense{background:var(--color-negative-bg);color:var(--color-negative)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 32px;text-align:center;color:var(--color-text-muted);gap:12px}.empty-state .empty-icon{font-size:40px;opacity:.4}.empty-state .empty-title{font-size:15px;font-weight:600;color:var(--color-text-secondary)}.empty-state .empty-desc{font-size:13px;max-width:280px}[data-theme=dark]{--color-bg: #0d0f1a;--color-surface: #161929;--color-surface-2: #1e2238;--color-border: #2a2f4a;--color-border-light: #232640;--color-border-focus: #818cf8;--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: #1e1b4b;--color-primary-text: #a5b4fc;--color-accent: #818cf8;--color-text: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-muted: #64748b;--color-positive: #34d399;--color-positive-bg: #064e3b33;--color-negative: #f87171;--color-negative-bg: #7f1d1d33;--color-row-hover: #1e2238;--color-category-bg: #1e1b4b55;--color-category-text: #a5b4fc;--color-category-border: #312e8166;--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow: 0 4px 12px rgba(0,0,0,.4), 0 1px 3px rgba(0,0,0,.2);--shadow-lg: 0 16px 48px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.3)}[data-theme=dark] body{background-image:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(99,102,241,.12) 0%,transparent 70%)}[data-theme=dark] .btn-secondary{background:var(--color-surface-2);color:var(--color-text-secondary);border-color:var(--color-border)}[data-theme=dark] .btn-secondary:hover{background:var(--color-surface)}[data-theme=dark] .btn-ghost:hover{background:var(--color-primary-light)}[data-theme=dark] .form-input{background:var(--color-surface-2);color:var(--color-text);border-color:var(--color-border)}[data-theme=dark] .modal,[data-theme=dark] .stat-card{background:var(--color-surface)}[data-theme=dark] .segment-toggle button.active{background:var(--color-surface);color:var(--color-primary-text)}[data-theme=dark] .budget-table td:first-child{background:var(--color-surface)}[data-theme=dark] .budget-table tr:hover td:first-child{background:var(--color-row-hover)}[data-theme=dark] .row-section td{background:#1a1d2e!important;color:#94a3b8;border-top-color:var(--color-border)!important;border-bottom-color:var(--color-border)!important}[data-theme=dark] .row-section td:first-child{background:#1a1d2e!important}[data-theme=dark] .row-category:hover td,[data-theme=dark] .row-category:hover td:first-child{background:#252960!important}[data-theme=dark] .table-scroll{box-shadow:var(--shadow),0 0 0 1px #ffffff0a}.bottom-nav{display:none}@media(max-width:640px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--color-surface);border-top:1px solid var(--color-border);padding:0;box-shadow:0 -4px 20px #0000001a;safe-area-inset-bottom:env(safe-area-inset-bottom)}.bottom-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px 12px;background:none;border:none;cursor:pointer;transition:color .15s;color:var(--color-text-muted);min-width:0}.bottom-nav-btn.active{color:var(--color-primary)}.bottom-nav-btn.active .bottom-nav-icon{filter:drop-shadow(0 0 4px rgba(99,102,241,.5))}.bottom-nav-icon{font-size:20px;line-height:1;transition:transform .15s}.bottom-nav-btn.active .bottom-nav-icon{transform:translateY(-1px)}.bottom-nav-label{font-size:9.5px;font-weight:500;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bottom-nav-btn.active .bottom-nav-label{font-weight:700}}@media(max-width:640px){.app-header{padding:0 12px!important}.app-main{padding:16px 12px 88px!important}.tab-bar{display:none!important}.modal{min-width:unset!important;width:95vw!important;padding:20px 16px!important}.account-label{display:none!important}.account-select{min-width:0!important;max-width:130px!important}.account-new-text{display:none!important}.stat-card{min-width:0}}
