:root,:root[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-raised: #283548;--border: rgba(51, 65, 85, .5);--text: #e2e8f0;--text-secondary: #94a3b8;--accent: #2dd4bf;--accent-contrast: #0f172a;--ok: #4ade80;--warn: #facc15;--warn-contrast: #0f172a;--danger: #f87171;--bar-track: #334155;--income: #4ade80;--expense: #f87171;--savings: #2dd4bf;--shadow: 0 8px 24px rgba(0, 0, 0, .4)}:root[data-theme=light]{--bg: #f8fafc;--surface: #ffffff;--surface-raised: #ffffff;--border: rgba(148, 163, 184, .35);--text: #0f172a;--text-secondary: #64748b;--accent: #0d9488;--accent-contrast: #ffffff;--ok: #16a34a;--warn: #ca8a04;--warn-contrast: #ffffff;--danger: #dc2626;--bar-track: #e2e8f0;--income: #16a34a;--expense: #dc2626;--savings: #0d9488;--shadow: 0 8px 24px rgba(15, 23, 42, .08)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.5}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}.app-main{padding:24px 32px 96px;max-width:1200px;width:100%;margin:0 auto;min-width:0}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.sidebar-title{font-size:18px;font-weight:700;padding:0 12px 12px;letter-spacing:-.02em}.sidebar .btn-primary{margin:0 8px 16px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);font-size:14.5px;text-align:left;width:100%}.nav-item:hover{background:color-mix(in srgb,var(--text) 6%,transparent);color:var(--text)}.nav-item.active{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);font-weight:600}.nav-label{flex:1}.badge{background:var(--danger);color:#fff;font-size:11px;font-weight:700;border-radius:999px;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.badge-dot{width:8px;height:8px;border-radius:999px;background:var(--warn)}.tabbar,.fab{display:none}@media(max-width:768px){.app{grid-template-columns:1fr}.sidebar{display:none}.app-main{padding:16px 16px 96px}.tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:40}.tabbar .nav-item{flex-direction:column;gap:2px;font-size:10.5px;padding:8px 2px 10px;justify-content:center;position:relative}.tabbar .badge{position:absolute;top:4px;right:50%;transform:translate(16px)}.fab{display:flex;position:fixed;right:16px;bottom:72px;width:56px;height:56px;border-radius:999px;background:var(--accent);color:var(--accent-contrast);border:none;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:41}}.btn{border-radius:8px;border:1px solid var(--border);background:var(--surface-raised);color:var(--text);padding:8px 14px;font-size:14px;display:inline-flex;align-items:center;gap:6px;justify-content:center}.btn:hover{border-color:var(--text-secondary)}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast);font-weight:600}.btn-primary:hover{filter:brightness(1.08);border-color:var(--accent)}.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn-sm{padding:4px 10px;font-size:13px;border-radius:6px}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text);border-color:transparent;background:color-mix(in srgb,var(--text) 6%,transparent)}.icon-btn{background:transparent;border:none;color:var(--text-secondary);padding:4px;border-radius:6px;display:inline-flex}.icon-btn:hover{color:var(--text);background:color-mix(in srgb,var(--text) 8%,transparent)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;margin:0;letter-spacing:-.02em}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px}.card-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 12px;display:flex;justify-content:space-between;align-items:center;gap:8px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.grid-2{grid-template-columns:1fr}}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}@media(max-width:900px){.kpi-row{grid-template-columns:repeat(2,1fr)}}.kpi-label{font-size:12.5px;color:var(--text-secondary);margin-bottom:4px}.kpi-value{font-size:21px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.kpi-value.positive{color:var(--ok)}.kpi-value.negative{color:var(--danger)}.progress{background:var(--bar-track);border-radius:999px;height:10px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .2s ease}.progress-fill.ok{background:var(--ok)}.progress-fill.warning{background:var(--warn)}.progress-fill.over{background:var(--danger)}.progress-fill.accent{background:var(--accent)}.chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;border-radius:999px;padding:2px 9px;white-space:nowrap}.chip-neutral{background:color-mix(in srgb,var(--text-secondary) 18%,transparent);color:var(--text)}.chip-ok{background:color-mix(in srgb,var(--ok) 22%,transparent);color:var(--ok)}.chip-warn{background:var(--warn);color:var(--warn-contrast)}.chip-danger{background:color-mix(in srgb,var(--danger) 25%,transparent);color:var(--danger)}.row-list{display:flex;flex-direction:column}.row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--border)}.row:last-child{border-bottom:none}.row.clickable{cursor:pointer;border-radius:8px;padding-left:8px;padding-right:8px}.row.clickable:hover{background:color-mix(in srgb,var(--text) 5%,transparent)}.row-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.row-main{flex:1;min-width:0}.row-title{font-size:14.5px;font-weight:500}.row-sub{font-size:12.5px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-amount{font-variant-numeric:tabular-nums;font-weight:600;font-size:14.5px;white-space:nowrap}.amount-expense{color:var(--expense)}.amount-income{color:var(--income)}.amount-savings{color:var(--savings)}.day-heading{font-size:12.5px;font-weight:600;color:var(--text-secondary);text-transform:capitalize;margin:16px 0 2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061799;display:flex;align-items:flex-start;justify-content:center;padding:8vh 16px 16px;z-index:50;overflow-y:auto}.modal{background:var(--surface-raised);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);width:100%;max-width:480px;padding:20px}.modal-title{margin:0 0 16px;font-size:17px;font-weight:700}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}.modal-actions .spacer{flex:1}.field{margin-bottom:14px}.field-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.input{width:100%;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:15px}.input:focus{outline:2px solid var(--accent);outline-offset:0;border-color:transparent}.input-amount{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.input-suffix{position:relative}.input-suffix .suffix{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:14px;pointer-events:none}.field-error{color:var(--danger);font-size:12.5px;margin-top:4px}.segment{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:3px;gap:2px}.segment button{flex:1;border:none;background:transparent;color:var(--text-secondary);padding:7px 10px;border-radius:7px;font-size:13.5px;font-weight:600}.segment button.active{background:var(--accent);color:var(--accent-contrast)}.chip-grid{display:flex;flex-wrap:wrap;gap:6px}.chip-option{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:6px 12px;font-size:13.5px}.chip-option:hover{border-color:var(--text-secondary)}.chip-option.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);font-weight:600}.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:60}.toast{background:var(--surface-raised);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:12px;max-width:380px;font-size:14px}.toast .btn-sm{flex-shrink:0}.banner{display:flex;align-items:center;gap:10px;background:color-mix(in srgb,var(--danger) 14%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 45%,transparent);border-radius:10px;padding:10px 14px;margin-bottom:18px;font-size:14px}.banner.banner-warn{background:color-mix(in srgb,var(--warn) 12%,var(--surface));border-color:color-mix(in srgb,var(--warn) 45%,transparent)}.banner-text{flex:1}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:11.5px;font-weight:600;color:var(--text-secondary);padding:4px 0}.calendar-day{min-height:76px;border:1px solid var(--border);border-radius:8px;padding:4px;font-size:12px;display:flex;flex-direction:column;gap:3px;overflow:hidden}.calendar-day.outside{opacity:.35}.calendar-day.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.calendar-day .day-number{font-size:11.5px;color:var(--text-secondary);font-weight:600}.calendar-bill{border-radius:5px;padding:1px 5px;font-size:10.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;border:none;cursor:pointer}.calendar-bill.state-overdue,.calendar-bill.state-dueToday{background:color-mix(in srgb,var(--danger) 28%,transparent);color:var(--danger)}.calendar-bill.state-dueSoon{background:var(--warn);color:var(--warn-contrast)}.calendar-bill.state-upcoming{background:color-mix(in srgb,var(--text-secondary) 20%,transparent);color:var(--text)}.calendar-bill.state-paid{background:color-mix(in srgb,var(--ok) 22%,transparent);color:var(--ok);text-decoration:line-through}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px}.login-title{font-size:20px;font-weight:700;margin:0 0 2px;letter-spacing:-.02em}.login-card form{margin-top:16px}.login-divider{height:1px;background:var(--border);margin:18px 0 14px}.login-info{background:color-mix(in srgb,var(--accent) 14%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);color:var(--text);border-radius:8px;padding:9px 12px;font-size:13px;margin-bottom:12px}.link-button{background:none;border:none;padding:0;color:var(--accent);font:inherit;font-weight:600;text-decoration:underline;cursor:pointer}.receipt-preview{display:flex;gap:12px;align-items:flex-start}.receipt-thumb{border:1px solid var(--border);border-radius:8px;padding:0;background:var(--surface);overflow:hidden;width:72px;height:72px;flex-shrink:0;cursor:pointer}.receipt-thumb img{width:72px;height:72px;object-fit:cover;display:block}.receipt-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617d9;display:flex;align-items:center;justify-content:center;z-index:70;padding:24px;cursor:zoom-out}.lightbox img{max-width:100%;max-height:100%;border-radius:8px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:36px 20px;color:var(--text-secondary)}.empty-icon{font-size:34px;margin-bottom:8px}.empty p{margin:0 0 14px;font-size:14.5px}.month-picker{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:15px}.month-picker .label{min-width:130px;text-align:center;text-transform:capitalize}.muted{color:var(--text-secondary)}.small{font-size:12.5px}.flex{display:flex;align-items:center;gap:8px}.flex-between{display:flex;align-items:center;justify-content:space-between;gap:8px}.stack{display:flex;flex-direction:column;gap:12px}.section-title{font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:20px 0 8px}.section-title.danger{color:var(--danger)}
