body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;background-color:#f4f4f9;color:#333}#app{display:flex;flex-direction:column;min-height:100vh}main{flex-grow:1;padding:2rem;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}@media(max-width:768px){main{padding:1rem}}header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}header nav{display:flex;gap:1.5rem}header nav a{text-decoration:none;color:#555;font-weight:500;font-size:1rem;padding-bottom:5px;border-bottom:2px solid transparent;transition:color .2s,border-bottom-color .2s}header nav a.router-link-active{color:#42b983;border-bottom-color:#42b983}header button{background-color:#d9534f;color:#fff;border:none;padding:.6rem 1rem;border-radius:5px;cursor:pointer;font-weight:500;transition:background-color .2s}header button:hover{background-color:#c9302c}.form-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;margin:2rem auto}.form-container h1{margin-top:0;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.8rem;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:1rem}button.primary{width:100%;padding:.8rem;background-color:#42b983;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}button.primary:hover{background-color:#36a476}.error-message{color:#d9534f;margin-top:1rem;text-align:center}.auth-link{display:block;text-align:center;margin-top:1.5rem;color:#555}.auth-link a{color:#42b983;text-decoration:none}.lists-page h1[data-v-8809b2ea]{margin-top:0;margin-bottom:1.5rem}.new-list-form[data-v-8809b2ea]{display:flex;gap:.75rem;margin-bottom:2rem}.new-list-form input[data-v-8809b2ea]{flex:1;padding:.7rem 1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}.new-list-form button[data-v-8809b2ea]{padding:.7rem 1.4rem;background-color:#42b983;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;white-space:nowrap;transition:background-color .2s}.new-list-form button[data-v-8809b2ea]:hover:not(:disabled){background-color:#36a476}.new-list-form button[data-v-8809b2ea]:disabled{opacity:.6;cursor:not-allowed}.loading[data-v-8809b2ea],.empty[data-v-8809b2ea]{color:#888;text-align:center;padding:2rem 0}.list-items[data-v-8809b2ea]{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.list-item[data-v-8809b2ea]{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:1rem 1.25rem;border-radius:8px;box-shadow:0 1px 4px #00000012;gap:1rem}.badge-shared[data-v-8809b2ea]{font-size:.7rem;font-weight:600;background:#e8f5e9;color:#42b983;border-radius:4px;padding:.1rem .4rem;margin-left:.5rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em}.list-name[data-v-8809b2ea]{font-size:1.05rem;font-weight:500;cursor:pointer;color:#333;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-name[data-v-8809b2ea]:hover{color:#42b983}.list-actions[data-v-8809b2ea]{display:flex;gap:.5rem;flex-shrink:0}.btn-copy[data-v-8809b2ea],.btn-delete[data-v-8809b2ea]{padding:.4rem .8rem;border:none;border-radius:5px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.btn-copy[data-v-8809b2ea]{background-color:#e8f5e9;color:#42b983}.btn-copy[data-v-8809b2ea]:hover{background-color:#c8e6c9}.btn-delete[data-v-8809b2ea]{background-color:#fdecea;color:#d9534f}.btn-delete[data-v-8809b2ea]:hover{background-color:#f5c6c5}.calculator[data-v-4d89b443]{display:flex;flex-direction:column;gap:1.25rem}.add-form[data-v-4d89b443]{display:flex;gap:.75rem}.add-form input[data-v-4d89b443]{flex:1;padding:.7rem 1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}.add-form input[data-v-4d89b443]:focus{outline:none;border-color:#42b983}.add-form button[data-v-4d89b443]{padding:.7rem 1.4rem;background-color:#42b983;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.add-form button[data-v-4d89b443]:hover:not(:disabled){background-color:#36a476}.add-form button[data-v-4d89b443]:disabled{opacity:.6;cursor:not-allowed}.entries[data-v-4d89b443]{display:flex;flex-direction:column;gap:0;border:1px solid #e8e8e8;border-radius:6px;overflow:hidden}.entry-row[data-v-4d89b443]{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid #f0f0f0}.entry-row[data-v-4d89b443]:last-of-type{border-bottom:none}.entry-amount[data-v-4d89b443]{font-size:1.1rem;font-weight:600}.btn-delete[data-v-4d89b443]{background:none;border:none;color:#ccc;font-size:1.2rem;cursor:pointer;line-height:1;padding:0 .25rem;transition:color .2s}.btn-delete[data-v-4d89b443]:hover{color:#d9534f}.total-row[data-v-4d89b443]{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#f9f9f9;border-bottom:2px solid #e0e0e0;font-weight:700}.total-label[data-v-4d89b443]{font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;color:#666}.total-amount[data-v-4d89b443]{font-size:1.2rem;color:#333}.empty[data-v-4d89b443]{color:#aaa;text-align:center;padding:1.5rem 0;margin:0}.shopping-list[data-v-8f935d41]{display:flex;flex-direction:column;gap:1.25rem}.add-form[data-v-8f935d41]{display:flex;gap:.75rem}.add-form input[data-v-8f935d41]{flex:1;padding:.7rem 1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}.add-form input[data-v-8f935d41]:focus{outline:none;border-color:#42b983}.add-form button[data-v-8f935d41]{padding:.7rem 1.4rem;background-color:#42b983;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.add-form button[data-v-8f935d41]:hover:not(:disabled){background-color:#36a476}.add-form button[data-v-8f935d41]:disabled{opacity:.6;cursor:not-allowed}.items-list[data-v-8f935d41]{display:flex;flex-direction:column;gap:0;border:1px solid #e8e8e8;border-radius:6px;overflow:hidden}.item-row[data-v-8f935d41]{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-bottom:1px solid #f0f0f0}.item-row[data-v-8f935d41]:last-child{border-bottom:none}.item-row.checked[data-v-8f935d41]{background-color:#fafafa}.item-checkbox[data-v-8f935d41]{width:1.1rem;height:1.1rem;cursor:pointer;accent-color:#42b983;flex-shrink:0}.item-name[data-v-8f935d41]{flex:1;font-size:1rem}.item-name.strikethrough[data-v-8f935d41]{text-decoration:line-through;opacity:.75}.btn-assign[data-v-8f935d41]{width:2rem;height:2rem;border:2px solid #ddd;border-radius:5px;background:#f5f5f5;cursor:pointer;font-size:.95rem;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:background-color .2s,border-color .2s}.btn-assign[data-v-8f935d41]:hover{border-color:#aaa;background:#eee}.btn-assign.assigned[data-v-8f935d41]{color:#fff}.btn-delete[data-v-8f935d41]{background:none;border:none;color:#ccc;font-size:1.2rem;cursor:pointer;line-height:1;padding:0 .25rem;transition:color .2s;flex-shrink:0}.btn-delete[data-v-8f935d41]:hover{color:#d9534f}.divider[data-v-8f935d41]{height:2px;background-color:#e8e8e8}.empty[data-v-8f935d41]{color:#aaa;text-align:center;padding:1.5rem 0;margin:0}.grocery-list-page[data-v-9a5523e6]{max-width:700px;margin:0 auto}.page-header[data-v-9a5523e6]{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.page-header h1[data-v-9a5523e6]{margin:0;font-size:1.5rem}.btn-back[data-v-9a5523e6]{background:none;border:none;color:#555;cursor:pointer;font-size:.95rem;padding:.3rem 0;transition:color .2s;white-space:nowrap}.btn-back[data-v-9a5523e6]:hover{color:#42b983}.loading[data-v-9a5523e6]{color:#888;text-align:center;padding:3rem 0}.tabs[data-v-9a5523e6]{display:flex;border-bottom:2px solid #e0e0e0;margin-bottom:1.5rem;gap:0}.tab-btn[data-v-9a5523e6]{background:none;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-bottom-color .2s}.tab-btn[data-v-9a5523e6]:hover{color:#42b983}.tab-btn.active[data-v-9a5523e6]{color:#42b983;border-bottom-color:#42b983}.tab-content[data-v-9a5523e6]{background:#fff;border-radius:8px;box-shadow:0 1px 4px #00000012;padding:1.5rem}
