:root{font-family:system-ui,sans-serif;line-height:1.5;color:#0f172a;background:#f8fafc}body{margin:0;min-height:100vh}code{font-size:.9em;padding:.1em .35em;border-radius:.25rem;background:#e2e8f0}.app{max-width:32rem;margin:0 auto;padding:2.5rem 1.25rem 3rem}.header h1{margin:0 0 .35rem;font-size:1.75rem}.lede{margin:0;color:#475569}.muted{margin:.75rem 0 0;color:#64748b;font-size:.95rem}.panel{margin-top:1.5rem;padding:1rem 1.1rem;border-radius:.5rem;border:1px solid #cbd5e1;background:#fff}.panel.warn{border-color:#f59e0b;background:#fffbeb}.panel.error{border-color:#f87171;background:#fef2f2}.panel.error button{margin-top:.75rem}.shopping{margin-top:1.5rem}.row{display:flex;gap:.5rem}.row input{flex:1;min-width:0;padding:.5rem .65rem;border:1px solid #cbd5e1;border-radius:.375rem;font:inherit}button{font:inherit;cursor:pointer;padding:.5rem .85rem;border-radius:.375rem;border:1px solid #0f172a;background:#0f172a;color:#fff}button:disabled{opacity:.55;cursor:not-allowed}button.ghost{border-color:#cbd5e1;background:#fff;color:#0f172a;padding:.35rem .55rem;font-size:.85rem}.list{list-style:none;margin:1rem 0 0;padding:0;border:1px solid #e2e8f0;border-radius:.5rem;background:#fff;overflow:hidden}.list-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .85rem;border-top:1px solid #f1f5f9}.list-item:first-child{border-top:none}.item-label{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1;cursor:pointer}.item-label span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.done{text-decoration:line-through;color:#94a3b8}
