:root{--color-bg:#f8f2eb;--color-surface:#fffffe;--color-surface-2:#f0eae3;--color-surface-3:#e8e2db;--color-accent:#c23430;--color-accent-dim:#c2343014;--color-accent-border:#c2343033;--color-text:#232222;--color-text-2:#5e5e5e;--color-text-3:#767676;--color-text-inv:#fffffe;--color-error:#c23430;--color-error-dim:#c2343014;--color-success:#2b6b4d;--color-success-dim:#2b6b4d14;--color-border:#23222214;--color-border-2:#23222226;--font-display:"Crimson Pro", "Georgia", serif;--font-ui:"DM Mono", "SF Mono", monospace;--mono:"DM Mono", "SF Mono", monospace;--font-body:system-ui, -apple-system, "Segoe UI", sans-serif;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:.9375rem;--text-lg:1rem;--text-xl:1.125rem;--text-2xl:1.375rem;--text-3xl:1.75rem;--text-4xl:2.25rem;--text-5xl:3rem;--leading-tight:1.2;--leading-snug:1.35;--leading-normal:1.5;--leading-relaxed:1.6;--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--space-0:0;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--duration-fast:.15s;--duration-base:.2s;--duration-slow:.3s;--z-base:1;--z-sticky:10;--z-footer:20;--z-nav:50;--z-modal:500;--z-toast:999;--z-island:999;--touch-min:44px;--phone-max-width:430px;--pad-h:20px;--status-bar-height:16px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--color-bg);width:100%;height:100%;color:var(--color-text);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-regular);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{width:100%;height:100%}body{overscroll-behavior:none}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.shell{background:var(--color-bg);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.phone{width:100%;max-width:var(--phone-max-width);background:var(--color-bg);height:100dvh;position:relative;overflow:hidden}.island{width:126px;height:36px;z-index:var(--z-island);background:#232222;border-radius:20px;position:absolute;top:10px;left:50%;transform:translate(-50%)}.status{height:var(--status-bar-height);z-index:998;pointer-events:none;justify-content:space-between;align-items:flex-end;padding:0 26px 6px;display:flex;position:absolute;top:0;left:0;right:0}.status-time{font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-medium);letter-spacing:-.02em}.status-icons{gap:var(--space-2);pointer-events:all;align-items:center;display:flex}.status-icons svg{opacity:.7}.screens{position:absolute;inset:0;overflow:hidden}.route-suspense{background:var(--color-bg);position:absolute;inset:0}.screen{scrollbar-width:none;-ms-overflow-style:none;opacity:0;pointer-events:none;transition:opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out);position:absolute;inset:0;overflow:hidden auto;transform:translateY(16px)}.screen::-webkit-scrollbar{display:none}.screen.active{opacity:1;pointer-events:all;transform:translateY(0)}.btn{justify-content:center;align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--mono);font-weight:var(--weight-medium);letter-spacing:-.01em;transition:all var(--duration-base) var(--ease-out);-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:var(--touch-min);border-radius:var(--radius-full);border:none;outline:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-accent);color:var(--color-text-inv);font-size:var(--text-base);width:100%;padding:14px 20px}.btn-primary:hover{filter:brightness(.9)}.btn-secondary{background:var(--color-surface);color:var(--color-text-2);font-size:var(--text-base);border:1px solid var(--color-border-2);padding:12px 16px}.btn-green{background:var(--color-accent);color:var(--color-text-inv);font-size:var(--text-base);width:100%;padding:14px 20px}.btn-done{border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-text-inv);font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);min-height:var(--touch-min);border:none;padding:6px 14px}.btn-done:active{transform:scale(.95)}.btn-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-ghost{color:var(--color-text-2);font-family:var(--mono);font-size:var(--text-sm);cursor:pointer;text-underline-offset:3px;text-decoration:underline;-webkit-text-decoration-color:var(--color-border-2);text-decoration-color:var(--color-border-2);transition:color var(--duration-base);background:0 0;border:none;padding:4px 0}.btn-ghost:hover{color:var(--color-text)}.btn-add-friend{border:1px dashed var(--color-border-2);color:var(--color-text-2);border-radius:var(--radius-full);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);background:0 0;min-height:32px;padding:6px 12px}.btn-add-friend:hover{border-color:var(--color-accent);color:var(--color-accent)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.card-padded{padding:0 var(--space-3)}.tear-divider{border:none;border-top:2px dashed var(--color-border-2);width:100%;height:1px;margin:var(--space-2) 0}.form-group{margin-bottom:var(--space-3)}.form-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);display:block}.form-input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-regular);transition:all var(--duration-base) var(--ease-out);box-sizing:border-box;height:50px;min-height:var(--touch-min);outline:none;padding:0 16px;box-shadow:0 1px 3px #1813100a}.form-input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim), 0 1px 3px #1813100a}.form-input::placeholder{color:var(--color-text-3);font-weight:var(--weight-light);font-style:italic}.form-row{gap:var(--space-2);align-items:center;display:flex}input[type=text],input[type=number]{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-regular);transition:all var(--duration-base) var(--ease-out);box-sizing:border-box;height:50px;min-height:var(--touch-min);outline:none;padding:0 16px;box-shadow:0 1px 3px #1813100a}input[type=text]:focus,input[type=number]:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim), 0 1px 3px #1813100a}input[type=text]::placeholder,input[type=number]::placeholder{color:var(--color-text-3);font-weight:var(--weight-light);font-style:italic}.form-error-banner{background:var(--color-error-dim);color:var(--color-error);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);margin-bottom:var(--space-3)}.header-row{align-items:center;gap:var(--space-3);margin-bottom:var(--space-1);display:flex}.header-back{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;width:36px;height:36px;transition:all var(--duration-base) var(--ease-out);color:var(--color-text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.header-back:active{transform:scale(.93)}.header-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;flex:1}.header-row-inner{align-items:center;gap:var(--space-3);display:flex}.header-save-btn{color:var(--color-text-2);font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;min-height:var(--touch-min);background:0 0;border:none}.inline-edit-row{align-items:center;gap:var(--space-2);display:flex}.inline-edit-input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);transition:all var(--duration-base) var(--ease-out);outline:none;flex:1;padding:8px 12px;box-shadow:0 1px 3px #1813100a}.inline-edit-input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim)}.inline-edit-confirm{border-radius:var(--radius-full);background:var(--color-accent);width:36px;height:36px;color:var(--color-text-inv);cursor:pointer;transition:all var(--duration-base) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.inline-edit-confirm:active{transform:scale(.93)}.empty-state{padding:var(--space-12) var(--space-4);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-text{font-size:var(--text-base);color:var(--color-text-2);line-height:var(--leading-relaxed)}.loading-screen{justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;height:100%;display:flex}.loading-spinner{border:2.5px solid var(--color-border-2);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.loading-text{font-size:var(--text-base);color:var(--color-text-2)}.back-btn{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;width:36px;height:36px;transition:all var(--duration-base) var(--ease-out);color:var(--color-text);border-radius:50%;justify-content:center;align-items:center;display:flex}.back-btn:active{transform:scale(.93)}.add-item-bar{padding:var(--space-2) var(--pad-h)}.add-item-row{gap:var(--space-2);align-items:center;display:flex}.add-item-input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-regular);transition:all var(--duration-base) var(--ease-out);height:44px;min-height:var(--touch-min);outline:none;flex:1;padding:0 12px;box-shadow:0 1px 3px #1813100a}.add-item-input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim)}.add-item-input::placeholder{color:var(--color-text-3);font-weight:var(--weight-light);font-style:italic}.add-item-btn{width:var(--touch-min);height:var(--touch-min);border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-text-inv);font-size:var(--text-xl);cursor:pointer;transition:all var(--duration-base) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.add-item-btn:active{transform:scale(.93)}.recovery-bar{gap:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);margin:var(--space-2) var(--pad-h);flex-direction:column;display:flex}.recovery-bar-title{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2)}.recovery-bar-sub{font-size:var(--text-xs);color:var(--color-text-2)}.recovery-input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-regular);transition:all var(--duration-base) var(--ease-out);outline:none;flex:1;min-width:0;height:36px;padding:0 8px}.recovery-input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 2px var(--color-accent-dim)}.recovery-btn{border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-text-inv);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);cursor:pointer;white-space:nowrap;transition:all var(--duration-base) var(--ease-out);border:none;padding:6px 12px}.recovery-btn:active{transform:scale(.95)}.edit-row{align-items:center;gap:var(--space-2);display:flex}.edit-input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-regular);transition:all var(--duration-base) var(--ease-out);outline:none;flex:1;height:40px;min-height:40px;padding:0 12px;box-shadow:0 1px 3px #1813100a}.edit-input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim)}.edit-confirm{border-radius:var(--radius-full);background:var(--color-accent);width:36px;height:36px;color:var(--color-text-inv);cursor:pointer;transition:all var(--duration-base) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.edit-confirm:active{transform:scale(.93)}.edit-cancel{border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-2);cursor:pointer;transition:all var(--duration-base) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;display:flex}.edit-cancel:active{transform:scale(.93)}.item-action-btn{border-radius:var(--radius-full);cursor:pointer;width:36px;height:36px;transition:all var(--duration-base) var(--ease-out);color:var(--color-text-3);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.item-action-btn:active{transform:scale(.9)}.item-action-btn.edit{color:var(--color-accent)}.item-action-btn.delete{color:var(--color-error)}.backend-badge{z-index:997;align-items:center;gap:var(--space-1);border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2);padding:4px 10px;display:inline-flex;position:absolute;top:60px;left:12px}.backend-badge-dot{border-radius:50%;width:6px;height:6px}.backend-badge-dot.online{background:var(--color-success)}.backend-badge-dot.offline{background:var(--color-text-3)}.ws-badge{align-items:center;padding:0 4px;display:inline-flex}.ws-badge-dot{width:6px;height:6px;transition:background var(--duration-base);border-radius:50%}.ws-badge-dot.connected{background:var(--color-success)}.ws-badge-dot.connecting{background:var(--color-text-3);animation:1s infinite pulse}.ws-badge-dot.disconnected{background:var(--color-error)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.offline-banner{justify-content:center;align-items:center;gap:var(--space-2);padding:10px var(--space-4);background:var(--color-surface-2);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-2);display:flex}.offline-banner-icon{font-size:14px}.token-reveal-sheet{background:var(--color-bg);z-index:var(--z-modal);padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.token-reveal-body{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:320px;display:flex}.token-reveal-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);letter-spacing:-.5px;margin-bottom:var(--space-3)}.token-reveal-desc{font-size:var(--text-sm);color:var(--color-text-2);margin-bottom:var(--space-6);line-height:var(--leading-relaxed)}.token-reveal-token-box{background:var(--color-surface);border:1px solid var(--color-border-2);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);font-family:var(--mono);font-size:var(--text-lg);font-weight:var(--weight-medium);letter-spacing:1px;color:var(--color-accent);margin-bottom:var(--space-4);word-break:break-all;text-align:center;width:100%}.token-reveal-link-box{background:var(--color-surface-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-xs);color:var(--color-accent);font-family:var(--mono);justify-content:space-between;align-items:center;gap:var(--space-3);cursor:pointer;width:100%;margin-bottom:var(--space-5);display:flex}.token-reveal-link-copy{font-size:var(--text-xs);color:var(--color-text-2);white-space:nowrap}.token-reveal-link-hint{font-size:var(--text-xs);color:var(--color-text-2);margin-bottom:var(--space-2)}.token-reveal-copy-btn{margin-bottom:var(--space-3)}.token-reveal-continue-btn{margin-top:0}.split-header-row{align-items:center;gap:var(--space-3);padding:var(--status-bar-height) var(--pad-h) var(--space-3);display:flex}.split-header-row .header-back{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;width:36px;height:36px;transition:all var(--duration-base) var(--ease-out);color:var(--color-text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.split-header-row .header-back:active{transform:scale(.93)}#home{background:var(--color-bg)}.home-pad{padding:var(--status-bar-height) var(--pad-h) var(--space-4)}.home-greeting{font-family:var(--font-display);font-size:30px;font-weight:var(--weight-light);margin-bottom:var(--space-1);line-height:1.12}.home-name{font-family:var(--font-display);font-size:30px;font-weight:var(--weight-light);letter-spacing:-.01em;color:var(--color-accent);display:inline}.balance-card{margin:var(--space-5) 0;border-radius:var(--radius-xl);background:linear-gradient(155deg,#1c1510 0%,#2a211a 50%,#1e1812 100%);padding:26px 24px 22px;position:relative;overflow:hidden;box-shadow:0 24px 64px #1813102e}.balance-card:before{content:"";border:1px solid #ffffff08;border-radius:50%;width:120px;height:120px;position:absolute;top:-40px;right:-30px}.balance-card:after{content:"";background:#c234300f;border-radius:50%;width:80px;height:80px;position:absolute;bottom:-20px;left:16px}.balance-label{font-family:var(--mono);font-size:var(--text-xs);color:#fdf9f380;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1);font-weight:var(--weight-light)}.balance-amount{font-family:var(--mono);font-size:40px;font-weight:var(--weight-medium);letter-spacing:-.03em;color:#fdf9f3;margin-top:8px;line-height:1}.balance-sub{font-size:var(--text-sm);color:#fdf9f373;margin-top:var(--space-2);font-weight:var(--weight-light)}.quick-actions{gap:var(--space-1);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.qa{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;align-items:center;padding:0;display:flex}.qa-ic{border-radius:var(--radius-md);background:var(--color-surface);border:1.5px solid var(--color-border);width:48px;height:48px;transition:all var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;font-size:18px;display:flex;box-shadow:0 1px 3px #1813100d}.qa:active .qa-ic{box-shadow:none;transform:scale(.9)}.qa-ic-a{background:var(--color-accent-dim);border-color:var(--color-accent-border);color:var(--color-accent)}.qa-l{color:var(--color-text-3);letter-spacing:.02em;font-size:10px;font-family:var(--mono);margin-top:7px}.section-title{font-family:var(--font-display);font-size:20px;font-weight:var(--weight-regular);margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.section-see{font-family:var(--mono);color:var(--color-accent);font-size:11px;font-weight:var(--weight-medium);cursor:pointer}.split-item{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;min-height:70px;transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;align-items:center;gap:14px;margin-bottom:8px;padding:14px 16px;display:flex;box-shadow:0 1px 3px #1813100a}.split-item:active{box-shadow:none;border-color:var(--color-border-2);transform:scale(.985)}.split-avatar{border-radius:var(--radius-md);width:44px;height:44px;font-family:var(--mono);font-size:13px;font-weight:var(--weight-semibold);background:var(--color-surface-2);color:var(--color-text-2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.split-info{flex:1;min-width:0}.split-name{font-size:14px;font-weight:var(--weight-medium);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.split-date{color:var(--color-text-2);margin-top:3px;font-size:11px}.split-amount{font-family:var(--mono);font-size:15px;font-weight:var(--weight-medium);text-align:right}.split-chevron{color:var(--color-text-3);margin-left:4px;font-size:20px;line-height:1}.split-amount.owed{color:var(--color-success)}.nav-bar{background:var(--color-bg);border-top:1px solid var(--color-border);height:84px;z-index:var(--z-nav);padding-bottom:20px;display:none;position:absolute;bottom:0;left:0;right:0}#scan{background:#232222}.scan-header{top:var(--status-bar-height);padding:10px var(--pad-h);z-index:var(--z-sticky);justify-content:space-between;align-items:center;display:flex;position:absolute;left:0;right:0}.scan-header .back-btn{color:#fff;background:#ffffff1a;border-color:#0000}.scan-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:#fff}.camera-view{background:#1a1a1a;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.receipt-preview{border-radius:var(--radius-md);width:260px;overflow:hidden}.receipt-preview img{width:100%;height:auto;display:block}.scan-overlay{pointer-events:none;position:absolute;inset:0}.scan-corner,.scan-line{display:none}.scan-bottom{padding:16px var(--pad-h) 32px;background:linear-gradient(#0000,#232222 40%);position:absolute;bottom:0;left:0;right:0}.scan-hint{text-align:center;font-size:var(--text-sm);color:#ffffff80;font-weight:var(--weight-light);margin-bottom:16px}.scan-actions{gap:var(--space-3);justify-content:center;align-items:center;display:flex}.scan-demo-hint{text-align:center;margin-top:var(--space-3);font-family:var(--mono);font-size:var(--text-xs);color:#ffffff73;cursor:pointer}.scan-demo-btn{border-color:#fff6!important}.shutter{cursor:pointer;width:64px;height:64px;transition:all var(--duration-base) var(--ease-out);background:#ffffff1a;border:3px solid #fff9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shutter:active{background:#fff3;transform:scale(.9)}.shutter-inner{background:#fffc;border-radius:50%;width:48px;height:48px}#processing{background:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;display:flex}.proc-content{padding:var(--space-10) var(--space-6);text-align:center;flex-direction:column;align-items:center;display:flex}.ai-ring{width:96px;height:96px;margin-bottom:var(--space-6);position:relative}.ai-ring svg{animation:1.5s linear infinite spin;position:absolute;inset:0}.ai-ring-inner{background:var(--color-surface);color:var(--color-accent);border-radius:50%;justify-content:center;align-items:center;font-size:24px;display:flex;position:absolute;inset:12px}.proc-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-3)}.proc-sub{font-size:var(--text-base);color:var(--color-text-2);margin-bottom:var(--space-6);font-weight:var(--weight-light)}.proc-steps{text-align:left;flex-direction:column;gap:0;width:100%;display:flex}.proc-steps-card{padding:2px var(--space-4);width:100%}.proc-step{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);display:flex}.proc-step:last-child{border-bottom:none}.proc-step-icon{border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--text-sm);transition:all var(--duration-slow);flex-shrink:0;justify-content:center;align-items:center;display:flex}.proc-step-icon.pending{background:var(--color-surface-2);color:var(--color-text-3)}.proc-step-icon.active{background:var(--color-accent-dim);color:var(--color-accent);animation:1s ease-in-out infinite pulse}.proc-step-icon.done{background:var(--color-success-dim);color:var(--color-success)}.proc-step-label{font-size:var(--text-base);font-weight:var(--weight-medium);flex:1}.proc-step-label span{color:var(--color-text-2)}.proc-check{background:var(--color-success);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.proc-spinner{border:2px solid var(--color-border-2);border-top-color:var(--color-accent);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}#items{background:var(--color-bg)}.items-header{padding:var(--status-bar-height) 0 0;z-index:var(--z-sticky);background:var(--color-bg);position:sticky;top:0}.items-title-row{align-items:center;gap:var(--space-3);margin-bottom:var(--space-1);display:flex}.chip{border-radius:var(--radius-sm);height:36px;font-size:var(--text-sm);background:var(--color-surface);border:1.5px solid var(--color-border);color:var(--color-text-2);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;font-family:var(--mono);flex-shrink:0;align-items:center;gap:7px;padding:0 13px;display:inline-flex;position:relative;box-shadow:0 1px 2px #1813100a}.chip:active{transform:scale(.96)}.chip-sel{background:var(--color-accent-dim);border-color:var(--color-accent-border);color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.ci{width:22px;height:22px;font-size:10px;font-weight:var(--weight-medium);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.badge{font-family:var(--mono);background:var(--color-accent-dim);color:var(--color-accent);font-size:10px;font-weight:var(--weight-medium);border:1px solid var(--color-accent-border);border-radius:6px;justify-content:center;align-items:center;padding:1px 5px;display:inline-flex}.pax-row{padding:12px var(--pad-h);scrollbar-width:none;gap:6px;display:flex;overflow-x:auto}.pax-row::-webkit-scrollbar{display:none}.tabs{border-bottom:1.5px solid var(--color-border);padding:0 var(--pad-h);display:flex}.tab{font-size:var(--text-sm);color:var(--color-text-2);cursor:pointer;font-family:var(--mono);transition:color var(--duration-fast);font-weight:var(--weight-regular);-webkit-tap-highlight-color:transparent;min-height:var(--touch-min);background:0 0;border:none;padding:10px 14px;position:relative}.tab.active{color:var(--color-text);font-weight:var(--weight-medium)}.tab.active:after{content:"";background:var(--color-accent);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1.5px;left:14px;right:14px}.tab.inactive{color:var(--color-text-3)}.items-list{padding:0 0 110px}.empty-state-items{padding:var(--space-8) 0;text-align:center;flex-direction:column;align-items:center;display:flex}.empty-state-label{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.empty-state-sub{font-size:var(--text-sm);color:var(--color-text-2);font-weight:var(--weight-light)}.item-row{min-height:52px;padding:10px var(--pad-h);border-bottom:1px solid var(--color-border);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;transition:background 80ms;display:flex;position:relative}.item-row:last-child{border-bottom:none}.item-row:active{background:#18131003}.item-check{border:1.5px solid var(--color-border-2);width:20px;height:20px;transition:all var(--duration-fast) var(--ease-out);color:#fff;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;display:flex}.item-check.checked{background:var(--color-accent);border-color:var(--color-accent);box-shadow:0 1px 6px #c234302e}.item-info{flex:1;min-width:0}.item-name{font-size:var(--text-sm);font-weight:var(--weight-medium);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.item-leader{letter-spacing:2px;color:var(--color-border-2);flex:1;min-width:8px;font-size:10px;overflow:hidden}.item-qty{font-size:var(--text-xs);color:var(--color-text-2);font-weight:var(--weight-light)}.item-price{font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);text-align:right;min-width:52px}.item-assignees{display:flex}.item-avatar{width:20px;height:20px;font-size:8px;font-family:var(--mono);font-weight:var(--weight-medium);border:2px solid var(--color-bg);background:var(--color-surface-2);color:var(--color-text-2);border-radius:5px;justify-content:center;align-items:center;margin-left:-6px;display:flex}.item-avatar:first-child{margin-left:0}.item-actions{align-items:center;gap:var(--space-1);display:flex}.items-footer{width:100%;max-width:var(--phone-max-width);padding:28px var(--pad-h) 16px;background:linear-gradient(to top, var(--color-bg) 75%, transparent);z-index:var(--z-footer);position:fixed;bottom:0;left:50%;transform:translate(-50%)}.items-footer-summary{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.items-footer-label{font-family:var(--mono);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.1em;font-size:10px}.items-footer-val{font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium)}.items-footer-total-val{font-family:var(--mono);font-size:22px;font-weight:var(--weight-medium)}.tear{align-items:center;gap:8px;padding:5px 0;display:flex;overflow:hidden}.tear-ln{border-top:1.5px dashed var(--color-border);flex:1;height:0}#summary{background:var(--color-bg)}.summary-header{padding:var(--status-bar-height) var(--pad-h) var(--space-3);border-bottom:1.5px solid var(--color-border);align-items:center;gap:14px;display:flex}.summary-header-info{flex:1;min-width:0}.summary-hero{display:none}.summary-title{font-family:var(--font-display);font-size:18px;font-weight:var(--weight-regular);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.summary-sub{color:var(--color-text-2);margin-top:2px;font-size:11px}.summary-share-btn{border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);width:38px;height:38px;color:var(--color-text-2);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex;box-shadow:0 1px 2px #1813100a}.summary-share-btn:active{transform:scale(.93)}.share-card{margin:0 var(--pad-h) var(--space-4);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.share-card-title{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold);margin-bottom:var(--space-1)}.share-card-sub{font-size:var(--text-xs);color:var(--color-text-2);margin-bottom:var(--space-3);font-weight:var(--weight-light)}.share-link-box{background:var(--color-surface-2);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-accent);font-family:var(--mono);justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);cursor:pointer;padding:10px 12px;display:flex}.share-link-copy{font-size:var(--text-xs);color:var(--color-text-2);white-space:nowrap}.share-btn-row{gap:var(--space-3);align-items:center;display:flex}.share-btn{flex:1}.person-cards{padding:0 var(--pad-h) var(--space-4)}.person-cards-label{font-size:10px;font-weight:var(--weight-medium);color:var(--color-text-2);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-3);font-family:var(--mono)}.person-card{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:13px 0;display:flex}.person-card:last-of-type{border-bottom:none}.person-card-ava{border-radius:var(--radius-sm);width:34px;height:34px;font-family:var(--mono);font-size:11px;font-weight:var(--weight-medium);background:var(--color-surface-2);color:var(--color-text-2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.person-card-info{flex:1;min-width:0}.person-card-name{font-size:14px;font-weight:var(--weight-medium)}.person-card-items{color:var(--color-text-2);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:11px;overflow:hidden}.person-card-amount{font-family:var(--mono);font-size:15px;font-weight:var(--weight-medium)}.person-card-breakdown{margin:var(--space-2) 0;flex-direction:column;gap:2px;padding-left:46px;display:flex}.breakdown-row{font-size:var(--text-xs);color:var(--color-text-2);font-weight:var(--weight-light);justify-content:space-between;display:flex}.breakdown-row.total{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text);border-top:1px solid var(--color-border);padding-top:4px}.pay-btn{border-radius:var(--radius-full);cursor:pointer;width:100%;font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);justify-content:center;align-items:center;gap:var(--space-2);transition:all var(--duration-base) var(--ease-out);min-height:var(--touch-min);border:none;padding:10px;display:flex}.pay-btn:active{transform:scale(.97)}.pay-btn.upi{background:var(--color-accent);color:var(--color-text-inv)}.pay-btn.link{background:var(--color-surface);color:var(--color-text-2);border:1px solid var(--color-border);flex:none;padding:10px 20px}.pay-btn.paid{background:var(--color-success-dim);color:var(--color-success)}.pay-btns{gap:var(--space-2);display:flex}.payments-section{margin:0 var(--pad-h) var(--space-4)}.payments-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-3)}.payment-item{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);display:flex}.payment-item:last-child{border-bottom:none}.payment-emoji{border-radius:var(--radius-full);background:var(--color-surface-2);width:32px;height:32px;font-family:var(--font-display);color:var(--color-text-2);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.payment-info{flex:1;min-width:0}.payment-name{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold)}.payment-time{font-size:var(--text-xs);color:var(--color-text-2);font-weight:var(--weight-light);margin-top:2px}.payment-amount{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-regular);flex-shrink:0}.payment-confirmed{font-size:var(--text-xs);color:var(--color-success);font-weight:var(--weight-medium);align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.payment-confirm-btn{border-radius:var(--radius-full);background:var(--color-accent-dim);color:var(--color-accent);font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);border:none;flex-shrink:0;padding:8px 14px}.payment-confirm-btn:active{transform:scale(.95)}.gac{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);margin-top:var(--space-5);padding:22px 24px;position:relative;overflow:hidden;box-shadow:0 4px 16px #18131012,0 1px 3px #18131008}.gac:before{content:"";background:var(--color-accent);height:3px;position:absolute;top:0;left:0;right:0}.gac-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-2);font-family:var(--mono)}.gac-amount{font-family:var(--mono);font-size:46px;font-weight:var(--weight-medium);letter-spacing:-.03em;color:var(--color-accent);line-height:1}#guest{background:var(--color-bg)}.guest-hero{padding:var(--space-8) var(--pad-h) var(--space-4);text-align:left}.guest-badge{align-items:center;gap:var(--space-2);background:var(--color-accent-dim);border:1px solid var(--color-accent-border);border-radius:var(--radius-full);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-accent);margin-bottom:var(--space-3);padding:4px 12px;display:inline-flex}.guest-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-2)}.guest-sub{font-size:var(--text-base);color:var(--color-text-2);font-weight:var(--weight-light);font-family:var(--font-body)}.guest-items{padding:0 var(--pad-h) 110px}.guest-host-note{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-sm);color:var(--color-text-2);margin-bottom:var(--space-3);gap:var(--space-2);font-weight:var(--weight-light);align-items:flex-start;display:flex}.guest-item{align-items:center;gap:var(--space-2);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--duration-fast);-webkit-tap-highlight-color:transparent;display:flex}.guest-item:last-child{border-bottom:none}.guest-item-sel{border-radius:var(--radius-full);border:2px solid var(--color-border-2);width:24px;height:24px;transition:all var(--duration-base) var(--ease-out);color:var(--color-text-inv);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.guest-item-sel.on{background:var(--color-accent);border-color:var(--color-accent)}.guest-item-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);flex:1}.guest-item-price{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-regular);color:var(--color-accent)}.guest-footer{width:100%;max-width:var(--phone-max-width);padding:var(--space-4) var(--pad-h) var(--space-8);background:var(--color-bg);border-top:1px solid var(--color-border);z-index:var(--z-footer);position:fixed;bottom:0;left:50%;transform:translate(-50%)}.guest-total-row{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.guest-total-label{font-family:var(--mono);font-size:var(--text-xs);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.5px;font-weight:var(--weight-light)}.guest-total-amount{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-accent)}#payment{background:var(--color-bg)}.payment-pad{padding:var(--status-bar-height) var(--pad-h) var(--space-8)}.pay-hero{text-align:center;padding:var(--space-4) 0 var(--space-6)}.pay-amount-label{font-family:var(--mono);font-size:var(--text-xs);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);font-weight:var(--weight-light)}.pay-amount-big{font-family:var(--font-display);font-size:3rem;font-weight:var(--weight-light);letter-spacing:-.04em;color:var(--color-accent)}.pay-to{font-size:var(--text-base);color:var(--color-text-2);margin-top:var(--space-2);font-weight:var(--weight-light)}.pay-methods{gap:var(--space-2);margin-bottom:var(--space-5);flex-direction:column;display:flex}.pay-method{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-base) var(--ease-out);-webkit-tap-highlight-color:transparent;min-height:var(--touch-min);display:flex}.pay-method:active{transform:scale(.98)}.pay-method.selected{border-color:var(--color-accent);background:var(--color-accent-dim)}.pay-method-icon{border-radius:var(--radius-full);width:44px;height:44px;font-family:var(--font-display);background:var(--color-surface-2);color:var(--color-text-2);justify-content:center;align-items:center;font-size:22px;display:flex}.pay-method-info{flex:1}.pay-method-name{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold)}.pay-method-sub{font-size:var(--text-xs);color:var(--color-text-2);font-weight:var(--weight-light);font-family:var(--font-body);margin-top:1px}.pay-method-badge{font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);padding:3px 8px}.pay-method-badge.fast{background:var(--color-success-dim);color:var(--color-success)}.pay-success-overlay{background:var(--color-bg);z-index:100;opacity:0;pointer-events:none;transition:opacity var(--duration-slow);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.pay-success-overlay.show{opacity:1;pointer-events:all}.pay-success-icon{background:var(--color-success);width:80px;height:80px;margin-bottom:var(--space-5);animation:popIn .4s var(--ease-out);color:var(--color-text-inv);border-radius:50%;justify-content:center;align-items:center;font-size:36px;display:flex}.pay-success-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-3)}.pay-success-sub{font-size:var(--text-base);color:var(--color-text-2);text-align:center;padding:0 var(--space-8);font-weight:var(--weight-light)}.pay-success-btn{margin-top:var(--space-5);width:80%}.toast{background:var(--color-text);color:var(--color-text-inv);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);white-space:nowrap;z-index:var(--z-toast);opacity:0;transition:all var(--duration-base) var(--ease-out);pointer-events:none;position:absolute;bottom:100px;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.modal-backdrop{z-index:var(--z-modal);opacity:0;pointer-events:none;transition:opacity var(--duration-base) var(--ease-out);-webkit-backdrop-filter:blur(4px);background:#23222266;justify-content:center;align-items:flex-end;display:flex;position:absolute;inset:0}.modal-backdrop.open{opacity:1;pointer-events:all}.modal-sheet{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;padding:var(--space-5) var(--pad-h) var(--space-8);transition:transform var(--duration-slow) var(--ease-out);border:none;transform:translateY(100%)}.modal-backdrop.open .modal-sheet{transform:translateY(0)}.modal-handle{background:var(--color-border-2);width:36px;height:4px;margin:0 auto var(--space-5);border-radius:2px}.modal-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-2)}.modal-sub{font-size:var(--text-xs);color:var(--color-text-2);margin-bottom:var(--space-4);font-weight:var(--weight-light);font-family:var(--font-body)}.modal-field{margin-bottom:var(--space-3)}.modal-label{font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1)}.modal-input-row{align-items:center;gap:var(--space-2);display:flex}.modal-input-row input{background:var(--color-surface);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-regular);height:50px;transition:all var(--duration-base) var(--ease-out);outline:none;flex:1;padding:0 14px;box-shadow:0 1px 3px #1813100a}.modal-input-row input:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 3px var(--color-accent-dim)}.modal-input-suffix{font-family:var(--font-display);font-size:var(--text-base);color:var(--color-text-2);font-weight:var(--weight-regular);min-width:20px}.modal-input-right{text-align:right}.modal-btns{gap:var(--space-2);margin-top:var(--space-4);display:flex}.modal-btn-cancel{border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-2);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);min-height:var(--touch-min);flex:1;padding:12px}.modal-btn-cancel:active{transform:scale(.97)}.modal-btn-confirm{border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-text-inv);font-family:var(--mono);font-size:var(--text-base);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);min-height:var(--touch-min);border:none;flex:2;padding:12px}.modal-btn-confirm:active{transform:scale(.97)}.qr-modal-content{text-align:center;flex-direction:column;align-items:center;display:flex}.qr-canvas-wrap{border-radius:var(--radius-md);padding:var(--space-3);margin:var(--space-3) 0;background:#fff;display:inline-block}.qr-person-info{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold);margin-bottom:var(--space-1)}.qr-amount-big{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-regular);color:var(--color-accent);letter-spacing:-.02em;margin-bottom:var(--space-1)}.qr-hint{font-size:var(--text-xs);color:var(--color-text-2);margin-bottom:var(--space-3);font-weight:var(--weight-light)}.qr-hint-error{color:var(--color-error)}.qr-upi-id{font-family:var(--mono);font-size:var(--text-xs);color:var(--color-accent);background:var(--color-accent-dim);border-radius:var(--radius-full);margin-bottom:var(--space-3);padding:4px 10px}.qr-modal-spacer{height:var(--space-3)}.qr-pay-btn{margin-bottom:var(--space-2)}.qr-close-btn{margin-top:0}.settle-section{margin:0 var(--pad-h) var(--space-4)}.settle-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.settle-title{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold)}.settle-badge{font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);background:var(--color-accent-dim);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-base) var(--ease-out);padding:3px 8px}.settle-badge:active{transform:scale(.95)}.settle-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.settle-txn{align-items:center;gap:var(--space-2);padding:var(--space-3);border-bottom:1px solid var(--color-border);transition:background var(--duration-fast);cursor:pointer;display:flex}.settle-txn:last-child{border-bottom:none}.settle-txn:active{background:var(--color-surface-2)}.settle-txn-arrows{font-family:var(--font-display);font-size:var(--text-base);color:var(--color-text-2);flex-shrink:0}.settle-txn-info{flex:1}.settle-txn-desc{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold)}.settle-txn-sub{font-size:var(--text-xs);color:var(--color-text-2);font-weight:var(--weight-light);margin-top:1px}.settle-txn-amount{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-regular);color:var(--color-accent)}.settle-txn-emoji{border-radius:var(--radius-full);background:var(--color-surface-2);width:28px;height:28px;font-family:var(--font-display);color:var(--color-text-2);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.settle-txn-pay{border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-text-inv);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-base) var(--ease-out);white-space:nowrap;border:none;padding:6px 12px}.settle-txn-pay:active{transform:scale(.95)}.settle-loading{padding:var(--space-5);justify-content:center;align-items:center;gap:var(--space-2);color:var(--color-text-2);font-size:var(--text-sm);display:flex}.settle-spinner{border:2px solid var(--color-border-2);border-top-color:var(--color-accent);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}.settle-empty{font-size:var(--text-xs);color:var(--color-text-2);text-align:center;padding:var(--space-5);font-weight:var(--weight-light)}.settle-card-all-settled{font-size:var(--text-sm);color:var(--color-success);padding:var(--space-5);text-align:center;font-weight:var(--weight-medium)}#history{background:var(--color-bg)}.history-header{padding:var(--status-bar-height) var(--pad-h) var(--space-4);align-items:center;gap:var(--space-3);display:flex}.history-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;flex:1}.history-count{font-size:var(--text-sm);color:var(--color-text-2);font-weight:var(--weight-light)}.history-list{padding:0 var(--pad-h) var(--space-8)}.history-empty{text-align:center;padding:var(--space-12) var(--pad-h);color:var(--color-text-2)}.history-empty-text{font-size:var(--text-base);line-height:var(--leading-relaxed);font-weight:var(--weight-light);font-family:var(--font-body)}.history-month{font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-3) 0 var(--space-1)}.setup-friend-row{gap:var(--space-2);margin-bottom:var(--space-3);align-items:center;display:flex}.setup-friend-remove{background:var(--color-error-dim);color:var(--color-error);border-radius:var(--radius-full);cursor:pointer;width:32px;height:32px;font-weight:var(--weight-medium);transition:all var(--duration-base) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.setup-friend-remove:active{transform:scale(.93)}.setup-content{padding:var(--space-4) var(--pad-h) var(--space-6);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.form-empty-friends{font-size:var(--text-sm);color:var(--color-text-3);padding:8px 0;font-style:italic}.form-row-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.form-rows{flex-direction:column;gap:0;display:flex}.form-input-name{flex:2;min-width:0}.form-input-emoji{flex-shrink:0;width:44px}.form-input-upi{flex:1.5;min-width:0}.bottom-spacer{height:80px}.stc-edit-btn{color:var(--color-accent);font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);cursor:pointer;min-height:var(--touch-min);background:0 0;border:none;padding:4px 8px}.summary-total-card{margin:0 var(--pad-h) var(--space-5);padding:var(--space-4) 0;border-top:1.5px dashed var(--color-border)}.stc-row{justify-content:space-between;align-items:center;margin-bottom:3px;display:flex}.stc-label{color:var(--color-text-2);align-items:center;gap:4px;font-size:12px;display:flex}.stc-val{font-family:var(--mono);color:var(--color-text-2);font-size:12px}.stc-divider{border-top:1px solid var(--color-border);height:0;margin:var(--space-3) 0}.stc-total-row{padding-top:var(--space-2);justify-content:space-between;align-items:center;display:flex}.stc-total-label{font-family:var(--font-display);font-size:20px;font-weight:var(--weight-regular)}.stc-total-val{font-family:var(--mono);font-size:20px;font-weight:var(--weight-medium)}.wordmark{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);font-style:italic;font-weight:300}@keyframes fabPulse{0%,to{box-shadow:0 6px 20px #c2343047,inset 0 1px #ffffff14}50%{box-shadow:0 6px 28px #c234306b,inset 0 1px #ffffff14}}.fab{background:var(--color-accent);width:54px;height:54px;color:var(--color-text-inv);cursor:pointer;z-index:var(--z-footer);transition:transform .1s var(--ease-out);-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;justify-content:center;align-items:center;font-size:24px;line-height:1;animation:3s ease-in-out 2s infinite fabPulse;display:flex;position:absolute;bottom:26px;right:20px;box-shadow:0 6px 20px #c2343047,inset 0 1px #ffffff14}.fab:active{transform:scale(.88)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width>=441px){.phone{border:1px solid var(--color-border);border-radius:52px;width:390px;height:844px;box-shadow:0 20px 60px #00000014}.island{display:block}}@media (width<=440px){.shell{align-items:flex-start}.phone{border-radius:0;width:100%;max-width:100%;height:100dvh}.island{display:none}.items-footer,.guest-footer{width:100%;max-width:100%;left:0;transform:none}.pay-success-overlay{position:fixed}}.onboarding-screen{background:var(--color-bg);flex-direction:column;height:100%;display:flex;overflow:hidden}.onboarding-demo{padding:var(--space-8) var(--space-5);justify-content:center;align-items:center;gap:var(--space-5);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.ob-circle{opacity:.5;pointer-events:none;border-radius:50%;position:absolute}.ob-circle-1{border:1.5px solid var(--color-border-2);background:var(--color-accent-dim);width:72px;height:72px;top:24px;left:24px}.ob-circle-2{background:#2b6b4d1a;border:1px solid #2b6b4d33;width:52px;height:52px;bottom:32px;right:16px}.ob-circle-3{border:1px solid var(--color-accent-border);opacity:.7;background:#c234300f;width:32px;height:32px;top:45%;right:8%}.onboarding-receipt{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);flex-direction:column;gap:10px;width:160px;padding:16px;display:flex}.onboarding-receipt-header,.onboarding-receipt-items{flex-direction:column;gap:6px;display:flex}.onboarding-receipt-line{background:var(--color-surface-2);border-radius:3px;height:6px}.onboarding-receipt-line.w100{width:100%}.onboarding-receipt-line.w90{width:90%}.onboarding-receipt-line.w80{width:80%}.onboarding-receipt-line.w70{width:70%}.onboarding-receipt-line.w60{width:60%}.onboarding-receipt-line.w50{width:50%}.onboarding-receipt-total{border-top:1px dashed var(--color-border-2);justify-content:center;padding-top:8px;transition:all .3s;display:flex}.onboarding-receipt-total.split{opacity:0;height:0;padding-top:0;overflow:hidden}.onboarding-receipt-split{opacity:0;justify-content:center;gap:8px;max-height:0;transition:all .3s;display:flex;overflow:hidden}.onboarding-receipt-split.show{opacity:1;max-height:40px}.onboarding-split-amount{font-family:var(--mono);color:var(--color-text);background:var(--color-accent-dim);border-radius:var(--radius-full);padding:4px 10px;font-size:12px}.onboarding-chips{justify-content:center;gap:10px;display:flex}.onboarding-chip{background:var(--color-surface);border-radius:var(--radius-full);border:1px solid var(--color-border);opacity:0;align-items:center;gap:8px;padding:8px 14px;transition:opacity .3s,transform .3s;display:flex;transform:translateY(12px)}.onboarding-chip.visible{opacity:1;transform:translateY(0)}.onboarding-chip-ava{border-radius:var(--radius-full);background:var(--color-accent);width:24px;height:24px;color:var(--color-text-inv);font-family:var(--font-display);justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.onboarding-chip-name{font-family:var(--mono);color:var(--color-text);font-size:13px;font-weight:var(--weight-regular)}.onboarding-bottom{padding:18px var(--space-7);text-align:left}.onboarding-brand{color:var(--color-text);margin-bottom:0;font-size:56px;line-height:1}.onboarding-tagline{font-family:var(--font-display);color:var(--color-text-2);margin-top:14px;margin-bottom:var(--space-8);font-size:16px;font-style:italic;font-weight:var(--weight-light);line-height:1.5}.onboarding-cta{width:100%}.onboarding-value-props{align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);flex-wrap:nowrap;display:flex}.onboarding-value-prop{white-space:nowrap;align-items:center;gap:5px;display:flex}.ob-vp-icon{font-size:14px}.ob-vp-text{font-family:var(--mono);color:var(--color-text-2);font-size:11px;font-weight:var(--weight-light)}.ob-vp-arrow{font-family:var(--mono);color:var(--color-text-3);flex-shrink:0;font-size:11px}.empty-state-visual{flex-direction:column;align-items:center;padding-top:60px;display:flex}.empty-state-svg{width:120px;height:140px;margin-bottom:var(--space-5)}.empty-state-text{font-family:var(--font-display);color:var(--color-text-2);margin-bottom:var(--space-6);font-size:17px;font-weight:var(--weight-regular)}.empty-state-btn{width:100%;max-width:260px;margin-bottom:var(--space-4)}.empty-state-link{color:var(--color-text-2);font-family:var(--mono);cursor:pointer;padding:var(--space-2) var(--space-3);min-height:44px;font-size:13px;font-weight:var(--weight-light);background:0 0;border:none}.empty-state-link:hover{color:var(--color-text)}.how-it-works-steps{margin-bottom:var(--space-6);flex-direction:column;gap:0;display:flex}.how-it-works-step{align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px dashed var(--color-border-2);display:flex}.how-it-works-step:last-child{border-bottom:none}.how-it-works-num{font-family:var(--font-display);color:var(--color-accent);text-align:center;width:36px;font-size:22px;font-weight:var(--weight-semibold);flex-shrink:0}.how-it-works-text{font-family:var(--mono);color:var(--color-text);font-size:14px;font-weight:var(--weight-regular)}.theme-toggle{display:none}.empty-state-receipt{margin-bottom:var(--space-5)}.empty-receipt-svg{width:96px;height:120px;display:block}.empty-state-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;margin-bottom:var(--space-2);text-align:center}.empty-state-sub-text{font-size:var(--text-base);color:var(--color-text-2);font-weight:var(--weight-light);line-height:var(--leading-relaxed);text-align:center;margin-bottom:var(--space-6);font-family:var(--font-body)}.home-name-placeholder{color:var(--color-text-3);border-bottom:1.5px dashed var(--color-text-3);padding-bottom:1px;font-style:italic}.how-it-works-sub{font-size:var(--text-xs);color:var(--color-text-3);font-family:var(--mono);font-weight:var(--weight-light);margin-top:3px}.history-stat-bar{padding:var(--space-4) var(--pad-h);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-2);align-items:center;gap:0;display:flex}.history-stat{flex-direction:column;flex:1;gap:2px;display:flex}.history-stat+.history-stat{padding-left:var(--space-5)}.history-stat-val{font-family:var(--mono);font-size:var(--text-2xl);font-weight:var(--weight-medium);letter-spacing:-.03em;color:var(--color-text)}.history-stat-label{font-family:var(--mono);font-size:var(--text-xs);color:var(--color-text-3);text-transform:uppercase;letter-spacing:.1em}.history-stat-divider{background:var(--color-border-2);flex-shrink:0;width:1px;height:36px}.history-empty-icon{margin-bottom:var(--space-4);font-size:40px;display:block}.history-empty-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);margin-bottom:var(--space-2);color:var(--color-text)}.history-empty-btn{margin-top:var(--space-5);width:80%;max-width:240px}@keyframes shimmer{0%{background-position:200%}to{background-position:-200%}}.guest-loading-screen{height:100%;padding:var(--pad-h);justify-content:center;align-items:center;gap:var(--space-6);flex-direction:column;display:flex}.guest-loading-brand{font-family:var(--font-display);font-size:32px;font-style:italic;font-weight:var(--weight-light);color:var(--color-text);letter-spacing:-.02em;opacity:.7}.guest-skeleton{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:320px;padding:var(--space-4);gap:var(--space-4);flex-direction:column;display:flex}.guest-skel-header{align-items:center;gap:var(--space-3);display:flex}.skel-circle{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-surface-2) 50%, var(--color-border) 75%);background-size:400% 100%;border-radius:50%;flex-shrink:0;width:44px;height:44px;animation:1.4s ease-in-out infinite shimmer}.skel-lines{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.skel-line{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-surface-2) 50%, var(--color-border) 75%);background-size:400% 100%;border-radius:5px;height:10px;animation:1.4s ease-in-out infinite shimmer}.skel-line-lg{width:70%}.skel-line-sm{width:45%}.skel-line-amount{flex-shrink:0;width:52px}.skel-items{gap:var(--space-3);flex-direction:column;display:flex}.skel-item-row{align-items:center;gap:var(--space-2);display:flex}.skel-dot{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-surface-2) 50%, var(--color-border) 75%);background-size:400% 100%;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:1.4s ease-in-out infinite shimmer}.guest-loading-hint{font-family:var(--mono);font-size:var(--text-xs);color:var(--color-text-3);letter-spacing:.04em}.guest-header{padding:var(--status-bar-height) var(--pad-h) var(--space-2)}.guest-invite-card{padding:var(--space-3) var(--pad-h) var(--space-4);align-items:center;gap:14px;display:flex}.guest-host-avatar{width:48px;height:48px;font-family:var(--mono);font-size:18px;font-weight:var(--weight-medium);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.guest-invite-text{flex-direction:column;gap:3px;display:flex}.guest-invite-from{font-size:var(--text-sm);color:var(--color-text-2);font-family:var(--mono)}.guest-invite-to{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);letter-spacing:-.02em;line-height:1.1}.guest-instruction{padding:0 var(--pad-h) var(--space-3);font-size:var(--text-sm);color:var(--color-text-2);font-weight:var(--weight-light);line-height:var(--leading-relaxed);font-family:var(--font-body)}.guest-item-sel-row{background:var(--color-accent-dim);margin:0 calc(-1 * var(--pad-h));padding-left:var(--pad-h);padding-right:var(--pad-h)}.guest-trust-note{text-align:center;font-size:var(--text-xs);color:var(--color-text-3);font-family:var(--mono);margin-top:var(--space-2);font-weight:var(--weight-light)}.gac-row{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.gac-sub-val{font-family:var(--mono);font-size:var(--text-sm);color:var(--color-text-2)}.gac-divider{border-top:1px solid var(--color-border);height:0;margin:var(--space-2) 0}.gac-total-row{justify-content:space-between;align-items:center;display:flex}.gac-total-label{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-semibold)}.pay-to-avatar{width:56px;height:56px;font-family:var(--mono);font-size:22px;font-weight:var(--weight-medium);margin:0 auto var(--space-3);border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-processing{opacity:.8;pointer-events:none;justify-content:center;align-items:center;gap:var(--space-2);display:flex}@keyframes btnSpin{to{transform:rotate(360deg)}}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite btnSpin;display:inline-block}@keyframes particleBurst{0%{opacity:1;transform:translate(0)scale(1)}to{transform:translate(var(--dx), var(--dy)) scale(0);opacity:0}}@keyframes checkDraw{0%{stroke-dashoffset:30px}to{stroke-dashoffset:0}}.pay-success-burst{width:0;height:0;position:absolute;top:50%;left:50%}.pay-success-particle{--angle:calc(var(--i) * 45deg);--dx:calc(cos(var(--angle)) * 60px);--dy:calc(sin(var(--angle)) * 60px);background:var(--color-accent);width:8px;height:8px;animation:particleBurst .6s .15s var(--ease-out) both;transform-origin:50%;border-radius:50%;margin:-4px;position:absolute}.pay-success-particle:nth-child(2){background:var(--color-success)}.pay-success-particle:nth-child(3){background:#f6bd60}.pay-success-particle:nth-child(5){background:var(--color-success)}.pay-success-particle:nth-child(7){background:#f6bd60}.pay-success-icon-wrap{margin-bottom:var(--space-5);animation:popIn .4s var(--ease-out)}.pay-success-check{width:80px;height:80px}.pay-check-path{stroke-dasharray:30;stroke-dashoffset:30px;animation:.4s .3s forwards checkDraw}.person-card-host{border-left:3px solid var(--color-accent);padding-left:var(--space-3);margin-left:calc(-1 * var(--space-3))}.person-card-paid{opacity:.7}.person-card-you-tag{font-family:var(--mono);font-size:10px;font-weight:var(--weight-medium);color:var(--color-accent);background:var(--color-accent-dim);border:1px solid var(--color-accent-border);border-radius:var(--radius-full);margin-left:var(--space-2);vertical-align:middle;align-items:center;padding:1px 6px;line-height:1.4;display:inline-flex}.form-add-first-friend{align-items:center;gap:var(--space-3);width:100%;padding:12px var(--space-3);border:1.5px dashed var(--color-border-2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-base) var(--ease-out);-webkit-tap-highlight-color:transparent;background:0 0;display:flex}.form-add-first-friend:active{background:var(--color-surface-2)}.form-add-first-icon{border:1.5px solid var(--color-accent-border);background:var(--color-accent-dim);width:28px;height:28px;color:var(--color-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;line-height:1;display:flex}.form-add-first-text{font-family:var(--mono);font-size:var(--text-sm);color:var(--color-text-2)}.pay-breakdown-summary{justify-content:center;align-items:center;gap:var(--space-3);font-family:var(--mono);font-size:var(--text-xs);color:var(--color-text-2);padding:var(--space-2) 0 var(--space-5);flex-wrap:wrap;display:flex}.pay-breakdown-tax{color:var(--color-text-3)}.pay-name-field{gap:var(--space-1);padding:0 var(--pad-h) var(--space-3);flex-direction:column;display:flex}.pay-name-label{font-family:var(--mono);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-2)}.pay-name-input{width:100%;padding:var(--space-3);border:1.5px solid var(--color-border-2);border-radius:var(--radius-md);background:var(--color-surface);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);transition:border-color var(--duration-fast) ease}.pay-name-input::placeholder{color:var(--color-text-3)}.pay-name-input:focus{border-color:var(--color-accent);outline:none}.form-error-sticky{background:var(--color-error);color:var(--color-text-inv);font-family:var(--mono);font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-3) var(--pad-h);text-align:center;z-index:var(--z-sticky);animation:slideInRight .2s var(--ease-out);position:absolute;bottom:0;left:0;right:0}@keyframes namePulse{0%,to{opacity:1}50%{opacity:.45}}.home-name-pulse{animation:1.4s ease-in-out .8s 3 namePulse}.balance-card-positive{border-color:#2b6b4d33}.balance-label-positive{color:var(--color-success)}.split-step-indicator{align-items:center;gap:5px;margin-top:4px;display:flex}.split-step-dot{background:var(--color-border-2);border-radius:50%;width:6px;height:6px;display:inline-block}.split-step-dot-active{background:var(--color-accent);border-radius:3px;width:16px}.items-select-all-bar{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--pad-h);border-bottom:1px solid var(--color-border);display:flex}.items-select-all-btn{font-family:var(--mono);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);border:1px solid var(--color-accent-border);background:var(--color-accent-dim);color:var(--color-accent);cursor:pointer;transition:all var(--duration-base) var(--ease-out);padding:5px 12px}.items-select-all-btn:active{transform:scale(.95)}.items-deselect-btn{background:var(--color-surface);border-color:var(--color-border-2);color:var(--color-text-2)}@keyframes checkBounce{0%{transform:scale(.5)}60%{transform:scale(1.2)}to{transform:scale(1)}}.guest-item-sel.on,.item-check.checked{animation:checkBounce .2s var(--ease-out) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-28px)}to{opacity:1;transform:translate(0)}}.screens.screen-forward{animation:slideInRight .26s var(--ease-out)}.screens.screen-back{animation:slideInLeft .26s var(--ease-out)}.bottom-nav{background:var(--color-surface);border-top:1px solid var(--color-border-2);height:68px;z-index:var(--z-nav);padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center;display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #00000005}.bottom-nav-item{color:var(--color-text-3);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;width:25%;height:100%;transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:10px;display:flex}.bottom-nav-item:hover,.bottom-nav-item:focus{color:var(--color-text);outline:none}.bottom-nav-item.active{color:var(--color-accent)}.bottom-nav-icon{transition:transform var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;display:flex}.bottom-nav-item.active .bottom-nav-icon{transform:translateY(-2px)}.screen{padding-bottom:98px!important}
