: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;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.9375rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.375rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--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;--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(.875rem + var(--safe-top)) var(--space-4) .875rem;background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;flex-shrink:0;position:relative}.header-brand{align-items:center;gap:.625rem;display:flex}.header-brand h1{font-size:var(--text-xl);letter-spacing:-.02em;font-weight:700}.header-subtitle{font-size:var(--text-sm);opacity:.85;margin-top:var(--space-1);margin-left:2rem}.header-side{top:calc(.875rem + var(--safe-top));right:var(--space-4);align-items:center;gap:var(--space-2);display:flex;position:absolute}.header-user{text-overflow:ellipsis;white-space:nowrap;max-width:8.5rem;font-size:var(--text-xs);color:#fff;background:#ffffff29;border:1px solid #ffffff40;border-radius:999px;padding:.25rem .625rem;font-weight:600;overflow:hidden}.signout-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff4d;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;transition:background .15s,transform .1s;display:inline-flex}.signout-btn:hover{background:#ffffff38}.signout-btn:active{transform:scale(.95)}.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);font-size:var(--text-xs);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-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-add-fab{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;margin-top:-1.375rem;transition:transform .15s;display:flex;box-shadow:0 4px 12px #2d6a4f66}.nav-btn-add:active .nav-add-fab{transform:scale(.92)}.stats-banner{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.375rem;margin-bottom:.625rem;padding-bottom:.125rem;display:flex;overflow-x:auto}.stats-banner::-webkit-scrollbar{display:none}.stat-card{align-items:center;gap:var(--space-2);scroll-snap-align:start;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);min-width:7.5rem;min-height:3.25rem;color:var(--color-primary);text-align:left;cursor:pointer;touch-action:manipulation;flex:none;padding:.5rem .625rem;font-family:inherit;transition:transform .1s,box-shadow .15s;display:flex}button.stat-card:hover{box-shadow:var(--shadow)}button.stat-card:active{transform:scale(.97)}.stat-card.warning{color:var(--color-accent);background:var(--color-warning-bg);border-color:color-mix(in srgb, var(--color-warning) 40%, transparent)}.stat-card.danger{color:var(--color-danger);background:var(--color-danger-bg);border-color:color-mix(in srgb, var(--color-danger) 35%, transparent)}.stat-card.zero,.stat-card.muted{color:var(--color-text-muted)}.stat-value{font-size:var(--text-lg);font-weight:700;line-height:1.2;display:block}.stat-label{color:inherit;opacity:.8;font-size:.625rem;display:block}.stat-card-skeleton{cursor:default;flex-direction:column;justify-content:center;align-items:flex-start;gap:.375rem}.skeleton-line{background:linear-gradient(90deg, var(--color-surface-2) 25%, var(--color-border) 50%, var(--color-surface-2) 75%);background-size:200% 100%;border-radius:4px;width:70%;height:.75rem;animation:1.4s infinite shimmer}.skeleton-line.short{width:45%;height:.5rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.btn{justify-content:center;align-items:center;gap:var(--space-2);min-height:var(--touch-target);border-radius:var(--radius);font-size:var(--text-md);cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;border:none;padding:.625rem 1.25rem;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-danger{background:var(--color-danger);color:#fff}.btn-danger-ghost{color:var(--color-danger);border:1px solid color-mix(in srgb, var(--color-danger) 35%, transparent);background:0 0}.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}.photo-picker{margin-bottom:var(--space-4)}.photo-picker-selected{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex}.photo-picker-thumb{object-fit:cover;border-radius:var(--radius);background:var(--color-surface-2);flex-shrink:0;width:72px;height:72px}.photo-picker-actions{align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex}.photo-picker-actions .btn-secondary{flex:1;min-width:0}.photo-picker-multi{padding:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.photo-picker-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(72px,1fr));margin:0;padding:0;list-style:none;display:grid}.photo-picker-grid-item{aspect-ratio:1;border-radius:var(--radius);background:var(--color-surface-2);position:relative;overflow:hidden}.photo-picker-grid-item img{object-fit:cover;width:100%;height:100%;display:block}.photo-picker-remove{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex;position:absolute;top:4px;right:4px}.photo-picker-multi-actions{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.photo-picker-multi-actions .btn-secondary{flex:1;min-width:0}.photo-picker-count{margin-top:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}.add-item-form{flex-direction:column;gap:.875rem;display:flex}.source-toggle{gap:var(--space-2);background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);padding:.375rem;display:flex}.source-btn{min-height:var(--touch-target);border-radius:calc(var(--radius) - 4px);font-size:var(--text-base);color:var(--color-text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.75rem .625rem;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.source-btn.active{background:var(--color-primary);color:#fff}.field-group{gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;display:flex}.field-group-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-weight:700}.field-group-collapsible{padding:0;overflow:hidden}.field-group-collapsible summary{min-height:var(--touch-target);padding:var(--space-3) var(--space-4);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;list-style:none;display:flex}.field-group-collapsible summary::-webkit-details-marker{display:none}.field-group-collapsible summary:after{content:"+";font-size:var(--text-lg);color:var(--color-text-muted);font-weight:400}.field-group-collapsible[open] summary:after{content:"−"}.field-group-collapsible-body{gap:var(--space-3);padding:0 var(--space-4) var(--space-4);flex-direction:column;display:flex}.form-section{flex-direction:column;gap:.375rem;display:flex}.form-section label{font-size:var(--text-sm);color:var(--color-text-muted);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{gap:var(--space-3);grid-template-columns:1fr;display:grid}@media (width>=400px){.form-row{grid-template-columns:1fr 1fr}}.form-error{padding:var(--space-3);background:var(--color-danger-bg);color:var(--color-danger);border-radius:var(--radius);font-size:var(--text-sm)}.select-wrap{align-items:center;display:flex;position:relative}.select-wrap select{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;cursor:pointer;padding:.75rem 2.25rem .75rem .875rem;font-family:inherit;font-size:16px}.select-wrap.has-icon select{padding-left:2.375rem}.select-wrap select:focus{outline:2px solid var(--color-primary-bg);border-color:var(--color-primary-light)}.select-icon{color:var(--color-primary);pointer-events:none;align-items:center;display:flex;position:absolute;left:.875rem}.select-chevron{color:var(--color-text-muted);pointer-events:none;position:absolute;right:.75rem}.expiration-hint{padding:var(--space-3);background:var(--color-surface-2);border-radius:var(--radius);flex-direction:column;gap:.375rem;display:flex}.expiration-hint p{font-size:var(--text-sm);color:var(--color-text-muted);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);font-size:var(--text-sm);cursor:pointer;touch-action:manipulation;align-items:center;gap:.35rem;margin-top:.375rem;padding:.5rem .75rem;font-weight:600;display:inline-flex}.opened-toggle{align-items:center;gap:var(--space-3);min-height:var(--touch-target);padding:.875rem var(--space-3);background:var(--color-surface-2);border-radius:var(--radius);font-size:var(--text-base);cursor:pointer;touch-action:manipulation;display:flex}.opened-toggle input{width:1.25rem;height:1.25rem;accent-color:var(--color-primary);flex-shrink:0}.edit-form-actions{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.search-bar{min-height:var(--touch-target);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--space-3);color:var(--color-text-muted);align-items:center;gap:.625rem;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:var(--space-2);margin-bottom:var(--space-3);display:flex}.filters .select-wrap{flex:1;min-width:0}.item-grid{gap:var(--space-2);flex-direction:column;display:flex}.item-list-error{justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:.625rem;display:flex}.alert-section{margin-bottom:var(--space-4)}.alert-section-title{margin-bottom:var(--space-2);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);align-items:center;gap:.375rem;font-weight:700;display:flex}.alert-section-title.danger{color:var(--color-danger)}.alert-section-title.warning{color:var(--color-accent)}.item-card{align-items:stretch;gap:var(--space-1);background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);animation:.18s item-in;display:flex;overflow:hidden}.item-card.exp-expired,.item-card.exp-urgent{border-left:3px solid var(--color-danger)}.item-card.exp-soon{border-left:3px solid var(--color-warning)}@keyframes item-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.item-card-main{min-width:0;min-height:3.5rem;padding:var(--space-2) 0 var(--space-2) .625rem;text-align:left;color:inherit;cursor:pointer;touch-action:manipulation;background:0 0;border:none;flex:1;align-items:center;gap:.625rem;font-family:inherit;display:flex}.item-card-main:active{background:var(--color-surface-2)}.item-card-icon{background:var(--color-surface-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative;overflow:hidden}.item-card-icon img{object-fit:cover;width:100%;height:100%}.item-card-emoji{font-size:1.25rem;line-height:1}.item-card-source{font-size:.5625rem;line-height:1;position:absolute;bottom:-2px;right:-2px}.item-card-body{flex:1;min-width:0}.item-card-top{justify-content:space-between;align-items:baseline;gap:.375rem;display:flex}.item-card-name{font-size:var(--text-base);text-overflow:ellipsis;white-space:nowrap;font-weight:700;line-height:1.25;overflow:hidden}.item-card-exp{white-space:nowrap;border-radius:999px;flex-shrink:0;padding:.125rem .375rem;font-size:.625rem;font-weight:600}.item-card-exp.exp-expired,.item-card-exp.exp-urgent{background:var(--color-danger-bg);color:var(--color-danger)}.item-card-exp.exp-soon{background:var(--color-warning-bg);color:var(--color-accent)}.item-card-exp.exp-ok{background:var(--color-primary-bg);color:var(--color-primary)}.item-card-meta{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;align-items:center;gap:.375rem;margin-top:.125rem;display:flex;overflow:hidden}.item-card-meta-loc{align-items:center;gap:.25rem;display:inline-flex}.item-card-meta-sep{opacity:.6}.item-card-open{text-transform:uppercase;color:var(--color-accent);background:var(--color-warning-bg);border-radius:4px;padding:.0625rem .3125rem;font-size:.625rem;font-weight:700}.btn-consume{width:var(--touch-target);height:var(--touch-target);margin-right:var(--space-1);background:var(--color-primary-bg);color:var(--color-primary);cursor:pointer;touch-action:manipulation;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-self:center;align-items:center;padding:0;transition:transform .1s;display:inline-flex}.btn-consume:active{transform:scale(.92)}.sheet-root{z-index:200;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet-backdrop{cursor:pointer;background:#00000073;border:none;animation:.2s fade-in;position:absolute;inset:0}.sheet{background:var(--color-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:640px;max-height:calc(100dvh - 3rem);box-shadow:var(--shadow-lg);outline:none;flex-direction:column;animation:.25s cubic-bezier(.32,.72,.25,1) slide-up;display:flex;position:relative}.sheet-tall{height:calc(100dvh - 3rem)}.sheet-handle{background:var(--color-border);border-radius:999px;flex-shrink:0;width:2.5rem;height:.25rem;margin:.625rem auto 0}.sheet-header{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4) var(--space-2);border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex}.sheet-header h4{font-size:var(--text-md);text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.sheet-close{flex-shrink:0}.sheet-body{-webkit-overflow-scrolling:touch;padding:var(--space-4) var(--space-4) calc(var(--space-4) + var(--safe-bottom));flex:1;overflow-y:auto}.add-chooser{gap:var(--space-2);flex-direction:column;display:flex}.add-chooser-option{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);text-align:left;cursor:pointer;touch-action:manipulation;font-family:inherit;transition:background .15s,transform .1s;display:flex}.add-chooser-option:active{background:var(--color-surface-2);transform:scale(.98)}.add-chooser-icon{background:var(--color-primary-bg);width:3rem;height:3rem;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.add-chooser-text{flex-direction:column;gap:.125rem;min-width:0;display:flex}.add-chooser-text strong{font-size:var(--text-md);color:var(--color-text)}.add-chooser-text small{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.35}.item-detail{gap:var(--space-4);flex-direction:column;display:flex}.item-detail-hero{border-radius:var(--radius-lg);background:var(--color-surface-2);justify-content:center;align-items:center;height:9rem;display:flex;overflow:hidden}.item-detail-hero img{object-fit:cover;width:100%;height:100%}.item-detail-hero-emoji{font-size:3.5rem;line-height:1}.item-detail-exp{padding:var(--space-3) var(--space-4);border-radius:var(--radius);background:var(--color-surface);border:1px solid var(--color-border);flex-direction:column;gap:.375rem;display:flex}.item-detail-exp strong{font-size:var(--text-md)}.item-detail-exp.exp-expired,.item-detail-exp.exp-urgent{background:var(--color-danger-bg);border-color:#0000}.item-detail-exp.exp-expired strong,.item-detail-exp.exp-urgent strong{color:var(--color-danger)}.item-detail-exp.exp-soon{background:var(--color-warning-bg);border-color:#0000}.item-detail-exp.exp-soon strong{color:var(--color-accent)}.item-detail-exp p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.4}.item-detail-qty{padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);justify-content:space-between;align-items:center;display:flex}.item-detail-qty-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:600}.qty-stepper{align-items:center;gap:var(--space-2);display:flex}.qty-stepper-btn{width:var(--touch-target);height:var(--touch-target);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);color:var(--color-text);cursor:pointer;touch-action:manipulation;justify-content:center;align-items:center;padding:0;transition:transform .1s;display:inline-flex}.qty-stepper-btn:active{transform:scale(.92)}.qty-stepper-value{min-width:3.5rem;font-size:var(--text-md);text-align:center;white-space:nowrap;font-weight:700;animation:.25s qty-pulse}@keyframes qty-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.item-detail-meta{gap:var(--space-3) var(--space-4);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);grid-template-columns:1fr 1fr;display:grid}.item-detail-meta-wide{grid-column:1/-1}.item-detail-meta dt{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-weight:600}.item-detail-meta dd{font-size:var(--text-base);margin-top:.125rem}.item-detail-actions{gap:var(--space-2);flex-direction:column;display:flex}.delete-confirm{gap:var(--space-2);padding:var(--space-3);background:var(--color-danger-bg);border-radius:var(--radius);flex-direction:column;display:flex}.delete-confirm p{font-size:var(--text-sm);color:var(--color-danger);text-align:center;font-weight:600}.delete-confirm-actions{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.history-sections{gap:var(--space-5);flex-direction:column;display:flex}.history-list{gap:var(--space-2);flex-direction:column;list-style:none;display:flex}.history-row{padding:var(--space-2) .625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:.625rem;display:flex}.history-row-emoji{background:var(--color-surface-2);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.125rem;display:flex}.history-row-body{flex-direction:column;min-width:0;display:flex}.history-row-name{font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.history-row-date{font-size:var(--text-xs);color:var(--color-text-muted)}.toast{bottom:calc(var(--nav-height) + .75rem);align-items:center;gap:var(--space-3);max-width:min(92vw,480px);padding:.75rem var(--space-4);background:var(--color-text);color:var(--color-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:var(--text-sm);z-index:150;font-weight:600;animation:.25s cubic-bezier(.32,.72,.25,1) toast-in;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast-action{color:#8fd8ae;font-size:var(--text-sm);cursor:pointer;touch-action:manipulation;background:0 0;border:none;flex-shrink:0;padding:.25rem 0;font-weight:700}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,.5rem)}to{opacity:1;transform:translate(-50%)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.empty-state,.loading-state{justify-content:center;align-items:center;gap:var(--space-3);padding:3rem var(--space-6);text-align:center;color:var(--color-text-muted);flex-direction:column;display:flex}.empty-state h3{font-size:var(--text-lg);color:var(--color-text)}.empty-state p{font-size:var(--text-sm);max-width:280px}.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{font-size:var(--text-base);color:var(--color-text-muted);margin-bottom:var(--space-4)}.setup-code{text-align:left;color:#d4edda;border-radius:var(--radius);font-size:var(--text-sm);margin-bottom:var(--space-4);background:#1a1a1a;padding:1rem 1.25rem;line-height:1.6;overflow-x:auto}.setup-note{font-size:var(--text-sm)!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:var(--space-5);padding-right:var(--space-5)}}.signin-btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius);width:100%;font-size:var(--text-base);cursor:pointer;margin-bottom:var(--space-3);border:none;padding:.875rem;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)}.scan-inventory{gap:var(--space-4);flex-direction:column;display:flex}.scan-intro{padding:.875rem var(--space-4);background:var(--color-primary-bg);border-radius:var(--radius);color:var(--color-primary);font-size:var(--text-sm);align-items:flex-start;gap:.625rem;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:var(--text-lg);font-weight:700}.scan-review-header p{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.scan-review-list{flex-direction:column;gap:.625rem;list-style:none;display:flex}.scan-review-item{padding:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);gap:.625rem;display:flex}.scan-review-item.deselected{opacity:.55}.scan-item-select{padding-top:var(--space-1);align-items:flex-start;display:flex}.scan-item-select input{width:1.125rem;height:1.125rem;accent-color:var(--color-primary)}.scan-item-summary{justify-content:space-between;align-items:flex-start;gap:var(--space-2);flex:1;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:var(--text-base);line-height:1.3;display:block}.scan-item-badge{text-transform:uppercase;letter-spacing:.03em;color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 12%, transparent);vertical-align:middle;border-radius:4px;margin-left:.375rem;padding:.0625rem .375rem;font-size:.625rem;font-weight:700;display:inline-block}.scan-item-meta,.scan-item-description{color:var(--color-text-muted);margin-top:.125rem;font-size:.75rem;display:block}.scan-item-meta svg{vertical-align:-.125em}.scan-item-actions{gap:var(--space-1);flex-shrink:0;display:flex}.scan-item-editor{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.scan-item-editor input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;font-size:var(--text-sm);background:var(--color-surface);padding:.5rem .625rem}.scan-item-editor .select-wrap select{min-height:2.5rem;font-size:var(--text-sm);padding-top:.5rem;padding-bottom:.5rem}.scan-editor-actions{justify-content:flex-end;gap:var(--space-2);display:flex}.manual-add-link{color:var(--color-primary);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2);text-underline-offset:2px;background:0 0;border:none;align-self:center;font-weight:600;text-decoration:underline}.manual-add-link:active{opacity:.8}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
