*{box-sizing:border-box;margin:0;padding:0}html{scroll-padding-top:calc(var(--header-height, 72px) + 48px)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}input,select,textarea{font-size:16px}:root{--font-size-xs: .8125rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.125rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--touch-target-min: 44px;--touch-target-comfortable: 48px;--container-max-width: 800px;--border-radius-sm: .25rem;--border-radius-md: .375rem;--border-radius-lg: .5rem;--header-height: 76px;--color-primary: #2563eb;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-500: #6b7280}@media(max-width:375px){:root{--header-height: 60px}}@media(min-width:640px){:root{--font-size-md: 1.125rem;--font-size-lg: 1.375rem;--font-size-xl: 1.75rem;--header-height: 84px}}@media(min-width:768px){:root{--font-size-lg: 1.5rem;--font-size-xl: 2rem;--touch-target-min: 36px}}.app{width:100%;max-width:800px;margin:0 auto;min-height:100vh;min-height:100dvh;background:#fff;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 0 60px #00000014}.header{background:linear-gradient(90deg,#7c3aed,#8b5cf6,#a855f7,#c026d3,#ec4899,#c026d3 75%,#a855f7 85%,#7c3aed);background-size:200% 100%;animation:header-gradient-flow 8s linear infinite;color:#fff;padding:var(--space-md);position:sticky;top:0;z-index:100;box-shadow:0 4px 20px #7c3aed59;height:var(--header-height);box-sizing:border-box;display:flex;align-items:center;flex-shrink:0}@keyframes header-gradient-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}.header-content{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-md)}@media(max-width:375px){.header{padding:var(--space-xs) var(--space-sm)}.header-content{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-xs)}.header-title{flex:0 1 auto;min-width:0}.header h1{font-size:.9375rem;white-space:nowrap}.header-subtitle{font-size:.625rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.header-actions{flex:0 0 auto;gap:var(--space-xs);flex-wrap:nowrap}.header-actions>.btn-secondary{display:none}.btn-compact{padding:.25rem .5rem;font-size:.75rem}.btn-mode .btn-mode-text{display:none}.btn-mode{padding:.5rem .75rem;font-size:1.125rem;min-width:44px;min-height:36px}.sync-indicator{font-size:1rem;padding:.375rem .5rem;flex-shrink:0;min-width:32px;min-height:32px;background:#ffffff26;display:inline-flex;align-items:center;justify-content:center}.sync-text-full{display:none!important}.sync-text-compact{display:inline!important}.header-sync{gap:.375rem}.user-menu-trigger{width:28px;height:28px;font-size:.875rem}.store-selector{padding:var(--space-xs) var(--space-sm)}.store-selector-label{display:none}.store-selector-row{gap:var(--space-xs)}.store-selector-dropdown{min-width:120px}.btn-templates{padding:.375rem .5rem;font-size:.75rem}}@media(min-width:768px){.header{padding:var(--space-lg)}.header-content{flex-direction:row;justify-content:space-between;align-items:center;gap:0}.item-edit-save,.item-edit-cancel,.item-edit-trigger,.btn-sm{min-height:auto}.item-stepper-btn{min-height:32px}.form-group input,.form-group select,.form-group textarea{min-height:auto}}.header-actions{display:flex;align-items:center;gap:1rem}.header-sync{display:flex;align-items:center;gap:.5rem}.header-title{display:flex;align-items:center;gap:.625rem}.header-title svg{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.header-title h1{font-size:var(--font-size-lg);font-weight:700;margin:0;letter-spacing:-.02em}.header-subtitle{font-size:.875rem;opacity:.9;margin-top:.125rem}.btn-compact{padding:.5rem .75rem;font-size:.875rem}.btn-large{padding:1rem 1.5rem;font-size:1rem;font-weight:600}.sync-indicator{font-size:.875rem;opacity:.9;padding:.375rem .75rem;border-radius:var(--border-radius-md);transition:all .2s;display:inline-flex;align-items:center;gap:.375rem;font-weight:500}.sync-text-compact{display:none}.btn-mode-text{display:inline}.sync-indicator.offline{background:#eab3084d;color:#fef3c7}.sync-indicator.pending{background:#3b82f64d;color:#dbeafe}.sync-indicator.syncing{background:#10b9814d;color:#d1fae5}.sync-indicator:hover{background:#ffffff26;opacity:1}.sync-spinner{display:inline-block;animation:spin 1s linear infinite}.user-menu-container{position:relative}.user-menu-trigger{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.user-menu-trigger:hover{background:#ffffff40}.user-menu-backdrop{position:fixed;inset:0;z-index:1000}.user-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border-radius:1rem;box-shadow:0 20px 40px #0003,0 0 0 1px #0000000d;min-width:220px;z-index:1001;overflow:hidden;animation:user-menu-slide-in .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes user-menu-slide-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#f8fafc,#eef2ff)}.user-menu-name{font-size:.875rem;font-weight:600;color:#111827;margin-bottom:.25rem;word-break:break-word}.user-menu-household{font-size:var(--font-size-sm);color:#6b7280}.user-menu-item{width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;font-size:.9375rem;color:#374151;cursor:pointer;transition:background .15s;display:block}.user-menu-item:hover{background:#f3f4f6}.user-menu-item-danger{color:#dc2626;border-top:1px solid #e5e7eb}.user-menu-item-danger:hover{background:#fef2f2}.user-menu-version{padding:.5rem 1rem;font-size:.7rem;color:#9ca3af;text-align:center;border-top:1px solid #e5e7eb}.version-mismatch{color:#f59e0b;font-weight:500;margin-top:.25rem}.store-selector{background:#fff;border-bottom:1px solid #e5e7eb;padding:.5rem 1rem;position:sticky;top:0;z-index:90}.store-selector select{padding:.375rem .5rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff}.store-selector-row{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.store-selector-dropdown{flex:1;min-width:0}.store-selector-label{font-size:var(--font-size-sm);font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.btn-templates{font-size:.8125rem;padding:.375rem .625rem;flex-shrink:0}.items-section{padding:var(--space-lg)}.items-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.items-header .section-title{margin-bottom:0}.items-sort{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:#6b7280}.items-sort select{padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:var(--font-size-sm);background:#fff}.section-title{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.item-list{list-style:none}.item{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;margin-bottom:var(--space-md);display:flex;align-items:center;gap:1rem;transition:all .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:0 1px 3px #0000000a}.item:hover{background:#fafaff;border-color:#a5b4fc;box-shadow:0 4px 12px #667eea1f;transform:translateY(-1px)}.item:active{transform:scale(.98) translateY(0);background:#eef2ff}.item.purchased{opacity:.7;background:#f9fafb}.item.purchased .item-name{color:#6b7280}.item-checkbox{width:44px;height:44px;min-width:44px;min-height:44px;cursor:pointer;accent-color:#2563eb}.item-content{flex:1;min-width:0}.item-name-row{display:flex;align-items:center;gap:.5rem}.item-name{font-weight:500;font-size:var(--font-size-md)}.item-has-notes{font-size:.75rem;opacity:.7}.item-compact-details{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#6b7280;margin-top:.125rem}.item-qty{color:#374151}.item-price{color:#059669;font-weight:500}.item-details{display:flex;flex-wrap:wrap;gap:.375rem;font-size:.8125rem;color:#6b7280}.item-main{display:flex;align-items:center;gap:1rem;width:100%}.item-qty-badge{background:#dbeafe;color:#1e40af;padding:.125rem .5rem;border-radius:var(--border-radius-sm);font-weight:500}.item-category-badge{background:#f3f4f6;color:#4b5563;padding:.125rem .5rem;border-radius:var(--border-radius-sm)}.item-price-badge{background:#dcfce7;color:#166534;padding:.125rem .5rem;border-radius:var(--border-radius-sm);font-weight:500}.item-store-badge{color:#9ca3af}.item-delete-btn{background:none;border:none;color:#9ca3af;font-size:1.25rem;padding:.5rem;cursor:pointer;border-radius:var(--border-radius-sm);transition:all .15s;flex-shrink:0;font-family:Arial,Helvetica,sans-serif;line-height:1}.item-delete-btn:hover{background:#fee2e2;color:#dc2626}.item-expanded{flex-direction:column;align-items:stretch}.item-expanded-content{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;width:100%}.item-details-grid{display:flex;flex-direction:column;gap:.5rem}.item-detail-row{display:flex;justify-content:space-between;align-items:flex-start;font-size:.875rem}.item-detail-label{color:#6b7280;flex-shrink:0;margin-right:1rem}.item-detail-value{color:#111827;text-align:right;word-break:break-word}.item-notes-row .item-detail-value{text-align:left;flex:1}.item-attribution{font-size:.75rem;color:#6b7280;margin-top:.75rem;padding-top:.5rem;border-top:1px solid #f3f4f6}.purchased-by{display:block;font-size:.75rem;color:#6b7280;margin-top:.125rem}.items-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.section-count{background:#e5e7eb;color:#374151;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:9999px}.item-notes{font-size:var(--font-size-sm);color:#6b7280;margin-bottom:.75rem}.item-notes-label{font-weight:500;color:#374151}.item-actions{display:flex;gap:.5rem}.btn-sm{padding:.375rem .75rem;font-size:var(--font-size-sm)}.btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fecaca}.item-meta{margin-top:.25rem;font-size:var(--font-size-sm);color:#6b7280;line-height:1.3}.item-edit{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.item-stepper{display:inline-flex;align-items:center;border:1px solid #d1d5db;border-radius:9999px;overflow:hidden;background:#f9fafb}.item-edit .item-stepper input{width:3.25rem;text-align:center;border:none;background:transparent;padding:.25rem .4rem}.item-stepper input:focus{outline:none}.item-stepper-btn{border:none;background:#eef2ff;color:#1e40af;padding:.25rem .6rem;font-size:1rem;cursor:pointer;min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center}.item-stepper-btn:active{background:#dbeafe}.item-edit input,.item-edit select{padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.item-edit select{min-width:90px}.item-edit-trigger{background:none;border:none;color:#2563eb;font-size:var(--font-size-sm);cursor:pointer;margin-right:.5rem;min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center}.item-edit-trigger:hover{text-decoration:underline}.item-edit-save,.item-edit-cancel{border:none;border-radius:.375rem;padding:.25rem .5rem;font-size:var(--font-size-sm);cursor:pointer;min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center}.item-edit-save{background:#2563eb;color:#fff}.item-edit-cancel{background:#e5e7eb;color:#374151}.item-saving-spinner{width:14px;height:14px;border:2px solid #d1d5db;border-top-color:#2563eb;border-radius:50%;display:inline-block;animation:spin .8s linear infinite}.item-history{font-size:var(--font-size-sm);color:#9ca3af;margin-top:.25rem;font-style:italic}.item-badge{display:inline-block;padding:.125rem .5rem;background:#dbeafe;color:#1e40af;border-radius:9999px;font-size:var(--font-size-sm);margin-right:.5rem}.empty-state-enhanced{text-align:center;padding:4rem 2rem;max-width:400px;margin:0 auto}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:#111827;margin-bottom:.75rem}.empty-state-description{font-size:var(--font-size-base);color:#6b7280;line-height:1.6;margin-bottom:2rem}.empty-state-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center}.empty-state-actions .btn{min-width:200px}.settings-layout{display:flex;flex-direction:column;padding:0;min-height:calc(100vh - 120px)}.settings-tabs-container{background:#fffffffa;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:50;overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:0 2px 8px #0000000d}.app .settings-tabs-container{top:var(--header-height)}.settings-tabs{display:flex;gap:0;padding:0 var(--space-md);min-width:min-content}.settings-tab{text-decoration:none;color:#6b7280;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;border-bottom:3px solid transparent;transition:all .2s;position:relative}.settings-tab:hover{color:#7c3aed;background:linear-gradient(to bottom,transparent,rgba(124,58,237,.05))}.settings-tab.active{color:#7c3aed;border-bottom-color:transparent;background:linear-gradient(to bottom,transparent,rgba(124,58,237,.08))}.settings-tab.active:after{content:"";position:absolute;bottom:-1px;left:var(--space-lg);right:var(--space-lg);height:3px;background:linear-gradient(90deg,#7c3aed,#a855f7,#ec4899);border-radius:3px 3px 0 0}.settings-content{min-height:60vh;padding:var(--space-lg);scroll-margin-top:calc(var(--header-height) + 48px)}@media(min-width:640px){.settings-tabs{padding:0 var(--space-xl)}.settings-tab{font-size:var(--font-size-base);padding:var(--space-lg) var(--space-xl)}}.settings-users{padding:1rem}.settings-users-header h2{font-size:1.5rem;font-weight:600;color:#111827}.settings-list{display:flex;flex-direction:column;gap:.75rem}.settings-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000a;transition:all .2s ease}.settings-card:hover{border-color:#c7d2fe;box-shadow:0 4px 12px #667eea14}.settings-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.settings-card-title{font-weight:600;color:#111827}.settings-card-meta{font-size:.875rem;color:#6b7280}.btn-sm{flex:0 0 auto;padding:.4rem .6rem;font-size:var(--font-size-sm);min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center}.form-help{display:block;margin-top:var(--space-sm);font-size:.8125rem;color:#6b7280}.product-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.product-toolbar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.product-search{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.9375rem}.product-filter{min-width:160px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.9375rem;background:#fff}.product-list{display:flex;flex-direction:column;gap:.5rem}.product-row{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;text-align:left;box-shadow:0 1px 3px #0000000a;transition:all .2s ease}.product-row:hover{border-color:#c7d2fe;box-shadow:0 4px 12px #667eea14}.product-thumb{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280;font-weight:600;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.product-body{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.product-name{font-size:.95rem;font-weight:600;color:#111827}.product-meta-line{font-size:var(--font-size-sm);color:#6b7280;min-width:0;line-height:1.2;word-break:break-word}.product-right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex:0 0 auto}.product-price{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.price-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;color:#9ca3af}.price-value{font-size:.9rem;font-weight:600;color:#111827}.product-status{background:#eff6ff;color:#1e40af;border-radius:9999px;border:1px solid #bfdbfe;padding:.125rem .5rem;font-size:var(--font-size-sm)}.product-amount{font-size:.8125rem;color:#374151}.product-actions{display:flex;flex-wrap:wrap;gap:.5rem;flex:0 0 auto;justify-content:flex-end}.product-actions .btn{flex:0 0 auto}@media(max-width:720px){.items-header{align-items:flex-start;flex-direction:column}.header-actions .btn{flex:0 0 auto}}@media(min-width:376px)and (max-width:720px){.header-actions{width:100%;flex-wrap:wrap;justify-content:space-between;gap:.5rem}.header-sync{text-align:left;width:100%}}.product-row{flex-direction:column;align-items:flex-start}.product-actions{width:auto;justify-content:flex-start;margin-left:auto}.product-right{width:100%;flex-direction:row;align-items:center;justify-content:space-between}.product-meta-line{line-height:1.3}} .product-edit{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem;border:1px dashed #e5e7eb;border-radius:.5rem;background:#f9fafb}.data-model .settings-section{background:#f9fafb}.model-intro{font-size:.9375rem;color:#4b5563;margin-top:.5rem}.model-section-note{font-size:.875rem;color:#6b7280;margin:-.25rem 0 .75rem}.model-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem}.model-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.model-card-title{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.model-card-title h4{font-size:1rem;font-weight:600;color:#111827;margin:0}.model-card-tag{font-size:var(--font-size-sm);color:#6b7280;background:#f3f4f6;padding:.125rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.04em}.model-card-desc{font-size:.8125rem;color:#6b7280;margin:0}.model-field-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;font-size:.8125rem;color:#374151}.model-field-name{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.model-field-meta{color:#6b7280;margin-left:.25rem}.model-relations{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.model-relations li{background:#fff;border:1px dashed #e5e7eb;border-radius:.375rem;padding:.5rem .75rem;font-size:.8125rem;color:#374151}.model-footnote{font-size:.8125rem;color:#6b7280;margin-top:.75rem}.home-empty{padding:2.5rem 1.5rem;text-align:center;color:#374151}.home-empty h2{font-size:1.25rem;margin-bottom:.5rem}.home-empty p{color:#6b7280;margin-bottom:1.5rem}.home-empty-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.fab{position:fixed;bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));right:1.5rem;width:64px;height:64px;background:linear-gradient(135deg,#7c3aed,#8b5cf6,#a855f7,#c026d3,#ec4899);background-size:200% 200%;animation:fab-gradient-spin 6s ease-in-out infinite;color:#fff;border:none;border-radius:50%;font-size:2rem;font-weight:300;cursor:pointer;box-shadow:0 8px 30px #8b5cf680,0 0 #ec489900;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;z-index:1000;-webkit-tap-highlight-color:transparent}@keyframes fab-gradient-spin{0%,to{background-position:0% 50%}25%{background-position:100% 50%}50%{background-position:100% 100%}75%{background-position:0% 100%}}.fab:hover{transform:scale(1.1) translateY(-3px);box-shadow:0 15px 40px #8b5cf68c,0 0 25px #ec489966;animation:fab-gradient-spin 2s ease-in-out infinite}.fab:active{transform:scale(.95);box-shadow:0 4px 15px #8b5cf666}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:modal-fade-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:1rem;width:100%;max-width:420px;padding:1.75rem;box-shadow:0 25px 50px #00000040,0 0 0 1px #0000000d;animation:modal-scale-in .3s cubic-bezier(.16,1,.3,1)}@keyframes modal-scale-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal h2{font-size:1.25rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:#374151}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-md);border:1px solid #d1d5db;border-radius:.5rem;font-size:var(--font-size-base);min-height:var(--touch-target-min);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.form-group textarea{resize:vertical;min-height:60px}.catalogue-selected{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.catalogue-selected-name{font-weight:600;color:#111827}.catalogue-selected-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8125rem;color:#6b7280}.catalogue-selected-actions{display:flex;gap:.5rem;flex-wrap:wrap}.form-row{display:flex;flex-direction:column;gap:var(--space-sm)}.form-row>*{flex:1}@media(min-width:640px){.form-row{flex-direction:row}}.modal-actions{display:flex;gap:.5rem;margin-top:1.5rem}.btn{flex:1;padding:.75rem 1rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:focus-visible{outline:2px solid #667eea;outline-offset:2px}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(90deg,#7c3aed,#8b5cf6,#a855f7,#c026d3,#ec4899,#7c3aed);background-size:200% 100%;animation:btn-gradient-flow 4s linear infinite;color:#fff;box-shadow:0 4px 14px #8b5cf666;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);background-size:200% 100%;animation:btn-shimmer 3s ease-in-out infinite;pointer-events:none}@keyframes btn-gradient-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes btn-shimmer{0%,to{background-position:-200% 50%}50%{background-position:200% 50%}}.btn-primary:hover:not(:disabled){box-shadow:0 8px 25px #8b5cf680;transform:translateY(-2px);animation:btn-gradient-flow 2s linear infinite}.btn-primary:active:not(:disabled){box-shadow:0 2px 8px #667eea59;transform:scale(.98) translateY(0)}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb;border-color:#d1d5db}.btn-secondary:active:not(:disabled){background:#d1d5db}.btn-danger{background:linear-gradient(135deg,#f87171,#dc2626);color:#fff;box-shadow:0 4px 14px #dc262640}.btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #dc262659;transform:translateY(-1px)}.btn-danger:active:not(:disabled){box-shadow:0 2px 8px #dc262640;transform:scale(.98) translateY(0)}.btn-loading{position:relative;color:transparent;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:spin .6s linear infinite;color:inherit}.btn-primary.btn-loading:after{border-color:#fff;border-top-color:transparent}.btn-secondary.btn-loading:after{border-color:#374151;border-top-color:transparent}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:#f8f9fa;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 100% 50% at 50% 100%,rgba(124,58,237,.1) 0%,transparent 50%),radial-gradient(ellipse 80% 40% at 30% 0%,rgba(0,212,255,.08) 0%,transparent 40%),radial-gradient(ellipse 60% 30% at 80% 20%,rgba(236,72,153,.06) 0%,transparent 40%);pointer-events:none;z-index:3}.auth-container:after{display:none}.stripe-wave{position:absolute;width:200%;height:60%;left:-50%;pointer-events:none}.stripe-wave-1{top:35%;background:linear-gradient(90deg,#00d4ff,#4f46e5 25%,#7c3aed,#a855f7,#ec4899,#f472b6,#00d4ff);background-size:200% 100%;transform:rotate(-12deg) skewY(-2deg);filter:blur(0px);animation:wave-flow 12s linear infinite;z-index:0}.stripe-wave-2{top:38%;background:linear-gradient(90deg,transparent 0%,rgba(79,70,229,.6) 20%,rgba(124,58,237,.8) 40%,rgba(168,85,247,.8) 60%,rgba(236,72,153,.6) 80%,transparent 100%);background-size:200% 100%;transform:rotate(-12deg) skewY(-1deg);filter:blur(30px);animation:wave-flow 15s linear infinite reverse;z-index:1}.stripe-wave-3{top:32%;height:70%;background:linear-gradient(90deg,transparent 0%,rgba(0,212,255,.3) 15%,rgba(124,58,237,.2) 35%,rgba(168,85,247,.3) 50%,rgba(236,72,153,.2) 65%,rgba(244,114,182,.3) 85%,transparent 100%);background-size:200% 100%;transform:rotate(-12deg) skewY(-3deg);filter:blur(60px);animation:wave-flow 18s linear infinite;z-index:2}@keyframes wave-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}.auth-card{position:relative;z-index:1;width:100%;max-width:420px;background:#fffffffa;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:1.5rem;padding:2.5rem;box-shadow:0 25px 60px -12px #7c3aed33,0 12px 30px -8px #0000001a,0 0 0 1px #fffc}.auth-card--login{display:flex;flex-direction:column;gap:1.75rem}.auth-header{text-align:center}.auth-header .logo{margin:0 auto .5rem}.auth-title{margin:.75rem 0 0;color:#1f2937;font-size:2.25rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,#7c3aed,#a855f7 40%,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-tagline{margin-top:.25rem;color:#6b7280;font-size:1.125rem;font-weight:500}.auth-subtitle{margin-top:.75rem;color:#9ca3af;font-size:.9375rem;line-height:1.5}.auth-callout{border:1px solid #a5b4fc;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#3730a3;padding:1rem 1.25rem;border-radius:.75rem;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.auth-callout:before{content:"✨"}.auth-body{display:flex;flex-direction:column;gap:1.25rem}.auth-alert{border:1px solid #fcd34d;background:#fffbeb;color:#92400e;border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem}.auth-alert-title{font-weight:600;margin-bottom:.25rem}.auth-alert-body code{background:#ffffffb3;border-radius:.25rem;padding:.125rem .35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.auth-provider{display:flex;flex-direction:column;align-items:center;gap:.75rem}.auth-provider-label{font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em}.auth-provider-button{min-height:48px;display:flex;align-items:center;justify-content:center;width:100%;max-width:320px;margin:0 auto;border-radius:.5rem;transition:transform .2s ease,box-shadow .2s ease}.auth-provider-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.auth-helper{font-size:.8125rem;color:#9ca3af;display:flex;align-items:center;gap:.5rem}.auth-helper:before{content:"";width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.auth-divider{display:flex;align-items:center;gap:1rem;color:#d1d5db;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#e5e7eb,transparent)}.auth-loading{text-align:center;padding:2rem 0;color:#6b7280}.auth-loading .spinner{margin:0 auto 1rem;width:40px;height:40px;border-width:3px}.auth-loading p{font-size:.9375rem;font-weight:500}.auth-footer{text-align:center;color:#9ca3af;font-size:.8125rem;padding-top:.5rem;border-top:1px solid #f3f4f6}.auth-footer>div:first-child{line-height:1.5}.auth-version{margin-top:.75rem;font-size:.6875rem;opacity:.5;font-weight:500;letter-spacing:.05em}@media(max-width:480px){.auth-container{padding:3rem 1rem 1rem;align-items:flex-start}.auth-card{padding:2rem 1.5rem;border-radius:1.25rem}.auth-icon{width:60px;height:60px}.auth-icon svg{width:32px;height:32px}.auth-title{font-size:1.5rem}}.offline-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;padding:.75rem 1rem;text-align:center;font-size:.9375rem;font-weight:500;position:sticky;top:0;z-index:101;border-bottom:2px solid #fbbf24;box-shadow:0 2px 4px #0000000d;display:flex;align-items:center;justify-content:center;gap:.5rem}.offline-banner:before{content:"⚠";font-size:1.125rem}.loading{text-align:center;padding:2rem;color:#6b7280}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.modal-large{max-width:520px;max-height:85vh;display:flex;flex-direction:column;border-radius:1.25rem;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.modal-header h2{margin:0;font-size:1.375rem;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#7c3aed,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-close{background:#f3f4f6;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.btn-close:hover{background:#e5e7eb;color:#1f2937;transform:rotate(90deg)}.modal-body{flex:1;overflow-y:auto;margin:0 -1.5rem;padding:0 1.5rem}.modal-body-grid{display:grid;gap:var(--space-lg)}.modal-scrollable-section{max-height:220px;overflow-y:auto;margin-top:var(--space-sm)}@media(min-width:640px){.modal-scrollable-section{max-height:300px}}.modal-footer{padding-top:1.25rem;margin-top:1rem;border-top:1px solid #f3f4f6;display:flex;gap:.75rem}.modal-footer .btn{flex:1}.template-search{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1rem;transition:all .2s;background:#f9fafb}.template-search:focus{outline:none;border-color:#a855f7;background:#fff;box-shadow:0 0 0 3px #a855f71a}.template-search::placeholder{color:#9ca3af}.template-section{margin-bottom:1.75rem}.template-section-title{font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.875rem;display:flex;align-items:center;gap:.5rem}.template-chips{display:flex;flex-wrap:wrap;gap:.5rem}.template-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9999px;color:#1e40af;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.template-chip:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.template-chip:active{transform:translateY(0)}.template-chip:disabled{opacity:.5;cursor:not-allowed}.template-chip-quantity{font-size:var(--font-size-sm);opacity:.8}.template-category{margin-bottom:1rem}.template-category-title{font-size:.9375rem;font-weight:600;color:#374151;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid #f3f4f6}.template-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.template-item{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem 1.25rem;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center}.template-item:hover{background:linear-gradient(135deg,#faf5ff,#fdf2f8);border-color:#c4b5fd;box-shadow:0 2px 8px #7c3aed1a}.template-item:active{background:linear-gradient(135deg,#ede9fe,#fce7f3)}.template-item-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.template-item-name{font-weight:600;font-size:.9375rem;color:#1f2937;display:flex;align-items:center}.template-item-details{display:flex;gap:.375rem;flex-shrink:0}.template-item-description{font-size:.8125rem;color:#6b7280;margin-top:.25rem}.template-item-arrow{font-size:1.25rem;color:#9ca3af;transition:all .2s}.template-item:hover .template-item-arrow{color:#7c3aed;transform:translate(4px)}.template-icon{display:inline-flex;margin-right:.5rem;font-size:1.125rem}.template-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:480px){.template-cards{grid-template-columns:repeat(4,1fr)}}.template-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem .75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease;text-align:center;min-height:90px}.template-card:hover{background:linear-gradient(135deg,#ede9fe,#fae8ff);border-color:#c4b5fd;transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed26}.template-card:active{transform:translateY(0)}.template-card-featured{background:linear-gradient(135deg,#faf5ff,#fdf2f8);border-color:#e9d5ff}.template-card-icon{font-size:1.75rem;line-height:1}.template-card-name{font-size:.8125rem;font-weight:600;color:#1f2937;line-height:1.2}.template-card-occasion{font-size:.6875rem;color:#7c3aed;font-weight:500;text-transform:uppercase;letter-spacing:.03em;padding:.125rem .5rem;background:#7c3aed1a;border-radius:9999px}.btn-back{background:none;border:none;color:#7c3aed;font-size:.9375rem;font-weight:600;cursor:pointer;padding:.5rem .75rem;margin:-.5rem .5rem -.5rem -.5rem;border-radius:.5rem;transition:all .2s}.btn-back:hover{background:#7c3aed1a}.template-description{color:#6b7280;font-size:.9375rem;line-height:1.5;margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#faf5ff,#fdf2f8);border-radius:.75rem;border:1px solid #f3e8ff}.template-items-section{margin-bottom:1.5rem}.template-items-section h3{font-size:.8125rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.template-items-list{list-style:none;background:#f9fafb;border-radius:.75rem;padding:.5rem;border:1px solid #f3f4f6}.template-items-optional{background:#fffbeb;border-color:#fef3c7}.template-item-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:.5rem;transition:background .15s}.template-item-row:hover{background:#fff}.template-item-row .template-item-name{font-weight:500;color:#1f2937}.template-item-qty{font-size:.875rem;color:#6b7280;font-weight:500}.template-optional-toggle{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-radius:.75rem;cursor:pointer;margin-bottom:1rem;transition:all .2s}.template-optional-toggle:hover{background:linear-gradient(135deg,#fef3c7,#fde68a)}.template-optional-toggle input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:#f59e0b}.template-optional-toggle span{font-weight:600;color:#92400e;font-size:.9375rem}.store-management{padding:1rem}.store-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.store-management-header h2{font-size:1.5rem;font-weight:600;color:#111827}.store-list{display:flex;flex-direction:column;gap:1.5rem}.store-section{background:#f9fafb;border-radius:.5rem;padding:1rem}.store-section-title{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.store-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.store-card:hover{border-color:#2563eb;box-shadow:0 2px 4px #0000000d}.store-info{flex:1}.store-name{font-size:1rem;font-weight:500;color:#111827;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.store-favorite{font-size:1.125rem}.store-meta{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.store-type-badge{display:inline-block;padding:.125rem .5rem;background:#f3f4f6;color:#374151;border-radius:9999px;font-size:var(--font-size-sm);text-transform:capitalize}.store-actions{display:flex;gap:.5rem;align-items:center}.store-search-results{display:flex;flex-direction:column;gap:.5rem;max-height:260px;overflow-y:auto;padding-right:.25rem}.store-search-result{text-align:left;padding:.5rem;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;cursor:pointer}.store-search-result:hover{border-color:#2563eb;background:#eff6ff}.store-search-meta{font-size:.8125rem;color:#6b7280}.store-search-empty{font-size:.8125rem;color:#9ca3af;padding:.25rem 0}.store-search-toggle{background:none;border:none;color:#2563eb;font-size:.8125rem;cursor:pointer;padding:0;margin-bottom:1rem}.store-search-toggle:hover{text-decoration:underline}.btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;color:#6b7280;transition:all .2s;border-radius:.25rem}.btn-icon:hover{background:#f3f4f6;color:#111827}.btn-icon.btn-danger:hover{background:#fef2f2;color:#dc2626}.item-organizer{display:flex;flex-direction:column;height:100%}.organizer-header{margin-bottom:1rem}.organizer-header h3{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:.25rem}.organizer-subtitle{font-size:.875rem;color:#6b7280;margin:0}.organizer-list{flex:1;overflow-y:auto;margin-bottom:1rem}.organizer-item{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem;cursor:move;transition:all .2s}.organizer-item:hover{border-color:#2563eb;box-shadow:0 2px 4px #0000000d}.organizer-item.dragging{opacity:.5;transform:scale(.98)}.organizer-item-handle{font-size:1.25rem;color:#9ca3af;cursor:grab;-webkit-user-select:none;user-select:none}.organizer-item-handle:active{cursor:grabbing}.organizer-item-content{flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem}.organizer-item-info{display:flex;align-items:center;gap:.75rem;flex:1}.organizer-item-position{font-size:.875rem;font-weight:600;color:#6b7280;background:#f3f4f6;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.organizer-item-name{font-size:1rem;font-weight:500;color:#111827}.organizer-item-meta{font-size:.875rem;color:#6b7280;margin-top:.125rem}.organizer-item-aisle{flex-shrink:0}.organizer-aisle-badge{font-size:var(--font-size-sm);padding:.25rem .5rem;background:#eff6ff;color:#1e40af;border:1px dashed #bfdbfe;border-radius:.25rem;cursor:pointer;transition:all .2s}.organizer-aisle-badge:hover{background:#dbeafe;border-color:#93c5fd}.organizer-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.household-settings{padding:1rem;max-height:80vh;overflow-y:auto}.household-settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.household-settings-header h2{font-size:1.5rem;font-weight:600;color:#111827;margin:0}.settings-section{margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.settings-section h3{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}.settings-section .form-row{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}@media(min-width:640px){.settings-section .form-row{grid-template-columns:2fr 1fr 1fr}}.settings-section .form-row.products-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.invite-code-display{display:flex;align-items:center;gap:.75rem}.invite-code-display code{font-size:1.125rem;font-weight:600;color:#2563eb;background:#fff;padding:.5rem 1rem;border-radius:.375rem;border:2px dashed #2563eb;flex:1}.location-display{padding:.75rem;background:#fff;border-radius:.375rem;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.location-coords{font-size:.875rem;color:#6b7280;font-family:monospace}.settings-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:2rem}.discovery-results{padding:1rem}.discovery-subtitle{color:#6b7280;margin-bottom:1rem}.discovered-stores-list{max-height:50vh;overflow-y:auto;margin-bottom:1.5rem}.discovered-store-card{display:flex;align-items:center;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;margin-bottom:.75rem;cursor:pointer;transition:all .15s}.discovered-store-card:hover{border-color:#3b82f6;background:#eff6ff}.discovered-store-card.selected{border-color:#2563eb;background:#dbeafe}.discovered-store-info{flex:1}.discovered-store-name{font-size:1rem;font-weight:600;color:#111827;margin-bottom:.25rem}.discovered-store-meta{font-size:.875rem;color:#6b7280}.discovery-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.empty-state{text-align:center;padding:3rem 1rem;color:#9ca3af}.modal-large{max-width:700px;max-height:90vh;overflow-y:auto}.aisles-manager{padding:1rem 0}.aisle-templates{margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:.5rem}.templates-intro{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.template-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.template-btn{padding:.375rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:9999px;font-size:.875rem;cursor:pointer;transition:all .15s}.template-btn:hover{border-color:#2563eb;background:#eff6ff}.aisle-form{background:#f9fafb;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.form-actions .btn{flex:0;padding:.5rem 1rem}.aisles-list{display:flex;flex-direction:column;gap:.5rem}.aisle-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem}.aisle-reorder{display:flex;flex-direction:column;gap:.125rem}.btn-small{padding:.125rem .375rem;font-size:var(--font-size-sm)}.aisle-info{flex:1}.aisle-name{font-weight:500;color:#111827;display:flex;align-items:center;gap:.5rem}.aisle-icon{font-size:1.25rem}.aisle-number{font-size:var(--font-size-sm);color:#6b7280;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.aisle-description{font-size:.8125rem;color:#6b7280;margin-top:.25rem}.aisle-meta{font-size:var(--font-size-sm);color:#9ca3af;margin-top:.25rem}.aisle-actions{display:flex;gap:.25rem}.add-aisle-btn{margin-top:.5rem}.store-products-manager{padding:1rem 0}.store-products-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.filter-buttons{display:flex;gap:.25rem}.filter-btn{padding:.375rem .75rem;background:#f3f4f6;border:1px solid transparent;border-radius:9999px;font-size:.8125rem;color:#6b7280;cursor:pointer;transition:all .15s}.filter-btn:hover{background:#e5e7eb}.filter-btn.active{background:#2563eb;color:#fff}.store-product-edit-section{background:#f9fafb;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.store-product-edit-section h3{font-size:1rem;margin-bottom:.75rem;color:#111827}.store-product-form .form-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.store-product-form .form-section:last-of-type{border-bottom:none}.store-product-form .form-section h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;padding-top:1.5rem}.checkbox-label input{width:auto}.store-products-list{display:flex;flex-direction:column;gap:1rem}.aisle-group{background:#f9fafb;border-radius:.5rem;padding:.75rem}.aisle-group-header{font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb;margin-bottom:.5rem}.aisle-group-header.aisle-unassigned{color:#9ca3af}.aisle-count{font-weight:400;font-size:.8125rem;color:#6b7280}.aisle-products{display:flex;flex-direction:column;gap:.5rem}.store-product-card{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem}.store-product-info{flex:1;min-width:0}.store-product-name{font-weight:500;color:#111827;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.store-product-category{font-size:var(--font-size-sm);color:#6b7280;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.store-product-details{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.25rem;font-size:.875rem}.store-product-price{font-weight:600;color:#059669}.price-current{color:#dc2626}.price-regular{color:#9ca3af;text-decoration:line-through;font-weight:400;margin-left:.25rem}.price-savings{background:#dc2626;color:#fff;font-size:var(--font-size-sm);padding:.125rem .375rem;border-radius:.25rem;margin-left:.25rem}.store-product-section{font-size:.8125rem;color:#6b7280}.availability-badge{font-size:var(--font-size-sm);padding:.125rem .375rem;border-radius:.25rem;background:#f3f4f6}.availability-in_stock{background:#d1fae5;color:#059669}.availability-low_stock{background:#fef3c7;color:#d97706}.availability-out_of_stock{background:#fee2e2;color:#dc2626}.store-product-deal{display:flex;align-items:center;gap:.5rem;margin-top:.375rem;font-size:.8125rem;color:#7c3aed}.flyer-badge{background:#ede9fe;color:#7c3aed;font-size:var(--font-size-sm);padding:.125rem .375rem;border-radius:.25rem;font-weight:500}.deal-expiry{color:#9ca3af;font-size:var(--font-size-sm)}.store-product-actions{display:flex;gap:.25rem}.catalogue-search{padding:1rem 0}.catalogue-tabs{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.tab-btn{padding:.5rem 1rem;background:transparent;border:none;border-radius:.375rem;font-size:.9375rem;color:#6b7280;cursor:pointer;transition:all .15s}.tab-btn:hover{background:#f3f4f6;color:#111827}.tab-btn.active{background:#2563eb;color:#fff}.search-view,.popular-view,.browse-view{min-height:300px}.view-description{font-size:.875rem;color:#6b7280;margin-bottom:1rem}.search-form{margin-bottom:1rem}.search-bar{display:flex;gap:.5rem;margin-bottom:.75rem}.search-bar input{flex:1;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem}.search-bar .btn{flex:0;padding:.625rem 1rem}.search-filters{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.search-filters select{padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff}.filter-checkbox{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#374151;cursor:pointer}.filter-checkbox input{width:auto}.btn-link{background:transparent;border:none;color:#2563eb;font-size:.875rem;cursor:pointer;padding:.375rem}.btn-link:hover{text-decoration:underline}.results-header{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.products-grid{display:flex;flex-direction:column;gap:.5rem}.catalogue-product-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .15s}.catalogue-product-card:hover{border-color:#2563eb;background:#eff6ff}.product-thumbnail{width:60px;height:60px;border-radius:.375rem;overflow:hidden;background:#f3f4f6;flex-shrink:0}.product-thumbnail img{width:100%;height:100%;object-fit:cover}.product-info{flex:1;min-width:0}.product-name{font-weight:500;color:#111827;margin-bottom:.125rem}.product-brand{font-size:.8125rem;color:#6b7280}.product-meta{display:flex;gap:.5rem;margin-top:.25rem}.product-category,.product-size{font-size:var(--font-size-sm);color:#6b7280;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.product-attributes{display:flex;gap:.375rem;margin-top:.375rem}.attr-badge{font-size:.6875rem;padding:.125rem .375rem;border-radius:9999px;font-weight:500}.attr-badge.organic{background:#d1fae5;color:#059669}.attr-badge.gf{background:#fef3c7;color:#d97706}.attr-badge.vegan{background:#dbeafe;color:#2563eb}.product-usage{font-size:var(--font-size-sm);color:#9ca3af;margin-top:.25rem}.product-price{text-align:right;font-weight:600;color:#059669}.price-note{display:block;font-size:.6875rem;font-weight:400;color:#9ca3af}.load-more-btn{width:100%;margin-top:1rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.category-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.category-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;font-weight:500;color:#111827;cursor:pointer;transition:background .15s}.category-header:hover{background:#f3f4f6}.category-icon{font-size:1.25rem}.category-name{flex:1}.subcategories{padding:0 .5rem .5rem;display:flex;flex-wrap:wrap;gap:.25rem}.subcategory-btn{padding:.25rem .5rem;background:#f3f4f6;border:none;border-radius:.25rem;font-size:var(--font-size-sm);color:#6b7280;cursor:pointer;transition:all .15s}.subcategory-btn:hover{background:#e5e7eb;color:#111827}.product-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem}.product-detail{background:#fff;border-radius:.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:1.5rem;position:relative}.product-detail .btn-close{position:absolute;top:1rem;right:1rem}.detail-image{width:100%;max-height:200px;border-radius:.5rem;overflow:hidden;margin-bottom:1rem;background:#f3f4f6}.detail-image img{width:100%;height:100%;object-fit:contain}.product-detail h2{font-size:1.25rem;margin-bottom:.25rem}.detail-brand{font-size:1rem;color:#6b7280;margin-bottom:.75rem}.detail-description{font-size:.9375rem;color:#374151;margin-bottom:1rem;line-height:1.5}.detail-specs{margin-bottom:1rem}.spec-row{display:flex;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.spec-label{width:100px;font-size:.8125rem;color:#6b7280}.spec-value{flex:1;font-size:.875rem;color:#111827}.detail-attributes{display:flex;gap:.5rem;margin-bottom:1rem}.detail-synonyms{font-size:.8125rem;color:#6b7280;padding:.75rem;background:#f9fafb;border-radius:.375rem;margin-bottom:1rem}.synonyms-label{font-weight:500;margin-right:.5rem}.detail-select-btn{width:100%}.loading-state{text-align:center;padding:3rem 1rem;color:#7c3aed;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-state:before{content:"";width:32px;height:32px;border:3px solid #e9d5ff;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:640px){.modal-large{max-width:100%;margin:auto 0 0;border-radius:1rem 1rem 0 0;max-height:90vh}.store-products-toolbar{flex-direction:column;align-items:stretch}.filter-buttons{overflow-x:auto;padding-bottom:.5rem}.category-grid{grid-template-columns:1fr}.search-filters{flex-direction:column;align-items:stretch}.search-filters select{width:100%}}.btn-mode{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);font-weight:600;display:inline-flex;align-items:center;gap:.375rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-mode:hover{background:#ffffff4d;border-color:#fff9}.btn-mode:disabled{opacity:.5;cursor:not-allowed;background:#ffffff1a;border-color:#fff3}.btn-mode-active{background:#10b981e6;color:#fff;border-color:#10b981e6}.btn-mode-active:hover{background:#10b981;border-color:#10b981}.app[data-mode=shopping] .header{background:linear-gradient(135deg,#00b496f2,#10b981f2 40%,#32c864e6,#64dc50d9);box-shadow:0 4px 20px #10b98159}.shopping-view{padding:var(--space-lg);background:#f9fafb;min-height:calc(100vh - 60px)}.shopping-progress{background:#fff;border-radius:var(--border-radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 1px 3px #0000001a}.shopping-progress-text{font-size:var(--font-size-md);font-weight:600;color:#111827;margin-bottom:var(--space-md);text-align:center}.shopping-progress-bar{height:12px;background:#e5e7eb;border-radius:9999px;overflow:hidden}.shopping-progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:9999px;transition:width .3s ease}.shopping-store-selector{margin-bottom:var(--space-lg)}.shopping-store-selector .store-selector-dropdown{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-md);border:2px solid #e5e7eb;border-radius:var(--border-radius-lg);background:#fff;color:#111827;font-weight:500}.shopping-item-meta{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:.25rem}.shopping-item-aisle{font-size:var(--font-size-xs);color:#10b981;background:#d1fae5;padding:.125rem .5rem;border-radius:var(--border-radius-sm);font-weight:500}.shopping-item-category{font-size:var(--font-size-xs);color:#6366f1;background:#e0e7ff;padding:.125rem .5rem;border-radius:var(--border-radius-sm);font-weight:500}.shopping-also{border-top:1px dashed #d1d5db;padding-top:var(--space-lg)}.shopping-also .shopping-section-title{color:#9ca3af}.shopping-section{margin-bottom:var(--space-xl)}.shopping-section-title{font-size:var(--font-size-sm);font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md)}.shopping-purchased{opacity:.7}.shopping-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.shopping-item{background:#fff;border:2px solid #e5e7eb;border-radius:var(--border-radius-lg);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;min-height:72px}.shopping-item:hover{background:#f9fafb;border-color:#10b981}.shopping-item:active{transform:scale(.98)}.shopping-item.purchased{opacity:.6;border-color:#d1d5db}.shopping-item.purchased .shopping-item-name{text-decoration:line-through}.shopping-checkbox{width:32px;height:32px;min-width:32px;cursor:pointer;flex-shrink:0}.shopping-item-content{flex:1;min-width:0}.shopping-item-name{font-size:var(--font-size-md);font-weight:500;color:#111827;margin-bottom:.25rem}.shopping-item-quantity{font-size:var(--font-size-sm);color:#6b7280}.shopping-item-price{font-size:var(--font-size-sm);color:#6b7280;font-weight:500;flex-shrink:0;padding:.25rem .5rem;background:#f3f4f6;border-radius:var(--border-radius-sm)}.shopping-item-drag-handle{color:#9ca3af;font-size:1.25rem;padding:0 .5rem;cursor:grab;touch-action:none;flex-shrink:0}.shopping-item-drag-handle:active{cursor:grabbing}.shopping-list-sortable{touch-action:pan-y}.shopping-item.dragging{opacity:.5;background:#f0fdf4;border-color:#10b981;box-shadow:0 4px 12px #10b9814d;cursor:grabbing;z-index:100}.shopping-item.dragging *{-webkit-user-select:none;user-select:none}.shopping-loading{text-align:center;padding:var(--space-md);color:#6b7280;font-size:var(--font-size-sm)}@media(min-width:768px){.shopping-checkbox{width:28px;height:28px;min-width:28px}.shopping-item{min-height:64px}}.skeleton{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--border-radius-sm)}.skeleton-text{height:1em;margin-bottom:.5em;transform-origin:0 60%;transform:scaleY(.6)}.skeleton-rectangular{border-radius:var(--border-radius-md)}.skeleton-circular{border-radius:50%}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text-container{display:flex;flex-direction:column;gap:.5rem}.skeleton-product{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:#fff;border:1px solid #e5e7eb;border-radius:var(--border-radius-md);margin-bottom:var(--space-sm)}.skeleton-product-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.skeleton-item{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:#fff;border:1px solid #e5e7eb;border-radius:var(--border-radius-md);margin-bottom:var(--space-sm)}.skeleton-item-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.modal-body-grid h3{font-size:.9375rem;font-weight:700;color:#1f2937;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.modal-body-grid h3:before{content:"";width:4px;height:1.25em;background:linear-gradient(180deg,#7c3aed,#ec4899);border-radius:2px}.modal-body-grid .product-search{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:.9375rem;background:#f9fafb;transition:all .2s;margin-bottom:.75rem}.modal-body-grid .product-search:focus{outline:none;border-color:#a855f7;background:#fff;box-shadow:0 0 0 3px #a855f71a}.modal-body-grid .product-search::placeholder{color:#9ca3af}.add-item-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:.75rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:.5rem;transition:all .2s ease;width:100%}.add-item-row:hover{border-color:#c4b5fd;background:linear-gradient(135deg,#faf5ff,#fdf2f8);box-shadow:0 2px 8px #7c3aed1a}.add-item-info{flex:1;min-width:0}.add-item-name{font-size:.9375rem;font-weight:600;color:#1f2937;margin-bottom:.375rem}.add-item-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.8125rem}.add-item-category,.add-item-brand{background:linear-gradient(135deg,#ede9fe,#fce7f3);color:#7c3aed;padding:.1875rem .625rem;border-radius:9999px;font-weight:500;font-size:.75rem}.add-item-qty,.add-item-store{color:#9ca3af;font-size:.8125rem}.add-item-price{color:#059669;font-weight:700;font-size:.875rem}.add-item-action{flex-shrink:0;padding:.5rem 1rem;background:linear-gradient(90deg,#7c3aed,#a855f7,#ec4899);background-size:200% 100%;animation:btn-gradient-flow 4s linear infinite;color:#fff;border-radius:.5rem;font-size:.8125rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #7c3aed40}.add-item-row:hover .add-item-action{box-shadow:0 4px 12px #7c3aed59;transform:translate(2px)}.add-item-quantity-control{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.add-item-quantity-control .qty-btn{width:28px;height:28px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#7c3aed;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.add-item-quantity-control .qty-btn:hover:not(:disabled){background:#f5f3ff;border-color:#c4b5fd}.add-item-quantity-control .qty-btn:disabled{opacity:.4;cursor:not-allowed}.add-item-quantity-control .qty-value{min-width:60px;text-align:center;font-size:.8125rem;font-weight:600;color:#374151}.add-item-action-btn{flex-shrink:0;padding:.5rem 1rem;background:linear-gradient(90deg,#7c3aed,#a855f7,#ec4899);background-size:200% 100%;animation:btn-gradient-flow 4s linear infinite;color:#fff;border:none;border-radius:.5rem;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s}.add-item-action-btn:hover:not(:disabled){box-shadow:0 4px 12px #7c3aed59}.add-item-action-btn:disabled{opacity:.5;cursor:not-allowed}.modal-body-grid>div:last-child{padding-top:1rem;border-top:1px solid #f3f4f6}.modal-body-grid>div:last-child h3{color:#6b7280;font-size:.875rem}.modal-body-grid>div:last-child .form-group{margin-bottom:1rem}.modal-body-grid>div:last-child .form-group label{font-size:.8125rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em}.modal-body-grid>div:last-child .form-group input{border:2px solid #e5e7eb;border-radius:.75rem;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.modal-body-grid>div:last-child .form-group input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f71a}.modal-body-grid>div:last-child .btn-primary{width:100%;padding:.875rem 1.5rem;font-size:.9375rem}.modal-scrollable-section{background:#f9fafb;border-radius:.75rem;padding:.5rem;border:1px solid #f3f4f6}.modal-scrollable-section .empty-state{padding:2rem 1rem;color:#9ca3af;font-size:.875rem;text-align:center}@media(max-width:500px){.modal.modal-large{max-width:100%;max-height:100vh;border-radius:0;padding:var(--space-md)}.modal-body-grid{gap:var(--space-xl)}.modal-body-grid h3{font-size:var(--font-size-base);margin-bottom:var(--space-sm)}.product-search{min-width:0;width:100%}.modal-scrollable-section{max-height:180px}}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none}@media(max-width:640px){.toast-container{left:20px;right:20px;max-width:none}}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--border-radius-lg);box-shadow:0 10px 25px #00000026;color:#fff;font-size:.9375rem;font-weight:500;pointer-events:auto;animation:toast-slide-in .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-exit{animation:toast-slide-out .3s ease-in forwards}@keyframes toast-slide-in{0%{transform:translate(calc(100% + 20px));opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(calc(100% + 20px));opacity:0}}.toast-success{background:linear-gradient(135deg,#10b981,#059669)}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626)}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.toast-icon{font-size:1.25rem;line-height:1;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:50%}.toast-message{flex:1;line-height:1.4}.toast-close{background:transparent;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s;flex-shrink:0}.toast-close:hover{background:#fff3}
