:root{--bg: #0f1020;--bg-2: #181a30;--card: #1f2140;--card-2: #262a4d;--text: #eef0ff;--muted: #9aa0c6;--accent: #6d5efc;--accent-2: #8b7dff;--danger: #ff6b81;--ok: #4ad991;--line: #2c2f55;--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(120% 100% at 50% 0%,#1a1c38 0%,var(--bg) 60%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input,select{font:inherit}.muted{color:var(--muted)}.small{font-size:.82rem}.error{color:var(--danger)}.hint{color:var(--muted);font-size:.78rem;margin:-6px 0 4px}.center{height:100%;display:grid;place-items:center}.spinner{width:26px;height:26px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent-2);animation:spin .8s linear infinite;margin:16px auto}@keyframes spin{to{transform:rotate(360deg)}}.app{max-width:560px;margin:0 auto;padding:max(16px,env(safe-area-inset-top)) 16px calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:14px}.topbar{display:flex;align-items:center;justify-content:space-between;position:relative;padding-top:8px}.topbar h1{margin:0;font-size:1.4rem}.avatar-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--card);font-size:1.3rem}.menu{position:absolute;right:0;top:54px;background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:10px;z-index:20;min-width:170px;box-shadow:0 12px 30px #0006}.menu-name{margin:4px 6px 10px;font-weight:600}.menu button{width:100%;text-align:left;background:transparent;border:none;color:var(--danger);padding:8px 6px;border-radius:8px}.menu button:hover{background:#ffffff0d}.add{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:10px}.add-row{display:flex;gap:8px}.add-row input{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;color:var(--text);padding:12px 14px;outline:none}.add-row input:focus{border-color:var(--accent)}.add-extra{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}label.inline{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--muted)}.add-extra select,.add-extra input{background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:8px 10px}.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;border-radius:12px;padding:12px 16px;font-weight:600}.primary:disabled{opacity:.5}.ghost{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:12px;padding:12px 16px}.filters{display:flex;gap:8px}.filters button{background:var(--card);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:6px 14px}.filters button.active{color:#fff;border-color:var(--accent);background:#6d5efc2e}.todos{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.todo{position:relative;display:flex;align-items:flex-start;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px;flex-wrap:wrap}.todo.done{opacity:.55}.check{width:26px;height:26px;border-radius:8px;border:2px solid var(--line);background:var(--bg-2);color:#fff;display:grid;place-items:center;flex:0 0 auto;margin-top:2px}.check.checked{background:var(--ok);border-color:var(--ok);color:#06351f;font-weight:700}.todo-body{flex:1;min-width:0}.todo-title{display:block;word-break:break-word}.todo.done .todo-title{text-decoration:line-through}.todo-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.chip{font-size:.74rem;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;padding:2px 8px;color:var(--muted)}.chip.danger{color:var(--danger);border-color:#ff6b8180}.chip.accent{color:var(--accent-2);border-color:#8b7dff80}.todo-actions{display:flex;gap:4px}.icon{background:transparent;border:none;font-size:1.05rem;padding:4px;border-radius:8px}.icon:hover{background:#ffffff0f}.picker{flex-basis:100%;display:flex;gap:6px;flex-wrap:wrap;align-items:center;border-top:1px dashed var(--line);margin-top:4px;padding-top:8px}.picker button{background:var(--card-2);border:1px solid var(--line);color:var(--text);border-radius:999px;padding:5px 12px;font-size:.85rem}.empty{text-align:center;color:var(--muted);padding:28px 10px}.banner{background:linear-gradient(135deg,rgba(109,94,252,.18),var(--card));border:1px solid rgba(139,125,255,.4);border-radius:var(--radius);padding:14px;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.banner-text{display:flex;flex-direction:column;gap:3px}.banner-actions{display:flex;gap:8px}.foot{text-align:center;padding-top:8px}.join{min-height:100%;display:grid;place-items:center;padding:20px}.join-card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 20px 60px #00000073}.join-card h1{margin:0 0 4px;font-size:1.6rem}.logo{font-size:1.5rem}.segmented{display:flex;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin:16px 0}.segmented button{flex:1;background:transparent;border:none;color:var(--muted);padding:9px;border-radius:9px}.segmented button.active{background:var(--accent);color:#fff}.join-card form{display:flex;flex-direction:column;gap:12px}.join-card label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--muted)}.join-card input{background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:12px;padding:12px 14px;outline:none}.join-card input:focus{border-color:var(--accent)}.emoji-row{display:flex;flex-wrap:wrap;gap:6px}.emoji{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);font-size:1.2rem}.emoji.active{border-color:var(--accent);background:#6d5efc38}
