:root,[data-theme=dark]{--bg: #0f1115;--bg-2: #161922;--bg-3: #1e2230;--bg-hover: #242a3a;--border: #2b3142;--text: #e7e9ee;--text-dim: #9aa0ae;--text-muted: #6b7180;--accent: #7c5cff;--accent-hover: #8c70ff;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 6px;--radius-lg: 10px;--tooltip-bg: #0b0d12;--mention-bg: rgba(124, 92, 255, .14);--danger-soft: rgba(239, 68, 68, .12);--accent-soft: rgba(124, 92, 255, .12)}[data-theme=light]{--bg: #f5f6f8;--bg-2: #ffffff;--bg-3: #eef0f4;--bg-hover: #e4e7ee;--border: #d6d9e0;--text: #1a1d24;--text-dim: #4b5563;--text-muted: #6b7280;--accent: #6543f0;--accent-hover: #5432e0;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--tooltip-bg: #1a1d24;--mention-bg: rgba(101, 67, 240, .14);--danger-soft: rgba(220, 38, 38, .1);--accent-soft: rgba(101, 67, 240, .1)}*{box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:#3d4456;background-clip:padding-box;border:2px solid transparent}*::-webkit-scrollbar-corner{background:transparent}html,body,#app{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:14px;line-height:1.45}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}input,select,textarea,button{font:inherit;color:inherit}input,select,textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;color:var(--text);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:80px}button{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:8px 14px;cursor:pointer;font-weight:500}button:hover{background:var(--accent-hover)}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}button.ghost:hover{background:var(--bg-hover)}button.danger{background:var(--danger)}button.ghost.danger{background:transparent;color:var(--danger);border-color:var(--danger)}button.ghost.danger:hover{background:var(--danger-soft);color:var(--danger)}button.small{padding:4px 8px;font-size:12px}.app-shell{display:flex;height:100vh}.sidebar{width:220px;background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;gap:4px;overflow-y:auto}.sidebar h1{font-size:16px;margin:0 0 12px 4px;letter-spacing:.5px}.sidebar-group{font-size:11px;text-transform:uppercase;color:var(--text-muted);margin:12px 6px 4px;letter-spacing:.8px}.nav-item,.sidebar a{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:13px;-webkit-user-select:none;user-select:none}.nav-item:hover,.sidebar a:hover{background:var(--bg-hover);color:var(--text)}.nav-item.active,.sidebar a.active{background:var(--bg-hover);color:var(--accent)}.nav-list{display:flex;flex-direction:column;gap:2px}.sidebar-footer{display:flex;align-items:center;gap:10px;padding:8px;border-top:1px solid var(--border);cursor:pointer}.sidebar-footer:hover{background:var(--bg-hover)}.theme-toggle{display:flex;gap:4px;padding:6px;border-top:1px solid var(--border)}.theme-toggle button{flex:1;background:transparent;color:var(--text-dim);border:1px solid transparent;padding:6px 8px;font-size:12px;border-radius:var(--radius)}.theme-toggle button:hover{background:var(--bg-hover);color:var(--text)}.theme-toggle button.active{background:var(--bg-hover);color:var(--accent);border-color:var(--border)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;gap:14px;padding:12px 18px;border-bottom:1px solid var(--border);background:var(--bg-2)}.topbar h2{margin:0;font-size:16px}.topbar .spacer{flex:1}.content{flex:1;overflow:auto;padding:18px}.auth-card{max-width:380px;margin:60px auto;background:var(--bg-2);padding:28px;border-radius:var(--radius-lg);border:1px solid var(--border)}.auth-card h2{margin:0 0 18px}.form-row{margin-bottom:12px}.form-row label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:4px}.error{color:var(--danger);font-size:12px;margin-top:8px}.avatar{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:50%;font-weight:600;font-size:12px;color:#fff;flex-shrink:0}.avatar.sm{width:22px;height:22px;font-size:11px}.avatar.lg{width:36px;height:36px;font-size:14px}.swimlanes{display:flex;gap:14px;height:100%;align-items:flex-start;overflow-x:auto}.lane{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px;min-width:260px;width:260px;display:flex;flex-direction:column;gap:8px;max-height:100%}.lane.drag-over{border-color:var(--accent);background:var(--bg-3)}.lane-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px;padding:2px 4px}.lane-header .count{color:var(--text-muted);font-weight:400;font-size:12px}.lane-tasks{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding:2px}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.task-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);cursor:grab;display:flex;align-items:stretch;overflow:hidden}.task-card:hover{border-color:var(--accent)}.task-card.dragging{opacity:.4}.task-card .task-body{flex:1;padding:10px 12px;display:flex;flex-direction:column;gap:6px;min-width:0}.task-card .title{font-weight:500;font-size:13px;line-height:1.3;word-break:break-word}.task-card .meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted);gap:8px}.label-bars{display:flex;flex-direction:column;flex-shrink:0}.label-bar{width:4px;flex:1;min-height:18px}.label-chip{display:inline-flex;align-items:center;justify-content:center;padding:3px 10px;min-height:18px;line-height:1;font-size:10px;border-radius:10px;color:#fff;font-weight:500;-webkit-user-select:none;user-select:none;vertical-align:middle}.chip-row{align-items:center}.label-bars,.label-bar{-webkit-user-select:none;user-select:none}.task-table{width:100%;border-collapse:collapse;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.task-table th,.task-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:13px}.task-table th{background:var(--bg-3);color:var(--text-dim);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.6px}.task-table tr:last-child td{border-bottom:none}.task-table tr:hover td{background:var(--bg-hover);cursor:pointer}.task-table th.sort-active{color:var(--accent)}.task-id-cell{font-family:monospace;font-size:12px;color:var(--text-muted);padding:2px 8px;border-radius:var(--radius);cursor:pointer;display:inline-block}.task-id-cell:hover{background:var(--bg-3);color:var(--text)}.comment-count-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:11px;min-width:34px;justify-content:center}.comment-count-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent)}.comment-count-btn.has-count{color:var(--text);border-color:var(--accent)}.notif-wrap{position:relative}.notif-bell{position:relative;padding:4px 10px;display:inline-flex;align-items:center;gap:4px}.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;font-size:10px;font-weight:600;min-width:18px;height:18px;border-radius:9px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--bg-2)}.notif-panel{position:absolute;bottom:calc(100% + 8px);left:0;width:340px;max-height:500px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 32px #00000080;z-index:80;display:flex;flex-direction:column}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.notif-list{overflow-y:auto;flex:1}.notif-item{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;position:relative}.notif-item:hover{background:var(--bg-hover)}.notif-item.read{opacity:.6}.notif-body{flex:1;min-width:0}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);align-self:center}@keyframes task-highlight-pulse{0%{box-shadow:0 0 0 3px var(--accent),0 0 14px 2px var(--accent-soft)}to{box-shadow:0 0 0 0 transparent,0 0 0 0 transparent}}.task-card.task-highlight{animation:task-highlight-pulse 3s ease-out;border-color:var(--accent)}.task-table tr.task-highlight td{background:var(--accent-soft);animation:task-highlight-pulse 3s ease-out}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal h3{margin-top:0}.modal .actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.color-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer}.color-swatch.selected{border-color:var(--text)}.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.view-toggle button{border-radius:0;background:var(--bg-3);color:var(--text-dim);padding:6px 12px;font-size:12px}.view-toggle button.active{background:var(--accent);color:#fff}.admin-grid{display:grid;grid-template-columns:1fr;gap:12px;max-width:900px}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.row{display:flex;gap:10px;align-items:center}.row>*{flex-shrink:0}.row .grow{flex:1}.toast{position:fixed;bottom:20px;right:20px;z-index:100;background:var(--bg-3);border:1px solid var(--border);padding:10px 14px;border-radius:var(--radius);box-shadow:0 6px 20px #0006}.assignee-row{display:flex;flex-wrap:wrap;gap:4px}.tooltip-wrap{position:relative;display:inline-flex}.tooltip-wrap:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--tooltip-bg);color:var(--text);border:1px solid var(--border);padding:4px 8px;border-radius:var(--radius);font-size:11px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .1s ease .15s;z-index:200;box-shadow:0 4px 12px #0006}.tooltip-wrap:hover:after{opacity:1}.hidden{display:none!important}.due-overdue{color:var(--danger)}.due-soon{color:var(--warning)}.estimate-chip{background:var(--bg-hover);color:var(--text-dim);border-radius:10px;padding:1px 7px;font-size:10px;font-weight:500}.task-id-pill{background:var(--bg-3);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius);padding:3px 10px;font-family:monospace;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.task-id-pill:hover{background:var(--bg-hover);color:var(--text)}.title-row{display:flex;gap:6px;align-items:baseline}.task-num{color:var(--text-muted);font-family:monospace;font-size:11px;flex-shrink:0}.pill-wrap{position:relative;display:inline-flex}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.pill-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:4px;min-width:160px;z-index:60;box-shadow:0 8px 20px #0006}.pill-menu-item{padding:4px;border-radius:var(--radius);cursor:pointer;font-size:12px}.pill-menu-item:hover,.pill-menu-item.selected{background:var(--bg-hover)}.priority-pill{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;color:#fff;letter-spacing:.3px}.topbar-search{width:220px;padding:6px 10px;font-size:12px}.filters-panel{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;width:360px;z-index:60;box-shadow:0 10px 28px #00000080;max-height:70vh;overflow-y:auto}.filters-section{margin-bottom:12px}.paint-button{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 6px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:12px}.paint-button:hover{background:var(--bg-hover)}.paint-button.active{border-color:var(--accent);background:var(--accent-soft)}.paint-dot{display:inline-block;width:16px;height:16px;border-radius:50%;box-sizing:border-box}body.painting,body.painting *{cursor:crosshair!important}.filters-head{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}.comments{display:flex;flex-direction:column;gap:10px;margin:6px 0 12px}.comment{display:flex;gap:8px}.comment-body{flex:1;min-width:0}.comment-head{display:flex;align-items:baseline;gap:8px;font-size:12px}.comment-head strong{font-size:13px}.comment-time{color:var(--text-muted);font-size:11px}.comment-del{background:transparent;color:var(--text-muted);border:none;padding:0 0 0 6px;font-size:11px;cursor:pointer}.comment-del:hover{color:var(--danger);background:transparent}.comment-text{font-size:13px;white-space:pre-wrap;word-break:break-word;margin-top:2px}.mention{color:var(--accent);font-weight:500;background:var(--mention-bg);padding:0 3px;border-radius:3px}.comment-compose{position:relative}.mention-menu{position:absolute;bottom:calc(100% + 2px);left:0;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:4px;min-width:180px;z-index:60;box-shadow:0 6px 16px #0006}.mention-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--radius);cursor:pointer;font-size:12px}.mention-item:hover{background:var(--bg-hover)}.comment-reply{margin-left:30px;padding-left:10px;border-left:2px solid var(--border);margin-top:8px}
