/* BUDGET PRO 2026 - FULL FEATURES */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{--bg:#0a0a0f;--card:rgba(255,255,255,0.03);--border:rgba(255,255,255,0.08);--text:#fff;--dim:rgba(255,255,255,0.6);--muted:rgba(255,255,255,0.3);--accent:#8b5cf6;--accent2:#06b6d4;--green:#10b981;--red:#ef4444;--orange:#f59e0b;--gradient:linear-gradient(135deg,var(--accent),var(--accent2))}
html,body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}

/* SPLASH */
.splash-screen{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s}
.splash-screen.hidden{opacity:0;pointer-events:none}
.splash-content{text-align:center}
.splash-logo{width:100px;height:100px;margin:0 auto 20px;position:relative}
.logo-coin{font-size:4rem;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.splash-title{font-size:2.5rem;font-weight:900;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.splash-tagline{color:var(--dim);margin:10px 0 30px}
.splash-loader{width:180px;height:4px;background:var(--border);border-radius:2px;margin:0 auto;overflow:hidden}
.loader-bar{height:100%;background:var(--gradient);animation:load 2s forwards}
@keyframes load{to{width:100%}}
.version-tag{margin-top:20px;font-size:.8rem;color:var(--accent)}

/* ONBOARDING */
.onboarding{position:fixed;inset:0;z-index:9998;background:var(--bg);display:none;flex-direction:column;padding:50px 30px 30px}
.onboarding.active{display:flex}
.onboard-slides{flex:1;position:relative}
.onboard-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;opacity:0;transition:opacity .4s}
.onboard-slide.active{opacity:1}
.onboard-slide h2{font-size:1.6rem;margin:20px 0 10px}
.onboard-slide p{color:var(--dim);max-width:280px}
.onboard-dots{display:flex;justify-content:center;gap:8px;margin:20px 0}
.dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}
.dot.active{width:25px;border-radius:4px;background:var(--accent)}
.onboard-actions{display:flex;justify-content:space-between}
.skip-btn{padding:15px 30px;background:0;border:0;color:var(--dim);font-size:1rem}
.next-btn{padding:15px 35px;background:var(--gradient);border:0;border-radius:50px;color:#fff;font-weight:600;box-shadow:0 10px 30px rgba(139,92,246,.4)}

/* BACKGROUND */
.bg-3d{position:fixed;inset:0;z-index:-2}
.bg-grid{position:absolute;inset:-50%;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;transform:perspective(500px) rotateX(60deg);animation:grid 20s linear infinite}
@keyframes grid{to{transform:perspective(500px) rotateX(60deg) translateY(50px)}}
.bg-glow{position:fixed;border-radius:50%;filter:blur(80px);animation:glow 15s ease-in-out infinite}
.glow-1{width:300px;height:300px;background:var(--accent);top:-5%;left:-5%;opacity:.2}
.glow-2{width:200px;height:200px;background:var(--accent2);bottom:10%;right:-5%;opacity:.15;animation-delay:-7s}
@keyframes glow{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}

/* GLASS */
.glass-card{background:var(--card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:18px}
.glass-card-3d{background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.02));backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 20px 40px rgba(0,0,0,.3)}

/* SCREENS */
.screen{display:none;min-height:100vh;padding:20px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:100px}
.screen.active{display:block;animation:fadeIn .4s}
@keyframes fadeIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* PROFILE SCREEN */
.profile-screen .screen-content{max-width:450px;margin:0 auto;padding-top:50px}
.profile-header{text-align:center;margin-bottom:40px}
.gradient-text{font-size:2.2rem;font-weight:900;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.subtitle{color:var(--dim);margin-top:8px}
.profiles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.profile-card{padding:20px 10px;text-align:center;cursor:pointer;transition:transform .2s}
.profile-card:active{transform:scale(.95)}
.profile-avatar{width:55px;height:55px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin:0 auto 10px;box-shadow:0 8px 25px rgba(0,0,0,.3)}
.profile-name{font-size:.85rem;font-weight:600}
.add-profile{border:2px dashed var(--border);background:0}
.add-icon{width:55px;height:55px;border-radius:50%;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 10px;color:var(--dim)}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all .3s;padding:20px}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{width:100%;max-width:400px;padding:25px;text-align:center;transform:scale(.9);transition:transform .3s}
.modal-overlay.active .modal{transform:scale(1)}
.modal-large{max-width:450px;max-height:85vh;overflow-y:auto}
.modal-fullscreen{max-width:100%;max-height:100%;height:100%;width:100%;border-radius:0;padding:0;display:flex;flex-direction:column}
.modal h2{font-size:1.5rem;margin-bottom:25px;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}
.modal p{color:var(--dim);font-size:.9rem;line-height:1.5}
.modal-icon{font-size:2.5rem;margin-bottom:10px}
.modal-actions{display:flex;gap:10px;margin-top:20px}
.modal-actions button{flex:1}

