@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg:#eef0ec;--surface:#fff;--surface-2:#f7f8f6;--surface-3:#f0f2ee;--line:#171a1614;--line-2:#171a1624;--ink:#1a1d18;--ink-2:#5c6157;--ink-3:#8c9286;--accent:#1f8a5b;--accent-press:#197049;--accent-soft:#e4f3ea;--accent-soft-2:#d3ecdd;--accent-ink:#14543a;--warn:#c97a16;--warn-soft:#fbeed6;--danger:#c7402f;--danger-soft:#f8e3df;--fav:#d65384;--fav-soft:#fbe6ef;--info:#2a6f9e;--info-soft:#e3eef6;--sh-1:0 1px 2px #171a160d, 0 1px 1px #171a160a;--sh-2:0 4px 16px #171a1614, 0 1px 3px #171a160d;--sh-3:0 12px 36px #171a1629, 0 4px 12px #171a1614;--sh-fab:0 8px 22px #1f8a5b57;--r-xs:8px;--r-sm:12px;--r-md:16px;--r-lg:22px;--r-xl:30px;--r-pill:999px;--app-max:1180px;--col-max:720px;--pad:18px;--nav-h:74px;--safe-b:env(safe-area-inset-bottom,0px);--font:"Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}body{overflow:hidden}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input{font-family:inherit}svg:not([width]){flex:none;width:22px;height:22px}::selection{background:var(--accent-soft-2)}::-webkit-scrollbar{width:0;height:0}#root{background:radial-gradient(1200px 700px at 80% -10%, #f3f5f1 0%, transparent 60%), var(--bg);justify-content:center;height:100%;display:flex}.shell{background:var(--surface-2);flex-direction:column;width:100%;max-width:520px;height:100%;display:flex;position:relative;overflow:hidden}.view{background:var(--surface-2);flex-direction:column;display:flex;position:absolute;inset:0}.view__scroll{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;flex:1;overflow:hidden auto}.pad{padding:0 var(--pad)}.stack-b{padding-bottom:calc(var(--nav-h) + 96px + var(--safe-b))}.stack-b-sm{padding-bottom:calc(28px + var(--safe-b))}.statusbar{height:44px;color:var(--ink);letter-spacing:.2px;flex:none;justify-content:space-between;align-items:center;padding:0 22px;font-size:13px;font-weight:700;display:flex}.statusbar .dots{align-items:center;gap:6px;display:flex}.statusbar svg{display:block}.appbar{padding:6px var(--pad) 12px;background:var(--surface-2);flex-direction:column;flex:none;gap:14px;display:flex}.appbar__row{align-items:center;gap:12px;display:flex}.appbar__title{letter-spacing:-.6px;font-size:28px;font-weight:800;line-height:1.05}.appbar__sub{color:var(--ink-2);margin-top:2px;font-size:13.5px;font-weight:500}.appbar__spacer{flex:1}.iconbtn{border-radius:var(--r-pill);background:var(--surface);width:44px;height:44px;box-shadow:var(--sh-1);color:var(--ink);flex:none;place-items:center;transition:transform .12s,background .15s;display:grid}.iconbtn:active{transform:scale(.93)}.iconbtn--ghost{box-shadow:none;background:0 0}.iconbtn--soft{background:var(--accent-soft);color:var(--accent-ink);box-shadow:none}.iconbtn--soft[disabled]{opacity:.5}.iconbtn.is-on{background:var(--accent-soft);color:var(--accent-ink)}.iconbtn svg{width:22px;height:22px}.item__acts{flex:none;align-items:center;gap:2px;display:flex}.item__acts .iconbtn{width:38px;height:38px}.item__acts .iconbtn svg{width:19px;height:19px}.avatar{border-radius:var(--r-pill);background:var(--accent-soft);width:44px;height:44px;color:var(--accent-ink);box-shadow:var(--sh-1);place-items:center;font-size:15px;font-weight:800;display:grid}.topnav{background:var(--surface-2);flex:none;align-items:center;gap:6px;height:56px;padding:0 8px 0 6px;display:flex}.topnav__title{font-size:17px;font-weight:700}.topnav .appbar__spacer{flex:1}.search{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);height:50px;box-shadow:var(--sh-1);color:var(--ink-3);align-items:center;gap:10px;padding:0 16px;display:flex}.search svg{flex:none;width:20px;height:20px}.search input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:15.5px;font-weight:500}.search input::placeholder{color:var(--ink-3);font-weight:500}.chips{scrollbar-width:none;gap:9px;padding:2px 0;display:flex;overflow:auto hidden}.chips--wrap{flex-wrap:wrap;overflow:visible}.chip{border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--line);height:38px;color:var(--ink-2);white-space:nowrap;flex:none;align-items:center;gap:7px;padding:0 15px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.chip svg{width:16px;height:16px}.chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}.chip--warn.is-active{background:var(--warn);border-color:var(--warn)}.chip__count{border-radius:var(--r-pill);background:var(--surface-3);color:var(--ink-2);padding:1px 7px;font-size:12px;font-weight:700}.chip.is-active .chip__count{color:#fff;background:#ffffff38}.seclabel{letter-spacing:.8px;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:8px;padding:0 4px;font-size:12px;font-weight:800;display:flex}.seclabel .line{background:var(--line);flex:1;height:1px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1)}.list{flex-direction:column;gap:10px;display:flex}.item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1);align-items:center;gap:14px;min-height:64px;padding:12px 14px;transition:transform .12s,box-shadow .15s;display:flex}.item:active{transform:scale(.985)}.item__thumb{background:var(--surface-3);width:48px;height:48px;color:var(--ink-2);border-radius:13px;flex:none;place-items:center;font-size:22px;display:grid;overflow:hidden}.item__body{flex:1;min-width:0}.item__name{letter-spacing:-.2px;align-items:center;gap:7px;font-size:16px;font-weight:700;line-height:1.2;display:flex}.item__name .truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.item__meta{color:var(--ink-2);flex-wrap:wrap;align-items:center;gap:8px;margin-top:3px;font-size:13.5px;font-weight:500;display:flex}.item__qty{text-align:right;color:var(--ink);font-variant-numeric:tabular-nums;flex:none;font-size:16px;font-weight:800}.item__qty small{color:var(--ink-3);margin-top:1px;font-size:11.5px;font-weight:600;display:block}.group{margin-top:8px}.group__head{align-items:center;gap:10px;padding:18px 4px 10px;display:flex}.group__icon{background:var(--surface-3);border-radius:9px;place-items:center;width:30px;height:30px;font-size:16px;display:grid}.group__name{letter-spacing:-.2px;font-size:15px;font-weight:800}.group__count{color:var(--ink-3);font-size:13px;font-weight:600}.badge{border-radius:var(--r-pill);letter-spacing:-.1px;white-space:nowrap;align-items:center;gap:4px;height:23px;padding:0 9px;font-size:12px;font-weight:700;display:inline-flex}.badge svg{width:13px;height:13px}.badge--warn{background:var(--warn-soft);color:var(--warn)}.badge--danger{background:var(--danger-soft);color:var(--danger)}.badge--accent{background:var(--accent-soft);color:var(--accent-ink)}.badge--info{background:var(--info-soft);color:var(--info)}.badge--muted{background:var(--surface-3);color:var(--ink-2)}.badge--auto{background:var(--accent-soft);color:var(--accent-ink)}.dot-fav{color:var(--fav);place-items:center;display:inline-grid}.dot-fav svg{width:17px;height:17px}.btn{border-radius:var(--r-md);letter-spacing:-.2px;justify-content:center;align-items:center;gap:10px;width:100%;height:56px;font-size:16.5px;font-weight:700;transition:transform .12s,background .15s,box-shadow .15s;display:inline-flex}.btn:active{transform:scale(.975)}.btn svg{width:21px;height:21px}.btn--primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px #1f8a5b42}.btn--primary:active{background:var(--accent-press)}.btn--dark{background:var(--ink);color:#fff}.btn--soft{background:var(--accent-soft);color:var(--accent-ink)}.btn--ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line-2);box-shadow:var(--sh-1)}.btn--danger-ghost{background:var(--surface);color:var(--danger);border:1px solid var(--danger-soft)}.btn--sm{border-radius:var(--r-sm);height:46px;font-size:15px}.btn--lg{height:60px;font-size:17.5px}.btn[disabled]{opacity:.45;pointer-events:none}.btnrow{gap:12px;display:flex}.btnrow .btn{flex:1}.stepper{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-pill);align-items:center;gap:4px;padding:5px;display:inline-flex}.stepper button{border-radius:var(--r-pill);background:var(--surface);width:42px;height:42px;color:var(--ink);box-shadow:var(--sh-1);place-items:center;font-size:22px;font-weight:700;transition:transform .1s;display:grid}.stepper button:active{transform:scale(.9)}.stepper__val{text-align:center;font-variant-numeric:tabular-nums;min-width:64px;font-size:18px;font-weight:800}.stepper__val small{color:var(--ink-3);font-size:12px;font-weight:600}.tabbar{height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);-webkit-backdrop-filter:saturate(180%)blur(22px);border-top:1px solid var(--line);z-index:40;background:#ffffffed;align-items:stretch;display:flex;position:absolute;bottom:0;left:0;right:0}.tab{color:var(--ink-3);letter-spacing:-.1px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;font-size:11px;font-weight:700;transition:color .15s;display:flex;position:relative}.tab svg{width:25px;height:25px}.tab.is-active{color:var(--accent)}.tab__badge{border-radius:var(--r-pill);background:var(--danger);color:#fff;border:2px solid #fff;place-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:11px;font-weight:800;display:grid;position:absolute;top:8px;left:50%}.tab--slot{pointer-events:none}.fab{left:50%;bottom:calc(var(--nav-h) - 26px + var(--safe-b));border-radius:var(--r-pill);background:var(--accent);color:#fff;width:64px;height:64px;box-shadow:var(--sh-fab);z-index:45;border:4px solid var(--surface-2);place-items:center;transition:transform .14s;display:grid;position:absolute;transform:translate(-50%)}.fab:active{transform:translate(-50%)scale(.92)}.fab svg{width:30px;height:30px}.sheet-scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:73;background:#1416126b;position:absolute;inset:0}.sheet{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;box-shadow:var(--sh-3);z-index:74;max-height:92%;padding-bottom:var(--safe-b);flex-direction:column;animation:.34s cubic-bezier(.32,.72,0,1) both sheetUp;display:flex;position:absolute;bottom:0;left:0;right:0}.sheet.closing{animation:.24s forwards sheetDown}@keyframes sheetUp{0%{opacity:.35;transform:translateY(60px)}to{opacity:1;transform:none}}@keyframes sheetDown{0%{opacity:1;transform:none}to{opacity:.2;transform:translateY(102%)}}.sheet__grip{background:var(--line-2);border-radius:3px;flex:none;width:40px;height:5px;margin:10px auto 4px}.sheet__body{padding:8px 20px 22px;overflow-y:auto}.sheet__title{letter-spacing:-.4px;font-size:21px;font-weight:800}.empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:40px 30px;display:flex}.empty__art{background:var(--surface);border:1px solid var(--line);width:96px;height:96px;box-shadow:var(--sh-1);color:var(--accent);border-radius:28px;place-items:center;margin-bottom:12px;display:grid}.empty__art svg{width:46px;height:46px}.empty__title{letter-spacing:-.3px;font-size:19px;font-weight:800}.empty__text{color:var(--ink-2);max-width:280px;font-size:14.5px;font-weight:500;line-height:1.45}.ph{background:repeating-linear-gradient(45deg, var(--surface-3) 0 11px, var(--surface-2) 11px 22px);color:var(--ink-3);letter-spacing:.3px;place-items:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;display:grid;position:relative;overflow:hidden}.ph span{background:#ffffffc7;border-radius:6px;padding:3px 8px;font-weight:600}.row{align-items:center;gap:12px;display:flex}.between{justify-content:space-between}.wrap-gap{flex-direction:column;gap:14px;display:flex}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}.muted{color:var(--ink-2)}.tiny{font-size:12.5px}.center{text-align:center}.hide{display:none!important}.grow{flex:1}.fw7{font-weight:700}.fw8{font-weight:800}.switch{border-radius:var(--r-pill);background:var(--line-2);flex:none;width:52px;height:31px;transition:background .2s;position:relative}.switch:after{content:"";width:25px;height:25px;box-shadow:var(--sh-1);background:#fff;border-radius:50%;transition:transform .2s;position:absolute;top:3px;left:3px}.switch.is-on{background:var(--accent)}.switch.is-on:after{transform:translate(21px)}@keyframes viewIn{0%{transform:translate(8px)}to{transform:none}}@keyframes viewInUp{0%{transform:translateY(7px)}to{transform:none}}.anim-in{animation:.26s cubic-bezier(.2,.7,.2,1) both viewIn}.anim-up{animation:.3s cubic-bezier(.2,.7,.2,1) both viewInUp}.stagger>*{animation:.38s cubic-bezier(.2,.7,.2,1) both viewInUp}.stagger>:first-child{animation-delay:20ms}.stagger>:nth-child(2){animation-delay:50ms}.stagger>:nth-child(3){animation-delay:80ms}.stagger>:nth-child(4){animation-delay:.11s}.stagger>:nth-child(5){animation-delay:.14s}.stagger>:nth-child(6){animation-delay:.17s}.stagger>:nth-child(7){animation-delay:.2s}.stagger>:nth-child(8){animation-delay:.23s}.stagger>:nth-child(9){animation-delay:.26s}.stagger>:nth-child(10){animation-delay:.29s}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}.check-toggle{border:2px solid var(--line-2);color:#fff;background:0 0;border-radius:50%;flex:none;place-items:center;width:30px;height:30px;transition:all .18s;display:grid}.check-toggle svg{width:18px;height:18px}.check-toggle.is-on{background:var(--accent);border-color:var(--accent)}.item.is-cart{border-color:var(--accent-soft-2);background:var(--accent-soft)}.item.is-bought{opacity:.7}.recipe-card{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);flex-direction:column;transition:transform .14s,box-shadow .15s;display:flex;overflow:hidden}.recipe-card:active{transform:scale(.985)}.recipe-card__media{aspect-ratio:16/9;width:100%;position:relative}.recipe-card__saved{width:32px;height:32px;color:var(--fav);box-shadow:var(--sh-1);background:#ffffffeb;border-radius:50%;place-items:center;display:grid;position:absolute;top:10px;right:10px}.recipe-card__saved svg{width:17px;height:17px}.recipe-card__body{flex-direction:column;gap:9px;padding:13px 15px 15px;display:flex}.recipe-card__name{letter-spacing:-.3px;font-size:17px;font-weight:800;line-height:1.2}.recipe-card__meta{color:var(--ink-2);gap:14px;font-size:13px;font-weight:600;display:flex}.recipe-card__meta span{align-items:center;gap:5px;display:inline-flex}.recipe-card__meta svg{width:15px;height:15px}.recipe-card__tags{flex-wrap:wrap;gap:6px;display:flex}.have{border-radius:50%;flex:none;place-items:center;width:26px;height:26px;display:grid}.have svg{width:16px;height:16px}.have--yes{background:var(--accent-soft);color:var(--accent)}.have--low{background:var(--warn-soft);color:var(--warn)}.have--no{background:var(--danger-soft);color:var(--danger)}.onb{z-index:50;background:var(--surface);padding:0 26px calc(28px + var(--safe-b));flex-direction:column;display:flex;position:absolute;inset:0;overflow-y:auto}.onb__hero{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;min-height:320px;display:flex}.onb__mark{background:var(--accent);color:#fff;width:88px;height:88px;box-shadow:var(--sh-fab);border-radius:26px;place-items:center;display:grid}.onb__mark svg{width:46px;height:46px}.onb__h1{letter-spacing:-.8px;font-size:30px;font-weight:800;line-height:1.08}.onb__p{color:var(--ink-2);max-width:300px;font-size:15.5px;font-weight:500;line-height:1.5}.onb__card{border-radius:var(--r-md);background:var(--surface);border:1.5px solid var(--line);width:100%;box-shadow:var(--sh-1);text-align:left;align-items:center;gap:14px;padding:18px;transition:border-color .15s,transform .12s;display:flex}.onb__card:active{transform:scale(.99)}.onb__card.is-sel{border-color:var(--accent);background:var(--accent-soft)}.onb__card .icn,.onb__card .ci{background:var(--accent-soft);width:46px;height:46px;color:var(--accent-ink);border-radius:13px;flex:none;place-items:center;display:grid}.onb__card .ci svg{width:23px;height:23px}.onb__card h3{font-size:16px;font-weight:800}.onb__card p{color:var(--ink-2);margin-top:1px;font-size:13px;font-weight:500}.field{flex-direction:column;gap:7px;display:flex}.field label{color:var(--ink-2);padding-left:2px;font-size:13px;font-weight:700}.field input{border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--surface);height:54px;color:var(--ink);outline:none;padding:0 16px;font-size:16px;font-weight:600;transition:border-color .15s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--ink-3);font-weight:500}.segmented{background:var(--surface-3);border-radius:var(--r-pill);gap:4px;padding:4px;display:flex}.segmented button{border-radius:var(--r-pill);height:40px;color:var(--ink-2);flex:1;justify-content:center;align-items:center;gap:7px;font-size:14.5px;font-weight:700;transition:all .15s;display:inline-flex}.segmented button svg{width:17px;height:17px}.segmented button.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}.detail-hero{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:6px 0 18px;display:flex}.detail-hero__thumb{background:var(--surface);border:1px solid var(--line);width:92px;height:92px;box-shadow:var(--sh-1);border-radius:26px;place-items:center;font-size:44px;display:grid}.detail-hero__name{letter-spacing:-.5px;align-items:center;gap:8px;font-size:26px;font-weight:800;display:flex}.detail-hero__cat{color:var(--ink-2);font-size:13.5px;font-weight:600}.kv{justify-content:space-between;align-items:center;padding:16px;display:flex}.kv+.kv{border-top:1px solid var(--line)}.kv__k{align-items:center;gap:12px;font-size:15.5px;font-weight:600;display:flex}.kv__k .kvi{background:var(--surface-2);width:38px;height:38px;color:var(--ink-2);border-radius:11px;place-items:center;display:grid}.kv__k .kvi svg{width:20px;height:20px}.kv__v{color:var(--ink-2);align-items:center;gap:8px;font-size:15.5px;font-weight:700;display:flex}.prod{background:var(--surface-2);border-radius:var(--r-sm);align-items:center;gap:12px;padding:12px 14px;display:flex}.prod__code{color:var(--ink-3);font-family:ui-monospace,monospace;font-size:12px}.prod__bc{gap:2px;height:22px;display:flex}.prod__bc i{background:var(--ink-3);width:2px}.member{align-items:center;gap:13px;padding:14px;display:flex}.member+.member{border-top:1px solid var(--line)}.member__av{border-radius:50%;flex:none;place-items:center;width:46px;height:46px;font-size:15px;font-weight:800;display:grid}.member__name{font-size:16px;font-weight:700}.member__role{color:var(--ink-2);align-items:center;gap:5px;font-size:13px;font-weight:600;display:flex}.member__role svg{width:14px;height:14px;color:var(--warn)}.dock{left:0;right:0;bottom:calc(var(--nav-h) + var(--safe-b));padding:14px var(--pad) 16px;background:linear-gradient(transparent, var(--surface-2) 22%);z-index:41;position:absolute}@media (width>=880px){.dock{background:0 0;width:100%;max-width:860px;margin:0 auto;padding-bottom:24px;position:sticky;bottom:0}}.suggest{border-radius:var(--r-md);background:var(--accent-soft);border:1.5px solid var(--accent-soft-2);align-items:center;gap:14px;padding:16px;display:flex}.suggest__ico{width:50px;height:50px;box-shadow:var(--sh-1);background:#fff;border-radius:14px;flex:none;place-items:center;font-size:26px;display:grid}.suggest__q{color:var(--accent-ink);font-size:13px;font-weight:700}.suggest__name{letter-spacing:-.3px;font-size:19px;font-weight:800}.optionrow{border-radius:var(--r-md);border:1.5px solid var(--line);background:var(--surface);text-align:left;align-items:center;gap:13px;width:100%;padding:14px;transition:all .14s;display:flex}.optionrow:active{transform:scale(.99)}.optionrow.is-sel{border-color:var(--accent);background:var(--accent-soft)}.optionrow__ico{background:var(--surface-2);border-radius:12px;flex:none;place-items:center;width:42px;height:42px;font-size:21px;display:grid}.optionrow__name{color:var(--ink);font-size:15.5px;font-weight:700}.optionrow__sub{color:var(--ink-2);font-size:12.5px;font-weight:500}.optionrow__radio{border:2px solid var(--line-2);border-radius:50%;flex:none;place-items:center;width:24px;height:24px;margin-left:auto;display:grid}.optionrow.is-sel .optionrow__radio{border-color:var(--accent);background:var(--accent);color:#fff}.optionrow.is-sel .optionrow__radio svg{width:14px;height:14px}.foundhead{align-items:center;gap:14px;display:flex}.foundhead__img{border-radius:15px;flex:none;width:64px;height:64px}.foundhead__name{letter-spacing:-.2px;font-size:17px;font-weight:800;line-height:1.2}.foundhead__code{color:var(--ink-3);align-items:center;gap:6px;margin-top:3px;font-family:ui-monospace,monospace;font-size:12px;display:flex}.ai-banner{border-radius:var(--r-md);background:linear-gradient(120deg, var(--ink), #2d322a);color:#fff;align-items:center;gap:13px;padding:15px 16px;display:flex}.ai-banner__ico{background:#ffffff24;border-radius:12px;flex:none;place-items:center;width:40px;height:40px;display:grid}.ai-banner h3{font-size:15px;font-weight:800}.ai-banner p{color:#ffffffb8;margin-top:1px;font-size:12.5px;font-weight:500}.warnbox{border-radius:var(--r-md);background:var(--warn-soft);border:1px solid #c97a162e;gap:12px;padding:15px;display:flex}.warnbox svg{width:20px;height:20px;color:var(--warn);flex:none;margin-top:1px}.warnbox b{color:#9a5d12}.warnbox p{color:#7d4f17;font-size:13.5px;font-weight:600;line-height:1.4}.add-bar{background:var(--surface);border:1.5px dashed var(--line-2);border-radius:var(--r-pill);height:52px;color:var(--ink-2);align-items:center;gap:12px;width:100%;padding:0 14px;font-size:15.5px;font-weight:600;display:flex}.add-bar__ic{background:var(--accent-soft);width:34px;height:34px;color:var(--accent);border-radius:50%;flex:none;place-items:center;display:grid}.cart-progress{flex-direction:column;gap:8px;padding:6px 0 4px;display:flex}.cart-progress__bar{background:var(--surface-3);border-radius:4px;height:8px;overflow:hidden}.cart-progress__bar i{background:var(--accent);border-radius:4px;height:100%;transition:width .4s cubic-bezier(.2,.8,.2,1);display:block}.cart-progress__txt{color:var(--ink-2);font-size:13px;font-weight:700}.cart-scan-cta{border-radius:var(--r-md);background:var(--accent-soft);border:1px solid var(--accent-soft-2);color:var(--accent-ink);align-items:center;gap:13px;margin-top:14px;padding:15px;display:flex}.cart-scan-cta__ic{width:44px;height:44px;color:var(--accent);box-shadow:var(--sh-1);background:#fff;border-radius:12px;flex:none;place-items:center;display:grid}.cart-scan-cta svg:last-child{color:var(--accent);width:20px;height:20px}.ing{align-items:center;gap:13px;padding:13px 15px;display:flex}.ing+.ing{border-top:1px solid var(--line)}.recipe-hero{aspect-ratio:16/11;width:100%}.recipe-hero__back,.recipe-hero__fav{width:42px;height:42px;color:var(--ink);box-shadow:var(--sh-2);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border-radius:50%;place-items:center;display:grid;position:absolute;top:14px}.recipe-hero__back{left:var(--pad)}.recipe-hero__fav{right:var(--pad);color:var(--fav)}.recipe-hero__back svg,.recipe-hero__fav svg{width:21px;height:21px}.recipe-detail__title{letter-spacing:-.6px;font-size:27px;font-weight:800;line-height:1.12}.save-recipe{border-radius:var(--r-md);background:var(--fav-soft);border:1px solid #d6538429;padding:16px}.recipe-grid{flex-direction:column;gap:14px;display:flex}.group-hero{text-align:center;flex-direction:column;align-items:center;gap:7px;padding:10px 0 6px;display:flex}.group-hero__mark{background:var(--accent-soft);width:74px;height:74px;color:var(--accent-ink);border-radius:22px;place-items:center;margin-bottom:6px;display:grid}.group-hero__mark svg{width:36px;height:36px}.group-hero__name{letter-spacing:-.4px;font-size:23px;font-weight:800}.group-switch{border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--line-2);height:42px;box-shadow:var(--sh-1);align-items:center;gap:8px;margin-top:12px;padding:0 18px;font-size:14px;font-weight:700;display:inline-flex}.group-switch svg{width:17px;height:17px}.invite-card{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--line);width:100%;box-shadow:var(--sh-1);align-items:center;gap:13px;padding:16px;display:flex}.invite-card__ic{background:var(--accent);color:#fff;border-radius:13px;flex:none;place-items:center;width:44px;height:44px;display:grid}.invite-card>svg:last-child{color:var(--ink-3)}.invite-code{border-radius:var(--r-md);background:var(--surface-2);border:1.5px dashed var(--line-2);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.invite-code span{letter-spacing:2px;color:var(--ink);font-family:ui-monospace,monospace;font-size:20px;font-weight:800}.devbtn{z-index:85;border-radius:var(--r-pill);background:var(--ink);color:#fff;height:34px;box-shadow:var(--sh-2);opacity:.82;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex;position:absolute;top:50px;right:12px}.devbtn svg{width:14px;height:14px}@media (width>=880px){.devbtn{top:16px}}.devmenu{z-index:86;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#14161280;justify-content:center;align-items:flex-start;padding:70px 16px 20px;display:none;position:absolute;inset:0}.devmenu.is-open{display:flex}.devmenu__panel{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:420px;max-height:100%;box-shadow:var(--sh-3);flex-direction:column;display:flex;overflow:hidden}.devmenu__head{border-bottom:1px solid var(--line);align-items:center;padding:16px 18px;display:flex}.devmenu__head h3{font-size:16px;font-weight:800}.devmenu__list{grid-template-columns:1fr 1fr;gap:6px;padding:8px;display:grid;overflow-y:auto}.devmenu__item{text-align:left;border-radius:var(--r-sm);background:var(--surface-2);padding:12px 13px}.devmenu__item b{font-size:13.5px;font-weight:700;display:block}.devmenu__item span{color:var(--ink-2);font-size:11.5px}.devmenu__sec{text-transform:uppercase;letter-spacing:.6px;color:var(--ink-3);grid-column:1/-1;padding:10px 6px 2px;font-size:11px;font-weight:800}.scan{z-index:70;color:#fff;background:#14160f;flex-direction:column;animation:.28s viewInUp;display:flex;position:absolute;inset:0}.scan__cam{background:radial-gradient(120% 80% at 50% 0,#2a2d22 0%,#14160f 70%);position:absolute;inset:0;overflow:hidden}.scan__cam:before{content:"";filter:blur(1px);background:repeating-linear-gradient(115deg,#ffffff06 0 40px,#0000 40px 96px),repeating-linear-gradient(0deg,#ffffff08 0 2px,#0000 2px 120px);position:absolute;inset:-10%}.scan__top{z-index:2;padding:12px var(--pad);align-items:center;gap:10px;display:flex;position:relative}.scan__close{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff24;place-items:center;width:44px;height:44px;display:grid}.scan__close svg{width:22px;height:22px}.scan__mode{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#12140e99;border:1px solid #ffffff38;gap:4px;margin:0 auto;padding:4px;display:flex;box-shadow:0 4px 14px #0000004d}.scan__mode button{border-radius:var(--r-pill);color:#ffffffeb;align-items:center;gap:7px;height:38px;padding:0 18px;font-size:14px;font-weight:700;transition:all .18s;display:inline-flex}.scan__mode button svg{width:16px;height:16px}.scan__mode button.is-active{color:var(--ink);background:#fff}.scan__mode button.is-active.remove{background:var(--warn);color:#fff}.scan__frame{z-index:2;flex:1;place-items:center;display:grid;position:relative}.reticle{aspect-ratio:1.5;border-radius:22px;width:76%;max-width:320px;position:relative}.reticle:before{content:"";border-radius:22px;position:absolute;inset:0;box-shadow:0 0 0 2000px #0f100b75}.reticle__corner{border:3px solid #fff;width:34px;height:34px;position:absolute}.reticle__corner.tl{border-bottom:0;border-right:0;border-radius:14px 0 0;top:-2px;left:-2px}.reticle__corner.tr{border-bottom:0;border-left:0;border-radius:0 14px 0 0;top:-2px;right:-2px}.reticle__corner.bl{border-top:0;border-right:0;border-radius:0 0 0 14px;bottom:-2px;left:-2px}.reticle__corner.br{border-top:0;border-left:0;border-radius:0 0 14px;bottom:-2px;right:-2px}.reticle.remove .reticle__corner{border-color:var(--warn)}.reticle__laser{background:linear-gradient(90deg,#0000,#46d68d,#0000);height:2px;animation:2.4s ease-in-out infinite laser;position:absolute;top:50%;left:8%;right:8%;box-shadow:0 0 12px 2px #46d68d99}.reticle.remove .reticle__laser{background:linear-gradient(90deg,#0000,#f0b44a,#0000);box-shadow:0 0 12px 2px #f0b44a80}@keyframes laser{0%,to{top:16%}50%{top:84%}}.scan__barcode{opacity:.9;align-items:stretch;gap:3px;height:54px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scan__barcode i{background:#ffffffd9;border-radius:1px;width:3px}.scan__hint{z-index:2;text-align:center;color:#ffffffc7;padding:0 30px 14px;font-size:14.5px;font-weight:600;position:relative}.scan__bottom{z-index:2;padding:16px var(--pad) calc(26px + var(--safe-b));grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;display:grid;position:relative}.scan__manual{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff24;justify-content:center;justify-self:start;align-items:center;gap:9px;height:52px;padding:0 20px;font-size:15px;font-weight:700;display:inline-flex}.scan__manual svg{width:19px;height:19px}.scan__shutter{background:#ffffff29;border:5px solid #ffffffd9;border-radius:50%;flex:none;place-items:center;width:70px;height:70px;display:grid}.scan__shutter:after{content:"";background:#fff;border-radius:50%;width:52px;height:52px;transition:transform .1s}.scan__shutter:active:after{transform:scale(.9)}.scan__counter{top:64px;right:var(--pad);z-index:3;background:var(--accent);color:#fff;border-radius:var(--r-pill);height:34px;box-shadow:var(--sh-2);align-items:center;gap:7px;padding:0 13px;font-size:14px;font-weight:800;display:inline-flex;position:absolute}.scan__counter svg{width:16px;height:16px}.fridge-signal{z-index:90;opacity:0;pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.fridge-signal.is-on{opacity:1;pointer-events:auto}.fridge-signal__glow{opacity:0;background:radial-gradient(60% 45% at 50% 46%,#1f8a5b47,#0000 70%);position:absolute;inset:0}.fridge-signal.is-on .fridge-signal__glow{animation:1.5s both fgGlow}@keyframes fgGlow{0%{opacity:0}25%{opacity:1}70%{opacity:1}to{opacity:0}}.fridge-signal__scrim{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;background:#ffffff8c;position:absolute;inset:0}.fridge-signal.is-on .fridge-signal__scrim{animation:1.5s both fgScrim}@keyframes fgScrim{0%{opacity:0}20%{opacity:1}75%{opacity:1}to{opacity:0}}.fridge-signal__card{z-index:2;opacity:0;flex-direction:column;align-items:center;gap:16px;display:flex;position:relative;transform:scale(.8)}.fridge-signal.is-on .fridge-signal__card{animation:1.5s cubic-bezier(.2,.8,.2,1) both fgCard}@keyframes fgCard{0%{opacity:0;transform:scale(.8)}16%{opacity:1;transform:scale(1)}78%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.96)}}.fridge-icon{background:var(--accent);color:#fff;border-radius:30px;place-items:center;width:108px;height:108px;display:grid;position:relative;box-shadow:0 18px 40px #1f8a5b66}.fridge-icon svg{width:54px;height:54px}.fridge-icon__ring{border:2.5px solid var(--accent);border-radius:38px;position:absolute;inset:-10px}.fridge-signal.is-on .fridge-icon__ring{animation:1.5s ease-out both fgRing}@keyframes fgRing{0%{opacity:0;transform:scale(.85)}18%{opacity:.6}60%{opacity:0;transform:scale(1.5)}to{opacity:0}}.fridge-signal__label{color:var(--accent-ink);letter-spacing:-.2px;font-size:18px;font-weight:800}.fridge-signal__sub{color:var(--ink-2);margin-top:-8px;font-size:14px;font-weight:600}.fridge-icon .check{position:absolute}.toast-wrap{left:16px;right:16px;top:calc(12px + env(safe-area-inset-top,0px));z-index:80;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:absolute}.toast{background:var(--ink);color:#fff;border-radius:var(--r-md);box-shadow:var(--sh-3);align-items:center;gap:11px;padding:13px 16px;font-size:14.5px;font-weight:600;animation:.3s cubic-bezier(.2,.8,.2,1) toastIn;display:flex}.toast--accent{background:var(--accent)}.toast svg{flex:none;width:20px;height:20px}.toast .grow{flex:1}.toast button{color:#fff;opacity:.85;font-size:14px;font-weight:800}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.cook{z-index:70;background:var(--surface);flex-direction:column;animation:.28s viewInUp;display:flex;position:absolute;inset:0}.cook__bar{padding:14px var(--pad) 4px;gap:5px;display:flex}.cook__bar i{background:var(--surface-3);border-radius:3px;flex:1;height:5px;overflow:hidden}.cook__bar i.done{background:var(--accent)}.cook__bar i.now{background:var(--accent-soft-2)}.cook__num{padding:14px var(--pad) 0;letter-spacing:1px;text-transform:uppercase;color:var(--accent);font-size:13px;font-weight:800}.cook__title{padding:6px var(--pad) 0;letter-spacing:-.6px;font-size:30px;font-weight:800;line-height:1.1}.cook__media{margin:18px var(--pad) 0;border-radius:var(--r-lg);aspect-ratio:16/10}.cook__text{padding:20px var(--pad) 0;color:var(--ink);font-size:19px;font-weight:500;line-height:1.5}.cook__foot{padding:16px var(--pad) calc(22px + var(--safe-b));align-items:center;gap:12px;display:flex}.cook__navbtn{border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--line);place-items:center;width:60px;height:60px;display:grid}.cook__navbtn svg{width:24px;height:24px}.cook__navbtn[disabled]{opacity:.35}.timer{margin:18px var(--pad) 0;border-radius:var(--r-md);background:var(--accent-soft);border:1px solid var(--accent-soft-2);align-items:center;gap:14px;padding:16px;display:flex}.timer__time{font-variant-numeric:tabular-nums;color:var(--accent-ink);letter-spacing:-1px;font-size:30px;font-weight:800}.timer__btn{border-radius:var(--r-pill);background:var(--accent);color:#fff;align-items:center;gap:7px;height:44px;margin-left:auto;padding:0 18px;font-size:14.5px;font-weight:700;display:inline-flex}.timer__btn svg{width:17px;height:17px}@media (width>=880px){#root{align-items:stretch;padding:0}.shell{max-width:var(--app-max);background:var(--surface);--pad:30px;flex-direction:row;margin:0 auto;box-shadow:0 0 60px #0000000f}.tabbar{background:var(--surface-2);border-top:none;border-right:1px solid var(--line);-webkit-backdrop-filter:none;backdrop-filter:none;flex-direction:column;flex:none;align-items:stretch;gap:4px;width:248px;height:auto;padding:26px 16px;position:relative}.tabbar__brand{letter-spacing:-.4px;align-items:center;gap:11px;padding:4px 12px 22px;font-size:19px;font-weight:800;display:flex}.tabbar__brand .mark{background:var(--accent);color:#fff;border-radius:11px;place-items:center;width:38px;height:38px;display:grid}.tabbar__brand .mark svg{width:22px;height:22px}.tab{border-radius:var(--r-md);flex-direction:row;flex:none;justify-content:flex-start;gap:14px;height:52px;padding:0 14px;font-size:15.5px;font-weight:700;transition:background .15s,color .15s}.tab svg{width:23px;height:23px}.tab.is-active{color:var(--accent);background:var(--accent-soft)}.tab__badge{border:none;margin:0 0 0 auto;position:static}.tab--slot{display:none}.tabbar__scan{border-radius:var(--r-md);background:var(--accent);color:#fff;height:56px;box-shadow:var(--sh-fab);justify-content:center;align-items:center;gap:10px;margin-top:auto;font-size:16px;font-weight:800;display:flex}.tabbar__scan svg{width:24px;height:24px}.tabbar__me{border-radius:var(--r-md);align-items:center;gap:11px;margin-top:8px;padding:8px 10px;display:flex}.statusbar,.fab{display:none}.shell>.view-host{flex:1;min-width:0;position:relative;overflow:hidden}.view{left:0}.stack-b{padding-bottom:60px}.view__scroll>.pad,.view__scroll>.appbar,.view__scroll>.topnav{max-width:860px;margin-left:auto;margin-right:auto}.appbar{padding-top:26px}.appbar__title{font-size:32px}.grid-2{grid-template-columns:repeat(2,1fr);align-items:start;gap:12px;display:grid}.grid-2>.seclabel,.grid-2>.group__head{grid-column:1/-1}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid!important}.scan,.cook{border-radius:0}.sheet{border-radius:var(--r-xl);width:min(560px,92%);max-height:86%;margin:0 auto;bottom:24px;left:0;right:0}.toast-wrap{width:min(520px,90%);top:auto;bottom:30px;left:50%;transform:translate(-50%)}}.tabbar__brand,.tabbar__scan,.tabbar__me{display:none}@media (width>=880px){.tabbar__brand,.tabbar__scan,.tabbar__me{display:flex}}.view-host{flex:1;min-width:0;position:relative;overflow:hidden}.appbar,.topnav{padding-top:calc(8px + env(safe-area-inset-top,0px))}@media (width>=880px){.appbar,.topnav{padding-top:26px}}
