*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8fafc;--card:#ffffff;--card-hover:#f8fafc;--text:#0f172a;--text-2:#374151;--muted:#64748b;--very-muted:#94a3b8;--border:#e2e8f0;--border-lt:#f1f5f9;--input-bg:#f8fafc;--hover:#f1f5f9;--sidebar:#0f172a;--green:#16a34a}html.dark{color-scheme:dark;--bg:#0d1117;--card:#161b22;--card-hover:#1c2128;--text:#e6edf3;--text-2:#c9d1d9;--muted:#8b949e;--very-muted:#6e7681;--border:#30363d;--border-lt:#21262d;--input-bg:#21262d;--hover:#1c2128;--sidebar:#010409}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);transition:background .25s,color .25s}button{cursor:pointer}button,input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}html.dark ::-webkit-scrollbar-thumb{background:#30363d}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes barFillAnim{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-14px) rotate(1deg)}66%{transform:translateY(-7px) rotate(-1deg)}}@keyframes floatSlow{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(2deg)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulseGreen{0%,to{box-shadow:0 0 0 0 rgba(22,163,74,.45)}50%{box-shadow:0 0 0 10px rgba(22,163,74,0)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes checkmark{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}.a-slideUp{animation:slideUp .55s cubic-bezier(.16,1,.3,1) both}.a-slideDown{animation:slideDown .45s cubic-bezier(.16,1,.3,1) both}.a-slideInLeft{animation:slideInLeft .55s cubic-bezier(.16,1,.3,1) both}.a-slideInRight{animation:slideInRight .55s cubic-bezier(.16,1,.3,1) both}.a-scaleIn{animation:scaleIn .45s cubic-bezier(.16,1,.3,1) both}.a-fadeIn{animation:fadeIn .4s ease both}.a-float{animation:float 5s ease-in-out infinite}.a-floatSlow{animation:floatSlow 7s ease-in-out infinite}.a-shake{animation:shake .4s cubic-bezier(.36,.07,.19,.97)}.d-0{animation-delay:0s}.d-1{animation-delay:.06s}.d-2{animation-delay:.12s}.d-3{animation-delay:.18s}.d-4{animation-delay:.24s}.d-5{animation-delay:.3s}.d-6{animation-delay:.36s}.d-7{animation-delay:.42s}.d-8{animation-delay:.48s}.d-9{animation-delay:.54s}.bar-fill{transform-origin:left;animation:barFillAnim 1s cubic-bezier(.16,1,.3,1) both}.bar-fill.d-1{animation-delay:.1s}.bar-fill.d-2{animation-delay:.2s}.bar-fill.d-3{animation-delay:.3s}.bar-fill.d-4{animation-delay:.4s}.bar-fill.d-5{animation-delay:.5s}.auth-root{height:100vh}.auth-brand,.auth-root{display:flex;overflow:hidden}.auth-brand{width:46%;position:relative;background:#080f1a;flex-direction:column;justify-content:center;padding:clamp(44px,9vh,100px) 60px;flex-shrink:0}.auth-brand>*{position:relative;z-index:1}.phone-frame{border-radius:30px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.55),0 8px 20px rgba(0,0,0,.3);flex-shrink:0}.phone-island{width:48px;height:7px;background:#0a0f1a;border-radius:4px;margin:7px auto 0}.brand-carousel{position:relative;height:185px}.carousel-slide{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;opacity:0;transform:translateY(16px);transition:opacity .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1);pointer-events:none;will-change:opacity,transform}.carousel-slide.active{opacity:1;transform:translateY(0);pointer-events:auto}.carousel-slide.leaving{opacity:0;transform:translateY(-16px);pointer-events:none}@keyframes fillProgress{0%{width:0}to{width:100%}}.progress-fill-active{height:100%;width:0;border-radius:99px;background:#4ade80;animation:fillProgress 4.5s linear forwards}.progress-fill-done{height:100%;width:100%;border-radius:99px;background:rgba(74,222,128,.38)}.progress-fill-empty{height:100%;width:0;border-radius:99px;background:transparent}.progress-bar-btn{flex:1 1;height:3px;padding:0;border:none;cursor:pointer;background:rgba(255,255,255,.1);border-radius:99px;overflow:hidden}.progress-bar-btn:focus-visible{outline:2px solid rgba(74,222,128,.5);outline-offset:2px}.auth-form-panel{flex:1 1;display:flex;align-items:center;justify-content:center;padding:clamp(36px,7vh,64px) 56px;background:#fff;border-left:none;box-shadow:inset 3px 0 0 0 rgba(22,163,74,.08);position:relative;overflow-y:auto;animation:slideInRight .6s cubic-bezier(.16,1,.3,1) both}.auth-input{width:100%;padding:13px 16px;border:1.5px solid #e2e8f0;border-radius:12px;font-size:15px;color:#0f172a;background:#f8fafc;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s;outline:none}.auth-input:focus{border-color:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.12);background:#fff}.auth-input.has-error{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.1)}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 0;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;outline:none;position:relative;overflow:hidden}.oauth-btn:after{content:"";position:absolute;inset:0;background:rgba(255,255,255,.08);opacity:0;transition:opacity .15s}.oauth-btn:hover:after{opacity:1}.oauth-btn:active{transform:scale(.98)}.oauth-google{border:1.5px solid #e2e8f0;background:#fff;color:#374151}.oauth-google:hover{border-color:#94a3b8;background:#f8fafc}.oauth-apple{border:none;background:#0f172a;color:#fff}.oauth-apple:hover{background:#1e293b}.auth-submit{width:100%;padding:14px 0;border:none;border-radius:12px;font-size:15px;font-weight:700;color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);cursor:pointer;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s,opacity .15s;letter-spacing:.01em}.auth-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15) 50%,transparent);background-size:200% 100%;opacity:0;transition:opacity .3s}.auth-submit:hover:before{opacity:1;animation:shimmer 1.4s linear infinite}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px rgba(22,163,74,.35)}.auth-submit:active:not(:disabled){transform:scale(.98) translateY(0)}.auth-submit:disabled{opacity:.65;cursor:not-allowed}.eye-btn{position:absolute;right:13px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#94a3b8;font-size:17px;padding:3px;line-height:1;transition:color .15s;border-radius:6px}.eye-btn:hover{color:#16a34a}.auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0}.auth-divider span{font-size:12px;color:#94a3b8;font-weight:500;white-space:nowrap}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:#e2e8f0}.stat-card{background:var(--card);border-radius:16px;padding:20px 22px;border:1px solid var(--border-lt);box-shadow:0 1px 4px rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s;cursor:default}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}.hover-lift{transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;margin-bottom:2px;text-decoration:none;transition:background .15s}.nav-link:hover{background:rgba(255,255,255,.07)}.nav-link:hover span{color:#e2e8f0}.nav-link:hover svg{stroke:#e2e8f0}.signout-btn{transition:background .15s,border-color .15s}.signout-btn:hover{background:rgba(255,255,255,.07)!important;border-color:rgba(255,255,255,.2)!important}.modal-backdrop{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal-card{animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}.ob-step{animation:slideUp .38s cubic-bezier(.16,1,.3,1) both}.ob-input{transition:border-color .18s,box-shadow .18s}.ob-input:focus{border-color:#16a34a!important;box-shadow:0 0 0 3px rgba(22,163,74,.12);outline:none}.ob-input.error{border-color:#ef4444!important}.ob-goal-btn{transition:border-color .15s,background .15s,transform .12s}.ob-goal-btn:hover{border-color:#16a34a!important;background:#f0fdf4!important;transform:translateY(-1px)}.ob-goal-btn:active{transform:scale(.97)}.action-btn{padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .12s,transform .1s}.action-btn:hover{opacity:.85}.action-btn:active{transform:scale(.96)}.add-chip{border-width:1px;border-style:solid;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;background:transparent;transition:background .15s,transform .12s}.add-chip:hover{opacity:.8;transform:scale(1.04)}.add-chip:active{transform:scale(.97)}.month-nav-btn{transition:background .15s,transform .12s,box-shadow .15s}.month-nav-btn:hover{background:var(--hover)!important;transform:scale(1.06)}.month-nav-btn:active{transform:scale(.95)}.btn-primary{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);background-size:200% 100%;opacity:0;transition:opacity .3s}.btn-primary:hover:not(:disabled):before{opacity:1;animation:shimmer 1.2s linear infinite}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(22,163,74,.3)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.goal-card{border-radius:14px;padding:16px 18px;background:var(--card);border:1px solid var(--border-lt);border-left-width:4px;transition:transform .2s,box-shadow .2s}.goal-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}.cat-card{background:var(--card);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.05);margin-bottom:10px;transition:box-shadow .2s}.cat-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.09)}.income-header-btn{transition:opacity .15s}.income-header-btn:hover{opacity:.85}.theme-toggle-btn{width:100%;padding:8px 12px;display:flex;align-items:center;gap:10px;background:transparent;border:none;cursor:pointer;border-radius:8px;color:#64748b;font-size:14px;text-align:left;transition:background .15s,color .15s}.theme-toggle-btn:hover{background:rgba(255,255,255,.06);color:#94a3b8}.auth-particle{position:absolute;border-radius:50%;pointer-events:none}.pw-seg{flex:1 1;height:3px;border-radius:2px;transition:background .3s ease}