:root{--bg: #f4f6f8;--surface: #ffffff;--surface-2: #f0f2f5;--text: #1a2027;--text-dim: #6b7785;--text-faint: #9aa6b2;--border: #e4e8ed;--accent: #10b981;--accent-strong: #059669;--accent-soft: #d1fae5;--danger: #ef4444;--danger-strong: #dc2626;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .08);--shadow-md: 0 4px 12px rgba(16, 24, 40, .1);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .18);--radius: 14px;--radius-lg: 20px;color-scheme:light}@media (prefers-color-scheme: dark){:root{--bg: #0f1419;--surface: #1a2027;--surface-2: #232b34;--text: #e8edf2;--text-dim: #9aa6b2;--text-faint: #6b7785;--border: #2c353f;--accent: #10b981;--accent-strong: #34d399;--accent-soft: #0f3d30;--danger: #f87171;--danger-strong: #ef4444;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5);color-scheme:dark}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}.app{max-width:520px;margin:0 auto;min-height:100vh;padding:0 16px calc(120px + env(safe-area-inset-bottom))}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:20px 4px 14px;background:linear-gradient(var(--bg) 70%,transparent)}.app-title{margin:0;font-size:28px;font-weight:800;letter-spacing:-.02em}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:12px;background:var(--surface);color:var(--text-dim);box-shadow:var(--shadow-sm);transition:transform .12s ease,color .12s ease}.icon-btn:active{transform:scale(.92)}.section-head{display:flex;align-items:center;justify-content:space-between;margin:12px 4px 6px}.section-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint)}.link-btn{border:none;background:none;color:var(--accent-strong);font-size:13px;font-weight:600;padding:4px 6px}.list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.row-wrap{position:relative;border-radius:var(--radius);overflow:hidden}.row-delete-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:flex-end;padding-right:22px;background:var(--danger);color:#fff;font-weight:600}.row{position:relative;display:flex;align-items:center;gap:10px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm);touch-action:pan-y;will-change:transform}.row.dragging{transition:none}.row.checked{background:var(--surface-2);box-shadow:none;animation:drop-in .3s ease-out backwards}.row.checked .row-name{color:var(--text-faint);text-decoration:line-through}.row.lit{animation:settle-out .75s linear forwards}.row.lit .row-name{animation:settle-name .75s linear forwards}@keyframes settle-out{0%{background:var(--surface);border-color:var(--border);transform:translateY(0);opacity:1}26.7%{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 0 0 3px #10b98140,var(--shadow-md)}60%{background:var(--accent-soft);border-color:var(--accent);transform:translateY(0);opacity:1;box-shadow:0 0 0 3px #10b98140,var(--shadow-md)}88%{transform:translateY(30px);opacity:1}to{background:var(--surface);border-color:var(--border);transform:translateY(38px);opacity:0;box-shadow:var(--shadow-sm)}}@keyframes settle-name{0%{color:var(--text)}26.7%{color:var(--accent-strong)}60%{color:var(--accent-strong)}to{color:var(--text)}}@keyframes drop-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.checkbox{flex:0 0 auto;width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:transparent;display:inline-flex;align-items:center;justify-content:center;padding:0;color:#fff;transition:background .15s ease,border-color .15s ease,transform .12s ease}.checkbox:active{transform:scale(.88)}.checkbox.on{background:var(--accent);border-color:var(--accent)}.checkbox svg{width:13px;height:13px;opacity:0;transform:scale(.5);transition:opacity .15s ease,transform .15s ease}.checkbox.on svg{opacity:1;transform:scale(1)}.row-main{flex:1 1 auto;min-width:0;text-align:left;border:none;background:none;padding:2px 0;color:inherit}.row-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-meta{display:flex;align-items:center;gap:6px;margin-top:1px;font-size:11.5px;color:var(--text-dim)}.chip{display:inline-flex;align-items:center;gap:4px;padding:1px 8px;border-radius:999px;background:var(--surface-2);font-size:12px;font-weight:600;color:var(--text-dim)}.row.checked .chip{background:transparent}.stepper{flex:0 0 auto;display:inline-flex;align-items:center;gap:2px;background:var(--surface-2);border-radius:999px;padding:2px}.step-btn{width:24px;height:24px;border:none;border-radius:50%;background:var(--surface);color:var(--text);font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform .1s ease}.step-btn:active{transform:scale(.85)}.step-btn:disabled{opacity:.4;box-shadow:none}.step-val{min-width:26px;text-align:center;font-size:12.5px;font-weight:700;font-variant-numeric:tabular-nums;padding:0 2px}.step-unit{border:none;background:none;color:var(--accent-strong);font-size:11px;font-weight:700;padding:0 4px}.drag-handle{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:30px;height:38px;margin-right:-6px;border:none;background:none;color:var(--text-faint);touch-action:none}.drag-handle:active{color:var(--text-dim)}.drag-handle svg{width:18px;height:18px}.list.dragging-active .row-wrap{transition:transform .18s ease}.list.dragging-active .row-wrap.row-dragging{transition:none}.row-wrap.row-dragging{overflow:visible}.row-wrap.row-dragging .row{box-shadow:var(--shadow-lg);border-color:var(--accent)}.empty{text-align:center;color:var(--text-faint);padding:48px 16px}.empty-emoji{font-size:40px}.empty p{margin:10px 0 0;font-size:15px}.fab{position:fixed;right:max(18px,env(safe-area-inset-right));bottom:calc(22px + env(safe-area-inset-bottom));display:inline-flex;align-items:center;gap:8px;height:56px;padding:0 22px;border:none;border-radius:999px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;box-shadow:var(--shadow-lg);z-index:30;transition:transform .12s ease,background .12s ease}.fab:active{transform:scale(.95);background:var(--accent-strong)}.fab svg{width:22px;height:22px}.add-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1459;z-index:40;animation:fade .15s ease}.add-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;flex-direction:column;gap:10px;padding:14px 16px calc(14px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);border-radius:20px 20px 0 0;box-shadow:var(--shadow-lg);animation:slide-up .2s ease}.add-row{display:flex;gap:10px}.suggestions{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:40vh;overflow-y:auto}.suggestion{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:15px;text-align:left}.suggestion.dup{border-color:var(--accent);background:var(--accent-soft)}.s-name{display:inline-flex;align-items:center;gap:7px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.s-tag{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--text-faint)}.s-tag.add{color:var(--accent-strong)}.add-input{flex:1 1 auto;min-width:0;height:48px;padding:0 16px;border:1.5px solid var(--border);border-radius:14px;background:var(--bg);color:var(--text);font-size:16px;outline:none}.add-input:focus{border-color:var(--accent)}.add-input.dup,.add-input.dup:focus{border-color:var(--accent-strong);background:var(--accent-soft)}.add-submit{flex:0 0 auto;height:48px;padding:0 20px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:16px;font-weight:700}.add-submit:disabled{opacity:.5}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1473;z-index:60;display:flex;align-items:flex-end;justify-content:center;animation:fade .15s ease}@media (min-width: 540px){.modal-backdrop{align-items:center}}.modal{width:100%;max-width:520px;background:var(--surface);border-radius:22px 22px 0 0;padding:8px 20px calc(24px + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);animation:slide-up .22s ease}@media (min-width: 540px){.modal{border-radius:22px;margin:0 16px}}.modal-grab{width:40px;height:4px;border-radius:2px;background:var(--border);margin:8px auto 14px}.modal-name{width:100%;border:none;background:none;color:var(--text);font-size:22px;font-weight:800;letter-spacing:-.01em;outline:none;padding:0 0 4px;border-bottom:2px solid transparent}.modal-name:focus{border-bottom-color:var(--accent)}.field{margin-top:22px}.field-label{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-faint);margin-bottom:10px}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}.cat-chip{display:flex;align-items:center;gap:7px;padding:9px 10px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);font-size:13px;font-weight:600;transition:border-color .12s ease,background .12s ease}.cat-chip .emoji{font-size:17px}.cat-chip.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.qty-row{display:flex;align-items:center;gap:14px}.qty-big{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border-radius:999px;padding:5px}.qty-big .step-btn{width:38px;height:38px;font-size:22px}.qty-big .step-val{min-width:48px;font-size:18px}.unit-select{display:flex;gap:6px;flex-wrap:wrap}.unit-opt{padding:8px 14px;border:1.5px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:14px;font-weight:600}.unit-opt.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.modal-actions{display:flex;gap:10px;margin-top:26px}.btn{flex:1 1 0;height:50px;border:none;border-radius:14px;font-size:16px;font-weight:700}.btn-primary{background:var(--accent);color:#fff}.btn-ghost{background:var(--surface-2);color:var(--text-dim)}.btn-danger{flex:0 0 auto;width:50px;background:transparent;color:var(--danger);display:inline-flex;align-items:center;justify-content:center}.btn-danger svg{width:20px;height:20px}.toast{position:fixed;top:calc(16px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:70;max-width:calc(100% - 32px);padding:11px 18px;border-radius:999px;background:var(--text);color:var(--bg);font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);animation:toast-in .22s ease}.header-actions{display:inline-flex;gap:8px}.tabs{display:flex;gap:8px;overflow-x:auto;padding:2px 4px 12px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.tabs::-webkit-scrollbar{display:none}.tab{flex:0 0 auto;display:inline-flex;align-items:center;border:1px solid var(--border);background:var(--surface);border-radius:999px;box-shadow:var(--shadow-sm)}.tab.active{border-color:var(--accent);background:var(--accent-soft)}.tab-main{display:inline-flex;align-items:center;gap:6px;border:none;background:none;color:var(--text);font-size:14px;font-weight:700;padding:8px 14px;white-space:nowrap;border-radius:999px}.tab.active .tab-main{color:var(--accent-strong)}.tab-emoji{font-size:15px}.tab-edit{display:inline-flex;align-items:center;border:none;background:none;color:var(--accent-strong);padding:8px 12px 8px 0}.tab-edit svg{width:15px;height:15px}.tab-add{display:inline-flex;align-items:center;justify-content:center;width:42px;color:var(--text-dim);padding:0}.tab-add svg{width:18px;height:18px}.aisle-bar{display:flex;align-items:center;justify-content:space-between;margin:0 4px 8px}.group{display:flex;align-items:stretch;gap:8px;margin-bottom:10px}.group-side{flex:0 0 auto;width:26px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:7px 0 6px;overflow:hidden;border-radius:10px;background:color-mix(in srgb,var(--cat-color) 14%,transparent);border-left:3px solid var(--cat-color)}.group-emoji{font-size:15px;line-height:1}.group-side-label{writing-mode:vertical-rl;text-orientation:mixed;font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--cat-color);white-space:nowrap}.group-rows{flex:1 1 auto;min-width:0}.row-accent{position:absolute;left:0;top:6px;bottom:6px;width:4px;border-radius:0 3px 3px 0}.row-check-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:flex-start;padding-left:22px;background:var(--accent);color:#fff;font-weight:600}.list-name-row{display:flex;align-items:center;gap:10px}.list-name-emoji{font-size:26px}.modal-hint{margin:6px 0 16px;font-size:13px;color:var(--text-dim)}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px}.emoji-opt{height:48px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface);font-size:22px;display:inline-flex;align-items:center;justify-content:center;transition:border-color .12s ease,background .12s ease}.emoji-opt.on{border-color:var(--accent);background:var(--accent-soft)}.order-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:6px;max-height:56vh;overflow-y:auto}.order-row{position:relative;display:flex;align-items:center;gap:10px;padding:10px 8px 10px 16px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.order-accent{position:absolute;left:0;top:8px;bottom:8px;width:4px;border-radius:0 3px 3px 0;background:var(--cat-color)}.order-emoji{font-size:18px}.order-label{flex:1 1 auto;font-size:14px;font-weight:600}.order-moves{display:inline-flex;gap:4px}.order-move{width:34px;height:34px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);display:inline-flex;align-items:center;justify-content:center}.order-move svg{width:16px;height:16px}.order-move:disabled{opacity:.35}.btn:disabled{opacity:.5}@media (prefers-reduced-motion: reduce){.emoji-opt{transition:none}}@keyframes fade{0%{opacity:0}}@keyframes slide-up{0%{transform:translateY(100%)}}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-12px)}}
