body{margin:0}#root{width:100%}:root{--black:#000;--near-black:#1d1d1f;--light-gray:#f5f5f7;--blue:#0071e3;--blue-dark:#06c;--white:#fff;--text-secondary:#0000008f;--text-tertiary:#00000061;--card-shadow:#0000001a 0px 2px 20px 0px;--card-shadow-md:#0000002e 3px 5px 30px 0px;--red:#ff3b30;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;color:var(--near-black);background:var(--light-gray);letter-spacing:-.374px;font-family:-apple-system,SF Pro Text,SF Pro Icons,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:17px;line-height:1.47}*{box-sizing:border-box;margin:0;padding:0}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.app{background:var(--light-gray);min-height:100svh}.main{max-width:600px;margin:0 auto;padding:80px 20px 48px}.pull-indicator{justify-content:center;align-items:center;margin-top:-16px;transition:height .2s;display:flex;overflow:hidden}.pull-icon{width:22px;height:22px;color:var(--text-secondary);transform:rotate(calc(var(--pull-progress,0) * 180deg));flex-shrink:0;transition:transform .1s}.pull-icon.spinning{animation:.8s linear infinite spin;transform:none}@keyframes spin{to{transform:rotate(360deg)}}.nav{-webkit-backdrop-filter:saturate(180%)blur(20px);z-index:100;background:#000000d1;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{color:var(--white);letter-spacing:-.374px;font-size:17px;font-weight:600}.nav-tabs{gap:4px;display:flex}.nav-tab{color:#ffffffa6;letter-spacing:-.224px;background:0 0;border:none;border-radius:980px;padding:6px 12px;font-size:14px;font-weight:400;transition:color .15s,background .15s}.nav-tab:hover{color:var(--white)}.nav-tab.active{color:var(--white);background:#ffffff24}.bottom-nav{display:none}@media (width<=640px){.nav .nav-tabs{display:none}.bottom-nav{height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);-webkit-backdrop-filter:saturate(180%)blur(20px);z-index:100;background:#fafafce0;border-top:1px solid #0000001a;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tab{color:#00000061;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;transition:color .15s;display:flex}.bottom-tab svg{stroke:currentColor;width:24px;height:24px}.bottom-tab span{letter-spacing:-.08px;font-size:10px;font-weight:500}.bottom-tab.active{color:var(--blue)}.bottom-tab:active{opacity:.6}.main{padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.user-picker{grid-template-columns:repeat(2,1fr)!important}.user-chip.family{flex-direction:row;grid-column:1/-1;justify-content:center;gap:10px;padding:12px 10px}}.flash{background:var(--near-black);color:var(--white);letter-spacing:-.224px;z-index:200;white-space:nowrap;box-shadow:var(--card-shadow-md);border-radius:980px;padding:10px 20px;font-size:14px;animation:.25s fadeSlide;position:fixed;top:66px;left:50%;transform:translate(-50%)}@keyframes fadeSlide{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.section-header{margin-bottom:28px}.section-title{letter-spacing:-.5px;color:var(--near-black);font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:40px;font-weight:600;line-height:1.1}.section-sub{color:var(--text-secondary);letter-spacing:-.374px;margin-top:4px;font-size:17px}.family-card{background:var(--near-black);box-shadow:var(--card-shadow);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:18px 20px;display:flex}.family-card.negative{background:#3a1a1a}.family-card-label{color:var(--white);letter-spacing:-.374px;font-size:17px;font-weight:600}.family-card-sub{color:#ffffff80;letter-spacing:-.12px;margin-top:2px;font-size:12px}.family-card-amount{color:var(--white);letter-spacing:-.5px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:32px;font-weight:600;line-height:1}.family-card-amount.neg{color:#ff6b63}.balance-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:32px;display:grid}.balance-card{background:var(--white);box-shadow:var(--card-shadow);border-radius:12px;flex-direction:column;gap:4px;padding:20px 18px;transition:transform .15s;display:flex}.balance-card:hover{box-shadow:var(--card-shadow-md);transform:translateY(-1px)}.balance-card.negative{background:#fff5f5}.balance-emoji{margin-bottom:4px;font-size:28px;line-height:1}.balance-name{color:var(--text-secondary);letter-spacing:-.224px;font-size:14px;font-weight:600}.balance-amount{color:var(--near-black);letter-spacing:-.5px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:28px;font-weight:600;line-height:1.14}.balance-amount.neg{color:var(--red)}.balance-daily{color:var(--text-tertiary);letter-spacing:-.12px;font-size:12px}.today-section{margin-bottom:28px}.today-heading{letter-spacing:-.3px;color:var(--near-black);margin-bottom:12px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:21px;font-weight:600}.expense-list{background:var(--white);box-shadow:var(--card-shadow);border-radius:12px;overflow:hidden}.expense-row{border-bottom:1px solid #0000000f;align-items:center;gap:12px;padding:13px 16px;display:flex}.expense-row:last-child{border-bottom:none}.expense-icon{text-align:center;flex-shrink:0;width:32px;font-size:22px}.expense-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.expense-cat{color:var(--near-black);letter-spacing:-.224px;font-size:15px;font-weight:500}.expense-note{color:var(--text-tertiary);letter-spacing:-.12px;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.expense-who{color:var(--text-tertiary);letter-spacing:-.12px;flex-shrink:0;font-size:12px}.expense-amt{color:var(--red);letter-spacing:-.224px;flex-shrink:0;font-size:15px;font-weight:600}.expense-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.delete-btn{color:var(--text-tertiary);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:12px;transition:background .15s,color .15s;display:flex}.delete-btn:hover{color:var(--red);background:#ff3b301f}.log-cta{justify-content:center;margin-top:8px;display:flex}.btn-primary{background:var(--blue);color:var(--white);letter-spacing:-.374px;border:none;border-radius:980px;padding:12px 28px;font-size:17px;font-weight:400;transition:background .15s,transform .1s}.btn-primary:hover{background:#0077ed}.btn-primary:active{background:#005cbf;transform:scale(.97)}.log-screen{flex-direction:column;gap:28px;display:flex}.field-group{flex-direction:column;gap:10px;display:flex}.field-label{color:var(--text-secondary);letter-spacing:-.224px;text-transform:uppercase;font-size:12px;font-weight:600}.optional{text-transform:none;color:var(--text-tertiary);font-size:12px;font-weight:400}.user-picker{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.user-chip{background:var(--white);color:var(--near-black);box-shadow:var(--card-shadow);letter-spacing:-.224px;border:2px solid #0000;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:14px 10px;font-size:15px;transition:border-color .15s,transform .1s;display:flex}.user-chip span:first-child{font-size:28px;line-height:1}.user-chip span:nth-child(2){font-size:15px;font-weight:500}.chip-bal{color:var(--text-secondary)!important;font-size:12px!important;font-weight:400!important}.user-chip.active{border-color:var(--blue)}.user-chip:active{transform:scale(.97)}.category-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.cat-btn{background:var(--white);box-shadow:var(--card-shadow);border:2px solid #0000;border-radius:12px;flex-direction:column;align-items:center;gap:5px;padding:12px 6px;transition:border-color .15s,transform .1s;display:flex}.cat-icon{font-size:24px;line-height:1}.cat-label{color:var(--near-black);letter-spacing:-.12px;text-align:center;font-size:11px;line-height:1.2}.cat-btn.active{border-color:var(--blue);background:#0071e30f}.cat-btn:active{transform:scale(.95)}.amount-input-wrap{background:var(--white);box-shadow:var(--card-shadow);border:2px solid #0000;border-radius:12px;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.amount-input-wrap:focus-within{border-color:var(--blue)}.currency-sign{color:var(--text-secondary);flex-shrink:0;padding:0 0 0 18px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:28px;font-weight:600;line-height:1}.amount-input{color:var(--near-black);letter-spacing:-.5px;-moz-appearance:textfield;background:0 0;border:none;outline:none;width:100%;padding:16px 18px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:28px;font-weight:600}.amount-input::-webkit-outer-spin-button{-webkit-appearance:none}.amount-input::-webkit-inner-spin-button{-webkit-appearance:none}.quick-amounts{gap:8px;display:flex}.quick-amt{background:var(--white);color:var(--blue-dark);letter-spacing:-.224px;border:1px solid #00000014;border-radius:8px;flex:1;padding:8px 4px;font-size:14px;font-weight:500;transition:background .12s,color .12s}.quick-amt:hover{background:#0071e314}.quick-amt:active{background:#0071e326}.note-input{background:var(--white);color:var(--near-black);letter-spacing:-.374px;width:100%;box-shadow:var(--card-shadow);border:2px solid #00000014;border-radius:12px;outline:none;padding:13px 16px;font-size:17px;transition:border-color .15s}.note-input:focus{border-color:var(--blue)}.note-input::placeholder{color:var(--text-tertiary)}.confirm-bar{background:var(--white);box-shadow:var(--card-shadow-md);border-radius:16px;flex-direction:column;gap:14px;padding:18px 20px;display:flex}.confirm-summary{color:var(--near-black);letter-spacing:-.374px;justify-content:space-between;align-items:center;font-size:17px;font-weight:500;display:flex}.confirm-amt{color:var(--red);letter-spacing:-.3px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:21px;font-weight:600}.confirm-bar .btn-primary{text-align:center;width:100%}.history-screen{flex-direction:column;gap:24px;display:flex}.history-group{flex-direction:column;gap:8px;display:flex}.history-date{color:var(--text-secondary);letter-spacing:-.224px;justify-content:space-between;padding:0 4px;font-size:14px;font-weight:600;display:flex}.history-total{color:var(--red);font-weight:600}.empty-state{text-align:center;color:var(--text-secondary);letter-spacing:-.374px;padding:60px 0;font-size:17px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#e8e8ea 25%,#f2f2f4 50%,#e8e8ea 75%) 0 0/800px 100%;border-radius:8px;animation:1.4s linear infinite shimmer}.skeleton-title{border-radius:10px;width:100px;height:44px}.skeleton-sub{width:180px;height:18px;margin-top:8px}.skeleton-family-card{border-radius:12px;height:80px;margin-bottom:12px}.skeleton-emoji{border-radius:50%;width:32px;height:32px;margin-bottom:8px}.skeleton-name{width:48px;height:14px;margin-bottom:8px}.skeleton-amount{border-radius:6px;width:80px;height:32px}.saving-overlay{z-index:400;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner{border:3px solid #00000014;border-top-color:var(--blue);background:var(--white);width:36px;height:36px;box-shadow:var(--card-shadow-md);box-sizing:content-box;border-radius:50%;padding:6px;animation:.7s linear infinite spin}.pin-screen{background:var(--black);flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:100svh;padding-bottom:32px;display:flex}.pin-title{color:var(--white);letter-spacing:-.3px;margin-bottom:4px;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:28px;font-weight:600}.pin-sub{color:#ffffff80;letter-spacing:-.224px;margin-bottom:24px;font-size:15px}.pin-dots{gap:16px;margin-bottom:40px;display:flex}.pin-dot{border:2px solid #fff6;border-radius:50%;width:14px;height:14px;transition:background .15s,border-color .15s}.pin-dot.filled{background:var(--white);border-color:var(--white)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.pin-dots.shake .pin-dot.filled{background:var(--red);border-color:var(--red)}.pin-dots.shake{animation:.5s shake}.pin-pad{flex-direction:column;gap:12px;display:flex}.pin-row{gap:20px;display:flex}.pin-key{width:76px;height:76px;color:var(--white);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:28px;font-weight:400;transition:background .1s,transform .1s;display:flex}.pin-key:active{background:#ffffff40;transform:scale(.93)}.pin-key.empty{pointer-events:none;background:0 0}.pin-key.del{background:0 0;font-size:22px}.pin-key.del:active{background:#ffffff1a}.dialog-backdrop{-webkit-backdrop-filter:blur(4px);z-index:300;background:#0006;justify-content:center;align-items:flex-end;padding:0 16px 32px;animation:.2s backdropIn;display:flex;position:fixed;inset:0}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.dialog{background:var(--white);width:100%;max-width:400px;box-shadow:var(--card-shadow-md);border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:28px 24px 24px;animation:.25s cubic-bezier(.34,1.56,.64,1) dialogIn;display:flex}@keyframes dialogIn{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.dialog-icon{margin-bottom:4px;font-size:36px;line-height:1}.dialog-title{color:var(--near-black);letter-spacing:-.3px;text-align:center;font-family:-apple-system,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:21px;font-weight:600}.dialog-detail{color:var(--near-black);letter-spacing:-.224px;text-align:center;font-size:15px;font-weight:500}.dialog-sub{color:var(--text-secondary);letter-spacing:-.224px;text-align:center;margin-bottom:8px;font-size:14px}.dialog-actions{gap:10px;width:100%;margin-top:4px;display:flex}.btn-ghost{background:var(--light-gray);color:var(--near-black);letter-spacing:-.374px;border:none;border-radius:980px;flex:1;padding:12px 20px;font-size:17px;font-weight:400;transition:background .15s}.btn-ghost:hover{background:#e8e8ea}.btn-danger{background:var(--red);color:var(--white);letter-spacing:-.374px;border:none;border-radius:980px;flex:1;padding:12px 20px;font-size:17px;font-weight:400;transition:background .15s,transform .1s}.btn-danger:hover{background:#e0352b}.btn-danger:active{transform:scale(.97)}@media (width<=480px){.main{padding:72px 16px 40px}.section-title{font-size:32px}.balance-grid{gap:10px}.balance-amount{font-size:24px}.category-grid{gap:6px}.cat-btn{padding:10px 4px}.cat-icon{font-size:20px}.cat-label{font-size:10px}.user-picker{gap:8px}}
