*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}#root{width:100%;min-width:100%;min-height:100vh;overflow-x:hidden}.login-container{min-height:100vh;height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-color:#4a7b6f;padding:0 1rem;position:fixed;top:0;left:0;overflow:hidden}.login-card-wrapper{max-width:28rem;width:100%;position:relative;z-index:10}.login-card{background-color:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.brand-logo-container{display:flex;align-items:center;justify-content:center;gap:1rem}.brand-logo{width:5.5rem;height:5.5rem;flex-shrink:0;-o-object-fit:contain;object-fit:contain}.brand-text-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.brand-name{font-size:2.813rem;font-weight:700;color:#000;letter-spacing:-.02em;line-height:1}.brand-caption{font-size:.7rem;color:#6b7280;margin:0;line-height:1.2;white-space:nowrap}.login-title{font-size:1.875rem;font-weight:700;color:#000;margin-bottom:.5rem}.login-subtitle{color:#6b7280;font-size:.875rem}.error-message{margin-bottom:1rem;padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.25rem}.error-text{color:#dc2626;font-size:.875rem;text-align:center}.google-button{width:100%;display:none;align-items:center;justify-content:center;gap:.75rem;border:1px solid #d1d5db;background-color:#fff;color:#000;padding:.875rem 0;border-radius:.5rem;font-weight:400;font-size:1rem;margin-top:1rem;cursor:pointer;transition:background-color .2s}.google-button:hover{background-color:#f9fafb}.google-button:disabled{opacity:.5;cursor:not-allowed}.google-icon{width:1.25rem;height:1.25rem}.divider-container{position:relative;margin:1.5rem 0}.divider-line{position:absolute;inset:0;display:flex;align-items:center}.divider-line:before{content:"";width:100%;border-top:1px solid #d1d5db}.divider-text{position:relative;display:flex;justify-content:center}.divider-text span{padding:0 .75rem;background-color:#fff;color:#6b7280;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column}.form-label{display:block;font-size:.875rem;font-weight:500;color:#000;margin-bottom:.5rem;text-align:left}.form-input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;transition:all .2s;background-color:#fff;color:#000}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.form-input-error{border-color:#dc2626}.form-input-error:focus{border-color:#dc2626;box-shadow:0 0 0 2px #dc262633}.form-error-text{margin-top:.25rem;font-size:.75rem;color:#dc2626}.password-input-wrapper{position:relative}.password-input{width:100%;padding:.75rem 3rem .75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;transition:all .2s;background-color:#fff;color:#000}.password-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.password-input.form-input-error{border-color:#dc2626}.password-input.form-input-error:focus{border-color:#dc2626;box-shadow:0 0 0 2px #dc262633}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#4b5563}.password-toggle svg{width:1.25rem;height:1.25rem}.options-row{display:flex;align-items:center;justify-content:space-between;padding-top:.25rem}.checkbox-label{display:flex;align-items:center;cursor:pointer}.checkbox-input{width:1rem;height:1rem;border:1px solid #d1d5db;border-radius:.25rem;cursor:pointer;accent-color:#2563eb;background-color:#fff;appearance:none;-webkit-appearance:none;-moz-appearance:none}.checkbox-input:checked{background-color:#2563eb;border-color:#2563eb;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='white' d='M10 3L4.5 8.5 2 6' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.checkbox-text{margin-left:.5rem;font-size:.875rem;color:#000}.forgot-password{font-size:.875rem;color:#2563eb;text-decoration:none;cursor:pointer}.forgot-password:hover{color:#1d4ed8;text-decoration:underline}.login-button{width:100%;background-color:#2f3943;color:#fff;padding:.875rem 0;border-radius:.5rem;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.login-button:hover{background-color:#232b33}.login-button:disabled{opacity:.5;cursor:not-allowed}.signup-link-container{margin-top:2rem;text-align:center}.signup-link{font-size:.875rem;color:#2563eb;text-decoration:underline;cursor:pointer}.signup-link:hover{color:#1d4ed8}.popup-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.popup-content{background-color:#fff;border-radius:.75rem;padding:2rem;max-width:28rem;width:90%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;text-align:center}.popup-title{font-size:1.5rem;font-weight:700;color:#000;margin-bottom:1rem}.popup-message{font-size:1rem;color:#6b7280;margin-bottom:1.5rem;line-height:1.5}.popup-button{width:100%;background-color:#2f3943;color:#fff;padding:.875rem 0;border-radius:.5rem;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:background-color .2s}.popup-button:hover{background-color:#232b33}.item-list-container{width:100%;height:100%;display:flex;flex-direction:column;gap:1.5rem;padding:1rem 3rem 0}@media(max-width:768px){.item-list-container{padding:1rem .5rem 0}}.item-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:1rem;border-bottom:2px solid black}.item-list-title-section{flex:1}.item-list-title{font-size:3rem;font-weight:600;color:#4a7b6f;margin:0 0 .25rem}.item-list-subtitle{font-size:.875rem;color:#6b7280;margin:0}.item-list-actions{display:flex;gap:.75rem;align-items:center}.item-list-add-button{width:2.5rem;height:2.5rem;background-color:#2563eb;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;flex-shrink:0}.item-list-add-button:hover{background-color:#1d4ed8}.item-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,300px));gap:.5rem 1.25rem;flex:1;overflow-y:auto}@media(max-width:768px){.item-list-grid{grid-template-columns:1fr;gap:.5rem}}.item-list-empty{grid-column:1 / -1;text-align:center;padding:3rem 1rem;color:#6b7280;font-size:1rem}.item-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;transition:all .2s;display:flex;flex-direction:column;gap:.75rem;position:relative;aspect-ratio:2;width:100%}.item-card-owner{background-color:#e5e7eb}.item-card-shared{background-color:#d1fae5}.item-card-not-my-list{background-color:#dbeafe}.item-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.item-card-creator-label{font-size:1rem;color:#6b7280;margin-top:.25rem}.item-card-creator-name{font-weight:500;color:#374151}.item-card-body{display:flex;flex-direction:column;gap:.5rem;cursor:pointer;flex:1}.item-card-delete{position:absolute;top:.75rem;right:.75rem;width:1.75rem;height:1.75rem;background-color:#dc2626;color:#fff;border:none;border-radius:.375rem;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s,background-color .2s;z-index:10}.item-card:hover .item-card-delete{opacity:1}.item-card-delete:hover{background-color:#b91c1c}.item-card-name{font-size:1.5rem;font-weight:600;color:#111827;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-card-details{display:flex;flex-direction:column;gap:.375rem}.item-card-detail{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:#6b7280}.item-card-detail svg{flex-shrink:0}.item-card-tag{font-size:.75rem;font-weight:500;color:#6b7280;margin-top:.25rem}.item-list-pagination{display:flex;justify-content:flex-end;align-items:center;gap:.75rem;margin-top:auto;padding-top:1rem}.item-list-pagination-button{padding:.5rem 1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s}.item-list-pagination-button:hover:not(:disabled){background-color:#f9fafb;border-color:#d1d5db}.item-list-pagination-button:disabled{opacity:.5;cursor:not-allowed}.item-list-pagination-numbers{display:flex;gap:.5rem}.item-list-pagination-number{width:2rem;height:2rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.item-list-pagination-number:hover{background-color:#f9fafb;border-color:#d1d5db}.item-list-pagination-number.active{background-color:#f97316;color:#fff;border-color:#f97316}.create-item{padding:1rem}.create-item-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.create-item-modal{background-color:#fff;border-radius:.75rem;width:90%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.create-item-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.create-item-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.create-item-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:background-color .2s}.create-item-modal-close:hover{background-color:#f3f4f6}.create-item-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.create-item-field{display:flex;flex-direction:column;gap:.5rem}.create-item-field label{font-size:.875rem;font-weight:500;color:#374151}.create-item-field input,.create-item-field select{padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;outline:none;transition:border-color .2s;background-color:#fff;color:#111827}.create-item-field input:focus,.create-item-field select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.create-item-error{padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#dc2626;font-size:.875rem}.create-item-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.create-item-cancel,.create-item-submit{padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.create-item-cancel{background-color:#fff;color:#374151;border:1px solid #d1d5db}.create-item-cancel:hover{background-color:#f9fafb}.create-item-submit{background-color:#2563eb;color:#fff}.create-item-submit:hover:not(:disabled){background-color:#1d4ed8}.create-item-submit:disabled{opacity:.5;cursor:not-allowed}.create-item-friends-loading,.create-item-friends-empty{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}.create-item-friends-empty{font-style:italic}.create-item-friends-list{max-height:200px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:.375rem;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.create-item-friend-checkbox{display:flex;align-items:center;gap:.75rem;padding:.5rem;cursor:pointer;border-radius:.375rem;transition:background-color .2s}.create-item-friend-checkbox:hover{background-color:#f9fafb}.create-item-friend-checkbox input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#2563eb;background-color:#fff;border:1px solid #d1d5db;border-radius:.25rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;position:relative}.create-item-friend-checkbox input[type=checkbox]:checked{background-color:#2563eb;border-color:#2563eb}.create-item-friend-checkbox input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.75rem;font-weight:700;line-height:1}.create-item-friend-name{font-size:.875rem;color:#374151;flex:1}.create-item-not-my-list-checkbox{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;cursor:pointer;font-size:.875rem;color:#374151;font-weight:400}.create-item-not-my-list-checkbox input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:#2563eb;background-color:#fff;border:1px solid #d1d5db;border-radius:.25rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;position:relative}.create-item-not-my-list-checkbox input[type=checkbox]:checked{background-color:#2563eb;border-color:#2563eb}.create-item-not-my-list-checkbox input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.75rem;font-weight:700;line-height:1}.share-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.share-modal{background-color:#fff;border-radius:.75rem;width:90%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.share-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.share-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:background-color .2s}.share-modal-close:hover{background-color:#f3f4f6}.share-modal-content{padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.share-qr-code{display:flex;justify-content:center;align-items:center;padding:1rem;background-color:#f9fafb;border-radius:.5rem}.share-url{width:100%;display:flex;gap:.5rem}.share-url-input{flex:1;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;outline:none;background-color:#f9fafb;color:#111827}.share-copy-button{padding:.625rem 1.25rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.share-copy-button:hover{background-color:#1d4ed8}.list-detail-container{padding:1.5rem;background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:1.5rem;height:100%}.list-detail-header{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.list-detail-members{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-wrap:nowrap}.list-detail-member-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:transform .2s}.list-detail-member-avatar:hover{transform:scale(1.1)}@media(max-width:768px){.list-detail-member-avatar{display:none}}.list-detail-back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s;white-space:nowrap}.list-detail-back-button:hover{background-color:#f9fafb;border-color:#d1d5db}.list-detail-title{font-size:35px;font-weight:600;color:#111827;margin:0;flex:1}.list-detail-add-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background-color:#f97316;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;align-self:flex-start}.list-detail-add-button:hover{background-color:#ea580c}.list-detail-add-form{padding:1rem;background-color:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.list-detail-item-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;outline:none;transition:border-color .2s;background-color:#fff;color:#111827;margin-bottom:.75rem}.list-detail-item-input:focus{border-color:#f97316}.list-detail-add-actions{display:flex;gap:.75rem;justify-content:flex-end}.list-detail-cancel-button{padding:.5rem 1rem;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s}.list-detail-cancel-button:hover{background-color:#f9fafb;border-color:#d1d5db}.list-detail-submit-button{padding:.5rem 1rem;background-color:#f97316;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.list-detail-submit-button:hover:not(:disabled){background-color:#ea580c}.list-detail-submit-button:disabled{opacity:.5;cursor:not-allowed}.list-detail-items{flex:1;overflow-y:auto;padding:0 .5rem}.list-detail-loading,.list-detail-empty{text-align:center;padding:2rem;color:#6b7280;font-size:.875rem}.list-detail-items-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.list-detail-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .2s}.list-detail-item:hover{background-color:#f3f4f6;border-color:#d1d5db}.list-detail-item-content{display:flex;align-items:center;gap:.75rem;flex:1;font-size:1.5rem}.list-detail-item-name{font-size:1.5rem;color:#111827;font-weight:500}.list-detail-item-link{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background-color:#2563eb;color:#fff;border-radius:.25rem;font-size:.75rem;text-decoration:none;transition:background-color .2s;border:none;cursor:pointer;margin-right:1rem;margin-left:2rem}.list-detail-item-link:hover{background-color:#1d4ed8}.list-detail-item-link-disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed;opacity:.6;margin-right:1rem}.list-detail-item-link-disabled:hover{background-color:#e5e7eb}.list-detail-item-actions{display:flex;align-items:center;gap:.5rem}.list-detail-item-edit-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.list-detail-item-edit-button:hover{background-color:#e5e7eb;color:#374151}.list-detail-item-edit{display:flex;flex-direction:column;gap:.5rem;width:100%}.list-detail-item-edit-input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;outline:none;transition:border-color .2s;background-color:#fff;color:#111827}.list-detail-item-edit-input:focus{border-color:#f97316}.list-detail-item-edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.list-detail-item-save-button{padding:.375rem .75rem;background-color:#f97316;color:#fff;border:none;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .2s}.list-detail-item-save-button:hover:not(:disabled){background-color:#ea580c}.list-detail-item-save-button:disabled{opacity:.5;cursor:not-allowed}.list-detail-item-cancel-button{padding:.375rem .75rem;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.75rem;color:#374151;cursor:pointer;transition:all .2s}.list-detail-item-cancel-button:hover{background-color:#f9fafb;border-color:#d1d5db}.list-detail-checkbox-wrapper{display:inline-flex;align-items:center;cursor:pointer;position:relative}.list-detail-checkbox{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.list-detail-checkbox-checkmark{height:20px;width:20px;background-color:#fff;border:2px solid #d1d5db;border-radius:.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.list-detail-checkbox-wrapper:hover .list-detail-checkbox-checkmark{border-color:#2563eb;background-color:#eff6ff}.list-detail-checkbox:checked~.list-detail-checkbox-checkmark{background-color:#2563eb;border-color:#2563eb}.list-detail-checkbox:checked~.list-detail-checkbox-checkmark:after{content:"";position:absolute;display:block;left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.list-detail-item-checked{opacity:.6;color:#6b7280}.list-detail-item-checked-by{font-size:.875rem;color:#6b7280;font-style:italic}@media(max-width:768px){.list-detail-item{flex-direction:column;align-items:flex-start;gap:.5rem}.list-detail-item-checked-by{margin-top:.25rem;width:100%}}.list-detail-edit-members-button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151;cursor:pointer;transition:all .2s;margin-left:.5rem}.list-detail-edit-members-button:hover{background-color:#e5e7eb;border-color:#9ca3af;transform:scale(1.05)}.list-detail-view-members-button{width:32px;height:32px;border-radius:50%;display:none;align-items:center;justify-content:center;background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151;cursor:pointer;transition:all .2s;margin-left:.5rem}.list-detail-view-members-button:hover{background-color:#e5e7eb;border-color:#9ca3af;transform:scale(1.05)}.list-detail-members-more{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#e5e7eb;border:1px solid #d1d5db;color:#374151;cursor:pointer;transition:all .2s;font-size:.75rem;font-weight:600;flex-shrink:0}.list-detail-members-more:hover{background-color:#d1d5db;border-color:#9ca3af;transform:scale(1.05)}@media(max-width:768px){.list-detail-members-more{display:none}}.list-detail-share-button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151;cursor:pointer;transition:all .2s;margin-left:.5rem;flex-shrink:0}.list-detail-share-button:hover{background-color:#e5e7eb;border-color:#9ca3af;transform:scale(1.05)}.list-detail-view-members-button-owner{display:none}@media(max-width:768px){.list-detail-view-members-button,.list-detail-view-members-button-owner{display:flex}.list-detail-edit-members-button{display:none}}.list-detail-edit-members-modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.list-detail-edit-members-content{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 25px #0003;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.list-detail-edit-members-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.list-detail-edit-members-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.list-detail-edit-members-close{width:32px;height:32px;border:none;background:none;font-size:1.5rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.list-detail-edit-members-close:hover{background-color:#f3f4f6;color:#111827}.list-detail-edit-members-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:2rem}.list-detail-current-members h4,.list-detail-add-members h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151}.list-detail-member-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;margin-bottom:.5rem}.list-detail-member-item-info{display:flex;align-items:center;gap:.5rem}.list-detail-member-item-email{font-size:.875rem;color:#111827}.list-detail-member-item-owner{font-size:.75rem;color:#6b7280;font-style:italic}.list-detail-member-add-button,.list-detail-member-remove-button{padding:.375rem .75rem;font-size:.875rem;border-radius:.375rem;border:none;cursor:pointer;transition:all .2s;font-weight:500}.list-detail-member-add-button{background-color:#2563eb;color:#fff}.list-detail-member-add-button:hover{background-color:#1d4ed8}.list-detail-member-remove-button{background-color:#ef4444;color:#fff}.list-detail-member-remove-button:hover{background-color:#dc2626}.list-detail-friends-list{max-height:300px;overflow-y:auto}.list-detail-no-friends{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}.friends-list{width:100%}.friends-list-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}.friends-loading{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}.friends-empty{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem;font-style:italic}.friends-list-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.friends-list-item{padding:0;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:background-color .2s;overflow:hidden;cursor:pointer;position:relative}.friends-list-item:hover{background-color:#f3f4f6}.friends-list-item-content{display:flex;align-items:center;transition:transform .3s ease;width:100%;position:relative;z-index:1;background-color:inherit}.friends-list-item-expanded .friends-list-item-content{transform:translate(-80px)}.friends-list-item-email{font-size:.875rem;color:#374151;padding:.75rem;flex:1;min-width:0}.friends-list-item-delete{position:absolute;right:-80px;top:0;bottom:0;padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#dc2626;border:none;border-radius:0 .375rem .375rem 0;cursor:pointer;transition:right .3s ease,background-color .2s;white-space:nowrap;width:80px;display:flex;align-items:center;justify-content:center;z-index:0}.friends-list-item-expanded .friends-list-item-delete{right:0}.friends-list-item-delete:hover{background-color:#b91c1c}.add-friend{width:100%}.add-friend-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}.add-friend-form{display:flex;flex-direction:column;gap:.75rem}.add-friend-input{width:100%;padding:.625rem .75rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:.375rem;outline:none;transition:border-color .2s;background-color:#fff;color:#111827}.add-friend-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.add-friend-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.add-friend-button{padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#2563eb;border:none;border-radius:.375rem;cursor:pointer;transition:background-color .2s}.add-friend-button:hover:not(:disabled){background-color:#1d4ed8}.add-friend-button:disabled{background-color:#9ca3af;cursor:not-allowed}.add-friend-error{padding:.5rem;font-size:.75rem;color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.25rem}.add-friend-success{padding:.5rem;font-size:.75rem;color:#059669;background-color:#d1fae5;border:1px solid #a7f3d0;border-radius:.25rem}.pending-requests{width:100%;margin-top:1.5rem}.pending-requests-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}.pending-requests-loading,.pending-requests-empty{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}.pending-requests-empty{font-style:italic}.pending-requests-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.pending-request-item-container{position:relative;overflow:hidden;cursor:pointer;border-radius:.375rem}.pending-request-item{padding:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;flex-direction:column;gap:.75rem;transition:transform .3s ease;position:relative;z-index:1;background-color:inherit}.pending-request-item-container:hover .pending-request-item{background-color:#f3f4f6}.pending-request-item-expanded .pending-request-item{transform:translate(-80px)}.pending-request-sent{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pending-request-email{font-size:.875rem;color:#374151}.pending-request-actions{display:flex;flex-direction:row;gap:.5rem}.pending-request-accept,.pending-request-reject{padding:.375rem .75rem;font-size:.75rem;font-weight:500;border:none;border-radius:.25rem;cursor:pointer;transition:background-color .2s}.pending-request-accept{color:#fff;background-color:#059669}.pending-request-accept:hover{background-color:#047857}.pending-request-reject{color:#fff;background-color:#dc2626}.pending-request-reject:hover{background-color:#b91c1c}.pending-request-status{font-size:.75rem;color:#6b7280;font-style:italic}.pending-request-delete-button{position:absolute;right:-80px;top:0;bottom:0;padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#dc2626;border:none;border-radius:0 .375rem .375rem 0;cursor:pointer;transition:right .3s ease,background-color .2s;white-space:nowrap;width:80px;display:flex;align-items:center;justify-content:center;z-index:0}.pending-request-item-expanded .pending-request-delete-button{right:0}.pending-request-delete-button:hover{background-color:#b91c1c}.friends-sidebar{background-color:#fff;border-radius:.5rem 0 0;padding:1.5rem;box-shadow:-1px 0 3px #0000001a;display:flex;flex-direction:column;gap:1.5rem;height:100%;min-height:calc(100vh - 73px);margin-right:0;width:100%}.friends-sidebar-toggle{display:flex;gap:.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.friends-toggle-button{flex:1;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#6b7280;background-color:transparent;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s;position:relative;overflow:visible}.friends-toggle-button:hover{background-color:#f9fafb;color:#374151}.friends-toggle-active{background-color:#2563eb;color:#fff;border-color:#2563eb;overflow:visible}.friends-toggle-active:hover{background-color:#1d4ed8;border-color:#1d4ed8}.friends-toggle-badge{position:absolute;top:-.5rem;right:-.5rem;background-color:#dc2626;color:#fff;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:50%;min-width:1.25rem;height:1.25rem;text-align:center;line-height:1.25rem;z-index:10;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.dashboard-container{width:100%;min-width:100%;min-height:100vh;background-color:#f9fafb;overflow-x:hidden}.dashboard-header{width:100%;min-width:100%;background-color:#d3d3d3;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;position:sticky;top:0;z-index:100}.dashboard-header-content{display:flex;align-items:center;justify-content:space-between}.dashboard-logo-section{display:flex;align-items:center;gap:.75rem}.dashboard-logo{width:3rem;height:3rem;-o-object-fit:contain;object-fit:contain}.dashboard-title{font-size:1.5rem;font-weight:700;color:#000;margin:0}.dashboard-actions{display:flex;align-items:center;gap:1rem}.dashboard-profile-dropdown{position:relative}.dashboard-button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:.5rem;cursor:pointer;transition:background-color .2s;border:none;display:flex;align-items:center;gap:.5rem}.dashboard-button-profile{color:#374151;background-color:#fff;border:1px solid #d1d5db}.dashboard-button-profile:hover{background-color:#f9fafb}.dashboard-button-email{display:inline}.dashboard-button-initial{display:none}@media(max-width:768px){.dashboard-button-email{display:none}.dashboard-button-initial{display:flex;width:32px;height:32px;border-radius:50%;background-color:#3b82f6;color:#fff;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.dashboard-button-profile{padding:.25rem;min-width:auto}}.dashboard-dropdown-chevron{transition:transform .2s;flex-shrink:0}.dashboard-dropdown-chevron.open{transform:rotate(180deg)}.dashboard-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;min-width:150px;z-index:1000;overflow:hidden}.dashboard-dropdown-item{width:100%;padding:.75rem 1rem;font-size:.875rem;font-weight:500;text-align:left;border:none;background:none;cursor:pointer;transition:background-color .2s;color:#374151}.dashboard-dropdown-item:hover{background-color:#f9fafb}.dashboard-dropdown-logout{color:#dc2626}.dashboard-dropdown-logout:hover{background-color:#fef2f2;color:#b91c1c}.dashboard-main{display:flex;width:100%;min-width:100%;min-height:calc(100vh - 73px)}.dashboard-content-wrapper{display:flex;width:100%;min-width:100%;align-items:stretch}.dashboard-content-left{flex:1;min-width:0;max-width:1400px;margin-left:auto;padding:2rem 2rem 2rem 1.5rem;display:flex;flex-direction:column;overflow:hidden;background-image:url(/assets/Background1-Cwv8i5f8.png);background-repeat:repeat;background-position:top left}.dashboard-content-right{min-width:320px;width:320px;flex-shrink:0;height:100%;min-height:calc(100vh - 73px);display:flex;flex-direction:column;margin-left:auto;margin-right:0}.dashboard-divider{width:1px;background-color:#e5e7eb;flex-shrink:0}.dashboard-mobile-menu-button{display:none;padding:.5rem;background:none;border:none;color:#374151;cursor:pointer;margin-right:.5rem}.dashboard-mobile-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:998}.dashboard-mobile-friends{display:none;position:fixed;top:0;right:0;bottom:0;width:320px;max-width:85vw;background-color:#fff;z-index:999;box-shadow:-2px 0 8px #0000001a;overflow-y:auto}.dashboard-mobile-friends-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #e5e7eb;background-color:#f9fafb;position:sticky;top:0;z-index:1}.dashboard-mobile-friends-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.dashboard-mobile-friends-close{width:32px;height:32px;border:none;background:none;font-size:1.5rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.dashboard-mobile-friends-close:hover{background-color:#f3f4f6;color:#111827}@media(max-width:768px){.dashboard-mobile-menu-button{display:block}.dashboard-content-right,.dashboard-divider{display:none}.dashboard-mobile-overlay,.dashboard-mobile-friends{display:block}}#root{width:100%;min-width:100%;max-width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