/* PIN */
.pin-container{display:flex;gap:10px;justify-content:center;margin-bottom:15px}
.pin-digit{width:50px;height:58px;background:rgba(255,255,255,.05);border:2px solid var(--border);border-radius:12px;font-size:1.6rem;text-align:center;color:var(--text);transition:all .2s}
.pin-digit:focus{outline:0;border-color:var(--accent);box-shadow:0 0 15px rgba(139,92,246,.3)}
.pin-digit.filled{background:rgba(139,92,246,.2);border-color:var(--accent)}
.pin-error{color:var(--red);font-size:.85rem;display:none}
.pin-error.show{display:block;animation:shake .5s}
@keyframes shake{25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}

/* AVATAR & COLOR */
.avatar-grid,.color-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:15px 0}
.avatar-opt{width:45px;height:45px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.4rem;cursor:pointer;transition:all .2s}
.avatar-opt.selected{border-color:var(--accent);transform:scale(1.1)}
.color-opt{width:32px;height:32px;border-radius:50%;background:var(--c);cursor:pointer;border:3px solid transparent;transition:all .2s}
.color-opt.selected{border-color:#fff;transform:scale(1.15)}

/* BUTTONS */
.btn-primary{padding:14px 25px;background:var(--gradient);border:0;border-radius:12px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 8px 25px rgba(139,92,246,.3)}
.btn-primary:active{transform:scale(.95)}
.btn-secondary{padding:14px 25px;background:0;border:1px solid var(--border);border-radius:12px;color:var(--dim);font-size:.95rem;cursor:pointer}
.input-modern{width:100%;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:.95rem;margin-bottom:12px}
.input-modern:focus{outline:0;border-color:var(--accent)}
.form-row{display:flex;gap:10px}
.form-row>*{flex:1}

/* APP HEADER */
.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;margin-bottom:15px}
.header-profile{display:flex;align-items:center;gap:10px;cursor:pointer}
.profile-avatar-small{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.header-info{display:flex;flex-direction:column}
.header-name{font-weight:600;font-size:.9rem}
.header-level{font-size:.7rem;color:var(--accent)}
.header-actions{display:flex;gap:8px}
.icon-btn{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--border);font-size:1.1rem;cursor:pointer;position:relative}
.icon-btn .badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;background:var(--red);border-radius:8px;font-size:.65rem;color:#fff;display:flex;align-items:center;justify-content:center}
.ai-glow{animation:aiGlow 2s infinite}
@keyframes aiGlow{0%,100%{box-shadow:0 0 5px rgba(139,92,246,.5)}50%{box-shadow:0 0 20px rgba(139,92,246,.8)}}

/* DAILY REWARD */
.daily-reward{display:flex;align-items:center;gap:12px;padding:12px 15px;margin-bottom:15px;cursor:pointer;background:linear-gradient(135deg,rgba(245,158,11,.2),rgba(236,72,153,.2));border-color:rgba(245,158,11,.3)}
.daily-reward.claimed{display:none}
.reward-icon{font-size:1.5rem;animation:bounce 1s infinite}
.reward-text{flex:1;font-weight:600}
.reward-xp{background:var(--orange);padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700}

