:root{color-scheme:light dark;--bg: oklch(.975 .011 78);--surface: oklch(.992 .008 84);--surface-2: oklch(.955 .015 76);--ink: oklch(.265 .021 50);--muted: oklch(.478 .028 56);--line: oklch(.895 .014 76);--line-2: oklch(.848 .02 74);--accent: oklch(.605 .15 42);--accent-ink: oklch(.985 .01 82);--olive: oklch(.52 .085 128);--olive-ink: oklch(.985 .01 120);--olive-text: oklch(.43 .085 128);--danger: oklch(.56 .16 28);--r-sm: 10px;--r: 14px;--r-lg: 20px;--space-2xs: 4px;--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--shadow-sm: 0 1px 2px oklch(.3 .03 50 / .06);--shadow: 0 1px 2px oklch(.3 .03 50 / .05), 0 8px 24px -10px oklch(.3 .05 50 / .16);--font-display: "Young Serif", Georgia, "Times New Roman", serif;--font-body: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--ease: cubic-bezier(.22, 1, .36, 1);accent-color:var(--accent)}@media(prefers-color-scheme:dark){:root{--bg: oklch(.205 .013 52);--surface: oklch(.245 .016 54);--surface-2: oklch(.29 .018 55);--ink: oklch(.93 .012 82);--muted: oklch(.712 .021 74);--line: oklch(.322 .017 55);--line-2: oklch(.382 .02 55);--accent: oklch(.705 .135 47);--accent-ink: oklch(.21 .03 44);--olive: oklch(.72 .088 128);--olive-ink: oklch(.21 .028 120);--olive-text: oklch(.78 .085 128);--danger: oklch(.705 .15 32);--shadow-sm: 0 1px 2px oklch(0 0 0 / .3);--shadow: 0 1px 2px oklch(0 0 0 / .3), 0 10px 28px -12px oklch(0 0 0 / .5)}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font:400 16px/1.5 var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}::selection{background:color-mix(in oklab,var(--accent) 26%,transparent)}:where(button,input,a):focus-visible{outline:2px solid var(--accent);outline-offset:2px}button{font:600 15px/1 var(--font-body);background:var(--surface-2);color:var(--ink);border:1px solid var(--line-2);border-radius:var(--r);padding:12px 16px;cursor:pointer;transition:transform .12s var(--ease),background-color .2s ease,border-color .2s ease,color .2s ease}button:active{transform:translateY(1px) scale(.99)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent;box-shadow:var(--shadow-sm)}button.ghost{background:transparent;border-color:var(--line-2)}button.link{background:none;border:none;color:var(--muted);padding:6px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:4px;font-weight:500}button.link:hover{color:var(--ink)}input[type=text],input[type=password]{font:400 16px/1.4 var(--font-body);background:var(--surface);border:1px solid var(--line-2);color:var(--ink);border-radius:var(--r);padding:13px 15px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}input::placeholder{color:var(--muted)}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 18%,transparent)}.app{position:relative;z-index:1;max-width:680px;margin:0 auto;padding:20px 16px 104px}.topbar{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:18px}.topbar h1{margin:0;font:400 clamp(26px,7vw,33px) / 1 var(--font-display);letter-spacing:.004em}.who{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;flex:0 0 auto}.dot{width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 3px color-mix(in oklab,var(--danger) 20%,transparent)}.dot.on{background:var(--olive);box-shadow:0 0 0 3px color-mix(in oklab,var(--olive) 22%,transparent)}.addbar{display:flex;gap:10px;margin-bottom:14px;position:sticky;top:0;z-index:5;padding:10px 0;background:linear-gradient(var(--bg) 72%,transparent)}.addbar input{flex:1}.section-title{display:flex;align-items:center;gap:9px;font:400 15px/1 var(--font-display);color:var(--ink);letter-spacing:.01em;margin:24px 2px 10px}.section-title:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex:0 0 auto}.completed-head{display:flex;align-items:center;justify-content:space-between}.list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;animation:rise .42s var(--ease) both}.row{display:flex;align-items:center;gap:14px;padding:14px 16px;transition:opacity .25s ease,background-color .2s ease}.row+.row{border-top:1px solid var(--line)}.row .name{flex:1;min-width:0;overflow-wrap:anywhere}.row .qty{color:var(--muted);font-size:13px}.row.done{opacity:.6}.row.completing{background:color-mix(in oklab,var(--olive) 9%,transparent)}.row.completing .name{color:var(--muted);text-decoration:line-through;text-decoration-color:color-mix(in oklab,var(--muted) 55%,transparent)}.check{position:relative;width:27px;height:27px;flex:0 0 auto;border-radius:50%;border:2px solid var(--line-2);background:transparent;color:transparent;display:grid;place-items:center;font-size:14px;cursor:pointer;padding:0;transition:background-color .2s ease,border-color .2s ease,transform .15s var(--ease)}.check:after{content:"";position:absolute;top:-9px;right:-9px;bottom:-9px;left:-9px}.check:active{transform:scale(.88)}.check.on{background:var(--olive);border-color:var(--olive);color:var(--olive-ink)}.empty{color:var(--muted);text-align:center;margin-top:64px;font-family:var(--font-display);font-size:18px;line-height:1.5}.empty span{display:block;margin-top:6px;font-family:var(--font-body);font-size:14px}.note{color:var(--olive-text);font-size:13.5px;margin:10px 2px}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;color:var(--ink)}.chip.add{cursor:pointer;flex-direction:column;align-items:flex-start;gap:1px;background:color-mix(in oklab,var(--olive) 13%,var(--surface));border-color:color-mix(in oklab,var(--olive) 32%,var(--line));color:var(--olive-text);transition:transform .12s var(--ease)}.chip.add:active{transform:scale(.98)}.chip-x{background:none;border:none;color:var(--muted);padding:0;font-size:12px;cursor:pointer}.chip-meta{color:var(--olive-text);opacity:.72;font-size:11px}.day{padding:16px 0;border-bottom:1px solid var(--line)}.day:last-child{border-bottom:none}.day-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.day-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.day-label b{color:var(--ink);font-size:15px;font-weight:700}.day-empty{display:flex;gap:10px;align-items:center}.meal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px;box-shadow:var(--shadow-sm);animation:rise .42s var(--ease) both}.meal.cooked{opacity:.72}.meal.eating-out{display:flex;justify-content:space-between;align-items:center;color:var(--muted);background:transparent;border-style:dashed;box-shadow:none}.meal-top{display:flex;gap:12px}.thumb{width:60px;height:60px;border-radius:12px;object-fit:cover;flex:0 0 auto}.thumb.placeholder{display:grid;place-items:center;background:var(--surface-2);font-size:26px}.meal-body{flex:1;min-width:0}.meal-title{font:400 18px/1.25 var(--font-display);margin-bottom:8px;display:flex;align-items:center;gap:8px;overflow-wrap:anywhere}.badge{font:600 11px/1 var(--font-body);color:var(--olive-ink);background:var(--olive);border-radius:999px;padding:3px 8px}.meal-actions{display:flex;gap:6px;margin-top:10px;justify-content:flex-end;flex-wrap:wrap}.meal-actions .danger{color:var(--danger)}.inline{display:flex;gap:8px}.inline input{flex:1}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;background:var(--surface);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -8px 24px -14px #42261647}.tabbar button{flex:1;background:none;border:none;border-radius:0;color:var(--muted);padding:10px 8px 12px;font-size:20px;display:flex;flex-direction:column;align-items:center;gap:3px;transition:color .2s ease}.tabbar button span{font-size:11px;font-weight:600;letter-spacing:.02em}.tabbar button.on{color:var(--accent)}.login{position:relative;z-index:1;max-width:400px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:0 28px 12vh;text-align:center;animation:rise .5s var(--ease) both}.login h1{font:400 clamp(30px,9vw,40px) / 1.05 var(--font-display);margin:0 0 6px}.login p{margin:2px 0 0}.login .users{display:flex;flex-direction:column;gap:12px;margin-top:22px}.login .users .primary{padding:16px;font-size:16px}.login .err{color:var(--danger);margin-top:14px;font-size:14px;min-height:18px}.login .toggle{margin-top:20px}.login .code{width:100%;margin-top:14px;text-align:center}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}
