:root{--bg: #0e1116;--panel: #161b22;--panel-2: #1f2630;--border: #2d333b;--text: #e6edf3;--dim: #8b949e;--accent: #ffb000;--ok: #2ea043;--prog: #d29922;--warn: #d9534f}*{box-sizing:border-box}html,body{margin:0}body{font:15px/1.45 -apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}.center{display:grid;place-items:center;height:100vh}.muted{color:var(--dim)}.sm{font-size:.85rem}.app{max-width:640px;margin:0 auto;padding-bottom:40px}.topbar{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top));background:var(--panel);border-bottom:1px solid var(--border)}.brand,.logo{display:inline-flex;align-items:center;gap:8px;background:none;border:0;color:var(--text);font-weight:700;font-size:1.15rem;cursor:pointer}.badge84{background:var(--accent);color:#1a1a1a;font-weight:800;padding:3px 8px;border-radius:6px;letter-spacing:.5px;font-size:.95em}.wordmark{color:var(--text)}.topbar .link{background:transparent;color:var(--text);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:.85rem;font-weight:500;cursor:pointer}.topbar .link:hover{border-color:var(--accent);color:var(--accent)}.avatar-btn{position:relative;background:none;border:0;padding:0;cursor:pointer}.avatar{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-size:.8rem;font-weight:700;overflow:hidden;flex-shrink:0}.avatar-img{width:100%;height:100%;object-fit:cover;display:block}.avatar-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.avatar-pick{width:48px;height:48px;font-size:24px;line-height:1;cursor:pointer;border:1px solid var(--border);border-radius:12px;background:var(--panel-2)}.avatar-pick.on{border-color:var(--accent);background:#ffb00024}.presence-status{font-size:.85rem;color:var(--dim)}.presence-status.on{color:#2ea043;font-weight:600}.bell-btn{position:relative;background:none;border:0;font-size:20px;cursor:pointer;padding:2px 4px;line-height:1}.bell-badge{position:absolute;top:-3px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--warn);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;line-height:1}.notif-row{display:flex;gap:10px;align-items:flex-start;text-align:left;width:100%;background:transparent;border:0;border-bottom:1px solid var(--border);padding:10px 2px;cursor:pointer;color:var(--text)}.notif-row.unread{background:#ffb00014}.history-row{flex-direction:row;align-items:flex-start;gap:10px}.mention-menu{border:1px solid var(--border);border-radius:10px;background:var(--panel-2);overflow:hidden;margin-top:-4px}.mention-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:0;padding:8px 10px;cursor:pointer;color:var(--text);font-size:.95rem}.mention-item:hover{background:var(--panel)}.online-dot{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;background:#2ea043;border:2px solid var(--panel)}.presence-row{padding:6px 0}.dot-sm{width:10px;height:10px;border-radius:50%;background:var(--border);display:inline-block}.dot-sm.on{background:#2ea043}.screen{padding:16px}h1{font-size:1.4rem;margin:10px 0 16px;color:var(--text)}.row{display:flex;align-items:center;gap:10px}.between{justify-content:space-between}.card{display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px;width:100%;margin-bottom:12px;text-align:left}.tappable{cursor:pointer}.tappable:hover{border-color:#3a424d}.tappable:active{transform:scale(.99)}input,select{font-size:1rem;padding:13px 14px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);color:var(--text);width:100%}input::placeholder{color:var(--dim)}input:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}.search{margin:0;flex:1}.search-row{display:flex;align-items:center;gap:10px;margin:0 0 10px}.completed-check{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--dim);white-space:nowrap}.completed-check input{width:auto}.filters{display:flex;gap:8px;margin-bottom:14px}.filter-btn{flex:1;width:auto;font-size:.9rem;padding:10px 12px}input[type=date]{cursor:pointer}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(.7)}input:disabled{opacity:.6}.lbl{font-size:.8rem;color:var(--dim);margin-top:4px}.check{display:flex;align-items:center;gap:10px;font-size:.95rem;color:var(--text)}.check input{width:auto}button.primary{background:var(--accent);color:#1a1a1a;border:0;border-radius:12px;padding:15px;font-size:1rem;font-weight:700;cursor:pointer}button.primary.sm{padding:9px 14px;font-size:.9rem}button.primary:hover{filter:brightness(1.06)}button.primary:disabled{opacity:.6;cursor:default}button.link{background:none;border:0;color:var(--accent);font-size:.95rem;cursor:pointer;padding:8px 0}button.link:hover{filter:brightness(1.12)}button.ghost{background:transparent;color:var(--text);border:1px dashed var(--border);border-radius:12px;padding:12px;font-size:.95rem;font-weight:600;cursor:pointer}button.ghost:hover{border-color:var(--accent);color:var(--accent)}.auth{max-width:420px;margin:0 auto;padding:56px 20px;text-align:center}.auth .logo{font-size:1.9rem;justify-content:center;margin-bottom:6px;cursor:default}.auth form{margin-top:20px;text-align:left}.err{color:#ff8a8a;font-size:.9rem}.badge{background:var(--panel-2);color:var(--dim);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:.8rem}.badge.late{background:#3b1d1f;color:#ffd1d1;border-color:#5b2528;margin-left:8px}.bar{height:7px;background:var(--panel-2);border-radius:4px;overflow:hidden}.fill{height:100%;background:var(--accent)}.empty{padding:40px 0;text-align:center;color:var(--dim)}.invite-link{display:flex;gap:8px;align-items:center}.invite-link input{font-size:.8rem}.section{font-size:1.05rem;margin:22px 0 10px;color:var(--text);border-top:1px solid var(--border);padding-top:18px}.sent-note{color:var(--ok);font-weight:600;font-size:.9rem}.role-select{width:auto;max-width:170px;padding:8px 10px;font-size:.85rem}.history-item{gap:3px;padding:12px 14px}.history-item strong{color:var(--accent)}.card-progress{display:flex;flex-direction:column;gap:5px;margin-top:2px}.card-pct{font-size:1.05rem;font-weight:700;color:var(--text)}.step-edit{flex-direction:row;align-items:center;gap:10px;padding:10px 12px}.step-num{color:var(--dim);font-size:.85rem;min-width:16px;text-align:center}.step-edit>input{flex:1}.step-days{display:flex;align-items:center;gap:6px}.step-days input{width:52px;text-align:center}.step-moves{display:flex;flex-direction:column;gap:2px}.step-move{background:transparent;border:1px solid var(--border);color:var(--dim);width:26px;height:16px;border-radius:5px;font-size:11px;line-height:1;cursor:pointer;padding:0}.step-move:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.step-move:disabled{opacity:.3;cursor:default}.step-remove{background:transparent;border:1px solid var(--border);color:var(--dim);width:30px;height:30px;border-radius:8px;font-size:18px;line-height:1;cursor:pointer}.step-remove:hover{border-color:var(--warn);color:var(--warn)}.tasks{display:flex;flex-direction:column;gap:8px;margin-top:12px}.task{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--border);border-left:5px solid var(--border);border-radius:12px;padding:14px;text-align:left;cursor:pointer;color:var(--text)}.task:hover{border-color:#3a424d}.task .dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border)}.tmain{display:flex;flex-direction:column;gap:3px;min-width:0}.task .tname{font-weight:600}.task .tmeta{font-size:.75rem;color:var(--dim)}.task .tstatus{font-weight:700}.task.in_progress{border-left-color:var(--prog)}.task.in_progress .dot{border-color:var(--prog);background:var(--prog)}.task.in_progress .tstatus{color:var(--prog)}.task.done{border-left-color:var(--ok)}.task.done .dot{border-color:var(--ok);background:var(--ok)}.task.done .tname{text-decoration:line-through;color:var(--dim)}.task.done .tstatus{color:var(--ok)}.tip{margin-top:16px}.rain-dot{width:14px;text-align:center;font-size:13px}.rain-toggle{background:transparent;border:1px solid var(--border);color:var(--dim);width:32px;height:32px;border-radius:8px;font-size:14px;line-height:1;cursor:pointer;padding:0}.rain-toggle:hover{border-color:var(--accent)}.rain-toggle.on{border-color:#4aa3ff;background:#4aa3ff1f}.task.rained{border-left-color:#4aa3ff}.task.rained .tstatus{color:#4aa3ff}.task-wrap{display:flex;flex-direction:column;gap:6px}.task-actions{display:flex;align-items:center;gap:5px;flex-shrink:0}.icon-btn,.rain-toggle{flex-shrink:0}.icon-btn{position:relative;background:transparent;border:1px solid var(--border);color:var(--dim);width:32px;height:32px;border-radius:8px;font-size:14px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover{border-color:var(--accent)}.photo-count{position:absolute;top:-6px;right:-6px;background:var(--accent);color:#1a1a1a;font-size:10px;font-weight:700;border-radius:999px;padding:1px 5px;line-height:1.3}.photo-strip{display:flex;flex-wrap:wrap;gap:6px;padding:0 2px 2px 32px}.thumb{width:64px;height:64px;padding:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;background:var(--panel-2)}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#080a10d1;display:flex;align-items:center;justify-content:center;padding:16px}.photo-modal-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:12px;max-width:92vw;max-height:90vh;display:flex;flex-direction:column;gap:10px}.photo-modal-card img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px}.photo-meta{display:flex;flex-direction:column;gap:4px;font-size:.9rem}.photo-meta a{color:#66b3ff}.icon-btn.on{border-color:var(--accent);color:var(--accent)}.share-sec{display:flex;flex-direction:column;gap:6px}.share-sec-head{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--dim);font-weight:600}.share-sec-head .link{padding:2px 0}.share-notes{display:flex;flex-direction:column;gap:6px;max-height:26vh;overflow-y:auto}.share-note{align-items:center}.share-note-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;min-width:0}.thumb{position:relative}.thumb.sel{border-color:var(--accent);border-width:2px}.thumb-check{position:absolute;top:2px;right:2px;background:var(--accent);color:#1a1a1a;border-radius:999px;width:16px;height:16px;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}.job-title{color:var(--accent)}.card .job-title{font-size:1.08rem}h1.job-title{color:var(--accent)}.due{font-weight:700;color:var(--accent);font-size:.92rem;margin:6px 0 2px}.due.late{color:#ff8a8a}.due-count{font-weight:600;opacity:.85}.details-toggle{padding:4px 0}.details{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.im-link{color:#66b3ff;text-decoration:underline;text-underline-offset:2px}.progress{margin:4px 0 12px}.progress-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.progress-pct{font-weight:700;color:var(--text)}.note-preview{margin-left:32px;padding:8px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem;white-space:pre-wrap;cursor:pointer}.note-when{font-size:.72rem;color:var(--dim);margin-bottom:4px;font-weight:600}.note-thread{margin-left:32px;display:flex;flex-direction:column;gap:8px}.note-entry{padding:8px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px}.note-entry .note-when{margin-bottom:2px}.note-body{white-space:pre-wrap;font-size:.85rem;color:var(--text)}.note-act{padding:0;font-size:.78rem}.note-card{width:480px;max-width:92vw}.note-input{width:100%;min-height:160px;resize:vertical;font:inherit;font-size:1rem;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);color:var(--text)}.note-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}
