@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&display=swap";:root{--accent:#8366EE;--r-card:20px;--r-md:14px;--r-sm:10px;--r-pill:999px;--accent-strong:color-mix(in srgb, var(--accent) 82%, #000 18%);--accent-ink:color-mix(in srgb, var(--accent) 70%, #1a1030);--have:#33B98A;--miss:#F0708F;font-synthesis-weight:none}[data-theme=light]{--bg:#F6F2FE;--bg-2:#EFE9FB;--surface:#FFFFFF;--surface-2:#FBF8FF;--surface-sunk:#F3EEFC;--ink:#241B38;--ink-2:#5B5273;--ink-3:#8B82A3;--line:#EAE2F7;--line-2:#DED3F2;--accent-soft:color-mix(in srgb, var(--accent) 12%, #fff);--accent-tint:color-mix(in srgb, var(--accent) 7%, #fff);--have-soft:color-mix(in srgb, var(--have) 14%, #fff);--miss-soft:color-mix(in srgb, var(--miss) 13%, #fff);--shadow-card:0 1px 2px rgba(40,24,80,.04), 0 6px 18px -10px rgba(60,36,120,.22);--shadow-pop:0 12px 40px -8px rgba(45,25,95,.3), 0 2px 8px rgba(45,25,95,.1);--scrim:rgba(36,22,70,.42);color-scheme:light}[data-theme=dark]{--bg:#150F22;--bg-2:#1B1430;--surface:#221A36;--surface-2:#291F40;--surface-sunk:#1B1430;--ink:#F2ECFE;--ink-2:#B7ACD2;--ink-3:#857B9E;--line:#332749;--line-2:#3E3057;--accent:#A488F6;--accent-soft:color-mix(in srgb, var(--accent) 22%, #1B1430);--accent-tint:color-mix(in srgb, var(--accent) 13%, #150F22);--accent-ink:color-mix(in srgb, var(--accent) 88%, #fff 12%);--have:#41D49C;--miss:#FF85A1;--have-soft:color-mix(in srgb, var(--have) 20%, #1B1430);--miss-soft:color-mix(in srgb, var(--miss) 18%, #1B1430);--shadow-card:0 1px 2px rgba(0,0,0,.3), 0 8px 22px -12px rgba(0,0,0,.6);--shadow-pop:0 18px 50px -10px rgba(0,0,0,.7), 0 2px 10px rgba(0,0,0,.4);--scrim:rgba(8,4,18,.62);color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}html,body,#root{height:100%}body{display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 80% at 20% 0%,#efe7fb,transparent 60%),radial-gradient(120% 90% at 100% 100%,#e7e0f8,transparent 55%),#e9e3f6;font-family:Hanken Grotesk,system-ui,sans-serif}.larder{position:relative;width:100%;max-width:480px;height:100dvh;margin:0 auto;overflow:hidden;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.4;-webkit-font-smoothing:antialiased}@media (min-width:520px){.larder{height:min(900px,96dvh);border-radius:34px;box-shadow:0 40px 90px -20px #3c247873}}.larder *{font-variant-ligatures:none}.serif,.display{font-family:Bricolage Grotesque,system-ui,sans-serif}.larder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(120% 60% at 50% -10%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 60%)}.scroll{position:relative;z-index:1;flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-top:calc(env(safe-area-inset-top) + 14px);scrollbar-width:none}.scroll::-webkit-scrollbar{display:none}.page{padding:0 18px 112px}.head{padding:8px 2px 14px;display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.head .eyebrow{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:5px}.head h1{font-family:Bricolage Grotesque,sans-serif;font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1.02;color:var(--ink)}.head .sub{color:var(--ink-3);font-size:13.5px;margin-top:4px}.icon-btn{width:42px;height:42px;flex:0 0 auto;border-radius:var(--r-md);background:var(--surface);color:var(--ink);box-shadow:var(--shadow-card);display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease}.icon-btn:active{transform:scale(.93)}.icon-btn svg{width:20px;height:20px}.theme-toggle{position:absolute;top:calc(env(safe-area-inset-top) + 14px);right:16px;z-index:25;width:40px;height:40px}.search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-md);padding:0 14px;height:48px;margin:2px 0 14px;transition:border-color .15s ease,box-shadow .15s ease}.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.search svg{width:18px;height:18px;color:var(--ink-3);flex:0 0 auto}.search input{flex:1;border:none;background:none;outline:none;min-width:0;font:inherit;font-size:15.5px;color:var(--ink)}.search input::placeholder{color:var(--ink-3)}.chips{display:flex;gap:8px;overflow-x:auto;padding:1px 18px 16px;margin:0 -18px;scrollbar-width:none}.chips::-webkit-scrollbar{display:none}.chip{flex:0 0 auto;border:1.5px solid var(--line-2);background:var(--surface);color:var(--ink-2);border-radius:var(--r-pill);padding:8px 14px;font-size:13px;font-weight:600;white-space:nowrap;transition:.15s ease;display:inline-flex;align-items:center;gap:6px}.chip:active{transform:scale(.95)}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.chip.cook.on{background:var(--have);border-color:var(--have);color:#06281c}[data-theme=dark] .chip.cook.on{color:#04150e}.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.rcard{position:relative;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-card);overflow:hidden;cursor:pointer;text-align:left;display:flex;flex-direction:column;padding:0;box-shadow:var(--shadow-card);transition:transform .18s cubic-bezier(.2,.8,.3,1),box-shadow .18s ease}.rcard:active{transform:scale(.975)}.rcard .thumb{position:relative;aspect-ratio:1/1;width:100%;overflow:hidden;background:linear-gradient(150deg,var(--accent-soft),var(--surface-sunk));display:flex;align-items:center;justify-content:center}.rcard .thumb img{width:100%;height:100%;object-fit:cover}.rcard .thumb .glyph{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:46px;color:color-mix(in srgb,var(--accent) 55%,var(--ink-3))}.rcard .fav{position:absolute;top:9px;right:9px;width:30px;height:30px;border-radius:50%;background:var(--scrim);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#ffd86b}.rcard .fav svg{width:16px;height:16px}.rcard .ready{position:absolute;top:9px;left:9px;font-size:10.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;background:var(--have);color:#06281c;padding:4px 8px;border-radius:var(--r-pill);display:flex;align-items:center;gap:4px}[data-theme=dark] .rcard .ready{color:#04150e}.rcard .body{padding:12px 13px 14px;display:flex;flex-direction:column;gap:7px;flex:1}.rcard h3{font-family:Bricolage Grotesque,sans-serif;font-weight:600;font-size:16.5px;line-height:1.12;letter-spacing:-.01em;color:var(--ink);text-wrap:balance}.rcard .meta{display:flex;gap:9px;font-size:11.5px;color:var(--ink-3);font-weight:600;flex-wrap:wrap;margin-top:auto}.rcard .meta span{display:inline-flex;align-items:center;gap:3px}.rcard .meta svg{width:12px;height:12px}.match{margin-top:2px}.match .lbl{font-size:11px;font-weight:700;color:var(--ink-2);margin-bottom:4px;display:flex;justify-content:space-between}.match .lbl .n{color:var(--accent-ink);font-variant-numeric:tabular-nums}.bar{height:6px;background:var(--surface-sunk);border-radius:99px;overflow:hidden}.bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent-ink));transition:width .4s cubic-bezier(.2,.8,.3,1)}.bar i.full{background:linear-gradient(90deg,var(--have),color-mix(in srgb,var(--have) 70%,#1bbf6e))}.fab{position:absolute;right:18px;bottom:calc(86px + env(safe-area-inset-bottom));z-index:30;height:54px;padding:0 20px 0 18px;border-radius:var(--r-pill);background:var(--accent);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px;box-shadow:0 10px 30px -6px color-mix(in srgb,var(--accent) 70%,transparent),0 2px 6px #0000002e;transition:transform .16s cubic-bezier(.2,.8,.3,1)}.fab:active{transform:scale(.94)}.fab svg{width:21px;height:21px}.nav{position:relative;z-index:20;flex:0 0 auto;display:flex;padding:9px 14px calc(14px + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--surface) 86%,transparent);-webkit-backdrop-filter:blur(18px) saturate(1.4);backdrop-filter:blur(18px) saturate(1.4);border-top:1px solid var(--line)}.nav button{flex:1;color:var(--ink-3);display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:700;padding:6px 0;transition:color .15s ease}.nav button svg{width:24px;height:24px;transition:transform .18s cubic-bezier(.2,.8,.3,1)}.nav button.on{color:var(--accent-ink)}.nav button.on svg{transform:translateY(-1px)}.nav .pip{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .2s ease}.nav button.on .pip{opacity:1}.scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;background:var(--scrim);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;flex-direction:column;justify-content:flex-end;animation:fade .2s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.sheet{background:var(--bg);border-radius:26px 26px 0 0;max-height:94%;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-pop);animation:rise .26s cubic-bezier(.2,.85,.3,1)}@keyframes rise{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet .grab{width:38px;height:5px;border-radius:99px;background:var(--line-2);margin:9px auto 2px;flex:0 0 auto}.sheet .sheet-head{display:flex;align-items:center;justify-content:space-between;padding:10px 18px 8px;flex:0 0 auto}.sheet .sheet-head h2{font-family:Bricolage Grotesque,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.02em}.sheet .sheet-body{overflow-y:auto;padding:4px 18px 22px}.sheet .sheet-body::-webkit-scrollbar{display:none}.close{width:34px;height:34px;background:var(--surface-sunk);color:var(--ink-2);border-radius:50%;display:flex;align-items:center;justify-content:center}.close:active{transform:scale(.92)}.close svg{width:16px;height:16px}.field{margin:14px 0}.field>label{display:block;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px}.input,.textarea{width:100%;background:var(--surface);border:1.5px solid var(--line);color:var(--ink);border-radius:var(--r-sm);padding:12px 14px;font:inherit;font-size:15.5px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.textarea{resize:vertical;min-height:96px;line-height:1.55}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.input::placeholder,.textarea::placeholder{color:var(--ink-3)}.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.btn{font-weight:700;font-size:15px;border-radius:var(--r-md);padding:13px 18px;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:transform .15s ease,background .15s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5}.btn.block{width:100%}.btn.ghost{background:var(--surface);color:var(--ink);border:1.5px solid var(--line-2)}.btn.soft{background:var(--accent-soft);color:var(--accent-ink)}.btn svg{width:18px;height:18px}.seg{display:flex;gap:5px;background:var(--surface-sunk);padding:4px;border-radius:var(--r-md);margin-bottom:4px}.seg button{flex:1;font-weight:700;font-size:13.5px;color:var(--ink-2);padding:9px 6px;border-radius:calc(var(--r-md) - 4px);transition:.15s ease;display:flex;align-items:center;justify-content:center;gap:6px}.seg button svg{width:16px;height:16px}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-card)}.paste-area{min-height:200px}.parsehint{font-size:12.5px;color:var(--ink-3);margin:8px 2px 2px;line-height:1.5}.parsehint b{color:var(--accent-ink)}.preview-card{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-card);padding:15px 15px 17px;margin-top:6px}.preview-card .pv-title{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:20px;letter-spacing:-.01em;margin-bottom:6px}.pv-sec{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);margin:14px 0 7px}.pv-ing{display:flex;align-items:baseline;gap:8px;padding:5px 0;border-bottom:1px solid var(--line);font-size:14.5px}.pv-ing .q{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent-ink);flex:0 0 auto;min-width:54px}.pv-step{display:flex;gap:10px;padding:6px 0;font-size:14px;line-height:1.5}.pv-step .num{flex:0 0 22px;height:22px;border-radius:50%;background:var(--accent-soft);color:var(--accent-ink);font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center}.count-pill{font-size:11px;font-weight:700;color:var(--accent-ink);background:var(--accent-soft);padding:2px 8px;border-radius:99px}.photo-drop{border:1.5px dashed var(--line-2);border-radius:var(--r-card);padding:26px 16px;text-align:center;color:var(--ink-3);background:var(--surface-2);transition:.15s ease;display:block}.photo-drop:active{border-color:var(--accent)}.photo-drop svg{width:30px;height:30px;margin-bottom:8px;color:var(--accent)}.photo-prev{width:100%;border-radius:var(--r-card);display:block}.tagrow{display:flex;flex-wrap:wrap;gap:7px}.tagrow .tg{display:inline-flex;align-items:center;gap:5px;background:var(--accent-soft);color:var(--accent-ink);border-radius:var(--r-pill);padding:6px 6px 6px 11px;font-size:13px;font-weight:600}.tagrow .tg button{color:inherit;opacity:.6;display:flex;width:16px;height:16px}.tagrow .tg button svg{width:14px;height:14px}.detail{position:absolute;top:0;right:0;bottom:0;left:0;z-index:35;background:var(--bg);display:flex;flex-direction:column;animation:slidein .28s cubic-bezier(.2,.85,.3,1)}@keyframes slidein{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.detail-scroll{flex:1;overflow-y:auto;scrollbar-width:none}.detail-scroll::-webkit-scrollbar{display:none}.hero{position:relative;height:330px;background:linear-gradient(150deg,var(--accent-soft),var(--surface-sunk));display:flex;align-items:center;justify-content:center}.hero img{width:100%;height:100%;object-fit:cover}.hero .glyph{font-family:Bricolage Grotesque;font-weight:700;font-size:90px;color:color-mix(in srgb,var(--accent) 45%,var(--ink-3))}.hero .scrim-top{position:absolute;inset:0 0 auto 0;height:120px;background:linear-gradient(180deg,var(--scrim),transparent)}.hero .scrim-bot{position:absolute;inset:auto 0 0 0;height:160px;background:linear-gradient(0deg,var(--bg),transparent)}.detail .topbar{position:absolute;top:calc(env(safe-area-inset-top) + 14px);left:0;right:0;z-index:5;display:flex;justify-content:space-between;padding:0 16px}.detail .topbar .icon-btn{background:var(--scrim);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;box-shadow:none}.detail-body{padding:0 18px 30px;margin-top:-44px;position:relative;z-index:2}.detail-body h1{font-family:Bricolage Grotesque;font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1.05;text-wrap:balance}.detail .metarow{display:flex;gap:7px;flex-wrap:wrap;margin:14px 0 4px}.stat{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-md);padding:9px 13px;display:flex;flex-direction:column;gap:1px}.stat .v{font-family:Bricolage Grotesque;font-weight:700;font-size:17px;color:var(--ink)}.stat .k{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.kitchen-card{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-card);padding:15px;margin:18px 0;box-shadow:var(--shadow-card)}.kitchen-card .kc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:11px}.kitchen-card .kc-head .t{font-weight:800;font-size:14px;white-space:nowrap}.kitchen-card .kc-head .frac{font-family:Bricolage Grotesque;font-weight:700;font-size:15px;color:var(--accent-ink);flex:0 0 auto}.seg-mini{display:flex;gap:8px}.seg-mini .pill{flex:1;text-align:center;padding:7px;border-radius:var(--r-sm);font-size:12.5px;font-weight:700}.seg-mini .have{background:var(--have-soft);color:color-mix(in srgb,var(--have) 75%,#000)}.seg-mini .miss{background:var(--miss-soft);color:color-mix(in srgb,var(--miss) 78%,#000)}[data-theme=dark] .seg-mini .have{color:var(--have)}[data-theme=dark] .seg-mini .miss{color:var(--miss)}.sec-h{display:flex;align-items:center;justify-content:space-between;margin:24px 0 12px}.sec-h h2{font-family:Bricolage Grotesque;font-size:21px;font-weight:700;letter-spacing:-.01em}.stepper{display:flex;align-items:center;gap:2px;background:var(--surface);border:1.5px solid var(--line-2);border-radius:var(--r-pill);padding:3px}.stepper button{width:30px;height:30px;color:var(--accent-ink);font-size:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.stepper button:active{background:var(--accent-soft)}.stepper .val{min-width:36px;text-align:center;font-weight:800;font-variant-numeric:tabular-nums;font-size:15px}.ing-line{display:flex;align-items:baseline;gap:11px;padding:10px 0;border-bottom:1px solid var(--line)}.ing-line .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;align-self:center}.ing-line.have .dot{background:var(--have)}.ing-line.miss .dot{background:var(--miss);box-shadow:0 0 0 3px var(--miss-soft)}.ing-line .q{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent-ink);flex:0 0 auto;min-width:58px;font-size:14.5px}.ing-line .nm{flex:1;font-size:15px}.ing-line.miss .nm{color:var(--ink-2)}.steps{list-style:none;counter-reset:s}.steps li{display:flex;gap:13px;padding:11px 0;counter-increment:s;line-height:1.55}.steps li:before{content:counter(s);flex:0 0 28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent-ink);font-family:Bricolage Grotesque;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}.notes{background:var(--surface-2);border:1.5px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:13px 15px;line-height:1.6;color:var(--ink-2);font-size:14.5px;white-space:pre-wrap}.detail-actions{display:flex;gap:10px;padding:14px 18px calc(18px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--surface)}.section-label{font-family:Bricolage Grotesque;font-size:19px;font-weight:700;letter-spacing:-.01em;margin:22px 0 12px;display:flex;align-items:center;gap:9px}.pantry-wrap{display:flex;flex-wrap:wrap;gap:8px}.p-chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1.5px solid var(--line-2);border-radius:var(--r-pill);padding:9px 9px 9px 14px;font-size:14px;font-weight:600}.p-chip button{background:var(--surface-sunk);color:var(--ink-3);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.p-chip button svg{width:12px;height:12px}.shop-item{display:flex;align-items:center;gap:13px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-md);padding:13px 14px;margin-bottom:9px;box-shadow:var(--shadow-card);transition:.18s ease}.shop-item.done{opacity:.55}.shop-item .check{width:24px;height:24px;border-radius:8px;border:2px solid var(--line-2);flex:0 0 auto;display:flex;align-items:center;justify-content:center;transition:.15s ease}.shop-item.done .check{background:var(--accent);border-color:var(--accent)}.shop-item .check svg{width:14px;height:14px;color:#fff}.shop-item .nm{flex:1;font-size:15px;font-weight:500}.shop-item.done .nm{text-decoration:line-through;color:var(--ink-3)}.shop-item .src{font-size:11px;font-weight:700;color:var(--accent-ink);background:var(--accent-soft);padding:3px 8px;border-radius:99px}.shop-item .del{color:var(--ink-3);width:26px;height:26px;display:flex;align-items:center;justify-content:center}.empty{text-align:center;padding:60px 28px}.empty .ill{width:96px;height:96px;margin:0 auto 18px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent-ink)}.empty .ill svg{width:44px;height:44px}.empty h3{font-family:Bricolage Grotesque;font-size:20px;font-weight:700;margin-bottom:6px}.empty p{color:var(--ink-3);font-size:14px;max-width:240px;margin:0 auto;line-height:1.5}.addbar{display:flex;gap:9px;margin-bottom:6px}.addbar .search{flex:1;margin:0}.addbar .btn{flex:0 0 auto;padding:0 18px}.muted{color:var(--ink-3)}
