@import "https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700;14..32,800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--bg-primary:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--bg-card2:#f1f5f9;--bg-inset:#f1f5f9;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--border-color:#e2e8f0;--border-light:#eef2ff;--accent:#4f46e5;--accent-dark:#4338ca;--accent-light:#eef2ff;--success:#10b981;--success-dark:#059669;--danger:#ef4444;--danger-dark:#dc2626;--warning:#f59e0b;--info:#3b82f6;--purple:#8b5cf6;--pink:#ec4899;--teal:#14b8a6;--orange:#f97316;--shadow-xs:0 1px 2px #00000008;--shadow-sm:0 1px 3px #0000000d, 0 1px 2px #00000008;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 15px -3px #0000000d, 0 4px 6px -2px #00000005;--shadow-xl:0 20px 25px -5px #0000000d, 0 10px 10px -5px #00000003;--shadow-glow:0 0 0 2px #4f46e533;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--font-display:"Plus Jakarta Sans", sans-serif;--font-body:"Inter", sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.2s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary:#0f172a;--bg-card:#1e293b;--bg-card-hover:#334155;--bg-card2:#1e293b;--bg-inset:#0f172a;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--border-color:#334155;--border-light:#1e293b;--accent-light:#1e1b4b;--shadow-xs:0 1px 2px #0003;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background var(--transition-normal), color var(--transition-normal);line-height:1.5}.app-container{background:var(--bg-primary);max-width:480px;min-height:100vh;transition:background var(--transition-normal);flex-direction:column;margin:0 auto;display:flex;position:relative}@media (width>=768px){.app-container{max-width:560px;box-shadow:var(--shadow-xl);border-radius:var(--radius-2xl);min-height:calc(100vh - 48px);margin:24px auto;overflow:hidden}}.auth-screen{background:linear-gradient(145deg,#0f172a 0%,#1e1b4b 45%,#312e81 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-bg-orb{filter:blur(80px);opacity:.25;pointer-events:none;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.auth-bg-orb-1{background:#6366f1;width:320px;height:320px;animation-delay:0s;top:-120px;right:-100px}.auth-bg-orb-2{background:#ec4899;width:240px;height:240px;animation-delay:-5s;bottom:40px;left:-80px}.auth-bg-orb-3{background:#14b8a6;width:180px;height:180px;animation-delay:-10s;top:40%;left:20%}@keyframes float{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(15px,-15px)rotate(5deg)}66%{transform:translate(-10px,10px)rotate(-3deg)}}.auth-logo{font-family:var(--font-display);background:linear-gradient(135deg,#fff,#c7d2fe);color:#0000;letter-spacing:-1px;z-index:2;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:3rem;font-weight:800;position:relative}.auth-tagline{color:#fff9;text-align:center;z-index:2;margin-bottom:40px;font-size:.85rem;position:relative}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-2xl);z-index:2;background:#ffffff0d;border:1px solid #ffffff1a;width:100%;max-width:400px;padding:32px 28px;position:relative;box-shadow:0 25px 50px -12px #00000040}.auth-tabs{border-radius:var(--radius-md);background:#00000040;gap:4px;margin-bottom:28px;padding:4px;display:flex}.auth-tab{border-radius:var(--radius-sm);color:#ffffff80;cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:700;font-family:var(--font-body);background:0 0;border:none;flex:1;padding:12px}.auth-tab.active{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1f}.auth-input{border-radius:var(--radius-md);color:#fff;width:100%;font-size:.9rem;font-family:var(--font-body);transition:all var(--transition-fast);background:#ffffff0f;border:1.5px solid #ffffff1f;outline:none;margin-bottom:14px;padding:14px 16px}.auth-input::placeholder{color:#ffffff59}.auth-input:focus{background:#ffffff1a;border-color:#ffffff4d}.auth-btn{border-radius:var(--radius-md);color:#fff;width:100%;font-size:.95rem;font-weight:800;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;margin-bottom:16px;padding:14px;box-shadow:0 4px 14px #6366f166}.auth-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #6366f180}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.auth-divider{color:#ffffff4d;align-items:center;gap:12px;margin:20px 0;font-size:.75rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#ffffff1f;flex:1;height:1px}.google-btn{border-radius:var(--radius-md);color:#fff;width:100%;font-size:.9rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background:#ffffff12;border:1.5px solid #ffffff26;justify-content:center;align-items:center;gap:12px;padding:13px;display:flex}.google-btn:hover:not(:disabled){background:#ffffff1f}.google-btn:disabled{opacity:.7;cursor:not-allowed}.google-icon{color:#4285f4;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:800;display:flex}.auth-error{color:#fca5a5;text-align:center;margin-bottom:12px;font-size:.8rem}.auth-features{z-index:2;grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:500px;margin-top:36px;display:grid;position:relative}.auth-feat{border-radius:var(--radius-md);text-align:center;transition:all var(--transition-fast);background:#ffffff0a;padding:10px 6px}.auth-feat-icon{margin-bottom:4px;font-size:1.3rem}.auth-feat-text{color:#ffffff80;font-size:.65rem;font-weight:600}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border-color);z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-normal);justify-content:space-between;align-items:center;padding:14px 18px;display:flex;position:sticky;top:0}.header-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.3px;font-size:1.15rem;font-weight:800}.header-logo{font-family:var(--font-display);background:linear-gradient(135deg, var(--accent), var(--purple));color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:800}.header-actions{align-items:center;gap:8px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), var(--purple));color:#fff;cursor:pointer;border:2px solid var(--accent-light);width:36px;height:36px;transition:transform var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:800;display:flex}.user-avatar:hover{transform:scale(1.05)}.icon-btn{cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;font-size:1.2rem;display:flex}.icon-btn:hover{background:var(--bg-card-hover);transform:scale(1.05)}.add-btn{background:linear-gradient(135deg, var(--accent), var(--purple));color:#fff;border-radius:var(--radius-md);cursor:pointer;width:38px;height:38px;transition:all var(--transition-fast);box-shadow:var(--shadow-md);border:none;justify-content:center;align-items:center;font-size:1.4rem;font-weight:700;display:flex}.add-btn:hover{box-shadow:var(--shadow-lg);transform:scale(1.05)}.app-content{transition:padding var(--transition-normal);flex:1;padding:16px 16px 90px;overflow-y:auto}.bottom-nav{background:var(--bg-card);border-top:1px solid var(--border-color);z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);width:100%;max-width:480px;transition:all var(--transition-normal);padding:6px 8px 10px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}@media (width>=768px){.bottom-nav{border-radius:0 0 var(--radius-2xl) var(--radius-2xl);max-width:560px}}.nav-item{cursor:pointer;transition:all var(--transition-fast);color:var(--text-muted);font-size:.65rem;font-weight:600;font-family:var(--font-body);border-radius:var(--radius-md);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 4px 6px;display:flex;position:relative}.nav-item.active{color:var(--accent);background:var(--accent-light)}.nav-icon{font-size:1.2rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);margin-bottom:12px;padding:16px}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;font-size:.75rem;font-weight:800}.balance-card{background:linear-gradient(135deg, #1e1b4b 0%, var(--accent) 60%, var(--purple) 100%);border-radius:var(--radius-xl);color:#fff;box-shadow:var(--shadow-lg);margin-bottom:16px;padding:24px 20px;position:relative;overflow:hidden}.balance-card:before{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:280px;height:280px;position:absolute;top:-100px;right:-80px}.balance-card:after{content:"";pointer-events:none;background:#ffffff0a;border-radius:50%;width:160px;height:160px;position:absolute;bottom:-60px;left:-40px}.balance-label{opacity:.75;margin-bottom:6px;font-size:.75rem;font-weight:600}.balance-amount{font-family:var(--font-display);letter-spacing:-1px;margin-bottom:20px;font-size:2.4rem;font-weight:800}.balance-stats{gap:24px;display:flex}.stat-item{flex:1}.stat-label{opacity:.7;margin-bottom:4px;font-size:.65rem}.stat-value{font-size:.95rem;font-weight:800}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px;display:grid}@media (width>=480px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:all var(--transition-fast);padding:12px}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.stat-card-icon{color:var(--text-muted);text-transform:uppercase;margin-bottom:6px;font-size:.7rem;font-weight:800}.stat-card-value{color:var(--text-primary);font-size:1.1rem;font-weight:900}.instant-entry{background:linear-gradient(135deg, var(--accent-light), #4f46e50d);border:2px solid var(--accent);border-radius:var(--radius-xl);transition:all var(--transition-fast);margin-bottom:16px;padding:18px}[data-theme=dark] .instant-entry{background:linear-gradient(135deg,#1e1b4b,#1a1633)}.instant-entry-title{font-family:var(--font-display);color:var(--accent);align-items:center;gap:6px;margin-bottom:12px;font-size:.8rem;font-weight:800;display:flex}.instant-type-pills{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.instant-pill{cursor:pointer;font-size:.7rem;font-weight:700;font-family:var(--font-body);transition:all var(--transition-fast);border:none;border-radius:24px;padding:6px 12px}.instant-cats{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.instant-cat{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);cursor:pointer;font-size:.7rem;font-weight:600;font-family:var(--font-body);transition:all var(--transition-fast);border-radius:24px;padding:5px 10px}.instant-cat.active{background:var(--accent);color:#fff;border-color:var(--accent)}.instant-row{align-items:center;gap:10px;margin-top:8px;display:flex}.instant-amount{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:1rem;font-weight:800;font-family:var(--font-body);transition:all var(--transition-fast);outline:none;flex:1;padding:12px 14px}.instant-amount:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.instant-note{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-card);width:100%;color:var(--text-primary);font-size:.85rem;font-family:var(--font-body);transition:all var(--transition-fast);outline:none;margin-top:10px;padding:10px 14px}.instant-note:focus{border-color:var(--accent)}.instant-go{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent), var(--purple));color:#fff;font-size:.85rem;font-weight:800;font-family:var(--font-body);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);border:none;padding:12px 20px}.instant-go:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.form-group{margin-bottom:16px}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.7rem;font-weight:800;display:block}.form-input,.form-select{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);transition:all var(--transition-fast);font-size:.9rem;font-family:var(--font-body);outline:none;padding:12px 14px}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.form-input-lg{padding:14px;font-size:1.1rem;font-weight:800}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);width:100%;font-size:.9rem;font-weight:800;font-family:var(--font-body);border:none;margin-top:8px;padding:14px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:var(--success-dark);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-dark)}.btn-outline{border:1.5px solid var(--border-color);color:var(--text-primary);background:0 0}.btn-outline:hover{background:var(--bg-card-hover)}.btn-small{border-radius:var(--radius-sm);cursor:pointer;width:auto;font-size:.72rem;font-weight:700;font-family:var(--font-body);transition:all var(--transition-fast);border:none;padding:8px 14px}.badge{border-radius:20px;padding:4px 10px;font-size:.68rem;font-weight:800;display:inline-block}.badge-expense{color:#ef4444;background:#ef44441a}.badge-income{color:#10b981;background:#10b9811a}.badge-borrow{color:#3b82f6;background:#3b82f61a}.badge-lend{color:#f59e0b;background:#f59e0b1a}.type-tabs{background:var(--bg-card2);border-radius:var(--radius-md);gap:8px;margin-bottom:20px;padding:6px;display:flex}.type-tab{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:700;font-family:var(--font-body);color:var(--text-muted);background:0 0;border:none;flex:1;padding:10px}.type-tab.active{background:var(--bg-card);color:var(--accent);box-shadow:var(--shadow-sm)}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-top:8px;display:grid}.cat-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);font-size:.75rem;font-weight:600;font-family:var(--font-body);color:var(--text-secondary);padding:8px 12px}.cat-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tx-item{cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px;display:flex}.tx-item:hover{background:var(--bg-card-hover)}.tx-emoji{border-radius:var(--radius-md);background:var(--bg-card2);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex}.tx-details{flex:1;min-width:0}.tx-cat{color:var(--text-primary);font-size:.88rem;font-weight:800}.tx-note{color:var(--text-muted);margin-top:2px;font-size:.7rem}.tx-amount{flex-shrink:0;font-size:.9rem;font-weight:900}.tx-amount-expense,.tx-amount-lend{color:var(--danger)}.tx-amount-income,.tx-amount-borrow{color:var(--success)}.filter-bar{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);margin-bottom:16px;padding:14px}.filter-pill{border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);font-size:.7rem;font-weight:700;font-family:var(--font-body);color:var(--text-muted);background:0 0;border-radius:24px;padding:6px 12px}.filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.progress-bar{background:var(--border-color);border-radius:3px;height:6px;margin:8px 0;overflow:hidden}.progress-fill{height:100%;transition:width var(--transition-normal);border-radius:3px}.progress-fill-success{background:var(--success)}.progress-fill-primary{background:var(--accent)}.progress-fill-warning{background:var(--warning)}.progress-fill-danger{background:var(--danger)}.month-chip{cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;font-size:.7rem;font-weight:700;font-family:var(--font-body);border-radius:24px;padding:6px 12px}.month-paid{background:var(--success);color:#fff}.month-overdue{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.month-upcoming{background:var(--bg-card2);color:var(--text-muted);border:1px solid var(--border-color)}.credit-card{border-radius:var(--radius-lg);color:#fff;min-height:140px;box-shadow:var(--shadow-md);margin-bottom:16px;padding:20px;position:relative;overflow:hidden}.credit-card:before{content:"";background:#ffffff14;border-radius:50%;width:200px;height:200px;position:absolute;top:-70px;right:-60px}.credit-card:after{content:"";background:#ffffff0d;border-radius:50%;width:120px;height:120px;position:absolute;bottom:-50px;left:20px}.credit-card-network{opacity:.8;margin-bottom:16px;font-size:.7rem}.credit-card-number{letter-spacing:2px;margin-bottom:12px;font-size:1rem;font-weight:800}.credit-card-name{font-size:.85rem;font-weight:700}.shopping-item{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:10px 0;display:flex}.shopping-checkbox{border:2px solid var(--border-color);cursor:pointer;width:22px;height:22px;transition:all var(--transition-fast);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shopping-checkbox.checked{background:var(--success);border-color:var(--success)}.shopping-item-details{flex:1}.shopping-item-name{font-size:.85rem;font-weight:700}.shopping-item-name.checked{color:var(--text-muted);text-decoration:line-through}.shopping-item-price{color:var(--text-muted);margin-top:2px;font-size:.7rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;animation:fadeIn var(--transition-fast) ease;background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=540px){.modal-overlay{align-items:center}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:480px;max-height:85vh;animation:slideUp var(--transition-normal) ease;padding:24px 20px 32px;overflow-y:auto}@media (width>=540px){.modal-content{border-radius:var(--radius-xl);max-width:480px;margin:20px}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-handle{background:var(--border-color);border-radius:2px;width:40px;height:4px;margin:0 auto 20px}.toast{z-index:1000;box-shadow:var(--shadow-lg);pointer-events:none;white-space:nowrap;animation:toastIn var(--transition-fast) ease;font-size:.8rem;font-weight:700;font-family:var(--font-body);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:40px;padding:12px 22px;position:fixed;top:20px;left:50%;transform:translate(-50%)}@media (width<=480px){.toast{white-space:normal;text-align:center;max-width:90%}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--info);color:#fff}.user-menu{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:50;min-width:200px;animation:slideDown var(--transition-fast) ease;padding:8px;position:absolute;top:65px;right:14px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary);align-items:center;gap:10px;padding:10px 14px;font-size:.85rem;font-weight:600;display:flex}.user-menu-item:hover{background:var(--bg-card-hover)}.user-menu-item.danger{color:var(--danger)}.voice-btn{background:linear-gradient(135deg, var(--danger), var(--orange));color:#fff;cursor:pointer;width:44px;height:44px;transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.voice-btn.recording{animation:1s infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.splash-screen{background:linear-gradient(160deg,#0f172a 0%,#1e1b4b 40%,#312e81 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.splash-logo{font-family:var(--font-display);background:linear-gradient(135deg,#fff,#c7d2fe);color:#0000;letter-spacing:-2px;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:3.5rem;font-weight:800}.splash-sub{color:#ffffff80;font-size:.85rem}.splash-dots{gap:8px;margin-top:48px;display:flex}.splash-dot{background:#ffffff4d;border-radius:50%;width:8px;height:8px;animation:1.4s infinite dotPulse}.splash-dot:nth-child(2){animation-delay:.2s}.splash-dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.3;transform:scale(1)}40%{opacity:1;transform:scale(1.4)}}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-col{flex-direction:column;display:flex}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-right{text-align:right}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=480px){.app-content{padding:12px 12px 85px}.balance-card{padding:18px}.balance-amount{font-size:1.8rem}.balance-stats{flex-wrap:wrap;gap:12px}.stat-item{min-width:70px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.instant-row{flex-direction:column}.instant-go{width:100%}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr))}.tx-emoji{width:38px;height:38px;font-size:1rem}.tx-cat,.tx-amount{font-size:.8rem}}@media (width>=481px) and (width<=768px){.stats-grid{grid-template-columns:repeat(3,1fr)}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-card{background:var(--bg-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-xl);padding:28px 36px}.loading-icon{margin-bottom:12px;font-size:2rem;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:.85rem;font-weight:800}.pwa-install-btn{z-index:9999;cursor:pointer;color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border:none;border-radius:14px;outline:none;padding:14px 22px;font-size:14px;font-weight:600;transition:all .3s;position:fixed;bottom:20px;right:20px;box-shadow:0 10px 30px #00000040}.pwa-install-btn:hover{transform:translateY(-3px);box-shadow:0 15px 35px #0000004d}@media (width<=768px){.pwa-install-btn{text-align:center;border-radius:12px;width:calc(100% - 32px);padding:16px;bottom:16px;right:16px}}
