*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--bg:#f5f4f0;--bg-card:#fff;--text-primary:#1a1a1a;--text-secondary:#6b6b65;--text-muted:#a0a09a;--border:#1a1a1a1a;--border-strong:#1a1a1a2e;--accent:#1a1a1a;--accent-text:#fff;--done-line:#b0afa9;--danger:#c0392b;--shadow-lift:0 8px 32px #0000001f, 0 2px 8px #00000014;--font-display:"Contrail One", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif;--radius:14px;--radius-sm:8px;--transition:.15s ease}@media (prefers-color-scheme:dark){:root{--bg:#141413;--bg-card:#1f1f1d;--text-primary:#f0ede6;--text-secondary:#8a8a82;--text-muted:#5a5a54;--border:#f0ede614;--border-strong:#f0ede624;--accent:#f0ede6;--accent-text:#141413;--done-line:#4a4a46;--shadow-lift:0 8px 32px #0006, 0 2px 8px #0000004d}}html,body,#root{height:100%}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}button{font-family:var(--font-body);cursor:pointer;color:inherit;background:0 0;border:none}input{font-family:var(--font-body)}.lists-container{flex-direction:column;gap:6px;padding:.75rem 1.5rem 0;display:flex}.list-item{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color var(--transition), opacity var(--transition), box-shadow .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;align-items:center;gap:12px;min-height:60px;padding:18px 16px;display:flex}.list-item:hover{border-color:var(--border-strong)}.list-item.dragging{opacity:0}.list-item.drag-overlay{box-shadow:var(--shadow-lift);border-color:var(--border-strong);touch-action:none;cursor:default}.list-info{flex-direction:column;flex:1;gap:4px;display:flex}.list-name{color:var(--text-primary);flex:1;font-size:16px;font-weight:500;line-height:1.4}.list-count{color:var(--text-muted);margin-left:.25rem;font-weight:400}.list-delete-btn{width:28px;height:28px;color:var(--text-muted);opacity:0;transition:color var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.list-item:hover .list-delete-btn,.list-item:focus-within .list-delete-btn{opacity:1}.list-delete-btn:hover{color:var(--danger)}@media (hover:none){.list-delete-btn{opacity:.5}}.share-hint{z-index:50;background:#fff;border-radius:.5rem;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.share-hint p{margin:0;font-weight:500}.share-hint button{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem}.share-hint button:hover{background:#f3f4f6}.menu{position:relative}.menu-trigger{cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.5rem;transition:background-color .2s;display:flex}.menu-trigger:hover{background-color:#f3f4f6}.menu-dropdown{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;min-width:160px;margin-top:.25rem;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.menu-item{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:.75rem 1rem;font-size:.875rem;transition:background-color .2s;display:block}.menu-item:hover{background-color:#f3f4f6}.menu-item:first-child{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.menu-item:last-child{border-bottom-right-radius:.5rem;border-bottom-left-radius:.5rem}.modal-overlay{z-index:100;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:1rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-close{cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s;display:flex}.modal-close:hover{background-color:#f3f4f6}.modal-body{padding:1.5rem}.members-section,.invite-section{margin-bottom:2rem}.members-section:last-child,.invite-section:last-child{margin-bottom:0}.members-section h3,.invite-section h3{text-transform:uppercase;color:#6b7280;letter-spacing:.05em;margin:0 0 1rem;font-size:.875rem;font-weight:600}.members-list{margin:0;padding:0;list-style:none}.member-item{border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:.5rem;padding:.75rem}.member-item:last-child{margin-bottom:0}.member-info{justify-content:space-between;align-items:center;display:flex}.member-id{font-family:monospace;font-size:.875rem}.member-role{text-transform:capitalize;background-color:#f3f4f6;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem}.btn-primary,.btn-share{cursor:pointer;border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.btn-primary{color:#fff;background-color:#000}.btn-primary:hover{background-color:#374151}.btn-share{color:#fff;background-color:#3b82f6}.btn-share:hover{background-color:#2563eb}.invite-link-container{flex-direction:column;gap:.75rem;display:flex}.invite-hint{color:#6b7280;margin:0;font-size:.875rem}.error{color:#dc2626;font-size:.875rem}.diagnostics-modal{background:var(--bg-card);border-radius:12px;width:90%;max-width:600px;max-height:85vh;padding:0;overflow-y:auto;box-shadow:0 8px 32px #0000001f}.diag-section{margin:1.5rem 0;padding:0 1.5rem}.diag-section:first-of-type{margin-top:0}.diag-section h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.875rem;font-weight:600}.diag-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.625rem 0;display:flex}.diag-row:last-child{border-bottom:none}.diag-label{color:var(--text-primary);font-size:.9375rem}.diag-value{color:var(--text-secondary);text-align:right;align-items:center;gap:.5rem;font-size:.9375rem;display:flex}.diag-mono{font-family:ui-monospace,SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,monospace;font-size:.875rem}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-green{background-color:#34c759}.status-red{background-color:#ff3b30}.status-orange{background-color:#ff9500}.status-blue{background-color:#007aff}.status-gray{background-color:#8e8e93}.diag-error{color:#ff3b30;word-break:break-word;font-size:.875rem}.diag-warning{color:#ff9500;font-weight:600}.app{max-width:560px;min-height:100dvh;margin:0 auto;padding:0 0 4rem}.app-header{background:var(--bg);z-index:10;border-bottom:1px solid var(--border);padding:3rem 1.5rem 1rem;position:sticky;top:0}.header-top{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.5rem;display:flex}.back-btn{width:32px;height:32px;color:var(--text-secondary);transition:background var(--transition), color var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:-4px;display:flex}.back-btn:hover{background:var(--bg-card);color:var(--text-primary)}.app-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);flex:1;font-size:2.4rem;font-style:italic;font-weight:400}.app-title.editable{cursor:pointer;transition:background var(--transition);border-radius:8px;margin:-4px -8px;padding:4px 8px}.app-title.editable:hover{background:var(--bg-card)}.title-input{letter-spacing:-.02em;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-strong);border-radius:8px;outline:none;flex:1;padding:4px 8px;font-family:Nunito,sans-serif;font-size:2.4rem;font-style:normal;font-weight:600}.title-input:focus{border-color:var(--accent)}.task-count{color:var(--text-muted);align-items:center;gap:1rem;min-height:20px;font-size:13px;display:flex}.clear-done-btn{color:var(--danger);opacity:.7;transition:opacity var(--transition);padding:0;font-size:13px}.clear-done-btn:hover{opacity:1}.reorder-btn{color:var(--text-secondary);border:1px solid var(--border-strong);transition:background var(--transition), color var(--transition), border-color var(--transition);letter-spacing:.01em;border-radius:100px;padding:6px 14px;font-size:13px;font-weight:500}.reorder-btn:hover{background:var(--bg-card)}.reorder-btn.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.add-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);align-items:center;gap:0;margin:1rem 1.5rem 0;display:flex;overflow:hidden}.add-form:focus-within{border-color:var(--border-strong)}.add-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:14px 16px;font-size:15px}.add-input::placeholder{color:var(--text-muted)}.add-submit{height:48px;color:var(--text-muted);transition:color var(--transition);flex-shrink:0;align-items:center;padding:0 16px;display:flex}.add-submit:not(:disabled):hover{color:var(--text-primary)}.add-submit:disabled{cursor:default;opacity:.3}.reorder-hint{color:var(--text-muted);letter-spacing:.02em;padding:.75rem 1.5rem 0;font-size:12px}.todo-list{flex-direction:column;gap:6px;padding:.75rem 1.5rem 0;display:flex}.todo-item{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color var(--transition), opacity var(--transition), box-shadow .2s ease;-webkit-user-select:none;user-select:none;touch-action:manipulation;align-items:center;gap:12px;min-height:52px;padding:13px 14px;display:flex}.todo-item.dragging{opacity:0}.todo-item.drag-overlay{box-shadow:var(--shadow-lift);border-color:var(--border-strong);touch-action:none}.check-btn{width:28px;height:28px;color:var(--text-primary);transition:transform var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.check-btn:active{transform:scale(.88)}.drag-handle,.drag-handle-overlay{width:28px;height:28px;color:var(--text-muted);cursor:grab;touch-action:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.drag-handle:active{cursor:grabbing}.todo-text{color:var(--text-primary);transition:color var(--transition);flex:1;font-size:15px;line-height:1.4}.todo-item.done .todo-text{color:var(--text-muted);text-decoration:line-through;-webkit-text-decoration-color:var(--done-line);text-decoration-color:var(--done-line)}.delete-btn{width:28px;height:28px;color:var(--text-muted);opacity:0;transition:color var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.todo-item:hover .delete-btn,.todo-item:focus-within .delete-btn{opacity:1}.delete-btn:hover{color:var(--danger)}@media (hover:none){.delete-btn{opacity:.5}}.completed-section{margin-top:1.5rem;padding:0 1.5rem}.completed-header{width:100%;color:var(--text-secondary);letter-spacing:.01em;justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;font-weight:500;display:flex}.completed-header:hover{color:var(--text-primary)}.completed-title{align-items:center;gap:6px;display:flex}.completed-chevron{color:var(--text-muted);transition:transform var(--transition);justify-content:center;align-items:center;display:flex}.completed-chevron.expanded{transform:rotate(180deg)}.completed-list{margin-top:0;padding:0}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 1.5rem;font-size:15px}
