@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--black: #000000;--white: #ffffff;--gray-50: #fafafa;--gray-100: #f4f4f5;--gray-200: #e4e4e7;--gray-300: #d4d4d8;--gray-400: #a1a1aa;--gray-500: #71717a;--gray-600: #52525b;--gray-700: #3f3f46;--gray-800: #27272a;--gray-900: #18181b;--emerald-200: #a7f3d0;--emerald-300: #6ee7b7;--emerald-400: #34d399;--emerald-500: #10b981;--emerald-600: #059669;--emerald-700: #047857;--red-500: #ef4444;--red-100: #fee2e2}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:radial-gradient(ellipse 80% 60% at 0% 0%,rgba(16,185,129,.25) 0%,transparent 70%),radial-gradient(ellipse 60% 50% at 100% 0%,rgba(59,130,246,.2) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 100% 100%,rgba(139,92,246,.18) 0%,transparent 70%),radial-gradient(ellipse 70% 50% at 0% 100%,rgba(236,72,153,.15) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 50% 50%,rgba(16,185,129,.1) 0%,transparent 70%),linear-gradient(135deg,#f0fdf4,#faf5ff,#fdf2f8);background-attachment:fixed;color:var(--gray-900);line-height:1.5}#root{min-height:100vh}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.5)}.nav-container{max-width:1100px;margin:0 auto;padding:0 24px;height:64px;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:10px;text-decoration:none}.logo-img{height:120px;width:auto;object-fit:contain;margin-left:-60px;margin-top:10px}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:16px;box-shadow:0 2px 8px #10b9814d}.logo-text{font-size:18px;font-weight:700;color:var(--gray-900);letter-spacing:-.3px}.nav-right{display:flex;align-items:center;gap:6px}.nav-link{padding:8px 16px;color:var(--gray-600);text-decoration:none;font-weight:500;font-size:14px;border-radius:8px;transition:all .2s}.nav-link:hover,.nav-link.active{color:var(--emerald-600);background:#10b98114}.nav-dropdown{position:relative}.nav-dropdown-trigger{display:flex;align-items:center;gap:4px;padding:8px 12px;color:var(--gray-600);background:none;border:none;font-weight:500;font-size:14px;border-radius:8px;cursor:pointer;transition:all .2s}.nav-dropdown-trigger:hover,.nav-dropdown-trigger.active{color:var(--emerald-600);background:#10b98114}.nav-dropdown-trigger svg{transition:transform .2s}.nav-dropdown:hover .nav-dropdown-trigger svg{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--white);border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 10px 40px #0000001a;min-width:160px;padding:6px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s}.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown-item{display:block;padding:10px 14px;color:var(--gray-600);text-decoration:none;font-size:14px;font-weight:500;border-radius:6px;transition:all .15s}.nav-dropdown-item:hover,.nav-dropdown-item.active{color:var(--emerald-600);background:#10b98114}.nav-btn-primary{display:inline-flex;align-items:center;padding:8px 16px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);font-size:14px;font-weight:500;border-radius:8px;text-decoration:none;border:none;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #10b9814d}.nav-btn-primary:hover{background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.nav-btn-outline{display:inline-flex;align-items:center;padding:8px 16px;background:transparent;color:var(--gray-600);font-size:14px;font-weight:500;border-radius:8px;border:1px solid var(--gray-200);cursor:pointer;transition:all .2s}.nav-btn-outline:hover{background:#10b98114;color:var(--emerald-600);border-color:var(--emerald-200)}.profile-wrapper{position:relative;margin-left:8px}.profile-avatar{width:40px;height:40px;border-radius:50%;border:2px solid transparent;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:all .2s;padding:0}.profile-avatar:hover{border-color:var(--emerald-400);box-shadow:0 0 0 3px #10b98133}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{color:var(--white);font-weight:600;font-size:14px;letter-spacing:.5px}.dropdown-overlay{position:fixed;inset:0;z-index:150}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--white);border-radius:12px;box-shadow:0 10px 40px #00000026;border:1px solid var(--gray-200);z-index:200;overflow:hidden}.dropdown-header{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50)}.dropdown-avatar{width:44px;height:44px;border-radius:50%;background:transparent;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.dropdown-avatar img{width:100%;height:100%;object-fit:cover}.dropdown-avatar span{color:var(--white);font-weight:600;font-size:16px}.dropdown-info{display:flex;flex-direction:column;min-width:0}.dropdown-name{font-weight:600;font-size:14px;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-email{font-size:12px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-divider{height:1px;background:var(--gray-200)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:transparent;color:var(--gray-700);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left;text-decoration:none}.dropdown-item:hover{background:var(--gray-50);color:var(--gray-900)}.dropdown-item svg{color:var(--gray-500);flex-shrink:0}.dropdown-item:hover svg{color:var(--gray-700)}.dropdown-item.logout{color:var(--red-500)}.dropdown-item.logout:hover{background:var(--red-100)}.dropdown-item.logout svg{color:var(--red-500)}.profile-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.profile-modal{background:var(--white);border-radius:16px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003;overflow:hidden}.profile-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--gray-200)}.profile-modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--gray-900)}.modal-close-btn{width:32px;height:32px;border:none;background:var(--gray-100);border-radius:8px;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close-btn:hover{background:var(--gray-200);color:var(--gray-700)}.profile-modal-body{padding:24px;max-height:60vh;overflow-y:auto}.profile-picture-section{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.profile-picture-preview{width:100px;height:100px;border-radius:50%;background:transparent;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:16px;box-shadow:0 4px 12px #10b9814d}.profile-picture-preview img{width:100%;height:100%;object-fit:cover}.preview-initials{color:var(--white);font-weight:700;font-size:32px;letter-spacing:1px}.profile-picture-actions{display:flex;gap:8px}.picture-action-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;border:none}.picture-action-btn.upload{background:#10b9811a;color:var(--emerald-600)}.picture-action-btn.upload:hover{background:#10b98133}.picture-action-btn.remove{background:var(--gray-100);color:var(--gray-600)}.picture-action-btn.remove:hover{background:var(--red-100);color:var(--red-500)}.profile-form-group{margin-bottom:16px}.profile-form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}.profile-form-group input{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;color:var(--gray-900);transition:border-color .15s}.profile-form-group input:focus{outline:none;border-color:var(--emerald-400)}.profile-form-group input.disabled{background:var(--gray-50);color:var(--gray-500);cursor:not-allowed}.form-hint{display:block;font-size:12px;color:var(--gray-400);margin-top:4px}.profile-modal-footer{display:flex;gap:8px;padding:16px 24px;background:var(--gray-50);border-top:1px solid var(--gray-200)}.modal-btn{flex:1;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:none}.modal-btn.cancel{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-200)}.modal-btn.cancel:hover{background:var(--gray-100)}.modal-btn.save{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);box-shadow:0 2px 8px #10b9814d}.modal-btn.save:hover{background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.password-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-200)}.password-section-header{margin-bottom:16px}.password-section-header h3{font-size:15px;font-weight:600;color:var(--gray-900);margin:0}.password-message{padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:16px}.password-message.error{background:var(--red-100);color:var(--red-500)}.password-message.success{background:#10b9811a;color:var(--emerald-600)}.change-password-btn{width:100%;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid var(--emerald-500);background:transparent;color:var(--emerald-600);margin-top:8px}.change-password-btn:hover:not(:disabled){background:#10b9811a}.change-password-btn:disabled{opacity:.6;cursor:not-allowed}.delete-account-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--red-100)}.delete-section-header{margin-bottom:16px}.delete-section-header h3{font-size:15px;font-weight:600;color:var(--red-500);margin:0}.delete-account-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid var(--red-500);background:transparent;color:var(--red-500)}.delete-account-btn:hover{background:var(--red-100)}.delete-confirm-box{background:var(--red-100);border-radius:8px;padding:16px}.delete-warning{font-size:13px;color:var(--red-500);margin-bottom:16px;line-height:1.5}.delete-error{padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:12px;background:var(--white);color:var(--red-500);border:1px solid var(--red-500)}.delete-confirm-actions{display:flex;gap:8px;margin-top:12px}.delete-cancel-btn{flex:1;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--gray-300);background:var(--white);color:var(--gray-700);transition:all .15s}.delete-cancel-btn:hover{background:var(--gray-100)}.delete-confirm-btn{flex:1;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;background:var(--red-500);color:var(--white);transition:all .15s}.delete-confirm-btn:hover:not(:disabled){background:#dc2626}.delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.nav-container{height:56px;padding:0 16px}.nav-link{padding:6px 10px;font-size:13px}.nav-btn-primary,.nav-btn-outline{padding:6px 12px;font-size:13px}.profile-dropdown{width:240px}.profile-modal{max-width:100%;margin:10px}.profile-picture-preview{width:80px;height:80px}.preview-initials{font-size:26px}.profile-picture-actions{flex-direction:column;width:100%}.picture-action-btn{justify-content:center}}.avatar-component{border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;transition:all .3s ease;position:relative}.avatar-component.avatar-sm{width:36px;height:36px}.avatar-component.avatar-md{width:40px;height:40px}.avatar-component.avatar-lg{width:44px;height:44px}.avatar-component.avatar-xl{width:100%;height:100%}.avatar-component img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-component .avatar-initials-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);font-weight:600;border-radius:50%}.avatar-sm .avatar-initials-inner,.avatar-md .avatar-initials-inner{font-size:14px}.avatar-lg .avatar-initials-inner{font-size:16px}.avatar-xl .avatar-initials-inner{font-size:32px;font-weight:700}.avatar-component .avatar-dicebear{width:100%;height:100%;object-fit:cover;border-radius:50%;background:var(--gray-100);animation:avatarFadeIn .4s ease;position:relative;z-index:1}@keyframes avatarFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.avatar-religious-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2}.persona-badge{display:flex;align-items:center;gap:6px;margin-top:8px;margin-bottom:4px;padding:4px 12px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:20px;font-size:12px;font-weight:600;color:var(--gray-700);letter-spacing:.3px}.persona-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--emerald-500);flex-shrink:0}.avatar-frame-silver_ring{border:3px solid #c0c0c0;box-shadow:0 0 12px #c0c0c080}.avatar-frame-gold_ring{border:3px solid #fbbf24;box-shadow:0 0 16px #fbbf2480}.avatar-frame-emerald_glow{border:3px solid var(--emerald-400);box-shadow:0 0 20px #34d39999,0 0 40px #10b98133;animation:emeraldPulse 3s ease-in-out infinite}@keyframes emeraldPulse{0%,to{box-shadow:0 0 20px #34d39999,0 0 40px #10b98133}50%{box-shadow:0 0 28px #34d399cc,0 0 56px #10b9814d}}.avatar-frame-streak_flame{border:3px solid #f97316;box-shadow:0 0 16px #f9731680;animation:flamePulse 2s ease-in-out infinite}@keyframes flamePulse{0%,to{box-shadow:0 0 16px #f9731680,0 0 32px #ef44441a}50%{box-shadow:0 0 24px #f97316b3,0 0 48px #ef444433}}.avatar-sm[class*=avatar-frame-]{border-width:2px}.avatar-sm.avatar-frame-emerald_glow,.avatar-sm.avatar-frame-streak_flame{animation:none}.home{min-height:100vh}.main-content{max-width:1000px;margin:0 auto;padding:0 24px}.landing{padding-top:64px}.hero{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:80px 0 60px}.hero-content{max-width:480px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#10b9811a;border-radius:100px;font-size:12px;font-weight:600;color:var(--emerald-600);margin-bottom:24px}.badge-dot{width:8px;height:8px;background:var(--emerald-500);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hero-title{font-size:48px;font-weight:700;color:var(--gray-900);line-height:1.1;margin:0 0 16px;letter-spacing:-1.5px}.gradient-text{background:linear-gradient(135deg,var(--emerald-500),#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:17px;color:var(--gray-500);line-height:1.6;margin:0 0 32px}.hero-actions{display:flex;gap:12px}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;background:var(--gray-900);color:#fff;font-size:15px;font-weight:500;border-radius:12px;text-decoration:none;transition:all .2s}.btn-primary:hover{background:var(--gray-800);transform:translateY(-2px);box-shadow:0 10px 20px #00000026}.btn-ghost{display:inline-flex;align-items:center;padding:14px 26px;background:transparent;color:var(--gray-600);font-size:15px;font-weight:500;border-radius:12px;text-decoration:none;transition:all .2s}.btn-ghost:hover{color:var(--gray-900);background:#0000000a}.hero-visual{display:flex;justify-content:flex-end}.budget-preview{width:100%;max-width:360px;padding:28px;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:1px solid rgba(255,255,255,.8);box-shadow:0 25px 50px #0000001a}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.preview-title{font-size:13px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.preview-badge{padding:4px 10px;background:var(--emerald-500);color:#fff;font-size:11px;font-weight:600;border-radius:6px}.preview-amount{margin-bottom:16px}.amount-value{display:block;font-size:40px;font-weight:700;color:var(--gray-900);letter-spacing:-1px;line-height:1}.amount-label{font-size:14px;color:var(--gray-500)}.preview-progress{margin-bottom:24px}.progress-track{height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:var(--emerald-500);border-radius:4px;transition:width .5s ease}.progress-text{font-size:12px;color:var(--gray-500)}.preview-categories{display:flex;flex-direction:column;gap:12px}.cat-row{display:grid;grid-template-columns:12px 90px 1fr 50px;align-items:center;gap:10px}.cat-dot{width:10px;height:10px;border-radius:50%}.cat-dot.green{background:var(--emerald-500)}.cat-dot.orange{background:#f59e0b}.cat-dot.purple{background:#8b5cf6}.cat-dot.blue{background:#3b82f6}.cat-name{font-size:13px;color:var(--gray-700)}.cat-bar{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.cat-fill{height:100%;background:var(--emerald-500);border-radius:3px}.cat-fill.warning{background:#f59e0b}.cat-value{font-size:12px;color:var(--gray-500);text-align:right}.features-section{padding:60px 0}.section-header{text-align:center;margin-bottom:48px}.section-label{display:inline-block;font-size:12px;font-weight:600;color:var(--emerald-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.section-title{font-size:32px;font-weight:700;color:var(--gray-900);margin:0;letter-spacing:-.5px}.features-bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.feature-card{padding:24px;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:18px;border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 16px 32px #00000014}.feature-card h3{font-size:16px;font-weight:600;color:var(--gray-900);margin:0 0 6px}.feature-card p{font-size:13px;color:var(--gray-500);margin:0;line-height:1.5}.feature-main{grid-column:span 2;grid-row:span 2}.feature-main-icon{width:56px;height:56px;background:var(--emerald-500);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:20px}.feature-main h3{font-size:20px;margin-bottom:8px}.feature-main p{font-size:15px;margin-bottom:24px}.feature-mini-visual{display:flex;flex-direction:column;gap:12px;padding:20px;background:var(--gray-50);border-radius:12px}.mini-cat{display:flex;align-items:center;gap:12px}.mini-cat span{width:60px;font-size:13px;color:var(--gray-600)}.mini-track{flex:1;height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}.mini-fill{height:100%;background:var(--emerald-500);border-radius:4px}.mini-fill.warn{background:#f59e0b}.feature-icon{width:48px;height:48px;background:var(--gray-100);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--gray-600);margin-bottom:16px}.feature-dark{background:linear-gradient(145deg,#1a1a2e,#16213e);border:none;position:relative}.feature-dark h3,.feature-dark p{color:#fff}.feature-dark p{color:#fff9}.feature-icon-light{width:48px;height:48px;background:#ffffff1a;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:16px}.feature-badge{position:absolute;top:16px;right:16px;padding:4px 10px;background:var(--emerald-500);color:#fff;font-size:10px;font-weight:600;border-radius:6px}.how-section{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:60px 0}.how-content{max-width:400px}.how-content .section-label{text-align:left}.how-content .section-title{text-align:left;margin-bottom:32px}.steps-list{display:flex;flex-direction:column;gap:24px}.step-row{display:flex;gap:16px}.step-num{width:40px;height:40px;background:var(--emerald-500);color:#fff;font-size:16px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-text h4{font-size:15px;font-weight:600;color:var(--gray-900);margin:0 0 4px}.step-text p{font-size:14px;color:var(--gray-500);margin:0}.how-visual{display:flex;justify-content:center}.phone-mock{width:240px;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:32px;border:1px solid rgba(255,255,255,.8);box-shadow:0 25px 50px #00000026;padding:24px}.phone-screen{text-align:center}.phone-label{display:block;font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:20px}.phone-ring-wrap{position:relative;width:140px;height:140px;margin:0 auto 16px}.phone-ring{width:100%;height:100%}.ring-bg{fill:none;stroke:var(--gray-200);stroke-width:3}.ring-fill{fill:none;stroke:var(--emerald-500);stroke-width:3;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center}.ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.ring-percent{display:block;font-size:28px;font-weight:700;color:var(--gray-900);line-height:1}.ring-text{font-size:12px;color:var(--gray-500)}.phone-amount{font-size:18px;font-weight:600;color:var(--gray-900)}.cta{padding:40px 0 60px}.cta-inner{background:linear-gradient(135deg,var(--emerald-500),#3b82f6);padding:64px 40px;border-radius:28px;text-align:center}.cta h2{font-size:28px;font-weight:700;color:#fff;margin:0 0 8px}.cta p{font-size:16px;color:#fffc;margin:0 0 28px}.btn-cta{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:#fff;color:var(--gray-900);font-size:15px;font-weight:600;border-radius:12px;text-decoration:none;transition:all .2s}.btn-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0003}.footer{display:flex;justify-content:space-between;align-items:center;padding:24px 0 40px}.footer-logo{font-size:18px;font-weight:700;color:var(--gray-900)}.footer-links{display:flex;align-items:center;gap:16px}.footer-links a{font-size:14px;color:var(--gray-500);text-decoration:none}.footer-links a:hover{color:var(--gray-900)}.footer-dot{width:4px;height:4px;background:var(--gray-300);border-radius:50%}.dashboard{padding:100px 0 60px}.loading-state{padding:100px 0;text-align:center;color:var(--gray-500);font-size:15px}.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.greeting-label{font-size:14px;color:var(--gray-500);display:block}.dash-greeting h1{font-size:36px;font-weight:700;color:var(--gray-900);margin:0;letter-spacing:-.5px}.dash-actions{display:flex;gap:10px}.action-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#fff;border:1px solid var(--gray-200);color:var(--gray-700);font-size:14px;font-weight:500;border-radius:10px;text-decoration:none;transition:all .2s}.action-btn:hover{background:var(--gray-50);border-color:var(--gray-300)}.action-btn.ai{background:var(--gray-900);border-color:var(--gray-900);color:#fff}.action-btn.ai:hover{background:var(--gray-800)}.budget-hero{display:flex;align-items:center;gap:40px;padding:32px;background:linear-gradient(135deg,var(--emerald-500),#10a37f);border-radius:24px;text-decoration:none;margin-bottom:24px;position:relative;overflow:hidden;transition:all .3s ease}.budget-hero:hover{transform:translateY(-4px);box-shadow:0 20px 40px #10b9814d}.budget-hero-left{flex:1}.budget-hero-label{display:block;font-size:13px;font-weight:600;color:#fffc;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.budget-hero-amount{display:flex;align-items:baseline;gap:4px;margin-bottom:16px}.hero-currency{font-size:28px;font-weight:600;color:#fff}.hero-value{font-size:48px;font-weight:700;color:#fff;letter-spacing:-1px;line-height:1}.hero-remaining{font-size:16px;color:#fffc;margin-left:8px}.budget-hero-bar{max-width:300px}.hero-bar-track{height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden;margin-bottom:8px}.hero-bar-fill{height:100%;background:#fff;border-radius:4px}.hero-bar-text{font-size:13px;color:#fffc}.budget-hero-right{position:relative;width:120px;height:120px}.budget-ring{width:100%;height:100%}.budget-ring .ring-bg{stroke:#ffffff4d}.budget-ring .ring-fill{stroke:#fff}.budget-ring-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.budget-ring-text .ring-percent{font-size:24px;color:#fff}.budget-ring-text .ring-label{font-size:11px;color:#fffc}.budget-hero-arrow{position:absolute;right:24px;top:50%;transform:translateY(-50%);color:#fff9;transition:all .2s}.budget-hero:hover .budget-hero-arrow{color:#fff;transform:translateY(-50%) translate(4px)}.budget-hero.empty{background:linear-gradient(135deg,var(--gray-400),var(--gray-500))}.budget-hero.empty .hero-value{font-size:24px}.budget-hero.empty .hero-bar-text{color:#ffffffb3;font-size:14px;margin-top:8px}.quick-stats{display:flex;gap:16px;margin-bottom:24px}.quick-stat{flex:1;padding:16px 20px;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.8)}.quick-stat .stat-label{display:block;font-size:12px;color:var(--gray-500);margin-bottom:4px}.quick-stat .stat-value{font-size:20px;font-weight:700;color:var(--gray-900)}.budget-categories{margin-bottom:24px}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.categories-header h2{font-size:16px;font-weight:600;color:var(--gray-900);margin:0}.view-link{font-size:13px;color:var(--emerald-600);text-decoration:none;font-weight:500}.view-link:hover{text-decoration:underline}.categories-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.category-card{padding:16px 20px;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;border:1px solid rgba(255,255,255,.8)}.category-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.category-dot{width:10px;height:10px;border-radius:50%}.category-dot.green{background:var(--emerald-500)}.category-dot.orange{background:#f59e0b}.category-dot.purple{background:#8b5cf6}.category-dot.blue{background:#3b82f6}.category-name{flex:1;font-size:14px;font-weight:500;color:var(--gray-700)}.category-amount{font-size:13px;color:var(--gray-500)}.category-bar{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.category-fill{height:100%;background:var(--emerald-500);border-radius:3px}.category-fill.warning{background:#f59e0b}.category-fill.over{background:#ef4444}.category-dot.gray{background:var(--gray-400)}.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.dash-card{padding:20px;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.8);text-decoration:none;transition:all .2s}.dash-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px #00000014}.dash-card h3{font-size:15px;font-weight:600;color:var(--gray-900);margin:0 0 4px}.dash-card p{font-size:13px;color:var(--gray-500);margin:0}.dash-card-icon{width:44px;height:44px;background:var(--gray-100);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--gray-600);margin-bottom:14px}.dash-card-icon.red{background:#ef44441a;color:#ef4444}.dash-card-icon.green{background:#10b9811a;color:var(--emerald-600)}.dash-card-icon.orange{background:#f59e0b1a;color:#f59e0b}.dash-card-icon.purple{background:#8b5cf61a;color:#8b5cf6}.ai-widget-card{background:linear-gradient(145deg,#1a1a2e,#16213e)!important;border:none!important;padding:16px!important;display:flex;flex-direction:column;gap:12px;grid-column:span 1;overflow:hidden}.ai-widget-header{display:flex;align-items:center;gap:10px}.ai-widget-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:0 2px 8px #10b9814d}.ai-widget-avatar img{width:100%;height:100%;object-fit:cover}.ai-widget-title h3{font-size:14px;font-weight:600;color:#fff!important;margin:0!important}.ai-widget-status{display:flex;align-items:center;gap:5px;font-size:11px;color:#ffffff80}.status-dot{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 6px #34d39999;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.ai-widget-preview{display:flex;flex-direction:column;gap:6px}.ai-preview-bubble{padding:8px 12px;border-radius:14px;font-size:11px;line-height:1.4;max-width:85%}.ai-preview-bubble.bot{background:#ffffff1f;color:#ffffffd9;border-bottom-left-radius:4px;align-self:flex-start}.ai-preview-bubble.user{background:linear-gradient(135deg,#34d399,#10b981);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.ai-widget-cta{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:#ffffff14;border-radius:10px;font-size:12px;font-weight:600;color:#34d399;margin-top:auto;transition:background .2s}.ai-widget-card:hover .ai-widget-cta{background:#34d39926}@media(max-width:900px){.hero{grid-template-columns:1fr;gap:40px}.hero-visual{justify-content:center}.features-bento{grid-template-columns:1fr 1fr}.feature-main{grid-column:span 2;grid-row:span 1}.how-section{grid-template-columns:1fr;gap:40px}.categories-grid{grid-template-columns:1fr}.dash-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.hero-title{font-size:36px}.hero-actions{flex-direction:column}.budget-preview{max-width:100%}.features-bento{grid-template-columns:1fr}.feature-main{grid-column:span 1}.cta-inner{padding:40px 24px}.cta h2{font-size:24px}.dash-header{flex-direction:column;align-items:flex-start;gap:16px}.budget-hero{flex-direction:column;text-align:center}.budget-hero-left{width:100%}.budget-hero-bar{max-width:100%}.budget-hero-arrow{display:none}.dash-grid{grid-template-columns:1fr 1fr}.footer{flex-direction:column;gap:16px;text-align:center}}.auth-options-row{display:flex;align-items:center;justify-content:space-between;margin:4px 0 8px}.remember-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#d1d5db;cursor:pointer}.remember-label input[type=checkbox]{width:16px;height:16px;accent-color:#16a34a;cursor:pointer}.forgot-link{font-size:14px;color:#16a34a;text-decoration:none;font-weight:500}.forgot-link:hover{text-decoration:underline}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:13px;font-size:15px;font-weight:500;color:#d1d5db;background:#111827;border:1px solid #374151;border-radius:8px;cursor:pointer;transition:background .2s ease;width:100%;margin-top:12px}.google-btn:hover{background:#1f2937}.google-btn img{width:20px;height:20px}.auth-divider{display:flex;align-items:center;margin:20px 0 16px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#374151}.auth-divider span{padding:0 12px;color:#6b7280;font-size:13px}.google-signin-wrapper{display:flex;justify-content:center}.auth-btn.secondary{background:#111827;color:#16a34a;border:1px solid #374151;box-shadow:none;display:block;text-align:center;text-decoration:none;width:100%;box-sizing:border-box}a.auth-btn{display:block;text-align:center;text-decoration:none}.success-icon.error{color:#f87171}.auth-page,.auth-container{min-height:100vh;background:#111827;display:flex;flex-direction:column;align-items:center;justify-content:center}.auth-container .auth-card{margin-top:0}.auth-logo{position:absolute;top:10px;left:20px;display:flex;align-items:center}.auth-logo img{height:120px;width:auto;object-fit:contain}.auth-card{background:#1f2937;padding:48px 40px;border-radius:12px;border:1px solid #374151;width:100%;max-width:440px;margin-top:120px}.auth-card h2{margin:0 0 32px;font-size:28px;font-weight:700;color:#f9fafb;letter-spacing:-.5px}.auth-subtitle{color:#9ca3af;margin:0 0 6px;font-size:15px}.auth-card form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column}.form-group input{padding:13px 16px;font-size:15px;border:1px solid #374151;border-radius:8px;transition:border-color .2s ease;background:#111827;color:#f9fafb}.form-group input:focus{outline:none;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a33}.form-group input::placeholder{color:#6b7280}.auth-btn{padding:14px;font-size:16px;font-weight:600;color:#fff;background:#16a34a;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease;margin-top:4px}.auth-btn:hover:not(:disabled){background:#15803d}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;color:#9ca3af;font-size:14px}.auth-footer a{color:#16a34a;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.error-banner{background-color:#dc26261a;color:#f87171;padding:12px 16px;border-radius:8px;margin-bottom:16px;text-align:center;font-size:14px;font-weight:500;border:1px solid rgba(220,38,38,.3)}.auth-btn.secondary{background:#111827;color:#16a34a;border:1px solid #374151;box-shadow:none}.auth-btn.secondary:hover:not(:disabled){background:#1f2937}.success-icon{font-size:64px;text-align:center;margin-bottom:16px}.auth-info{text-align:center;color:#9ca3af;font-size:14px;line-height:1.6;margin:0 0 24px}@media(max-width:480px){.auth-card{padding:32px 24px;margin-top:80px}.auth-card h2{font-size:24px}.auth-logo{top:20px;left:20px}}.expense-page{min-height:100vh;background:transparent}.expense-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.expense-header{margin-bottom:32px}.expense-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.expense-header p{color:var(--gray-500);font-size:15px;margin:0}.stat-card{background:var(--white);padding:20px;border-radius:12px;border:1px solid var(--gray-200);cursor:pointer;transition:all .2s}.stat-card.active{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border:none;box-shadow:0 4px 12px #10b9814d}.stat-card.active .stat-label,.stat-card.active .stat-value{color:var(--white)}.stat-card.active .stat-label{color:#fffc}.expense-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.quick-filters{display:flex;gap:4px}.quick-filter-btn{padding:8px 14px;border:none;border-radius:8px;font-size:13px;font-weight:500;background:transparent;color:var(--gray-500);cursor:pointer;transition:all .15s}.quick-filter-btn:hover{background:#10b9811a;color:var(--emerald-600)}.quick-filter-btn.active{background:#10b9811a;color:var(--emerald-600);font-weight:600}.expense-count{font-size:13px;color:var(--gray-500)}.expense-list{display:flex;flex-direction:column;gap:8px}.expense-card{display:flex;align-items:center;gap:14px;background:var(--white);padding:16px;border-radius:12px;border:1px solid var(--gray-200);transition:border-color .15s}.expense-card:hover{border-color:var(--gray-300)}.expense-icon{width:40px;height:40px;border-radius:10px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;flex-shrink:0}.expense-icon img{width:22px;height:22px;opacity:.8}.expense-details{flex:1;min-width:0}.expense-top{display:flex;align-items:center;gap:8px}.expense-category{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.cat-food{background:#fef3c7;color:#d97706}.cat-travel{background:#dbeafe;color:#2563eb}.cat-education{background:#fce7f3;color:#db2777}.cat-leisure{background:#ede9fe;color:#7c3aed}.cat-other{background:var(--gray-100);color:var(--gray-600)}.expense-amount{font-size:16px;font-weight:600;color:var(--gray-900);margin-left:auto}.expense-desc{margin:4px 0 0;color:var(--gray-600);font-size:14px}.expense-travel,.expense-mood{margin:2px 0 0;color:var(--gray-400);font-size:13px}.expense-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.expense-card:hover .expense-actions{opacity:1}.modal{background:var(--white);border-radius:16px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.expense-form{padding:20px 24px 24px}.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.category-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 4px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid var(--gray-200);background:var(--white)}.category-option:hover{border-color:var(--gray-300)}.category-option.selected{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-color:var(--emerald-500)}.category-option.selected span{color:var(--white)}.category-option.selected img{filter:brightness(0) invert(1)}.category-option img{width:24px;height:24px;opacity:.7}.category-option span{font-size:11px;font-weight:500;color:var(--gray-600)}.travel-options{background:var(--gray-50);padding:16px;border-radius:10px;margin-bottom:16px}.travel-options .form-group{margin-bottom:12px}.travel-options .form-group:last-child{margin-bottom:0}.fare-hint{display:block;font-size:12px;color:var(--gray-500);margin-top:6px}.fare-hint.success{color:var(--emerald-500)}@media(max-width:640px){.expense-main{padding:80px 16px 60px}.stats-grid{grid-template-columns:1fr;gap:8px}.expense-header h1{font-size:24px}.expense-controls{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column}.quick-filters{width:100%}.quick-filter-btn{flex:1}.filter-select{width:100%}.add-btn{width:100%;justify-content:center}.expense-actions{opacity:1}.category-grid{grid-template-columns:repeat(3,1fr)}.form-row{grid-template-columns:1fr}}.subscription-page{min-height:100vh;background:transparent}.subscription-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.subscription-header{margin-bottom:32px}.subscription-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.subscription-header p{color:var(--gray-500);font-size:15px;margin:0}.stat-card:hover .stat-label{color:var(--emerald-600)}.alert-section{background:var(--white);border-radius:12px;border:1px solid var(--gray-200);margin-bottom:16px;overflow:hidden}.alert-section.upcoming{border-color:#fbbf24;background:linear-gradient(135deg,#fffbeb 0%,var(--white) 100%)}.alert-section.unused{border-color:#f87171;background:linear-gradient(135deg,#fef2f2 0%,var(--white) 100%)}.alert-header{display:flex;align-items:center;gap:8px;padding:14px 16px;font-size:14px;font-weight:600;border-bottom:1px solid var(--gray-100)}.alert-section.upcoming .alert-header{color:#b45309;border-bottom-color:#fef3c7}.alert-section.upcoming .alert-header svg{color:#f59e0b}.alert-section.unused .alert-header{color:#dc2626;border-bottom-color:#fee2e2}.alert-section.unused .alert-header svg{color:#ef4444}.alert-header svg{width:18px;height:18px}.alert-list{padding:8px}.alert-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;transition:background-color .15s}.alert-item:hover{background:#00000008}.alert-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-info{flex:1;min-width:0}.alert-name{display:block;font-size:14px;font-weight:500;color:var(--gray-900)}.alert-detail{display:block;font-size:12px;color:var(--gray-500);margin-top:2px}.alert-actions{display:flex;gap:6px}.alert-action{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;background:var(--gray-100);color:var(--gray-600)}.alert-action:hover{background:var(--gray-200);color:var(--gray-900)}.alert-action.mark{background:#10b9811a;color:var(--emerald-600)}.alert-action.mark:hover{background:#10b98133}.alert-action.cancel{background:var(--red-100);color:var(--red-500)}.alert-action.cancel:hover{background:#fecaca}.subscription-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.filter-group{display:flex;align-items:center;gap:8px}.filter-select{padding:8px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;background:var(--white);color:var(--gray-700);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--emerald-400)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-title{font-size:14px;font-weight:600;color:var(--gray-900);margin:0}.subscription-count{font-size:13px;color:var(--gray-500)}.loading-spinner{width:24px;height:24px;border:2px solid var(--gray-200);border-top-color:var(--emerald-500);border-radius:50%;animation:spin .6s linear infinite;margin:0 auto 12px}.subscription-list{display:flex;flex-direction:column;gap:8px}.subscription-card{display:flex;align-items:center;gap:14px;background:var(--white);padding:16px;border-radius:12px;border:1px solid var(--gray-200);transition:border-color .15s}.subscription-card:hover{border-color:var(--gray-300)}.subscription-card.paused{opacity:.7}.subscription-card.cancelled{opacity:.5}.subscription-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.subscription-details{flex:1;min-width:0}.subscription-top{display:flex;align-items:center;gap:8px}.subscription-name{font-size:15px;font-weight:600;color:var(--gray-900)}.subscription-status{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-active{background:#10b9811a;color:var(--emerald-600)}.status-paused{background:#fef3c7;color:#b45309}.status-cancelled{background:var(--gray-100);color:var(--gray-500)}.subscription-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.subscription-cycle{font-size:13px;color:var(--gray-600)}.subscription-payment{font-size:13px;color:var(--gray-500)}.payment-soon{color:#f59e0b;font-weight:500}.subscription-used{margin:4px 0 0;font-size:12px;color:var(--gray-400)}.unused-warning{color:#ef4444;font-weight:500}.subscription-cost{font-size:16px;font-weight:600;color:var(--gray-900);margin-left:auto}.subscription-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.subscription-card:hover .subscription-actions{opacity:1}.action-btn.mark{background:#10b9811a;color:var(--emerald-600)}.action-btn.mark:hover{background:#10b98133}.action-btn.cancel{background:#fef3c7;color:#b45309}.action-btn.cancel:hover{background:#fde68a}.empty-icon{width:56px;height:56px;background:var(--gray-100);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.empty-icon svg{width:28px;height:28px;color:var(--gray-400)}.subscription-form{padding:20px 24px 24px}.category-section{margin-bottom:24px}.category-header{display:flex;align-items:center;gap:8px;padding:12px 0;margin-bottom:8px;border-bottom:1px solid var(--gray-200)}.category-icon{font-size:20px}.category-name{font-size:16px;font-weight:600;color:var(--gray-900)}.category-count{background:var(--gray-100);color:var(--gray-600);padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}.category-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid var(--gray-200);background:var(--white)}.category-option:hover{border-color:var(--gray-300);background:var(--gray-50)}.category-option.selected{border-color:var(--emerald-500);background:#10b9811a}.category-option .cat-icon{font-size:20px}.category-option span:last-child{font-size:11px;font-weight:500;color:var(--gray-600)}.category-option.selected span:last-child{color:var(--emerald-700)}.provider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.provider-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid var(--gray-200);background:var(--white)}.provider-option:hover{border-color:var(--gray-300);background:var(--gray-50)}.provider-option.selected{border-color:var(--provider-color, var(--emerald-500));background:color-mix(in srgb,var(--provider-color, var(--emerald-500)) 10%,white)}.provider-option span{font-size:11px;font-weight:500;color:var(--gray-600)}.provider-option.selected span{color:var(--gray-900)}.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.plan-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid var(--gray-200);background:var(--white)}.plan-option:hover{border-color:var(--gray-300);background:var(--gray-50)}.plan-option.selected{border-color:var(--emerald-500);background:#10b9811a}.plan-option .plan-name{font-size:13px;font-weight:600;color:var(--gray-900)}.plan-option .plan-price{font-size:12px;color:var(--gray-500)}.plan-option.selected .plan-name{color:var(--emerald-700)}.plan-option.selected .plan-price{color:var(--emerald-600)}.plan-option.custom{border-style:dashed}.plan-option.custom .plan-name{color:var(--gray-600)}.plan-option.custom.selected{border-style:solid}.loading-plans{text-align:center;padding:16px;color:var(--gray-500);font-size:13px}@media(max-width:640px){.subscription-main{padding:80px 16px 60px}.stats-grid{grid-template-columns:1fr;gap:8px}.subscription-header h1{font-size:24px}.subscription-controls{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column}.filter-select{width:100%}.add-btn{width:100%;justify-content:center}.subscription-card{flex-wrap:wrap}.subscription-actions{opacity:1;width:100%;margin-top:12px;padding-top:12px;border-top:1px solid var(--gray-100);justify-content:flex-end}.subscription-cost{margin-left:0}.provider-grid{grid-template-columns:repeat(3,1fr)}.form-row{grid-template-columns:1fr}.alert-item{flex-wrap:wrap}.alert-actions{width:100%;margin-top:8px;justify-content:flex-end}}.field-hint{display:block;font-size:11px;color:var(--gray-400);margin-top:4px}.bills-page{min-height:100vh;background:transparent}.bills-main{max-width:900px;margin:0 auto;padding:100px 24px 80px}.bills-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.bills-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.bills-header p{color:var(--gray-500);font-size:15px;margin:0}.add-bill-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,var(--emerald-500) 0%,var(--emerald-600) 100%);color:var(--white);border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.add-bill-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.summary-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--white);border-radius:14px;border:1px solid var(--gray-200);transition:all .2s}.summary-card:hover{border-color:var(--emerald-300)}.summary-card.total{background:linear-gradient(135deg,rgba(59,130,246,.05) 0%,var(--white) 100%);border-color:#3b82f633}.summary-card.paid{background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--white) 100%);border-color:var(--emerald-200)}.summary-card.unpaid{background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--white) 100%);border-color:#fcd34d}.summary-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--gray-50);border-radius:12px}.summary-content{display:flex;flex-direction:column}.summary-label{font-size:13px;color:var(--gray-500);margin-bottom:2px}.summary-value{font-size:24px;font-weight:700;color:var(--gray-900);letter-spacing:-.5px}.summary-count{font-size:12px;color:var(--gray-400);margin-top:2px}.bills-section{margin-bottom:32px}.bills-section h2{font-size:16px;font-weight:600;color:var(--gray-900);margin:0 0 16px}.bills-section.paid-section{opacity:.8}.bills-list{display:flex;flex-direction:column;gap:12px}.bill-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--white);border-radius:12px;border:1px solid var(--gray-200);transition:all .2s}.bill-card:hover{border-color:var(--emerald-300);box-shadow:0 2px 8px #0000000a}.bill-card.overdue{background:linear-gradient(135deg,rgba(239,68,68,.05) 0%,var(--white) 100%);border-color:#fca5a5}.bill-card.due-soon{background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--white) 100%);border-color:#fcd34d}.bill-card.paid{background:var(--gray-50);border-color:var(--gray-200)}.bill-icon{font-size:24px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--white);border-radius:10px;box-shadow:0 1px 3px #0000000f;flex-shrink:0}.bill-card.paid .bill-icon{opacity:.6}.bill-info{flex:1;min-width:0}.bill-name{font-size:15px;font-weight:600;color:var(--gray-900);margin-bottom:4px}.bill-card.paid .bill-name{color:var(--gray-500);text-decoration:line-through}.bill-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500)}.bill-dot{opacity:.4}.bill-amount{font-size:18px;font-weight:700;color:var(--gray-900);flex-shrink:0}.bill-card.paid .bill-amount{color:var(--gray-400)}.bill-status-badge{padding:5px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.bill-status-badge.overdue{background:#fee2e2;color:#b91c1c}.bill-status-badge.due-soon{background:#fef3c7;color:#b45309}.bill-status-badge.upcoming{background:var(--gray-100);color:var(--gray-600)}.bill-status-badge.paid{background:var(--emerald-100);color:var(--emerald-700)}.bill-actions{display:flex;gap:6px;flex-shrink:0}.bill-actions button{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;cursor:pointer;transition:all .15s}.mark-paid-btn{background:var(--emerald-100);color:var(--emerald-600)}.mark-paid-btn:hover{background:var(--emerald-500);color:var(--white)}.undo-btn{background:var(--gray-100);color:var(--gray-500)}.undo-btn:hover{background:var(--gray-200);color:var(--gray-700)}.edit-btn{background:var(--gray-100);color:var(--gray-500)}.edit-btn:hover{background:#3b82f61a;color:#3b82f6}.delete-btn{background:var(--gray-100);color:var(--gray-500)}.delete-btn:hover{background:var(--red-100);color:var(--red-500)}.empty-state p{font-size:14px;color:var(--gray-500);margin:0 0 20px}.add-first-btn{padding:10px 20px;background:var(--emerald-500);color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.add-first-btn:hover{background:var(--emerald-600)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--white);border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--gray-200)}.modal-header h2{font-size:18px;font-weight:600;color:var(--gray-900);margin:0}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:8px;color:var(--gray-500);cursor:pointer}.modal form{padding:24px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;background:var(--white);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--emerald-400)}.form-group textarea{resize:vertical}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions .cancel-btn{flex:1;padding:12px;background:var(--gray-100);color:var(--gray-700);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.form-actions .cancel-btn:hover{background:var(--gray-200)}.form-actions .submit-btn{flex:1;padding:12px;background:var(--emerald-500);color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.form-actions .submit-btn:hover{background:var(--emerald-600)}@media(max-width:768px){.bills-main{padding:80px 16px 60px}.bills-header{flex-direction:column;gap:16px}.add-bill-btn{width:100%;justify-content:center}.summary-grid{grid-template-columns:1fr;gap:12px}.bill-card{flex-wrap:wrap;gap:12px}.bill-info{flex:1 1 calc(100% - 60px)}.bill-amount{order:3}.bill-status-badge{order:4}.bill-actions{order:5;width:100%;justify-content:flex-end}.form-row{grid-template-columns:1fr}}.chat-page{height:100vh;display:flex;flex-direction:column;background:transparent;padding-top:64px}.chat-container{display:flex;flex:1;overflow:hidden}.chat-sidebar{width:280px;background:var(--white);border-right:1px solid var(--gray-200);padding:20px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.new-chat-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:var(--white);background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border:none;border-radius:10px;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #10b9814d}.new-chat-btn:hover{background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.sidebar-section h3{font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.conversations-list{display:flex;flex-direction:column;gap:4px}.conversation-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s;border:1px solid transparent}.conversation-item:hover{background:var(--gray-50)}.conversation-item.active{background:#10b9811a;border-color:var(--emerald-200)}.conversation-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.conversation-title{font-size:13px;font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-item.active .conversation-title{color:var(--emerald-700)}.conversation-date{font-size:11px;color:var(--gray-400)}.delete-conv-btn{padding:4px;background:transparent;border:none;border-radius:4px;color:var(--gray-400);cursor:pointer;opacity:0;transition:all .15s}.conversation-item:hover .delete-conv-btn{opacity:1}.delete-conv-btn:hover{background:var(--red-100);color:var(--red-500)}.loading-conversations{font-size:13px;color:var(--gray-400);padding:8px 0}.no-conversations{font-size:13px;color:var(--gray-400);margin:0;padding:8px 0}.toggle-option{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--gray-50);border-radius:10px;cursor:pointer}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-desc{font-size:12px;color:var(--gray-500)}.toggle-switch{width:40px;height:22px;background:var(--gray-200);border-radius:11px;position:relative;transition:background .2s}.toggle-switch.active{background:var(--emerald-500)}.toggle-handle{width:18px;height:18px;background:var(--white);border-radius:50%;position:absolute;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 3px #0000001a}.toggle-switch.active .toggle-handle{left:20px}.quick-questions{display:flex;flex-direction:column;gap:6px}.quick-btn{padding:10px 12px;font-size:13px;font-weight:500;color:var(--gray-600);background:var(--white);border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;text-align:left;transition:all .15s}.quick-btn:hover{border-color:var(--emerald-300);color:var(--emerald-600);background:#10b9810d}.sidebar-section.tips{margin-top:auto;padding:14px;background:var(--gray-50);border-radius:10px}.sidebar-section.tips h3{color:var(--gray-500);margin-bottom:6px}.sidebar-section.tips p{font-size:13px;color:var(--gray-500);margin:0;line-height:1.5}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--white)}.messages-container{flex:1;overflow-y:auto;padding:32px 24px;display:flex;flex-direction:column;gap:24px}.message{display:flex;gap:12px;max-width:720px}.message.user{flex-direction:row-reverse;align-self:flex-end}.message-avatar{flex-shrink:0}.avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.avatar.ai{background:var(--white);padding:0;overflow:hidden}.avatar.ai img{width:100%;height:100%;object-fit:cover}.avatar.user{background:var(--emerald-500);color:var(--white)}.message-content{flex:1}.message-header{margin-bottom:4px}.message-author{font-size:13px;font-weight:500;color:var(--gray-500)}.message-text{padding:14px 16px;border-radius:12px;font-size:14px;line-height:1.6;white-space:pre-wrap}.message.assistant .message-text{background:var(--gray-50);color:var(--gray-800);border-top-left-radius:4px}.message.user .message-text{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border-top-right-radius:4px}.message.user .message-header{text-align:right}.typing-indicator{display:flex;gap:5px;padding:14px 16px;background:var(--gray-50);border-radius:4px 12px 12px;width:fit-content}.typing-indicator span{width:7px;height:7px;background:var(--gray-400);border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.input-form{padding:20px 24px;background:var(--white);border-top:1px solid var(--gray-200)}.input-wrapper{display:flex;gap:10px;max-width:720px;margin:0 auto}.input-wrapper input{flex:1;padding:12px 16px;font-size:14px;border:1px solid var(--gray-200);border-radius:10px;background:var(--white);color:var(--gray-900);transition:border-color .15s}.input-wrapper input:focus{outline:none;border-color:var(--emerald-400)}.input-wrapper input::placeholder{color:var(--gray-400)}.input-wrapper button{width:44px;height:44px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 2px 8px #10b9814d}.input-wrapper button:hover:not(:disabled){background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.input-wrapper button:disabled{opacity:.4;cursor:not-allowed}.input-hint{text-align:center;font-size:12px;color:var(--gray-400);margin:8px 0 0}@media(max-width:900px){.chat-sidebar{display:none}}@media(max-width:640px){.chat-page{padding-top:56px}.messages-container{padding:20px 16px}.message-text{padding:12px 14px;font-size:14px}.input-form{padding:16px}.input-wrapper input{padding:10px 14px}.input-wrapper button{width:40px;height:40px}}.overview-page{min-height:100vh;background:transparent}.overview-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.overview-header{margin-bottom:32px}.overview-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.overview-header p{color:var(--gray-500);font-size:15px;margin:0}.stats-grid.four-col{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px}.stat-label{font-size:12px;font-weight:500;color:var(--gray-500);margin-bottom:4px}.stat-value{font-size:20px;font-weight:700;color:var(--gray-900);letter-spacing:-.5px}.chart-section{background:var(--white);padding:24px;border-radius:12px;border:1px solid var(--gray-200);margin-bottom:24px}.chart-section h2{font-size:16px;font-weight:600;color:var(--gray-900);margin:0 0 20px}.category-bars{display:flex;flex-direction:column;gap:12px}.category-bar-item{display:flex;align-items:center;gap:12px}.bar-label{width:100px;font-size:13px;font-weight:500;color:var(--gray-700);display:flex;align-items:center;gap:6px}.bar-icon{font-size:16px}.bar-container{flex:1;height:24px;background:var(--gray-100);border-radius:6px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(135deg,var(--emerald-400),var(--emerald-500));border-radius:6px;transition:width .3s ease}.bar-amount{width:80px;text-align:right;font-size:13px;font-weight:600;color:var(--gray-900)}.trend-chart{display:flex;align-items:flex-end;justify-content:space-between;height:200px;padding-top:20px}.trend-bar{display:flex;flex-direction:column;align-items:center;flex:1;height:100%}.trend-value{font-size:11px;font-weight:600;color:var(--gray-600);margin-bottom:8px}.trend-bar-container{flex:1;width:40px;background:var(--gray-100);border-radius:6px 6px 0 0;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}.trend-fill{width:100%;background:linear-gradient(180deg,var(--emerald-400),var(--emerald-500));border-radius:6px 6px 0 0;transition:height .3s ease;min-height:4px}.trend-label{font-size:12px;font-weight:500;color:var(--gray-500);margin-top:8px}.loading-msg{text-align:center;color:var(--gray-500);padding:60px 20px}.empty-text{color:var(--gray-400);font-size:14px;text-align:center;padding:20px}@media(max-width:640px){.overview-main{padding:80px 16px 60px}.stats-grid.four-col{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:18px}.trend-bar-container{width:30px}.bar-label{width:80px;font-size:12px}.bar-amount{width:60px;font-size:12px}}.income-page{min-height:100vh;background:transparent}.income-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.income-header{margin-bottom:32px}.income-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.income-header p{color:var(--gray-500);font-size:15px;margin:0}.stat-value.income{color:var(--emerald-600)}.income-controls{display:flex;justify-content:flex-end;margin-bottom:24px}.add-btn{padding:8px 16px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #10b9814d}.add-btn:hover{background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.add-btn svg{width:16px;height:16px}.income-list{display:flex;flex-direction:column;gap:8px}.income-card{display:flex;align-items:center;gap:14px;background:var(--white);padding:16px;border-radius:12px;border:1px solid var(--gray-200);transition:border-color .15s}.income-card:hover{border-color:var(--gray-300)}.income-icon{width:48px;height:48px;background:#10b9811a;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.income-details{flex:1;min-width:0}.income-source{font-size:15px;font-weight:600;color:var(--gray-900)}.income-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.income-frequency{font-size:13px;color:var(--emerald-600);font-weight:500}.income-date{font-size:13px;color:var(--gray-500)}.income-amount{font-size:18px;font-weight:700;color:var(--emerald-600)}.income-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.income-card:hover .income-actions{opacity:1}.empty-icon{font-size:48px;margin-bottom:16px}.modal{background:var(--white);border-radius:16px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-close{width:32px;height:32px;border:none;background:var(--gray-100);border-radius:8px;font-size:18px;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.income-form{padding:20px 24px 24px}@media(max-width:640px){.income-main{padding:80px 16px 60px}.stats-grid{grid-template-columns:1fr;gap:8px}.income-card{flex-wrap:wrap}.income-actions{opacity:1;width:100%;margin-top:12px;padding-top:12px;border-top:1px solid var(--gray-100);justify-content:flex-end}.form-row{grid-template-columns:1fr}}.plans-page{min-height:100vh;background:transparent}.plans-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.plans-header{margin-bottom:32px}.plans-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.plans-header p{color:var(--gray-500);font-size:15px;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.stat-card{background:var(--white);padding:20px;border-radius:12px;border:1px solid var(--gray-200);transition:all .2s}.stat-card:hover{border-color:var(--emerald-300);background:#10b9810d}.stat-value{font-size:24px;font-weight:700;color:var(--gray-900);letter-spacing:-.5px}.stat-value.saved{color:var(--emerald-600)}.ai-goal-section{margin-bottom:28px}.ai-goal-form{margin-bottom:12px}.ai-input-wrapper{display:flex;align-items:center;background:var(--white);border-radius:16px;border:2px solid var(--gray-200);padding:4px 4px 4px 16px;transition:border-color .2s,box-shadow .2s}.ai-input-wrapper:focus-within{border-color:var(--emerald-400);box-shadow:0 0 0 4px #10b9811a}.ai-input-icon{color:var(--emerald-500);flex-shrink:0;display:flex;margin-right:10px}.ai-input-wrapper input{flex:1;padding:12px 0;font-size:15px;border:none;background:transparent;color:var(--gray-900);outline:none}.ai-input-wrapper input::placeholder{color:var(--gray-400)}.ai-input-wrapper button{width:42px;height:42px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.ai-input-wrapper button:hover:not(:disabled){background:linear-gradient(135deg,var(--emerald-600),#059669);transform:scale(1.05)}.ai-input-wrapper button:disabled{opacity:.35;cursor:not-allowed}.ai-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.ai-examples{display:flex;flex-wrap:wrap;gap:8px;padding:0 4px}.ai-example-chip{padding:6px 14px;background:#10b98114;color:var(--emerald-700);border:1px solid rgba(16,185,129,.15);border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.ai-example-chip:hover{background:#10b98126;border-color:var(--emerald-400);transform:translateY(-1px)}.parsed-preview{background:var(--white);border:2px solid var(--emerald-300);border-radius:14px;padding:16px 20px;margin-bottom:28px;animation:fadeSlideIn .3s ease}.parsed-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.parsed-badge{padding:3px 10px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:#fff;border-radius:12px;font-size:11px;font-weight:600}.parsed-hint{font-size:13px;color:var(--gray-500)}.parsed-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--gray-50);border-radius:10px;margin-bottom:14px}.parsed-icon{width:48px;height:48px;background:var(--white);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;box-shadow:0 1px 3px #0000000f}.parsed-details{flex:1;min-width:0}.parsed-title{font-size:16px;font-weight:600;color:var(--gray-900);margin-bottom:4px}.parsed-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.parsed-meta span{font-size:13px;color:var(--gray-500)}.parsed-amount{font-weight:600;color:var(--emerald-600)!important}.parsed-type{padding:2px 8px;background:var(--white);border-radius:6px;font-size:12px!important}.parsed-date:before,.parsed-current:before{content:"·";margin-right:8px;color:var(--gray-300)}.parsed-actions{display:flex;gap:8px;justify-content:flex-end}.btn-discard{padding:8px 18px;background:var(--gray-100);color:var(--gray-600);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-discard:hover{background:var(--gray-200);color:var(--gray-800)}.btn-save{padding:8px 20px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #10b9814d}.btn-save:hover{background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 4px 12px #10b98166}.plans-list{display:flex;flex-direction:column;gap:16px}.plan-card{background:var(--white);padding:20px;border-radius:12px;border:1px solid var(--gray-200);transition:border-color .15s}.plan-card:hover{border-color:var(--gray-300)}.plan-card.complete{border-color:var(--emerald-300);background:#10b98108}.plan-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}.plan-icon{width:48px;height:48px;background:var(--gray-100);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.plan-info{flex:1;min-width:0}.plan-title{font-size:16px;font-weight:600;color:var(--gray-900)}.plan-type{font-size:13px;color:var(--gray-500);margin-top:2px}.plan-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.plan-card:hover .plan-actions{opacity:1}.action-btn{padding:6px 10px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.action-btn.edit{background:var(--gray-100);color:var(--gray-600)}.action-btn.edit:hover{background:var(--gray-200);color:var(--gray-900)}.action-btn.delete{background:var(--red-100);color:var(--red-500)}.action-btn.delete:hover{background:#fecaca}.plan-progress{margin-bottom:16px}.progress-bar{height:12px;background:var(--gray-100);border-radius:6px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(135deg,var(--emerald-400),var(--emerald-500));border-radius:6px;transition:width .3s ease}.progress-stats{display:flex;justify-content:space-between;align-items:center}.progress-amount{font-size:14px;color:var(--gray-600)}.progress-percent{font-size:14px;font-weight:600;color:var(--emerald-600)}.plan-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.plan-deadline{font-size:13px;color:var(--gray-500)}.plan-deadline.soon{color:#f59e0b;font-weight:500}.add-progress-btn{padding:6px 12px;background:#10b9811a;color:var(--emerald-600);border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.add-progress-btn:hover{background:#10b98133}.add-progress-form{display:flex;align-items:center;gap:8px}.add-progress-form input{width:100px;padding:6px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px}.add-progress-form input:focus{outline:none;border-color:var(--emerald-400)}.add-progress-form button{padding:6px 12px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;background:var(--emerald-500);color:var(--white)}.add-progress-form button.cancel{background:var(--gray-100);color:var(--gray-600)}.complete-badge{padding:4px 10px;background:var(--emerald-500);color:var(--white);border-radius:12px;font-size:12px;font-weight:600}.empty-state{text-align:center;padding:80px 20px;background:var(--white);border-radius:12px;border:1px solid var(--gray-200)}.empty-illustration{margin-bottom:20px}.empty-state h3{font-size:16px;font-weight:600;color:var(--gray-900);margin:0 0 4px}.empty-state p{color:var(--gray-500);font-size:14px;margin:0 0 20px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal{background:var(--white);border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--gray-900)}.modal-close{width:32px;height:32px;border:none;background:var(--gray-100);border-radius:8px;font-size:18px;color:var(--gray-500);cursor:pointer}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.plan-form{padding:20px 24px 24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}.optional-label{font-weight:400;color:var(--gray-400);font-size:11px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;background:var(--white);color:var(--gray-900);transition:border-color .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--emerald-400)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.type-option{display:flex;align-items:center;gap:8px;padding:12px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid var(--gray-200);background:var(--white)}.type-option:hover{border-color:var(--gray-300);background:var(--gray-50)}.type-option.selected{border-color:var(--emerald-500);background:#10b9811a}.type-icon{font-size:20px}.type-option span:last-child{font-size:12px;font-weight:500;color:var(--gray-600)}.type-option.selected span:last-child{color:var(--emerald-700)}.form-error{background:var(--red-100);color:var(--red-500);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}.form-buttons{display:flex;gap:8px;margin-top:8px}.btn-secondary,.btn-primary{flex:1;padding:10px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white)}.btn-primary:hover{background:linear-gradient(135deg,var(--emerald-600),#059669)}@media(max-width:640px){.plans-main{padding:80px 16px 60px}.stats-grid{grid-template-columns:1fr;gap:8px}.plan-actions{opacity:1}.plan-footer{flex-direction:column;align-items:flex-start}.type-grid,.form-row{grid-template-columns:1fr}.ai-examples{gap:6px}.ai-example-chip{font-size:11px;padding:5px 10px}.parsed-card{flex-direction:column;text-align:center}.parsed-meta{justify-content:center}.parsed-actions{justify-content:stretch}.parsed-actions button{flex:1}}.budget-page{min-height:100vh;background:transparent}.budget-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.budget-header{margin-bottom:32px}.budget-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.budget-header p{color:var(--gray-500);font-size:15px;margin:0}.loading-msg{text-align:center;color:var(--gray-500);padding:60px 20px;font-size:14px}.live-stats{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:16px;margin-bottom:24px}.live-stat-card{background:var(--white);padding:20px;border-radius:14px;border:1px solid var(--gray-200);transition:all .2s}.live-stat-card:hover{border-color:var(--emerald-300)}.live-stat-card.main-stat{grid-row:span 1}.live-stat-card.main-stat.on-track{background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--white) 100%);border-color:var(--emerald-200)}.live-stat-card.main-stat.warning{background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--white) 100%);border-color:#fcd34d}.live-stat-card.main-stat.exceeded{background:linear-gradient(135deg,rgba(239,68,68,.05) 0%,var(--white) 100%);border-color:#fca5a5}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.stat-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--gray-50);border-radius:8px;color:var(--gray-500)}.main-stat.on-track .stat-icon{background:var(--emerald-50);color:var(--emerald-600)}.main-stat.warning .stat-icon{background:#fef3c7;color:#d97706}.main-stat.exceeded .stat-icon{background:#fee2e2;color:#dc2626}.status-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.on-track{background:var(--emerald-100);color:var(--emerald-700)}.status-badge.warning{background:#fef3c7;color:#b45309}.status-badge.exceeded{background:#fee2e2;color:#b91c1c}.stat-content{margin-bottom:12px}.stat-label{font-size:13px;font-weight:500;color:var(--gray-500);margin-bottom:4px}.stat-value{font-size:28px;font-weight:700;color:var(--gray-900);letter-spacing:-.5px}.stat-value.positive{color:var(--emerald-600)}.stat-value.negative{color:var(--red-500)}.stat-value.expense{color:var(--gray-700)}.stat-sub{font-size:12px;color:var(--gray-400);margin-top:2px}.stat-progress{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.stat-progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.stat-progress-fill.on-track{background:linear-gradient(135deg,var(--emerald-400),var(--emerald-500))}.stat-progress-fill.warning{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.stat-progress-fill.exceeded{background:linear-gradient(135deg,#f87171,#ef4444)}.error-msg{background:var(--red-100);color:var(--red-500);padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.budget-section{background:var(--white);border-radius:14px;border:1px solid var(--gray-200);padding:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{font-size:16px;font-weight:600;color:var(--gray-900);margin:0}.edit-btn{padding:8px 14px;background:var(--gray-100);color:var(--gray-700);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.edit-btn:hover{background:var(--gray-200)}.edit-actions{display:flex;gap:8px}.cancel-btn{padding:8px 14px;background:var(--gray-100);color:var(--gray-700);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer}.cancel-btn:hover{background:var(--gray-200)}.save-btn{padding:8px 14px;background:var(--emerald-500);color:var(--white);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer}.save-btn:hover:not(:disabled){background:var(--emerald-600)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.total-budget-edit{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--gray-200)}.total-budget-edit label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:6px}.total-budget-edit input{width:100%;max-width:200px;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:16px;font-weight:600}.total-budget-edit input:focus{outline:none;border-color:var(--emerald-400)}.category-limits{display:flex;flex-direction:column;gap:14px}.category-limit-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;background:var(--gray-50);transition:all .2s}.category-limit-item.on-track{background:#10b9810d}.category-limit-item.warning{background:#f59e0b14}.category-limit-item.exceeded{background:#ef444414}.category-limit-item.exceeded .category-name{color:var(--red-600)}.category-info{display:flex;align-items:center;gap:10px;width:110px;flex-shrink:0}.category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-name{font-size:14px;font-weight:500;color:var(--gray-700)}.limit-input{display:flex;align-items:center;gap:4px;flex:1}.limit-input span{color:var(--gray-500);font-size:14px}.limit-input input{width:100px;padding:8px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:14px;background:var(--white)}.limit-input input:focus{outline:none;border-color:var(--emerald-400)}.limit-progress{flex:1}.limit-bar{height:8px;background:var(--white);border-radius:4px;box-shadow:inset 0 1px 2px #0000000d;position:relative;overflow:visible}.limit-fill{height:100%;border-radius:4px;transition:width .3s ease}.limit-fill.on-track{background:linear-gradient(135deg,var(--emerald-400),var(--emerald-500))}.limit-fill.warning{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.limit-fill.exceeded{background:linear-gradient(135deg,#f87171,#ef4444)}.limit-values{display:flex;align-items:center;gap:4px;width:130px;justify-content:flex-end;font-size:13px;font-weight:500}.limit-values span.warning{color:#d97706}.limit-values span.exceeded{color:var(--red-500)}.limit-of{color:var(--gray-400);font-weight:400}.category-status-badge{padding:4px 8px;border-radius:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.category-status-badge.on-track{background:var(--emerald-100);color:var(--emerald-700)}.category-status-badge.warning{background:#fef3c7;color:#b45309}.category-status-badge.exceeded{background:#fee2e2;color:#b91c1c}.insights-section{background:var(--white);border-radius:14px;border:1px solid var(--gray-200);padding:24px;margin-top:24px}.insights-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:var(--white);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.insights-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.insights-btn.refresh{background:var(--gray-100);color:var(--gray-700)}.insights-btn.refresh:hover:not(:disabled){background:var(--gray-200);box-shadow:none;transform:none}.insights-btn:disabled{opacity:.6;cursor:not-allowed}.insights-loading{display:flex;flex-direction:column;gap:12px}.insight-skeleton{height:72px;border-radius:10px;background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-50) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.insights-grid{display:flex;flex-direction:column;gap:12px}.insight-card{padding:16px 18px;background:var(--gray-50);border-radius:10px;border:1px solid var(--gray-100);border-left:3px solid var(--emerald-400);animation:fadeSlideIn .3s ease forwards;opacity:0}.insight-card:nth-child(2){border-left-color:#3b82f6}.insight-card:nth-child(3){border-left-color:#8b5cf6}.insight-card:nth-child(4){border-left-color:#f59e0b}.insight-card:nth-child(5){border-left-color:#6b7280}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.insight-content h4{font-size:14px;font-weight:600;color:var(--gray-900);margin:0 0 4px}.insight-content p{font-size:13px;color:var(--gray-600);margin:0;line-height:1.5}.insights-empty{text-align:center;padding:24px}.insights-empty p{color:var(--gray-400);font-size:14px;margin:0}.insights-error{padding:12px 16px;background:var(--red-100);color:var(--red-500);border-radius:8px;font-size:14px}.quick-actions{margin-top:24px;display:flex;justify-content:center}.reset-btn{padding:10px 20px;background:var(--gray-100);color:var(--gray-600);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.reset-btn:hover:not(:disabled){background:var(--gray-200);color:var(--gray-700)}.reset-btn:disabled{opacity:.6;cursor:not-allowed}.empty-state{text-align:center;padding:60px 20px;background:var(--white);border-radius:14px;border:1px solid var(--gray-200)}.empty-illustration{margin-bottom:16px;opacity:.6}.empty-state h3{font-size:18px;font-weight:600;color:var(--gray-900);margin:0 0 8px}.empty-state p{font-size:14px;color:var(--gray-500);margin:0}.buffer-card{background:var(--white);border:1px solid var(--gray-200);border-radius:14px;padding:16px 20px;margin-bottom:16px}.buffer-card.depleted{border-color:#fca5a5}.buffer-header{display:flex;justify-content:space-between;font-size:13px;font-weight:500;color:var(--gray-600);margin-bottom:8px}.buffer-depleted-text{color:var(--red-500)}.buffer-bar{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.buffer-fill{height:100%;border-radius:3px;background:linear-gradient(135deg,#60a5fa,#3b82f6);transition:width .3s}.buffer-overflows{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.overflow-chip{font-size:11px;padding:3px 8px;border-radius:4px;background:#fee2e2;color:#b91c1c}.pacing-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.pacing-badge.ahead{background:var(--emerald-100);color:var(--emerald-700)}.pacing-badge.behind{background:#fee2e2;color:#b91c1c}.pacing-badge.on_track{background:#dbeafe;color:#1d4ed8}.bonus-chip{margin-top:6px;font-size:11px;padding:3px 8px;border-radius:4px;background:var(--emerald-100);color:var(--emerald-700);display:inline-block;font-weight:500}.tier-section{margin-bottom:20px}.tier-section:last-child{margin-bottom:0}.tier-header{display:flex;align-items:center;gap:8px;padding:6px 0;margin-bottom:10px;font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.tier-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tier-dot.essential{background:#3b82f6}.tier-dot.goals{background:#8b5cf6}.tier-amount{margin-left:auto;font-weight:500;color:var(--gray-600);font-size:13px;text-transform:none;letter-spacing:0}.tier-note{font-size:12px;color:var(--gray-400);padding:4px 0 8px 16px;line-height:1.5}.essential-items{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.essential-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#3b82f60a;border-radius:8px;border:1px solid rgba(59,130,246,.1)}.essential-info{display:flex;align-items:center;gap:10px}.essential-value{font-size:14px;font-weight:600;color:var(--gray-700)}.goal-breakdown{display:flex;flex-direction:column;gap:6px;padding:8px 0 0 16px}.goal-item{display:flex;justify-content:space-between;font-size:13px;color:var(--gray-600);padding:6px 12px;background:#8b5cf60d;border-radius:6px}.section-actions{display:flex;align-items:center;gap:8px}.explain-toggle{background:none;border:none;color:var(--emerald-600);font-size:13px;font-weight:500;cursor:pointer;padding:4px 0}.explain-toggle:hover{text-decoration:underline}.explanations-panel{background:var(--gray-50);border-radius:10px;padding:16px;margin-bottom:20px}.explanation-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--gray-100)}.explanation-item:last-child{border-bottom:none;padding-bottom:0}.explanation-item .category-dot{margin-top:4px}.explanation-body{flex:1}.explanation-values{font-size:13px;font-weight:500;color:var(--gray-700)}.explanation-values .arrow{color:var(--gray-400);margin:0 6px}.explanation-reason{font-size:12px;color:var(--gray-500);margin-top:2px;line-height:1.4}.category-status-area{display:flex;flex-direction:column;gap:3px;align-items:flex-end;flex-shrink:0;max-width:200px}.status-detail{font-size:11px;color:var(--gray-500);text-align:right}.next-action{font-size:11px;color:var(--emerald-600);font-weight:500;text-align:right}.projected-warning{font-size:11px;color:#d97706;font-style:italic;text-align:right}.category-status-badge.buffer-absorbing{background:#dbeafe;color:#1d4ed8}.category-limit-item.buffer-absorbing{background:#3b82f60d}.limit-fill.buffer-absorbing{background:linear-gradient(135deg,#60a5fa,#3b82f6)}.projected-marker{position:absolute;top:-2px;width:2px;height:12px;background:#d97706;border-radius:1px;cursor:help}.unused-section{margin-top:16px;border-top:1px solid var(--gray-100);padding-top:4px}.unused-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;font-size:13px;font-weight:500;color:var(--gray-400);cursor:pointer;padding:8px 0}.unused-toggle svg{transition:transform .2s}.unused-toggle svg.rotated{transform:rotate(180deg)}.unused-categories{display:flex;flex-direction:column;gap:8px;padding-top:8px}.category-limit-item.unused{opacity:.45;background:var(--gray-50)}.goal-protection-prompt{background:var(--white);border:1px solid #fcd34d;border-radius:14px;padding:20px;margin-bottom:16px}.prompt-header h3{font-size:15px;font-weight:600;color:var(--gray-900);margin:0 0 4px}.prompt-header p{font-size:13px;color:var(--gray-500);margin:0 0 16px}.prompt-options{display:flex;flex-direction:column;gap:8px}.prompt-option{text-align:left;padding:14px 16px;border:1px solid var(--gray-200);border-radius:10px;background:var(--white);cursor:pointer;transition:all .15s}.prompt-option:hover{border-color:var(--emerald-300);background:#10b98108}.prompt-option.recommended{border-color:var(--emerald-300);background:#10b9810d}.option-title{font-size:14px;font-weight:500;color:var(--gray-900)}.option-subtitle{font-size:12px;color:var(--gray-500);margin-top:2px}@media(max-width:768px){.budget-main{padding:80px 16px 60px}.live-stats{grid-template-columns:1fr;gap:12px}.live-stat-card.main-stat{grid-row:auto}.category-limit-item{flex-wrap:wrap;gap:8px}.category-info{width:100%}.limit-progress{order:3;width:100%;flex:none}.limit-values{width:auto;order:2}.category-status-badge{order:4;margin-left:auto}.category-status-area{width:100%;align-items:flex-start;max-width:none;order:5}.section-actions{flex-wrap:wrap;justify-content:flex-end}.prompt-options{gap:8px}}.smart-budget-banner{display:flex;align-items:center;gap:14px;padding:16px 20px;background:linear-gradient(135deg,#8b5cf614,#3b82f60f);border:1px solid rgba(139,92,246,.2);border-radius:14px;margin-bottom:20px;animation:fadeSlideIn .4s ease forwards}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.smart-badge-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:10px;color:#fff;flex-shrink:0}.smart-badge-text{display:flex;flex-direction:column;gap:2px}.smart-badge-title{font-size:15px;font-weight:600;color:var(--gray-900)}.smart-badge-sub{font-size:12px;color:var(--gray-500)}.basic-budget-info{padding:14px 20px;background:var(--white);border:1px solid var(--gray-200);border-radius:14px;margin-bottom:20px}.basic-budget-label{font-size:13px;font-weight:600;color:var(--gray-600);margin-bottom:4px}.smart-progress-bar{height:6px;background:var(--gray-100);border-radius:3px;margin:8px 0 6px;overflow:hidden}.smart-progress-fill{height:100%;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:3px;transition:width .4s ease}.smart-progress-text{font-size:12px;color:var(--gray-400)}.persona-page{min-height:100vh;background:transparent}.persona-main{max-width:800px;margin:0 auto;padding:100px 24px 80px}.persona-header{margin-bottom:32px}.persona-header h1{font-size:28px;font-weight:700;color:var(--gray-900);margin:0 0 4px;letter-spacing:-.5px}.persona-header p{color:var(--gray-500);font-size:15px;margin:0}.persona-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px;background:var(--white);border-radius:16px;border:1px solid var(--gray-200)}.persona-locked-icon{width:64px;height:64px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--gray-400)}.persona-locked h2{font-size:20px;font-weight:700;color:var(--gray-900);margin:0 0 8px}.persona-locked p{font-size:14px;color:var(--gray-500);margin:0 0 24px;max-width:360px;line-height:1.6}.persona-progress-bar{width:240px;height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden;margin-bottom:8px}.persona-progress-fill{height:100%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-radius:4px;transition:width .6s ease}.persona-progress-text{font-size:12px;color:var(--gray-400);font-weight:500}.persona-profile-card{background:var(--white);border-radius:16px;border:1px solid var(--gray-200);overflow:hidden;margin-bottom:20px}.persona-profile-top{position:relative;padding:32px 32px 24px;display:flex;align-items:center;gap:24px}.persona-avatar-wrapper{width:120px;height:120px;border-radius:50%;overflow:hidden;flex-shrink:0;box-shadow:0 8px 24px #0000001f;border:3px solid var(--white)}.persona-avatar-wrapper img{width:100%;height:100%;object-fit:cover}.persona-profile-info{flex:1}.persona-profile-info h2{font-size:24px;font-weight:700;color:var(--gray-900);margin:0 0 4px}.persona-type-label{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:10px}.persona-type-label .dot{width:8px;height:8px;border-radius:50%}.persona-type-CAUTIOUS_SAVER{background:#60a5fa1f;color:#2563eb}.persona-type-CAUTIOUS_SAVER .dot{background:#3b82f6}.persona-type-IMPULSIVE_SPENDER{background:#f871711f;color:#dc2626}.persona-type-IMPULSIVE_SPENDER .dot{background:#ef4444}.persona-type-WEEKEND_SPLURGER{background:#fb923c1f;color:#c2410c}.persona-type-WEEKEND_SPLURGER .dot{background:#f97316}.persona-type-SUBSCRIPTION_HOARDER{background:#a78bfa1f;color:#7c3aed}.persona-type-SUBSCRIPTION_HOARDER .dot{background:#8b5cf6}.persona-type-BALANCED_BUDGETER{background:#34d3991f;color:#059669}.persona-type-BALANCED_BUDGETER .dot{background:#10b981}.persona-type-VOLATILE_SPENDER{background:#eab3081f;color:#a16207}.persona-type-VOLATILE_SPENDER .dot{background:#eab308}.persona-type-DISCIPLINED_PLANNER{background:#06b6d41f;color:#0e7490}.persona-type-DISCIPLINED_PLANNER .dot{background:#06b6d4}.persona-type-WEEKEND_SPIKER{background:#fb923c1f;color:#c2410c}.persona-type-WEEKEND_SPIKER .dot{background:#f97316}.persona-type-CATEGORY_FOCUSED_SPENDER{background:#ec48991f;color:#be185d}.persona-type-CATEGORY_FOCUSED_SPENDER .dot{background:#ec4899}.persona-description{font-size:14px;color:var(--gray-600);line-height:1.6;margin:0}.persona-stats-row{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--gray-100)}.persona-stat{padding:20px 24px;text-align:center;border-right:1px solid var(--gray-100)}.persona-stat:last-child{border-right:none}.persona-stat-value{font-size:20px;font-weight:700;color:var(--gray-900);margin-bottom:2px}.persona-stat-label{font-size:12px;font-weight:500;color:var(--gray-500)}.persona-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.persona-detail-card{background:var(--white);border-radius:14px;border:1px solid var(--gray-200);padding:24px}.persona-detail-card h3{font-size:14px;font-weight:600;color:var(--gray-900);margin:0 0 16px;display:flex;align-items:center;gap:8px}.persona-detail-card h3 svg{color:var(--emerald-500)}.persona-feature-list{display:flex;flex-direction:column;gap:10px}.persona-feature-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--gray-50);border-radius:10px}.persona-feature-rank{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.persona-feature-name{font-size:13px;font-weight:500;color:var(--gray-700)}.persona-emotional-status{display:flex;align-items:center;gap:12px;padding:16px;border-radius:10px}.persona-emotional-status.flagged{background:#f8717114;border:1px solid rgba(248,113,113,.2)}.persona-emotional-status.clear{background:#34d39914;border:1px solid rgba(52,211,153,.2)}.emotional-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.emotional-icon.flagged{background:#f8717126;color:#dc2626}.emotional-icon.clear{background:#34d39926;color:#059669}.emotional-info h4{font-size:14px;font-weight:600;margin:0 0 2px}.emotional-info.flagged h4{color:#dc2626}.emotional-info.clear h4{color:#059669}.emotional-info p{font-size:12px;color:var(--gray-500);margin:0;line-height:1.5}.confidence-meter{margin-top:8px}.confidence-bar-bg{width:100%;height:10px;background:var(--gray-100);border-radius:5px;overflow:hidden;margin-bottom:8px}.confidence-bar-fill{height:100%;border-radius:5px;transition:width .8s ease}.confidence-bar-fill.high{background:linear-gradient(135deg,#10b981,#059669)}.confidence-bar-fill.medium{background:linear-gradient(135deg,#f59e0b,#d97706)}.confidence-bar-fill.low{background:linear-gradient(135deg,#ef4444,#dc2626)}.confidence-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--gray-400);font-weight:500}.confidence-value{font-size:28px;font-weight:700;color:var(--gray-900);margin-bottom:4px}.confidence-label-text{font-size:12px;color:var(--gray-500);margin-bottom:12px}.persona-tips-card{background:var(--white);border-radius:14px;border:1px solid var(--gray-200);padding:24px}.persona-tips-card h3{font-size:14px;font-weight:600;color:var(--gray-900);margin:0 0 16px;display:flex;align-items:center;gap:8px}.persona-tips-card h3 svg{color:var(--emerald-500)}.persona-tips-list{display:flex;flex-direction:column;gap:10px}.persona-tip{display:flex;gap:10px;padding:12px;background:var(--gray-50);border-radius:10px;font-size:13px;color:var(--gray-700);line-height:1.5}.persona-tip-icon{flex-shrink:0;color:var(--emerald-500);margin-top:1px}.persona-footer{text-align:center;padding:16px;font-size:12px;color:var(--gray-400)}.persona-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px}.persona-loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--emerald-500);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.persona-loading p{font-size:14px;color:var(--gray-500)}.avatar-editor-card{grid-column:1 / -1}.avatar-editor-card h3{justify-content:space-between}.avatar-edit-toggle{padding:4px 14px;font-size:12px;font-weight:600;border:1px solid var(--gray-200);border-radius:8px;background:var(--white);color:var(--emerald-600);cursor:pointer;transition:all .15s}.avatar-edit-toggle:hover{background:#10b9810d;border-color:var(--emerald-300)}.avatar-editor{display:flex;flex-direction:column;gap:20px}.avatar-editor-preview{display:flex;justify-content:center;padding:16px 0}.avatar-editor-preview-inner{width:120px;height:120px;border-radius:50%;overflow:hidden}.avatar-editor-tabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:4px}.avatar-editor-tabs button{padding:8px 14px;font-size:12px;font-weight:600;border:1px solid var(--gray-200);border-radius:8px;background:var(--white);color:var(--gray-600);cursor:pointer;white-space:nowrap;transition:all .15s}.avatar-editor-tabs button:hover{border-color:var(--emerald-300);color:var(--emerald-600)}.avatar-editor-tabs button.active{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);border-color:transparent}.avatar-editor-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px;max-height:240px;overflow-y:auto;padding:4px}.avatar-option{position:relative;width:100%;aspect-ratio:1;border:2px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .15s;overflow:hidden}.avatar-option:hover:not(:disabled){border-color:var(--emerald-300);transform:scale(1.05)}.avatar-option.selected{border-color:var(--emerald-500);background:#10b98114;box-shadow:0 0 0 2px #10b98133}.avatar-option.locked{opacity:.5;cursor:not-allowed}.avatar-option.locked:hover{transform:none;border-color:var(--gray-200)}.avatar-option img{width:100%;height:100%;object-fit:cover;border-radius:8px}.avatar-option .lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff9;border-radius:10px}.avatar-option .lock-overlay svg{color:var(--gray-500)}.avatar-option.color-swatch{padding:0}.avatar-option .color-circle{width:70%;height:70%;border-radius:50%}.avatar-option .color-circle-none{background:var(--gray-200);display:flex;align-items:center;justify-content:center;color:var(--gray-500)}.avatar-option.frame-option .frame-preview{width:36px;height:36px;border-radius:50%;background:var(--gray-100)}.avatar-editor-actions{display:flex;gap:10px;justify-content:flex-end}.avatar-reset-btn{padding:8px 16px;font-size:13px;font-weight:500;border:1px solid var(--gray-200);border-radius:8px;background:var(--white);color:var(--gray-600);cursor:pointer;transition:all .15s}.avatar-reset-btn:hover{background:var(--gray-50)}.avatar-save-btn{padding:8px 20px;font-size:13px;font-weight:600;border:none;border-radius:8px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #10b9814d}.avatar-save-btn:hover{background:linear-gradient(135deg,var(--emerald-600),#059669)}.milestones-card{grid-column:1 / -1}.milestones-list{display:flex;flex-direction:column;gap:12px}.milestone-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:var(--gray-50);border:1px solid transparent;transition:all .2s}.milestone-item.achieved{background:#10b9810f;border-color:#10b98126}.milestone-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.milestone-item:not(.achieved) .milestone-icon{background:var(--gray-200);color:var(--gray-400)}.milestone-item.achieved .milestone-icon{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white)}.milestone-info{flex:1;min-width:0}.milestone-name{font-size:14px;font-weight:600;color:var(--gray-900);display:block;margin-bottom:2px}.milestone-desc{font-size:12px;color:var(--gray-500);display:block;margin-bottom:6px}.milestone-progress-bar{width:100%;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.milestone-item.achieved .milestone-progress-bar{background:#10b98133}.milestone-progress-fill{height:100%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-radius:3px;transition:width .6s ease}.milestone-progress-text{font-size:11px;color:var(--gray-400);margin-top:4px;display:block}.milestone-rewards{display:flex;flex-wrap:wrap;gap:4px;flex-shrink:0}.milestone-reward-badge{padding:2px 8px;font-size:10px;font-weight:600;border-radius:6px;background:var(--gray-100);color:var(--gray-600);white-space:nowrap}.milestone-item.achieved .milestone-reward-badge{background:#10b9811f;color:var(--emerald-700)}.confidence-level-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-left:6px;vertical-align:middle;text-transform:capitalize}.confidence-level-badge.high{background:#10b98126;color:#059669}.confidence-level-badge.medium{background:#f59e0b26;color:#d97706}.confidence-level-badge.low{background:#ef444426;color:#dc2626}.confidence-level-inline{display:inline-block;font-size:12px;font-weight:700;padding:2px 10px;border-radius:10px;margin-left:8px;vertical-align:middle;text-transform:capitalize}.confidence-level-inline.high{background:#10b98126;color:#059669}.confidence-level-inline.medium{background:#f59e0b26;color:#d97706}.confidence-level-inline.low{background:#ef444426;color:#dc2626}.confidence-breakdown{margin-top:16px;display:flex;flex-direction:column;gap:8px}.confidence-factor{display:flex;align-items:center;gap:8px}.confidence-factor-label{font-size:11px;font-weight:500;color:var(--gray-500);width:100px;flex-shrink:0}.confidence-factor-bar-bg{flex:1;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.confidence-factor-bar-fill{height:100%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-radius:3px;transition:width .6s ease}.confidence-factor-value{font-size:11px;font-weight:600;color:var(--gray-700);width:28px;text-align:right;flex-shrink:0}.radar-chart-card{grid-column:1 / -1}.radar-chart-container{display:flex;justify-content:center;padding:8px 0}.radar-chart-svg{width:100%;max-width:340px}.radar-label{font-size:10px;font-weight:600;fill:var(--gray-600)}.radar-value{font-size:9px;font-weight:700;fill:var(--emerald-700)}.discipline-card{grid-column:1 / -1}.discipline-body{display:flex;align-items:center;gap:24px}.discipline-score-ring{position:relative;width:80px;height:80px;flex-shrink:0}.discipline-score-ring svg{width:100%;height:100%}.discipline-score-number{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--gray-900)}.discipline-details{display:flex;gap:16px;flex-wrap:wrap}.discipline-streak{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:var(--gray-50);border-radius:10px}.discipline-streak-value{font-size:20px;font-weight:700;color:var(--gray-900)}.discipline-streak-label{font-size:11px;font-weight:500;color:var(--gray-500)}.discipline-trend{display:flex;align-items:center;gap:4px;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;text-transform:capitalize}.discipline-trend.improving{background:#10b9811a;color:#059669}.discipline-trend.worsening{background:#ef44441a;color:#dc2626}.discipline-trend.stable{background:#3b82f61a;color:#2563eb}.discipline-trend-arrow{font-size:16px}.discipline-feedback{margin:12px 0 0;font-size:13px;color:var(--gray-600);line-height:1.5;padding:10px 14px;background:var(--gray-50);border-radius:10px}.nudge-list-card{grid-column:1 / -1}.nudge-list{display:flex;flex-direction:column;gap:10px}.nudge-item{padding:14px 16px;border-radius:12px;border:1px solid}.nudge-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.nudge-type-badge{font-size:11px;font-weight:700;padding:2px 10px;border-radius:8px;text-transform:uppercase;letter-spacing:.3px}.nudge-badges{display:flex;gap:4px}.nudge-severity-badge,.nudge-timing-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:capitalize}.nudge-severity-badge.severity-strong{background:#ef44441f;color:#dc2626}.nudge-severity-badge.severity-medium{background:#f59e0b1f;color:#d97706}.nudge-severity-badge.severity-light{background:#3b82f61f;color:#2563eb}.nudge-timing-badge.timing-reactive{background:#8b5cf61a;color:#7c3aed}.nudge-timing-badge.timing-preventive{background:#06b6d41a;color:#0891b2}.nudge-item-title{font-size:14px;font-weight:600;color:var(--gray-900);margin-bottom:4px}.nudge-item-message{font-size:13px;color:var(--gray-600);line-height:1.5}@media(max-width:640px){.persona-main{padding:80px 16px 60px}.persona-profile-top{flex-direction:column;text-align:center;padding:24px 20px 20px}.persona-avatar-wrapper{width:100px;height:100px}.persona-stats-row{grid-template-columns:1fr}.persona-stat{border-right:none;border-bottom:1px solid var(--gray-100)}.persona-stat:last-child{border-bottom:none}.persona-details-grid{grid-template-columns:1fr}.avatar-editor-options{grid-template-columns:repeat(auto-fill,minmax(56px,1fr))}.milestone-item{flex-wrap:wrap}.milestone-rewards{width:100%;padding-left:48px}.discipline-body{flex-direction:column;align-items:flex-start}.discipline-details{width:100%}.radar-chart-svg{max-width:280px}}.onboarding-page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:24px;background:transparent}.onboarding-container{width:100%;max-width:560px;background:var(--white);border-radius:24px;box-shadow:0 20px 60px #0000001f;border:1px solid var(--gray-200);overflow:hidden}.progress-indicator{display:flex;justify-content:center;gap:8px;padding:24px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--gray-200);transition:all .3s ease}.progress-dot.active{background:var(--emerald-500);box-shadow:0 0 0 4px #10b98133}.progress-dot.completed{background:var(--emerald-400)}.onboarding-content{padding:32px}.step-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-header{text-align:center;margin-bottom:32px}.step-header h2{font-size:24px;font-weight:700;color:var(--gray-900);margin:0 0 8px;letter-spacing:-.5px}.step-header p{color:var(--gray-500);font-size:15px;margin:0;line-height:1.5}.welcome-header{margin-bottom:24px}.welcome-emoji{font-size:48px;display:block;margin-bottom:16px}.welcome-features{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.feature-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50);border-radius:12px}.feature-icon{font-size:24px}.feature-item span:last-child{font-size:15px;font-weight:500;color:var(--gray-700)}.step-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:var(--gray-700)}.form-group input,.form-group select{padding:12px 14px;border:1px solid var(--gray-200);border-radius:10px;font-size:15px;color:var(--gray-900);transition:all .2s;background:var(--white)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--emerald-400);box-shadow:0 0 0 3px #10b9811a}.form-group input::placeholder{color:var(--gray-400)}.input-with-prefix{position:relative;display:flex;align-items:center}.input-with-prefix .prefix{position:absolute;left:14px;color:var(--gray-400);font-size:15px;font-weight:500}.input-with-prefix input{padding-left:32px;width:100%}.optional{font-weight:400;color:var(--gray-400);font-size:12px}.form-hint{font-size:12px;color:var(--gray-400);margin:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.option-btn{padding:14px 12px;border:1px solid var(--gray-200);border-radius:10px;background:var(--white);font-size:14px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .2s;text-align:center}.option-btn:hover{border-color:var(--gray-300);background:var(--gray-50)}.option-btn.selected{border-color:var(--emerald-500);background:#10b98114;color:var(--emerald-700)}.employment-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.employment-type-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 16px;border:1px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;transition:all .2s;text-align:center}.employment-type-card:hover{border-color:var(--gray-300);background:var(--gray-50)}.employment-type-card.selected{border-color:var(--emerald-500);background:#10b9810d;box-shadow:0 0 0 3px #10b9811a}.emp-icon{font-size:36px}.emp-label{font-size:15px;font-weight:600;color:var(--gray-900)}.emp-desc{font-size:12px;color:var(--gray-500)}.income-summary{padding:20px;background:linear-gradient(135deg,#10b98114,#0d948814);border:1px solid rgba(16,185,129,.2);border-radius:12px;text-align:center}.summary-label{font-size:13px;color:var(--gray-600);margin-bottom:4px}.summary-amount{font-size:28px;font-weight:700;color:var(--emerald-600);letter-spacing:-.5px}.goal-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.goal-type-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;border:1px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;transition:all .2s;text-align:center}.goal-type-card:hover{border-color:var(--gray-300);background:var(--gray-50)}.goal-type-card.selected{border-color:var(--emerald-500);background:#10b9810d}.goal-icon{font-size:28px}.goal-label{font-size:13px;font-weight:600;color:var(--gray-900)}.goal-desc{font-size:10px;color:var(--gray-500);line-height:1.3}.goal-timeline{display:flex;align-items:center;gap:14px;padding:16px 20px;background:linear-gradient(135deg,#3b82f614,#6366f114);border:1px solid rgba(59,130,246,.2);border-radius:12px}.timeline-icon{font-size:24px}.timeline-info{display:flex;flex-direction:column}.timeline-label{font-size:12px;color:var(--gray-600)}.timeline-value{font-size:16px;font-weight:600;color:#3b82f6}.budget-style-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.budget-style-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:1px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;transition:all .2s;text-align:center}.budget-style-card:hover{border-color:var(--gray-300)}.budget-style-card.selected{border-color:var(--emerald-500);background:#10b9810d}.style-icon{font-size:28px}.style-label{font-size:14px;font-weight:600;color:var(--gray-900)}.style-desc{font-size:11px;color:var(--gray-500)}.category-chip-grid{display:flex;flex-wrap:wrap;gap:8px}.category-chip{padding:8px 14px;border:1px solid var(--gray-200);border-radius:20px;background:var(--white);font-size:13px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .2s}.category-chip:hover{border-color:var(--gray-300)}.category-chip.selected.protect{border-color:var(--emerald-400);background:#10b9811a;color:var(--emerald-700)}.category-chip.selected.cut{border-color:#f59e0b;background:#f59e0b1a;color:#b45309}.subscription-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.subscription-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;border:1px solid var(--gray-200);border-radius:12px;background:var(--white);cursor:pointer;transition:all .2s;text-align:center}.subscription-card:hover{border-color:var(--gray-300);background:var(--gray-50)}.subscription-card.selected{border-color:var(--emerald-500);background:#10b9810d}.sub-icon{font-size:24px}.sub-name{font-size:13px;font-weight:600;color:var(--gray-900)}.sub-cost{font-size:12px;color:var(--gray-500)}.selected-total{text-align:center;padding:12px;background:var(--gray-50);border-radius:10px;font-size:14px;font-weight:500;color:var(--gray-700)}.toggle-list{display:flex;flex-direction:column;gap:12px}.toggle-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--gray-50);border-radius:12px}.toggle-info{display:flex;align-items:center;gap:12px}.toggle-icon{font-size:20px}.toggle-info>div{display:flex;flex-direction:column}.toggle-label{font-size:14px;font-weight:500;color:var(--gray-900)}.toggle-desc{font-size:12px;color:var(--gray-500);margin-top:2px}.toggle-btn{width:48px;height:28px;border-radius:14px;background:var(--gray-200);border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle-btn:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--white);box-shadow:0 2px 4px #0000001a;transition:transform .2s}.toggle-btn.on{background:var(--emerald-500)}.toggle-btn.on:after{transform:translate(20px)}.step-actions{display:flex;gap:12px;margin-top:32px}.step-actions.single{justify-content:center}.btn-secondary,.btn-primary,.btn-skip{flex:1;padding:14px 20px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-skip{background:none;color:var(--gray-400);flex:.5}.btn-skip:hover{color:var(--gray-600)}.btn-primary{background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:var(--white);box-shadow:0 4px 12px #10b9814d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--emerald-600),#059669);box-shadow:0 6px 16px #10b98166}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.complete{background:linear-gradient(135deg,var(--emerald-500),#0d9488)}.error-msg{margin-top:16px;padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#dc2626;font-size:14px;text-align:center}@media(max-width:600px){.onboarding-page{padding:40px 16px 16px;align-items:flex-start}.onboarding-container{border-radius:20px}.onboarding-content{padding:24px 20px}.step-header h2{font-size:20px}.option-grid{grid-template-columns:1fr}.employment-type-grid{grid-template-columns:repeat(2,1fr);gap:10px}.employment-type-card{padding:16px 12px}.emp-icon{font-size:28px}.emp-label{font-size:13px}.goal-type-grid{grid-template-columns:repeat(2,1fr)}.goal-type-card{padding:14px 10px}.goal-icon{font-size:24px}.budget-style-grid{grid-template-columns:1fr}.subscription-grid{grid-template-columns:repeat(2,1fr)}.step-actions{flex-direction:column-reverse}.step-actions .btn-skip{flex:1;order:-1}.form-row{grid-template-columns:1fr}.toggle-item{padding:12px}.toggle-info{gap:10px}.toggle-icon{font-size:18px}.toggle-label{font-size:13px}.toggle-desc{font-size:11px}.income-summary{padding:16px}.summary-amount{font-size:24px}.goal-timeline{padding:14px 16px}}
