:root{--bg-primary: #0f1117;--bg-secondary: #161822;--bg-tertiary: #1c1f2e;--bg-elevated: #222539;--bg-hover: #282c44;--bg-active: #2d3250;--glass-bg: rgba(30, 33, 50, .7);--glass-border: rgba(255, 255, 255, .06);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .3);--text-primary: #e8eaf0;--text-secondary: #9ca3b4;--text-tertiary: #6b7280;--text-muted: #4b5263;--accent-indigo: #6366f1;--accent-indigo-glow: rgba(99, 102, 241, .25);--accent-cyan: #06b6d4;--accent-cyan-glow: rgba(6, 182, 212, .25);--accent-emerald: #10b981;--accent-emerald-glow: rgba(16, 185, 129, .25);--accent-amber: #f59e0b;--accent-amber-glow: rgba(245, 158, 11, .25);--accent-rose: #f43f5e;--accent-rose-glow: rgba(244, 63, 94, .25);--accent-purple: #a855f7;--status-todo: #6b7280;--status-progress: #6366f1;--status-review: #f59e0b;--status-done: #10b981;--status-blocked: #f43f5e;--priority-critical: #f43f5e;--priority-high: #f59e0b;--priority-medium: #6366f1;--priority-low: #6b7280;--border-default: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .1);--border-accent: rgba(99, 102, 241, .3);--sp-xs: 4px;--sp-sm: 8px;--sp-md: 12px;--sp-lg: 16px;--sp-xl: 24px;--sp-2xl: 32px;--sp-3xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--fs-xs: .7rem;--fs-sm: .8rem;--fs-base: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.375rem;--fs-2xl: 1.75rem;--fw-light: 300;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--ease-out: cubic-bezier(.16, 1, .3, 1);--transition-fast: .15s var(--ease-out);--transition-normal: .25s var(--ease-out);--transition-slow: .4s var(--ease-out);--shadow-sm: 0 1px 3px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.25);--shadow-lg: 0 8px 30px rgba(0,0,0,.35);--shadow-glow-indigo: 0 0 20px rgba(99,102,241,.15);--sidebar-width: 260px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow:hidden;height:100vh}#app{display:flex;height:100vh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--accent-indigo);color:#fff}:focus-visible{outline:2px solid var(--accent-indigo);outline-offset:2px}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 600px 400px at 10% 20%,rgba(99,102,241,.06) 0%,transparent 70%),radial-gradient(ellipse 500px 300px at 90% 80%,rgba(6,182,212,.05) 0%,transparent 70%);pointer-events:none;z-index:0}.hidden{display:none!important}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-lg) var(--sp-xl);border-bottom:1px solid var(--border-default);background:var(--bg-secondary);flex-shrink:0;gap:var(--sp-lg)}.top-bar-left{display:flex;align-items:center;gap:var(--sp-md)}.page-title{font-size:var(--fs-xl);font-weight:var(--fw-bold);letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.top-bar-right{display:flex;align-items:center;gap:var(--sp-md)}.search-box{display:flex;align-items:center;gap:var(--sp-sm);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--sp-sm) var(--sp-md);transition:border-color var(--transition-fast)}.search-box:focus-within{border-color:var(--accent-indigo);box-shadow:var(--shadow-glow-indigo)}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-box input{background:none;border:none;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--fs-sm);outline:none;width:200px}.search-box input::placeholder{color:var(--text-muted)}.view-container{flex:1;overflow:auto;padding:var(--sp-xl)}.btn{display:inline-flex;align-items:center;gap:var(--sp-sm);font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:var(--fw-medium);border:1px solid transparent;border-radius:var(--radius-md);padding:var(--sp-sm) var(--sp-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:1.4}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-indigo);color:#fff;border-color:var(--accent-indigo)}.btn-primary:hover{background:#5558e6;box-shadow:var(--shadow-glow-indigo)}.btn-accent{background:linear-gradient(135deg,var(--accent-indigo),var(--accent-purple));color:#fff}.btn-accent:hover{opacity:.9;box-shadow:var(--shadow-glow-indigo)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-strong)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:var(--fs-xs)}.btn-full{width:100%;justify-content:center}.badge{display:inline-flex;align-items:center;font-size:var(--fs-xs);font-weight:var(--fw-semibold);padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase}.badge-info{background:#6366f126;color:var(--accent-indigo)}.badge-success{background:#10b98126;color:var(--accent-emerald)}.badge-warning{background:#f59e0b26;color:var(--accent-amber)}.badge-danger{background:#f43f5e26;color:var(--accent-rose)}.badge-neutral{background:#6b728026;color:var(--text-secondary)}.status-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-medium);text-transform:capitalize}.status-todo{background:#6b728026;color:#9ca3af}.status-in-progress{background:#6366f126;color:#818cf8}.status-review{background:#f59e0b26;color:#fbbf24}.status-done{background:#10b98126;color:#34d399}.status-blocked{background:#f43f5e26;color:#fb7185}.priority-badge{padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.05em}.priority-critical{background:#f43f5e33;color:#fb7185}.priority-high{background:#f59e0b33;color:#fbbf24}.priority-medium{background:#6366f133;color:#818cf8}.priority-low{background:#6b728033;color:#9ca3af}.tag{display:inline-flex;align-items:center;font-size:10px;font-weight:var(--fw-medium);padding:2px 7px;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default)}.progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;min-width:60px}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal);background:linear-gradient(90deg,var(--accent-indigo),var(--accent-cyan))}.progress-bar-fill[data-done=true]{background:var(--accent-emerald)}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--bg-tertiary)}.progress-ring-fill{fill:none;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:90%;max-width:520px;box-shadow:var(--shadow-lg);animation:slideUp .3s var(--ease-out)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-lg) var(--sp-xl);border-bottom:1px solid var(--border-default)}.modal-header h2{font-size:var(--fs-lg);font-weight:var(--fw-semibold)}.modal-close{background:none;border:none;color:var(--text-tertiary);font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--sp-xl)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-sm);padding:var(--sp-lg) var(--sp-xl);border-top:1px solid var(--border-default)}.form-group{margin-bottom:var(--sp-lg)}.form-label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary);margin-bottom:var(--sp-xs)}.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--fs-sm);padding:var(--sp-sm) var(--sp-md);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent-indigo);box-shadow:var(--shadow-glow-indigo)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:60px}.form-row{display:flex;gap:var(--sp-md)}.form-row .form-group{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}[data-tooltip]{position:relative}[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--fs-xs);padding:4px 8px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;z-index:99;box-shadow:var(--shadow-md);animation:fadeIn .15s ease}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-strong);color:var(--text-secondary);padding:var(--sp-sm) var(--sp-md);font-size:var(--fs-sm);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-indigo)}.status-archived{background:#4b556326;color:#6b7280;text-decoration:line-through}.color-swatch{display:block;width:28px;height:28px;border-radius:8px;border:3px solid transparent;transition:border-color .15s,transform .15s;cursor:pointer}.color-swatch:hover{transform:scale(1.1)}.attachments-empty{text-align:center;color:var(--text-muted);padding:var(--sp-lg) 0;font-size:var(--fs-sm)}.attachments-list{display:flex;flex-direction:column;gap:var(--sp-xs);margin-bottom:var(--sp-lg);max-height:200px;overflow-y:auto}.attachment-item{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-sm) var(--sp-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.attachment-item:hover{border-color:var(--border-strong)}.attachment-icon{font-size:1.2rem;flex-shrink:0}.attachment-info{flex:1;min-width:0;display:flex;flex-direction:column}.attachment-name{font-size:var(--fs-sm);color:var(--text-primary);font-weight:var(--fw-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-meta{font-size:10px;color:var(--text-tertiary)}.attachment-remove{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:14px;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0}.attachment-remove:hover{color:var(--accent-rose);background:#f43f5e1a}.attachment-upload-area{border-top:1px solid var(--border-default);padding-top:var(--sp-lg)}.attachment-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-sm);padding:var(--sp-xl) var(--sp-lg);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-tertiary);font-size:var(--fs-sm);transition:all var(--transition-fast);margin-bottom:var(--sp-md)}.attachment-upload-zone:hover{border-color:var(--accent-indigo);background:#6366f10a;color:var(--text-secondary)}.attachment-upload-zone.dragover{border-color:var(--accent-indigo);background:#6366f114;color:var(--accent-indigo)}.attachment-path-row{display:flex;gap:var(--sp-sm);align-items:center}.attachment-path-row .form-input{flex:1}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-default);display:flex;flex-direction:column;flex-shrink:0;z-index:10;position:relative}.sidebar-header{padding:var(--sp-lg) var(--sp-xl);border-bottom:1px solid var(--border-default)}.logo{display:flex;align-items:center;gap:var(--sp-sm)}.logo-icon{font-size:1.5rem}.logo-text{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.03em}.logo-highlight{background:linear-gradient(135deg,var(--accent-indigo),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--sp-lg) 0}.nav-section{margin-bottom:var(--sp-xl)}.nav-section-title{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:0 var(--sp-xl);margin-bottom:var(--sp-sm)}.nav-item{display:flex;align-items:center;gap:var(--sp-sm);width:100%;padding:var(--sp-sm) var(--sp-xl);background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);text-align:left;border-left:3px solid transparent}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{color:var(--accent-indigo);background:#6366f114;border-left-color:var(--accent-indigo)}.nav-item svg{flex-shrink:0}.project-nav-item{display:flex;align-items:center;gap:var(--sp-sm);width:100%;padding:6px var(--sp-xl);background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.project-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.project-nav-item.active{color:var(--text-primary);background:var(--bg-hover)}.project-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.project-nav-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-nav-count{font-size:var(--fs-xs);color:var(--text-muted);font-weight:var(--fw-medium)}.project-nav-all{display:flex;align-items:center;gap:var(--sp-sm);width:100%;padding:6px var(--sp-xl);background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);text-align:left;margin-bottom:4px}.project-nav-all:hover{background:var(--bg-hover);color:var(--text-primary)}.project-nav-all.active{color:var(--accent-indigo);background:#6366f114}.sidebar-footer{padding:var(--sp-lg) var(--sp-xl);border-top:1px solid var(--border-default)}.grid-view{animation:fadeIn .3s ease}.grid-table-wrapper{border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:auto;background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.grid-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:900px}.grid-table thead{position:sticky;top:0;z-index:5}.grid-table th{background:var(--bg-tertiary);padding:var(--sp-sm) var(--sp-md);text-align:left;font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-strong);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;transition:color var(--transition-fast)}.grid-table th:hover{color:var(--text-primary)}.grid-table th:first-child{padding-left:var(--sp-lg)}.col-task{width:auto;min-width:350px}.col-status{width:110px}.col-priority{width:90px}.col-start,.col-due{width:100px}.col-progress{width:120px}.col-tags{width:auto}.grid-table td{padding:var(--sp-sm) var(--sp-md);border-bottom:1px solid var(--border-default);font-size:var(--fs-sm);color:var(--text-primary);vertical-align:middle}.grid-table td:first-child{padding-left:var(--sp-lg)}.grid-table tbody tr{transition:background var(--transition-fast)}.grid-table tbody tr:hover{background:var(--bg-hover)}.grid-table tbody tr:last-child td{border-bottom:none}.grid-project-row td{background:#6366f10a;padding:var(--sp-md) var(--sp-md);font-weight:var(--fw-semibold);border-bottom:1px solid var(--border-strong)}.grid-project-row:hover td{background:#6366f114!important}.grid-project-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;display:inline-flex;transition:transform var(--transition-fast);margin-right:var(--sp-sm)}.grid-project-toggle.collapsed{transform:rotate(-90deg)}.grid-project-toggle svg{width:14px;height:14px}.grid-project-color{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:var(--sp-sm);vertical-align:middle}.grid-task-row td:first-child{padding-left:calc(var(--sp-lg) + 24px)}.grid-subtask-row td:first-child{padding-left:calc(var(--sp-lg) + 48px)}.grid-subtask-row td{font-size:var(--fs-xs);color:var(--text-secondary)}.grid-cell-editable{cursor:text;border-radius:var(--radius-sm);padding:2px 4px;transition:background var(--transition-fast)}.grid-cell-editable:hover{background:var(--bg-active)}.grid-progress{display:flex;align-items:center;gap:var(--sp-sm)}.grid-progress-value{font-size:var(--fs-xs);color:var(--text-tertiary);font-weight:var(--fw-medium);font-family:var(--font-mono);min-width:32px}.grid-tags{display:flex;gap:4px;flex-wrap:wrap}.grid-date{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-secondary)}.grid-empty{text-align:center;padding:var(--sp-3xl);color:var(--text-muted)}.grid-empty-icon{font-size:3rem;margin-bottom:var(--sp-md)}.grid-empty-text{font-size:var(--fs-base)}.col-attachments{width:50px;text-align:center}.col-actions{width:60px;text-align:center}.grid-task-count{font-size:var(--fs-xs);color:var(--text-tertiary);font-weight:var(--fw-normal);margin-left:var(--sp-sm)}.grid-agent{font-size:var(--fs-xs);color:var(--text-tertiary)}.grid-assignee-text{font-size:var(--fs-xs);color:var(--text-secondary)}.grid-task-name-cell{display:flex;align-items:center;gap:4px}.grid-subtask-toggle{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:inline-flex;transition:transform var(--transition-fast),color var(--transition-fast);flex-shrink:0}.grid-subtask-toggle:hover{color:var(--accent-indigo)}.grid-subtask-toggle.collapsed{transform:rotate(-90deg)}.grid-subtask-toggle svg{width:12px;height:12px}.grid-subtask-spacer{display:inline-block;width:18px;flex-shrink:0}.grid-task-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-subtask-indent{color:var(--text-secondary);font-size:var(--fs-xs)}.grid-att-count{font-size:var(--fs-xs);color:var(--text-tertiary);white-space:nowrap}.grid-actions{display:flex;justify-content:center;align-items:center}.grid-action-toggle{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.grid-action-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.grid-dropdown-menu{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:1000;padding:4px;display:none;flex-direction:column;min-width:160px;animation:fadeIn .1s ease}.grid-dropdown-menu.active{display:flex}.grid-dropdown-item{background:none;border:none;text-align:left;padding:8px 12px;font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;gap:10px;width:100%;transition:background var(--transition-fast)}.grid-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.grid-dropdown-item.delete:hover{color:var(--accent-rose);background:#f43f5e1a}.grid-dropdown-item svg{width:16px;height:16px;opacity:.7}.grid-dropdown-item:hover svg{opacity:1}.gantt-view{animation:fadeIn .3s ease}.gantt-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-lg)}.gantt-zoom{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:2px}.gantt-zoom-btn{background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--fs-xs);font-weight:var(--fw-medium);padding:4px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.gantt-zoom-btn:hover{color:var(--text-primary)}.gantt-zoom-btn.active{background:var(--accent-indigo);color:#fff}.gantt-container{display:flex;border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.gantt-tasks{width:280px;min-width:280px;border-right:2px solid var(--border-strong);flex-shrink:0}.gantt-tasks-header{padding:var(--sp-sm) var(--sp-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-strong);font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;height:50px;display:flex;align-items:center}.gantt-task-item{padding:8px var(--sp-md);border-bottom:1px solid var(--border-default);font-size:var(--fs-sm);display:flex;align-items:center;gap:var(--sp-sm);height:40px;transition:background var(--transition-fast)}.gantt-task-item:hover{background:var(--bg-hover)}.gantt-task-item.project-item{font-weight:var(--fw-semibold);background:#6366f10a}.gantt-task-color{width:6px;height:6px;border-radius:50%;flex-shrink:0}.gantt-task-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-timeline{flex:1;overflow-x:auto;position:relative}.gantt-timeline-header{display:flex;background:var(--bg-tertiary);border-bottom:1px solid var(--border-strong);height:50px;position:sticky;top:0;z-index:3}.gantt-day-cell{min-width:40px;border-right:1px solid var(--border-default);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.gantt-day-cell.weekend{background:#ffffff05}.gantt-day-cell.today{background:#6366f114}.gantt-day-name{font-weight:var(--fw-medium);color:var(--text-tertiary)}.gantt-day-num{font-family:var(--font-mono);font-size:11px}.gantt-bars{position:relative}.gantt-bar-row{height:40px;border-bottom:1px solid var(--border-default);position:relative}.gantt-bar{position:absolute;top:10px;height:20px;border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-fast),box-shadow var(--transition-fast);display:flex;align-items:center;overflow:hidden;min-width:8px}.gantt-bar:hover{opacity:.9;box-shadow:0 2px 12px #0000004d;z-index:2}.gantt-bar-fill{height:100%;border-radius:var(--radius-sm);opacity:.4}.gantt-bar-label{position:absolute;left:8px;font-size:10px;font-weight:var(--fw-medium);color:#fff;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.5)}.gantt-today-marker{position:absolute;top:0;bottom:0;width:2px;background:var(--accent-rose);z-index:4;box-shadow:0 0 8px #f43f5e66}.gantt-today-marker:before{content:"Today";position:absolute;top:-50px;left:50%;transform:translate(-50%);font-size:9px;font-weight:var(--fw-bold);color:var(--accent-rose);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.gantt-dependency{stroke:var(--text-muted);stroke-width:1.5;fill:none;marker-end:url(#arrowhead)}.kanban-view{animation:fadeIn .3s ease}.kanban-board{display:flex;gap:var(--sp-lg);height:calc(100vh - 150px);overflow-x:auto;padding-bottom:var(--sp-lg)}.kanban-column{min-width:280px;max-width:320px;flex:1;display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-default);overflow:hidden}.kanban-column-header{padding:var(--sp-md) var(--sp-lg);display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--border-default);flex-shrink:0}.kanban-column-title{display:flex;align-items:center;gap:var(--sp-sm);font-size:var(--fs-sm);font-weight:var(--fw-semibold)}.kanban-column-dot{width:8px;height:8px;border-radius:50%}.kanban-column-count{font-size:var(--fs-xs);color:var(--text-muted);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-full);font-weight:var(--fw-medium)}.kanban-column-body{flex:1;overflow-y:auto;padding:var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-sm)}.kanban-column-body.drag-over{background:#6366f10d;border:2px dashed var(--accent-indigo);border-radius:var(--radius-md)}.kanban-card{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--sp-md);cursor:grab;transition:all var(--transition-fast);animation:slideIn .2s ease}.kanban-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card:active{cursor:grabbing;opacity:.8}.kanban-card.dragging{opacity:.5;transform:rotate(2deg)}.kanban-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-sm);margin-bottom:var(--sp-sm)}.kanban-card-title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);line-height:1.4}.kanban-card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm);margin-top:var(--sp-sm)}.kanban-card-project{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-muted)}.kanban-card-project-dot{width:6px;height:6px;border-radius:50%}.kanban-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:var(--sp-sm)}.kanban-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-md);padding-top:var(--sp-sm);border-top:1px solid var(--border-default)}.kanban-card-assignee{font-size:var(--fs-xs);color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.kanban-card-due{font-size:10px;font-family:var(--font-mono);color:var(--text-muted)}.kanban-card-due.overdue{color:var(--accent-rose)}.dashboard-view{animation:fadeIn .3s ease}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--sp-lg)}.dashboard-widget{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.dashboard-widget:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.widget-header{padding:var(--sp-md) var(--sp-lg);border-bottom:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between}.widget-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.widget-body{padding:var(--sp-lg)}.dashboard-projects{grid-column:1 / -1}.project-health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--sp-md)}.project-health-card{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--sp-lg);display:flex;align-items:center;gap:var(--sp-lg);transition:border-color var(--transition-fast),transform var(--transition-fast)}.project-health-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.project-health-info{flex:1}.project-health-name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);margin-bottom:2px}.project-health-agent{font-size:var(--fs-xs);color:var(--text-muted)}.project-health-tasks{font-size:var(--fs-xs);color:var(--text-tertiary);margin-top:var(--sp-sm)}.donut-chart{display:flex;align-items:center;gap:var(--sp-xl)}.donut-legend{display:flex;flex-direction:column;gap:var(--sp-sm)}.donut-legend-item{display:flex;align-items:center;gap:var(--sp-sm);font-size:var(--fs-sm);color:var(--text-secondary)}.donut-legend-color{width:10px;height:10px;border-radius:3px;flex-shrink:0}.donut-legend-count{font-weight:var(--fw-semibold);color:var(--text-primary);margin-left:auto;font-family:var(--font-mono)}.deadline-list{display:flex;flex-direction:column;gap:var(--sp-sm)}.deadline-item{display:flex;align-items:center;gap:var(--sp-md);padding:var(--sp-sm);border-radius:var(--radius-md);transition:background var(--transition-fast)}.deadline-item:hover{background:var(--bg-hover)}.deadline-date{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--text-muted);min-width:70px}.deadline-task{flex:1;font-size:var(--fs-sm);color:var(--text-primary)}.deadline-project{font-size:var(--fs-xs);color:var(--text-tertiary)}.deadline-urgent .deadline-date{color:var(--accent-rose);font-weight:var(--fw-bold)}.activity-list{display:flex;flex-direction:column;gap:var(--sp-sm);max-height:250px;overflow-y:auto}.activity-item{display:flex;gap:var(--sp-sm);padding:var(--sp-sm);border-radius:var(--radius-md);font-size:var(--fs-sm)}.activity-dot{width:6px;height:6px;border-radius:50%;margin-top:6px;flex-shrink:0}.activity-text{color:var(--text-secondary)}.activity-text strong{color:var(--text-primary);font-weight:var(--fw-medium)}.activity-time{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}.fm-panel{height:100%;display:flex;flex-direction:column;background:var(--bg-surface);border-left:1px solid var(--border);border-radius:var(--radius-lg) 0 0 var(--radius-lg);overflow:hidden}.fm-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.fm-title{font-size:var(--fs-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin:0}.fm-title svg{opacity:.6}.fm-actions-header{display:flex;gap:4px}.fm-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:4px 6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.fm-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.fm-tree{flex:1;overflow-y:auto;padding:8px 0}.fm-tree::-webkit-scrollbar{width:4px}.fm-tree::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.fm-item{display:flex;align-items:center;padding:6px 12px;gap:8px;cursor:default;transition:background .1s ease;position:relative;min-height:32px}.fm-item:hover{background:#6366f114}.fm-item-icon{font-size:14px;flex-shrink:0;width:18px;text-align:center}.fm-item-name{font-size:var(--fs-xs);color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:JetBrains Mono,monospace}.fm-file .fm-item-name{color:var(--text-secondary)}.fm-item-size{font-size:10px;color:var(--text-tertiary);white-space:nowrap;font-family:JetBrains Mono,monospace}.fm-item-actions{display:flex;gap:2px;opacity:1;transition:opacity .15s ease}.fm-item-attach,.fm-item-download,.fm-item-delete{background:transparent;border:none;cursor:pointer;font-size:12px;padding:2px 4px;border-radius:3px;transition:all .1s ease;line-height:1;opacity:.5}.fm-item-attach{color:var(--accent)}.fm-item-download{color:#10b981}.fm-item-attach:hover,.fm-item-download:hover{background:#6366f126;opacity:1}.fm-item-download:hover{background:#10b98126}.fm-item-delete{color:var(--text-tertiary);opacity:0}.fm-item:hover .fm-item-delete{opacity:1}.fm-item-delete:hover{background:#f43f5e33;color:var(--danger)}.fm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;padding:32px}.fm-empty-icon{font-size:40px;opacity:.4}.fm-empty-text{font-size:var(--fs-sm);color:var(--text-tertiary);text-align:center}.fm-empty-folder{font-size:var(--fs-xs);color:var(--text-tertiary);text-align:center;padding:32px 16px}.view-container-split{display:flex;gap:0;height:100%}.view-container-split .view-main{flex:1;overflow:auto;min-width:0}.view-container-split .view-files{width:300px;min-width:260px;max-width:360px;flex-shrink:0;height:100%;overflow:hidden}.server-file-picker{border:1px solid var(--border);border-radius:var(--radius);max-height:200px;overflow-y:auto;margin-top:8px}.server-file-picker .fm-item{padding:5px 10px}.server-file-picker .fm-item:hover{background:#6366f11f}.server-file-picker .fm-item.selected{background:#6366f133;border-left:3px solid var(--accent)}.server-file-picker-label{font-size:var(--fs-xs);color:var(--text-secondary);margin-top:12px;margin-bottom:4px;display:flex;align-items:center;gap:6px}.server-file-picker-label svg{opacity:.5}
