:root{--bg-primary:#2c2826;--bg-secondary:#363230;--bg-tertiary:#423d3a;--bg-elevated:#3e3a37;--bg-hover:#4a4542;--text-primary:#e8e6e1;--text-secondary:#b0aba5;--text-muted:#7d7875;--accent-primary:#b8c9bb;--accent-secondary:#e0c6c2;--accent-warning:#e8d595;--accent-success:#9ebda2;--accent-danger:#e09f9f;--border-color:#4a4542;--border-light:#544f4c;--dot-color:#423d3a;--node-bg:#363230;--node-border:#4a4542;--node-selected:var(--accent-primary);--node-start:#d4d4d8;--node-goal:var(--accent-success);--node-c-default-bg:#363230;--node-c-default-border:#4a4542;--node-c-blue-bg:#2a303c;--node-c-blue-border:#8ab4f8;--node-c-green-bg:#2a362e;--node-c-green-border:#81c995;--node-c-yellow-bg:#36322a;--node-c-yellow-border:#fdd663;--node-c-red-bg:#362a2a;--node-c-red-border:#f28b82;--node-c-purple-bg:#302a36;--node-c-purple-border:#c58af9;--node-c-cyan-bg:#2a3436;--node-c-cyan-border:#78d9ec;--shadow-sm:0 2px 8px rgba(0,0,0,.2);--shadow-md:0 4px 16px rgba(0,0,0,.3);--shadow-lg:0 8px 24px rgba(0,0,0,.4);--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--transition-fast:0.2s cubic-bezier(0.2,0.8,0.2,1);--transition-normal:0.3s cubic-bezier(0.2,0.8,0.2,1);--header-height:64px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Inter,Noto Sans JP,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow:hidden;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;z-index:100}.header-left,.header-right{display:flex;align-items:center;gap:8px}.app-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);color:var(--text-secondary)}.icon-btn:hover{background:var(--bg-tertiary)}.icon-btn:active{background:var(--bg-elevated)}.icon-btn svg{width:20px;height:20px;fill:currentColor}.icon-btn.active{background:var(--bg-tertiary);color:var(--accent-primary);box-shadow:inset 0 2px 4px rgba(0,0,0,.05)}.zoom-level{font-size:.75rem;color:var(--text-secondary);min-width:40px;text-align:center}.divider{width:1px;height:24px;background:var(--border-color);margin:0 4px}.canvas-container{flex:1;position:relative;overflow:hidden;touch-action:none;background:var(--bg-primary)}.canvas-svg{width:100%;height:100%;cursor:grab}.canvas-svg:active{cursor:grabbing}.node-group{cursor:pointer}.node-body{fill:var(--node-bg);stroke:var(--node-border);stroke-width:2;rx:20;ry:20;transition:all var(--transition-fast)}.node-group.selected .node-body,.node-group:hover .node-body{stroke:var(--node-selected);filter:drop-shadow(0 0 8px rgba(138,180,248,.3))}.node-group.start .node-body{fill:var(--node-start);stroke:var(--node-start)}.node-group.goal .node-body{fill:transparent;stroke:var(--node-goal);stroke-width:3;stroke-dasharray:6 3}.node-group.color-default .node-body{fill:var(--node-c-default-bg);stroke:var(--node-c-default-border)}.node-group.color-blue .node-body{fill:var(--node-c-blue-bg);stroke:var(--node-c-blue-border)}.node-group.color-green .node-body{fill:var(--node-c-green-bg);stroke:var(--node-c-green-border)}.node-group.color-yellow .node-body{fill:var(--node-c-yellow-bg);stroke:var(--node-c-yellow-border)}.node-group.color-red .node-body{fill:var(--node-c-red-bg);stroke:var(--node-c-red-border)}.node-group.color-purple .node-body{fill:var(--node-c-purple-bg);stroke:var(--node-c-purple-border)}.node-group.color-cyan .node-body{fill:var(--node-c-cyan-bg);stroke:var(--node-c-cyan-border)}.node-text{fill:var(--text-primary);font-family:Inter,Noto Sans JP,sans-serif;font-weight:500;text-anchor:middle;dominant-baseline:central;pointer-events:none}.node-date-badge{fill:var(--accent-primary);font-weight:600}.connection{fill:none;stroke:var(--border-light);stroke-width:2;stroke-linecap:round;pointer-events:none}.node-group.connecting-from .node-body{stroke:var(--accent-secondary);stroke-width:3;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{filter:drop-shadow(0 0 4px var(--accent-secondary))}50%{filter:drop-shadow(0 0 12px var(--accent-secondary))}}.inline-editor{position:fixed;z-index:1000;display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:220px;max-width:350px;animation:fadeInUp .2s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.inline-editor textarea{width:100%;min-height:40px;max-height:150px;padding:10px 12px;font-size:.9375rem;font-family:inherit;background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:var(--radius-sm);outline:none;resize:none;transition:border-color var(--transition-fast)}.inline-editor textarea:focus{border-color:var(--accent-primary)}.inline-editor textarea::-moz-placeholder{color:var(--text-muted)}.inline-editor textarea::placeholder{color:var(--text-muted)}.inline-color-picker{display:flex;justify-content:center;gap:8px;padding:4px 0}.color-swatch{width:20px;height:20px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform var(--transition-fast),border-color var(--transition-fast);opacity:.7}.color-swatch:hover{transform:scale(1.2);opacity:1}.color-swatch.active{border-color:var(--text-primary);transform:scale(1.1);opacity:1}.color-swatch.default{background:var(--node-c-default-border)}.color-swatch.blue{background:var(--node-c-blue-border)}.color-swatch.green{background:var(--node-c-green-border)}.color-swatch.yellow{background:var(--node-c-yellow-border)}.color-swatch.red{background:var(--node-c-red-border)}.color-swatch.purple{background:var(--node-c-purple-border)}.color-swatch.cyan{background:var(--node-c-cyan-border)}.inline-date-row{display:flex;align-items:center;gap:8px}.inline-date-row label{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap}.inline-date-input{flex:1;padding:6px 10px;font-size:.875rem;font-family:inherit;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);outline:none}.inline-date-input:focus{border-color:var(--accent-primary)}.inline-actions{display:flex;gap:8px}.inline-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.inline-btn:hover{background:var(--bg-elevated)}.inline-btn svg{width:18px;height:18px;fill:var(--text-secondary)}.inline-btn.delete:hover{background:var(--accent-danger)}.inline-btn.delete:hover svg{fill:#000}.inline-btn.done:hover{background:var(--accent-primary)}.inline-btn.done:hover svg{fill:#000}.inline-btn.clear-date{width:28px;height:28px}.inline-btn.clear-date svg{width:14px;height:14px}.inline-hint{font-size:.75rem;color:var(--text-muted);text-align:center}.context-menu{position:fixed;z-index:300;min-width:180px;padding:8px 0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:fadeIn .15s ease}.context-menu-item{display:flex;align-items:center;gap:12px;padding:10px 16px;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.context-menu-item:hover{background:var(--bg-tertiary)}.context-menu-item svg{width:18px;height:18px;fill:var(--text-secondary)}.context-menu-item.disabled{opacity:.5;pointer-events:none}.context-menu-divider{height:1px;margin:8px 0;background:var(--border-color)}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);padding:12px 24px;background:var(--bg-elevated);color:var(--text-primary);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);font-size:.875rem;font-weight:500;z-index:600;animation:toastIn .3s ease}@keyframes toastIn{0%{transform:translateX(-50%) translateY(100%);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}.hidden{display:none!important}.dashboard-content{display:flex;height:calc(100vh - var(--header-height));gap:0}.right-panel-container{height:100%;overflow:hidden}.right-panel-container,.task-list-panel{flex:1;display:flex;flex-direction:column}.task-list-panel{padding:20px;overflow-y:auto;border-bottom:1px solid var(--border-color);background:var(--bg-primary);min-height:0}.timeline-panel{background:var(--bg-secondary);min-height:0}.timeline-content,.timeline-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.timeline-content{position:relative;border-top:1px solid var(--border-color)}.timeline-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);opacity:.5}.timeline-placeholder svg{width:48px;height:48px;fill:currentColor}.dashboard-header{text-align:center;margin-bottom:16px;flex-shrink:0}.dashboard-header h2{font-size:1.5rem;font-weight:600;margin-bottom:4px}.dashboard-header .subtitle{color:var(--text-secondary);font-size:.875rem}.search-sort-bar{display:flex;gap:12px;margin-bottom:12px;flex-shrink:0}.search-box{flex:1;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.search-box svg{width:20px;height:20px;fill:var(--text-muted);flex-shrink:0}.search-box input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;outline:none}.search-box input::-moz-placeholder{color:var(--text-muted)}.search-box input::placeholder{color:var(--text-muted)}.sort-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.sort-controls label{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap}.sort-controls select{padding:8px 12px;font-size:.875rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;outline:none}.flow-grid{display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto}.flow-card{display:flex;align-items:center;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);min-height:40px}.flow-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--bg-tertiary);border-color:var(--border-light)}.flow-card.selected{background:var(--bg-tertiary);border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(138,180,248,.2)}.flow-card-header{display:flex;align-items:center;flex:1;min-width:0;margin-right:8px}.flow-card-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-card-input,.flow-card-title{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.flow-card-input{width:100%;padding:2px 4px;background:var(--bg-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);outline:none}.flow-card-meta{gap:6px;font-size:.6875rem;color:var(--text-secondary);flex-shrink:0}.flow-card-due,.flow-card-meta{display:flex;align-items:center}.flow-card-due{gap:4px;padding:1px 6px;background:var(--bg-elevated);border-radius:var(--radius-full);font-size:.625rem;font-weight:500}.flow-card-due svg{width:10px;height:10px;fill:currentColor}.flow-card-action{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:all var(--transition-fast)}.flow-card:hover .flow-card-action{opacity:1}.flow-card-action:hover{background:var(--bg-hover);color:var(--text-primary)}.flow-card-action.delete:hover{background:var(--accent-danger);color:#fff}.flow-card-action svg{width:16px;height:16px;fill:currentColor}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-muted);text-align:center}.empty-icon{width:48px;height:48px;fill:var(--text-muted);margin-bottom:12px;opacity:.5}.todo-panel{width:20vw;display:flex;flex-direction:column;background:var(--bg-primary);border-right:1px solid var(--border-color)}.todo-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color)}.todo-panel-header h2{font-size:1rem;font-weight:600;margin:0}.todo-mode-toggle{display:flex;gap:4px}.todo-mode-toggle button{padding:4px 8px;font-size:.75rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.todo-mode-toggle button.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#000}.todo-list{flex:1;overflow-y:auto;padding:8px}.todo-empty{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:.875rem}.todo-flow-group{margin-bottom:16px}.todo-flow-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:8px 12px 4px;text-transform:uppercase;letter-spacing:.5px}.todo-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:6px;cursor:pointer;transition:all var(--transition-fast)}.todo-item:hover{background:var(--bg-tertiary)}.todo-item-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.todo-item-title{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.todo-item-flow{font-size:.7rem;color:var(--text-muted)}.todo-item-date{font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);white-space:nowrap}.todo-item-date.overdue{background:rgba(255,82,82,.2);color:#ff5252}.todo-item-date.today{background:rgba(255,193,7,.2);color:#ffc107}.todo-item-date.tomorrow{background:rgba(138,180,248,.2);color:var(--accent-primary)}.todo-item-date.soon{background:rgba(129,199,132,.2);color:#81c784}.flow-preview-popup{position:fixed;width:240px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:1000;pointer-events:none;animation:fadeIn .15s ease-out}.preview-popup-title{font-size:.875rem;font-weight:600;padding:12px 12px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-popup-meta{font-size:.7rem;color:var(--text-muted);padding:0 12px 8px}.preview-popup-canvas{width:100%;height:120px;background:var(--bg-primary);border-radius:0 0 var(--radius-md) var(--radius-md)}.preview-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;padding:40px}.preview-empty-icon{width:64px;height:64px;fill:var(--text-muted);margin-bottom:16px;opacity:.3}.preview-hint{font-size:.75rem;margin-top:4px;opacity:.7}.preview-content{flex:1;display:flex;flex-direction:column;padding:20px}.preview-title{font-size:1.25rem;font-weight:600;margin-bottom:8px}.preview-meta{font-size:.8125rem;color:var(--text-secondary);margin-bottom:16px;display:flex;gap:16px}.preview-canvas-container{flex:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;min-height:300px}.preview-canvas-svg{width:100%;height:100%}.btn-open-flow{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:14px 24px;font-size:1rem;font-weight:500;background:var(--accent-primary);color:#000;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-open-flow:hover{background:var(--accent-secondary)}.btn-open-flow svg{width:20px;height:20px;fill:currentColor}.memo-panel{position:fixed;top:56px;left:0;width:320px;height:calc(100vh - 56px);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;animation:slideInLeft .2s ease-out}@keyframes slideInLeft{0%{transform:translateX(-100%);opacity:0}to{transform:translateX(0);opacity:1}}.memo-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color)}.memo-panel-header h3{font-size:1rem;font-weight:600;margin:0}.memo-panel-content{flex:1;display:flex;flex-direction:column;padding:16px;gap:12px;overflow:hidden}.memo-node-title{font-size:.875rem;font-weight:500;color:var(--text-secondary);padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.memo-textarea{flex:1;padding:12px;font-size:.875rem;font-family:inherit;line-height:1.6;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);resize:none;outline:none}.memo-textarea:focus{border-color:var(--accent-primary)}.memo-textarea::-moz-placeholder{color:var(--text-muted)}.memo-textarea::placeholder{color:var(--text-muted)}.inline-btn.memo:hover{background:var(--accent-primary)}.inline-btn.memo:hover svg{fill:#000}.memo-tooltip{position:fixed;max-width:280px;padding:8px 12px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8125rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;z-index:1000;box-shadow:0 4px 12px rgba(0,0,0,.3);pointer-events:none;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width:900px){.dashboard-content{flex-direction:column}.task-list-panel{max-width:100%;border-right:none;border-bottom:1px solid var(--border-color);max-height:50%}.preview-panel{min-width:auto}.search-sort-bar{flex-direction:column}}.chunk-group{margin-bottom:12px}.chunk-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background var(--transition-fast)}.chunk-header:hover{background:var(--bg-hover)}.chunk-arrow{width:20px;height:20px;fill:var(--text-secondary);transition:transform var(--transition-fast)}.chunk-arrow.collapsed{transform:rotate(-90deg)}.chunk-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.chunk-count{font-size:.75rem;color:var(--text-muted)}.chunk-flows{display:flex;flex-direction:column;gap:6px;padding-left:8px;margin-top:6px}.flow-card-chunk-select{padding:2px 6px;font-size:.7rem;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;outline:none;max-width:80px}.flow-card-chunk-select:focus{border-color:var(--accent-primary)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:24px;min-width:320px;box-shadow:var(--shadow-lg);animation:fadeInUp .2s ease}.modal-content h3{font-size:1.125rem;font-weight:600;margin-bottom:16px}.modal-input{width:100%;padding:10px 12px;font-size:.9375rem;font-family:inherit;background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:var(--radius-sm);outline:none;margin-bottom:16px}.modal-input:focus{border-color:var(--accent-primary)}.modal-input::-moz-placeholder{color:var(--text-muted)}.modal-input::placeholder{color:var(--text-muted)}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.modal-btn{padding:8px 16px;font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.modal-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.modal-btn.cancel:hover{background:var(--bg-hover)}.modal-btn.confirm{background:var(--accent-primary);color:#000}.modal-btn.confirm:hover{background:var(--accent-success)}.todo-chunk-filter{padding:8px 16px;border-bottom:1px solid var(--border-color)}.todo-chunk-filter select{width:100%;padding:6px 10px;font-size:.8125rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;outline:none}.todo-chunk-filter select:focus{border-color:var(--accent-primary)}.dashboard-header.compact{padding:8px 16px;min-height:40px}.gantt-container{flex-direction:column;height:100%;overflow:hidden;min-height:0}.gantt-container,.gantt-toolbar{display:flex;background:var(--bg-secondary)}.gantt-toolbar{align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0;z-index:40}.gantt-scroll-area{flex:1;overflow:auto;position:relative;min-height:0}.gantt-table{display:flex;flex-direction:column;min-width:-moz-fit-content;min-width:fit-content}.gantt-header-row,.gantt-row{display:flex;flex-wrap:nowrap}.gantt-row{border-bottom:1px dashed var(--border-light)}.gantt-header-row{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);height:48px}.sticky-header{position:sticky;top:0;z-index:20}.sticky-col{position:sticky;left:0;z-index:10;background:var(--bg-primary);border-right:1px solid var(--border-color)}.sticky-header .sticky-col{z-index:30;background:var(--bg-secondary)}.gantt-corner-cell{padding-left:12px;font-weight:600}.gantt-corner-cell,.gantt-date-cell{display:flex;align-items:center;font-size:.75rem;color:var(--text-secondary);flex-shrink:0}.gantt-date-cell{flex-direction:column;justify-content:center;border-right:1px solid var(--border-light);background:var(--bg-secondary)}.gantt-date-cell.today{background:rgba(184,201,187,.2);color:var(--accent-primary);font-weight:600}.gantt-date-cell.weekend{background:rgba(0,0,0,.2)}.swimlane-header{border-bottom:1px solid var(--border-color)}.swimlane-header,.swimlane-header .sticky-col{background:var(--bg-tertiary)}.swimlane-label{display:flex;align-items:center;gap:8px;padding:0 12px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.gantt-swimlane-bar{width:4px;height:16px;border-radius:2px}.gantt-cell-sidebar{flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:0 12px;background:var(--bg-primary)}.task-label{cursor:pointer;transition:background var(--transition-fast)}.task-label:hover{background:var(--bg-hover)}.gantt-task-title{font-size:.8125rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-task-flow{font-size:.6875rem;color:var(--text-muted)}.gantt-timeline-cells{display:flex;position:relative}.gantt-cell{flex-shrink:0;border-right:1px solid var(--border-light);height:100%}.gantt-cell.today{background:rgba(184,201,187,.05);border-left:2px solid var(--accent-primary)}.gantt-cell.today,.gantt-date-cell.today{border-left:1px solid var(--accent-primary);border-right:1px solid var(--accent-primary)}.gantt-cell.weekend{background:rgba(0,0,0,.15)}.gantt-cell.spacer{opacity:.5;background:var(--bg-tertiary)}.gantt-task-bar{position:absolute;top:8px;height:calc(100% - 16px);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;padding:0 8px;font-size:.75rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);z-index:5}.gantt-task-bar:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);z-index:6;filter:brightness(1.1)}.gantt-task-bar.color-default{background:var(--node-c-default-bg);border-color:var(--node-c-default-border)}.gantt-task-bar.color-blue{background:var(--node-c-blue-bg);border-color:var(--node-c-blue-border)}.gantt-task-bar.color-green{background:var(--node-c-green-bg);border-color:var(--node-c-green-border)}.gantt-task-bar.color-yellow{background:var(--node-c-yellow-bg);border-color:var(--node-c-yellow-border)}.gantt-task-bar.color-red{background:var(--node-c-red-bg);border-color:var(--node-c-red-border)}.gantt-task-bar.color-purple{background:var(--node-c-purple-bg);border-color:var(--node-c-purple-border)}.gantt-task-bar.color-cyan{background:var(--node-c-cyan-bg);border-color:var(--node-c-cyan-border)}.gantt-empty{padding:40px;text-align:center;color:var(--text-muted)}.gantt-nav{gap:12px}.gantt-nav,.gantt-nav-btn{display:flex;align-items:center}.gantt-nav-btn{justify-content:center;width:28px;height:28px;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.gantt-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.gantt-nav-btn svg{width:18px;height:18px;fill:currentColor}.gantt-week-label{font-size:.9375rem;font-weight:600;color:var(--text-primary);min-width:120px;text-align:center}.gantt-controls{display:flex;align-items:center;gap:8px}.gantt-zoom-btn{padding:4px 10px;font-size:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.gantt-zoom-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.gantt-zoom-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#000}.gantt-today-btn{padding:4px 10px;font-size:.75rem;background:transparent;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);color:var(--accent-primary);cursor:pointer;margin-left:8px;transition:all var(--transition-fast)}.gantt-today-btn:hover{background:var(--accent-primary);color:#000}.gantt-tooltip{position:fixed;padding:12px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;pointer-events:none;animation:fadeIn .1s ease-out;transform:translate(-50%,-100%);margin-top:-8px;max-width:240px}.gantt-tooltip-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.gantt-tooltip-meta{display:flex;flex-direction:column;gap:2px;font-size:.75rem;color:var(--text-secondary)}.gantt-tooltip-memo{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted);white-space:pre-wrap}@media (max-width:1024px){:root{--header-height:56px}.icon-btn{min-width:44px;min-height:44px}.flow-card{min-height:48px;padding:12px 16px}.todo-item{min-height:44px;padding:10px 12px}.context-menu-item{min-height:44px;padding:12px 16px}.todo-panel{min-width:220px;max-width:280px}.inline-editor{min-width:280px}.inline-editor textarea{min-height:60px;font-size:1rem}.inline-btn{min-width:44px;min-height:44px}.color-swatch{width:28px;height:28px}.search-box input{font-size:1rem}.sort-controls select{font-size:.9375rem;padding:10px 14px}}@media (max-width:768px){.dashboard-content{flex-direction:column}.todo-panel{max-width:none;min-width:0;max-height:200px;border-right:none;border-bottom:1px solid var(--border-color)}.right-panel-container{flex:1;min-height:0}.app-title{font-size:1rem}.task-list-panel{padding:12px}}.fab-add-node{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--accent-primary);border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;transition:all var(--transition-fast)}.fab-add-node:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(0,0,0,.3)}.fab-add-node:active{transform:scale(.95)}.fab-add-node svg{width:28px;height:28px;fill:var(--bg-primary)}.icon-btn.delete-mode.active{background:var(--node-red);color:#fff}.icon-btn.delete-mode.active svg{fill:#fff}.inline-add-buttons{display:flex;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color)}.inline-add-buttons .inline-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.inline-add-buttons .inline-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.inline-add-buttons .inline-btn:hover svg{fill:#fff}.inline-add-buttons .inline-btn svg{width:18px;height:18px;fill:var(--text-secondary)}