:root{--color-bg:#faf8f5;--color-surface:#fff;--color-surface-2:#f3f0eb;--color-border:#e8e2d9;--color-text:#2c2418;--color-text-muted:#7a6f62;--color-primary:#2d6a4f;--color-primary-light:#40916c;--color-primary-bg:#d8f3dc;--color-accent:#bc6c25;--color-danger:#c1121f;--color-danger-bg:#fde8ea;--color-warning:#e09f3e;--color-warning-bg:#fef3e2;--color-success:#2d6a4f;--radius:12px;--radius-lg:16px;--shadow:0 2px 8px #2c241814;--shadow-lg:0 8px 24px #2c24181f;--nav-height:calc(64px + env(safe-area-inset-bottom,0px));--touch-target:44px;--header-height:80px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);color:var(--color-text);background:var(--color-bg);font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100dvh;background:var(--color-bg);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:-webkit-fill-available;padding-left:var(--safe-left);padding-right:var(--safe-right)}#root{min-height:100dvh;min-height:-webkit-fill-available}.app{min-height:100dvh;background:var(--color-bg);flex-direction:column;width:100%;max-width:640px;min-height:-webkit-fill-available;margin:0 auto;display:flex}.app-header{padding:calc(.75rem + var(--safe-top)) 1rem .75rem;background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;flex-shrink:0}.header-brand{align-items:center;gap:.625rem;display:flex}.header-brand h1{letter-spacing:-.02em;font-size:1.375rem;font-weight:700}.header-subtitle{opacity:.85;margin-top:.25rem;margin-left:2rem;font-size:.875rem}.app-main{padding:.875rem .875rem calc(var(--nav-height) + .875rem);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;overflow:hidden auto}.bottom-nav{width:100%;max-width:640px;min-height:var(--nav-height);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--color-border);padding:.375rem .5rem var(--safe-bottom);z-index:100;background:#ffffffeb;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-btn{min-height:var(--touch-target);min-width:var(--touch-target);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius);touch-action:manipulation;-webkit-user-select:none;user-select:none;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.15rem;padding:.375rem .5rem;font-size:.6875rem;font-weight:600;transition:color .15s,background .15s;display:flex}.nav-btn:active{transform:scale(.96)}.nav-btn.active,.nav-btn-add{color:var(--color-primary)}.nav-btn-add .lucide,.nav-btn-add svg{background:var(--color-primary-bg);border-radius:50%;padding:.25rem}.nav-btn-add.active{background:var(--color-primary-bg)}.stats-banner{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.5rem;margin-bottom:.875rem;padding-bottom:.125rem;display:flex;overflow-x:auto}.stats-banner::-webkit-scrollbar{display:none}.stat-card{scroll-snap-align:start;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);min-width:9.5rem;color:var(--color-primary);flex:none;align-items:center;gap:.625rem;padding:.75rem;display:flex}.stat-card.warning{color:var(--color-warning);background:var(--color-warning-bg);border-color:#0000}.stat-card.danger{color:var(--color-danger);background:var(--color-danger-bg);border-color:#0000}.stat-card.muted{color:var(--color-text-muted)}.stat-value{font-size:1.25rem;font-weight:700;line-height:1.2;display:block}.stat-label{color:inherit;opacity:.8;font-size:.7rem;display:block}.btn{min-height:var(--touch-target);border-radius:var(--radius);cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:1rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--color-surface-2);color:var(--color-text)}.btn-full{width:100%;padding:.875rem}.btn-icon{min-width:var(--touch-target);min-height:var(--touch-target);background:var(--color-surface-2);color:var(--color-text);border-radius:50%;padding:.625rem}.btn-touch{min-width:var(--touch-target);min-height:var(--touch-target)}.btn-sm{min-width:var(--touch-target);min-height:var(--touch-target);padding:.5rem}.btn-capture{border:4px solid var(--color-primary);background:#fff;border-radius:50%;flex-shrink:0;width:72px;min-width:72px;height:72px;min-height:72px;padding:0}.capture-ring{background:var(--color-primary);border-radius:50%;width:48px;height:48px;display:block}.camera-capture{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);margin-bottom:1rem;overflow:hidden}.camera-header{background:var(--color-surface-2);padding:.625rem 1rem}.camera-source-badge{color:var(--color-text-muted);font-size:.8125rem;font-weight:600}.camera-viewport{aspect-ratio:3/4;background:#1a1a1a;justify-content:center;align-items:center;max-height:min(55dvh,480px);display:flex;position:relative}@media (orientation:landscape) and (height<=500px){.camera-viewport{aspect-ratio:4/3;max-height:40dvh}}.camera-video,.camera-preview{object-fit:cover;width:100%;height:100%;display:block}.camera-video.mirrored{transform:scaleX(-1)}.camera-error{color:#aaa;text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;font-size:.875rem;display:flex}.camera-controls{background:var(--color-surface-2);justify-content:center;align-items:center;gap:1.25rem;padding:1rem 1.25rem;display:flex}.btn-full-mobile{flex:1;max-width:280px}.add-item-form{flex-direction:column;gap:.875rem;display:flex}.source-toggle{background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);gap:.5rem;padding:.375rem;display:flex}.source-btn{min-height:var(--touch-target);border-radius:calc(var(--radius) - 4px);color:var(--color-text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;flex:1;padding:.75rem .625rem;font-size:.9375rem;font-weight:600;transition:background .15s,color .15s}.source-btn.active{background:var(--color-primary);color:#fff}.form-section{flex-direction:column;gap:.375rem;display:flex}.form-section label{color:var(--color-text-muted);font-size:.8125rem;font-weight:600}.form-section input,.form-section select,.form-section textarea{width:100%;min-height:var(--touch-target);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);appearance:none;padding:.75rem .875rem;font-family:inherit;font-size:16px}.form-section textarea{resize:vertical;min-height:5rem}.form-section input:focus,.form-section select:focus,.form-section textarea:focus{outline:2px solid var(--color-primary-bg);border-color:var(--color-primary-light)}.form-row{grid-template-columns:1fr;gap:.75rem;display:grid}@media (width>=400px){.form-row{grid-template-columns:1fr 1fr}}.form-error{background:var(--color-danger-bg);color:var(--color-danger);border-radius:var(--radius);padding:.75rem;font-size:.875rem}.expiration-hint{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:.375rem;padding:.75rem;display:flex}.expiration-hint p{color:var(--color-text-muted);font-size:.8125rem;line-height:1.4}.exp-mode-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:999px;align-items:center;width:fit-content;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.exp-mode-badge.mode-use_by{background:var(--color-danger-bg);color:var(--color-danger)}.exp-mode-badge.mode-best_by{background:var(--color-warning-bg);color:var(--color-accent)}.exp-mode-badge.mode-replace_by{color:#3949ab;background:#e8eaf6}.exp-mode-badge.mode-none{background:var(--color-surface-2);color:var(--color-text-muted)}.suggest-btn{min-height:var(--touch-target);border:1px dashed var(--color-primary-light);border-radius:var(--radius);background:var(--color-primary-bg);color:var(--color-primary);cursor:pointer;touch-action:manipulation;align-items:center;gap:.35rem;margin-top:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:600;display:inline-flex}.opened-toggle{min-height:var(--touch-target);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;touch-action:manipulation;align-items:center;gap:.75rem;padding:.875rem .75rem;font-size:.9375rem;display:flex}.opened-toggle input{width:1.25rem;height:1.25rem;accent-color:var(--color-primary);flex-shrink:0}.item-opened-tag{text-transform:uppercase;background:var(--color-warning);color:#fff;border-radius:4px;padding:1px 4px;font-size:.6rem;font-weight:700;position:absolute;bottom:4px;left:4px}.search-bar{min-height:var(--touch-target);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);align-items:center;gap:.625rem;margin-bottom:.75rem;padding:0 .875rem;display:flex}.search-bar input{min-height:var(--touch-target);color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-size:16px}.filters{gap:.5rem;margin-bottom:.75rem;display:flex}.filters select{min-height:var(--touch-target);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);flex:1;padding:.625rem .75rem;font-size:16px}.expiring-notice{background:var(--color-warning-bg);color:var(--color-accent);border-radius:var(--radius);align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.625rem .875rem;font-size:.8125rem;font-weight:600;display:flex}.item-grid{flex-direction:column;gap:.75rem;display:flex}.item-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow);gap:.875rem;padding:.875rem;display:flex}.item-card.exp-expired,.item-card.exp-urgent{border-left:4px solid var(--color-danger)}.item-card.exp-soon{border-left:4px solid var(--color-warning)}.item-card-photo{border-radius:var(--radius);background:var(--color-surface-2);flex-shrink:0;width:96px;height:96px;position:relative;overflow:hidden}.item-card-photo img{object-fit:cover;width:100%;height:100%}.item-card-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;display:flex}.item-source-tag{background:#ffffffe6;border-radius:4px;padding:1px 3px;font-size:.75rem;position:absolute;top:4px;right:4px}.item-card-body{flex:1;min-width:0}.item-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.item-card-header h3{font-size:1rem;font-weight:700;line-height:1.3}.item-card-menu{position:relative}.item-menu-trigger{flex-shrink:0;margin:-.375rem -.375rem 0 0}.action-sheet-root{z-index:200;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.action-sheet-backdrop{cursor:pointer;background:#00000073;border:none;animation:.2s fade-in;position:absolute;inset:0}.action-sheet{background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:640px;padding-bottom:calc(.75rem + var(--safe-bottom));box-shadow:var(--shadow-lg);animation:.25s slide-up;position:relative}.action-sheet-handle{background:var(--color-border);border-radius:999px;width:2.5rem;height:.25rem;margin:.625rem auto 0}.action-sheet-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem .5rem;display:flex}.action-sheet-header h4{text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:700;overflow:hidden}.action-sheet-close{flex-shrink:0}.action-sheet-actions{flex-direction:column;padding:.375rem 0;display:flex}.action-sheet-btn{width:100%;min-height:3.25rem;color:var(--color-text);text-align:left;cursor:pointer;touch-action:manipulation;background:0 0;border:none;align-items:center;gap:.875rem;padding:.875rem 1.25rem;font-size:1rem;font-weight:500;display:flex}.action-sheet-btn:active{background:var(--color-surface-2)}.action-sheet-btn.destructive{color:var(--color-danger)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.item-card-meta{flex-wrap:wrap;gap:.375rem;margin-top:.375rem;display:flex}.meta-chip{background:var(--color-surface-2);color:var(--color-text-muted);border-radius:999px;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.7rem;display:inline-flex}.item-card-description{color:var(--color-text-muted);margin-top:.375rem;font-size:.8125rem}.item-card-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.625rem;display:flex}.quantity-controls{align-items:center;gap:.5rem;display:flex}.quantity-display{text-align:center;min-width:3rem;font-size:.875rem;font-weight:600}.expiration-badge{border-radius:999px;padding:.25rem .5rem;font-size:.7rem;font-weight:600}.expiration-badge.exp-expired,.expiration-badge.exp-urgent{background:var(--color-danger-bg);color:var(--color-danger)}.expiration-badge.exp-soon{background:var(--color-warning-bg);color:var(--color-accent)}.expiration-badge.exp-ok{background:var(--color-primary-bg);color:var(--color-primary)}.item-purchase-date{color:var(--color-text-muted);margin-top:.375rem;font-size:.7rem}.empty-state,.loading-state{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.empty-state h3{color:var(--color-text);font-size:1.125rem}.empty-state p{max-width:280px;font-size:.875rem}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.setup-screen{min-height:100dvh;min-height:-webkit-fill-available;padding:calc(1rem + var(--safe-top)) 1rem calc(1rem + var(--safe-bottom));justify-content:center;align-items:center;display:flex}.setup-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);max-width:480px;box-shadow:var(--shadow-lg);text-align:center;padding:2rem}.setup-card h1{margin:1rem 0 .75rem;font-size:1.5rem}.setup-card p{color:var(--color-text-muted);margin-bottom:1rem;font-size:.9375rem}.setup-code{text-align:left;color:#d4edda;border-radius:var(--radius);background:#1a1a1a;margin-bottom:1rem;padding:1rem 1.25rem;font-size:.875rem;line-height:1.6;overflow-x:auto}.setup-note{font-size:.8125rem!important}code{background:var(--color-surface-2);border-radius:4px;padding:.125rem .375rem;font-size:.85em}@media (width>=640px){.stats-banner{grid-template-columns:repeat(4,1fr);display:grid;overflow-x:visible}.stat-card{min-width:0}.app-main,.app-header{padding-left:1.25rem;padding-right:1.25rem}}.signin-btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-bottom:.75rem;padding:.875rem;font-size:.9375rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.signin-btn:active{transform:scale(.98)}.signin-btn:disabled{opacity:.6;cursor:not-allowed}.signin-btn-secondary{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.app-header{position:relative}.signout-btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);width:2.25rem;height:2.25rem;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;transition:background .15s,transform .1s;display:inline-flex;position:absolute;top:1rem;right:1rem}.signout-btn:hover{background:var(--color-surface)}.signout-btn:active{transform:scale(.95)}.scan-inventory{flex-direction:column;gap:1rem;display:flex}.scan-intro{background:var(--color-primary-bg);border-radius:var(--radius);color:var(--color-primary);align-items:flex-start;gap:.625rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.scan-intro svg{flex-shrink:0;margin-top:.125rem}.scan-review{flex-direction:column;gap:.875rem;display:flex}.scan-review-header h2{font-size:1.125rem;font-weight:700}.scan-review-header p{color:var(--color-text-muted);margin-top:.25rem;font-size:.875rem}.scan-review-list{flex-direction:column;gap:.625rem;list-style:none;display:flex}.scan-review-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);gap:.625rem;padding:.75rem;display:flex}.scan-review-item.deselected{opacity:.55}.scan-item-select{align-items:flex-start;padding-top:.25rem;display:flex}.scan-item-select input{width:1.125rem;height:1.125rem;accent-color:var(--color-primary)}.scan-item-summary{flex:1;justify-content:space-between;align-items:flex-start;gap:.5rem;min-width:0;display:flex}.scan-item-main{gap:.625rem;min-width:0;display:flex}.scan-item-icon{font-size:1.25rem;line-height:1.2}.scan-item-main strong{font-size:.9375rem;line-height:1.3;display:block}.scan-item-meta,.scan-item-description{color:var(--color-text-muted);margin-top:.125rem;font-size:.75rem;display:block}.scan-item-actions{flex-shrink:0;gap:.25rem;display:flex}.scan-item-editor{flex-direction:column;flex:1;gap:.5rem;display:flex}.scan-item-editor input,.scan-item-editor select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:100%;padding:.5rem .625rem;font-size:.875rem}.scan-editor-actions{justify-content:flex-end;gap:.5rem;display:flex}.manual-add-link{color:var(--color-primary);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;align-self:center;padding:.5rem;font-size:.875rem;font-weight:600;text-decoration:underline}.manual-add-link:active{opacity:.8}
