@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.user-selector{position:relative}.user-selector__google-wrapper{align-items:flex-end;gap:var(--space-2);flex-direction:column;display:flex}.user-selector--loading{align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.user-selector__spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.user-selector__trigger-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--text-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);display:flex}.user-selector__trigger-btn:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-glow-green)}.user-selector__form{gap:var(--space-2);flex-direction:column;display:flex}.user-selector__input-row{gap:var(--space-2);align-items:center;display:flex}.user-selector__input{padding:var(--space-2) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--text-sm);font-family:var(--font-sans);width:180px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.user-selector__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.user-selector__input--error{border-color:var(--color-critical)}.user-selector__submit-btn{padding:var(--space-2) var(--space-3);background:var(--color-primary);color:#000;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast), transform var(--transition-fast);border:none}.user-selector__submit-btn:hover:not(:disabled){background:#86efac;transform:translateY(-1px)}.user-selector__submit-btn:disabled{opacity:.5;cursor:not-allowed}.user-selector__cancel-btn{padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0}.user-selector__cancel-btn:hover{color:var(--color-critical);border-color:var(--color-critical)}.user-selector__error{font-size:var(--text-xs);color:var(--color-critical)}.user-selector__avatar{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);font-size:var(--text-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);display:flex}.user-selector__avatar:hover{border-color:var(--color-primary);box-shadow:var(--shadow-glow-green)}.user-selector__avatar-img{object-fit:cover;border:1.5px solid var(--color-border);border-radius:50%;flex-shrink:0;width:26px;height:26px}.user-selector__avatar-placeholder{font-size:1rem}.user-selector__avatar-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:500;overflow:hidden}.user-selector__chevron{font-size:var(--text-xs);color:var(--color-text-muted);transition:transform var(--transition-fast)}.user-selector__chevron--up{transform:scaleY(-1)}.user-selector__dropdown{top:calc(100% + var(--space-2));background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-lg);padding:var(--space-3);gap:var(--space-3);z-index:200;flex-direction:column;animation:.15s both fadeInUp;display:flex;position:absolute;right:0}.user-selector__dropdown-info{flex-direction:column;gap:2px;display:flex}.user-selector__dropdown-label{font-size:var(--text-xs);color:var(--color-text-faint)}.user-selector__dropdown-email{font-size:var(--text-sm);color:var(--color-primary);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.user-selector__logout-btn{padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-sm);font-family:var(--font-sans);cursor:pointer;text-align:center;transition:all var(--transition-fast)}.user-selector__logout-btn:hover{color:var(--color-critical);border-color:var(--color-critical)}@media (width<=540px){.user-selector__avatar-name,.user-selector__chevron{display:none}.user-selector__avatar{padding:var(--space-1);border-radius:50%}.user-selector__avatar-img{width:32px;height:32px}.user-selector__google-wrapper{zoom:.75}}.layout{flex-direction:column;min-height:100vh;display:flex}.layout__header{z-index:100;padding:var(--space-4) var(--space-8);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--space-4);background:#0f1117d9;display:flex;position:sticky;top:0}.layout__logo{align-items:center;gap:var(--space-2);text-decoration:none;display:flex}.layout__logo-icon{filter:drop-shadow(0 0 8px #4ade8080);font-size:1.75rem}.layout__logo-text{font-size:var(--text-xl);background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-weight:700}@media (width<=540px){.layout__header{padding:var(--space-3) var(--space-4)}.layout__main{padding:var(--space-5) var(--space-4)}.layout__logo-text{font-size:.8rem}}.layout__main{width:100%;max-width:1100px;padding:var(--space-8) var(--space-6);padding-bottom:calc(64px + var(--space-8));flex:1;margin:0 auto}.layout__footer{text-align:center;padding:var(--space-6);color:var(--color-text-faint);font-size:var(--text-xs);border-top:1px solid var(--color-border)}.savings-score{gap:var(--space-4);flex-direction:column;display:flex}.savings-score__hero{border-radius:var(--radius-xl);padding:var(--space-8) var(--space-8) var(--space-6);gap:var(--space-5);flex-direction:column;display:flex;position:relative;overflow:hidden}.savings-score__hero--green{box-shadow:0 0 40px #4ade801f, var(--shadow-lg);background:linear-gradient(135deg,#052e16 0%,#14532d 60%,#166534 100%);border:1px solid #4ade804d}.savings-score__hero--red{box-shadow:0 0 40px #f871711f, var(--shadow-lg);background:linear-gradient(135deg,#2d0a0a 0%,#4c1414 60%,#7f1d1d 100%);border:1px solid #f871714d}.savings-score__hero-main{gap:var(--space-2);flex-direction:column;display:flex}.savings-score__hero-eyebrow{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.1em;color:#fff9;font-weight:500}.savings-score__hero-amount{letter-spacing:-.02em;color:#fff;font-size:4rem;font-weight:800;line-height:1}.savings-score__hero--green .savings-score__hero-amount{color:#86efac;text-shadow:0 0 40px #4ade8080}.savings-score__hero--red .savings-score__hero-amount{color:#fca5a5;text-shadow:0 0 40px #f8717180}.savings-score__hero-sub{font-size:var(--text-xs);color:#ffffff73;line-height:1.5}.savings-score__streak-chip{bottom:3.5rem;right:var(--space-6);font-size:var(--text-sm);color:#fb923c;border-radius:var(--radius-full);letter-spacing:.02em;background:#fb923c2e;border:1px solid #fb923c59;padding:3px 10px;font-weight:700;position:absolute}.savings-score__illustration{width:72px;height:72px;top:var(--space-6);right:var(--space-6);opacity:.85;flex-shrink:0;position:absolute}.savings-score__illustration svg{width:100%;height:100%}.savings-score__level-badge{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.savings-score__level-badge-text{font-size:var(--text-xs);color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.savings-score__bar-wrap{border-radius:var(--radius-full);background:#ffffff1a;width:100%;height:4px;overflow:hidden}.savings-score__bar-fill{border-radius:var(--radius-full);height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.savings-score__hero--green .savings-score__bar-fill{background:linear-gradient(90deg,#16a34a,#4ade80)}.savings-score__hero--red .savings-score__bar-fill{background:linear-gradient(90deg,#dc2626,#f87171)}.savings-score__cards{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.savings-score__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);align-items:flex-start;gap:var(--space-1);transition:border-color var(--transition-fast);flex-direction:column;min-width:0;display:flex;overflow:hidden}.savings-score__card-label,.savings-score__card-sub{overflow-wrap:break-word;word-break:break-word;width:100%}.savings-score__card--green{border-color:#4ade8040}.savings-score__card--red{border-color:#f8717140}.savings-score__card--blue{border-color:#60a5fa40}.savings-score__card--amber{border-color:#fbbf2440}.savings-score__card-icon{width:36px;height:36px;margin-bottom:var(--space-1)}.savings-score__card-emoji{margin-bottom:var(--space-1);font-size:1.6rem;line-height:1}.savings-score__card-value{font-size:var(--text-xl);color:var(--color-text);font-weight:700;line-height:1}.savings-score__card--green .savings-score__card-value{color:var(--color-primary)}.savings-score__card--red .savings-score__card-value{color:var(--color-critical)}.savings-score__card--blue .savings-score__card-value{color:#60a5fa}.savings-score__card--amber .savings-score__card-value{color:#fbbf24}.savings-score__card-content{flex-direction:column;gap:2px;display:flex}.savings-score__card-label{font-size:var(--text-sm);color:var(--color-text);margin-top:var(--space-1);font-weight:500}.savings-score__card-sub{font-size:var(--text-xs);color:var(--color-text-muted)}.savings-score__empty{text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);padding:var(--space-2) 0}@media (width<=540px){.savings-score__hero{padding:var(--space-5)}.savings-score__hero-amount{font-size:2.75rem}.savings-score__illustration{display:none}.savings-score__cards{gap:var(--space-2);grid-template-columns:1fr 1fr}}.dashboard{gap:var(--space-8);flex-direction:column;display:flex}.dashboard--guest{justify-content:center;align-items:center;min-height:calc(100vh - 140px)}.dashboard__guest-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-10);align-items:center;gap:var(--space-5);text-align:center;width:100%;max-width:480px;box-shadow:var(--shadow-lg);flex-direction:column;animation:.5s both fadeInUp;display:flex}.dashboard__guest-icon{filter:drop-shadow(0 0 24px #4ade8066);font-size:4rem;animation:3s infinite pulse-ring}.dashboard__guest-title{font-size:var(--text-3xl);background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.dashboard__guest-subtitle{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.7}.dashboard__guest-steps{gap:var(--space-3);width:100%;margin-top:var(--space-2);flex-direction:column;display:flex}.dashboard__step{align-items:center;gap:var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);text-align:left;display:flex}.dashboard__step-num{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#000;width:24px;height:24px;font-size:var(--text-xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.dashboard__error{background:var(--color-critical-bg);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--color-critical);font-size:var(--text-sm);border:1px solid #f871714d}.chat-fab{z-index:600;background:var(--color-surface);border:2px solid var(--color-border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.3rem;transition:transform .25s cubic-bezier(.175,.885,.32,1.275),box-shadow .2s;display:flex;position:fixed;bottom:calc(64px + 1rem);right:1.25rem;box-shadow:0 4px 16px #0000002e}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px #00000040}.product-card{align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);animation:.3s both fadeInUp;display:flex;position:relative}.product-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-hover);transform:translateY(-2px)}.product-card--critical{border-left:3px solid var(--color-critical)}.product-card--warning{border-left:3px solid var(--color-warning)}.product-card--ok{border-left:3px solid var(--color-ok)}.product-card--unknown{border-left:3px solid var(--color-text-faint)}.product-card__icon{background:var(--color-surface-2);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:2rem;display:flex}.product-card__body{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.product-card__header{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.product-card__name{font-size:var(--text-base);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.product-card__badge{font-size:var(--text-xs);padding:2px var(--space-2);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;font-weight:600}.product-card__badge--critical{background:var(--color-critical-bg);color:var(--color-critical);border:1px solid #f871714d}.product-card__badge--warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid #fb923c4d}.product-card__badge--ok{background:var(--color-ok-bg);color:var(--color-ok);border:1px solid #4ade804d}.product-card__badge--unknown{color:var(--color-text-faint);background:#47556933;border:1px solid #4755694d}.product-card__category{font-size:var(--text-xs);color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.05em}.product-card__expiry{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.product-card__expiry-date{font-size:var(--text-sm);color:var(--color-text-muted)}.product-card__days{font-size:var(--text-xs);font-weight:600}.product-card__days--critical{color:var(--color-critical)}.product-card__days--warning{color:var(--color-warning)}.product-card__days--ok{color:var(--color-ok)}.product-card__days--unknown{color:var(--color-text-faint)}.product-card__meta{color:var(--color-text-muted);flex-wrap:wrap;gap:8px;margin-top:8px;font-size:.8rem;display:flex}.product-card__partial{gap:var(--space-2);margin-top:var(--space-2);display:flex}.product-card__partial-input{width:110px;padding:var(--space-1) var(--space-2);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--text-xs);font-family:var(--font-sans);outline:none}.product-card__partial-input:focus{border-color:var(--color-primary)}.product-card__partial-btn{padding:var(--space-1) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-xs);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.product-card__partial-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.product-card__actions{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.product-card__action-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000}.product-card__action-btn--consume{color:var(--color-primary);background:#4ade801f;border-color:#4ade804d}.product-card__action-btn--consume:hover{background:#4ade8038}.product-card__action-btn--waste{color:var(--color-critical);background:#f871711a;border-color:#f871714d}.product-card__action-btn--waste:hover{background:#f8717133}.product-card__action-btn--edit{background:var(--color-surface-2);border-color:var(--color-border);color:var(--color-text-muted)}.product-card__action-btn--edit:hover{border-color:var(--color-accent);color:var(--color-accent)}@media (width<=600px){.product-card{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.product-card__icon{width:40px;height:40px;font-size:1.6rem}.product-card__partial{gap:var(--space-2);flex-direction:column}.product-card__partial-input{width:100%}.product-card__partial-btn{text-align:center;width:100%}}.product-card__delete-btn{cursor:pointer;opacity:.35;transition:opacity var(--transition-fast), transform var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast);padding:var(--space-1);border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;flex-shrink:0;align-self:flex-start;font-size:1rem;line-height:1}.product-card:hover .product-card__delete-btn{opacity:1}.product-card__delete-btn:hover{background:var(--color-critical-bg);border-color:#f871714d;transform:scale(1.2)}.product-list{gap:var(--space-4);flex-direction:column;display:flex}.product-list__header{justify-content:space-between;align-items:center;display:flex}.product-list__title{font-size:var(--text-xl);font-weight:700}.product-list__count{font-size:var(--text-xs);color:var(--color-text-faint);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:2px var(--space-3);font-weight:600}.product-list__grid{gap:var(--space-3);flex-direction:column;display:flex}.product-list--loading{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-12) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.product-list__spinner-ring{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.product-list--empty{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-12) var(--space-8);text-align:center;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.product-list__empty-icon{font-size:3rem;animation:2.5s infinite pulse-ring}.product-list__empty-title{font-size:var(--text-xl);color:var(--color-text-muted);font-weight:600}.product-list__empty-text{font-size:var(--text-sm);color:var(--color-text-faint);max-width:300px}.not-found{justify-content:center;align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;min-height:calc(100vh - 140px);animation:.4s fadeInUp;display:flex}.not-found__icon{font-size:4rem}.not-found__title{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:5rem;font-weight:700;line-height:1}.not-found__subtitle{color:var(--color-text-muted);font-size:var(--text-lg)}.not-found__link{margin-top:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-primary);font-size:var(--text-sm);transition:all var(--transition-fast);font-weight:500}.not-found__link:hover{background:var(--color-primary-glow);border-color:var(--color-primary)}.bottom-nav{background:var(--color-surface);border-top:1px solid var(--color-border);z-index:500;height:64px;padding-bottom:env(safe-area-inset-bottom);justify-content:space-between;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:visible}.bottom-nav__tab{padding:var(--space-2) 0;color:var(--color-text-muted);transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;text-decoration:none;display:flex}.bottom-nav__tab--active{color:var(--color-primary)}.bottom-nav__tab-icon{font-size:1.3rem;line-height:1}.bottom-nav__tab-label{letter-spacing:.02em;text-transform:uppercase;font-size:.62rem;font-weight:600}.bottom-nav__center{flex:0 0 80px;justify-content:center;align-items:center;height:64px;display:flex;position:relative}.bottom-nav__fab{background:var(--color-primary);color:#000;cursor:pointer;z-index:10;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:2.2rem;font-weight:300;line-height:1;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),background .2s,box-shadow .2s;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #4ade8073}.bottom-nav__fab--open{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);transform:translate(-50%)rotate(45deg);box-shadow:0 4px 20px #00000040}.bottom-nav__fan-item{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;opacity:0;pointer-events:none;z-index:9;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:48px;height:48px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),opacity .2s;display:flex;position:absolute;bottom:12px;left:50%;box-shadow:0 4px 16px #0003}.bottom-nav__fan-item--open{opacity:1;pointer-events:auto}.bottom-nav__fan-item:hover{background:var(--color-bg-alt);border-color:var(--color-primary)}.bottom-nav__fan-icon{font-size:1.1rem;line-height:1}.bottom-nav__fan-label{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:.48rem;font-weight:700}.bottom-nav__backdrop{z-index:499;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;position:fixed;inset:0}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0006;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;padding:2rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideUp;position:relative;overflow-y:auto;box-shadow:0 10px 30px #0003}.modal-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;transition:background .2s,color .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:var(--color-bg-alt);color:var(--color-text)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.image-uploader{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);gap:var(--space-4);flex-direction:column;animation:.4s both fadeInUp;display:flex}.image-uploader__title{font-size:var(--text-2xl);color:var(--color-text);font-weight:700}.image-uploader__subtitle{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:calc(var(--space-1) * -1)}.image-uploader__dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);justify-content:center;align-items:center;gap:var(--space-3);cursor:pointer;transition:all var(--transition-normal);background:var(--color-surface-2);text-align:center;flex-direction:column;display:flex}.image-uploader__dropzone:hover,.image-uploader__dropzone--active{border-color:var(--color-primary);background:var(--color-primary-glow);box-shadow:var(--shadow-glow-green)}.image-uploader__dropzone-icon{transition:transform var(--transition-normal);font-size:2.5rem}.image-uploader__dropzone:hover .image-uploader__dropzone-icon{transform:scale(1.15)}.image-uploader__dropzone-text{color:var(--color-text-muted);font-size:var(--text-sm)}.image-uploader__dropzone-text strong{color:var(--color-primary)}.image-uploader__dropzone-hint{font-size:var(--text-xs);color:var(--color-text-faint)}.image-uploader__preview{gap:var(--space-4);flex-direction:column;align-items:center;display:flex}.image-uploader__preview-img{border-radius:var(--radius-lg);object-fit:contain;border:1px solid var(--color-border);max-width:100%;max-height:320px;box-shadow:var(--shadow-md);animation:.3s fadeInUp}.image-uploader__preview-actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.image-uploader__btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;display:flex}.image-uploader__btn--primary{background:linear-gradient(135deg, var(--color-primary) 0%, #22c55e 100%);color:#000;box-shadow:0 4px 16px #4ade804d}.image-uploader__btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #4ade8073}.image-uploader__btn--primary:disabled{opacity:.6;cursor:not-allowed}.image-uploader__btn--secondary{background:var(--color-surface-2);color:var(--color-text-muted);border:1px solid var(--color-border)}.image-uploader__btn--secondary:hover:not(:disabled){border-color:var(--color-critical);color:var(--color-critical)}.image-uploader__btn--secondary:disabled{opacity:.5;cursor:not-allowed}.image-uploader__spinner{border:2px solid #0000004d;border-top-color:#000;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@media (width<=540px){.image-uploader{padding:var(--space-4)}.image-uploader__title{font-size:var(--text-lg)}.image-uploader__dropzone{padding:var(--space-6) var(--space-4)}.image-uploader__dropzone-icon{font-size:1.75rem}}.image-uploader__error{color:var(--color-critical);background:var(--color-critical-bg);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border:1px solid #f871714d}.image-uploader__success{color:var(--color-primary);background:var(--color-ok-bg);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border:1px solid #4ade804d}.camera-view{background:var(--color-surface);border-radius:var(--radius-lg);flex-direction:column;width:100%;display:flex;overflow:hidden}.camera-view__header{text-align:center;border-bottom:1px solid var(--color-border);padding:1rem}.camera-view__title{margin:0;font-size:1.1rem;font-weight:600}.camera-view__error{text-align:center;color:var(--color-critical);background:var(--color-critical-bg);justify-content:center;align-items:center;min-height:300px;padding:2rem;display:flex}.camera-view__video-container{background:#000;justify-content:center;align-items:center;width:100%;min-height:300px;max-height:60vh;display:flex;position:relative;overflow:hidden}.camera-view__video{object-fit:cover;width:100%;height:100%}.camera-view__controls{background:var(--color-surface);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.camera-view__btn-secondary{background:var(--color-bg-alt);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;border:none;padding:.75rem 1.25rem;font-weight:600;transition:background .2s}.camera-view__btn-secondary:hover{background:var(--color-border)}.camera-view__btn-capture{border:4px solid var(--color-primary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;padding:4px;transition:transform .2s;display:flex}.camera-view__btn-capture:hover{transform:scale(1.05)}.camera-view__btn-capture-inner{background:var(--color-primary);border-radius:50%;width:100%;height:100%;transition:transform .1s}.camera-view__btn-capture:active .camera-view__btn-capture-inner{transform:scale(.9)}.item-form{gap:var(--space-5);flex-direction:column;width:100%;display:flex}.item-form__title{font-size:var(--text-xl);color:var(--color-text);font-weight:700}.item-form__grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.item-form__label{gap:var(--space-1);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);flex-direction:column;font-weight:500;display:flex}.item-form__label--full{grid-column:1/-1}.item-form__input{padding:var(--space-2) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);font-family:var(--font-sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:100%}.item-form__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.item-form__select{cursor:pointer}.item-form__error{font-size:var(--text-sm);color:var(--color-critical);background:var(--color-critical-bg);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);border:1px solid #f871714d}.item-form__actions{gap:var(--space-3);justify-content:flex-end;display:flex}.item-form__btn{padding:var(--space-2) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none}.item-form__btn--cancel{background:var(--color-surface-2);color:var(--color-text-muted);border:1px solid var(--color-border)}.item-form__btn--cancel:hover:not(:disabled){border-color:var(--color-critical);color:var(--color-critical)}.item-form__btn--save{background:linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));color:#000}.item-form__btn--save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #4ade804d}.item-form__btn:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.item-form__grid{grid-template-columns:1fr}}.barcode-scanner{flex-direction:column;align-items:center;gap:1rem;min-height:420px;padding:1.5rem;display:flex}.barcode-scanner__header{justify-content:space-between;align-items:center;width:100%;display:flex}.barcode-scanner__title{color:var(--color-text);margin:0;font-size:1.15rem;font-weight:700}.barcode-scanner__close{background:var(--color-surface-2,var(--color-bg-alt));border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:1rem;transition:background .2s;display:flex}.barcode-scanner__close:hover{background:var(--color-bg)}.barcode-scanner__viewport{aspect-ratio:4/3;border-radius:var(--radius-lg);background:#000;width:100%;max-width:360px;position:relative;overflow:hidden}.barcode-scanner__video{object-fit:cover;width:100%;height:100%;display:block}.barcode-scanner__error{text-align:center;height:100%;color:var(--color-critical,#ef4444);background:#ef444414;justify-content:center;align-items:center;padding:1rem;font-size:.9rem;display:flex}.barcode-scanner__frame{pointer-events:none;position:absolute;inset:15%}.barcode-scanner__frame-corner{border-color:var(--color-primary,#a3e635);border-style:solid;border-width:0;width:22px;height:22px;position:absolute}.barcode-scanner__frame-corner--tl{border-top-width:3px;border-left-width:3px;border-top-left-radius:4px;top:0;left:0}.barcode-scanner__frame-corner--tr{border-top-width:3px;border-right-width:3px;border-top-right-radius:4px;top:0;right:0}.barcode-scanner__frame-corner--bl{border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:4px;bottom:0;left:0}.barcode-scanner__frame-corner--br{border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:4px;bottom:0;right:0}.barcode-scanner__scan-line{background:linear-gradient(90deg, transparent 0%, var(--color-primary,#a3e635) 30%, var(--color-primary,#a3e635) 70%, transparent 100%);height:2px;box-shadow:0 0 8px var(--color-primary,#a3e635);animation:2s ease-in-out infinite barcodeScanLine;position:absolute;left:0;right:0}.barcode-scanner__hint{color:var(--color-text-muted);text-align:center;min-height:1.4em;margin:0;font-size:.85rem}.barcode-scanner__cancel-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:.55rem 2rem;font-size:.9rem;transition:background .2s,color .2s}.barcode-scanner__cancel-btn:hover{background:var(--color-bg-alt);color:var(--color-text)}@keyframes barcodeScanLine{0%{top:5%}50%{top:90%}to{top:5%}}.voice-overlay{z-index:10;background:var(--color-surface);border-radius:inherit;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;padding:1.5rem;display:flex;position:absolute;inset:0}.voice-overlay__close{background:var(--color-bg-alt);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.9rem;transition:background .2s;display:flex;position:absolute;top:1rem;right:1rem}.voice-overlay__close:hover{background:var(--color-bg)}.voice-overlay__broccoli{-webkit-user-select:none;user-select:none;filter:drop-shadow(0 4px 16px #0003);font-size:5rem;line-height:1;transition:transform .2s}.voice-overlay__broccoli--speaking{animation:.35s ease-in-out infinite alternate broccoliSpeak}.voice-overlay__broccoli--listening{animation:.9s ease-in-out infinite broccoliListen}.voice-overlay__status{color:var(--color-text-muted);text-align:center;max-width:260px;min-height:2.4em;margin:0;font-size:.92rem;line-height:1.4}.voice-overlay__wave{align-items:flex-end;gap:4px;height:28px;display:flex}.voice-overlay__bar{background:linear-gradient(to top, var(--color-primary,#a3e635), var(--color-accent,#86efac));border-radius:3px;width:5px;animation:.8s ease-in-out infinite alternate soundBar;display:block}.voice-overlay__bar:first-child{height:40%}.voice-overlay__bar:nth-child(2){height:70%}.voice-overlay__bar:nth-child(3){height:100%}.voice-overlay__bar:nth-child(4){height:70%}.voice-overlay__bar:nth-child(5){height:40%}.voice-overlay__mic{background:linear-gradient(135deg, var(--color-primary,#a3e635) 0%, var(--color-accent,#4ade80) 100%);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;font-size:1.8rem;transition:transform .2s cubic-bezier(.175,.885,.32,1.275),box-shadow .2s;display:flex;box-shadow:0 4px 20px #a3e63559}.voice-overlay__mic:hover:not(.voice-overlay__mic--disabled){transform:scale(1.1);box-shadow:0 6px 28px #a3e63580}.voice-overlay__mic--active{background:linear-gradient(135deg,#ef4444 0%,#f97316 100%);animation:1s ease-in-out infinite micPulse;box-shadow:0 4px 20px #ef444466}.voice-overlay__mic--disabled{opacity:.5;cursor:not-allowed}.voice-overlay__hint{color:var(--color-text-muted);opacity:.7;text-align:center;margin:0;font-size:.75rem}@keyframes broccoliSpeak{0%{transform:rotate(-4deg)scale(1.04)}to{transform:rotate(4deg)scale(1.1)}}@keyframes broccoliListen{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes soundBar{0%{transform:scaleY(.3)}to{transform:scaleY(1)}}@keyframes micPulse{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 12px #ef444400}}.chat-modal-overlay{z-index:3000;pointer-events:none;justify-content:flex-end;align-items:flex-end;padding:6rem 1.5rem 6.5rem;display:flex;position:fixed;inset:0}.chat-modal{pointer-events:all;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;width:100%;max-width:420px;max-height:70vh;animation:.3s cubic-bezier(.175,.885,.32,1.275) chatSlideUp;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000059}.chat-modal__header{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.chat-modal__header-title{align-items:center;gap:.75rem;display:flex}.chat-modal__header-icon{font-size:1.8rem}.chat-modal__title{color:#000;margin:0;font-size:1rem;font-weight:700}.chat-modal__subtitle{color:#000000b3;margin:0;font-size:.72rem}.chat-modal__close{color:#000;cursor:pointer;background:#00000026;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;transition:background .2s;display:flex}.chat-modal__close:hover{background:#00000040}.chat-modal__messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:.75rem;min-height:200px;padding:1rem;display:flex;overflow-y:auto}.chat-modal__message{align-items:flex-end;gap:.5rem;display:flex}.chat-modal__message--user{flex-direction:row-reverse}.chat-modal__avatar{flex-shrink:0;font-size:1.4rem}.chat-modal__bubble{border-radius:var(--radius-lg);white-space:pre-wrap;word-break:break-word;max-width:78%;padding:.65rem 1rem;font-size:.9rem;line-height:1.5}.chat-modal__message--agent .chat-modal__bubble{background:var(--color-surface-2,var(--color-bg-alt));border:1px solid var(--color-border);color:var(--color-text);border-bottom-left-radius:4px}.chat-modal__message--user .chat-modal__bubble{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#000;border-bottom-right-radius:4px;font-weight:500}.chat-modal__bubble--loading{align-items:center;gap:5px;padding:.85rem 1.1rem;display:flex}.chat-modal__bubble--loading span{background:var(--color-text-muted);border-radius:50%;width:8px;height:8px;animation:1.2s infinite chatBounce}.chat-modal__bubble--loading span:nth-child(2){animation-delay:.2s}.chat-modal__bubble--loading span:nth-child(3){animation-delay:.4s}.chat-modal__input-row{border-top:1px solid var(--color-border);flex-shrink:0;align-items:flex-end;gap:.5rem;padding:.75rem 1rem .5rem;display:flex}.chat-modal__input{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);resize:none;outline:none;flex:1;max-height:100px;padding:.6rem .9rem;font-family:inherit;font-size:.9rem;line-height:1.4;transition:border-color .2s;overflow-y:auto}.chat-modal__input:focus{border-color:var(--color-primary)}.chat-modal__input:disabled{opacity:.5}.chat-modal__send{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#000;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;transition:transform .2s,opacity .2s;display:flex}.chat-modal__send:hover:not(:disabled){transform:scale(1.08)}.chat-modal__send:disabled{opacity:.4;cursor:not-allowed}.chat-modal__mic{background:var(--color-bg-alt);border:1px solid var(--color-border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:background .2s,transform .2s;display:flex}.chat-modal__mic:hover{background:var(--color-surface);transform:scale(1.1)}.chat-modal__hint{text-align:center;color:var(--color-text-muted);flex-shrink:0;margin:0;padding:0 1rem .5rem;font-size:.68rem}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes chatBounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}@media (width<=480px){.chat-modal-overlay{justify-content:stretch;align-items:flex-end;padding:0}.chat-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:100%;max-height:80vh}}:root{--color-bg:#0f1117;--color-surface:#1a1d27;--color-surface-2:#21253a;--color-border:#ffffff14;--color-border-hover:#ffffff2e;--color-primary:#4ade80;--color-primary-dark:#16a34a;--color-primary-glow:#4ade8026;--color-accent:#818cf8;--color-accent-glow:#818cf826;--color-critical:#f87171;--color-critical-bg:#f871711a;--color-warning:#fb923c;--color-warning-bg:#fb923c1a;--color-ok:#4ade80;--color-ok-bg:#4ade8014;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-text-faint:#475569;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow-green:0 0 20px #4ade8033;--shadow-glow-red:0 0 20px #f8717133;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:600;line-height:1.25}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:#86efac}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-2);border-radius:var(--radius-full)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-ring{0%{opacity:.8;transform:scale(.85)}50%{opacity:.4;transform:scale(1)}to{opacity:.8;transform:scale(.85)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in-up{animation:fadeInUp var(--transition-slow) both}
