:root{--bg: #f5f6f8;--surface: #ffffff;--surface-2: #fafbfc;--border: #e4e7eb;--text: #1c2430;--muted: #6b7685;--accent: #2f9e44;--accent-soft: #e9f7ee;--danger: #d6336c;--shadow: 0 1px 3px rgba(20, 30, 50, .08), 0 8px 24px rgba(20, 30, 50, .06);color-scheme:light dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}@media (prefers-color-scheme: dark){:root{--bg: #0f141a;--surface: #171d25;--surface-2: #1e252f;--border: #2b333f;--text: #e4e8ee;--muted: #8b95a4;--accent: #51cf66;--accent-soft: #16301f;--danger: #ff7aa6;--shadow: 0 1px 3px rgba(0, 0, 0, .5), 0 8px 24px rgba(0, 0, 0, .35)}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-size:15px}button{font:inherit;cursor:pointer}input{font:inherit}.brand{display:flex;align-items:center;gap:10px}.brand h1{font-size:20px;margin:0}.brand-mark{background:var(--accent);color:#fff;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:16px;font-weight:700}.brand.small{font-weight:600;font-size:16px}.brand.small .brand-mark{width:26px;height:26px;font-size:13px}.code-name{text-transform:lowercase}.muted{color:var(--muted)}.center{text-align:center}.link{background:none;border:none;color:var(--accent);font-size:14px}.error{color:var(--danger);font-size:14px}.gate{display:grid;place-items:center;min-height:100%;padding:20px;background:radial-gradient(circle at 30% 20%,var(--accent-soft),var(--bg))}.gate-card{background:var(--surface);padding:32px 28px;border-radius:16px;box-shadow:var(--shadow);width:min(380px,100%);display:flex;flex-direction:column;gap:14px}.gate-card .hint{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.gate-card input{padding:12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text)}.gate-card button{background:var(--accent);color:#fff;border:none;padding:12px;border-radius:9px;font-weight:600}.gate-card button:disabled{opacity:.55}.app{max-width:640px;margin:0 auto;padding:16px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 4px 16px}.content{display:flex;flex-direction:column;gap:18px}.add{display:grid;grid-template-columns:1fr 68px auto;gap:8px;background:var(--surface);padding:12px;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.add input{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text)}.add-title{grid-column:1;grid-row:1}.add-qty{grid-column:2;grid-row:1;text-align:center}.add-desc{grid-column:1 / -1;grid-row:2}.add button{grid-row:1;grid-column:3;background:var(--accent);color:#fff;border:none;padding:0 20px;border-radius:8px;font-weight:600}.add button:disabled{opacity:.5}.count{margin-left:8px;font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:1px 8px}.todo-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.todo{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px}.todo-main{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.todo-title{font-weight:600}.todo-desc{color:var(--muted);font-size:13px}.done-btn{flex-shrink:0;border:1px solid var(--accent);color:var(--accent);background:var(--accent-soft);border-radius:8px;padding:8px 16px;font-weight:600}.done-btn:hover{background:var(--accent);color:#fff}.empty{text-align:center;padding:28px;border:1px dashed var(--border);border-radius:12px}.saved h3{font-size:13px;font-weight:600;color:var(--text);margin:0 0 10px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden}.chip-add{background:none;border:none;padding:6px 10px;color:var(--text);font-size:13px}.chip-add:hover{color:var(--accent)}.chip-forget{background:none;border:none;border-left:1px solid var(--border);color:var(--muted);padding:6px 9px;font-size:11px}.chip-forget:hover{color:var(--danger)}input,textarea,select{font-size:16px}.home{max-width:640px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:18px}.home-brand{padding:8px 4px 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.new-list{padding:16px;display:flex;flex-direction:column;gap:10px}.new-list h2,.lists h2{font-size:15px;margin:0 0 2px}.new-list input,.new-list textarea{padding:12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);font-family:inherit;resize:vertical}.new-list button{background:var(--accent);color:#fff;border:none;padding:13px;border-radius:9px;font-weight:600}.new-list button:disabled{opacity:.5}.lists{display:flex;flex-direction:column;gap:10px}.list-card{display:flex;align-items:stretch;padding:0}.list-card:hover{border-color:var(--accent)}.list-card-main{flex:1;min-width:0;text-align:left;background:none;border:none;color:inherit;display:flex;flex-direction:column;gap:3px;padding:14px 16px}.card-actions{display:flex;align-items:center;gap:2px;padding-right:8px}.icon-btn{width:36px;height:36px;display:grid;place-items:center;background:none;border:none;color:var(--muted);border-radius:8px}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.danger:hover{color:var(--danger)}.list-edit,.meta-edit{padding:14px 16px;display:flex;flex-direction:column;gap:8px}.meta-edit{padding:6px 0 0}.list-edit input,.list-edit textarea,.meta-edit input,.meta-edit textarea{padding:10px 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--text);font-family:inherit;resize:vertical}.edit-actions{display:flex;align-items:center;gap:14px}.edit-actions button[type=submit]{background:var(--accent);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-weight:600}.edit-name{font-size:12px;margin-left:auto}.list-head-top{display:flex;justify-content:space-between;align-items:center}.head-actions{display:flex;gap:2px}.splash{display:grid;place-items:center;min-height:100vh}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.google-signin{display:flex;flex-direction:column;gap:8px;align-items:center}.gate-card .link{align-self:flex-start}.home-top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.home-user{display:flex;align-items:center;gap:12px;font-size:13px;max-width:60%}.home-user span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shared-badge,.ro-badge{font-style:normal;font-size:11px;padding:1px 7px;border-radius:10px;margin-left:8px;background:var(--accent-soft);color:var(--accent)}.ro-badge{margin-left:0}.head-meta{display:flex;align-items:center;gap:8px;margin-top:8px}.share-row{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}.share-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.share-toggle input{width:16px;height:16px;accent-color:var(--accent)}.qty-badge{flex-shrink:0;font-variant-numeric:tabular-nums;font-weight:600;color:var(--muted)}.todo.readonly{cursor:default}.list-card-title{font-weight:600;font-size:16px}.list-card-desc{color:var(--muted);font-size:13px}.list-card-count{color:var(--accent);font-size:12px;font-weight:600;margin-top:2px}.list-head{padding:10px 4px 14px;display:flex;flex-direction:column;gap:2px}.list-head .link{align-self:flex-start;margin-bottom:4px}.list-title{font-size:22px;margin:0}.list-desc{color:var(--muted);margin:2px 0 0;font-size:14px;line-height:1.5}.list-head .count{align-self:flex-start;margin:8px 0 0}.todo{gap:8px}.todo-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drag-handle{flex-shrink:0;background:none;border:none;color:var(--muted);font-size:18px;cursor:grab;padding:4px 2px;touch-action:none}.drag-handle:active{cursor:grabbing}.qty{display:flex;align-items:center;gap:6px;flex-shrink:0}.qty-btn{width:30px;height:30px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:8px;font-size:18px;line-height:1;display:grid;place-items:center}.qty-btn:disabled{opacity:.4}.qty-val{min-width:18px;text-align:center;font-variant-numeric:tabular-nums}.done-btn{padding:8px 14px}