/* AI INPUT */
.ai-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;margin-bottom:15px}
.ai-badge{background:var(--gradient);padding:4px 8px;border-radius:15px;font-size:.65rem;font-weight:700}
.ai-input{flex:1;background:0;border:0;color:var(--text);font-size:.9rem;padding:8px 0}
.ai-input:focus{outline:0}
.ai-input::placeholder{color:var(--muted)}
.ai-btn{width:36px;height:36px;border-radius:50%;border:0;background:rgba(255,255,255,.1);font-size:1rem;cursor:pointer}
.ai-btn.primary{background:var(--accent)}
.ai-btn:active{transform:scale(.9)}

/* BALANCE CARD */
.balance-card{padding:20px;margin-bottom:15px}
.balance-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.balance-top span{color:var(--dim);font-size:.85rem}
.currency-select{background:rgba(255,255,255,.1);border:1px solid var(--border);border-radius:8px;padding:5px 8px;color:var(--text);font-size:.75rem}
.balance-amount{font-size:2.4rem;font-weight:900;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:15px}
.balance-stats{display:flex;justify-content:space-around;margin-bottom:15px}
.balance-stats .stat{text-align:center}
.balance-stats .stat span{font-size:.75rem;color:var(--dim);display:block}
.balance-stats .stat strong{font-size:1rem}
.balance-stats .income strong{color:var(--green)}
.balance-stats .expense strong{color:var(--red)}
.budget-progress{padding-top:15px;border-top:1px solid var(--border)}
.budget-info{display:flex;justify-content:space-between;font-size:.8rem;margin-bottom:8px}
.budget-info span:first-child{color:var(--dim)}
.budget-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.budget-fill{height:100%;background:var(--gradient);border-radius:3px;transition:width .5s}

/* PREDICTION */
.prediction-card{display:flex;align-items:center;gap:12px;padding:12px 15px;margin-bottom:15px}
.prediction-icon{font-size:1.8rem}
.prediction-content{flex:1}
.prediction-label{font-size:.7rem;color:var(--accent);display:block}
.prediction-text{font-size:.85rem}

/* QUICK ACTIONS */
.quick-actions{display:flex;gap:8px;margin-bottom:15px;overflow-x:auto;padding:3px}
.quick-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 15px;background:var(--card);border:1px solid var(--border);border-radius:12px;font-size:.7rem;color:var(--dim);white-space:nowrap;cursor:pointer}
.quick-btn span:first-child{font-size:1.3rem}
.quick-btn:active{background:rgba(139,92,246,.2);transform:scale(.95)}

/* CHALLENGE */
.challenge-card{padding:15px;margin-bottom:15px}
.challenge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.challenge-header span:first-child{font-weight:600}
.challenge-reward{background:var(--green);padding:3px 8px;border-radius:10px;font-size:.7rem}
.challenge-text{font-size:.85rem;color:var(--dim);margin-bottom:10px}
.challenge-progress{display:flex;align-items:center;gap:10px}
.challenge-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.challenge-fill{height:100%;background:var(--green);border-radius:3px}
#challengeStatus{font-size:.75rem;color:var(--dim)}

/* GAMIFICATION */
.gamification-bar{display:flex;align-items:center;gap:12px;padding:12px 15px;margin-bottom:15px}
.streak-info{display:flex;align-items:center;gap:4px}
.streak-fire{font-size:1.2rem;animation:fire 1s infinite}
@keyframes fire{50%{transform:scale(1.2)}}
.streak-count{font-size:1.2rem;font-weight:800;color:var(--orange)}
.streak-info span:last-child{font-size:.7rem;color:var(--dim)}
.level-progress{flex:1}
.level-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:3px}
.level-fill{height:100%;background:var(--gradient);border-radius:3px}
#xpText{font-size:.65rem;color:var(--dim)}
.badges-btn{width:36px;height:36px;background:rgba(245,158,11,.2);border:0;border-radius:50%;font-size:1.1rem;cursor:pointer}

