*,*:before,*:after{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#212121;background:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100dvh}#root{min-height:100dvh}h1,h2,h3,h4{margin:0}img{display:block;max-width:100%}.scanner{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.scanner__viewport{position:relative;width:100%;max-width:480px;aspect-ratio:4 / 3;background:#000;border-radius:12px;overflow:hidden}.scanner__video{width:100%;height:100%;object-fit:cover}.scanner__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0009}.scanner__guide{position:absolute;inset:20%;border:2px solid rgba(255,255,255,.6);border-radius:8px;pointer-events:none;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{border-color:#fff6}50%{border-color:#1a73e8e6}}.scanner__stop{margin-top:4px}.scanner__toolbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.scanner__manual{display:flex;gap:8px;width:100%;max-width:480px}.scanner__manual-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:Courier New,monospace;background:#fafafa;transition:border-color .15s}.scanner__manual-input:focus{outline:none;border-color:#1a73e8;background:#fff}.scanner__error{color:#d32f2f;font-size:.875rem;text-align:center}.scanner__feedback{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:.875rem;width:100%;max-width:480px}.scanner__feedback--info{background:#e3f2fd;color:#1565c0}.scanner__feedback--warn{background:#fff3e0;color:#e65100}.scanner__feedback--success{background:#e8f5e9;color:#2e7d32}.scanner__feedback--error{background:#ffebee;color:#c62828}.scanner__feedback-close{margin-left:auto;background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;opacity:.6}.scanner__checking{font-size:.875rem;color:#666;animation:blink 1s steps(3,end) infinite}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}.scanner__counter{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:#555;padding:6px 14px;background:#f1f3f4;border-radius:20px}.scanner__counter-num{font-weight:700;font-size:1rem;color:#1a73e8}.capture{display:flex;flex-direction:column;align-items:center;gap:16px;padding:8px;width:100%}.capture__title{font-size:1.1rem;font-weight:600}.capture__barcode{font-family:Courier New,monospace;background:#eee;padding:2px 8px;border-radius:4px}.capture__slots{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:480px}.capture__slot{display:flex;flex-direction:column;align-items:center;gap:8px}.capture__slot h3{font-size:.9rem;margin:0;color:#555}.capture__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;aspect-ratio:3 / 4;background:#f0f0f0;border:2px dashed #ccc;border-radius:8px;cursor:pointer;font-size:.85rem;color:#666;transition:background .2s}.capture__placeholder:active{background:#e0e0e0}.capture__icon{font-size:2rem}.capture__preview{width:100%;aspect-ratio:3 / 4;object-fit:cover;border-radius:8px}.capture__input{display:none}.capture__actions{display:flex;gap:12px}.zoomable{position:relative;width:100%;aspect-ratio:3 / 4;overflow:hidden;background:#000;border-radius:10px;touch-action:none;user-select:none;-webkit-user-select:none}.zoomable__img{width:100%;height:100%;object-fit:contain;transform-origin:center center;will-change:transform;transition:transform .05s linear;pointer-events:none}.zoomable__reset{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:.8rem;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.nutrition-form{width:100%;max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.nutrition-form__lang-row{display:flex;gap:4px;justify-content:flex-end}.nutrition-form__lang-btn{padding:3px 10px;border:1px solid #ccc;border-radius:6px;background:#f5f5f5;font-size:.75rem;font-weight:600;cursor:pointer;color:#666;transition:all .15s}.nutrition-form__lang-btn--active{background:#1a73e8;border-color:#1a73e8;color:#fff}.nutrition-form__hint{font-size:.8125rem;color:#666;margin:-8px 0 0;background:#f0f7ff;padding:8px 12px;border-radius:8px;border:1px solid #c8dff7}.nutrition-form__unit-toggle{display:flex;align-items:center;gap:8px}.nutrition-form__unit-label{font-size:.8125rem;font-weight:600;color:#444}.nutrition-form__unit-btn{padding:5px 12px;border:1px solid #ccc;border-radius:6px;background:#f5f5f5;font-size:.8125rem;cursor:pointer;color:#555;transition:all .15s}.nutrition-form__unit-btn--active{background:#1a73e8;border-color:#1a73e8;color:#fff}.nutrition-form__section{display:flex;flex-direction:column;gap:10px}.nutrition-form__fieldset{border:1px solid #e0e0e0;border-radius:10px;padding:12px;margin:0}.nutrition-form__fieldset--muted{opacity:.7;border-style:dashed}.nutrition-form__legend{font-size:.8125rem;font-weight:700;color:#333;padding:0 6px}.nutrition-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.nutrition-form__label{display:flex;flex-direction:column;gap:3px}.nutrition-form__label-text{font-size:.75rem;font-weight:600;color:#444}.nutrition-form__input-wrap{display:flex;align-items:center;gap:4px}.nutrition-form__input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;background:#fafafa;transition:border-color .15s}.nutrition-form__input:focus{outline:none;border-color:#1a73e8;background:#fff}.nutrition-form__label--num .nutrition-form__input{text-align:right;padding-right:4px}.nutrition-form__unit{font-size:.75rem;color:#888;min-width:24px}.nutrition-form__salt-note{font-size:.75rem;color:#666;margin:0 0 8px;font-style:italic}.nutrition-form__auto{font-size:.625rem;color:#999;font-weight:400}.nutrition-form__toggle{background:none;border:none;padding:0;font:inherit;font-size:.8125rem;font-weight:700;color:#333;cursor:pointer;display:flex;align-items:center;gap:6px}.nutrition-form__micro-entry{display:flex;flex-direction:column;gap:3px}.nutrition-form__micro-header{display:flex;align-items:center;justify-content:space-between}.nutrition-form__micro-remove{background:none;border:none;color:#b71c1c;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 2px;opacity:.6;transition:opacity .15s}.nutrition-form__micro-remove:hover{opacity:1}.nutrition-form__micro-add{grid-column:1 / -1;margin-top:8px}.nutrition-form__micro-picker{margin-top:10px;padding:10px;border:1px solid #d0e3f7;border-radius:8px;background:#f5f9ff;display:flex;flex-direction:column;gap:10px}.nutrition-form__micro-presets{display:flex;flex-wrap:wrap;gap:6px}.nutrition-form__micro-preset-btn{padding:4px 10px;border:1px solid #c8dff7;border-radius:14px;background:#fff;font-size:.75rem;cursor:pointer;color:#1a73e8;transition:all .15s}.nutrition-form__micro-preset-btn:hover{background:#1a73e8;color:#fff;border-color:#1a73e8}.nutrition-form__micro-custom{display:flex;flex-direction:column;gap:6px;padding-top:6px;border-top:1px solid #d0e3f7}.nutrition-form__micro-custom-row{display:flex;gap:6px;align-items:center}.nutrition-form__micro-custom-row .nutrition-form__input--text{flex:1}.nutrition-form__input--select{padding:8px 6px;border:1px solid #ddd;border-radius:8px;font-size:.875rem;background:#fafafa;width:60px}.nutrition-form__warnings{padding:10px 12px;border-radius:8px;background:#fff8e1;border:1px solid #ffe082;display:flex;flex-direction:column;gap:4px}.nutrition-form__warnings--error{background:#fce4ec;border-color:#ef9a9a}.nutrition-form__warning{font-size:.8125rem;margin:0;line-height:1.35;color:#5d4037}.nutrition-form__warnings--error .nutrition-form__warning{color:#b71c1c}.nutrition-form__actions{display:flex;gap:10px;padding-top:8px}.nutrition-form__actions .btn{flex:1}.detail{display:flex;flex-direction:column;width:100%;max-width:900px;margin:0 auto;gap:0}.detail__header{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid #eee;flex-wrap:wrap}.detail__barcode{font-family:Courier New,monospace;font-size:.85rem;font-weight:600;color:#333}.detail__name{font-size:.85rem;color:#666}.detail__image-section{display:flex;flex-direction:column}.detail__side-tabs{display:flex;gap:0;border-bottom:1px solid #eee}.detail__side-tab{flex:1;padding:8px 0;background:none;border:none;border-bottom:2px solid transparent;font-size:.85rem;font-weight:600;color:#888;cursor:pointer;transition:color .15s,border-color .15s}.detail__side-tab--active{color:#1a73e8;border-bottom-color:#1a73e8}.detail__image-wrap{width:100%;height:45vh;min-height:200px;max-height:400px;background:#f5f5f5}.detail__no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#bbb;font-size:.9rem}.detail__form-section{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}.detail__toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:8px 20px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:1000;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(min-width:700px){.detail{flex-direction:column}.detail__image-section{max-height:50vh}.detail__image-wrap{height:50vh;max-height:500px}}.gallery{width:100%;display:flex;flex-direction:column;gap:0}.gallery--empty{text-align:center;padding:40px 16px;color:#888}.gallery__hint{font-size:.85rem;color:#aaa}.gallery__progress{display:flex;align-items:center;gap:10px;padding:10px 12px 6px}.gallery__progress-bar{flex:1;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.gallery__progress-fill{height:100%;background:#43a047;border-radius:3px;transition:width .3s ease;min-width:2px}.gallery__progress-text{font-size:.75rem;font-weight:600;color:#666;white-space:nowrap}.gallery__search{display:flex;align-items:center;gap:0;padding:4px 12px 8px;position:relative}.gallery__search-input{width:100%;padding:7px 32px 7px 10px;border:1px solid #ddd;border-radius:8px;font-size:.85rem;background:#fafafa;transition:border-color .15s}.gallery__search-input:focus{outline:none;border-color:#1a73e8;background:#fff}.gallery__search-clear{position:absolute;right:18px;background:none;border:none;font-size:.85rem;color:#999;cursor:pointer;padding:4px}.gallery__filters{display:flex;gap:0;border-bottom:1px solid #eee;padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.gallery__filter{padding:10px 12px;background:none;border:none;border-bottom:2px solid transparent;font-size:.8rem;font-weight:600;color:#888;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:5px}.gallery__filter--active{color:#1a73e8;border-bottom-color:#1a73e8}.gallery__filter-badge{background:#ef5350;color:#fff;font-size:.65rem;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}.gallery__list{display:flex;flex-direction:column;gap:1px;background:#eee}.card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;cursor:pointer;transition:background .12s}.card:active{background:#f5f5f5}.card--needs-nutrition{border-left:3px solid #ff9800}.card__thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#f5f5f5}.card__thumb-img{width:100%;height:100%;object-fit:cover}.card__thumb-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.card__row{display:flex;align-items:center;gap:6px}.card__row--meta{justify-content:space-between}.card__barcode{font-family:Courier New,monospace;font-size:.82rem;font-weight:600;color:#333}.card__product-name{font-size:.78rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card__date{font-size:.7rem;color:#aaa}.card__nutrition-status{font-size:.7rem;font-weight:600}.card__nutrition-status--done{color:#2e7d32}.card__nutrition-status--missing{color:#e65100}.card__delete{flex-shrink:0;background:none;border:none;font-size:1rem;padding:4px;cursor:pointer;opacity:.4;transition:opacity .15s}.card__delete:hover{opacity:1}.badge{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:8px;white-space:nowrap}.badge--pending{background:#fff3e0;color:#e65100}.badge--synced{background:#e8f5e9;color:#2e7d32}.badge--error{background:#ffebee;color:#c62828}.sync{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;width:100%;max-width:480px}.sync__row{display:flex;align-items:center;gap:8px}.sync__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sync__dot--online{background:#4caf50}.sync__dot--offline{background:#bdbdbd}.sync__label{font-size:.85rem;color:#555}.sync__pending{font-size:.85rem;font-weight:600;color:#e65100}.sync__spinner{width:14px;height:14px;border:2px solid #ddd;border-top-color:#1a73e8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sync__controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.sync__toggle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#555;cursor:pointer}.sync__toggle input{accent-color:#1a73e8}.login{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:#f5f5f5;padding:16px}.login__card{background:#fff;border-radius:16px;padding:32px 24px;width:100%;max-width:380px;box-shadow:0 2px 12px #00000014;text-align:center}.login__title{font-size:1.6rem;color:#1a73e8;margin:0 0 4px}.login__subtitle{font-size:.9rem;color:#888;margin:0 0 24px}.login__form{display:flex;flex-direction:column;gap:12px}.login__input{padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.login__input:focus{border-color:#1a73e8}.login__error{color:#c62828;font-size:.85rem;margin:0}.login__submit{margin-top:4px;width:100%;padding:12px}.login__toggle{background:none;border:none;color:#1a73e8;font-size:.85rem;cursor:pointer;margin-top:16px;padding:0}.login__toggle:hover{text-decoration:underline}.login__version{margin-top:16px;font-size:.7rem;color:#999;text-align:center}.user-mgmt{width:100%;max-width:600px}.user-mgmt__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.user-mgmt__title{font-size:1.2rem;font-weight:700;color:#333;margin:0}.user-mgmt__error{color:#c62828;background:#ffebee;padding:8px 12px;border-radius:8px;font-size:.85rem;margin-bottom:12px}.user-mgmt__loading,.user-mgmt__empty{text-align:center;color:#888;padding:24px 0}.user-mgmt__list{display:flex;flex-direction:column;gap:8px}.user-row{background:#fff;border-radius:10px;border:1px solid #e0e0e0;overflow:hidden}.user-row--inactive{opacity:.65}.user-row__summary{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.user-row__info{display:flex;flex-direction:column;gap:2px}.user-row__name{font-weight:600;font-size:.95rem;color:#333}.user-row__email{font-size:.8rem;color:#888}.user-row__badges{display:flex;align-items:center;gap:6px}.user-row__chevron{font-size:.7rem;color:#aaa;margin-left:4px}.badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.badge--admin{background:#e3f2fd;color:#1565c0}.badge--active{background:#e8f5e9;color:#2e7d32}.badge--inactive{background:#fce4ec;color:#c62828}.user-row__details{padding:0 16px 16px;border-top:1px solid #f0f0f0}.user-row__actions{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.user-row__reset{display:flex;gap:8px;align-items:center;margin-bottom:8px}.user-row__reset .user-form__input{flex:1;margin:0}.user-row__feedback{font-size:.8rem;color:#1565c0;background:#e3f2fd;padding:6px 10px;border-radius:6px;margin:8px 0}.user-row__meta{font-size:.75rem;color:#aaa;margin:4px 0 0}.user-form{background:#fff;border-radius:10px;border:1px solid #e0e0e0;padding:16px;margin-bottom:16px}.user-form__title{font-size:1rem;font-weight:600;margin:0 0 12px;color:#333}.user-form__input{display:block;width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;margin-bottom:10px;box-sizing:border-box}.user-form__input:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e826}.user-form__checkbox{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#555;margin-bottom:12px;cursor:pointer}.user-form__error{color:#c62828;font-size:.8rem;margin-bottom:8px}.user-form__actions{display:flex;gap:8px}.app{display:flex;flex-direction:column;min-height:100dvh;background:#f5f5f5}.header{display:flex;flex-direction:column;gap:8px;padding:16px;background:#fff;border-bottom:1px solid #e0e0e0;align-items:center}.header__title{font-size:1.4rem;font-weight:700;color:#1a73e8;margin:0}.header__row{display:flex;align-items:center;justify-content:space-between;width:100%}.nav{display:flex;background:#fff;border-bottom:1px solid #e0e0e0}.nav__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 0;border:none;background:none;font-size:.95rem;font-weight:500;color:#888;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.nav__tab--active{color:#1a73e8;border-bottom-color:#1a73e8}.nav__icon{font-size:1.1rem}.nav__badge{background:#e65100;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.main{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:8px;font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:opacity .2s,background .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:#1a73e8;color:#fff}.btn--primary:hover:not(:disabled){background:#1557b0}.btn--secondary{background:#e0e0e0;color:#333}.btn--secondary:hover:not(:disabled){background:#d0d0d0}.btn--danger{background:#ffebee;color:#c62828}.btn--danger:hover:not(:disabled){background:#ffcdd2}.btn--small{padding:6px 12px;font-size:.8rem}
