*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.App-header{color:#fff;padding:2rem 1rem;text-align:center}.App-header h1{font-size:3rem;margin-bottom:.5rem}.App-header p{font-size:1.1rem;opacity:.9}.App-main{margin:0 auto;max-width:1000px;padding:2rem 1rem}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:3rem 2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-header h1{color:#333;font-size:2.5rem;margin:0}.login-header p{color:#666;font-size:.95rem;margin:.5rem 0 0}.login-content h2{color:#333;font-size:1.5rem;margin:0 0 .5rem;text-align:center}.login-content p{color:#666;margin-bottom:1.5rem;text-align:center}.discord-login-btn{align-items:center;background:linear-gradient(135deg,#5865f2,#4752c4);border:none;border-radius:8px;box-shadow:0 4px 15px #5865f24d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;padding:.75rem;transition:all .3s ease;width:100%}.discord-login-btn:hover{box-shadow:0 6px 20px #5865f266;transform:translateY(-2px)}.discord-login-btn:active{transform:translateY(0)}.login-info{background:#f5f5f5;border-left:4px solid #667eea;border-radius:8px;margin-top:1.5rem;padding:1rem}.login-info p{color:#666;font-size:.9rem;margin:0;text-align:left}@media (max-width:600px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:2rem}}.dashboard{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.dashboard-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000001a;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1.5rem 2rem}.header-content{color:#fff}.header-home{border-radius:8px;cursor:pointer;padding:.2rem .35rem;transition:background .2s ease}.header-home:hover{background:#ffffff14}.header-home:focus-visible{outline:2px solid #ffffffe6;outline-offset:2px}.header-content h1{font-size:1.8rem;margin:0}.header-content p{font-size:.9rem;margin:.25rem 0 0;opacity:.9}.user-info{align-items:center;color:#fff;display:flex;position:relative}.user-avatar-btn{background:none;border:none;border-radius:50%;cursor:pointer;display:inline-flex;padding:0}.user-avatar-btn:focus-visible{outline:2px solid #ffffffe6;outline-offset:2px}.user-avatar{border:2px solid #fff;border-radius:50%;height:40px;overflow:hidden;width:40px}.user-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:#ffffff4d;display:flex;font-size:1.2rem;font-weight:700;height:100%;justify-content:center;width:100%}.user-menu-dropdown{background:#0f172af2;border:1px solid #ffffff38;border-radius:10px;box-shadow:0 12px 26px #00000047;display:none;flex-direction:column;gap:.55rem;min-width:190px;padding:.7rem;position:absolute;right:0;top:calc(100% + .55rem);z-index:20}.user-info.menu-open .user-menu-dropdown{display:flex}.username{font-size:.95rem;font-weight:600}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;padding:.4rem .8rem;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d;border-color:#ffffff80}.user-menu-btn{background:#ffffff14;border:1px solid #ffffff40;border-radius:6px;color:#f9fafb;cursor:pointer;font-size:.88rem;padding:.45rem .65rem;text-align:left;width:100%}.user-menu-btn:hover{background:#ffffff29}.user-menu-btn.logout{border-color:#fecaca99;color:#fee2e2}.dashboard-main{margin:2rem auto 0;max-width:1200px;min-height:60vh;padding:0 1rem 2rem}@media (max-width:768px){.dashboard-header{align-items:center;flex-direction:row;gap:.75rem}.user-info{justify-content:flex-end;margin-left:auto;width:auto}.user-menu-dropdown{min-width:170px}.header-content h1{font-size:1.5rem}.header-content p{margin-top:.15rem}}.receipt-upload-container{position:relative}.upload-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.upload-header h2{color:#f8faff;font-size:1.8rem;margin:0;text-shadow:0 2px 8px #00000038}.back-btn{background:#ffffff29;border:1px solid #ffffff59;border-radius:6px;color:#f8faff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.back-btn:hover{background:#ffffff42;color:#fff}.upload-zone{background:#fff;border:2px dashed #667eea;border-radius:12px;cursor:pointer;padding:4rem 2rem;text-align:center;transition:all .3s ease}.upload-zone:hover{background-color:#f9f7ff;border-color:#764ba2;transform:translateY(-2px)}.upload-content{pointer-events:none}.upload-icon{font-size:4rem;margin-bottom:1rem}.upload-zone h2{color:#333;margin-bottom:.5rem}.upload-zone p{color:#666;margin:.5rem 0}.upload-hint{color:#5f6368;font-size:.9rem}.loading{align-items:center;background:#ffffffe6;border-radius:12px;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading p{color:#667eea;font-weight:500;margin-top:1rem}.bill-splitter{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:2rem}.step-indicator{display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.step{background:#f5f5f5;border-radius:8px;color:#999;flex:1 1;font-weight:500;padding:1rem;text-align:center;transition:all .3s ease}.step.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.step-content{min-height:400px}.combined-layout{grid-gap:1.2rem;align-items:start;display:grid;gap:1.2rem;grid-template-columns:minmax(0,1fr) 360px}.combined-main{min-width:0}.results-sidebar{background:#f7f9ff;border:1px solid #e2e8ff;border-radius:10px;padding:1rem;position:sticky;top:1rem}.results-placeholder h3{margin-top:0}.results-placeholder p{color:#5d6482;margin-bottom:1rem}.sidebar-people-section{margin-bottom:0;margin-top:.6rem}.sidebar-people-section h3{margin-bottom:.8rem;margin-top:0}.step-content h2{color:#333;font-size:1.8rem;margin-bottom:1.5rem}.step-content h3{color:#555;margin-bottom:1rem;margin-top:2rem}.bill-title-section{margin-bottom:1.5rem}.top-page-actions{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.top-page-actions-right{align-items:center;display:flex;gap:.6rem}.bill-name-display{align-items:center;display:flex;gap:.8rem}.bill-name-display h2{flex:1 1;margin:0}.btn-edit-name{background:none;border:none;border-radius:4px;color:#667eea;cursor:pointer;font-size:1.2rem;padding:.4rem .6rem;transition:all .2s}.btn-edit-name:hover{background:#667eea1a;transform:scale(1.15)}.bill-name-editor{align-items:center;display:flex;gap:.8rem;margin-bottom:1.5rem}.bill-name-editor input{border:2px solid #667eea;border-radius:6px;flex:1 1;font-size:1.1rem;font-weight:600;padding:.8rem}.bill-name-editor input:focus{border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a;outline:none}.btn-cancel-name,.btn-save-name{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 1rem;transition:all .2s}.btn-save-name{background:#4caf50;color:#fff}.btn-save-name:hover{background:#45a049}.btn-cancel-name{background:#f0f0f0;color:#333}.btn-cancel-name:hover{background:#e0e0e0}.people-input-section{background:#f9f9f9;border-radius:8px;margin-top:2rem;padding:1.5rem}.step-content .people-input-section h3{margin-bottom:.8rem;margin-top:0}.charges-section{background:#f5f8ff;border:1px solid #d9e3ff;border-radius:8px;margin-top:1rem;padding:1rem}.charges-section h3{margin-top:0}.charges-section p{color:#5d6482;margin:.4rem 0 .9rem}.charges-form{align-items:flex-end;display:flex;flex-wrap:wrap;gap:.9rem}.charges-list{grid-gap:.6rem;display:grid;gap:.6rem;margin-bottom:.8rem}.charge-empty-state{background:#eef3ff;border:1px dashed #cfd8f6;border-radius:6px;color:#7a819f;padding:.65rem .8rem}.charge-row{grid-gap:.55rem;align-items:center;display:grid;gap:.55rem;grid-template-columns:minmax(180px,1fr) auto minmax(120px,160px) auto}.charge-row input{padding:.65rem .75rem}.charge-row input,.charge-type-toggle{border:1px solid #cfd8f6;border-radius:6px}.charge-type-toggle{display:flex;overflow:hidden}.charge-type-btn{background:#f3f6ff;border:none;color:#5d6482;cursor:pointer;font-size:.88rem;font-weight:700;line-height:1;padding:.42rem .7rem}.charge-type-btn:hover{background:#e4eaff}.charge-type-btn.active{background:#4c5fd5;color:#fff}.charge-value-wrap{display:flex;flex-direction:column;gap:.2rem}.charge-value-wrap input{width:100%}.charge-preview{color:#4c5fd5;font-size:.78rem;font-weight:600;padding-left:.25rem}.btn-add-charge{background:#f3f6ff;border:1px dashed #4c5fd5;border-radius:6px;color:#4c5fd5;cursor:pointer;font-weight:600;padding:.65rem .9rem}.btn-add-charge:hover{background:#e8edff}.btn-remove-charge{background:#ffe9e9;border:none;border-radius:6px;color:#b42318;cursor:pointer;font-weight:600;padding:.62rem .85rem}.charges-form label{color:#4c5578;display:flex;flex-direction:column;font-weight:600;gap:.35rem}.charges-form input{border:1px solid #cfd8f6;border-radius:6px;min-width:140px;padding:.65rem .75rem}.btn-save-charges{background:#4c5fd5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.7rem 1rem}.btn-save-charges:disabled{cursor:not-allowed;opacity:.6}@media (max-width:700px){.charge-row{grid-template-columns:1fr}}.add-person-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.add-person-form input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:1rem;min-width:150px;padding:.75rem}.user-dropdown{min-width:260px;position:relative}.user-dropdown-toggle{align-items:center;background:#fff;border:1px solid #ddd;border-radius:6px;color:#1f2937;cursor:pointer;display:flex;font-size:.95rem;gap:.6rem;justify-content:space-between;padding:.75rem;width:100%}.dropdown-caret{color:#6b7280;transition:transform .2s ease}.dropdown-caret.open{transform:rotate(180deg)}.user-dropdown-menu{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 10px 25px #0f172a24;left:0;max-height:220px;overflow-y:auto;padding:.35rem;position:absolute;right:0;top:calc(100% + .35rem);z-index:20}.user-dropdown-option{grid-gap:.55rem;align-items:center;border-radius:6px;color:#1f2937;cursor:pointer;display:grid;gap:.55rem;grid-template-columns:18px 28px minmax(0,1fr);padding:.45rem .5rem}.user-dropdown-option:hover{background:#f3f4f6}.user-dropdown-option input{flex:0 0 auto;height:16px;justify-self:center;margin:0;width:16px}.user-dropdown-avatar{align-items:center;background:#e5e7eb;border-radius:999px;color:#374151;display:inline-flex;font-size:.8rem;font-weight:700;height:28px;justify-content:center;object-fit:cover;width:28px}.user-dropdown-avatar-fallback{background:#e0e7ff;color:#4338ca}.user-dropdown-avatar-manual{background:#ecfdf3;color:#027a48}.user-dropdown-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-user-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:1rem;min-width:180px;padding:.75rem}.add-person-form button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background .3s ease}.add-person-form button:hover:not(:disabled){background:#764ba2}.add-person-form button:disabled{cursor:not-allowed;opacity:.5}.people-added-list{margin-top:1.5rem}.people-added-list h4{color:#666;margin-bottom:.75rem}.person-chip{background:#fff;border:2px solid #667eea;border-radius:20px;color:#667eea;display:inline-block;font-weight:500;margin:.25rem;padding:.5rem 1rem}.person-row{gap:.6rem;justify-content:space-between;margin-bottom:.35rem}.person-actions,.person-row{align-items:center;display:flex}.person-actions{gap:.45rem}.btn-sponsor-toggle{background:#f6f8ff;border:1px solid #d0d8f7;border-radius:999px;color:#4c5fd5;cursor:pointer;font-size:.76rem;font-weight:700;padding:.28rem .62rem;white-space:nowrap}.btn-sponsor-toggle.active{background:#fff9e7;border-color:#f6d365;color:#7f5b00}.btn-sponsor-toggle:disabled{cursor:not-allowed;opacity:.65}.btn-remove-person{background:#fff1f2;border:1px solid #fecaca;border-radius:999px;color:#b42318;cursor:pointer;font-size:.76rem;font-weight:700;padding:.28rem .62rem;white-space:nowrap}.btn-remove-person:hover{background:#ffe4e6}.btn-remove-person:disabled{cursor:not-allowed;opacity:.65}.sponsored-badge{background:gold;color:#333}.sponsored-badge,.verified-badge{border-radius:4px;font-size:.8rem;margin-left:.5rem;padding:.1rem .5rem}.verified-badge{background:#4caf50;color:#fff;font-weight:600}.step-buttons{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.step-buttons button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.btn-calculate,.btn-next,.btn-reset{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-calculate:hover:not(:disabled),.btn-next:hover:not(:disabled),.btn-reset:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.btn-calculate:disabled,.btn-next:disabled{cursor:not-allowed;opacity:.5}.btn-back,.btn-cancel{background:#f0f0f0;border:none;border-radius:6px;color:#333;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.btn-back:hover,.btn-cancel:hover{background:#e0e0e0}.btn-receipt-photo{background:#eff6ff;border:1px solid #3b82f6;border-radius:8px;color:#1d4ed8;cursor:pointer;font-size:.92rem;font-weight:600;padding:.72rem 1rem;transition:all .2s ease}.btn-receipt-photo:hover{background:#dbeafe;border-color:#2563eb}.btn-invite{background:#f0fdf4;border:1px solid #16a34a;border-radius:8px;color:#166534;cursor:pointer;font-size:.92rem;font-weight:600;padding:.72rem 1rem;transition:all .2s ease}.btn-invite:hover:not(:disabled){background:#dcfce7;border-color:#15803d}.btn-invite:disabled{cursor:not-allowed;opacity:.7}.invite-modal{width:min(620px,100%)}.invite-link-row{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:1fr auto;margin:.2rem 0 1rem}.invite-link-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#1f2937;font-size:.92rem;padding:.62rem .75rem;width:100%}.invite-link-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633;outline:none}.invite-copy-btn{background:#16a34a;border:1px solid #16a34a;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.56rem .92rem}.invite-copy-btn:hover:not(:disabled){background:#15803d;border-color:#15803d}.invite-copy-btn:disabled{cursor:not-allowed;opacity:.7}@media (max-width:1150px){.combined-layout{grid-template-columns:1fr}.results-sidebar{position:static}.top-page-actions{flex-wrap:wrap;gap:.6rem}.top-page-actions-right{flex-wrap:wrap;justify-content:flex-end;width:100%}}.btn-delete{background:#f44;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.8rem 1.2rem;transition:all .2s ease}.btn-delete:hover{background:#c00;box-shadow:0 4px 12px #ff00004d;transform:translateY(-2px)}.btn-delete:active{transform:translateY(0)}.bill-splitter.participant-view{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:2px solid #e0e0e0}.participant-header{border-bottom:2px solid #f0f0f0;margin-bottom:2rem;padding-bottom:1.5rem;text-align:center}.participant-header h2{color:#333;font-size:1.5rem;margin:0 0 .5rem}.participant-header p{color:#999;font-size:.95rem;margin:0}.bill-splitter.participant-view .step-indicator{display:none}.bill-splitter.participant-view .loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:300px}.bill-splitter.participant-view .loading .spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}.bill-splitter.participant-view .loading p{color:#667eea;font-weight:500}.item-selector{background:#f9f9f9;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.item-editor-panel{background:#fff;border:1px solid #e8e8e8;border-radius:8px;margin-bottom:1rem;padding:1rem}.item-editor-panel h3{color:#4a4a4a;font-size:1rem;margin:0 0 .75rem}.item-editor-row{display:flex;flex-wrap:wrap;gap:.5rem}.item-editor-row input{border:1px solid #d8d8d8;border-radius:6px;padding:.6rem .7rem}.item-editor-row button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.6rem .9rem}.item-editor-row button:disabled{cursor:not-allowed;opacity:.5}.items-list{grid-gap:.75rem;display:grid;gap:.75rem}.item-group{background:#fff;border:1px solid #e3e6ef;border-radius:8px;overflow:visible}.item-group.unclaimed-group{border-color:#0000;position:relative}.item-group.unclaimed-group:before{border:1px solid #ef4444;border-radius:8px;content:"";inset:0;pointer-events:none;position:absolute;z-index:2}.item-group-header{align-items:center;background:#f7f9ff;border-bottom:1px solid #e8ecfa;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:.9rem 1rem}.item-group-header.clickable{cursor:pointer}.group-name-row{align-items:center;display:flex;gap:.5rem}.group-name-row h4{color:#334;font-size:1rem;margin:0}.group-count{background:#e8edff;border-radius:999px;color:#4c5fd5;font-size:.78rem;font-weight:700;padding:.15rem .55rem}.group-meta-row{align-items:center;display:flex;gap:.7rem}.group-edit-inline{align-items:center;display:flex;flex-wrap:wrap;gap:.4rem;width:100%}.group-edit-inline input{border:1px solid #d8d8d8;border-radius:6px;padding:.45rem .6rem}.edit-group-btn{background:#eef2ff;border:none;border-radius:6px;color:#4c5fd5;cursor:pointer;font-size:.8rem;font-weight:600;padding:.35rem .6rem}.edit-group-btn:hover{background:#e0e7ff}.group-total{color:#4c5fd5;font-weight:700}.toggle-group-btn{background:#eef2ff;border:none;border-radius:6px;color:#4c5fd5;cursor:pointer;font-size:.8rem;padding:.35rem .55rem}.item-group-units{grid-gap:.45rem;display:grid;gap:.45rem;padding:.5rem}.item-card{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;padding:1rem;transition:all .2s ease}.item-unit-card{background:#fff;border:1px solid #eaedf5}.item-unit-card.unclaimed-item{border-color:#ef4444}.item-edit-inline{display:flex;flex-wrap:wrap;gap:.4rem}.item-edit-inline input{border:1px solid #d8d8d8;border-radius:6px;padding:.45rem .6rem}.cancel-inline,.edit-item-btn,.save-inline{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;padding:.45rem .7rem}.save-inline{background:#4caf50;color:#fff}.cancel-inline{background:#ececec;color:#555}.edit-item-btn{background:#eef2ff;color:#4c5fd5}.item-actions{display:flex;gap:.45rem;margin-left:.75rem}.delete-item-btn{background:#ffe9e9;border:none;border-radius:6px;color:#b42318;cursor:pointer;font-size:.85rem;padding:.45rem .7rem}.item-card:hover{box-shadow:0 2px 8px #0000001a}.item-info{flex:1 1}.item-info h4{color:#333;font-size:1rem;margin:0}.item-id{color:#999;font-size:.85rem;margin:.25rem 0 0}.item-price{color:#667eea;font-size:1.2rem;font-weight:600;min-width:80px;text-align:right}.no-items{color:#999;padding:2rem;text-align:center}.items-total{align-items:center;background:#fff;border-radius:6px;border-top:2px solid #667eea;display:flex;font-size:1.1rem;justify-content:space-between;margin-top:1rem;padding:1rem}.items-total span{color:#667eea;font-size:1.3rem;font-weight:600}.charges-inside-items{margin-top:1rem}.items-grand-total{align-items:center;background:#eef8f1;border:1px solid #ccead4;border-radius:6px;display:flex;font-size:1.05rem;justify-content:space-between;margin-top:.8rem;padding:1rem}.items-grand-total span{color:#067647;font-size:1.2rem;font-weight:700}.item-claimants{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.3rem}.claimant-chip{background:#eef2ff;border-radius:999px;color:#4c5fd5;font-size:.75rem;font-weight:600;padding:.1rem .5rem}.claim-split-btn-wrapper{align-items:stretch;border-radius:6px;display:flex;margin-left:.75rem;overflow:visible;position:relative}.btn-claim-main{background:#667eea;border:none;border-radius:6px 0 0 6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.45rem .8rem;transition:background .15s;white-space:nowrap}.btn-claim-main:hover{background:#5567d8}.btn-claim-main.claimed{background:#e8edff;color:#4c5fd5}.btn-claim-main.claimed:hover{background:#d8e0f8}.claim-split-btn-wrapper:not(:has(.claim-dropdown-anchor)) .btn-claim-main{border-radius:6px}.claim-dropdown-anchor{position:relative}.btn-claim-arrow{background:#667eea;border:none;border-left:1px solid #ffffff4d;border-radius:0 6px 6px 0;color:#fff;cursor:pointer;font-size:.8rem;padding:.45rem .55rem;transition:background .15s}.btn-claim-arrow:hover{background:#5567d8}.claim-dropdown{background:#fff;border:1px solid #d9e0f5;border-radius:8px;box-shadow:0 4px 16px #0000001f;min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.claim-dropdown-item{align-items:center;background:#fff;border:none;color:#333;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.6rem .9rem;text-align:left;transition:background .1s;width:100%}.claim-dropdown-item:hover{background:#f0f4ff}.claim-dropdown-item.claimed{color:#4c5fd5;font-weight:600}.claim-check{color:#4c5fd5;font-weight:700;text-align:center;width:1rem}@media (max-width:768px){.item-card{grid-gap:.55rem;align-items:start;display:grid;gap:.55rem;grid-template-areas:"info price" "actions actions" "claim claim";grid-template-columns:1fr auto}.item-info{grid-area:info;min-width:0}.item-info h4{overflow-wrap:anywhere}.item-price{grid-area:price;min-width:auto;text-align:right}.item-actions{flex-wrap:wrap;grid-area:actions;margin-left:0}.claim-split-btn-wrapper{grid-area:claim;margin-left:0;width:max-content}.item-group-header{align-items:flex-start;flex-direction:column;gap:.5rem}.group-meta-row{flex-wrap:wrap;justify-content:space-between;width:100%}}.confirm-modal-backdrop{align-items:center;background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1200}.confirm-modal{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 20px 45px #0f172a3d;padding:1rem 1rem .95rem;width:min(460px,100%)}.confirm-modal h3{color:#111827;margin:0}.confirm-modal p{color:#374151;line-height:1.45;margin:.7rem 0 1rem}.confirm-modal-actions{display:flex;gap:.6rem;justify-content:flex-end}.confirm-action-btn,.confirm-cancel-btn{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#1f2937;cursor:pointer;font-weight:600;padding:.55rem .9rem}.confirm-action-btn.danger{background:#dc2626;border-color:#dc2626;color:#fff}.confirm-cancel-btn:hover{background:#f3f4f6}.confirm-action-btn.danger:hover{background:#b91c1c;border-color:#b91c1c}.results{animation:slideIn .3s ease}.results.compact h2{font-size:1.2rem;margin-bottom:1rem}.results.compact .results-summary{gap:.7rem;grid-template-columns:1fr;margin-bottom:1.1rem}.results.compact .summary-card{box-shadow:none;padding:.85rem 1rem;text-align:left}.results.compact .summary-card h3{font-size:.78rem}.results.compact .total-amount{font-size:1.25rem}.results.compact .people-breakdown{margin-top:.4rem}.results.compact .pay-to-section{margin-bottom:.7rem;margin-top:.2rem}.results.compact .people-breakdown h3{font-size:1.02rem;margin-bottom:.75rem;margin-top:0}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.results h2{color:#333;margin-bottom:1.5rem}.results-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;padding:1.5rem;text-align:center}.summary-card h3{color:#f8faff;font-size:.9rem;margin:0 0 .5rem;opacity:1;text-shadow:0 1px 2px #00000038}.total-amount{font-size:2rem;font-weight:700;margin:0}.pay-to-section{background:#f8faff;border:1px solid #d9e3ff;border-radius:8px;margin-bottom:.9rem;margin-top:.6rem;padding:.7rem .8rem}.pay-to-heading{color:#475467;font-size:.82rem;font-weight:700;letter-spacing:.03em;margin-bottom:.45rem;text-transform:uppercase}.pay-to-controls{align-items:center;display:flex;gap:.5rem}.pay-to-controls select{background:#fff;border:1px solid #c6d4ff;border-radius:6px;color:#1f2937;flex:1 1;font-size:.9rem;min-width:0;padding:.45rem .55rem}.pay-to-saving{color:#667085;font-size:.8rem}.pay-to-display{color:#344054;font-size:.95rem;font-weight:600}.pay-to-display.empty{color:#667085;font-weight:500}.people-breakdown{margin-top:2rem}.people-breakdown h3{color:#333;font-size:1.3rem;margin-bottom:1rem}.results-list{display:flex;flex-direction:column;gap:1rem}.result-card{background:#fff;border:2px solid #f0f0f0;border-radius:8px;padding:0;transition:all .3s ease}.result-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.result-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;list-style:none;padding:1rem 1.1rem}.result-header-right{align-items:center;display:flex;gap:.6rem}.person-actions-menu{position:relative}.person-actions-trigger{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:999px;color:#374151;cursor:pointer;display:inline-flex;font-size:.78rem;font-weight:700;gap:.35rem;padding:.28rem .6rem}.person-actions-trigger:disabled{cursor:not-allowed;opacity:.65}.person-actions-caret{color:#6b7280;transition:transform .2s ease}.person-actions-caret.open{transform:rotate(180deg)}.person-actions-panel{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 10px 25px #0f172a24;min-width:160px;padding:.3rem;position:absolute;right:0;top:calc(100% + .35rem);z-index:30}.person-actions-item{background:#0000;border:none;border-radius:6px;color:#1f2937;cursor:pointer;font-size:.82rem;padding:.44rem .5rem;text-align:left;width:100%}.person-actions-item:hover{background:#f3f4f6}.person-actions-item.danger{color:#b42318}.person-actions-item.danger:hover{background:#fff1f2}.payment-toggle-btn{background:#fff5f4;border:1px solid #b42318;border-radius:999px;color:#b42318;cursor:pointer;font-size:.78rem;font-weight:700;padding:.25rem .6rem}.payment-toggle-btn.paid{background:#effcf6;border-color:#16794a;color:#16794a}.payment-toggle-btn:disabled{cursor:not-allowed;opacity:.65}.result-header::-webkit-details-marker{display:none}.result-name{align-items:center;color:#333;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem}.result-sponsored{background:linear-gradient(135deg,gold,#ffed4e);border-radius:4px;color:#333;font-size:.75rem;font-weight:700;padding:.25rem .5rem}.result-total{color:#667eea;font-size:1.4rem;font-weight:700}.result-items{border-top:1px solid #f0f0f0;margin-top:0;padding:.85rem 1.1rem 1rem}.result-item{align-items:center;color:#4b5563;display:flex;font-size:.95rem;justify-content:space-between;padding:.5rem 0}.result-item .item-amount{color:#667085;font-weight:500}.no-items-warning{color:#b42318;font-size:.9rem;font-style:italic;margin:0;padding:.8rem 1.1rem 1rem}.results.compact .result-header{padding:.8rem .9rem}.results.compact .result-name{font-size:.96rem}.results.compact .result-total{font-size:1.1rem}.results.compact .result-items{padding:.7rem .9rem .8rem}.results.compact .result-item{font-size:.88rem}.results.compact .no-items-warning{font-size:.82rem;padding:.6rem .9rem .8rem}.bill-history{margin:0 auto;max-width:1200px;padding:2rem;width:100%}.history-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.history-actions{align-items:center;display:flex;gap:.7rem}.bill-search-input{border:1px solid #d0d8f7;border-radius:8px;font-size:.95rem;min-width:220px;padding:.7rem .8rem}.bill-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea29;outline:none}.history-header h2{color:#f8faff;font-size:2rem;margin:0 0 .5rem;text-shadow:0 2px 8px #00000038}.history-header .subtitle{color:#f8faffe6;font-size:.95rem;margin:0}.new-bill-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.8rem 1.5rem;transition:transform .2s,box-shadow .2s}.new-bill-btn:hover{box-shadow:0 6px 20px #667eea80;transform:translateY(-2px)}.new-bill-btn:active{transform:translateY(0)}.loading{color:#f8faffeb;font-size:1.1rem;padding:3rem;text-align:center}.empty-state{background:#f9f9f9;border:2px dashed #e0e0e0;border-radius:12px;padding:4rem 2rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:#333;font-size:1.5rem;margin:1rem 0}.empty-state p{color:#5f6368;font-size:1rem;margin:.5rem 0 1.5rem}.primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.8rem 1.5rem;transition:transform .2s}.primary-btn:hover{transform:translateY(-2px)}.bills-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.bill-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000000d;cursor:pointer;display:flex;flex-direction:column;padding:1.5rem;transition:all .3s ease}.bill-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea26;transform:translateY(-4px)}.bill-card-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.bill-role-badge{border-radius:6px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.35rem .75rem;text-transform:uppercase}.bill-role-badge[data-role=creator]{background:#667eea1a;color:#4457c8}.bill-role-badge[data-role=participant]{background:#4caf502e;color:#1f7a34}.bill-date{color:#667085;font-size:.85rem;white-space:nowrap}.bill-card-body{flex:1 1;margin-bottom:1rem}.bill-name{color:#333;font-size:1.05rem;font-weight:600;line-height:1.3;margin-bottom:.8rem;word-break:break-word}.my-share-block{margin-bottom:.7rem}.my-share-label{color:#667085;font-size:.78rem;font-weight:700;letter-spacing:.4px;margin-bottom:.25rem;text-transform:uppercase}.my-share-main-row{align-items:center;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between}.my-share-amount{color:#344054;font-size:1.9rem;font-weight:800;line-height:1}.share-paid-badge{border-radius:999px;font-size:.75rem;font-weight:700;padding:.2rem .6rem}.share-paid-badge.paid{background:#ecfdf3;border:1px solid #a6f4c5;color:#027a48}.share-paid-badge.unpaid{background:#fff5f4;border:1px solid #fecdc9;color:#b42318}.bill-total-secondary{color:#667085;font-size:.92rem;margin-bottom:.8rem}.bill-pay-to-secondary{color:#475467;font-size:.86rem;font-weight:600;margin-bottom:.8rem}.bill-meta{display:flex;flex-wrap:wrap;gap:1rem}.people-count{color:#666;font-size:.9rem;gap:.4rem}.finalized-badge,.people-count{align-items:center;display:flex}.finalized-badge{background:#4caf502e;border-radius:4px;color:#1f7a34;font-size:.75rem;font-weight:600;gap:.3rem;padding:.25rem .6rem}.bill-card-footer{align-items:center;border-top:1px solid #f0f0f0;display:flex;padding-top:1rem}.view-link{color:#667eea;font-size:.95rem;font-weight:600;text-decoration:none;transition:color .2s}.view-link:hover{color:#764ba2}.view-link-btn{font:inherit;padding:0}.delete-btn,.view-link-btn{background:none;border:none;cursor:pointer}.delete-btn{align-items:center;border-radius:4px;display:inline-flex;font-size:1.1rem;justify-content:center;margin-left:auto;padding:.4rem .6rem;transition:all .2s}.delete-btn:hover{background:#ff00001a;transform:scale(1.15)}.delete-btn:active{transform:scale(.95)}@media (max-width:768px){.history-header{align-items:flex-start;flex-direction:column;gap:1rem}.history-actions{align-items:stretch;flex-direction:column;width:100%}.bill-search-input{min-width:0;width:100%}.bills-grid{grid-template-columns:1fr}.bill-history{padding:1rem}}.admin-page{background:#fff;border-radius:12px;box-shadow:0 10px 24px #0000001a;padding:1.5rem;width:100%}.admin-header h2{margin:0}.admin-header p{color:#6b7280;margin:.35rem 0 1rem}.admin-empty,.admin-loading{color:#4b5563;padding:1rem}.admin-error{background:#fff1f2;border:1px solid #fecaca;border-radius:8px;color:#b42318;margin-bottom:.8rem;padding:.65rem .8rem}.admin-users-list{grid-gap:.65rem;display:grid;gap:.65rem}.admin-user-row{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:.8rem;justify-content:space-between;padding:.7rem}.admin-user-info{align-items:center;display:flex;gap:.65rem;min-width:0}.admin-user-avatar{border:1px solid #d1d5db;border-radius:50%;flex-shrink:0;height:42px;overflow:hidden;width:42px}.admin-user-avatar img{height:100%;object-fit:cover;width:100%}.admin-avatar-placeholder{align-items:center;background:#dbeafe;color:#1d4ed8;display:flex;font-weight:700;height:100%;justify-content:center;width:100%}.admin-user-meta{min-width:0}.admin-user-primary{color:#111827;font-weight:700}.admin-user-secondary{color:#6b7280;font-size:.83rem;overflow-wrap:anywhere}.admin-user-actions{align-items:center;display:flex;gap:.45rem}.admin-user-actions input{border:1px solid #d1d5db;border-radius:8px;min-width:210px;padding:.5rem .65rem}.admin-user-actions button{background:#4c5fd5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:.5rem .75rem}.admin-user-actions button:disabled{cursor:not-allowed;opacity:.65}@media (max-width:768px){.admin-page{padding:1rem}.admin-user-row{align-items:stretch;flex-direction:column}.admin-user-actions{width:100%}.admin-user-actions input{min-width:0;width:100%}}.display-name-modal-backdrop{align-items:center;background:#0f172a99;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1400}.display-name-modal{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 22px 44px #0f172a47;padding:1.1rem;width:min(460px,100%)}.display-name-modal h3{color:#111827;margin:0}.display-name-modal p{color:#4b5563;margin:.55rem 0 .9rem}.display-name-modal input{border:1px solid #cbd5e1;border-radius:8px;font-size:.98rem;padding:.66rem .74rem;width:100%}.display-name-modal input:focus{border-color:#4c5fd5;box-shadow:0 0 0 3px #4c5fd526;outline:none}.display-name-modal-actions{display:flex;gap:.55rem;justify-content:flex-end;margin-top:.85rem}.cancel-display-name-btn,.save-display-name-btn{border-radius:8px;cursor:pointer;font-weight:700;padding:.65rem .9rem}.save-display-name-btn{background:#4c5fd5;border:none;color:#fff}.cancel-display-name-btn{background:#fff;border:1px solid #d1d5db;color:#374151}.cancel-display-name-btn:disabled,.save-display-name-btn:disabled{cursor:not-allowed;opacity:.65}
/*# sourceMappingURL=main.223ebf13.css.map*/