/* TABS */
.tab-bar{display:flex;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:4px;margin-bottom:15px}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 5px;background:0;border:0;border-radius:10px;color:var(--dim);font-size:.7rem;cursor:pointer}
.tab span:first-child{font-size:1rem}
.tab.active{background:var(--gradient);color:#fff}
.tab-content{display:none}
.tab-content.active{display:block;animation:fadeIn .3s}

/* TRANSACTIONS */
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.section-header h3{font-size:1rem}
.filter-chips{display:flex;gap:6px}
.chip{padding:6px 12px;background:var(--card);border:1px solid var(--border);border-radius:15px;color:var(--dim);font-size:.75rem;cursor:pointer}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.transactions-list{display:flex;flex-direction:column;gap:8px}
.transaction-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--card);border:1px solid var(--border);border-radius:12px}
.txn-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:rgba(255,255,255,.05)}
.txn-info{flex:1;min-width:0}
.txn-desc{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.txn-meta{font-size:.7rem;color:var(--dim)}
.txn-amount{font-weight:700}
.txn-amount.income{color:var(--green)}
.txn-amount.expense{color:var(--red)}
.empty-state{text-align:center;padding:40px;color:var(--dim)}

/* CHARTS */
.chart-card{padding:15px;margin-bottom:12px}
.chart-card h4{font-size:.9rem;margin-bottom:12px}
.chart-container{height:180px}
.ai-report{display:flex;align-items:center;gap:10px;padding:15px;cursor:pointer}
.ai-report span:first-child{font-size:1.3rem}
.ai-report span:last-child{margin-left:auto;color:var(--accent)}

/* ACCOUNTS */
.accounts-list,.splits-list{display:flex;flex-direction:column;gap:10px}
.account-card{display:flex;align-items:center;gap:12px;padding:15px;cursor:pointer}
.account-icon{font-size:1.5rem}
.account-info{flex:1}
.account-info strong{display:block;font-size:.9rem}
.account-info span{font-size:.75rem;color:var(--dim)}
.account-balance{font-weight:700;color:var(--green)}
.add-account{justify-content:center;border:2px dashed var(--border);background:0}
.split-card{padding:15px;cursor:pointer;text-align:center}

/* MORE */
.more-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.more-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;cursor:pointer}
.more-item span:first-child{font-size:1.8rem}
.more-item span:last-child{font-size:.8rem;color:var(--dim)}

/* ADD MODAL */
.type-toggle{display:flex;gap:8px;margin-bottom:20px}
.type-btn{flex:1;padding:12px;border:2px solid var(--border);border-radius:10px;background:0;color:var(--dim);font-size:.9rem;cursor:pointer}
.type-btn.expense.active{background:rgba(239,68,68,.2);border-color:var(--red);color:var(--red)}
.type-btn.income.active{background:rgba(16,185,129,.2);border-color:var(--green);color:var(--green)}
.amount-input-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.currency-symbol{font-size:1.8rem;color:var(--dim);margin-right:5px}
.amount-input{width:140px;font-size:2.5rem;font-weight:800;background:0;border:0;color:var(--text);text-align:center}
.amount-input:focus{outline:0}
.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:15px}
.cat-opt{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 5px;background:var(--card);border:2px solid var(--border);border-radius:10px;font-size:.65rem;color:var(--dim);cursor:pointer}
.cat-opt span:first-child{font-size:1.3rem}
.cat-opt.selected{border-color:var(--accent);background:rgba(139,92,246,.2);color:var(--text)}

/* SPLIT */
.split-people{display:flex;flex-direction:column;gap:8px}
.split-person{display:flex;gap:8px;align-items:center}
.split-person input{flex:1}
.split-person span{font-size:1.2rem}
.split-result{margin-top:15px;padding:15px;background:rgba(16,185,129,.1);border-radius:12px;text-align:left}
.split-result p{margin:5px 0;font-size:.9rem}

/* REMINDERS */
.reminders-list{display:flex;flex-direction:column;gap:10px;margin-bottom:15px;text-align:left}
.reminder-item{display:flex;align-items:center;gap:12px;padding:12px}
.reminder-icon{font-size:1.5rem}
.reminder-info{flex:1}
.reminder-info strong{display:block}
.reminder-info span{font-size:.75rem;color:var(--dim)}
.reminder-amount{font-weight:700}

