:root{--deep-navy: #0F1B2D;--deep-navy-85: rgba(15, 27, 45, .85);--warm-sand: #F5E6D3;--ivory-white: #FDFAF6;--soft-mint: #6DECB9;--ocean-teal: #2DD4BF;--coral-rose: #E8736C;--muted-slate: #94A3B8;--surface: #FFF8F3;--surface-low: #FFF2E2;--surface-card: #FFFFFF;--surface-high: #F5E6D3;--surface-highest: #EFE0CD;--surface-border: #E8DDD0;--heirloom-warm-300: #C4B5A4;--heirloom-warm-400: #94A3B8;--heirloom-warm-500: #64748B;--heirloom-warm-900: #0F1B2D;--rose-gold: #E8736C;--soul-shadow: 0 2px 12px rgba(15, 27, 45, .06);--soul-shadow-lg: 0 8px 32px rgba(15, 27, 45, .1);--soul-shadow-xl: 0 16px 48px rgba(15, 27, 45, .12);--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--sp-20: 5rem;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: 3rem;--font-h1: 2rem;--font-h2: 1.5rem;--font-h3: 1.25rem;--font-body: 1rem;--font-small: .875rem;--font-xs: .75rem;--font-sm: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--radius-pill: 9999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--surface);color:var(--deep-navy);line-height:1.6;overflow-x:hidden}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.landing{min-height:100vh;display:flex;flex-direction:column}.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-8) var(--sp-6);background:radial-gradient(ellipse at 20% 80%,rgba(109,236,185,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(45,212,191,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(232,115,108,.04) 0%,transparent 60%),var(--surface);overflow:hidden}.hero:before{content:"";position:absolute;top:-200px;right:-200px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(109,236,185,.1) 0%,transparent 70%);animation:float 8s ease-in-out infinite}.hero:after{content:"";position:absolute;bottom:-150px;left:-150px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,115,108,.08) 0%,transparent 70%);animation:float 10s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-20px) scale(1.05)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #2dd4bf4d}50%{box-shadow:0 0 40px #2dd4bf80}}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.hero-content{position:relative;z-index:1;max-width:680px;animation:slide-up .8s var(--ease-out) both}.logo-area{margin-bottom:var(--sp-8)}.logo-icon{width:80px;height:80px;margin:0 auto var(--sp-4);background:var(--deep-navy);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:var(--soul-shadow-lg);animation:slide-up .6s var(--ease-out) .2s both}.logo-text{font-size:var(--font-display);font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--deep-navy) 0%,#2a3a5c 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-tagline{font-size:var(--font-h3);color:var(--muted-slate);font-weight:400;margin-top:var(--sp-2)}.feature-pills{display:flex;flex-wrap:wrap;gap:var(--sp-3);justify-content:center;margin:var(--sp-8) 0;animation:slide-up .8s var(--ease-out) .4s both}.pill{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:var(--surface-card);border-radius:var(--radius-full);font-size:var(--font-small);font-weight:500;color:var(--deep-navy);box-shadow:var(--soul-shadow);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.pill:hover{transform:translateY(-2px);box-shadow:var(--soul-shadow-lg)}.pill-emoji{font-size:1.1rem}.cta-group{display:flex;flex-direction:column;gap:var(--sp-4);align-items:center;margin-top:var(--sp-8);animation:slide-up .8s var(--ease-out) .6s both}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:0 var(--sp-8);height:52px;border:none;border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-body);font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--deep-navy) 0%,#1a2d4a 100%);color:#fff;min-width:240px;box-shadow:var(--soul-shadow-lg)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--soul-shadow-xl)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;color:var(--ocean-teal);font-weight:500}.btn-secondary:hover{background:#2dd4bf14}.btn-scan{background:linear-gradient(135deg,var(--ocean-teal) 0%,#20b8a4 100%);color:#fff;min-width:200px;box-shadow:0 4px 20px #2dd4bf4d}.btn-scan:hover{transform:translateY(-2px);box-shadow:0 8px 30px #2dd4bf66}.btn-outline{background:transparent;color:var(--deep-navy);border:1.5px solid var(--surface-highest)}.btn-outline:hover{border-color:var(--ocean-teal);background:#2dd4bf0a}.powered-by{margin-top:var(--sp-6);font-size:var(--font-xs);color:var(--muted-slate);animation:fade-in 1s var(--ease-out) 1s both}.scanner-section{padding:var(--sp-16) var(--sp-6);background:var(--warm-sand);position:relative}.scanner-section:before{content:"";position:absolute;top:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,var(--surface),var(--warm-sand))}.section-header{text-align:center;margin-bottom:var(--sp-10);position:relative;z-index:1}.section-badge{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-4);background:#2dd4bf1a;color:var(--ocean-teal);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-4)}.section-title{font-size:var(--font-h1);font-weight:800;letter-spacing:-.02em;margin-bottom:var(--sp-3)}.section-subtitle{font-size:var(--font-body);color:var(--muted-slate);max-width:500px;margin:0 auto}.scanner-container{max-width:420px;margin:0 auto;position:relative;z-index:1}.scanner-card{background:var(--surface-card);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--soul-shadow-xl)}.upload-zone{padding:var(--sp-10) var(--sp-6);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:background var(--duration-normal) var(--ease-out);position:relative;min-height:240px}.upload-zone:hover{background:var(--surface-low)}.upload-zone.drag-over{background:#2dd4bf0f;outline:2px dashed var(--ocean-teal);outline-offset:-8px}.upload-icon{width:72px;height:72px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--ocean-teal) 0%,#20b8a4 100%);display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:var(--sp-4);box-shadow:0 4px 20px #2dd4bf40;transition:transform var(--duration-normal) var(--ease-out)}.upload-zone:hover .upload-icon{transform:scale(1.05)}.upload-title{font-size:var(--font-h3);font-weight:700;margin-bottom:var(--sp-2)}.upload-hint{font-size:var(--font-small);color:var(--muted-slate)}.scanning-overlay{padding:var(--sp-10) var(--sp-6);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:240px}.scanning-ring{width:80px;height:80px;border:3px solid var(--surface-high);border-top-color:var(--ocean-teal);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--sp-4)}.scanning-text{font-size:var(--font-body);font-weight:600;color:var(--deep-navy)}.scanning-subtext{font-size:var(--font-small);color:var(--muted-slate);margin-top:var(--sp-1)}.preview-area{position:relative;background:var(--deep-navy);min-height:200px;display:flex;align-items:center;justify-content:center}.preview-image{width:100%;max-height:280px;object-fit:contain}.preview-badge{position:absolute;top:var(--sp-3);left:var(--sp-3);display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);background:var(--deep-navy-85);color:var(--ocean-teal);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.scan-border{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:2px solid var(--ocean-teal);border-radius:var(--radius-md);animation:pulse-glow 2s ease-in-out infinite;pointer-events:none}.results-area{padding:var(--sp-6)}.result-header{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-5)}.result-check{width:36px;height:36px;border-radius:50%;background:var(--soft-mint);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.result-merchant{font-size:var(--font-h3);font-weight:700}.result-address{font-size:var(--font-xs);color:var(--muted-slate);display:flex;align-items:center;gap:var(--sp-1)}.items-list{margin-bottom:var(--sp-5)}.item-row{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 0}.item-price{font-size:var(--font-small);font-weight:600;font-variant-numeric:tabular-nums}.item-separator{height:1px;background:var(--surface-high);margin:var(--sp-2) 0}.item-total{font-weight:700;font-size:var(--font-body)}.item-total .item-price{font-size:var(--font-h3);color:var(--deep-navy)}.result-meta{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-5);padding-top:var(--sp-5);border-top:1px solid var(--surface-high)}.meta-chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);background:var(--surface-low);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500}.meta-chip.category{background:#2dd4bf1a;color:var(--ocean-teal)}.meta-chip.confidence{background:#6decb91a;color:#0d9668}.meta-chip.time{color:var(--muted-slate)}.gemini-tag{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);background:var(--surface-low);border-radius:var(--radius-md);margin-top:var(--sp-4);font-size:var(--font-xs);color:var(--muted-slate)}.scanner-actions{padding:0 var(--sp-6) var(--sp-6);display:flex;gap:var(--sp-3)}.scanner-actions .btn{flex:1;height:44px;font-size:var(--font-small)}.features-section{padding:var(--sp-16) var(--sp-6);background:var(--surface)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--sp-6);max-width:960px;margin:0 auto}.feature-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-8);box-shadow:var(--soul-shadow);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--soul-shadow-lg)}.feature-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:var(--sp-4)}.feature-icon.mint{background:#6decb91f}.feature-icon.teal{background:#2dd4bf1f}.feature-icon.coral{background:#e8736c1f}.feature-icon.navy{background:#0f1b2d14}.feature-title{font-size:var(--font-h3);font-weight:700;margin-bottom:var(--sp-2)}.feature-desc{font-size:var(--font-small);color:var(--muted-slate);line-height:1.6}.footer{padding:var(--sp-10) var(--sp-6);text-align:center;background:var(--deep-navy);color:#ffffff80;font-size:var(--font-small)}.footer-brand{font-size:var(--font-body);font-weight:700;color:#fff;margin-bottom:var(--sp-2)}.footer-love{margin-top:var(--sp-2)}.error-message{padding:var(--sp-4);margin:var(--sp-4) var(--sp-6);background:#e8736c14;border-radius:var(--radius-md);color:var(--coral-rose);font-size:var(--font-small);text-align:center}@media (max-width: 640px){.logo-text{font-size:2.2rem}.logo-tagline{font-size:var(--font-body)}.section-title{font-size:var(--font-h2)}.features-grid{grid-template-columns:1fr}.scanner-container{margin:0 calc(var(--sp-6) * -1);max-width:none}.scanner-card{border-radius:var(--radius-lg);margin:0 var(--sp-4)}}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface);gap:var(--sp-4)}.loading-logo{font-size:3rem;animation:pulse-glow 2s ease-in-out infinite}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--sp-6);background:radial-gradient(ellipse at 20% 80%,rgba(109,236,185,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(232,115,108,.06) 0%,transparent 50%),var(--surface)}.auth-card{width:100%;max-width:400px;background:var(--surface-card);border-radius:var(--radius-xl);padding:var(--sp-8);box-shadow:var(--soul-shadow-xl);animation:slide-up .6s var(--ease-out) both}.auth-logo{text-align:center;margin-bottom:var(--sp-8)}.auth-logo .logo-icon{width:64px;height:64px;background:var(--deep-navy);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--sp-3)}.auth-logo .logo-text{font-size:var(--font-h1);font-weight:800;background:linear-gradient(135deg,var(--deep-navy),#2a3a5c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-logo .logo-tagline{font-size:var(--font-small);color:var(--muted-slate);margin-top:var(--sp-1)}.auth-tabs{display:flex;gap:var(--sp-1);background:var(--surface-low);border-radius:var(--radius-full);padding:3px;margin-bottom:var(--sp-6)}.auth-tab{flex:1;padding:var(--sp-2) var(--sp-4);border:none;border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-small);font-weight:600;color:var(--muted-slate);cursor:pointer;transition:all var(--duration-fast)}.auth-tab.active{background:var(--surface-card);color:var(--deep-navy);box-shadow:var(--soul-shadow)}.auth-form{display:flex;flex-direction:column;gap:var(--sp-4)}.input-group{display:flex;flex-direction:column;gap:var(--sp-1)}.input-group label{font-size:var(--font-small);font-weight:600;color:var(--deep-navy)}.input-group input,.input-group select{padding:var(--sp-3) var(--sp-4);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-body);color:var(--deep-navy);background:var(--surface);transition:border-color var(--duration-fast);outline:none}.input-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--sp-3) center;background-size:16px;padding-right:var(--sp-8);cursor:pointer}.input-group input:focus,.input-group select:focus{border-color:var(--ocean-teal)}.input-group input::placeholder,.input-group select::placeholder{color:var(--muted-slate)}.auth-error{padding:var(--sp-2) var(--sp-3);background:#e8736c14;color:var(--coral-rose);border-radius:var(--radius-sm);font-size:var(--font-small);text-align:center}.auth-divider{display:flex;align-items:center;gap:var(--sp-4);margin:var(--sp-5) 0;color:var(--muted-slate);font-size:var(--font-small)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--surface-highest)}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-6);border:1.5px solid var(--surface-highest);border-radius:var(--radius-full);background:var(--surface-card);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;color:var(--deep-navy);cursor:pointer;transition:all var(--duration-fast)}.btn-google:hover{border-color:var(--ocean-teal);background:#2dd4bf0a}.btn-text{background:none;border:none;color:var(--muted-slate);font-family:var(--font-family);font-size:var(--font-small);cursor:pointer;padding:var(--sp-2)}.btn-text:hover{color:var(--coral-rose)}.btn-danger{background:#e8736c14;color:var(--coral-rose);border:none;width:100%;padding:var(--sp-3);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;margin-top:var(--sp-4)}.pairing-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--sp-6);background:var(--surface)}.pairing-card{width:100%;max-width:400px;background:var(--surface-card);border-radius:var(--radius-xl);padding:var(--sp-8);box-shadow:var(--soul-shadow-xl);text-align:center;animation:slide-up .6s var(--ease-out) both}.pairing-icon{font-size:3rem;margin-bottom:var(--sp-4)}.pairing-desc{color:var(--muted-slate);font-size:var(--font-small);margin:var(--sp-3) 0 var(--sp-6);line-height:1.6}.pairing-card .btn-primary,.pairing-card .btn-secondary{width:100%}.pairing-card .btn-secondary{border:1.5px solid var(--surface-highest);padding:var(--sp-3);border-radius:var(--radius-full);margin-top:var(--sp-3)}.pairing-card .input-group{text-align:left}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--surface)}.app-content{flex:1;padding-bottom:calc(85px + env(safe-area-inset-bottom,0px));overflow-y:auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-around;height:auto;min-height:68px;background:var(--surface-card);border-top:1px solid var(--surface-high);box-shadow:0 -4px 20px #0f1b2d0f;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;height:68px;padding:0;border:none;background:none;font-family:var(--font-family);cursor:pointer;color:var(--muted-slate);transition:color var(--duration-fast)}.nav-item.active{color:var(--ocean-teal)}.nav-item.scan-btn .nav-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--ocean-teal),#20b8a4);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-top:-20px;box-shadow:0 4px 16px #2dd4bf59;transition:transform var(--duration-fast)}.nav-item.scan-btn:active .nav-icon{transform:scale(.95)}.nav-icon{font-size:1.2rem}.nav-label{font-size:9px;font-weight:600}.dashboard{padding:var(--sp-6);padding-top:calc(env(safe-area-inset-top,0px) + var(--sp-6))}.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-6)}.dash-greeting{font-size:var(--font-small);color:var(--muted-slate)}.dash-name{font-size:var(--font-h2);font-weight:800}.icon-btn{width:40px;height:40px;border:none;border-radius:50%;background:var(--surface-low);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast)}.icon-btn:hover{background:var(--surface-high)}.wallet-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-bottom:var(--sp-6)}.wallet-card{padding:var(--sp-5);border-radius:var(--radius-lg);box-shadow:var(--soul-shadow)}.wallet-card.shared{background:linear-gradient(135deg,var(--deep-navy),#1a2d4a);color:#fff}.wallet-card.personal{background:var(--surface-card);border:1.5px solid var(--surface-highest)}.wallet-label{font-size:var(--font-xs);opacity:.8;display:block;margin-bottom:var(--sp-2)}.wallet-balance{font-size:var(--font-h3);font-weight:800;font-variant-numeric:tabular-nums}.wallet-card.shared .wallet-balance{color:var(--soft-mint)}.monthly-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-bottom:var(--sp-6)}.stat-card{padding:var(--sp-4);background:var(--surface-card);border-radius:var(--radius-md);box-shadow:var(--soul-shadow)}.stat-label{font-size:var(--font-xs);color:var(--muted-slate);display:block;margin-bottom:var(--sp-1)}.stat-value{font-size:var(--font-h3);font-weight:700;font-variant-numeric:tabular-nums}.stat-value.expense{color:var(--coral-rose)}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-8)}.action-btn{padding:var(--sp-3) var(--sp-4);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all var(--duration-fast)}.action-btn.scan{background:linear-gradient(135deg,var(--ocean-teal),#20b8a4);color:#fff;box-shadow:0 4px 16px #2dd4bf40}.action-btn.scan:hover{transform:translateY(-2px)}.action-btn.add{background:var(--surface-card);color:var(--deep-navy);border:1.5px solid var(--surface-highest)}.action-btn.add:hover{border-color:var(--ocean-teal)}.section{margin-bottom:var(--sp-6)}.section .section-title{font-size:var(--font-body);font-weight:700;margin-bottom:var(--sp-4)}.empty-text{text-align:center;color:var(--muted-slate);font-size:var(--font-small);padding:var(--sp-8) 0}.tx-list{display:flex;flex-direction:column;gap:var(--sp-2)}.tx-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--surface-card);border-radius:var(--radius-md);box-shadow:var(--soul-shadow);transition:transform var(--duration-fast)}.tx-row:active{transform:scale(.98)}.tx-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--surface-low);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.tx-info{flex:1;display:flex;flex-direction:column;min-width:0}.tx-merchant{font-size:var(--font-small);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-date{font-size:var(--font-xs);color:var(--muted-slate)}.tx-amount{font-size:var(--font-small);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.tx-amount.expense{color:var(--coral-rose)}.tx-amount.income{color:var(--soft-mint)}.tx-card{border-radius:var(--radius-md);background:var(--surface-card);box-shadow:var(--soul-shadow);overflow:hidden;transition:box-shadow .2s,border-color .2s;border:1.5px solid transparent}.tx-card.expanded{border-color:var(--ocean-teal);box-shadow:0 4px 20px #2dd4bf1a}.tx-card .tx-row{cursor:pointer;box-shadow:none;border-radius:0;-webkit-user-select:none;user-select:none}.tx-chevron{font-size:1.2rem;color:var(--muted-slate);transition:transform .25s ease;flex-shrink:0;margin-left:var(--sp-1)}.tx-chevron.open{transform:rotate(90deg)}.tx-detail{padding:0 var(--sp-4) var(--sp-4);border-top:1px solid var(--surface-lowest);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:800px}}.tx-detail-meta{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-3) 0;border-bottom:1px solid var(--surface-lowest)}.tx-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-xs)}.tx-meta-label{color:var(--muted-slate);font-weight:500}.tx-meta-value{color:var(--text-primary);font-weight:600;text-align:right;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-detail-section{padding:var(--sp-3) 0;border-bottom:1px solid var(--surface-lowest)}.tx-detail-section:last-of-type{border-bottom:none}.tx-detail-section-header{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-xs);font-weight:600;color:var(--muted-slate);margin-bottom:var(--sp-2)}.tx-edit-btn{background:none;border:1px solid var(--surface-highest);border-radius:var(--radius-full);padding:2px 8px;font-size:11px;cursor:pointer;color:var(--ocean-teal);font-family:var(--font-family);transition:all .15s}.tx-edit-btn:hover{background:#2dd4bf14;border-color:var(--ocean-teal)}.tx-note-text{font-size:var(--font-small);color:var(--text-primary);margin:0;line-height:1.5}.tx-category-display{font-size:var(--font-small);color:var(--text-primary);font-weight:500}.tx-edit-inline input{width:100%;padding:var(--sp-2);border:1.5px solid var(--ocean-teal);border-radius:var(--radius-sm);background:var(--surface-low);font-family:var(--font-family);font-size:var(--font-small);color:var(--text-primary);margin-bottom:var(--sp-2)}.tx-edit-actions{display:flex;gap:var(--sp-2);align-items:center}.btn-sm{padding:4px 12px!important;font-size:12px!important;min-height:28px}.tx-edit-category .category-grid.compact{gap:4px}.tx-edit-category .category-grid.compact .emoji-btn{padding:4px 6px;font-size:11px}.tx-items-list{display:flex;flex-direction:column;gap:var(--sp-1)}.tx-item-row{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-xs);padding:var(--sp-1) 0}.tx-item-name{flex:1;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-item-qty{color:var(--muted-slate);font-weight:500;min-width:24px;text-align:center}.tx-item-price{font-weight:600;font-variant-numeric:tabular-nums;min-width:70px;text-align:right}.tx-items-edit{display:flex;flex-direction:column;gap:var(--sp-2)}.tx-item-edit-row{display:flex;gap:var(--sp-1);align-items:center}.tx-item-name-input{flex:1;padding:4px 8px;border:1px solid var(--surface-highest);border-radius:var(--radius-sm);background:var(--surface-low);font-family:var(--font-family);font-size:12px;color:var(--text-primary)}.tx-item-qty-input,.tx-item-price-input{width:auto;flex:0 0 auto;min-width:65px;padding:4px 6px;border:1px solid var(--surface-highest);border-radius:var(--radius-sm);background:var(--surface-low);font-family:var(--font-family);font-size:12px;color:var(--text-primary);text-align:right}.tx-item-qty-input{min-width:40px;width:40px}.tx-detail-danger{padding-top:var(--sp-3);margin-top:var(--sp-1)}.btn-ghost-danger{background:none;border:1px solid rgba(240,113,120,.25);border-radius:var(--radius-sm);color:var(--coral-rose);padding:var(--sp-2) var(--sp-3);font-family:var(--font-family);font-size:var(--font-xs);font-weight:500;cursor:pointer;width:100%;transition:all .15s}.btn-ghost-danger:hover{background:#f0717814;border-color:var(--coral-rose)}.tx-confirm-delete{background:#f071780f;border:1px solid rgba(240,113,120,.2);border-radius:var(--radius-sm);padding:var(--sp-3);text-align:center}.tx-confirm-delete p{margin:0 0 var(--sp-2);font-size:var(--font-small);font-weight:600;color:var(--coral-rose)}.tx-confirm-actions{display:flex;gap:var(--sp-2);justify-content:center}.btn-danger{background:var(--coral-rose)!important;color:#fff!important;border:none!important}.tab-page{padding:var(--sp-6);padding-top:calc(env(safe-area-inset-top,0px) + var(--sp-6))}.page-title{font-size:var(--font-h2);font-weight:800;margin-bottom:var(--sp-2)}.page-desc{font-size:var(--font-small);color:var(--muted-slate);margin-bottom:var(--sp-6)}.settings-section{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-4);box-shadow:var(--soul-shadow)}.setting-item{padding:var(--sp-3) var(--sp-4);font-size:var(--font-small);font-weight:500;border-bottom:1px solid var(--surface-high)}.setting-item:last-child{border-bottom:none}.setting-item.invite-code{display:flex;justify-content:space-between;align-items:center}.setting-item code{background:var(--surface-low);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-sm);font-family:SF Mono,Fira Code,monospace;font-size:var(--font-xs);color:var(--ocean-teal);letter-spacing:.1em}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.bottom-sheet{background:var(--surface-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:90svh;height:max-content;overflow-y:auto;padding:var(--sp-4) var(--sp-5) var(--sp-8);animation:slideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sheet-handle{width:40px;height:4px;background:var(--surface-border);border-radius:2px;margin:0 auto var(--sp-4)}.sheet-title{font-size:var(--font-lg);font-weight:700;color:var(--heirloom-warm-900);margin-bottom:var(--sp-5);text-align:center}.add-tx-form{display:flex;flex-direction:column;gap:var(--sp-4)}.type-toggle{display:flex;gap:var(--sp-2);background:var(--surface-low);padding:var(--sp-1);border-radius:var(--radius-md)}.type-btn{flex:1;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--heirloom-warm-500);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all .2s}.type-btn.active.expense{background:#fee2e2;color:#dc2626}.type-btn.active.income{background:#dcfce7;color:#16a34a}.amount-input-group{display:flex;align-items:center;gap:var(--sp-2);background:var(--surface-low);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4)}.amount-input{flex:1;border:none;background:transparent;font-size:2rem;font-weight:700;color:var(--heirloom-warm-900);text-align:center;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.amount-input::-webkit-outer-spin-button,.amount-input::-webkit-inner-spin-button{-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:0}.amount-currency{font-size:1.5rem;color:var(--heirloom-warm-400);font-weight:600}.categories-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-2)}.cat-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-2) var(--sp-1);border:2px solid transparent;border-radius:var(--radius-md);background:var(--surface-low);cursor:pointer;transition:all .2s;font-size:1.2rem}.cat-chip .cat-name{font-size:.65rem;color:var(--heirloom-warm-500);white-space:nowrap}.cat-chip.active{border-color:var(--ocean-teal);background:#2b8c8214}.cat-chip.active .cat-name{color:var(--ocean-teal);font-weight:600}.ledger-page{display:flex;flex-direction:column;gap:var(--sp-4)}.ledger-summary{display:flex;gap:var(--sp-3)}.summary-item{flex:1;display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-lg);background:var(--surface-card)}.summary-item.expense .summary-value{color:#dc2626}.summary-item.income .summary-value{color:#16a34a}.summary-label{font-size:var(--font-xs);color:var(--heirloom-warm-400);font-weight:500}.summary-value{font-size:var(--font-md);font-weight:700}.ledger-search input{width:100%;padding:var(--sp-2) var(--sp-4);border:1px solid var(--surface-border);border-radius:var(--radius-pill);background:var(--surface-card);font-size:var(--font-sm);color:var(--heirloom-warm-900);outline:none}.ledger-search input:focus{border-color:var(--ocean-teal)}.ledger-filters{display:flex;gap:var(--sp-2)}.filter-chip{padding:var(--sp-1) var(--sp-3);border:1px solid var(--surface-border);border-radius:var(--radius-pill);background:transparent;font-size:var(--font-xs);color:var(--heirloom-warm-500);cursor:pointer;transition:all .2s}.filter-chip.active{background:var(--ocean-teal);color:#fff;border-color:var(--ocean-teal)}.tx-groups{display:flex;flex-direction:column;gap:var(--sp-4)}.tx-group-header{font-size:var(--font-xs);font-weight:600;color:var(--heirloom-warm-400);text-transform:capitalize;padding-bottom:var(--sp-1);border-bottom:1px solid var(--surface-border)}.tx-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) 0;border-bottom:1px solid var(--surface-low)}.tx-row-left{display:flex;align-items:center;gap:var(--sp-3)}.tx-emoji{font-size:1.4rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface-low);border-radius:var(--radius-md)}.tx-row-info{display:flex;flex-direction:column;gap:2px}.tx-merchant{font-size:var(--font-sm);font-weight:600;color:var(--heirloom-warm-900)}.tx-note{font-size:var(--font-xs);color:var(--heirloom-warm-400)}.tx-amount.expense{color:#dc2626;font-weight:700}.tx-amount.income{color:#16a34a;font-weight:700}.empty-ledger,.empty-goals{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-8) 0}.empty-icon{font-size:3rem;margin-bottom:var(--sp-2)}.empty-text{color:var(--heirloom-warm-400);font-size:var(--font-sm)}.empty-hint{color:var(--heirloom-warm-300);font-size:var(--font-xs)}.goals-page{display:flex;flex-direction:column;gap:var(--sp-4);position:relative;padding-bottom:80px}.goals-list{display:flex;flex-direction:column;gap:var(--sp-3)}.goal-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.goal-header{display:flex;align-items:center;gap:var(--sp-3)}.goal-emoji{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-low);border-radius:var(--radius-md)}.goal-info{display:flex;flex-direction:column;gap:2px}.goal-name{font-size:var(--font-md);font-weight:700;color:var(--heirloom-warm-900);margin:0}.goal-deadline{font-size:var(--font-xs);color:var(--heirloom-warm-400)}.goal-progress{display:flex;flex-direction:column;gap:var(--sp-1)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--ocean-teal),var(--rose-gold));border-radius:5px;transition:width .5s ease}.progress-labels{display:flex;justify-content:space-between;font-size:var(--font-xs);color:var(--heirloom-warm-500)}.progress-pct{font-size:var(--font-xs);font-weight:700;color:var(--ocean-teal);text-align:right}.fund-form{display:flex;flex-direction:column;gap:var(--sp-2)}.fund-form input{padding:var(--sp-2) var(--sp-3);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.fund-actions{display:flex;gap:var(--sp-2)}.fund-btn{width:100%}.fab{position:fixed;bottom:100px;right:20px;width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--ocean-teal),var(--rose-gold));color:#fff;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 16px #2b8c8259;z-index:50;transition:transform .2s}.fab:active{transform:scale(.9)}.emoji-picker{display:flex;gap:var(--sp-2);flex-wrap:wrap;justify-content:center}.emoji-btn{width:44px;height:44px;border:2px solid transparent;border-radius:var(--radius-md);background:var(--surface-low);font-size:1.4rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-btn.active{border-color:var(--ocean-teal);background:#2b8c821a}.add-goal-form,.settings-page{display:flex;flex-direction:column;gap:var(--sp-4)}.settings-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-4)}.settings-card.profile-card{display:flex;align-items:center;gap:var(--sp-4)}.profile-avatar img{width:56px;height:56px;border-radius:50%;object-fit:cover}.avatar-placeholder{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--ocean-teal),var(--rose-gold));color:#fff;font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center}.profile-details h3{font-size:var(--font-md);font-weight:700;color:var(--heirloom-warm-900);margin:0}.profile-email{font-size:var(--font-xs);color:var(--heirloom-warm-400);margin:2px 0 0}.settings-label{font-size:var(--font-xs);font-weight:600;color:var(--heirloom-warm-400);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--sp-3)}.settings-row{display:flex;gap:var(--sp-2);align-items:center}.settings-row input{flex:1;padding:var(--sp-2) var(--sp-3);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--heirloom-warm-900)}.settings-info{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 0;border-bottom:1px solid var(--surface-low)}.settings-info:last-child{border-bottom:none}.info-label{font-size:var(--font-sm);color:var(--heirloom-warm-500)}.info-value{font-size:var(--font-sm);font-weight:600;color:var(--heirloom-warm-900)}.logout-btn{width:100%;padding:var(--sp-3)}.btn-danger{background:#fee2e2;color:#dc2626;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#fecaca}.btn-sm{padding:var(--sp-1) var(--sp-3)!important;font-size:var(--font-xs)!important}.btn-outline{background:transparent;border:1px solid var(--surface-border);color:var(--ocean-teal);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3);font-weight:600;cursor:pointer;transition:all .2s}.btn-outline:hover{border-color:var(--ocean-teal);background:#2b8c820d}.btn-text{background:none;border:none;color:var(--heirloom-warm-400);cursor:pointer;font-size:var(--font-sm)}.settings-footer{text-align:center;font-size:var(--font-xs);color:var(--heirloom-warm-300);margin-top:var(--sp-4)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.sheet-form{display:flex;flex-direction:column;gap:var(--sp-4)}.sheet-handle{width:40px;height:4px;background:var(--surface-highest);border-radius:2px;margin:0 auto var(--sp-4)}.sheet-title{font-size:var(--font-lg);font-weight:700;color:var(--deep-navy);margin-bottom:var(--sp-5);text-align:center}.toggle-btn{flex:1;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted-slate);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn.active.expense{background:#e8736c1a;color:var(--coral-rose)}.toggle-btn.active.income{background:#6decb91a;color:#16a34a}.amount-input.expense{color:var(--coral-rose)}.amount-input.income{color:#16a34a}.wallet-option{flex:1;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);background:transparent;font-family:var(--font-family);font-size:var(--font-small);cursor:pointer;transition:all .2s}.wallet-option.active{border-color:var(--ocean-teal);background:#2dd4bf0f;color:var(--ocean-teal);font-weight:600}.full-width{width:100%}.btn.expense{background:linear-gradient(135deg,var(--coral-rose),#d35f58)}.btn.income{background:linear-gradient(135deg,#16a34a,#15803d)}.page-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4)}.btn-small{padding:var(--sp-1) var(--sp-3);border:1.5px solid var(--surface-highest);border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s}.btn-small:hover{border-color:var(--ocean-teal);color:var(--ocean-teal)}.card{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-5);box-shadow:var(--soul-shadow);margin-bottom:var(--sp-4)}.card-title{font-size:var(--font-body);font-weight:700;margin:0 0 var(--sp-4)}.emoji-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-2)}.emoji-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--sp-2);border:2px solid transparent;border-radius:var(--radius-md);background:var(--surface-low);font-size:1.4rem;cursor:pointer;transition:all .2s}.emoji-btn.active{border-color:var(--ocean-teal);background:#2dd4bf14}.emoji-label{font-size:.6rem;color:var(--muted-slate);white-space:nowrap}.form-actions{display:flex;gap:var(--sp-3)}.form-actions .btn{flex:1}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-10) 0}.empty-icon{font-size:3rem}.empty-subtext{color:var(--muted-slate);font-size:var(--font-xs);text-align:center;max-width:280px}.progress-section{display:flex;flex-direction:column;gap:var(--sp-1)}.progress-bar{height:10px;background:var(--surface-low);border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--ocean-teal),var(--soft-mint));border-radius:5px;transition:width .5s ease}.progress-labels{display:flex;justify-content:space-between;font-size:var(--font-xs);color:var(--muted-slate)}.progress-current{font-weight:600;color:var(--ocean-teal)}.progress-target{font-weight:600}.progress-percent{font-size:var(--font-xs);font-weight:700;color:var(--ocean-teal);text-align:right}.contributions-mini{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-2) 0;border-top:1px solid var(--surface-high)}.contrib-row{display:flex;justify-content:space-between;font-size:var(--font-xs)}.contrib-name{color:var(--muted-slate)}.contrib-amount{color:var(--soft-mint);font-weight:600}.add-funds-form{display:flex;flex-direction:column;gap:var(--sp-2);padding-top:var(--sp-2)}.add-funds-form input{padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-small);outline:none}.add-funds-form input:focus{border-color:var(--ocean-teal)}.btn-add-funds{width:100%;padding:var(--sp-2);border:1.5px solid var(--ocean-teal);border-radius:var(--radius-md);background:#2dd4bf0f;color:var(--ocean-teal);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all .2s}.btn-add-funds:hover{background:#2dd4bf1f}.scanner-container{width:100%;max-width:480px;margin:0 auto}.scanner-card{background:var(--surface-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--soul-shadow)}.scanner-idle{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-4)}.capture-zone,.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-6);border:2px dashed var(--surface-highest);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:center}.capture-zone{background:linear-gradient(135deg,#2dd4bf0f,#6decb90f);border-color:var(--ocean-teal);border-style:solid}.capture-zone:hover{background:linear-gradient(135deg,#2dd4bf1f,#6decb91f);transform:translateY(-2px)}.upload-zone:hover{border-color:var(--ocean-teal);background:#2dd4bf08}.upload-zone.drag-over{border-color:var(--ocean-teal);background:#2dd4bf14;transform:scale(1.02)}.capture-icon,.upload-icon{font-size:2rem}.capture-title,.upload-title{font-size:var(--font-small);font-weight:700;color:var(--deep-navy);margin:0}.capture-hint,.upload-hint{font-size:var(--font-xs);color:var(--muted-slate);margin:0}.upload-input{display:none}.preview-area{position:relative;width:100%;max-height:300px;overflow:hidden}.preview-image{width:100%;height:100%;object-fit:cover;display:block}.preview-badge{position:absolute;top:var(--sp-3);right:var(--sp-3);padding:var(--sp-1) var(--sp-3);background:#0f1b2dbf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600}.scan-border{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:2px solid var(--ocean-teal);border-radius:var(--radius-md);animation:scanPulse 1.5s infinite}@keyframes scanPulse{0%,to{opacity:.3}50%{opacity:1}}.scanning-overlay{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-6)}.scanning-ring{width:48px;height:48px;border:3px solid var(--surface-high);border-top-color:var(--ocean-teal);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scanning-text{font-size:var(--font-small);font-weight:700;color:var(--deep-navy);margin:0}.scanning-subtext{font-size:var(--font-xs);color:var(--muted-slate);margin:0}.results-area{padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.result-header{display:flex;align-items:center;gap:var(--sp-3)}.result-check{width:32px;height:32px;background:#2dd4bf1f;color:var(--ocean-teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.result-merchant{font-size:var(--font-body);font-weight:700;color:var(--deep-navy);margin:0}.result-address{font-size:var(--font-xs);color:var(--muted-slate);margin:2px 0 0}.items-list{display:flex;flex-direction:column;gap:var(--sp-1)}.item-row{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-1) 0}.item-name{font-size:var(--font-small);color:var(--deep-navy)}.item-price{font-size:var(--font-small);font-weight:600;color:var(--deep-navy)}.item-total .item-name{font-weight:700}.item-total .item-price{font-size:var(--font-body);font-weight:800;color:var(--coral-rose)}.item-separator{height:1px;background:var(--surface-high);margin:var(--sp-1) 0}.result-meta{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.meta-chip{padding:var(--sp-1) var(--sp-2);background:var(--surface-low);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500;color:var(--deep-navy)}.meta-chip.category{background:#2dd4bf1a;color:var(--ocean-teal);font-weight:600}.meta-chip.confidence{background:#6decb91a;color:#16a34a}.gemini-tag{text-align:center;font-size:var(--font-xs);color:var(--muted-slate);padding:var(--sp-2) 0}.scanner-actions{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-4)}.btn-sync{width:100%;padding:var(--sp-3) var(--sp-4);border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--ocean-teal),var(--soft-mint));color:#fff;font-family:var(--font-family);font-size:var(--font-small);font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #2dd4bf4d}.btn-sync:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2dd4bf66}.btn-sync:disabled{opacity:.6;cursor:not-allowed}.sync-success{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3);background:#6decb91a;border:1.5px solid var(--soft-mint);border-radius:var(--radius-md);color:#16a34a;font-size:var(--font-small);font-weight:600;animation:syncPop .3s ease}@keyframes syncPop{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.sync-check{font-size:1.2rem}.btn-scan,.btn-scan-another{width:100%;padding:var(--sp-2) var(--sp-4);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);background:transparent;font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all .2s;color:var(--deep-navy)}.btn-scan:hover,.btn-scan-another:hover{border-color:var(--ocean-teal);color:var(--ocean-teal)}.notif-wrapper{position:relative}.notif-bell{position:relative;background:none;border:none;cursor:pointer;font-size:1.3rem;padding:var(--sp-1)}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;background:var(--coral-rose);color:#fff;font-size:.6rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:badgePop .3s ease}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.notif-dropdown{position:absolute;top:100%;right:0;width:320px;max-height:400px;background:var(--surface-card);border-radius:var(--radius-lg);box-shadow:var(--soul-shadow-xl);z-index:300;overflow:hidden;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notif-header{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--surface-high)}.notif-title{font-weight:700;font-size:var(--font-small)}.notif-mark-all{background:none;border:none;color:var(--ocean-teal);font-size:var(--font-xs);font-weight:600;cursor:pointer;font-family:var(--font-family)}.notif-list{overflow-y:auto;max-height:340px}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-8) var(--sp-4);color:var(--muted-slate)}.notif-item{display:flex;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);cursor:pointer;transition:background .15s;position:relative}.notif-item:hover{background:var(--surface-low)}.notif-item.unread{background:#2dd4bf0a}.notif-item-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}.notif-item-content{flex:1;min-width:0}.notif-item-title{font-size:var(--font-xs);font-weight:600;margin:0;color:var(--deep-navy)}.notif-item-body{font-size:var(--font-xs);color:var(--muted-slate);margin:2px 0 0}.notif-item-time{font-size:.65rem;color:var(--heirloom-warm-300)}.notif-dot{width:8px;height:8px;background:var(--ocean-teal);border-radius:50%;flex-shrink:0;margin-top:6px}.dash-header-actions{display:flex;align-items:center;gap:var(--sp-2)}.wallet-toggle{display:flex;background:var(--surface-low);border-radius:var(--radius-full);padding:3px;margin-bottom:var(--sp-4)}.wallet-toggle-btn{flex:1;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s;color:var(--muted-slate)}.wallet-toggle-btn.active{background:var(--surface-card);color:var(--deep-navy);box-shadow:var(--soul-shadow)}.wallet-card-big{border-radius:var(--radius-xl);padding:var(--sp-5);margin-bottom:var(--sp-4);color:#fff;position:relative;overflow:hidden}.wallet-card-big.shared{background:linear-gradient(135deg,#0f1b2d,#1e3a5f)}.wallet-card-big.personal{background:linear-gradient(135deg,#2dd4bf,#0d9488)}.wallet-card-big .wallet-label{font-size:var(--font-xs);opacity:.8}.wallet-balance-big{font-size:var(--font-h1);font-weight:800;margin:var(--sp-2) 0}.wallet-card-stats{display:flex;gap:var(--sp-4);font-size:var(--font-xs);opacity:.8}.wallet-stat.income{color:var(--soft-mint)}.wallet-stat.expense{color:#fca5a5}.goals-tab-toggle{display:flex;background:var(--surface-low);border-radius:var(--radius-full);padding:3px;margin-bottom:var(--sp-4)}.goals-tab-btn{flex:1;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s;color:var(--muted-slate)}.goals-tab-btn.active{background:var(--surface-card);color:var(--deep-navy);box-shadow:var(--soul-shadow)}.goal-header{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3)}.goal-emoji{font-size:1.5rem}.goal-info{flex:1;display:flex;flex-direction:column;gap:2px}.goal-name{font-weight:700;font-size:var(--font-small)}.goal-type-badge{font-size:.65rem;color:var(--muted-slate)}.goal-deadline{font-size:var(--font-xs);color:var(--muted-slate);margin:var(--sp-2) 0 0}.invite-result{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-4) 0}.invite-label{font-size:var(--font-small);color:var(--deep-navy);text-align:center}.invite-code-big{font-size:var(--font-h1);font-weight:800;letter-spacing:4px;color:var(--ocean-teal);background:#2dd4bf14;padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-md);font-family:Courier New,monospace}.invite-hint{font-size:var(--font-xs);color:var(--muted-slate);text-align:center}.invite-code-row{display:flex;align-items:center;gap:var(--sp-2)}.invite-code{font-family:Courier New,monospace;font-size:var(--font-small);font-weight:700;letter-spacing:2px;color:var(--ocean-teal);background:#2dd4bf0f;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm)}.btn-copy{padding:var(--sp-1) var(--sp-2);border:1px solid var(--surface-highest);border-radius:var(--radius-sm);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);cursor:pointer;transition:all .15s}.btn-copy:hover{border-color:var(--ocean-teal);color:var(--ocean-teal)}.settings-hint{font-size:var(--font-xs);color:var(--muted-slate);padding:var(--sp-2) var(--sp-4)}.wallet-picker-sheet{text-align:center}.sheet-desc{font-size:var(--font-small);color:var(--muted-slate);margin-bottom:var(--sp-4)}.wallet-picker-options{display:flex;gap:var(--sp-3);padding:0 0 var(--sp-2)}.wallet-picker-btn{flex:1;padding:var(--sp-4);border:2px solid var(--surface-highest);border-radius:var(--radius-lg);background:transparent;font-family:var(--font-family);font-size:var(--font-body);font-weight:700;cursor:pointer;transition:all .2s}.wallet-picker-btn:hover{transform:translateY(-2px);box-shadow:var(--soul-shadow)}.wallet-picker-btn.shared:hover{border-color:var(--deep-navy);background:#0f1b2d0a}.wallet-picker-btn.personal:hover{border-color:var(--ocean-teal);background:#2dd4bf0a}.ledger-filters{display:flex;flex-direction:column;gap:var(--sp-2);margin-bottom:var(--sp-4)}.filter-group{display:flex;gap:var(--sp-1);flex-wrap:wrap}.filter-chip{padding:var(--sp-1) var(--sp-2);border:1.5px solid var(--surface-highest);border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.filter-chip.active{border-color:var(--ocean-teal);background:#2dd4bf14;color:var(--ocean-teal);font-weight:600}.tx-wallet-badge{font-size:.6rem;margin-left:4px}.btn-danger{background:#e8736c14;border:1.5px solid var(--coral-rose);color:var(--coral-rose);border-radius:var(--radius-md);padding:var(--sp-3);font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#e8736c26}.required{color:var(--coral-rose)}.stat-value.income{color:#16a34a}.solo-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);background:linear-gradient(135deg,#2dd4bf14,#6decb914);border-radius:var(--radius-md);margin-bottom:var(--sp-4);font-size:var(--font-small);font-weight:600;color:var(--deep-navy)}.solo-pair-btn{padding:var(--sp-1) var(--sp-3);border:1.5px solid var(--ocean-teal);border-radius:var(--radius-full);background:transparent;color:var(--ocean-teal);font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s}.solo-pair-btn:hover{background:var(--ocean-teal);color:#fff}.pairing-skip-section{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--surface-high)}.btn-text.muted{color:var(--muted-slate);font-size:var(--font-xs)}.settings-leave-btn{margin-top:var(--sp-4)}.btn-danger-outline{background:transparent;border:1.5px solid var(--coral-rose);color:var(--coral-rose);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3);font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s}.btn-danger-outline:hover{background:#e8736c14}.couple-active{color:#16a34a;font-weight:600}.settings-no-couple{font-size:var(--font-small);color:var(--muted-slate);text-align:center;padding:var(--sp-3) 0}.settings-join-form{display:flex;flex-direction:column;gap:var(--sp-3);padding-top:var(--sp-2)}.settings-footer{text-align:center;font-size:var(--font-xs);color:var(--muted-slate);padding:var(--sp-6) 0 var(--sp-4)}.voice-tx{background:var(--surface-card);border-radius:var(--radius-xl);padding:var(--sp-5);box-shadow:var(--soul-shadow)}.voice-idle{display:flex;flex-direction:column;gap:var(--sp-4)}.voice-header{text-align:center}.voice-emoji{font-size:2rem;display:block;margin-bottom:var(--sp-2)}.voice-header h3{font-size:var(--font-body);font-weight:700;color:var(--deep-navy);margin:0}.voice-desc{font-size:var(--font-xs);color:var(--muted-slate);margin:var(--sp-1) 0 0}.voice-record-btn{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-4);border:2px dashed var(--ocean-teal);border-radius:var(--radius-lg);background:#2dd4bf0a;color:var(--ocean-teal);font-family:var(--font-family);font-size:var(--font-body);font-weight:700;cursor:pointer;transition:all .2s}.voice-record-btn:hover{background:#2dd4bf1a;border-color:var(--ocean-teal)}.voice-mic{font-size:1.5rem}.voice-divider{display:flex;align-items:center;gap:var(--sp-3);color:var(--muted-slate);font-size:var(--font-xs)}.voice-divider:before,.voice-divider:after{content:"";flex:1;height:1px;background:var(--surface-highest)}.voice-text-input{display:flex;gap:var(--sp-2)}.voice-text-input input{flex:1;min-width:0}.voice-parse-btn{padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-md);background:var(--ocean-teal);color:#fff;font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.voice-parse-btn:disabled{opacity:.5;cursor:not-allowed}.voice-error{font-size:var(--font-xs);color:var(--coral-rose);padding:var(--sp-2);background:#e8736c0f;border-radius:var(--radius-sm)}.voice-listening{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4);padding:var(--sp-6) 0}.voice-pulse-ring{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#2dd4bf1a;position:relative;animation:voicePulse 1.5s ease infinite}@keyframes voicePulse{0%,to{box-shadow:0 0 #2dd4bf4d}50%{box-shadow:0 0 0 20px #2dd4bf00}}.voice-mic-big{font-size:2.5rem}.voice-listening-text{font-weight:700;color:var(--ocean-teal);animation:fadeInOut 1.5s ease infinite}@keyframes fadeInOut{0%,to{opacity:1}50%{opacity:.5}}.voice-transcript-live{font-size:var(--font-small);color:var(--muted-slate);font-style:italic;text-align:center;min-height:20px}.voice-review{display:flex;flex-direction:column;gap:var(--sp-4)}.voice-review-header{display:flex;justify-content:space-between;align-items:center}.voice-ai-badge{font-size:var(--font-xs);font-weight:700;color:var(--ocean-teal);background:#2dd4bf14;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-full)}.voice-confidence{font-size:var(--font-xs);font-weight:600}.voice-confidence.high{color:#16a34a}.voice-confidence.low{color:var(--coral-rose)}.type-toggle{display:flex;background:var(--surface-low);border-radius:var(--radius-full);padding:3px}.toggle-btn{flex:1;padding:var(--sp-2) var(--sp-3);border:none;border-radius:var(--radius-full);background:transparent;font-family:var(--font-family);font-size:var(--font-small);font-weight:600;cursor:pointer;transition:all .2s;color:var(--muted-slate)}.toggle-btn.active.expense{background:#e8736c1f;color:var(--coral-rose)}.toggle-btn.active.income{background:#16a34a1f;color:#16a34a}.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-2)}.emoji-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-2) var(--sp-1);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);background:transparent;cursor:pointer;transition:all .15s;font-size:1.2rem;min-height:60px;height:auto}.emoji-btn.active{border-color:var(--ocean-teal);background:#2dd4bf0f}.emoji-label{font-size:.65rem;color:var(--text-primary);font-family:var(--font-family);white-space:normal;text-align:center;line-height:1.1;overflow:visible;max-width:100%}.wallet-selector{display:flex;gap:var(--sp-2)}.wallet-option{flex:1;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--surface-highest);border-radius:var(--radius-md);background:transparent;font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .15s}.wallet-option.active{border-color:var(--ocean-teal);background:#2dd4bf14;color:var(--ocean-teal)}.voice-actions{display:flex;flex-direction:column;gap:var(--sp-2)}.voice-learn-hint{font-size:var(--font-xs);color:var(--muted-slate);text-align:center;font-style:italic}.scan-section-divider{display:flex;align-items:center;gap:var(--sp-3);margin:var(--sp-6) 0;color:var(--muted-slate);font-size:var(--font-xs)}.scan-section-divider:before,.scan-section-divider:after{content:"";flex:1;height:1px;background:var(--surface-highest)}@media (max-width: 400px){.dashboard{padding:var(--sp-4);padding-top:env(safe-area-inset-top,var(--sp-6))}.wallet-cards{gap:var(--sp-3)}.wallet-card{padding:var(--sp-3)}.wallet-balance{font-size:1.15rem}.tx-card .tx-row{padding:var(--sp-2) 0}.tx-amount{font-size:var(--font-xs)}.tx-emoji{width:32px;height:32px;font-size:1.2rem}.cat-chip{padding:var(--sp-1);font-size:1rem}.cat-chip .cat-name{font-size:.55rem}}.btn-section-toggle{background:none;border:none;color:var(--ocean-teal);font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;cursor:pointer;margin-left:auto;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out)}.btn-section-toggle:hover{background:#2dd4bf14}.section-title{display:flex;align-items:center;gap:var(--sp-2)}.cat-manager{display:flex;flex-direction:column;gap:var(--sp-5)}.cat-group{display:flex;flex-direction:column;gap:var(--sp-2)}.cat-group-label{font-size:var(--font-xs);font-weight:700;color:var(--muted-slate);text-transform:uppercase;letter-spacing:.04em}.cat-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.cat-chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500;transition:transform var(--duration-fast) var(--ease-out)}.cat-chip.default{background:var(--surface-low);color:var(--deep-navy)}.cat-chip.custom{background:#2dd4bf1a;color:var(--ocean-teal)}.cat-type-badge{font-size:.6rem;opacity:.6;margin-left:var(--sp-1)}.cat-empty{font-size:var(--font-small);color:var(--muted-slate);font-style:italic;padding:var(--sp-2) 0}.cat-custom-list{display:flex;flex-direction:column;gap:var(--sp-2)}.cat-custom-item{animation:slide-up .2s var(--ease-out) both}.cat-display-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);padding:var(--sp-1) 0}.cat-actions{display:flex;align-items:center;gap:var(--sp-1)}.cat-action-btn{background:none;border:none;cursor:pointer;font-size:var(--font-xs);padding:var(--sp-1);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out);line-height:1}.cat-action-btn:hover{background:var(--surface-low)}.cat-action-btn.danger{color:var(--coral-rose);font-weight:600}.cat-edit-row{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) 0}.cat-add-form{display:flex;flex-direction:column;gap:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--surface-highest)}.cat-add-inputs{display:flex;gap:var(--sp-2);align-items:center}.cat-type-select{font-family:var(--font-family);font-size:var(--font-xs);padding:var(--sp-2) var(--sp-2);border:1.5px solid var(--surface-highest);border-radius:var(--radius-sm);background:var(--surface-card);color:var(--deep-navy);min-width:80px;cursor:pointer}.add-cat-btn{border:2px dashed var(--surface-highest)!important;background:transparent!important;opacity:.7;transition:all var(--duration-fast) var(--ease-out)}.add-cat-btn:hover,.add-cat-btn.active{opacity:1;border-color:var(--ocean-teal)!important;background:#2dd4bf0a!important}.new-cat-form{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-3);margin-top:var(--sp-2);background:var(--surface-low);border-radius:var(--radius-md);border:1px solid var(--surface-highest);animation:slide-up .2s var(--ease-out) both}.new-cat-inputs{display:flex;gap:var(--sp-2);align-items:center}.new-cat-emoji-input{width:48px;text-align:center;font-size:1.2rem;padding:var(--sp-2);border:1.5px solid var(--surface-highest);border-radius:var(--radius-sm);background:var(--surface-card);font-family:var(--font-family)}.new-cat-emoji-input:focus{border-color:var(--ocean-teal);outline:none}.new-cat-name-input{flex:1;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--surface-highest);border-radius:var(--radius-sm);background:var(--surface-card);font-family:var(--font-family);font-size:var(--font-small)}.new-cat-name-input:focus{border-color:var(--ocean-teal);outline:none}.new-cat-actions{display:flex;gap:var(--sp-2);justify-content:flex-end}.btn-sm{height:34px;padding:0 var(--sp-4);font-size:var(--font-xs)}.analytics-page{display:flex;flex-direction:column;gap:var(--sp-5)}.analytics-month-nav{display:flex;align-items:center;justify-content:center;gap:var(--sp-4)}.month-nav-btn{background:var(--surface-card);border:1.5px solid var(--surface-highest);border-radius:var(--radius-full);width:36px;height:36px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out);color:var(--deep-navy);font-weight:700}.month-nav-btn:hover:not(.disabled){background:var(--ocean-teal);color:#fff;border-color:var(--ocean-teal)}.month-nav-btn.disabled{opacity:.3;cursor:not-allowed}.month-nav-label{font-size:var(--font-body);font-weight:700;color:var(--deep-navy);text-transform:capitalize;min-width:140px;text-align:center}.analytics-filters{display:flex;gap:var(--sp-2);overflow-x:auto;padding-bottom:var(--sp-1)}.analytics-overview{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.overview-card{background:var(--surface-card);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--soul-shadow);display:flex;flex-direction:column;gap:var(--sp-1);position:relative;overflow:hidden;animation:slide-up .4s var(--ease-out) both}.overview-card:nth-child(1){animation-delay:0s}.overview-card:nth-child(2){animation-delay:.05s}.overview-card:nth-child(3){animation-delay:.1s}.overview-card.net{grid-column:1 / -1;text-align:center;padding:var(--sp-3) var(--sp-4);flex-direction:row;justify-content:center;align-items:center;gap:var(--sp-3)}.overview-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.overview-card.expense:before{background:var(--coral-rose)}.overview-card.income:before{background:var(--ocean-teal)}.overview-card.positive:before{background:var(--soft-mint)}.overview-card.negative:before{background:var(--coral-rose)}.overview-label{font-size:var(--font-xs);color:var(--muted-slate);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.overview-value{font-size:var(--font-lg);font-weight:800;color:var(--deep-navy);font-variant-numeric:tabular-nums}.overview-card.expense .overview-value{color:var(--coral-rose)}.overview-card.income .overview-value{color:var(--ocean-teal)}.overview-sign{font-size:var(--font-xs);font-weight:600}.change-indicator{font-size:var(--font-xs);font-weight:600;display:flex;align-items:center;gap:var(--sp-1)}.change-indicator.good{color:var(--ocean-teal)}.change-indicator.bad{color:var(--coral-rose)}.change-indicator.neutral{color:var(--muted-slate)}.change-vs{font-weight:400;color:var(--muted-slate);font-size:.65rem}.analytics-card{background:var(--surface-card);border-radius:var(--radius-lg);padding:var(--sp-5);box-shadow:var(--soul-shadow);animation:slide-up .4s var(--ease-out) .15s both}.analytics-card-title{font-size:var(--font-body);font-weight:700;margin-bottom:var(--sp-4);color:var(--deep-navy)}.analytics-empty{font-size:var(--font-small);color:var(--muted-slate);text-align:center;padding:var(--sp-6) 0;font-style:italic}.pie-chart-container{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4)}.pie-chart-svg{transform:rotate(-90deg);overflow:visible}.pie-slice{transition:all .3s var(--ease-out)}.pie-center-label{font-size:1.8rem;transform:rotate(90deg);transform-origin:center;dominant-baseline:central}.pie-center-value{font-size:.7rem;font-weight:700;fill:var(--muted-slate);transform:rotate(90deg);transform-origin:center;dominant-baseline:central}.pie-legend{width:100%;display:flex;flex-direction:column;gap:var(--sp-1)}.pie-legend-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;font-family:var(--font-family);font-size:var(--font-small);width:100%;text-align:left;transition:background var(--duration-fast) var(--ease-out)}.pie-legend-item:hover,.pie-legend-item.active{background:var(--surface-low)}.pie-legend-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pie-legend-emoji{flex-shrink:0}.pie-legend-name{flex:1;font-weight:500;color:var(--deep-navy)}.pie-legend-pct{font-weight:700;color:var(--deep-navy);min-width:32px;text-align:right}.pie-legend-amount{font-size:var(--font-xs);color:var(--muted-slate);min-width:80px;text-align:right;font-variant-numeric:tabular-nums}.bar-chart-scroll{overflow-x:auto;padding-bottom:var(--sp-2)}.bar-chart-svg{min-width:260px}.bar-income{fill:var(--ocean-teal);opacity:.85;transition:opacity var(--duration-fast)}.bar-income:hover{opacity:1}.bar-expense{fill:var(--coral-rose);opacity:.85;transition:opacity var(--duration-fast)}.bar-expense:hover{opacity:1}.bar-label{font-size:.5rem;fill:var(--muted-slate);font-weight:500}.bar-legend-text{font-size:.45rem;fill:var(--muted-slate);font-weight:500}.weekly-trend{display:flex;flex-direction:column;gap:var(--sp-3)}.weekly-summary{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-2)}.weekly-current{font-size:var(--font-small);color:var(--deep-navy)}.weekly-change{font-size:var(--font-xs);font-weight:600;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-full)}.weekly-change.up{color:var(--coral-rose);background:#e8736c1a}.weekly-change.down{color:var(--ocean-teal);background:#2dd4bf1a}.weekly-svg{max-height:100px}.weekly-area{fill:#2dd4bf14}.weekly-line{stroke:var(--ocean-teal);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.weekly-dot{fill:var(--ocean-teal);stroke:var(--surface-card);stroke-width:2}.top-categories{display:flex;flex-direction:column;gap:var(--sp-4)}.top-cat-item{display:flex;gap:var(--sp-3);align-items:flex-start;animation:slide-up .3s var(--ease-out) both}.top-cat-item:nth-child(1){animation-delay:0s}.top-cat-item:nth-child(2){animation-delay:.05s}.top-cat-item:nth-child(3){animation-delay:.1s}.top-cat-rank{font-size:var(--font-xs);font-weight:800;color:var(--muted-slate);min-width:24px;padding-top:var(--sp-1)}.top-cat-info{flex:1;display:flex;flex-direction:column;gap:var(--sp-1)}.top-cat-header{display:flex;justify-content:space-between;align-items:baseline}.top-cat-name{font-weight:600;font-size:var(--font-small);color:var(--deep-navy)}.top-cat-amount{font-weight:700;font-size:var(--font-small);color:var(--deep-navy);font-variant-numeric:tabular-nums}.top-cat-bar-track{height:6px;background:var(--surface-low);border-radius:var(--radius-full);overflow:hidden}.top-cat-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s var(--ease-out)}.top-cat-meta{display:flex;justify-content:space-between;align-items:center}.top-cat-pct{font-size:var(--font-xs);color:var(--muted-slate)}.top-cat-change{font-size:var(--font-xs);font-weight:600}.top-cat-change.up{color:var(--coral-rose)}.top-cat-change.down{color:var(--ocean-teal)}@media (max-width: 400px){.analytics-overview{grid-template-columns:1fr 1fr;gap:var(--sp-2)}.overview-card{padding:var(--sp-3)}.overview-value{font-size:var(--font-body)}.pie-chart-svg{width:160px;height:160px}}@media (min-width: 641px){.analytics-overview{grid-template-columns:1fr 1fr 1fr}.overview-card.net{grid-column:auto}.pie-chart-container{flex-direction:row;gap:var(--sp-6)}.pie-legend{max-width:320px}}.budget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}.budget-header .analytics-card-title{margin-bottom:0}.budget-add-form{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-3);background:var(--surface-low);border-radius:var(--radius-md);margin-bottom:var(--sp-4);animation:slide-up .2s var(--ease-out) both}.budget-cat-select{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.budget-limit-row{display:flex;gap:var(--sp-2);align-items:center}.budget-list{display:flex;flex-direction:column;gap:var(--sp-3)}.budget-item{padding:var(--sp-3);border-radius:var(--radius-md);background:var(--surface);border-left:4px solid var(--ocean-teal);animation:slide-up .3s var(--ease-out) both;transition:border-color var(--duration-fast)}.budget-item.warning{border-left-color:#f59e0b;background:#f59e0b0a}.budget-item.exceeded{border-left-color:var(--coral-rose);background:#e8736c0a}.budget-item-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--sp-2)}.budget-item-name{font-weight:600;font-size:var(--font-small);color:var(--deep-navy)}.budget-item-amounts{display:flex;align-items:baseline;gap:var(--sp-1);font-variant-numeric:tabular-nums}.budget-spent{font-weight:700;font-size:var(--font-small);color:var(--deep-navy)}.budget-divider{color:var(--muted-slate);font-size:var(--font-xs)}.budget-limit{font-size:var(--font-xs);color:var(--muted-slate)}.budget-bar-track{height:8px;background:var(--surface-low);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--sp-2)}.budget-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s var(--ease-out);background:var(--ocean-teal)}.budget-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.budget-bar-fill.exceeded{background:linear-gradient(90deg,var(--coral-rose),#ef4444)}.budget-item-footer{display:flex;align-items:center;gap:var(--sp-2)}.budget-status-label{font-size:var(--font-xs);font-weight:600;flex:1}.budget-status-label.safe{color:var(--ocean-teal)}.budget-status-label.warning{color:#f59e0b}.budget-status-label.exceeded{color:var(--coral-rose)}.budget-pct{font-size:var(--font-xs);font-weight:700;color:var(--muted-slate)}.ai-card{background:linear-gradient(135deg,var(--surface-card) 0%,rgba(45,212,191,.03) 100%)}.ai-cta{text-align:center;padding:var(--sp-4) 0}.ai-cta-text{font-size:var(--font-small);color:var(--muted-slate);margin-bottom:var(--sp-4);line-height:1.5}.ai-loading-skeleton{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-2) 0}.ai-insight-item.pulse{background:var(--surface-low);border:1px solid transparent;animation:pulse-glow-light 2s cubic-bezier(.4,0,.6,1) infinite;pointer-events:none}@keyframes pulse-glow-light{0%,to{opacity:.8}50%{opacity:.4;background:var(--surface-border)}}.skeleton-icon{width:24px;height:24px;border-radius:50%;background:var(--surface-border);flex-shrink:0}.skeleton-text-group{flex:1;display:flex;flex-direction:column;gap:var(--sp-2);margin-top:6px}.skeleton-line{height:12px;background:var(--surface-border);border-radius:var(--radius-sm);width:100%}.skeleton-line.short{width:70%}.ai-insights-list{display:flex;flex-direction:column;gap:var(--sp-3)}.ai-insight-item{display:flex;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--radius-md);background:var(--surface);border-left:3px solid var(--ocean-teal);animation:slide-up .3s var(--ease-out) both}.ai-insight-item:nth-child(1){animation-delay:0s}.ai-insight-item:nth-child(2){animation-delay:.05s}.ai-insight-item:nth-child(3){animation-delay:.1s}.ai-insight-item:nth-child(4){animation-delay:.15s}.ai-insight-item:nth-child(5){animation-delay:.2s}.ai-insight-item.warning{border-left-color:#f59e0b;background:#f59e0b0a}.ai-insight-item.success{border-left-color:var(--soft-mint);background:#6decb90a}.ai-insight-icon{font-size:1.2rem;flex-shrink:0;padding-top:1px}.ai-insight-text{font-size:var(--font-small);color:var(--deep-navy);line-height:1.5}.pvs-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--sp-4);align-items:start}.pvs-column{display:flex;flex-direction:column;gap:var(--sp-2);text-align:center}.pvs-label{font-size:var(--font-xs);font-weight:700;color:var(--muted-slate);text-transform:uppercase;letter-spacing:.03em}.pvs-amount{font-size:var(--font-lg);font-weight:800;color:var(--deep-navy);font-variant-numeric:tabular-nums}.pvs-pct{font-size:var(--font-xs);color:var(--muted-slate)}.pvs-bar-track{height:6px;background:var(--surface-low);border-radius:var(--radius-full);overflow:hidden}.pvs-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s var(--ease-out)}.pvs-bar-fill.personal{background:var(--ocean-teal)}.pvs-bar-fill.shared{background:var(--coral-rose)}.pvs-divider{width:1px;background:var(--surface-highest);align-self:stretch}.pvs-cats{display:flex;flex-direction:column;gap:var(--sp-1);margin-top:var(--sp-1)}.pvs-cat{font-size:var(--font-xs);color:var(--muted-slate);text-align:center;line-height:1.4}@media (max-width: 360px){.pvs-grid{grid-template-columns:1fr;gap:var(--sp-3)}.pvs-divider{width:100%;height:1px}.pvs-amount{font-size:var(--font-body)}}.analytics-scope-filter{display:flex;justify-content:center;gap:var(--sp-2);margin-bottom:var(--sp-5);background:var(--surface-low);padding:var(--sp-1);border-radius:var(--radius-full)}.scope-chip{flex:1;padding:var(--sp-2) var(--sp-3);background:transparent;border:none;border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-xs);font-weight:600;color:var(--muted-slate);cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);text-align:center}.scope-chip.active{background:var(--surface);color:var(--deep-navy);box-shadow:0 2px 8px #00000014}.recurring-summary{background:linear-gradient(135deg,var(--deep-navy) 0%,#2a3a5c 100%);border-radius:20px;padding:var(--sp-6) var(--sp-5);box-shadow:0 10px 25px -5px #1a2d4a66,inset 0 1px #ffffff1a;margin-bottom:var(--sp-6);position:relative;overflow:hidden}.recurring-summary:before{content:"";position:absolute;top:-50%;right:-20%;width:150px;height:150px;background:radial-gradient(circle,rgba(45,212,191,.15) 0%,transparent 70%);border-radius:50%}.recurring-summary-row{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-5);position:relative;z-index:1}.recurring-stat{display:flex;flex-direction:column;gap:4px}.recurring-stat:first-child{text-align:left}.recurring-stat:nth-child(2){text-align:center}.recurring-stat:last-child{text-align:right}.recurring-stat-label{font-size:11px;color:#fff9;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.recurring-stat-value{font-size:var(--font-body);font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.recurring-stat-value.paid{color:var(--soft-mint)}.recurring-stat-value.remaining{color:#ff9e99}.recurring-progress-bar{height:8px;background:#ffffff1a;border-radius:var(--radius-full);overflow:hidden;position:relative;z-index:1}.recurring-progress-fill{height:100%;background:linear-gradient(90deg,var(--ocean-teal),#4ade80);border-radius:var(--radius-full);transition:width .8s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 10px #2dd4bf80}.recurring-progress-label{font-size:var(--font-xs);color:#ffffffb3;text-align:right;margin-top:var(--sp-3);position:relative;z-index:1}.recurring-list{display:flex;flex-direction:column;gap:var(--sp-4)}.recurring-card{display:flex;align-items:center;gap:var(--sp-3);background:var(--surface-card);border-radius:16px;padding:var(--sp-4) var(--sp-4);box-shadow:0 2px 8px #0000000a,0 1px 2px #00000005;border:1px solid var(--surface-border);position:relative;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out);animation:slide-up .4s var(--ease-out) both}.recurring-card:active{transform:scale(.98)}.recurring-card:before{content:"";position:absolute;left:0;top:10%;bottom:10%;width:4px;border-radius:0 4px 4px 0;transition:background-color .3s ease}.recurring-card.overdue:before{background-color:var(--coral-rose);box-shadow:2px 0 8px #e8736c4d}.recurring-card.overdue{background:linear-gradient(to right,rgba(232,115,108,.04),var(--surface-card) 20%);border-color:#e8736c33}.recurring-card.pending:before{background-color:#f59e0b}.recurring-card.paid:before{background-color:var(--ocean-teal)}.recurring-card.paid{opacity:.65;background:var(--surface-base);box-shadow:none}.recurring-card-left{display:flex;align-items:center;gap:var(--sp-3);flex:1;min-width:0}.recurring-emoji{font-size:1.5rem;flex-shrink:0;width:44px;height:44px;border-radius:12px;background:#2dd4bf1a;display:flex;align-items:center;justify-content:center}.recurring-info{display:flex;flex-direction:column;gap:1px;min-width:0}.recurring-name{font-size:var(--font-small);font-weight:600;color:var(--deep-navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recurring-meta{font-size:var(--font-xs);color:var(--muted-slate)}.recurring-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-1);flex-shrink:0}.recurring-amount{font-size:var(--font-small);font-weight:700;color:var(--deep-navy);font-variant-numeric:tabular-nums}.recurring-paid-badge{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.recurring-paid-amount{font-size:var(--font-small);font-weight:600;color:var(--ocean-teal);font-variant-numeric:tabular-nums}.recurring-paid-label{font-size:var(--font-xs);color:var(--ocean-teal)}.btn-pay{padding:var(--sp-2) var(--sp-4);background:var(--surface-card);color:var(--ocean-teal);border:1.5px solid var(--ocean-teal);border-radius:20px;font-size:12px;font-weight:700;font-family:var(--font-family);cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 10px #2dd4bf26}.btn-pay:active{transform:scale(.92);background:#2dd4bf1a}.recurring-delete{position:absolute;top:var(--sp-2);right:var(--sp-2);width:20px;height:20px;border:none;background:none;color:var(--muted-slate);font-size:10px;cursor:pointer;opacity:.4;transition:opacity var(--duration-fast);display:flex;align-items:center;justify-content:center}.recurring-delete:hover{opacity:1;color:var(--coral-rose)}.recurring-add-btn{width:100%;padding:var(--sp-4);margin-top:var(--sp-5);background:linear-gradient(135deg,#2dd4bf14,#2dd4bf05);border:1.5px dashed rgba(45,212,191,.4);border-radius:16px;font-family:var(--font-family);font-size:var(--font-small);font-weight:600;color:var(--ocean-teal);cursor:pointer;transition:all .3s var(--ease-out)}.recurring-add-btn:hover{background:#2dd4bf1f;border-style:solid;transform:translateY(-2px);box-shadow:0 8px 16px #2dd4bf1a}.recurring-add-btn:active{transform:translateY(0)}.add-bill-sheet{max-height:85vh;overflow-y:auto}.bill-presets{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-4)}.bill-preset-chip{padding:var(--sp-1) var(--sp-3);background:var(--surface-low);border:1px solid var(--surface-border);border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-xs);color:var(--deep-navy);cursor:pointer;transition:all var(--duration-fast)}.bill-preset-chip:hover{background:#2dd4bf14;border-color:var(--ocean-teal)}.presets-toggle{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) 0;margin-bottom:var(--sp-2);background:none;border:none;font-family:var(--font-family);font-size:var(--font-xs);font-weight:500;color:var(--ocean-teal);cursor:pointer;transition:color var(--duration-fast)}.presets-toggle:hover{color:#0d9488}.presets-arrow{display:inline-block;transition:transform .25s var(--ease-out);font-size:12px}.presets-arrow.open{transform:rotate(90deg)}.bill-category-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.bill-cat-chip{padding:var(--sp-1) var(--sp-3);background:var(--surface-low);border:1.5px solid var(--surface-border);border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-xs);color:var(--deep-navy);cursor:pointer;transition:all var(--duration-fast)}.bill-cat-chip:hover{border-color:var(--ocean-teal)}.bill-cat-chip.active{background:#2dd4bf1f;border-color:var(--ocean-teal);color:var(--ocean-teal);font-weight:600}.input-with-emoji{display:flex;gap:var(--sp-2)}.emoji-input{width:48px;text-align:center;font-size:1.2rem;flex-shrink:0}.input-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.menu-grid{display:flex;flex-direction:column;gap:var(--sp-4);margin-top:var(--sp-6)}.menu-card{display:flex;align-items:center;gap:var(--sp-4);background:var(--surface);padding:var(--sp-4);border-radius:var(--radius-lg);border:1px solid var(--surface-border);box-shadow:0 4px 15px #00000008;text-align:left;cursor:pointer;transition:transform .2s var(--ease-out),box-shadow .2s;width:100%}.menu-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000000f;border-color:var(--ocean-teal-20)}.menu-card-icon{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--surface-low);border-radius:var(--radius-md);flex-shrink:0}.menu-card-content{flex:1}.menu-card-content h3{font-size:var(--font-body);font-weight:600;color:var(--deep-navy);margin-bottom:var(--sp-1)}.menu-card-content p{font-size:var(--font-xs);color:var(--muted-slate);margin:0;line-height:1.4}.menu-card-arrow{color:var(--ocean-teal);font-size:1.5rem;font-weight:300;margin-left:var(--sp-2)}
