:root{--bg:#f7f7f5;--card:#fff;--text:#1f2430;--muted:#6b7280;--border:#e5e7eb;--accent:#16a34a;--accent-ink:#fff;--danger:#dc2626;--code-bg:#f1f5f2;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font:16px/1.5 system-ui,Segoe UI,Roboto,sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#14171c;--card:#1d2127;--text:#e5e7eb;--muted:#9ca3af;--border:#2e333c;--accent:#22c55e;--code-bg:#232a2500}}*{box-sizing:border-box}body{margin:0}#root{width:100%;max-width:560px;min-height:100svh;padding:env(safe-area-inset-top) 16px env(safe-area-inset-bottom);margin:0 auto}h1{margin:0 0 4px;font-size:28px}h2{margin:0 0 8px;font-size:22px}h3{margin:0 0 8px;font-size:17px}p{margin:0 0 8px}code{background:var(--code-bg);border-radius:6px;padding:2px 6px;font-family:ui-monospace,Consolas,monospace;font-size:14px}.splash{place-items:center;min-height:100svh;font-size:48px;animation:1.2s ease-in-out infinite pulse;display:grid}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;margin:16px 0;padding:20px}.muted{color:var(--muted)}.small{font-size:13px}form{flex-direction:column;gap:12px;margin-top:16px;display:flex}label{color:var(--muted);flex-direction:column;gap:6px;font-size:14px;display:flex}input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:10px;padding:12px;font-size:16px}input:focus{outline:2px solid var(--accent);outline-offset:1px}button{background:var(--accent);color:var(--accent-ink);cursor:pointer;border:none;border-radius:10px;padding:12px 16px;font-size:16px;font-weight:600}button:disabled{opacity:.6;cursor:default}button.link{color:var(--accent);background:0 0;width:100%;padding:8px;font-weight:500}.tabs{gap:8px;margin-top:16px;display:flex}.tabs button{background:var(--bg);color:var(--muted);border:1px solid var(--border);flex:1}.tabs button.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.error{color:var(--danger);font-size:14px}.success{color:var(--accent);font-size:14px}.shell header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.shell header .link{width:auto}.next ul{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.next li{color:var(--muted)}.tabview{padding:8px 0 84px}.tabbar{background:var(--card);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);max-width:560px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.tabbar button{color:var(--muted);background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 0 8px;font-size:12px;font-weight:500;display:flex}.tabbar button.active{color:var(--accent)}.tabbar .icon{font-size:20px}.seg{gap:6px;margin:12px 0;display:flex}.seg button{text-transform:capitalize;background:var(--bg);color:var(--muted);border:1px solid var(--border);flex:1;padding:8px 0;font-size:14px}.seg button.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.preview{object-fit:cover;border:1px solid var(--border);border-radius:12px;width:100%;max-height:320px;margin:12px 0}.row{gap:8px;margin-top:12px;display:flex}.row button{flex:1}button.ghost{background:var(--bg);color:var(--text);border:1px solid var(--border)}.items{flex-direction:column;gap:8px;margin:12px 0;padding:0;list-style:none;display:flex}.items li{background:var(--card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:8px;padding:8px 10px;display:flex}.items li.excluded{opacity:.45}.items .name{flex:1;min-width:0;font-size:15px}.items input.name{background:0 0;border:none;padding:6px 0}.items input.name:focus{border-bottom:1px solid var(--accent);outline:none}.items .qty{text-align:center;width:56px;padding:6px;font-size:14px}.items .unit{width:48px;font-size:13px}.items input.unit{width:56px;padding:6px;font-size:13px}.items .del{color:var(--danger);background:0 0;border:none;width:auto;padding:4px 6px;font-size:16px}.inventory section,.cook section{margin-bottom:8px}.inventory h3{margin:16px 0 6px}.cook-head{justify-content:space-between;align-items:center;display:flex}.cook-head .link{width:auto}.cook section{margin:8px 0 20px}.invite-foot{text-align:center;margin-top:24px}.cards{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px;display:grid}.rcard{background:var(--card);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;display:flex;position:relative;overflow:hidden}.rcard img{aspect-ratio:4/3;object-fit:cover;background:var(--bg);width:100%}.rcard-body{flex-direction:column;gap:6px;padding:8px 10px 10px;display:flex}.rtitle{font-size:14px;font-weight:600;line-height:1.25}.badge{border-radius:6px;align-self:flex-start;padding:2px 6px;font-size:11px}.badge.ok{background:var(--accent-bg,#22c55e26);color:var(--accent)}.badge.need{color:#a16207;background:#eab30829}.heart{color:#fff;background:#00000073;border:none;border-radius:50%;place-items:center;width:34px;height:34px;padding:0;font-size:18px;line-height:1;display:grid;position:absolute;top:6px;right:6px}.heart.on{color:#ff5a7a}.modal-backdrop{z-index:50;background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:16px 16px 0 0;width:100%;max-width:560px;max-height:92svh;position:relative;overflow-y:auto}.modal-close{color:#fff;z-index:2;background:#00000080;border:none;border-radius:50%;width:34px;height:34px;padding:0;font-size:16px;position:absolute;top:10px;right:10px}.modal-img{object-fit:cover;width:100%;max-height:240px}.modal-body{padding:16px 18px 28px}.modal-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.modal-head h2{flex:1}.modal-head .heart{background:var(--bg);color:var(--muted);flex-shrink:0;position:static}.modal-head .heart.on{color:#ff5a7a}.shop{background:#eab3081f;border-radius:8px;padding:8px 10px;font-size:14px}.ing{padding-left:18px}.ing li{margin:3px 0}.steps{padding-left:20px}.steps li{margin:8px 0;line-height:1.5}.source{color:var(--accent);margin-top:12px;font-weight:600;display:inline-block}.chef{margin-top:8px}.chef>button{width:100%;margin:8px 0}.chef-list{flex-direction:column;gap:8px;display:flex}.chef-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.chef-head{width:100%;color:var(--text);text-align:left;background:0 0;border:none;border-radius:0;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;font-weight:400;display:flex}.chef-head .rtitle{font-size:15px}.chev{color:var(--muted);flex-shrink:0;font-size:12px}.chef-detail{padding:0 14px 14px}.chef-detail p{margin:4px 0}.chef-detail .steps{margin-top:8px}.header-actions{align-items:center;gap:6px;display:flex}.icon-btn{cursor:pointer;background:0 0;border:none;width:auto;padding:4px 6px;font-size:20px;line-height:1}.meals{flex-wrap:wrap;gap:6px;margin:10px 0 4px;display:flex}.meals button{background:var(--bg);color:var(--muted);border:1px solid var(--border);flex:28%;padding:10px 4px;font-size:13px;font-weight:500}.meals button.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.chipgroup{margin:16px 0}.chipgroup h3{margin:0 0 8px}.chips{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:16px;width:auto;padding:6px 12px;font-size:13px;font-weight:400}.chip.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.additem{gap:6px;margin:12px 0 4px;display:flex}.additem input{flex:1;min-width:0}.additem select{border:1px solid var(--border);background:var(--bg);width:auto;color:var(--text);border-radius:10px;padding:0 8px;font-size:14px}.additem button{width:auto;padding:12px 16px}.qtyctl{align-items:center;gap:4px;display:flex}.step{background:var(--bg);width:32px;height:32px;color:var(--text);border:1px solid var(--border);border-radius:8px;flex-shrink:0;place-items:center;padding:0;font-size:20px;line-height:1;display:grid}.qtyctl .qty{width:46px}.dup{background:#eab3081f;border:1px solid #eab30866;border-radius:10px;margin:8px 0;padding:10px 12px}.dup .row{margin-top:8px}.dup .row button{padding:8px 10px;font-size:13px}.scanreview li{flex-direction:column;align-items:stretch;gap:6px}.rowmain{align-items:center;gap:8px;display:flex}.rowmain .name{flex:1;min-width:0}.dupline{flex-wrap:wrap;align-items:center;gap:6px;padding-left:26px;display:flex}.mergepill{background:var(--bg);width:auto;color:var(--muted);border:1px solid var(--border);border-radius:14px;padding:4px 10px;font-size:12px;font-weight:500}.mergepill.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.cart{background:#00000073;border:none;border-radius:50%;place-items:center;width:34px;height:34px;padding:0;font-size:15px;display:grid;position:absolute;top:6px;left:6px}.shoplist{flex-direction:column;gap:6px;margin:12px 0;padding:0;list-style:none;display:flex}.shoplist li{background:var(--card);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.shoplist label{cursor:pointer;flex:1;align-items:center;gap:10px;min-width:0;display:flex}.shoplist input[type=checkbox]{flex-shrink:0;width:20px;height:20px}.shoplist li.done .sname{color:var(--muted);text-decoration:line-through}.snote{margin-left:4px}.shopactions{margin-top:12px}.shop p{margin:0}.addshop{width:auto;margin-top:8px;padding:8px 12px;font-size:13px}.toast{color:#fff;z-index:60;background:#000000d9;border-radius:20px;padding:8px 16px;font-size:14px;position:fixed;bottom:92px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000004d}