/* BUDGET LIMITS */
.budget-limits{text-align:left}
.limit-item{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.limit-item span{width:100px;font-size:.85rem}
.limit-item input{flex:1;padding:10px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;color:var(--text)}

/* AI CHAT */
.ai-chat-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--border);padding-top:max(15px,env(safe-area-inset-top))}
.ai-chat-title{display:flex;align-items:center;gap:10px}
.ai-avatar{font-size:1.8rem;width:40px;height:40px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center}
.ai-chat-title h3{font-size:1rem;margin:0}
.ai-status{font-size:.7rem;color:var(--green)}
.close-btn{width:36px;height:36px;border-radius:50%;border:0;background:rgba(255,255,255,.1);color:var(--text);font-size:1.1rem;cursor:pointer}
.ai-chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:12px}
.ai-message,.user-message{display:flex;gap:8px;max-width:85%}
.user-message{align-self:flex-end;flex-direction:row-reverse}
.msg-avatar{width:30px;height:30px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:1rem}
.msg-bubble{background:var(--card);border:1px solid var(--border);border-radius:15px;padding:10px 14px;font-size:.9rem;line-height:1.5}
.user-message .msg-bubble{background:var(--accent)}
.ai-suggestions{display:flex;flex-wrap:wrap;gap:6px}
.ai-suggestions button{padding:8px 12px;background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.3);border-radius:15px;color:var(--text);font-size:.8rem;cursor:pointer}
.ai-chat-input{display:flex;gap:8px;padding:12px 15px;border-top:1px solid var(--border);padding-bottom:max(12px,env(safe-area-inset-bottom))}
.ai-chat-input input{flex:1;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:.9rem}
.ai-chat-input button{width:44px;height:44px;border-radius:50%;border:0;background:var(--gradient);color:#fff;font-size:1.2rem;cursor:pointer}

/* SMS PARSER */
textarea.input-modern{resize:none}
.sms-result{margin-top:15px;padding:15px;background:rgba(139,92,246,.1);border-radius:12px;text-align:left}

/* NOTIFICATIONS */
.notif-list{text-align:left;margin-bottom:15px}
.notif-item{padding:12px;border-bottom:1px solid var(--border)}
.notif-item:last-child{border:0}
.notif-time{font-size:.7rem;color:var(--dim)}

/* BADGES */
.badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.badge-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:15px;background:var(--card);border-radius:12px;opacity:.4}
.badge-item.earned{opacity:1;background:linear-gradient(145deg,rgba(139,92,246,.2),rgba(6,182,212,.2))}
.badge-icon{font-size:1.8rem}
.badge-item span:last-child{font-size:.7rem;color:var(--dim)}

/* VOICE */
.voice-anim{position:relative;width:80px;height:80px;margin:0 auto 15px}
.voice-ring{position:absolute;inset:0;border:3px solid var(--accent);border-radius:50%;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.5}}
.voice-anim>span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem}
.voice-hint{font-size:.8rem;color:var(--dim)}
.voice-result{font-size:1rem;color:var(--accent);min-height:25px;margin-top:10px}

/* CAMERA */
.camera-preview{width:100%;aspect-ratio:4/3;background:#000;border-radius:12px;overflow:hidden}
.camera-preview video{width:100%;height:100%;object-fit:cover}

/* AI PROCESSING */
.ai-processing{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:5000;opacity:0;visibility:hidden;transition:all .3s}
.ai-processing.show{opacity:1;visibility:visible}
.ai-proc-content{text-align:center}
.ai-thinking{width:70px;height:70px;margin:0 auto 15px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;animation:think 1s infinite}
@keyframes think{50%{transform:scale(1.1)}}
.ai-proc-content p{font-size:1rem}

/* TOAST */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(80px);display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--green);border-radius:25px;color:#fff;font-weight:500;opacity:0;transition:all .3s;z-index:2000}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.error{background:var(--red)}

