:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;overscroll-behavior:none}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;min-height:100dvh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:none}.app{display:flex;flex-direction:column;height:100dvh;max-width:100%;margin:0;padding:0;overflow:hidden}.app__main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;position:relative}.app__navigation{display:flex;background:#f8f9fa;border-top:1px solid #dee2e6;padding:.5rem;padding-bottom:calc(env(safe-area-inset-bottom) + .5rem);flex-shrink:0}.nav-button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem .5rem;background:none;border:none;border-radius:.5rem;text-decoration:none;color:#6c757d;font-size:.875rem;font-weight:500;cursor:pointer;min-height:3.5rem;outline:none;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}.nav-button:hover{background:#e9ecef;color:#495057;text-decoration:none}.nav-button--active,.nav-button--active:hover{background:#007bff;color:#fff}.nav-button__icon{font-size:1.5rem;margin-bottom:.25rem}.nav-button__text{font-size:.75rem}#root{max-width:100%;margin:0;padding:0;text-align:left}.logo{height:6em;padding:1.5em;will-change:filter}.logo:hover{filter:drop-shadow(0 0 2em rgba(100,108,255,.6666666667))}.logo.react:hover{filter:drop-shadow(0 0 2em rgba(97,218,251,.6666666667))}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.camera-core,.camera-core__container{position:relative;width:100%;height:100%}.camera-core__video{width:100%;height:100%;object-fit:cover;background:#000}.camera-core__loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff;z-index:10}.camera-core__loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.camera-core__loading-text{font-size:1rem;text-align:center}.camera-core__overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:5}.camera-core__overlay>*{pointer-events:auto}.shared-camera-layout{position:relative;height:100%;width:100%;background:#000;overflow:hidden}.shared-camera-layout__video-container{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1}.shared-camera-layout__camera{width:100%;height:100%}.shared-camera-layout__video{width:100%;height:100%;object-fit:cover}.shared-camera-layout__content{position:relative;height:100%;width:100%;z-index:2;pointer-events:none}.shared-camera-layout__content>*{pointer-events:auto}.camera-feed__controls{position:absolute;top:10px;right:10px;z-index:1001}.camera-feed__controls.is-hidden{display:none}.camera-feed__stock-button{background:#000000b3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.camera-feed__stock-button:hover{background:#000000e6;border-color:#ffffff80}.camera-controls__label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.camera-controls__select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:.9rem}.camera-controls__select option{color:#333;background:#fff}.camera-controls__scan-controls{margin-bottom:1rem}.camera-controls__start-button,.camera-controls__stop-button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.camera-controls__start-button{background:#007bff;color:#fff}.camera-controls__start-button:hover:not(:disabled){background:#0056b3}.camera-controls__start-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.camera-controls__stop-button{background:#dc3545;color:#fff}.camera-controls__stop-button:hover{background:#c82333}.camera-controls__error{padding:1rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:1rem}.camera-controls__error-message{margin-bottom:.5rem;font-weight:500}.camera-controls__retry-button{padding:.5rem 1rem;background:#721c24;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s ease}.camera-controls__retry-button:hover{background:#5a151a}.camera-controls__loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:#666}.camera-controls__loading-spinner{width:40px;height:40px;border:4px solid #e9ecef;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.camera-controls__loading-text{font-size:1rem;text-align:center}.camera-controls__permission-request{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6;text-align:center}.camera-controls__permission-button{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s ease;min-width:140px}.camera-controls__permission-button:hover:not(:disabled){background:#0056b3}.camera-controls__permission-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.camera-overlay{background:#000000b3;padding:1rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.camera-overlay .camera-controls__label{color:#fff;margin-bottom:.5rem}.camera-overlay .camera-controls__select{background:#ffffffe6;border:1px solid rgba(255,255,255,.3);color:#333}.camera-overlay .camera-controls__start-button{background:#007bff;color:#fff;border:1px solid rgba(255,255,255,.3)}.camera-overlay .camera-controls__start-button:hover:not(:disabled){background:#0056b3}.stock-overlay{background:#000c;color:#fff;border-radius:8px;flex:1 1 auto;min-height:0;display:flex;flex-direction:column;justify-content:space-between;padding:12px}.stock-overlay__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.3)}.stock-overlay__header h3{margin:0;font-size:1.2rem;font-weight:600}.stock-overlay__hide-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:16px;font-size:.85rem;cursor:pointer;transition:background .2s ease,border-color .2s ease}.stock-overlay__hide-button:hover{background:#ffffff4d;border-color:#ffffff80}.stock-overlay__content{display:grid;grid-template-columns:repeat(var(--stock-columns, 3),1fr);gap:1rem}.stock-overlay__item{background:#ffffff1a;padding:12px;border-radius:8px;border-left:4px solid #4CAF50}.stock-overlay__item-name{font-weight:500;margin-bottom:4px}.stock-overlay__item-details{display:flex;justify-content:space-between;font-size:.9rem;opacity:.8}.stock-overlay__item-amount{color:#4caf50;font-weight:500}.stock-overlay__loading,.stock-overlay__error,.stock-overlay__empty{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;font-size:1.1rem;opacity:.8;text-align:center}.stock-overlay__error{color:#f44336}.stock-overlay__error-message{margin-bottom:15px}.stock-overlay__retry-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.stock-overlay__retry-button:hover{background:#ffffff4d}.stock-overlay__empty-message{font-size:1.2rem;margin-bottom:8px}.stock-overlay__empty-submessage{font-size:.9rem;opacity:.7}.stock-overlay__footer{display:flex;justify-content:end}.stock-overlay__button-group{display:flex;align-items:center;justify-content:center;gap:.5rem}.stock-overlay__clear-failed-button{transition:background .2s,opacity .2s}.stock-overlay__clear-failed-button:hover{background:#c82333!important}.stock-overlay__debug-clear-button{transition:background .2s,opacity .2s}.stock-overlay__debug-clear-button:hover{background:#5a6268!important;opacity:1!important}.stock-overlay__queue-status{margin-top:.5rem;text-align:center;font-size:.8rem;color:#6c757d;font-style:italic}@media (max-width: 768px){.stock-overlay{padding:15px}.stock-overlay__header h3{font-size:1rem}.stock-overlay__item{padding:10px}}.product-image{border-radius:8px;overflow:hidden;background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.product-image__img{width:100%;height:100%;object-fit:cover;border-radius:8px}.product-image__placeholder{font-size:2rem;color:#fff9}.product-image__loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.product-image--small{width:40px;height:40px}.product-image--small .product-image__placeholder{font-size:1rem}.product-image--medium{width:80px;height:80px}.product-image--medium .product-image__placeholder{font-size:2rem}.product-image--large{width:120px;height:120px}.product-image--large .product-image__placeholder{font-size:3rem}@media (max-width: 480px){.product-image--medium{width:60px;height:60px}.product-image--medium .product-image__placeholder{font-size:1.5rem}.product-image--large{width:80px;height:80px}.product-image--large .product-image__placeholder{font-size:2rem}}.scanned-item-display{background:#000000d9;border-radius:12px;padding:1.5rem;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:400px;margin:0 auto}.scanned-item-display__content{display:flex;flex-direction:column;gap:1rem}.scanned-item-display__header{display:flex;align-items:flex-start;gap:1rem}.scanned-item-display__product-info{flex:1;min-width:0}.scanned-item-display__product-name{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#fff;line-height:1.3}.scanned-item-display__details{display:flex;flex-direction:column;gap:.25rem}.scanned-item-display__location,.scanned-item-display__stock{font-size:.9rem;color:#fffc;display:flex;align-items:center;gap:.5rem}.scanned-item-display__actions{display:flex;gap:.75rem}.scanned-item-display__clear-button,.scanned-item-display__consume-button{flex:1;padding:.75rem 1rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:48px}.scanned-item-display__clear-button{background:#6c757dcc;color:#fff;border:1px solid rgba(255,255,255,.3)}.scanned-item-display__clear-button:hover{background:#5a6268e6}.scanned-item-display__consume-button{background:#28a745e6;color:#fff;border:1px solid rgba(255,255,255,.3);white-space:nowrap}.scanned-item-display__consume-button:disabled{background:#6c757d80;color:#ffffff80;cursor:not-allowed}.scanned-item-display__consume-button:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 4px 12px #28a7454d}.scanned-item-display__consume-button:disabled{background:#6c757d80;cursor:not-allowed;opacity:.6}.scanned-item-display__barcode{font-size:.8rem;color:#fff9;text-align:center;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1);font-family:monospace}@media (max-width: 480px){.scanned-item-display{padding:1rem;max-width:100%;margin:0 1rem}.scanned-item-display__product-name{font-size:1.1rem}.scanned-item-display__actions{gap:.5rem}.scanned-item-display__clear-button,.scanned-item-display__consume-button{font-size:.9rem;min-height:44px}}.barcode-not-found__clear-button{padding:.75rem 1.5rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:48px}@media (max-width: 480px){.barcode-not-found{padding:1rem;max-width:100%;margin:0 1rem}.barcode-not-found__icon{font-size:2.5rem}.barcode-not-found__title{font-size:1.1rem}.barcode-not-found__message{font-size:.9rem}.barcode-not-found__clear-button{font-size:.9rem;min-height:44px}}.undo-button{color:#fff;font-weight:600;font-size:1rem;border:none;border-radius:.5rem;padding:.75rem 1.5rem;box-shadow:0 4px 12px #00000026;transition:background .2s,opacity .2s}.undo-button--enabled{background:#28a745;cursor:pointer;opacity:1}.undo-button--enabled:hover{background:#218838}.undo-button--disabled{background:#ccc;cursor:not-allowed;opacity:.6}.undo-button--disabled:hover{background:#ccc}.camera-feed__overlays{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:20;display:flex;flex-direction:column;align-items:stretch;gap:8px}.camera-feed__overlays>*{pointer-events:auto;position:static}.camera-feed__scanned-item,.camera-feed__barcode-not-found{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:25;max-width:90%}.camera-feed__undo-footer{display:flex;justify-content:flex-end}.camera-feed__barcode-row{display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;font-weight:500;background:#000000b3;padding:12px 20px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;pointer-events:none;margin-left:20px;margin-right:20px;margin-bottom:8px;align-self:stretch}.camera-feed__bottom-controls{pointer-events:auto;margin:auto 12px 12px;align-self:stretch;display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.camera-feed__bottom-left,.camera-feed__bottom-center,.camera-feed__bottom-right{display:flex;gap:12px}.camera-feed__pick-product-button{background:#000000b3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:12px 20px;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.camera-feed__pick-product-button:hover{background:#000000e6;border-color:#ffffff80}.camera-feed__permission-request{display:contents}.camera-overlay .camera-controls__permission-button{background:#007bff;border:1px solid rgba(255,255,255,.3)}.camera-overlay .camera-controls__permission-button:hover:not(:disabled){background:#0056b3}.camera-feed__device-selector{display:contents}.product-picker{display:block;flex:1 1 auto;max-width:100%}.product-picker__field{flex:1 1 auto}.product-picker__label{color:#374151;font-weight:500;font-size:14px}.product-picker__input,.product-picker__select{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:.375rem;font-size:1rem;background:#fff;color:#212529;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.product-picker__input:focus,.product-picker__select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.product-picker__list{max-height:300px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:6px;margin-top:8px}.product-picker__item{padding:6px 10px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.product-picker__item:last-child{border-bottom:none}.product-picker__item:hover{background-color:#f9fafb}.product-picker__item--new{background-color:#f0f9ff;color:#0369a1;font-weight:500}.product-picker__item--new:hover{background-color:#e0f2fe}.product-picker__name{font-weight:500;color:#111827;display:flex;align-items:center;gap:6px;font-size:.85rem}.product-picker__description{font-size:.75rem;color:#6b7280;margin-top:2px}.product-picker__stock{font-size:.7rem;color:#059669;font-weight:500}.product-picker__badge{font-size:.65rem;padding:1px 4px;border-radius:8px;font-weight:500}.product-picker__badge--parent{background-color:#e0f2fe;color:#0369a1}.product-picker__badge--has-children{background-color:#f3e8ff;color:#7c3aed}.manual-product-picker{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.manual-product-picker__content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:80vh;overflow:hidden;box-shadow:0 10px 25px #0000004d;display:flex;flex-direction:column;position:relative;z-index:1001}.manual-product-picker__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;flex-shrink:0;background:#fff}.manual-product-picker__header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.manual-product-picker__close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:.25rem;border-radius:4px;transition:background-color .2s}.manual-product-picker__close-btn:hover{background-color:#f0f0f0;color:#333}.manual-product-picker__search-section{padding:1.5rem;border-bottom:1px solid #e0e0e0;flex-shrink:0;background:#fff;position:relative}.manual-product-picker__product-section{padding:1.5rem;flex:1;overflow-y:auto}.manual-product-picker__selected-product{margin-bottom:1.5rem}.manual-product-picker__selected-product-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.manual-product-picker__selected-product-header h4{margin:0;font-size:1rem;font-weight:600;color:#333}.manual-product-picker__clear-product-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#666;padding:.25rem;border-radius:4px;transition:background-color .2s;line-height:1}.manual-product-picker__clear-product-btn:hover{background-color:#f0f0f0;color:#333}.manual-product-picker__product-info{display:flex;flex-direction:column;gap:.25rem}.manual-product-picker__product-row{display:flex;align-items:flex-start;gap:1rem}.manual-product-picker__product-image{flex-shrink:0}.manual-product-picker__product-details{display:flex;flex-direction:column;gap:.25rem;flex:1}.manual-product-picker__product-name{font-weight:500;color:#333}.manual-product-picker__product-description{font-size:.875rem;color:#666}.manual-product-picker__stock-info{margin-top:.25rem}.manual-product-picker__stock-amount{font-size:.875rem;color:#059669;font-weight:500}.manual-product-picker__stock-empty{font-size:.875rem;color:#dc3545;font-weight:500}.manual-product-picker__amount-section{margin-bottom:1.5rem}.manual-product-picker__amount-label{font-weight:500;color:#333;margin-bottom:.5rem}.manual-product-picker__amount-row{display:flex;align-items:stretch;gap:.75rem}.manual-product-picker__amount-row .purchase-controls__amount-container{flex:1}.manual-product-picker__all-btn{background:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.manual-product-picker__all-btn:hover:not(:disabled){background:#0056b3}.manual-product-picker__all-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.manual-product-picker__actions{display:flex;gap:.75rem;justify-content:flex-end}.manual-product-picker__consume-btn{background:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.manual-product-picker__consume-btn:hover{background:#c82333}.manual-product-picker__cancel-btn{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.manual-product-picker__cancel-btn:hover{background:#5a6268}@media (max-width: 600px){.manual-product-picker{padding:.5rem}.manual-product-picker__content{max-height:90vh}.manual-product-picker__header,.manual-product-picker__search-section,.manual-product-picker__product-section{padding:1rem}.manual-product-picker__actions{flex-direction:column}.manual-product-picker__consume-btn,.manual-product-picker__cancel-btn{width:100%}}.camera-feed{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.camera-feed>*{pointer-events:auto}.camera-feed__loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:1rem 2rem;border-radius:8px;font-size:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.camera-feed__error{color:#ff6b6b;margin:8px 0;font-weight:700;background:#dc3545e6;border:1px solid rgba(220,53,69,.3);padding:8px 16px;border-radius:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.camera-feed__error .camera-controls__error-message{margin-bottom:.5rem}.camera-feed__error .camera-controls__retry-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.camera-feed__error .camera-controls__retry-button:hover{background:#ffffff4d}.camera-feed__scanning-disabled{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:5;pointer-events:none}.camera-feed__scanning-disabled-content{background:#000c;color:#fff;padding:.75rem 1.5rem;border-radius:1rem;font-size:.9rem;font-weight:500;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.purchase-controls{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #dee2e6;border-radius:1rem 1rem 0 0;padding:.75rem;max-height:99vh;overflow-y:auto;z-index:1000;box-shadow:0 -4px 6px -1px #0000001a;color:#212529}.purchase-controls__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e9ecef}.purchase-controls__product-info{display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;flex:1}.purchase-controls__current-stock{font-size:.875rem;color:#6c757d;font-weight:500;margin-top:.125rem}.purchase-controls__product-image{flex-shrink:0}.purchase-controls__product-image--placeholder{width:150px;height:75px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:.375rem;font-size:2.5rem;color:#6c757d}.external-product-image{width:150px;height:75px;border-radius:.375rem;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border:1px solid #dee2e6}.external-product-image__img{width:100%;height:100%;object-fit:cover}.external-product-image__img--loading{opacity:0}.external-product-image__placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f8f9fa;font-size:1.25rem;color:#6c757d}.external-product-image__loading{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.purchase-controls__header h3{margin:0;font-size:1rem;font-weight:600;color:#212529}.purchase-controls__close{background:transparent;border:none;font-size:1.25rem;color:#6c757d;cursor:pointer;padding:.25rem;line-height:1}.purchase-controls__close:hover{color:#495057}.purchase-controls__form{display:flex;flex-direction:column;gap:.5rem;width:100%;box-sizing:border-box}.purchase-controls__field{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;width:100%;box-sizing:border-box}.purchase-controls__field label{font-weight:500;color:#495057;font-size:.8rem;min-width:80px;flex-shrink:0}.purchase-controls__field--vertical{flex-direction:column;align-items:flex-start;gap:.25rem}.purchase-controls__field--vertical label{min-width:auto;font-size:.8rem}.purchase-controls__field--vertical>*:not(label){width:100%}.purchase-controls__amount-row{display:flex;align-items:center;gap:.75rem;min-width:0}.purchase-controls__amount-section{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0;overflow:hidden}.purchase-controls__amount-label{font-weight:500;color:#495057;font-size:.875rem;flex-shrink:0}.purchase-controls__amount-container{display:flex;align-items:center;border:1px solid #ced4da;border-radius:.375rem;overflow:hidden;background:#fff;flex:1;min-width:0}.purchase-controls__amount-buttons{display:flex;flex-direction:column;border-left:1px solid #ced4da}.purchase-controls__amount-btn{background:#f8f9fa;border:none;padding:.25rem;font-size:1rem;font-weight:600;color:#495057;cursor:pointer;transition:all .2s ease;min-width:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:0}.purchase-controls__amount-btn:first-child{border-bottom:1px solid #ced4da}.purchase-controls__amount-btn:hover:not(:disabled){background:#e9ecef;color:#212529}.purchase-controls__amount-btn:active:not(:disabled){background:#dee2e6}.purchase-controls__amount-btn:disabled{background:#f8f9fa;color:#adb5bd;cursor:not-allowed}.purchase-controls__amount-input{flex:1;border:none;padding:.5rem;text-align:center;font-size:1rem;background:#fff;color:#212529;min-width:0}.purchase-controls__amount-input:focus{outline:none;background:#f8f9fa}.purchase-controls__amount-input::-webkit-outer-spin-button,.purchase-controls__amount-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.purchase-controls__amount-input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.purchase-controls__location-select,.purchase-controls__product-group-select,.purchase-controls__parent-product-select{padding:.5rem;border:1px solid #ced4da;border-radius:.375rem;font-size:1rem;background:#fff;color:#212529;flex:1;min-width:0;width:100%}.purchase-controls__text-input{padding:.5rem;border:1px solid #ced4da;border-radius:.375rem;font-size:1rem;background:#fff;color:#212529;flex:1;min-width:0}.purchase-controls__location-select:focus,.purchase-controls__product-group-select:focus,.purchase-controls__parent-product-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.purchase-controls__location-select option,.purchase-controls__product-group-select option,.purchase-controls__parent-product-select option{color:#212529;background:#fff}.purchase-controls__purchase-button{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-top:.5rem}.purchase-controls__purchase-button:hover:not(:disabled){background:#218838}.purchase-controls__purchase-button:disabled{background:#6c757d;cursor:not-allowed;color:#fff}.purchase-controls__parent-product-picker{position:relative;display:flex;align-items:center;gap:8px;flex:1}.purchase-controls__clear-parent{background:#ef4444;color:#fff;border:none;border-radius:50%;width:28px;height:28px;padding:0;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;flex-shrink:0}.purchase-controls__clear-parent:hover{background:#dc2626}.purchase-controls__selected-parent{background:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem;color:#374151;flex:1}.purchase-controls__toggle{display:flex;gap:12px;flex-wrap:wrap}.purchase-controls__parent-group{display:flex;flex-direction:column;gap:8px;width:100%;max-width:100%;box-sizing:border-box;padding:8px;border:1px solid #e5e7eb;border-radius:8px;background:#fafafa}.purchase-controls__toggle-option{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid #d1d5db;border-radius:8px;background:#fff;cursor:pointer;user-select:none;-webkit-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent;line-height:1.2}.purchase-controls__toggle-option input[type=radio]{pointer-events:none}.purchase-controls__toggle-option:active{transform:translateY(.5px)}.purchase-controls__toggle-option.active{background:#eef2ff;border-color:#6366f1;color:#1f2937;box-shadow:inset 0 0 0 1px #6366f1}.purchase-controls__ai-loading{margin-top:.5rem;padding:.5rem;background:#e3f2fd;border:1px solid #bbdefb;border-radius:.375rem;font-size:.875rem;color:#1976d2;display:flex;align-items:center;gap:.5rem}.purchase-controls__ai-suggestion{margin-top:.5rem;padding:.5rem;background:#f3e5f5;border:1px solid #e1bee7;border-radius:.375rem;font-size:.875rem;color:#7b1fa2;display:flex;align-items:center;gap:.5rem}.purchase-controls__ai-error{margin-top:.5rem;padding:.5rem;background:#ffebee;border:1px solid #ffcdd2;border-radius:.375rem;font-size:.875rem;color:#c62828;display:flex;align-items:center;gap:.5rem}.purchase-controls__ai-suggest-btn{margin-top:.5rem;padding:.5rem 1rem;background:#f3e5f5;border:1px solid #e1bee7;border-radius:.375rem;font-size:.875rem;color:#7b1fa2;cursor:pointer;transition:all .2s ease}.purchase-controls__ai-suggest-btn:hover:not(:disabled){background:#e1bee7;border-color:#ba68c8}.purchase-controls__ai-suggest-btn:disabled{opacity:.6;cursor:not-allowed}.expiry-picker{background:#fff;border:1px solid #dee2e6;border-radius:.25rem;padding:1rem;color:#212529;width:100%;box-sizing:border-box}.expiry-picker__selected{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f8f9fa;border-radius:.25rem;font-size:.875rem;color:#212529}.expiry-picker__clear{background:transparent;border:none;color:#6c757d;cursor:pointer;font-size:.875rem;padding:.25rem .5rem;border-radius:.25rem;transition:all .2s ease}.expiry-picker__clear:hover{color:#495057;background:#e9ecef}.expiry-picker__title{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-weight:600;font-size:.875rem;color:#212529}.expiry-picker__quick-days{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.expiry-picker__years{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.5rem}.expiry-picker__months{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem}.expiry-picker__days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.expiry-picker__year,.expiry-picker__month,.expiry-picker__day,.expiry-picker__quick-day{padding:.5rem;border:1px solid #dee2e6;background:#fff;border-radius:.25rem;cursor:pointer;transition:all .2s ease;font-size:.875rem;text-align:center;color:#212529;height:2.5rem;display:flex;align-items:center;justify-content:center}.expiry-picker__year:hover,.expiry-picker__month:hover,.expiry-picker__day:hover,.expiry-picker__quick-day:hover{background:#e9ecef;border-color:#adb5bd;color:#212529}.expiry-picker__year:active,.expiry-picker__month:active,.expiry-picker__day:active,.expiry-picker__quick-day:active{background:#007bff;color:#fff}.expiry-picker__back,.expiry-picker__clear{background:transparent;border:none;color:#6c757d;cursor:pointer;font-size:.875rem;padding:.25rem .5rem}.expiry-picker__back:hover,.expiry-picker__clear:hover{color:#495057}.expiry-picker__never-overdue{font-size:1.75rem;line-height:1;display:flex;align-items:center;justify-content:center;height:2.5rem;overflow:hidden}.barcode-not-found{background:#dc3545e6;border-radius:12px;padding:1.5rem;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:350px;margin:0 auto;text-align:center}.barcode-not-found__content{display:flex;flex-direction:column;align-items:center;gap:1rem}.barcode-not-found__icon{font-size:3rem;margin-bottom:.5rem}.barcode-not-found__title{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.barcode-not-found__message{margin:0;font-size:.95rem;color:#ffffffe6;line-height:1.4}.barcode-not-found__barcode{font-size:.85rem;color:#ffffffb3;font-family:monospace;background:#0003;padding:.5rem 1rem;border-radius:6px;word-break:break-all}.barcode-not-found__actions{display:flex;gap:.75rem;width:100%}.barcode-not-found__clear-button,.barcode-not-found__manual-button{flex:1;padding:.75rem 1rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:48px;border:1px solid rgba(255,255,255,.3)}.barcode-not-found__clear-button{background:#fff3;color:#fff}.barcode-not-found__clear-button:hover{background:#ffffff4d;transform:translateY(-1px)}.barcode-not-found__manual-button{background:#ffffffe6;color:#dc3545}.barcode-not-found__manual-button:hover{background:#fff;transform:translateY(-1px)}@media (max-width: 480px){.barcode-not-found{padding:1rem;max-width:100%;margin:0 1rem}.barcode-not-found__icon{font-size:2.5rem}.barcode-not-found__title{font-size:1.1rem}.barcode-not-found__message{font-size:.9rem}.barcode-not-found__actions{flex-direction:column;gap:.5rem}.barcode-not-found__clear-button,.barcode-not-found__manual-button{font-size:.9rem;min-height:44px}}.purchase-feed{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;display:flex;flex-direction:column}.purchase-feed>*{pointer-events:auto}.purchase-feed__barcode{position:absolute;bottom:4rem;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:.5rem 1rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.875rem;z-index:10}.purchase-feed__barcode-not-found{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:20}.purchase-feed__bottom-controls{pointer-events:auto;margin:auto 12px 12px;align-self:stretch;display:flex;justify-content:space-between;align-items:flex-end;gap:12px;z-index:10}.purchase-feed__scan-controls{background:#000000b3;padding:1rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.purchase-feed__scan-controls .camera-controls__start-button{background:#007bff;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.purchase-feed__scan-controls .camera-controls__start-button:hover:not(:disabled){background:#0056b3}.purchase-feed__scan-controls .camera-controls__start-button:disabled{background:#ffffff4d;color:#ffffffb3;cursor:not-allowed}.purchase-feed__manual-button{background:#2563eb;color:#fff;border:1px solid #1d4ed8;width:96px;height:72px;padding:.5rem;border-radius:10px;cursor:pointer;font-size:.95rem;line-height:1.1;display:inline-flex;align-items:center;justify-content:center;text-align:center}.purchase-feed__manual-button:hover:not(:disabled){background:#1d4ed8}.grocery-list{max-width:600px;margin:0 auto;position:relative}.grocery-list__global-loading{position:fixed;top:1rem;right:1rem;z-index:1000}.grocery-list__loading-dot{width:8px;height:8px;background-color:#007bff;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.grocery-list__title{font-size:1.75rem;font-weight:600;color:#212529;margin-bottom:1.5rem;text-align:center}.grocery-list__content{background:#fff;padding:.125rem;box-shadow:0 2px 4px #0000001a}.grocery-list__toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:#495057}.grocery-list__toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.grocery-list__toggle-label{cursor:pointer}.grocery-list__placeholder{color:#6c757d;text-align:center;margin-bottom:1rem;font-size:1rem}.grocery-list__loading,.grocery-list__error,.grocery-list__empty{text-align:center;padding:2rem;color:#6c757d}.grocery-list__error{color:#dc3545}.grocery-list__retry-button,.grocery-list__refresh-button,.grocery-list__clear-button,.grocery-list__add-button{background:#007bff;color:#fff;border:none;padding:.75rem 1.25rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease;white-space:nowrap;min-height:2.5rem}.grocery-list__retry-button:hover,.grocery-list__refresh-button:hover{background:#0056b3}.grocery-list__add-button{background:#28a745;font-weight:600}.grocery-list__add-button:hover{background:#218838}.grocery-list__clear-button{background:#6c757d;font-size:.8rem;padding:.6rem 1rem}.grocery-list__clear-button:hover{background:#5a6268}.grocery-list__clear-button:disabled{background:#6c757d;cursor:not-allowed}.grocery-list__groups{display:flex;flex-direction:column;gap:.5rem}.grocery-list__group{background:#f8f9fa;border-radius:.5rem;border:1px solid #dee2e6;overflow:hidden}.grocery-list__group-title{background:#e9ecef;margin:0;padding:.25rem .5rem;font-size:.875rem;font-weight:600;color:#495057;border-bottom:1px solid #dee2e6}.grocery-list__items{display:flex;flex-direction:column}.grocery-list__item{display:flex;align-items:center;justify-content:space-between;padding:.25rem .5rem;background:#fff;border-bottom:1px solid #f1f3f4;transition:background-color .2s ease}.grocery-list__item:last-child{border-bottom:none}.grocery-list__item:hover{background:#f8f9fa}.grocery-list__item--done{opacity:.6;background:#f8f9fa}.grocery-list__item--done .grocery-list__item-name{text-decoration:line-through;color:#6c757d}.grocery-list__item--done .grocery-list__item-details{color:#adb5bd}.grocery-list__item--done .grocery-list__item-amount{background:#6c757d;color:#fff}.grocery-list__item--done .grocery-list__item-note{color:#adb5bd}.grocery-list__item-content{flex:1;display:flex;align-items:center;gap:.75rem}.grocery-list__item-name{font-weight:500;color:#212529;font-size:.875rem}.grocery-list__item-details{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6c757d}.grocery-list__item-amount{background:#007bff;color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-weight:600;font-size:.75rem;min-width:2rem;text-align:center;flex-shrink:0}.grocery-list__item-note{color:#6c757d;font-style:italic}.grocery-list__done-button{background:#28a745;color:#fff;border:none;width:1.75rem;height:1.75rem;border-radius:50%;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;margin-left:.5rem}.grocery-list__done-button:hover{background:#218838}.grocery-list__undo-button{background:#6c757d;color:#fff;border:none;width:1.75rem;height:1.75rem;border-radius:50%;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;margin-left:.5rem}.grocery-list__undo-button:hover{background:#5a6268}.grocery-list__aisle-button-small{background:#17a2b8;color:#fff;border:none;width:1.75rem;height:1.75rem;border-radius:50%;cursor:pointer;font-size:.625rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;margin-left:.25rem}.grocery-list__aisle-button-small:hover{background:#138496}.grocery-list__aisle-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.grocery-list__aisle-picker{background:#fff;border-radius:.5rem;padding:1.5rem;max-width:90vw;width:300px;box-shadow:0 4px 6px #0000001a}.grocery-list__aisle-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.grocery-list__aisle-picker-header h4{margin:0;font-size:1rem;color:#212529}.grocery-list__aisle-picker-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.grocery-list__aisle-picker-close:hover{color:#212529}.grocery-list__aisle-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.grocery-list__aisle-button{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;padding:.75rem;border-radius:.25rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease}.grocery-list__aisle-button:hover{background:#e9ecef;border-color:#adb5bd}.grocery-list__aisle-button--selected{background:#007bff;color:#fff;border-color:#007bff}.grocery-list__aisle-button--selected:hover{background:#0056b3;border-color:#0056b3}.grocery-list__actions{margin-top:2rem;display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:.5rem;border:1px solid #dee2e6}.grocery-list__actions-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.grocery-list__buttons-group{display:flex;gap:.5rem;flex-wrap:wrap}.grocery-list__floating-undo{position:fixed;z-index:1000;transform:translate(-50%,-50%);display:flex;align-items:center;gap:.5rem;background:#28a745;color:#fff;border-radius:.5rem;padding:.5rem;box-shadow:0 4px 12px #00000026;animation:grocery-list__floating-undo-appear .3s ease-out}.grocery-list__floating-undo-button{background:none;border:none;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background-color .2s ease}.grocery-list__floating-undo-button:hover{background:#fff3}.grocery-list__floating-undo-dismiss{background:none;border:none;color:#fff;font-size:1rem;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem}.grocery-list__floating-undo-dismiss:hover{background:#fff3}@keyframes grocery-list__floating-undo-appear{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes grocery-list__floating-undo-disappear{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.8)}}.grocery-list__floating-undo--disappearing{animation:grocery-list__floating-undo-disappear .2s ease-in forwards}.add-item-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.add-item-modal{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 25px #0003}.add-item-modal__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background-color:#f9fafb}.add-item-modal__header h2{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.add-item-modal__close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.add-item-modal__close:hover{background-color:#f3f4f6;color:#374151}.add-item-modal__body{flex:1;overflow-y:auto;padding:16px}.add-item-modal__field{margin-bottom:12px}.add-item-modal__field label{display:block;margin-bottom:4px;font-weight:500;color:#374151;font-size:14px}.add-item-modal__search-input,.add-item-modal__input,.add-item-modal__select{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:.375rem;font-size:1rem;background:#fff;color:#212529;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.add-item-modal__search-input:focus,.add-item-modal__input:focus,.add-item-modal__select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.add-item-modal__select option{color:#212529;background:#fff}.add-item-modal__product-list{max-height:min(300px,calc(100vh - 400px));overflow-y:auto;border:1px solid #e5e7eb;border-radius:6px;margin-top:8px}@supports (height: 100dvh){.add-item-modal__product-list{max-height:min(300px,calc(100dvh - 400px))}}.add-item-modal--keyboard-open .add-item-modal__product-list{max-height:min(300px,calc(100vh - 250px))}@supports (height: 100dvh){.add-item-modal--keyboard-open .add-item-modal__product-list{max-height:min(300px,calc(100dvh - 250px))}}@supports (height: 100svh){.add-item-modal__product-list{max-height:min(300px,calc(100svh - 250px))}.add-item-modal--keyboard-open .add-item-modal__product-list{max-height:min(300px,calc(100svh - 200px))}}.add-item-modal__product-item{padding:6px 10px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.add-item-modal__product-item:last-child{border-bottom:none}.add-item-modal__product-item:hover{background-color:#f9fafb}.add-item-modal__product-item.selected{background-color:#eff6ff;border-color:#dbeafe}.add-item-modal__new-product-option{background-color:#f0f9ff;color:#0369a1;font-weight:500}.add-item-modal__new-product-option:hover{background-color:#e0f2fe}.add-item-modal__product-name{font-weight:500;color:#111827;display:flex;align-items:center;gap:6px;font-size:.85rem}.add-item-modal__product-description{font-size:.75rem;color:#6b7280;margin-top:2px}.add-item-modal__product-stock{font-size:.7rem;color:#059669;font-weight:500}.add-item-modal__no-stock-badge{background-color:#e0f2fe;color:#0369a1;font-size:.65rem;padding:1px 4px;border-radius:8px;font-weight:500}.add-item-modal__new-product-form{background-color:#f8fafc;padding:12px;border-radius:6px;margin-top:8px}.add-item-modal__new-product-form h3{margin:0 0 12px;font-size:1rem;color:#374151}.add-item-modal__checkbox-field{display:flex;align-items:center}.add-item-modal__checkbox-field label{display:flex;align-items:center;margin-bottom:0;cursor:pointer;font-weight:400}.add-item-modal__checkbox-field input[type=checkbox]{margin-right:8px;width:auto}.add-item-modal__amount-container{display:flex;align-items:center;border:1px solid #ced4da;border-radius:.375rem;overflow:hidden;background:#fff;flex:1;min-width:0}.add-item-modal__amount-input{flex:1;border:none;padding:.5rem;text-align:center;font-size:1rem;background:#fff;color:#212529;min-width:0}.add-item-modal__amount-input:focus{outline:none;background:#f8f9fa}.add-item-modal__amount-input::-webkit-outer-spin-button,.add-item-modal__amount-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.add-item-modal__amount-input[type=number]{-moz-appearance:textfield}.add-item-modal__amount-buttons{display:flex;flex-direction:column;border-left:1px solid #ced4da}.add-item-modal__amount-btn{background:#f8f9fa;border:none;padding:.25rem;font-size:1rem;font-weight:600;color:#495057;cursor:pointer;transition:all .2s ease;min-width:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:0}.add-item-modal__amount-btn:first-child{border-bottom:1px solid #ced4da}.add-item-modal__amount-btn:hover:not(:disabled){background:#e9ecef;color:#212529}.add-item-modal__amount-btn:active:not(:disabled){background:#dee2e6}.add-item-modal__amount-btn:disabled{background:#f8f9fa;color:#adb5bd;cursor:not-allowed}.add-item-modal__footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #e5e7eb;background-color:#f9fafb}.add-item-modal__cancel-btn,.add-item-modal__add-btn{padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;font-size:14px}.add-item-modal__cancel-btn{background:#fff;border:1px solid #d1d5db;color:#374151}.add-item-modal__cancel-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.add-item-modal__add-btn{background-color:#3b82f6;border:1px solid #3b82f6;color:#fff}.add-item-modal__add-btn:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.add-item-modal__add-btn:disabled{background-color:#9ca3af;border-color:#9ca3af;cursor:not-allowed}@media (max-width: 640px){.add-item-modal-overlay{padding:10px}.add-item-modal{max-width:none;width:100%;max-height:95vh}.add-item-modal__header,.add-item-modal__body,.add-item-modal__footer{padding-left:16px;padding-right:16px}.add-item-modal__amount-container{flex-direction:row}.add-item-modal__amount-buttons{flex-direction:column;border-left:1px solid #ced4da;border-top:none}.add-item-modal__amount-btn{width:40px;height:30px;min-width:40px}.add-item-modal__amount-btn:first-child{border-bottom:1px solid #ced4da;border-right:none}.add-item-modal__parent-product-picker{flex:1}}.add-item-modal__parent-product-picker{position:relative;display:flex;align-items:center;gap:8px;flex:1}.add-item-modal__clear-parent{background:#ef4444;color:#fff;border:none;border-radius:50%;width:28px;height:28px;padding:0;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;flex-shrink:0}.add-item-modal__clear-parent:hover{background:#dc2626}.add-item-modal__selected-parent{background:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem;color:#374151;flex:1}.recipe-list-item{border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .2s ease}.recipe-list-item:hover{background-color:#f5f5f5}.recipe-list-item:active{background-color:#e0e0e0}.recipe-list-item__content{display:flex;justify-content:space-between;align-items:center;padding:.5rem;min-height:2rem}.recipe-list-item__name{font-size:1rem;font-weight:500;color:#333;flex:1}.recipe-list-item__status{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.recipe-list-item__icon{font-size:1rem}.recipe-list-item__text{color:#666;white-space:nowrap}.recipe-list{background-color:#fff}.recipe-list__container{padding:0}.recipe-suggestions{background:#fff;padding:12px 16px;border-bottom:1px solid #e9ecef}.recipe-suggestions__header{margin:0}.recipe-suggestions__button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #0d6efd;background:#0d6efd;color:#fff;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:.95rem}.recipe-suggestions__button[disabled]{opacity:.6;cursor:not-allowed}.recipe-suggestions__items{margin-top:12px}.recipe-ingredient-item{border-bottom:1px solid #e0e0e0;padding:.5rem 0}.recipe-ingredient-item:last-child{border-bottom:none}.recipe-ingredient-item__content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.recipe-ingredient-item__info{flex:1}.recipe-ingredient-item__name{font-weight:500;color:#333;margin-bottom:.25rem}.recipe-ingredient-item__amount{font-size:.875rem;color:#666}.recipe-ingredient-item__variable{color:#999;font-style:italic}.recipe-ingredient-item__stock{display:flex;align-items:center;gap:.5rem;font-size:.875rem;white-space:nowrap}.recipe-ingredient-item__status{font-size:1rem}.recipe-ingredient-item__cart-icon{font-size:.9rem}.recipe-ingredient-item__stock-amount{color:#666}.recipe-ingredient-item__note{margin-top:.5rem;font-size:.75rem;color:#666;font-style:italic;padding-left:1rem;border-left:2px solid #e0e0e0}.recipe-ingredient-item--available{background-color:#f8fff8}.recipe-ingredient-item--unavailable{background-color:#fff8f8}.recipe-detail{display:flex;flex-direction:column;min-height:100%;background-color:#fff}.recipe-detail__header{padding:1rem;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa}.recipe-detail__back-button{background:none;border:none;color:#007bff;font-size:.875rem;cursor:pointer;padding:.5rem 0;margin-bottom:.5rem}.recipe-detail__back-button:hover{text-decoration:underline}.recipe-detail__title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#333}.recipe-detail__servings{font-size:.875rem;color:#666}.recipe-detail__main{flex:1;padding:1rem}.recipe-detail__section-title{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#333}.recipe-detail__ingredients-list{margin-bottom:2rem}.recipe-detail__actions{border-top:1px solid #e0e0e0;padding-top:1rem}.recipe-detail__action-buttons{display:flex;flex-direction:column;gap:.75rem}.recipe-detail__action-button{padding:.75rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.recipe-detail__action-button--add-to-list{background-color:#007bff;color:#fff}.recipe-detail__action-button--add-to-list:hover{background-color:#0056b3}.recipe-detail__action-button--consume{background-color:#28a745;color:#fff}.recipe-detail__action-button--consume:hover:not(.recipe-detail__action-button--disabled){background-color:#1e7e34}.recipe-detail__action-button--disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.recipe-page{display:flex;flex-direction:column;min-height:100%;background-color:#f5f5f5}.recipe-page__header{background-color:#fff;padding:1rem;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000001a}.recipe-page__title{margin:0;font-size:1.5rem;font-weight:600;color:#333}.recipe-page__main{flex:1;display:flex;flex-direction:column}.recipe-page__loading,.recipe-page__error{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem;text-align:center}.loading-spinner{font-size:1.2rem;color:#666}.recipe-page__error h2{color:#d32f2f;margin-bottom:.5rem}.recipe-page__error p{color:#666;margin:0}.qr-scanner{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:500px;margin:0 auto}.qr-scanner__container{position:relative;width:100%;aspect-ratio:4/3;border-radius:8px;overflow:hidden;background:#000}.qr-scanner__camera{width:100%;height:100%}.qr-scanner__controls{display:flex;flex-direction:column;gap:1rem}.qr-scanner__device-selector,.qr-scanner__scan-controls,.qr-scanner__error{margin-bottom:0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-page__container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:40px;max-width:500px;width:100%}.login-page__title{text-align:center;margin:0 0 30px;color:#333;font-size:28px;font-weight:600}.login-page__content{display:flex;flex-direction:column;gap:24px}.login-page__description{text-align:center;color:#666;line-height:1.6;margin:0}.login-page__description code{background:#f5f5f5;padding:4px 8px;border-radius:4px;font-family:monospace;color:#e74c3c}.login-page__qr-section{display:flex;flex-direction:column;gap:16px}.login-page__camera-scanner{width:100%}.login-page__video{width:100%;height:100%;object-fit:cover}.login-page__manual-button{padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.login-page__manual-button{background:#007bff;color:#fff;width:100%}.login-page__manual-button:hover{background:#0056b3}.login-page__divider{text-align:center;position:relative;margin:16px 0}.login-page__divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#dee2e6}.login-page__divider span{background:#fff;padding:0 16px;color:#666;font-size:14px}.login-page__error{background:#f8d7da;color:#721c24;padding:12px;border-radius:6px;border:1px solid #f5c6cb;text-align:center}.login-page__success{background:#d4edda;color:#155724;padding:12px;border-radius:6px;border:1px solid #c3e6cb;text-align:center}.login-page__manual-form{display:flex;flex-direction:column;gap:16px}.login-page__form-group{display:flex;flex-direction:column;gap:8px}.login-page__form-label{font-weight:500;color:#333;font-size:14px}.login-page__form-input{padding:12px;border:1px solid #dee2e6;border-radius:6px;font-size:16px;transition:border-color .2s ease}.login-page__form-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.login-page__form-input::placeholder{color:#adb5bd}.login-page__form-actions{display:flex;gap:12px;margin-top:8px}.login-page__cancel-button,.login-page__submit-button{flex:1;padding:12px;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.login-page__cancel-button{background:#6c757d;color:#fff}.login-page__cancel-button:hover:not(:disabled){background:#5a6268}.login-page__submit-button{background:#28a745;color:#fff}.login-page__submit-button:hover:not(:disabled){background:#218838}.login-page__cancel-button:disabled,.login-page__submit-button:disabled{opacity:.6;cursor:not-allowed}.pwa-status-container{width:100%}.pwa-status-grid{display:flex;flex-direction:column;gap:12px}.pwa-status-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.pwa-status-item--full{justify-content:center;margin-top:8px}.pwa-status-label{font-weight:500;color:#495057;font-size:14px}.pwa-status-value{font-weight:600;font-size:14px;display:flex;align-items:center;gap:4px}.pwa-status-value--success{color:#198754}.pwa-status-value--warning{color:#fd7e14}.pwa-status-value--info{color:#0d6efd}.pwa-install-button{background:#0d6efd;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:8px}.pwa-install-button:hover{background:#0b5ed7;transform:translateY(-1px);box-shadow:0 4px 12px #0d6efd4d}.pwa-install-button:active{background:#0a58ca;transform:translateY(0)}@media (max-width: 768px){.pwa-status-item{flex-direction:column;align-items:flex-start;gap:8px}.pwa-status-value{align-self:flex-end}}.settings-page{background:#f8f9fa;min-height:100%;display:flex;flex-direction:column}.settings-page__container{max-width:600px;margin:0 auto;background:#fff;flex:1;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:1rem}.settings-page__title{background:#007bff;color:#fff;margin:0;padding:1.5rem;font-size:1.5rem;font-weight:600;text-align:center}.settings-page__content{padding:1.5rem}.settings-page__section{margin-bottom:2rem}.settings-page__section:last-child{margin-bottom:0}.settings-page__section-title{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.settings-page__config-info{background:#f8f9fa;border-radius:8px;padding:1rem}.settings-page__config-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e9ecef}.settings-page__config-item:last-child{border-bottom:none}.settings-page__config-label{font-weight:500;color:#495057;font-size:.9rem}.settings-page__config-value{font-family:monospace;color:#6c757d;font-size:.85rem;word-break:break-all;text-align:right;flex:1;overflow:hidden}.settings-page__config-value--full{max-width:100%;width:100%;text-align:left;font-family:inherit;color:inherit}.settings-page__input{width:100%;max-width:100%;padding:.5rem .75rem;border:1px solid #ced4da;border-radius:6px;font-size:.95rem;background:#fff;color:#212529;box-sizing:border-box;display:block}.settings-page__picker-list{margin-top:.5rem;border:1px solid #ced4da;border-radius:6px;background:#fff;max-height:240px;overflow:auto;box-shadow:0 2px 6px #0000000d}.settings-page__picker-item,.settings-page__picker-new{padding:.5rem .75rem;cursor:pointer}.settings-page__picker-item:hover,.settings-page__picker-new:hover{background:#f1f3f5}.settings-page__input:focus{outline:none;border-color:#86b7fe;box-shadow:0 0 0 .1rem #0d6efd26}.settings-page__actions{display:flex;flex-direction:column;gap:.75rem}.settings-page__action-button{display:flex;align-items:center;gap:.75rem;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.settings-page__action-button--primary{background:#007bff;color:#fff}.settings-page__action-button--primary:hover{background:#0056b3}.settings-page__action-button--warning{background:#ffc107;color:#212529}.settings-page__action-button--warning:hover{background:#e0a800}.settings-page__action-button--danger{background:#dc3545;color:#fff}.settings-page__action-button--danger:hover{background:#c82333}.settings-page__action-button--quiet{background:#e9ecef;color:#495057}.settings-page__action-button--quiet:hover{background:#dee2e6}.settings-page__action-button:disabled{opacity:.5;cursor:not-allowed;background:#e9ecef!important;color:#6c757d!important}.settings-page__action-button:disabled:hover{background:#e9ecef!important;color:#6c757d!important}.settings-page__action-icon{font-size:1.25rem;flex-shrink:0}.settings-page__action-text{flex:1}.settings-page__about{background:#f8f9fa;border-radius:8px;padding:1rem}.settings-page__about-text{margin:0 0 .5rem;color:#6c757d;font-size:.9rem;line-height:1.5}.settings-page__about-text:last-child{margin-bottom:0}.settings-page__pwa-info{background:#f8f9fa;border-radius:8px;padding:1rem}.settings-page__pwa-status{width:100%}@media (min-width: 768px){.settings-page{padding:2rem}.settings-page__actions{flex-direction:row;flex-wrap:wrap}.settings-page__action-button{flex:1;min-width:200px}}.settings-page__excluded-list{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}.settings-page__excluded-item{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid #ced4da;border-radius:999px;background:#f1f3f5;color:#343a40;font-size:.9rem}.settings-page__excluded-name{line-height:1}.settings-page__excluded-remove{border:none;background:transparent;color:#6c757d;cursor:pointer;padding:0 4px;line-height:1;font-size:.9rem}.settings-page__excluded-remove:hover{color:#212529}
