:root{--teal: #0ABFA3;--teal-dim: #089683;--bg: #0B1120;--bg-card: #131D30;--bg-input: #1A2540;--stroke: rgba(255,255,255,.08);--text: #E8ECF4;--text-muted: #7A889E;--red: #EF4444;--amber: #F59E0B;--green: #10B981;--radius: 14px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom:env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;font-size:16px}body{height:100%;background:var(--bg);color:var(--text);font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}#app{height:100%;display:flex;flex-direction:column}.nav-bar{display:flex;align-items:center;justify-content:space-around;padding:8px 0 calc(8px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--stroke);flex-shrink:0}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 16px;border-radius:10px;cursor:pointer;background:none;border:none;color:var(--text-muted);font-size:11px;font-family:inherit;transition:color .15s}.nav-tab svg{width:22px;height:22px}.nav-tab.active{color:var(--teal)}.screen{flex:1;overflow:hidden;display:none;flex-direction:column}.screen.active{display:flex}.auth-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:24px}.auth-logo{width:72px;height:72px}.auth-title{font-size:26px;font-weight:700;text-align:center}.auth-sub{font-size:14px;color:var(--text-muted);text-align:center;line-height:1.5}.auth-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--stroke);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:16px}.field-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.field-input{width:100%;background:var(--bg-input);border:1px solid var(--stroke);border-radius:10px;padding:12px 14px;color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:border-color .15s}.field-input:focus{border-color:var(--teal)}.btn{width:100%;padding:14px;border-radius:12px;border:none;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s}.btn:active{opacity:.8}.btn-primary{background:var(--teal);color:#fff}.btn-ghost{background:transparent;color:var(--teal);border:1px solid var(--teal)}.auth-error{color:var(--red);font-size:13px;text-align:center;min-height:18px}.chat-header{display:flex;align-items:center;gap:12px;padding:calc(12px + var(--safe-top)) 16px 12px;background:var(--bg-card);border-bottom:1px solid var(--stroke);flex-shrink:0}.chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--teal),#087aad);display:flex;align-items:center;justify-content:center;font-size:18px}.chat-name{font-weight:700;font-size:16px}.chat-sub{font-size:12px;color:var(--text-muted)}.chat-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.msg{display:flex;flex-direction:column;max-width:82%}.msg.user{align-self:flex-end}.msg.grace{align-self:flex-start}.bubble{padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5}.msg.user .bubble{background:var(--teal);color:#fff;border-bottom-right-radius:4px}.msg.grace .bubble{background:var(--bg-card);border:1px solid var(--stroke);border-bottom-left-radius:4px}.msg-time{font-size:11px;color:var(--text-muted);margin-top:3px;padding:0 4px}.msg.user .msg-time{text-align:right}.card-bubble{background:var(--bg-card);border:1px solid var(--stroke);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px;border-bottom-left-radius:4px}.card-tag{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;width:fit-content}.tag-confirmed{background:#10b98126;color:var(--green)}.tag-warning{background:#f59e0b26;color:var(--amber)}.card-num{color:var(--teal);font-weight:700}.card-bold{font-weight:700}.chat-input-row{display:flex;align-items:flex-end;gap:10px;padding:12px 16px calc(12px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--stroke);flex-shrink:0}.chat-input{flex:1;background:var(--bg-input);border:1px solid var(--stroke);border-radius:22px;padding:10px 16px;color:var(--text);font-size:15px;font-family:inherit;outline:none;resize:none;max-height:120px;transition:border-color .15s;line-height:1.4}.chat-input:focus{border-color:var(--teal)}.chat-send{width:44px;height:44px;border-radius:50%;background:var(--teal);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;flex-shrink:0}.chat-send:active{opacity:.8}.chat-send svg{width:20px;height:20px;fill:#fff}.typing-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:dot .9s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes dot{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.screen-header{display:flex;align-items:center;justify-content:space-between;padding:calc(16px + var(--safe-top)) 16px 12px;background:var(--bg);border-bottom:1px solid var(--stroke);flex-shrink:0}.screen-title{font-size:20px;font-weight:700}.tx-list{flex:1;overflow-y:auto}.tx-day-header{padding:10px 16px 4px;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg);position:sticky;top:0}.tx-row{display:flex;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid var(--stroke)}.tx-icon{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px}.tx-icon.sale{background:#0abfa31f}.tx-icon.purchase{background:#ef44441f}.tx-icon.expense{background:#f59e0b1f}.tx-icon.income{background:#10b9811f}.tx-body{flex:1;min-width:0}.tx-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.tx-amt{font-size:15px;font-weight:700;flex-shrink:0}.tx-amt.pos{color:var(--teal)}.tx-amt.neg{color:var(--red)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);padding:32px}.empty-icon{font-size:48px;opacity:.4}.empty-text{font-size:15px;text-align:center;line-height:1.5}.reports-scroll{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.summary-card{background:var(--bg-card);border:1px solid var(--stroke);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:6px}.summary-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:28px;font-weight:800;color:var(--teal)}.summary-sub{font-size:13px;color:var(--text-muted)}.period-tabs{display:flex;background:var(--bg-card);border:1px solid var(--stroke);border-radius:12px;padding:4px;gap:4px}.period-tab{flex:1;padding:8px 0;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.period-tab.active{background:var(--teal);color:#fff}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric-card{background:var(--bg-card);border:1px solid var(--stroke);border-radius:var(--radius);padding:14px}.metric-label{font-size:12px;color:var(--text-muted);margin-bottom:6px}.metric-val{font-size:20px;font-weight:800}.metric-val.green{color:var(--green)}.metric-val.red{color:var(--red)}.settings-scroll{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.settings-section-header{font-size:12px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:12px 0 4px}.settings-row{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--stroke);border-radius:var(--radius);padding:14px 16px}.settings-icon{font-size:20px;flex-shrink:0}.settings-body{flex:1}.settings-row-title{font-size:15px;font-weight:600}.settings-row-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.settings-arrow{color:var(--text-muted);font-size:18px}.danger{color:var(--red)}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--stroke);border-radius:24px;padding:10px 20px;font-size:14px;font-weight:600;z-index:999;white-space:nowrap;animation:toastIn .25s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}}
