:root{--bg:#fbf6ef;--surface:#fff;--surface-2:#f4ece0;--ink:#2c241d;--ink-soft:#6f6358;--brown:#7a4a2b;--brown-deep:#5d3720;--line:#e7ddcf;--fresh:#3f8f5b;--fresh-bg:#e6f1e8;--soon:#c07d12;--soon-bg:#faedd3;--past:#b8503b;--past-bg:#f6e0db;--radius:16px;--radius-sm:10px;--shadow:0 6px 20px #3f2a1814;--mono:ui-monospace, "SFMono-Regular", "Menlo", "Consolas", monospace;--sans:system-ui, -apple-system, "Segoe UI", "Helvetica Neue", sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.45}h1,h2,h3,p{margin:0}button{font-family:inherit}.app{max-width:560px;padding:0 16px calc(86px + env(safe-area-inset-bottom));min-height:100vh;margin:0 auto}.content{padding-top:4px}.muted-note{color:var(--ink-soft);text-align:center;padding:40px 12px}.masthead{z-index:5;background:var(--bg);border-bottom:1px solid var(--line);padding:20px 0 12px;position:sticky;top:0}.masthead-title h1{letter-spacing:-.01em;color:var(--brown-deep);font-size:1.5rem}.tagline{color:var(--ink-soft);margin-top:2px;font-size:.86rem}.summary{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.summary-chip{background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);border-radius:999px;padding:5px 11px;font-size:.8rem}.summary-chip strong{color:var(--ink)}.summary-chip[data-status=soon][data-empty=false]{background:var(--soon-bg);color:var(--soon);border-color:#0000}.summary-chip[data-status=past][data-empty=false]{background:var(--past-bg);color:var(--past);border-color:#0000}.summary-chip[data-status=soon][data-empty=false] strong,.summary-chip[data-status=past][data-empty=false] strong{color:inherit}.toolbar{flex-direction:column;gap:10px;padding:14px 0 10px;display:flex}.search{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);width:100%;min-width:0;color:var(--ink);padding:11px 13px;font-size:.95rem}.filters{flex-wrap:wrap;gap:6px;display:flex}.filter-chip{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);cursor:pointer;border-radius:999px;padding:6px 13px;font-size:.82rem;font-weight:600}.filter-chip[aria-selected=true]{background:var(--brown);color:#fff;border-color:#0000}.toolbar-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar-actions .sort{margin-left:auto}.sort{color:var(--ink-soft);align-items:center;gap:8px;font-size:.82rem;display:flex}.sort select{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);padding:7px 10px;font-size:.86rem}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;padding:10px 14px;font-size:.9rem;font-weight:600;transition:background .15s,transform 50ms}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--brown);color:#fff}.btn.primary:hover{background:var(--brown-deep)}.add-btn{white-space:nowrap}.btn.ghost{border-color:var(--line);color:var(--ink);background:0 0;font-weight:500}.btn.ghost:hover{background:var(--surface-2)}.btn.ghost.danger{color:var(--past)}.btn.danger-solid{background:var(--past);color:#fff}.list{flex-direction:column;gap:12px;padding:4px 0 8px;display:flex}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 15px}.card[data-status=past]{filter:saturate(.6);opacity:.92}.card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.card-heading{flex:1;min-width:0}.card-thumb{object-fit:cover;border-radius:10px;flex-shrink:0;width:46px;height:46px}.card-name{color:var(--ink);font-size:1.1rem}.card-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.chip{background:var(--surface-2);color:var(--brown-deep);border-radius:999px;padding:3px 9px;font-size:.72rem;font-weight:600}.chip.location{background:var(--brown);color:#fff}.brand{color:var(--ink-soft);font-size:.82rem}.badge{white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:.72rem;font-weight:700}.badge[data-status=fresh]{background:var(--fresh-bg);color:var(--fresh)}.badge[data-status=soon]{background:var(--soon-bg);color:var(--soon)}.badge[data-status=past]{background:var(--past-bg);color:var(--past)}.stamp{font-family:var(--mono);letter-spacing:.12em;color:var(--brown-deep);text-transform:uppercase;border:1.5px dashed #7a4a2b80;border-radius:6px;margin-top:12px;padding:6px 10px;font-size:.82rem;display:inline-block}.potency{background:var(--surface-2);border-radius:999px;height:8px;margin-top:12px;overflow:hidden}.potency-fill{border-radius:999px;height:100%;transition:width .3s}.potency-fill[data-status=fresh]{background:var(--fresh)}.potency-fill[data-status=soon]{background:var(--soon)}.potency-fill[data-status=past]{background:var(--past)}.card-notes{color:var(--ink-soft);margin-top:10px;font-size:.86rem}.card-bottom{justify-content:space-between;align-items:center;gap:8px;margin-top:12px;display:flex}.days{color:var(--ink-soft);font-size:.84rem;font-weight:600}.days[data-status=past]{color:var(--past)}.days[data-status=soon]{color:var(--soon)}.card-actions{gap:6px;display:flex}.card-actions .btn{padding:7px 12px;font-size:.82rem}.empty{text-align:center;color:var(--ink-soft);padding:56px 20px}.empty-emblem{font-size:3rem}.empty h2{color:var(--ink);margin:12px 0 6px}.empty p{margin-bottom:18px}.backdrop{z-index:20;background:#2c1e126b;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.sheet{background:var(--bg);width:100%;max-width:560px;padding:10px 18px calc(22px + env(safe-area-inset-bottom));border-radius:22px 22px 0 0;max-height:92vh;animation:.22s rise;overflow-y:auto}.sheet-handle{background:var(--line);border-radius:999px;width:42px;height:4px;margin:4px auto 10px}.sheet-title{color:var(--brown-deep);margin-bottom:14px;font-size:1.2rem}.form{flex-direction:column;gap:14px;display:flex}.field{color:var(--ink-soft);flex-direction:column;gap:6px;font-size:.84rem;display:flex}.field-row{gap:12px;display:flex}.field-row .field{flex:1}.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);padding:11px 12px;font-family:inherit;font-size:.95rem}.field input[aria-invalid=true]{border-color:var(--past)}.field textarea{resize:vertical}.optional{color:var(--ink-soft);font-weight:400}.field-error{color:var(--past);font-size:.8rem}.form-hint{color:var(--ink-soft);margin-top:-4px;font-size:.8rem}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.confirm{background:var(--surface);border-radius:var(--radius);max-width:380px;box-shadow:var(--shadow);align-self:center;margin:auto 16px;padding:22px}.confirm h2{margin-bottom:8px;font-size:1.1rem}.confirm p{color:var(--ink-soft);font-size:.9rem}.confirm-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}@keyframes rise{0%{opacity:.6;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.scan-btn{cursor:pointer;align-items:center;gap:6px;display:inline-flex}.scan-btn[aria-disabled=true]{opacity:.6;pointer-events:none}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.empty-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.notice{border-radius:var(--radius-sm);margin-bottom:14px;padding:10px 12px;font-size:.86rem}.notice[data-tone=info]{background:var(--soon-bg);color:var(--soon)}.notice[data-tone=error]{background:var(--past-bg);color:var(--past)}.form-thumb{object-fit:cover;border:1px solid var(--line);border-radius:12px;align-self:center;width:84px;height:84px}.scan-overlay{z-index:30;background:#2c1e126b;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.scan-card{background:var(--surface);border-radius:var(--radius);text-align:center;color:var(--ink-soft);box-shadow:var(--shadow);padding:26px 30px}.scan-spinner{border:3px solid var(--surface-2);border-top-color:var(--brown);border-radius:50%;width:34px;height:34px;margin:0 auto 12px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}:focus-visible{outline:2px solid var(--brown);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important}}.tabbar{background:var(--surface);border-top:1px solid var(--line);width:100%;max-width:560px;padding-bottom:env(safe-area-inset-bottom);z-index:10;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:9px 0 10px;font-size:.72rem;font-weight:600;display:flex;position:relative}.tab[aria-current=page]{color:var(--brown-deep)}.tab-icon{font-size:1.2rem;line-height:1}.tab-badge{background:var(--brown);color:#fff;text-align:center;border-radius:999px;min-width:17px;height:17px;margin-left:8px;padding:0 4px;font-size:.66rem;line-height:17px;position:absolute;top:4px;left:50%}.field-narrow{max-width:96px}.card-usage{justify-content:space-between;align-items:center;gap:10px;margin-top:12px;display:flex}.qty{border:1px solid var(--line);border-radius:999px;align-items:center;display:inline-flex;overflow:hidden}.qty-btn{background:var(--surface);width:38px;height:34px;color:var(--brown-deep);cursor:pointer;border:none;font-size:1.2rem;line-height:1}.qty-btn:active{background:var(--surface-2)}.qty-value{text-align:center;min-width:34px;color:var(--ink);font-weight:700}.result-count{color:var(--ink-soft);padding:4px 2px 8px;font-size:.84rem}.shopping{flex-direction:column;gap:12px;padding-top:14px;display:flex}.shopping-add{gap:8px;display:flex}.shopping-add .search{flex:1}.shopping-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.shopping-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:10px;padding:8px 10px 8px 12px;display:flex}.shopping-check{cursor:pointer;flex:1;align-items:center;gap:10px;display:flex}.shopping-check input{width:20px;height:20px;accent-color:var(--brown)}.shopping-row[data-done=true] .shopping-name{color:var(--ink-soft);text-decoration:line-through}.shopping-note{color:var(--ink-soft);font-size:.84rem}.recipes{flex-direction:column;gap:12px;padding-top:14px;display:flex}.seg{background:var(--surface-2);border-radius:var(--radius-sm);gap:3px;padding:3px;display:flex}.seg-btn{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 6px;font-size:.86rem;font-weight:600}.seg-btn[aria-selected=true]{background:var(--surface);color:var(--brown-deep);box-shadow:var(--shadow)}.pick-list{border:1px solid var(--line);border-radius:var(--radius-sm);flex-direction:column;gap:4px;max-height:44vh;padding:6px;display:flex;overflow-y:auto}.pick-row{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:7px 8px;display:flex}.pick-row:hover{background:var(--surface-2)}.pick-row input{width:19px;height:19px;accent-color:var(--brown)}.pick-row span:first-of-type{flex:1}.pick-cat{color:var(--ink-soft);font-size:.76rem}.btn.block{justify-content:center;width:100%}.recipe-list{flex-direction:column;gap:14px;display:flex}.recipe{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:10px;padding:16px;display:flex}.recipe-head{justify-content:space-between;align-items:baseline;gap:10px;display:flex}.recipe-title{color:var(--brown-deep);font-size:1.1rem}.recipe-time{color:var(--ink-soft);flex:none;font-size:.8rem;font-weight:600}.recipe-desc{color:var(--ink-soft);font-size:.9rem}.recipe-uses{color:var(--ink-soft);flex-wrap:wrap;align-items:center;gap:6px;font-size:.82rem;display:flex}.ingredients{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.ingredient{align-items:baseline;gap:8px;font-size:.92rem;display:flex}.ingredient[data-have=true] span{color:var(--fresh);font-weight:700}.ingredient[data-have=false],.ingredient[data-have=false] span{color:var(--ink-soft)}.steps{flex-direction:column;gap:6px;margin:0;padding-left:20px;font-size:.92rem;display:flex}.toggle-all{align-self:flex-start;padding:6px 12px;font-size:.82rem}.shelf-list{flex-direction:column;gap:8px;max-height:52vh;margin:4px 0 12px;display:flex;overflow-y:auto}.shelf-row{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);align-items:flex-start;gap:10px;padding:10px;display:flex}.shelf-row[data-off=true]{opacity:.5}.shelf-check{width:20px;height:20px;accent-color:var(--brown);flex-shrink:0;margin-top:8px}.shelf-fields{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.shelf-name{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--ink);padding:8px 10px;font-size:.95rem;font-weight:600}.shelf-selects{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.shelf-selects select{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);min-width:0;color:var(--ink);flex:1;padding:6px 8px;font-size:.82rem}.shelf-selects .qty{flex-shrink:0}.link-btn{color:inherit;font:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:700;text-decoration:underline}
