*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2E7D52;--color-primary-light: #4CAF7D;--color-primary-dark: #1B5E3A;--color-background: #F8F9FA;--color-surface: #FFFFFF;--color-text: #1C1C1E;--color-text-secondary: #6B7280;--color-text-light: #9CA3AF;--color-error: #D32F2F;--color-divider: #E0E0E0;--color-disabled: #BDBDBD;--radius: 12px}html,body{height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--color-background);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}#root{height:100%}.page-container{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px}.card{background-color:var(--color-surface);border-radius:var(--radius);padding:32px 24px;width:100%;max-width:400px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f}.title{font-size:28px;font-weight:700;color:var(--color-primary);text-align:center;margin-bottom:8px}.subtitle{font-size:16px;color:var(--color-text-secondary);text-align:center;margin-bottom:24px}.btn-primary{display:block;width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background-color:var(--color-primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background-color .15s ease;text-align:center}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-dark);transform:scale(.98)}.btn-primary:disabled{background-color:var(--color-disabled);cursor:not-allowed}.text-input,.code-input{display:block;width:100%;padding:14px 16px;font-size:16px;color:var(--color-text);background-color:var(--color-background);border:1.5px solid var(--color-divider);border-radius:var(--radius);outline:none;transition:border-color .15s ease;margin-bottom:16px}.text-input:focus,.code-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2e7d521f}.text-input:disabled,.code-input:disabled{opacity:.6;cursor:not-allowed}.code-input{font-size:32px;font-weight:600;text-align:center;letter-spacing:8px;font-variant-numeric:tabular-nums}.code-input::placeholder{color:var(--color-text-light);letter-spacing:8px}.error-text{color:var(--color-error);font-size:14px;text-align:center;margin-bottom:16px}.btn-secondary{display:inline-block;padding:12px 24px;font-size:16px;font-weight:600;color:var(--color-text);background-color:var(--color-background);border:1.5px solid var(--color-divider);border-radius:var(--radius);cursor:pointer}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:8px 16px;font-size:14px}.tab-page{max-width:480px;margin:0 auto;padding:0 12px 32px}.tab-header{text-align:center;padding:16px 0 8px;position:sticky;top:0;background:var(--color-background);z-index:10}.tab-brand{font-size:24px;font-weight:700;color:var(--color-primary);margin-bottom:4px}.tab-header-info{display:flex;align-items:center;justify-content:center;gap:8px}.tab-restaurant{font-size:16px;color:var(--color-text);font-weight:600}.status-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase}.status-active{background-color:#e8f5e9;color:#2e7d32}.status-completed{background-color:#e3f2fd;color:#1565c0}.completed-banner{background:#fff3e0;color:#e65100;text-align:center;padding:10px 16px;border-radius:var(--radius);margin:8px 0;font-size:14px;font-weight:500}.receipt-image-container{margin:8px 0;border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative}.receipt-image{width:100%;max-height:200px;object-fit:cover;display:block}.receipt-tap-hint{position:absolute;bottom:8px;right:8px;background:#0009;color:#fff;font-size:11px;padding:2px 8px;border-radius:4px}.image-zoom-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:100;display:flex;align-items:center;justify-content:center}.image-zoom-full{max-width:95vw;max-height:90vh;object-fit:contain}.image-zoom-close{position:absolute;top:16px;right:16px;background:#fff3;border:none;color:#fff;font-size:24px;width:40px;height:40px;border-radius:50%;cursor:pointer}.totals-card{padding:16px 20px;margin:8px 0}.totals-row{display:flex;justify-content:space-between;padding:4px 0;font-size:14px;color:var(--color-text-secondary)}.totals-total{font-weight:700;font-size:16px;color:var(--color-text);border-top:1px solid var(--color-divider);margin-top:4px;padding-top:8px}.your-total-card{background:var(--color-surface);border-radius:var(--radius);padding:16px 20px;margin:8px 0;border:2px solid var(--color-primary-light);box-shadow:0 1px 3px #00000014}.total-breakdown{margin:8px 0 16px}.breakdown-row{display:flex;justify-content:space-between;padding:3px 0;font-size:14px;color:var(--color-text-secondary)}.breakdown-total{font-weight:700;font-size:16px;color:var(--color-text);border-top:1px solid var(--color-divider);margin-top:4px;padding-top:6px}.btn-venmo{display:block;width:100%;padding:14px;font-size:15px;font-weight:600;color:#fff;background:#008cff;border:none;border-radius:var(--radius);cursor:pointer;text-align:center}.btn-venmo:active{background:#006fcc;transform:scale(.98)}.paid-badge{text-align:center;padding:12px;font-size:18px;font-weight:700;color:var(--color-primary)}.hint-text{text-align:center;font-size:13px;color:var(--color-text-light);margin-top:8px}.items-section{margin:8px 0}.items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-title{font-size:18px;font-weight:700;color:var(--color-text)}.btn-add-item{background:none;border:1.5px solid var(--color-primary);color:var(--color-primary);font-weight:600;font-size:13px;padding:6px 12px;border-radius:8px;cursor:pointer}.progress-tracker{margin-bottom:12px}.progress-header{display:flex;justify-content:space-between;font-size:12px;color:var(--color-text-secondary);margin-bottom:4px}.progress-bar-bg{height:6px;background:var(--color-divider);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.participant-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.legend-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.legend-name{white-space:nowrap}.item-card{background:var(--color-surface);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;border:1.5px solid var(--color-divider);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;-webkit-tap-highlight-color:transparent}.item-card:active:not(.item-disabled){transform:scale(.99)}.item-claimed{border-color:var(--color-primary-light);background:#f0fff4}.item-disabled{cursor:default;opacity:.8}.item-main{display:flex;justify-content:space-between;align-items:flex-start}.item-info{flex:1;min-width:0}.item-name{font-size:15px;font-weight:500;color:var(--color-text);word-break:break-word}.item-qty{color:var(--color-text-secondary);font-weight:400}.item-split-text{display:block;font-size:12px;color:var(--color-text-light);margin-top:2px}.item-right{display:flex;align-items:center;gap:8px;margin-left:12px;flex-shrink:0}.item-price{font-size:15px;font-weight:600;color:var(--color-text)}.item-edit-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;line-height:1}.item-claims{display:flex;gap:4px;margin-top:8px}.claim-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.item-hint{font-size:12px;color:var(--color-text-light);margin-top:4px}.empty-items{text-align:center;padding:32px 16px;color:var(--color-text-light);font-size:14px}.participants-card{padding:16px 20px;margin:8px 0}.participant-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.participant-row+.participant-row{border-top:1px solid var(--color-divider)}.participant-info{display:flex;align-items:center;gap:8px}.participant-name{font-size:14px;color:var(--color-text)}.badge{font-size:10px;padding:1px 6px;border-radius:4px;margin-left:4px;font-weight:500}.badge-web{background:#e8f5e9;color:#2e7d32}.badge-app{background:#e3f2fd;color:#1565c0}.badge-host{background:#fff3e0;color:#e65100}.participant-amount{font-size:14px;font-weight:600;color:var(--color-text)}.paid-text{color:var(--color-primary);font-weight:600}.add-item-form{background:var(--color-surface);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;border:1.5px dashed var(--color-primary)}.add-item-row{display:flex;gap:8px}.add-item-row .text-input{margin-bottom:8px}.add-item-price{max-width:100px}.add-item-actions{display:flex;gap:8px;justify-content:flex-end}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}.modal-content{background:var(--color-surface);border-radius:var(--radius);padding:24px;width:100%;max-width:360px;box-shadow:0 8px 32px #0003}.modal-title{font-size:20px;font-weight:700;color:var(--color-text);margin-bottom:16px}.input-label{display:block;font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.modal-actions .btn-primary,.modal-actions .btn-secondary{flex:1}.feedback-fab{position:fixed;bottom:20px;right:20px;width:44px;height:44px;border-radius:50%;background-color:var(--color-primary);color:#fff;font-size:22px;font-weight:700;border:none;cursor:pointer;box-shadow:0 2px 8px #0003;z-index:40;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease}.feedback-fab:hover{background-color:var(--color-primary-dark)}.feedback-type-row{display:flex;gap:8px;margin-bottom:16px}.feedback-type-btn{flex:1;padding:8px;border-radius:8px;border:1.5px solid var(--color-divider);background:none;font-size:13px;color:var(--color-text-secondary);cursor:pointer;text-align:center;font-weight:500}.feedback-type-active{border-color:var(--color-primary);background-color:#2e7d5214;color:var(--color-primary);font-weight:600}.feedback-textarea{display:block;width:100%;min-height:100px;padding:12px;font-size:14px;color:var(--color-text);background-color:var(--color-background);border:1.5px solid var(--color-divider);border-radius:var(--radius);outline:none;resize:vertical;font-family:inherit;margin-bottom:8px}.feedback-textarea:focus{border-color:var(--color-primary)}code{font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;background-color:var(--color-background);padding:2px 6px;border-radius:4px;font-size:13px}
