.shop-root{background:var(--shop-bg);color:var(--shop-text);min-height:100vh;min-height:100dvh;font-size:16px;-webkit-tap-highlight-color:transparent}.shop-root *{box-sizing:border-box}.shop-header{position:sticky;top:0;z-index:30;background:var(--shop-bg);padding:env(safe-area-inset-top,0) 12px 8px;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--shop-border)}.shop-header-row{display:flex;align-items:center;gap:8px;min-height:56px;padding-top:12px}.shop-back{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:999px;background:var(--shop-surface-alt);color:var(--shop-text);cursor:pointer}.shop-title{flex:1;font-weight:600;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-progress-text{font-size:13px;color:var(--shop-text-muted);font-variant-numeric:tabular-nums}.shop-progress-bar{height:4px;background:var(--shop-surface-alt);border-radius:2px;overflow:hidden;margin-bottom:8px}.shop-progress-fill{height:100%;background:var(--shop-primary);transition:width .2s ease}.shop-offline-banner{background:var(--shop-pantry-bg);color:var(--shop-text);padding:6px 12px;font-size:13px;text-align:center;border-bottom:1px solid var(--shop-pantry-border)}.shop-content{padding-bottom:calc(96px + env(safe-area-inset-bottom,0))}.shop-aisle-header{position:sticky;top:84px;z-index:10;padding:6px 16px;background:var(--shop-surface-alt);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--shop-text-muted);border-top:1px solid var(--shop-border);border-bottom:1px solid var(--shop-border);display:flex;justify-content:space-between}.shop-row-wrapper{position:relative;background:var(--shop-bg);overflow:hidden;border-bottom:1px solid var(--shop-border)}.shop-row-reveal{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;color:#fff;font-weight:600;font-size:14px}.shop-row-reveal.left{background:var(--shop-success-bg);justify-content:flex-end}.shop-row-reveal.right{background:var(--shop-danger-bg);justify-content:flex-start}.shop-row{position:relative;display:flex;align-items:center;gap:12px;min-height:64px;padding:12px 16px;background:var(--shop-bg);user-select:none;-webkit-user-select:none;cursor:pointer;touch-action:pan-y}.shop-row.checked .shop-row-text{opacity:.45;text-decoration:line-through}.shop-checkbox{width:28px;height:28px;border-radius:999px;border:2px solid var(--shop-border);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--shop-bg);transition:background .12s ease,border-color .12s ease}.shop-checkbox.checked{background:var(--shop-primary);border-color:var(--shop-primary);color:#fff}.shop-row-text{flex:1;min-width:0}.shop-row-line1{font-size:16px;font-weight:600;display:flex;gap:6px;flex-wrap:wrap}.shop-row-line2{font-size:13px;color:var(--shop-text-muted);margin-top:2px}.shop-row-warning{margin-top:4px;font-size:12px;color:var(--color-warning);display:flex;align-items:center;gap:4px}.shop-row-chevron{width:36px;height:36px;border-radius:999px;border:none;background:transparent;color:var(--shop-text-muted);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.shop-row-sources{background:var(--shop-surface-alt);padding:8px 16px 14px 56px;display:flex;flex-direction:column;gap:4px;font-size:14px}.shop-pantry-toggle{display:flex;align-items:center;gap:10px;width:100%;background:var(--shop-pantry-bg);color:var(--shop-text);border:none;border-bottom:1px solid var(--shop-pantry-border);padding:14px 16px;font-weight:600;font-size:15px;cursor:pointer}.shop-pantry-row{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:var(--shop-bg);border-bottom:1px solid var(--shop-border)}.shop-pantry-row.dismissed .shop-pantry-name{opacity:.45;text-decoration:line-through}.shop-pantry-name{font-weight:600;font-size:16px}.shop-pantry-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.shop-button{height:48px;border-radius:12px;border:1px solid var(--shop-border);background:var(--shop-bg);color:var(--shop-text);font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}.shop-button.primary{background:var(--shop-primary);color:#fff;border-color:var(--shop-primary)}.shop-button.ghost{background:transparent;border-color:transparent;color:var(--shop-text-muted)}.shop-fab{position:fixed;right:20px;bottom:calc(20px + env(safe-area-inset-bottom,0));width:56px;height:56px;border-radius:999px;background:var(--shop-primary);color:#fff;border:none;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #00000040;cursor:pointer;z-index:40}.bs-backdrop{position:fixed;inset:0;background:#0006;z-index:50;display:flex;align-items:flex-end;justify-content:center;animation:bs-fade-in .15s ease}@keyframes bs-fade-in{0%{background:#0000}to{background:#0006}}.bs-sheet{background:var(--shop-surface);color:var(--shop-text);border-radius:16px 16px 0 0;width:100%;max-width:600px;padding:16px 16px calc(16px + env(safe-area-inset-bottom,0));animation:bs-slide-up .22s cubic-bezier(.2,.8,.2,1)}@keyframes bs-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bs-handle{width:40px;height:4px;background:var(--shop-border);border-radius:2px;margin:0 auto 14px}.bs-title{font-size:16px;font-weight:700;margin-bottom:12px}.shop-input{width:100%;height:48px;border-radius:12px;border:1px solid var(--shop-border);background:var(--shop-surface);color:var(--shop-text);padding:0 14px;font-size:16px}.shop-input:focus{outline:2px solid var(--shop-primary);border-color:var(--shop-primary)}.shop-empty{padding:48px 20px;text-align:center;color:var(--shop-text-muted)}:root{--color-primary: #3F8C5A;--color-primary-dark: #2C6B43;--color-primary-light: #DEF1E2;--color-accent: #E2A93B;--color-bg: #FAFAF7;--color-surface: #FFFFFF;--color-surface-alt: #F2F2EE;--color-border: #E0E0DA;--color-border-strong: #C2C2B8;--color-text: #1F2421;--color-text-muted: #6E6E66;--color-text-subtle: #8E8E84;--color-danger: #C0594A;--color-warning: #C9923A;--color-success: #3F8C5A;--shop-bg: #FFFFFF;--shop-surface: #FFFFFF;--shop-surface-alt: #F4F4F0;--shop-text: #0F1411;--shop-text-muted: #4A4A45;--shop-border: #D5D5CE;--shop-primary: #2F7048;--shop-pantry-bg: #FFF1CC;--shop-pantry-border: #E5C36F;--shop-danger-bg: #B73B2D;--shop-success-bg: #2F7048;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-8: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", Monaco, Consolas, monospace;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 2px 8px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12)}@media(prefers-color-scheme:dark){:root{--shop-bg: #0E1411;--shop-surface: #161D19;--shop-surface-alt: #1F2722;--shop-text: #F4F8F5;--shop-text-muted: #B5BDB7;--shop-border: #2D3631;--shop-primary: #5DBE82;--shop-pantry-bg: #3B2E12;--shop-pantry-border: #846C2C;--shop-danger-bg: #D14C3C;--shop-success-bg: #4FA46B}}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);font-size:15px;line-height:1.5;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}h1,h2,h3,h4{margin:0 0 var(--space-3);font-weight:600}h1{font-size:28px}h2{font-size:22px}h3{font-size:18px}h4{font-size:15px}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:8px 14px;border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-md);font-weight:500;transition:background .12s ease,border-color .12s ease}.btn:hover{background:var(--color-surface-alt)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-danger{border-color:var(--color-danger);color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--color-surface-alt)}.btn-icon{padding:6px;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent}.btn-icon:hover{background:var(--color-surface-alt)}.input{width:100%;padding:8px 12px;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface)}.input:focus{outline:2px solid var(--color-primary-light);border-color:var(--color-primary)}.field-label{display:block;font-size:13px;font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-1)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.error-banner{background:#fce8e4;color:var(--color-danger);padding:var(--space-3);border-radius:var(--radius-md);font-size:14px;margin-bottom:var(--space-3)}.muted{color:var(--color-text-muted)}.subtle{color:var(--color-text-subtle)}
