:root{--blue: #2563eb;--blue-soft: #dbeafe;--green: #16a34a;--green-soft: #dcfce7;--orange: #ea580c;--orange-soft: #ffedd5;--red: #dc2626;--red-soft: #fee2e2;--bg: #f6f7f9;--surface: #ffffff;--text: #1e293b;--muted: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 4px 12px rgba(15, 23, 42, .05);--radius: 18px;--radius-sm: 12px}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--text: #f1f5f9;--muted: #94a3b8;--border: #334155;--blue-soft: #1e3a5f;--green-soft: #143521;--orange-soft: #3d2410;--red-soft: #3d1515;--shadow: 0 1px 3px rgba(0, 0, 0, .4)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;font-size:16px;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input,select{font:inherit;color:inherit}.app{max-width:520px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 16px 8px}.topbar h1{font-size:1.4rem;letter-spacing:-.02em}.accent{color:var(--blue)}.topbar-actions{display:flex;gap:4px}.content{flex:1;padding:8px 16px 24px}.page{display:flex;flex-direction:column;gap:14px}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.hero{text-align:center;padding:24px 16px}.hero.compact{padding:18px 16px}.hero-amount{font-size:2.6rem;font-weight:800;letter-spacing:-.03em;color:var(--green);margin:4px 0 10px}.hero-amount.neg{color:var(--red)}.hero-unit{font-size:1rem;font-weight:500;color:var(--muted)}.hero-sub{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 16px;font-size:.85rem;color:var(--muted);margin-bottom:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mini{text-align:center;padding:12px 6px}.mini-icon{font-size:1.3rem}.mini-amount{font-weight:700;font-size:.95rem}.green{color:var(--green)}.orange{color:var(--orange)}.section-title{font-size:1rem;font-weight:700;margin-bottom:8px}.section-head{display:flex;justify-content:space-between;align-items:baseline}section{display:flex;flex-direction:column;gap:8px}.bill-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-left:4px solid transparent}.bill-row.st-paid{border-left-color:var(--green)}.bill-row.st-soon{border-left-color:var(--orange)}.bill-row.st-late{border-left-color:var(--red)}.bill-row.st-upcoming{border-left-color:var(--blue)}.bill-icon{font-size:1.4rem}.bill-info{flex:1;display:flex;flex-direction:column;min-width:0}.bill-info strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bill-amount{white-space:nowrap}.bill-actions{display:flex;align-items:center;gap:2px}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:11px 18px;font-weight:600;transition:transform .06s ease,opacity .15s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn-full{width:100%;margin-top:8px}.btn-small{padding:7px 14px;font-size:.85rem}.btn-paid{background:var(--green-soft);border-color:var(--green);color:var(--green)}.btn-link{background:none;border:none;color:var(--blue);font-weight:600;font-size:.85rem}.btn-icon{background:none;border:none;font-size:1.05rem;padding:8px;border-radius:50%;line-height:1}.btn-icon:hover{background:var(--bg)}.btn-icon.danger{opacity:.55}.btn-icon.danger:hover{opacity:1}.bottomnav{position:fixed;bottom:0;left:0;right:0;max-width:520px;margin:0 auto;display:flex;align-items:center;justify-content:space-around;background:var(--surface);border-top:1px solid var(--border);padding:8px 4px calc(8px + env(safe-area-inset-bottom));z-index:50}.navbtn{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.7rem;font-weight:600;color:var(--muted);padding:4px 10px;border-radius:var(--radius-sm)}.navbtn.active{color:var(--blue)}.navicon{font-size:1.25rem}.fab{width:54px;height:54px;border-radius:50%;background:var(--blue);color:#fff;border:none;font-size:1.8rem;font-weight:300;line-height:1;box-shadow:0 4px 14px #2563eb73;margin-top:-22px}.alert{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:var(--radius-sm);font-size:.9rem;line-height:1.45}.alert-danger{background:var(--red-soft)}.alert-warn{background:var(--orange-soft)}.alert-info{background:var(--blue-soft)}.alert-ok{background:var(--green-soft)}.tight-mode{background:var(--orange-soft);border:1px solid var(--orange)}.tight-mode h3{margin-bottom:6px}.tight-mode p{font-size:.92rem;line-height:1.5}.info-strip{display:flex;gap:10px;align-items:center;padding:12px 14px;font-size:.9rem}.info-strip.good{background:var(--green-soft)}.gauge-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted);margin-bottom:4px}.gauge-track{height:10px;background:var(--bg);border-radius:99px;overflow:hidden}.gauge-fill{height:100%;border-radius:99px;transition:width .4s ease}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:fadeIn .15s ease}.modal{background:var(--surface);width:100%;max-width:520px;max-height:88dvh;overflow-y:auto;border-radius:24px 24px 0 0;padding:18px 18px calc(18px + env(safe-area-inset-bottom));animation:slideUp .2s ease}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-head h2{font-size:1.15rem}@keyframes fadeIn{0%{opacity:0}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}}.addmenu{background:var(--surface);width:100%;max-width:520px;border-radius:24px 24px 0 0;padding:22px 18px calc(22px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px;animation:slideUp .2s ease}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field-label{font-size:.82rem;font-weight:600;color:var(--muted)}.field input,.field select{border:1.5px solid var(--border);background:var(--bg);border-radius:var(--radius-sm);padding:12px 14px;outline:none}.field input:focus,.field select:focus{border-color:var(--blue)}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.check{display:flex;align-items:center;gap:10px;margin:6px 0 14px;font-size:.92rem}.check input{width:18px;height:18px;accent-color:var(--blue)}.chip-grid{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1.5px solid var(--border);background:var(--bg);border-radius:999px;padding:8px 13px;font-size:.85rem;color:var(--text)}.chip.on{background:var(--blue);border-color:var(--blue);color:#fff}.seg{display:flex;background:var(--surface);border-radius:999px;padding:4px;box-shadow:var(--shadow);overflow-x:auto}.seg-btn{flex:1;border:none;background:none;padding:9px 10px;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--muted);white-space:nowrap}.seg-btn.on{background:var(--blue);color:#fff}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:12px}.cal-head{text-align:center;font-size:.7rem;font-weight:700;color:var(--muted);padding:4px 0}.cal-day{aspect-ratio:1;border:none;background:var(--bg);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:.82rem;color:var(--text)}.cal-day.today{outline:2px solid var(--blue);font-weight:800}.cal-day.sel{background:var(--blue-soft)}.cal-dots{display:flex;gap:2px;height:5px}.cal-dots i,.cal-legend i{width:5px;height:5px;border-radius:50%;display:inline-block}.cal-legend{display:flex;gap:12px;justify-content:center;margin-top:12px;flex-wrap:wrap}.cal-legend i{width:8px;height:8px;margin-right:4px}.cap{text-transform:capitalize}.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}.donut-total{font-size:1.05rem;font-weight:800;fill:var(--text)}.donut-sub{font-size:.7rem;fill:var(--muted)}.legend{list-style:none;width:100%;display:flex;flex-direction:column;gap:6px}.legend li{display:flex;align-items:center;gap:8px;font-size:.88rem}.legend li strong{margin-left:auto}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.compare-bars{display:flex;flex-direction:column;gap:12px;margin-top:10px}.compare-row{display:grid;grid-template-columns:110px 1fr 52px;gap:10px;align-items:center}.compare-label{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compare-tracks{display:flex;flex-direction:column;gap:3px}.bar{height:8px;border-radius:99px;min-width:2px}.bar.prev{background:var(--border)}.bar.curr{background:var(--blue)}.compare-delta{font-size:.75rem;font-weight:700;text-align:right}.compare-delta.up{color:var(--orange)}.compare-delta.down{color:var(--green)}.trend{display:flex;gap:6px;align-items:flex-end;height:130px;margin-top:14px}.trend-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.trend-value{font-size:.62rem;color:var(--muted);font-weight:700}.trend-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.trend-bar{width:70%;max-width:34px;border-radius:6px 6px 2px 2px;background:var(--border);transition:height .4s ease}.trend-bar.now{background:var(--blue)}.trend-label{font-size:.68rem;color:var(--muted);text-transform:capitalize}.red{color:var(--red)}.proj-result{text-align:center;margin:14px 0 10px}.proj-amount{font-size:1.9rem;font-weight:800;color:var(--blue);margin:4px 0;letter-spacing:-.02em}.scan-btn{display:flex;align-items:center;justify-content:center;gap:8px}.scan-items{list-style:none;display:flex;flex-direction:column;gap:6px;margin:10px 0;max-height:32dvh;overflow-y:auto}.scan-items li{display:flex;align-items:center;gap:8px}.scan-items input{border:1.5px solid var(--border);background:var(--bg);border-radius:8px;padding:7px 10px;min-width:0}.scan-items input.item-label{flex:1}.scan-items input.item-price{width:84px;text-align:right}.scan-status{display:flex;align-items:center;gap:10px;padding:14px;justify-content:center;color:var(--muted)}.spinner{width:18px;height:18px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.top-products{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:10px}.top-products li{display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-items:center}.top-products .tp-bar{grid-column:1 / -1;height:6px;border-radius:99px;background:var(--blue);min-width:4px}.top-products .tp-label{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.goal-card{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.goal-head{display:flex;justify-content:space-between;align-items:center}.goal-meta{display:flex;justify-content:space-between}.goal-actions{display:flex;gap:8px}.chat{display:flex;flex-direction:column;gap:8px;max-height:40dvh;overflow-y:auto;padding:4px 0 10px}.bubble{max-width:85%;padding:10px 14px;border-radius:16px;font-size:.9rem;line-height:1.5;white-space:pre-line}.bubble.bot{background:var(--bg);align-self:flex-start;border-bottom-left-radius:4px}.bubble.user{background:var(--blue);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.quick-questions{display:flex;gap:8px;overflow-x:auto;padding:8px 0}.quick-questions .chip{flex-shrink:0}.chat-input{display:flex;gap:8px;margin-top:8px}.chat-input input{flex:1;border:1.5px solid var(--border);background:var(--bg);border-radius:999px;padding:11px 16px;outline:none}.chat-input input:focus{border-color:var(--blue)}.onboarding{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,var(--blue-soft),var(--bg) 55%)}.onboarding-card{background:var(--surface);border-radius:24px;box-shadow:var(--shadow);padding:30px 24px;width:100%;max-width:420px;text-align:center}.onboarding-card h1{font-size:1.7rem;margin-bottom:4px}.onboarding-card .field{text-align:left}.onboarding-logo{font-size:2.4rem}.steps-dots{display:flex;gap:8px;justify-content:center;margin:18px 0 20px}.dot-step{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.dot-step.on{background:var(--blue)}.muted{color:var(--muted)}.small{font-size:.8rem}.center{text-align:center}.sep{border:none;border-top:1px solid var(--border);margin:18px 0}.empty{text-align:center;padding:60px 24px;display:flex;flex-direction:column;align-items:center;gap:10px}.empty-icon{font-size:3rem}@media (min-width: 720px){html{font-size:17px}.content{padding:12px 20px 32px}}
