:root{--primary-blue: #007AFF;--primary-blue-hover: #0056CC;--background-light: #f8fafc;--background-dark: #1a1a1a;--text-light: #1a1a1a;--text-dark: #ffffff;--gray-light: #9ca3af;--gray-dark: #6b7280;--touch-target: 44px;--touch-target-large: 52px}@media (prefers-color-scheme: dark){:root{--background: var(--background-dark);--text: var(--text-dark)}}@media (prefers-color-scheme: light){:root{--background: var(--background-light);--text: var(--text-light)}}*,*:before,*:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);transition:color .5s,background-color .5s;line-height:1.6;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;min-height:100vh;margin:0;padding:0;font-weight:400}button,input,label{-webkit-tap-highlight-color:rgba(0,0,0,.1);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}input{-webkit-user-select:text;user-select:text}input[type=text],textarea{font-size:16px}@media screen and (max-width: 480px){input[type=text],textarea{font-size:16px!important}}.login-container[data-v-ded1a14e]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8f9fa;padding:1rem}.login-card[data-v-ded1a14e]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;padding:2rem;width:100%;max-width:400px;animation:slideUp-ded1a14e .3s ease-out}@keyframes slideUp-ded1a14e{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header[data-v-ded1a14e]{text-align:center;margin-bottom:2rem}.login-icon[data-v-ded1a14e]{margin-bottom:1rem}.lock-icon[data-v-ded1a14e]{width:3rem;height:3rem;color:#007aff;filter:drop-shadow(0 2px 4px rgba(0,122,255,.2))}.spinner-icon[data-v-ded1a14e]{width:1.25rem;height:1.25rem;display:inline-block;vertical-align:middle;animation:spin-ded1a14e 1s linear infinite}@keyframes spin-ded1a14e{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.signin-icon[data-v-ded1a14e],.error-icon[data-v-ded1a14e]{width:1.25rem;height:1.25rem;display:inline-block;vertical-align:middle}.login-header h1[data-v-ded1a14e]{margin:0 0 2rem;font-size:2rem;color:#1a1a1a;font-weight:700;letter-spacing:-.025em}.login-form[data-v-ded1a14e]{margin-bottom:2rem}.form-group[data-v-ded1a14e]{margin-bottom:1.5rem}.form-group label[data-v-ded1a14e]{display:block;margin-bottom:.5rem;color:#1a1a1a;font-weight:500;font-size:.9rem}.form-group input[data-v-ded1a14e]{width:100%;padding:1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .2s ease;box-sizing:border-box;background:#fff}.form-group input[data-v-ded1a14e]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input[data-v-ded1a14e]:disabled{background-color:#f8f9fa;opacity:.7}.login-button[data-v-ded1a14e]{width:100%;padding:1rem;background:#007aff;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button[data-v-ded1a14e]:hover:not(:disabled){background:#0056cc;transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.login-button[data-v-ded1a14e]:active:not(:disabled){transform:translateY(0)}.login-button[data-v-ded1a14e]:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message[data-v-ded1a14e]{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:1rem;border-radius:8px;margin-top:1rem;text-align:center;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem}@media (max-width: 480px){.login-container[data-v-ded1a14e]{padding:.5rem}.login-card[data-v-ded1a14e]{padding:1.5rem;border-radius:12px}.login-header h1[data-v-ded1a14e]{font-size:1.75rem}.form-group input[data-v-ded1a14e],.login-button[data-v-ded1a14e]{padding:.875rem}}@media (max-width: 768px){.login-card[data-v-ded1a14e]{margin:1rem}.form-group input[data-v-ded1a14e]{font-size:16px}}@media (prefers-color-scheme: dark){.login-container[data-v-ded1a14e]{background:#1a1a1a}.login-card[data-v-ded1a14e]{background:#2d3748;color:#f7fafc;border-color:#4a5568}.login-header h1[data-v-ded1a14e]{color:#f7fafc}.form-group label[data-v-ded1a14e]{color:#e2e8f0}.form-group input[data-v-ded1a14e]{background:#4a5568;color:#f7fafc;border-color:#4a5568}.form-group input[data-v-ded1a14e]:focus{border-color:#007aff}.error-message[data-v-ded1a14e]{background:#7f1d1d;color:#fca5a5;border-color:#991b1b}}.shopping-item[data-v-17d61fd3]{width:100%;margin:0;padding:1rem 1.25rem;background:#fff;border-bottom:1px solid #f1f5f9;transition:background-color .2s ease;display:flex;align-items:center;justify-content:space-between;box-sizing:border-box}.shopping-item[data-v-17d61fd3]:nth-child(2n){background-color:#f8fafc}.shopping-item[data-v-17d61fd3]:hover{background-color:#f1f5f9!important}.shopping-item[data-v-17d61fd3]:active{background-color:#e2e8f0!important}.item-content[data-v-17d61fd3]{display:flex;align-items:center;gap:1rem;flex:1;min-height:48px}.item-checkbox[data-v-17d61fd3]{width:24px;height:24px;min-width:24px;min-height:24px;cursor:pointer;accent-color:#007AFF;border-radius:50%;appearance:none;-webkit-appearance:none;border:2px solid #d1d5db;background:#fff;transition:all .2s ease;position:relative;margin:0}.item-checkbox[data-v-17d61fd3]:checked{background:#007aff;border-color:#007aff}.item-checkbox[data-v-17d61fd3]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:700;line-height:1}.user-avatars[data-v-17d61fd3]{display:flex;align-items:center;gap:.375rem;margin-right:.5rem;flex-shrink:0}.user-avatar[data-v-17d61fd3]{display:flex;align-items:center;justify-content:center;width:24px;height:24px;position:relative;flex-shrink:0}.avatar-img[data-v-17d61fd3]{width:100%;height:100%;border-radius:50%;object-fit:cover;border:1px solid #e5e7eb}.avatar-placeholder[data-v-17d61fd3]{width:100%;height:100%;border-radius:50%;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;border:1px solid #e5e7eb}.creator-placeholder[data-v-17d61fd3]{background:linear-gradient(45deg,#667eea,#764ba2)}.purchaser-placeholder[data-v-17d61fd3]{background:linear-gradient(45deg,#10b981,#059669)}.purchaser-indicator[data-v-17d61fd3]{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background:#10b981;border-radius:50%;color:#fff;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;line-height:1}.delete-button[data-v-17d61fd3]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:#9ca3af;cursor:pointer;border-radius:8px;transition:all .2s ease;opacity:.6}.delete-button[data-v-17d61fd3]:hover{background-color:#fee2e2;color:#dc2626;opacity:1;transform:scale(1.05)}.delete-button[data-v-17d61fd3]:active{transform:scale(.95)}.item-text[data-v-17d61fd3]{font-size:1.0625rem;font-weight:400;color:#1f2937;line-height:1.5;word-break:break-word;flex:1;transition:all .2s ease}.item-text.purchased[data-v-17d61fd3]{text-decoration:line-through;color:#6b7280;opacity:.7}@media (max-width: 200px){.shopping-item[data-v-17d61fd3]{padding:1rem .5rem}.item-checkbox[data-v-17d61fd3]{width:28px;height:28px;min-width:28px;min-height:28px}.item-checkbox[data-v-17d61fd3]:checked:after{font-size:16px}.item-text[data-v-17d61fd3]{font-size:1rem;font-weight:600}.item-content[data-v-17d61fd3]{min-height:50px;gap:.75rem}.user-avatars[data-v-17d61fd3]{gap:.25rem;margin-right:.25rem}.user-avatar[data-v-17d61fd3]{width:20px;height:20px}.avatar-placeholder[data-v-17d61fd3]{font-size:.6rem}.purchaser-indicator[data-v-17d61fd3]{width:10px;height:10px;font-size:7px;bottom:-1px;right:-1px}.delete-button[data-v-17d61fd3]{width:32px;height:32px}.delete-button svg[data-v-17d61fd3]{width:16px;height:16px}}@media (prefers-color-scheme: dark){.shopping-item[data-v-17d61fd3]{background:#1f2937;border-bottom-color:#374151}.shopping-item[data-v-17d61fd3]:nth-child(2n){background-color:#111827}.shopping-item[data-v-17d61fd3]:hover{background-color:#374151!important}.shopping-item[data-v-17d61fd3]:active{background-color:#4b5563!important}.item-checkbox[data-v-17d61fd3]{border-color:#6b7280;background:#374151}.item-checkbox[data-v-17d61fd3]:checked{background:#007aff;border-color:#007aff}.item-text[data-v-17d61fd3]{color:#f9fafb}.item-text.purchased[data-v-17d61fd3]{color:#9ca3af}.delete-button[data-v-17d61fd3]{color:#6b7280}.avatar-img[data-v-17d61fd3],.avatar-placeholder[data-v-17d61fd3]{border-color:#4b5563}.purchaser-indicator[data-v-17d61fd3]{background:#10b981;border-color:#1f2937}.delete-button[data-v-17d61fd3]:hover{background-color:#7f1d1d;color:#f87171}}.list-selector[data-v-c015d605]{position:relative;margin-bottom:1rem}.list-title[data-v-c015d605]{display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;padding:.75rem 1rem;border-radius:12px;transition:all .3s ease;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.list-title[data-v-c015d605]:hover{background-color:#ffffff26;transform:scale(1.02)}.list-title h1[data-v-c015d605]{margin:0;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.dropdown-icon[data-v-c015d605]{font-size:1rem;color:#ffffffe6;transition:transform .3s ease}.list-title.open .dropdown-icon[data-v-c015d605]{transform:rotate(180deg)}@media (prefers-color-scheme: light){.list-title[data-v-c015d605]{background:#0000000d;border:1px solid rgba(0,0,0,.06)}.list-title[data-v-c015d605]:hover{background:#00000014}.dropdown-icon[data-v-c015d605]{color:#4b5563}}.dropdown-overlay[data-v-c015d605]{position:fixed;inset:0;z-index:999}.dropdown-menu[data-v-c015d605]{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:250px;background:#fff;border:none;border-radius:16px;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;z-index:1000;max-height:320px;overflow-y:auto;animation:dropdownSlide-c015d605 .3s ease-out}@media (max-width: 768px){.dropdown-menu[data-v-c015d605]{position:fixed;left:12px;right:12px;top:clamp(56px,10vh,80px);transform:none;min-width:0;max-height:min(60vh,420px);border-radius:14px;overflow-y:auto}.dropdown-overlay[data-v-c015d605]{z-index:999}}@keyframes dropdownSlide-c015d605{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dropdown-item[data-v-c015d605]{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;color:#1a1a1a;font-size:.95rem;transition:all .2s ease;position:relative}.dropdown-item[data-v-c015d605]:first-child{border-radius:16px 16px 0 0}.dropdown-item[data-v-c015d605]:last-child{border-radius:0 0 16px 16px}.dropdown-item[data-v-c015d605]:hover{background-color:#f3f4f6;padding-left:1.5rem}.dropdown-item.selected[data-v-c015d605]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.dropdown-item.selected[data-v-c015d605]:hover{opacity:.9}.dropdown-item.create-new[data-v-c015d605]{color:#667eea;font-weight:600;border-top:1px solid #e5e7eb;margin-top:.5rem;padding-top:1.25rem}.dropdown-item.create-new[data-v-c015d605]:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#5a67d8}.list-name[data-v-c015d605]{flex:1}.privacy-indicator[data-v-c015d605]{margin-left:.5rem;font-size:.8rem}.dropdown-separator[data-v-c015d605]{height:1px;background-color:#eee;margin:.25rem 0}.modal-overlay[data-v-c015d605]{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn-c015d605 .2s ease-out}@keyframes fadeIn-c015d605{0%{opacity:0}to{opacity:1}}.modal-content[data-v-c015d605]{background:#fff;border-radius:20px;padding:2.5rem;width:90%;max-width:450px;box-shadow:0 20px 60px #00000026;animation:modalSlideUp-c015d605 .3s ease-out}@keyframes modalSlideUp-c015d605{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h2[data-v-c015d605]{margin:0 0 2rem;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.form-group[data-v-c015d605]{margin-bottom:1rem}.form-group label[data-v-c015d605]{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input[data-v-c015d605],.form-group textarea[data-v-c015d605]{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;box-sizing:border-box;transition:all .3s ease;background:#f9fafb}.form-group input[data-v-c015d605]:focus,.form-group textarea[data-v-c015d605]:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group textarea[data-v-c015d605]{resize:vertical;min-height:80px}.checkbox-group[data-v-c015d605]{margin:1.5rem 0}.checkbox-label[data-v-c015d605]{display:flex;align-items:center;cursor:pointer}.checkbox-label input[data-v-c015d605]{margin-right:.5rem;width:auto}.checkbox-text[data-v-c015d605]{font-size:.9rem}.form-actions[data-v-c015d605]{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-cancel[data-v-c015d605],.btn-create[data-v-c015d605]{padding:.875rem 2rem;border:none;border-radius:10px;font-size:.95rem;cursor:pointer;font-weight:600;transition:all .3s ease}.btn-cancel[data-v-c015d605]{background:#f3f4f6;color:#6b7280}.btn-cancel[data-v-c015d605]:hover{background:#e5e7eb;transform:translateY(-2px)}.btn-create[data-v-c015d605]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-create[data-v-c015d605]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-create[data-v-c015d605]:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;box-shadow:none}@media (max-width: 480px){.modal-content[data-v-c015d605]{width:95%;padding:1.5rem}.list-title h1[data-v-c015d605]{font-size:1.3rem}}.app-container[data-v-515fe6a2]{min-height:100vh;background:#f8fafc;padding:1rem 1rem 5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.auth-loading[data-v-515fe6a2]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:0}.auth-loading-content[data-v-515fe6a2]{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.auth-loading-spinner[data-v-515fe6a2]{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #007AFF;border-radius:50%;animation:spin-515fe6a2 1s linear infinite}@keyframes spin-515fe6a2{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-loading-text[data-v-515fe6a2]{font-size:.9rem;color:#6b7280;font-weight:500;margin:0}.main-app[data-v-515fe6a2]{min-height:100vh;display:flex;flex-direction:column;padding:0}.app-header[data-v-515fe6a2]{text-align:center;margin-bottom:2rem;padding:1rem 0;background:none;color:inherit;position:static;box-shadow:none}.header-content[data-v-515fe6a2]{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;position:relative}.user-menu[data-v-515fe6a2]{position:relative;display:flex;align-items:center;flex-shrink:0}.user-avatar-button[data-v-515fe6a2]{width:36px;height:36px;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;background:transparent;padding:0}.user-avatar-button[data-v-515fe6a2]:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.user-avatar-img[data-v-515fe6a2]{width:100%;height:100%;object-fit:cover;border-radius:50%;border:2px solid rgba(255,255,255,.2)}.user-avatar-placeholder[data-v-515fe6a2]{width:100%;height:100%;border-radius:50%;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;border:2px solid rgba(255,255,255,.2)}.user-dropdown[data-v-515fe6a2]{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 8px 24px #0000001f;border:1px solid rgba(0,0,0,.08);min-width:200px;z-index:1000;animation:dropdownSlide-515fe6a2 .2s ease-out}@keyframes dropdownSlide-515fe6a2{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header[data-v-515fe6a2]{padding:12px 16px}.user-dropdown-name[data-v-515fe6a2]{font-weight:600;font-size:.9rem;color:#1a1a1a;margin-bottom:2px}.user-dropdown-email[data-v-515fe6a2]{font-size:.8rem;color:#6b7280}.user-dropdown-divider[data-v-515fe6a2]{height:1px;background:#e5e7eb;margin:4px 0}.user-dropdown-item[data-v-515fe6a2]{width:100%;display:flex;align-items:center;gap:8px;padding:10px 16px;background:none;border:none;cursor:pointer;font-size:.9rem;transition:background-color .2s ease;text-align:left}.user-dropdown-item[data-v-515fe6a2]:hover{background:#f9fafb}.logout-item[data-v-515fe6a2]{color:#ef4444;border-radius:0 0 8px 8px}.logout-item[data-v-515fe6a2]:hover{background:#fef2f2;color:#dc2626}.app-title[data-v-515fe6a2]{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem;letter-spacing:-.025em;display:flex;align-items:center;gap:.5rem}.shopping-cart-icon[data-v-515fe6a2]{color:#007aff;width:1.3rem;height:1.3rem;display:inline-block;vertical-align:middle}.sync-indicator[data-v-515fe6a2]{display:flex;align-items:center;justify-content:center;gap:.5rem;opacity:.7;font-size:.875rem}.sync-dot[data-v-515fe6a2]{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse-515fe6a2 2s infinite}.sync-text[data-v-515fe6a2]{color:#6b7280;font-weight:500}@keyframes pulse-515fe6a2{0%,to{opacity:1}50%{opacity:.5}}.notification[data-v-515fe6a2]{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:1000;background:#10b981;color:#fff;padding:.75rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #10b98166;animation:slideDown-515fe6a2 .3s ease-out;max-width:90vw;text-align:center}.notification-text[data-v-515fe6a2]{font-weight:500;font-size:.9rem;line-height:1.2}@keyframes slideDown-515fe6a2{0%{opacity:0;transform:translate(-50%) translateY(-100%)}to{opacity:1;transform:translate(-50%) translateY(0)}}.app-main[data-v-515fe6a2]{width:100%;margin:0;flex:1;padding:0}.bottom-nav[data-v-515fe6a2]{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;padding:.5rem;z-index:100;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.nav-button[data-v-515fe6a2]{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;border:none;background:transparent;color:#9ca3af;cursor:pointer;transition:all .2s ease;border-radius:8px;font-size:.75rem;font-weight:500;min-height:60px}.nav-button[data-v-515fe6a2]:hover{background:#f9fafb;color:#6b7280}.nav-button.active[data-v-515fe6a2]{color:#007aff}.nav-button.active[data-v-515fe6a2]:hover{background:#007aff0d}.nav-icon[data-v-515fe6a2]{position:relative;display:flex;align-items:center;justify-content:center}.nav-badge[data-v-515fe6a2]{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:600;padding:.125rem .25rem;border-radius:10px;min-width:16px;text-align:center;line-height:1}.nav-label[data-v-515fe6a2]{margin-top:.125rem;text-transform:none;letter-spacing:0}.tab-content[data-v-515fe6a2]{width:100%;max-width:none;margin:0;padding:0}.add-item-form[data-v-515fe6a2]{margin-bottom:1.5rem;width:100%;max-width:100%;box-sizing:border-box}.input-group[data-v-515fe6a2]{display:flex;align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;transition:all .2s ease;padding-right:.5rem;gap:.5rem;width:100%;max-width:100%;box-sizing:border-box}.input-group[data-v-515fe6a2]:focus-within{border-color:#007aff;box-shadow:0 4px 12px #007aff26}.item-input[data-v-515fe6a2]{flex:1;border:none;outline:none;font-size:1.125rem;padding:1rem 1.25rem;background:transparent;color:#1a1a1a;border-radius:12px 0 0 12px;min-width:0;width:auto}.add-button[data-v-515fe6a2]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:#007aff;color:#fff;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.add-button[data-v-515fe6a2]:hover:not(:disabled){background:#0056cc;transform:scale(1.05)}.add-button[data-v-515fe6a2]:active{transform:scale(.98)}.add-button[data-v-515fe6a2]:disabled{opacity:.4;cursor:not-allowed;transform:none}.add-button svg[data-v-515fe6a2]{transition:transform .2s ease}.add-button:hover:not(:disabled) svg[data-v-515fe6a2]{transform:scale(1.1)}.voice-button[data-v-515fe6a2]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:#f3f4f6;color:#6b7280;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.voice-button[data-v-515fe6a2]:hover:not(:disabled){background:#e5e7eb;color:#374151;transform:scale(1.05)}.voice-button.listening[data-v-515fe6a2]{background:#ef4444;color:#fff;animation:microphonePulse-515fe6a2 1.2s ease-in-out infinite;box-shadow:0 0 0 4px #ef44444d}.voice-button.listening[data-v-515fe6a2]:hover:not(:disabled){background:#dc2626;animation:microphonePulse-515fe6a2 1.2s ease-in-out infinite;box-shadow:0 0 0 4px #dc262666}@keyframes microphonePulse-515fe6a2{0%,to{background:#ef4444;transform:scale(1);box-shadow:0 0 0 4px #ef44444d}50%{background:#dc2626;transform:scale(1.05);box-shadow:0 0 0 6px #ef444480}}.voice-button[data-v-515fe6a2]:active{transform:scale(.98)}.voice-button[data-v-515fe6a2]:disabled{opacity:.4;cursor:not-allowed;transform:none}.voice-button svg[data-v-515fe6a2]{transition:transform .2s ease}.voice-button:hover:not(:disabled) svg[data-v-515fe6a2]{transform:scale(1.1)}.item-input[data-v-515fe6a2]::placeholder{color:#9ca3af}.item-input[data-v-515fe6a2]:disabled{opacity:.6;cursor:not-allowed}.section-container[data-v-515fe6a2]{width:100%;margin-bottom:2rem}.section-title[data-v-515fe6a2]{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0 0 1rem;padding:.75rem 1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;border-left:4px solid #007AFF}.items-list[data-v-515fe6a2]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;overflow:hidden;width:100%;margin:0}.mark-all-section[data-v-515fe6a2]{margin-top:1.5rem;display:flex;justify-content:center;width:100%}.mark-all-button[data-v-515fe6a2]{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#007aff;color:#fff;border:none;border-radius:12px;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #007aff33;min-height:48px}.mark-all-button[data-v-515fe6a2]:hover:not(:disabled){background:#0056cc;transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.mark-all-button[data-v-515fe6a2]:active{transform:translateY(0);box-shadow:0 2px 6px #007aff33}.mark-all-button[data-v-515fe6a2]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #007aff1a}.mark-all-button svg[data-v-515fe6a2]{transition:transform .2s ease;flex-shrink:0}.mark-all-button:hover:not(:disabled) svg[data-v-515fe6a2]{transform:scale(1.1)}.completed-groups[data-v-515fe6a2]{display:flex;flex-direction:column;gap:2rem;width:100%;margin:0;padding:0}.completed-group[data-v-515fe6a2]{width:100%;margin:0}.group-title[data-v-515fe6a2]{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 1rem;padding:0 .5rem}.completed-item[data-v-515fe6a2]{position:relative;border-bottom:1px solid #e5e7eb;margin-bottom:0}.completed-item[data-v-515fe6a2]:last-child{border-bottom:none}.completed-item .shopping-item[data-v-515fe6a2]{border-bottom:none}.item-modified-date[data-v-515fe6a2]{font-size:.8rem;color:#9ca3af;padding:.25rem 1.25rem .75rem 3.5rem;font-weight:500;opacity:.8;margin-top:-.5rem}.loading-message[data-v-515fe6a2],.error-message[data-v-515fe6a2],.empty-message[data-v-515fe6a2]{text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;font-size:1.0625rem;font-weight:400;color:#6b7280}.loading-message[data-v-515fe6a2]{color:#0284c7;border-color:#bae6fd}.error-message[data-v-515fe6a2]{color:#dc2626;border-color:#fecaca}.empty-message[data-v-515fe6a2]{color:#6b7280}@media (max-width: 480px){.app-container[data-v-515fe6a2]{padding:.75rem .75rem 5rem}.add-item-form[data-v-515fe6a2]{margin-bottom:1.25rem}.input-group[data-v-515fe6a2]{gap:.375rem;padding-right:.375rem}.item-input[data-v-515fe6a2]{font-size:.95rem;padding:.75rem .875rem}.voice-button[data-v-515fe6a2],.add-button[data-v-515fe6a2]{width:38px;height:38px}.voice-button svg[data-v-515fe6a2]{width:16px;height:16px}.add-button svg[data-v-515fe6a2]{width:17px;height:17px}}@media (max-width: 768px){.app-main[data-v-515fe6a2]{padding:1rem}.header-content[data-v-515fe6a2]{flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem}.app-title[data-v-515fe6a2]{flex:1;text-align:left}.user-menu[data-v-515fe6a2]{position:absolute;top:0;right:0}.user-dropdown[data-v-515fe6a2]{min-width:180px;right:-8px}.add-item-form[data-v-515fe6a2]{margin-bottom:1.5rem;width:100%;box-sizing:border-box}.input-group[data-v-515fe6a2]{padding-right:.5rem;gap:.5rem;min-width:0;overflow:hidden}.item-input[data-v-515fe6a2]{font-size:1rem;padding:.875rem 1rem;min-width:0;flex-shrink:1}.voice-button[data-v-515fe6a2],.add-button[data-v-515fe6a2]{width:40px;height:40px;flex-shrink:0}}@media (max-width: 200px){.app-container[data-v-515fe6a2]{padding:.5rem .5rem 4rem}.app-title[data-v-515fe6a2]{font-size:1.25rem}.sync-indicator[data-v-515fe6a2]{font-size:.75rem;gap:.25rem}.sync-dot[data-v-515fe6a2]{width:6px;height:6px}.notification[data-v-515fe6a2]{top:.5rem;padding:.5rem 1rem;max-width:95vw}.notification-text[data-v-515fe6a2]{font-size:.8rem}.bottom-nav[data-v-515fe6a2]{padding:.25rem}.nav-button[data-v-515fe6a2]{padding:.5rem .25rem;font-size:.65rem;min-height:54px;gap:.125rem}.nav-icon svg[data-v-515fe6a2]{width:20px;height:20px}.nav-badge[data-v-515fe6a2]{font-size:.55rem;padding:.0625rem .1875rem;min-width:14px;top:-4px;right:-4px}.completed-groups[data-v-515fe6a2]{gap:1.5rem}.group-title[data-v-515fe6a2]{font-size:1rem;margin-bottom:.75rem;padding:0 .25rem}.item-modified-date[data-v-515fe6a2]{font-size:.7rem;padding:.125rem 1rem .5rem 3rem;margin-top:-.25rem}.add-item-form[data-v-515fe6a2]{margin-bottom:1rem}.input-group[data-v-515fe6a2]{padding-right:.375rem;gap:.25rem;min-width:0;overflow:hidden}.item-input[data-v-515fe6a2]{font-size:.95rem;padding:.65rem .8rem;min-width:0;flex-shrink:1}.voice-button[data-v-515fe6a2]{width:34px;height:34px;flex-shrink:0}.voice-button svg[data-v-515fe6a2]{width:15px;height:15px}.add-button[data-v-515fe6a2]{width:34px;height:34px;flex-shrink:0}.add-button svg[data-v-515fe6a2]{width:16px;height:16px}.user-avatar-button[data-v-515fe6a2]{width:30px;height:30px}.user-dropdown[data-v-515fe6a2]{min-width:160px;right:-4px}.section-container[data-v-515fe6a2]{margin-bottom:1.5rem}.section-title[data-v-515fe6a2]{font-size:1.125rem;padding:.5rem .75rem;margin-bottom:.75rem}.loading-message[data-v-515fe6a2],.error-message[data-v-515fe6a2],.empty-message[data-v-515fe6a2]{padding:1.5rem .75rem;font-size:1rem}.mark-all-section[data-v-515fe6a2]{margin-top:1rem}.mark-all-button[data-v-515fe6a2]{padding:.75rem 1.25rem;font-size:.9rem;min-height:44px}.mark-all-button svg[data-v-515fe6a2]{width:18px;height:18px}}@media (prefers-color-scheme: dark){.app-container[data-v-515fe6a2],.auth-loading[data-v-515fe6a2]{background:#1a1a1a}.auth-loading-spinner[data-v-515fe6a2]{border-color:#374151;border-top-color:#007aff}.auth-loading-text[data-v-515fe6a2]{color:#9ca3af}.app-title[data-v-515fe6a2]{color:#fff}.user-dropdown[data-v-515fe6a2]{background:#1f2937;border-color:#374151;box-shadow:0 8px 24px #0006}.user-dropdown-name[data-v-515fe6a2]{color:#f9fafb}.user-dropdown-email[data-v-515fe6a2]{color:#9ca3af}.user-dropdown-divider[data-v-515fe6a2],.user-dropdown-item[data-v-515fe6a2]:hover{background:#374151}.logout-item[data-v-515fe6a2]:hover{background:#7f1d1d;color:#f87171}.input-group[data-v-515fe6a2]{background:#2a2a2a;box-shadow:0 2px 8px #0000004d;border-color:#374151}.input-group[data-v-515fe6a2]:focus-within{border-color:#007aff;box-shadow:0 4px 12px #007aff40}.item-input[data-v-515fe6a2]{color:#fff}.item-input[data-v-515fe6a2]::placeholder{color:#6b7280}.add-button[data-v-515fe6a2]:disabled{opacity:.3}.voice-button[data-v-515fe6a2]{background:#374151;color:#9ca3af}.voice-button[data-v-515fe6a2]:hover:not(:disabled){background:#4b5563;color:#d1d5db}.voice-button.listening[data-v-515fe6a2]{background:#ef4444;color:#fff;animation:microphonePulse-515fe6a2 1.2s ease-in-out infinite;box-shadow:0 0 0 4px #ef444466}.voice-button.listening[data-v-515fe6a2]:hover:not(:disabled){background:#dc2626;animation:microphonePulse-515fe6a2 1.2s ease-in-out infinite;box-shadow:0 0 0 4px #dc262680}.section-title[data-v-515fe6a2]{background:#2a2a2a;color:#fff;box-shadow:0 2px 4px #0000004d}.sync-text[data-v-515fe6a2]{color:#9ca3af}.bottom-nav[data-v-515fe6a2]{background:#1f2937;border-top:1px solid #374151}.nav-button[data-v-515fe6a2]{color:#6b7280}.nav-button[data-v-515fe6a2]:hover{background:#37415180;color:#9ca3af}.nav-button.active[data-v-515fe6a2]:hover{background:#007aff1a}.items-list[data-v-515fe6a2]{background:#1f2937;border-color:#374151;box-shadow:0 2px 8px #0000004d}.group-title[data-v-515fe6a2]{color:#d1d5db}.completed-item[data-v-515fe6a2]{border-bottom-color:#374151}.item-modified-date[data-v-515fe6a2]{color:#6b7280}.loading-message[data-v-515fe6a2],.error-message[data-v-515fe6a2],.empty-message[data-v-515fe6a2]{background:#1f2937;border-color:#374151;box-shadow:0 2px 8px #0000004d}.loading-message[data-v-515fe6a2]{color:#60a5fa;border-color:#1e3a8a}.error-message[data-v-515fe6a2]{color:#f87171;border-color:#7f1d1d}.empty-message[data-v-515fe6a2]{color:#9ca3af}.mark-all-button[data-v-515fe6a2]{background:#007aff;box-shadow:0 2px 8px #007aff4d}.mark-all-button[data-v-515fe6a2]:hover:not(:disabled){background:#0056cc;box-shadow:0 4px 12px #007aff66}.mark-all-button[data-v-515fe6a2]:disabled{opacity:.4;box-shadow:0 2px 8px #007aff26}}
