:root{--bg: #f5f6f5;--surface: #ffffff;--surface-2: #eef1ee;--border: #e4e7e4;--text: #1d231f;--muted: #8a958c;--accent: #16a34a;--accent-press: #15803d;--accent-soft: #e7f5ec;--danger: #e0483a;--shadow: 0 1px 2px rgba(20, 40, 25, .06), 0 1px 3px rgba(20, 40, 25, .05);color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font:16px/1.4 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}.muted{color:var(--muted)}.error{color:var(--danger);margin:0;font-size:.9rem}button{font:inherit;cursor:pointer;border:none;border-radius:12px;background:var(--accent);color:#fff;padding:.6rem 1rem;font-weight:600;transition:background .12s ease,opacity .12s ease}button:active{background:var(--accent-press)}button:disabled{opacity:.4;cursor:default}.link{background:none;color:var(--accent);padding:.3rem .5rem}.icon-btn{background:none;color:var(--muted);padding:.35rem .55rem;font-size:1.1rem;line-height:1;font-weight:400;border-radius:10px}.icon-btn:active{background:var(--surface-2)}.icon-btn.ghost{color:var(--muted)}input:not([type=checkbox]){font:inherit;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:.6rem .75rem;width:100%}input:not([type=checkbox]):focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.screen{min-height:100%;max-width:640px;margin:0 auto;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.center{display:flex;align-items:center;justify-content:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:1.75rem;box-shadow:var(--shadow)}.login{display:flex;flex-direction:column;gap:.75rem;width:min(340px,90vw)}.brand{margin:0;font-size:1.9rem;font-weight:800;letter-spacing:-.02em;color:var(--accent)}.login .muted{margin:-.5rem 0 .5rem}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:.25rem;padding:.6rem .75rem;background:#f5f6f5d9;-webkit-backdrop-filter:saturate(1.4) blur(8px);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--border)}.spacer{flex:1}.tabs{display:flex;gap:.2rem;background:var(--surface-2);border-radius:12px;padding:.2rem}.tab{background:none;color:var(--muted);padding:.35rem .9rem;border-radius:9px;font-weight:600}.tab.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.cat-select{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:.4rem .5rem;max-width:9rem}.list-switcher{position:relative;flex:none;min-width:0}.ls-btn{display:flex;align-items:center;gap:.3rem;max-width:11rem;background:var(--surface-2);color:var(--text);font-weight:700;padding:.4rem .7rem;border-radius:12px}.ls-btn:disabled{opacity:1;background:none;padding-left:.2rem}.ls-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ls-caret{flex:none;font-size:.7rem;color:var(--muted)}.ls-menu{position:absolute;left:0;top:calc(100% + .45rem);z-index:31;min-width:12rem;display:flex;flex-direction:column;padding:.4rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px #1428192e}.ls-option{text-align:left;background:none;color:var(--text);font-weight:600;padding:.55rem .6rem;border-radius:9px}.ls-option.on{color:var(--accent)}.ls-option:active{background:var(--surface-2)}.acct-wrap{position:relative;flex:none}.avatar{width:2.1rem;height:2.1rem;padding:0;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center}.acct-menu{position:absolute;right:0;top:calc(100% + .45rem);z-index:31;min-width:12rem;display:flex;flex-direction:column;gap:.55rem;padding:.7rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px #1428192e}.acct-who{font-size:.85rem;color:var(--muted);padding:.1rem .25rem}.acct-who strong{color:var(--text)}.acct-signout{width:100%}.add-bar{display:flex;gap:.5rem;padding:.75rem}.add-bar input{flex:1}.cat-section{margin-top:.25rem}.cat-header{position:sticky;top:3.1rem;z-index:5;margin:0;padding:.4rem 1rem;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:#f5f6f5d9;-webkit-backdrop-filter:saturate(1.4) blur(8px);backdrop-filter:saturate(1.4) blur(8px);display:flex;align-items:center;gap:.5rem;cursor:pointer;user-select:none;-webkit-user-select:none}.cat-header:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.cat-dot{width:.6rem;height:.6rem;border-radius:50%;flex:none}.cat-name{flex:1;min-width:0}.cat-chevron{flex:none;font-size:1.1rem;line-height:1;transition:transform .15s ease}.cat-chevron.collapsed{transform:rotate(-90deg)}.cat-count{flex:none;font-size:.72rem;font-weight:700;color:var(--muted);background:#0000000f;border-radius:999px;padding:.05rem .5rem}.list-toolbar{display:flex;justify-content:flex-end;padding:.15rem .6rem 0}.swatch-wrap{position:relative;flex:none}.swatch{width:1.5rem;height:1.5rem;border-radius:50%;border:1px solid rgba(0,0,0,.12);padding:0;cursor:pointer}.swatch.none{background:var(--surface);border:1.5px dashed var(--muted)}.palette-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30}.palette{position:absolute;top:calc(100% + .3rem);left:0;z-index:31;display:grid;grid-template-columns:repeat(8,auto);gap:.4rem;padding:.55rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px #1428192e}.dot{width:1.5rem;height:1.5rem;border-radius:50%;border:2px solid transparent;padding:0;cursor:pointer}.dot.sel{border-color:var(--text)}.dot.none{background:var(--surface);border:1.5px dashed var(--muted)}.items{list-style:none;margin:0;padding:0 .5rem .35rem}.list-tail{height:4.5rem}.item{display:flex;align-items:center;gap:.25rem;padding:.2rem .25rem;border-bottom:1px solid var(--border)}.item.editing{gap:.5rem;padding:.4rem .25rem}.check{flex:1;display:flex;align-items:center;gap:.8rem;padding:.55rem .5rem;cursor:pointer;min-width:0}.check input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;flex:none;width:1.4rem;height:1.4rem;margin:0;border:2px solid #c7d0c9;border-radius:50%;background:var(--surface);display:grid;place-content:center;cursor:pointer;transition:background .12s ease,border-color .12s ease}.check input[type=checkbox]:after{content:"";width:.7rem;height:.7rem;border-radius:50%;transform:scale(0);background:#fff;transition:transform .12s ease}.check input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.check input[type=checkbox]:checked:after{content:"✓";width:auto;height:auto;background:none;color:#fff;font-size:.85rem;font-weight:700;transform:scale(1)}.name{flex:1;min-width:0}.item.checked .name{color:var(--muted);text-decoration:line-through}.qty-tag{margin-left:.5rem;font-size:.8rem;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:.05rem .5rem}.grow{flex:1}.qty{flex:0 0 5rem;width:5rem}.empty{text-align:center;padding:2rem 0}.footer{position:fixed;bottom:0;left:0;right:0;max-width:640px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem calc(.6rem + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 12px #1428190d}.footer-actions{display:flex;align-items:center;gap:.5rem}.manage{padding:.5rem .5rem 5rem}.manage section{margin-bottom:1.5rem}.section-title{margin:.5rem .5rem .25rem;font-size:1rem;font-weight:700}.hint{margin:0 .5rem .5rem;font-size:.85rem}.rows{list-style:none;margin:0;padding:0 .5rem}.row{display:flex;align-items:center;gap:.35rem;padding:.3rem .25rem;border-bottom:1px solid var(--border)}.row .grow{flex:1;min-width:0}.row.on-list .grow{color:var(--accent)}.badge{color:var(--accent);padding:.35rem .55rem;font-size:1.1rem;line-height:1}.drag-handle{background:none;border:none;color:#c2ccc4;cursor:grab;touch-action:none;padding:.5rem .4rem;font-size:1.05rem;line-height:1}.drag-handle:active{cursor:grabbing}.item.dragging,.row.dragging{background:var(--surface);border-radius:12px;border-bottom-color:transparent;box-shadow:0 8px 24px #1428192e;position:relative;z-index:2}.cat-add{flex:none;background:none;color:var(--accent);font-size:1.15rem;line-height:1;font-weight:400;padding:.1rem .3rem;border-radius:8px}.cat-add:active{background:#0000000f}.fab{position:fixed;right:max(1rem,calc(50% - 320px));bottom:calc(1.25rem + env(safe-area-inset-bottom));width:3.5rem;height:3.5rem;padding:0;border-radius:50%;font-size:1.9rem;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #14281947;z-index:20;transition:bottom .15s ease,background .12s ease}.fab.raised{bottom:calc(4.6rem + env(safe-area-inset-bottom))}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e1659;z-index:40}.sheet{position:fixed;left:0;right:0;bottom:0;max-width:640px;margin:0 auto;background:var(--surface);border-radius:20px 20px 0 0;box-shadow:0 -8px 30px #1428192e;padding:1rem 1rem calc(1rem + env(safe-area-inset-bottom));z-index:41}.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}.sheet-title{font-weight:700}.sheet-form{display:flex;flex-direction:column;gap:.6rem}.sheet-row{display:flex;gap:.5rem}.sheet-cat{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:.6rem .75rem;width:100%}.sheet-suggestions{list-style:none;margin:0;padding:0;max-height:40vh;overflow-y:auto;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.sheet-suggestion{width:100%;text-align:left;background:none;color:var(--text);font-weight:500;padding:.65rem .75rem;border-radius:0;border-bottom:1px solid var(--border)}.sheet-suggestions li:last-child .sheet-suggestion{border-bottom:none}.sheet-suggestion:active{background:var(--surface-2)}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(4.7rem + env(safe-area-inset-bottom));z-index:50;display:flex;align-items:center;gap:.9rem;max-width:min(420px,calc(100% - 2rem));padding:.7rem .75rem .7rem 1rem;background:#1f2421;color:#f3f6f4;border-radius:12px;box-shadow:0 8px 24px #14281947}.toast-msg{flex:1;min-width:0;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-undo{flex:none;background:none;color:#6ee7a0;font-weight:700;padding:.25rem .5rem}.sync-dot{font-size:.7rem;padding:0 .3rem}.sync-dot.active{color:var(--accent)}.sync-dot.paused{color:var(--accent);opacity:.6}.sync-dot.offline{color:var(--muted)}.sync-dot.error{color:var(--danger)}.sync-dot.idle{color:var(--muted);opacity:.5}