/* ACHIEVEMENT */
.achievement-popup{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:3000;opacity:0;visibility:hidden;background:rgba(0,0,0,.7);transition:all .3s}
.achievement-popup.show{opacity:1;visibility:visible}
.achievement-content{padding:30px;text-align:center;animation:pop .5s}
@keyframes pop{0%{transform:scale(0)}50%{transform:scale(1.1)}100%{transform:scale(1)}}
.achievement-icon{font-size:3.5rem;margin-bottom:10px}
.achievement-content h3{color:var(--orange);margin-bottom:8px}
.xp-earned{display:inline-block;padding:4px 12px;background:var(--gradient);border-radius:15px;font-size:.85rem;font-weight:600;margin-top:10px}

/* BUDGET ALERT */
.budget-alert{position:fixed;top:0;left:0;right:0;padding:20px;padding-top:max(20px,env(safe-area-inset-top));z-index:4000;transform:translateY(-100%);transition:transform .3s}
.budget-alert.show{transform:translateY(0)}
.alert-content{display:flex;align-items:center;gap:10px;padding:15px;background:rgba(239,68,68,.9)}
.alert-icon{font-size:1.5rem}
.alert-content p{flex:1;font-size:.9rem}
.alert-content button{padding:8px 15px;background:#fff;border:0;border-radius:8px;color:var(--red);font-weight:600}

/* FAB */
.fab{position:fixed;bottom:max(25px,env(safe-area-inset-bottom));right:20px;width:56px;height:56px;border-radius:50%;background:var(--gradient);border:0;color:#fff;font-size:2rem;box-shadow:0 8px 30px rgba(139,92,246,.5);cursor:pointer;z-index:100}
.fab:active{transform:scale(.9)}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* RECURRING BILLS */
.recurring-list{max-height:350px;overflow-y:auto;margin:15px 0}
.recurring-item{display:flex;align-items:center;gap:12px;padding:12px;margin-bottom:10px;background:rgba(255,255,255,0.03);border-radius:12px;border:1px solid var(--border)}
.recurring-item.inactive{opacity:.5}
.recurring-icon{width:40px;height:40px;background:var(--gradient);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.recurring-info{flex:1;min-width:0}
.recurring-name{font-weight:600;font-size:.95rem}
.recurring-meta{font-size:.75rem;color:var(--dim);margin-top:2px}
.recurring-due{font-size:.7rem;color:var(--green);margin-top:4px}
.recurring-due.soon{color:var(--orange)}
.recurring-amount{font-weight:700;color:var(--accent);font-size:1rem}
.recurring-actions{display:flex;gap:5px}
.recurring-actions .btn-icon{width:32px;height:32px;border:0;background:rgba(255,255,255,0.05);border-radius:8px;font-size:.9rem;cursor:pointer}
.recurring-summary{text-align:center;padding:10px;background:rgba(139,92,246,0.1);border-radius:10px;color:var(--accent);font-weight:600}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:5px}
.form-group{margin-bottom:15px}
.form-group label{display:block;font-size:.85rem;color:var(--text);font-weight:600;margin-bottom:8px;letter-spacing:.3px}
.form-group input,.form-group select{width:100%;padding:14px 16px;background:rgba(255,255,255,0.06);border:2px solid var(--border);border-radius:12px;color:var(--text);font-size:1rem;transition:all .2s}
.form-group input:focus,.form-group select:focus{outline:0;border-color:var(--accent);background:rgba(139,92,246,0.08);box-shadow:0 0 0 3px rgba(139,92,246,0.15)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-group select option{background:var(--bg);color:var(--text);padding:10px}
.form-group input::placeholder{color:var(--muted)}
.upcoming-bills{padding:15px;margin:15px 0}
.upcoming-bills .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.upcoming-bills .see-all{background:0;border:0;color:var(--accent);font-size:.8rem}

/* SUBCATEGORY */
.subcategory-wrap{margin:10px 0}
.subcategory-wrap select{width:100%;padding:12px 15px;background:rgba(139,92,246,0.1);border:1px solid var(--accent);border-radius:12px;color:var(--text);font-size:1rem}
