:root{--bg: #f5f5f5;--surface: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--border: #e0e0e0;--accent: #4f8ef7;--hover: #f0f0f0;--drop-over-bg: #e8f0fe;--today-bg: #eef4ff;--card-bg: #ffffff;--gantt-row-alt: rgba(0, 0, 0, .02);--month-alt-bg: rgba(0, 0, 0, .035);--week-alt-bg: rgba(0, 0, 0, .03);--danger: #e85d4a;--header-height: 52px}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #1a1a1a;--surface: #242424;--text-primary: #f0f0f0;--text-secondary: #999999;--border: #383838;--accent: #5a9cff;--hover: #2e2e2e;--drop-over-bg: #1e2a3e;--today-bg: #1e2e58;--card-bg: #2e2e2e;--gantt-row-alt: rgba(255, 255, 255, .02);--month-alt-bg: rgba(255, 255, 255, .04);--week-alt-bg: rgba(255, 255, 255, .035);--danger: #ff6b5a}}:root[data-theme=dark]{--bg: #1a1a1a;--surface: #242424;--text-primary: #f0f0f0;--text-secondary: #999999;--border: #383838;--accent: #5a9cff;--hover: #2e2e2e;--drop-over-bg: #1e2a3e;--today-bg: #1e2e58;--card-bg: #2e2e2e;--gantt-row-alt: rgba(255, 255, 255, .02);--month-alt-bg: rgba(255, 255, 255, .04);--week-alt-bg: rgba(255, 255, 255, .035);--danger: #ff6b5a}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text-primary);overflow:hidden;height:100vh}#root{height:100vh;display:flex;flex-direction:column}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:16px;flex-shrink:0;z-index:10}.about-btn{font-size:16px;font-weight:700;color:var(--text-primary);white-space:nowrap;background:none;border:none;padding:0;cursor:pointer;opacity:.9}.about-btn:hover{opacity:1;color:var(--accent)}.demo-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:var(--accent);border-radius:4px;padding:2px 6px;opacity:.8}.header-controls{display:flex;align-items:center;gap:12px;margin-left:auto}.today-btn{background:none;border:1px solid var(--accent);border-radius:4px;padding:4px 12px;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;transition:background .1s,color .1s}.today-btn:hover{background:var(--accent);color:#fff}.year-nav{display:flex;align-items:center;gap:4px}.year-nav-label{font-size:14px;font-weight:700;color:var(--text-primary);min-width:44px;text-align:center}.year-nav-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:16px;line-height:1;color:var(--text-secondary);cursor:pointer;transition:background .1s,color .1s}.year-nav-btn:hover{background:var(--hover);color:var(--text-primary)}.theme-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:14px;line-height:1;color:var(--text-secondary);cursor:pointer;transition:background .1s,color .1s}.theme-btn:hover{background:var(--hover);color:var(--text-primary)}.header-divider{width:1px;height:24px;background:var(--border)}.electron .app-header{-webkit-app-region:drag;padding-left:80px}.electron .app-header button,.electron .app-header input,.electron .app-header select{-webkit-app-region:no-drag}.gantt-panel{flex-shrink:0;position:relative}.gantt-scroll{width:100%;height:100%;overflow-x:auto;overflow-y:auto;background:var(--bg)}.gantt-add-btn{position:absolute;bottom:18px;left:50%;transform:translate(-50%);z-index:20;background:var(--surface);border:1.5px dashed var(--accent);border-radius:6px;padding:6px 20px;font-size:11px;font-weight:600;color:var(--accent);cursor:pointer;white-space:nowrap;box-shadow:0 1px 6px #0000001a;transition:background .1s,color .1s}.gantt-add-btn:hover{background:var(--accent);color:#fff}.gantt-scroll::-webkit-scrollbar{width:12px;height:12px}.gantt-scroll::-webkit-scrollbar-track{background:var(--border);border-radius:6px}.gantt-scroll::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:6px;border:2px solid var(--bg)}.gantt-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.todo-scroll{flex:1;min-height:0;overflow-x:auto;overflow-y:auto;background:var(--bg)}.year-view .todo-scroll,.year-view .gantt-scroll{overflow-x:hidden}.todo-scroll::-webkit-scrollbar{width:12px;height:12px}.todo-scroll::-webkit-scrollbar-track{background:var(--border);border-radius:6px}.todo-scroll::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:6px;border:2px solid var(--bg)}.todo-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.gantt-resizer{flex-shrink:0;height:3px;cursor:ns-resize;background:var(--text-secondary);position:relative;z-index:5;transition:background .15s}.gantt-resizer:hover,.gantt-resizer:active{background:var(--accent)}.task-context-menu{position:fixed;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 16px #00000026;padding:4px;min-width:160px}.context-menu-item{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;border-radius:4px;font-size:13px;color:var(--text-primary);cursor:pointer}.context-menu-item:hover{background:var(--hover)}.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:var(--danger);color:#fff}.zoom-controls{display:flex;align-items:center;gap:4px}.zoom-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:4px 10px;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background .1s,color .1s,border-color .1s}.zoom-btn:hover{background:var(--hover);color:var(--text-primary)}.zoom-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.backup-panel{display:flex;align-items:center;gap:6px}.backup-label{font-size:11px;color:var(--text-secondary);opacity:.5;padding-right:2px}.import-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:4px 10px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:border-color .1s,color .1s}.import-btn:hover{border-color:var(--accent);color:var(--accent)}.gantt-bar{position:absolute;border-radius:4px;cursor:grab;-webkit-user-select:none;user-select:none;opacity:.88;transition:opacity .1s,box-shadow .1s;overflow:hidden;z-index:2}.gantt-bar:hover{opacity:1;box-shadow:0 2px 8px #00000040;z-index:3}.gantt-bar:active{cursor:grabbing}.gantt-bar.dragging{opacity:.4}.gantt-bar-title{position:absolute;top:50%;transform:translate(-50%) translateY(-50%);font-size:11px;color:#fff;white-space:nowrap;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.3);pointer-events:none;-webkit-user-select:none;user-select:none}.gantt-bar-handle{position:absolute;top:0;bottom:0;width:8px;cursor:ew-resize;z-index:4;opacity:0;transition:opacity .15s}.gantt-bar-handle.left{left:0;border-radius:4px 0 0 4px}.gantt-bar-handle.right{right:0;border-radius:0 4px 4px 0}.gantt-bar:hover .gantt-bar-handle{opacity:1;background:#0003}.gantt-bar.resizing{opacity:1;cursor:ew-resize}.gantt-section{position:relative;border-bottom:2px solid var(--border)}.gantt-month-header{position:sticky;top:0;z-index:10;height:22px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;flex-direction:row}.gantt-month-cell{flex-shrink:0;height:100%;border-left:1px solid var(--border);position:relative;overflow:hidden}.gantt-month-cell.alt-month{background:var(--month-alt-bg)}.gantt-month-text{position:absolute;top:50%;transform:translate(-50%) translateY(-50%);font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;pointer-events:none}.gantt-date-header{position:sticky;top:22px;z-index:10;height:22px;border-bottom:1px solid var(--border);overflow:hidden;background:var(--surface)}.gantt-date-cell{position:absolute;top:0;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.gantt-date-cell.month-start{border-left:1px solid var(--border)}.gantt-date-text{font-size:11px;color:var(--text-secondary);white-space:nowrap}.gantt-bars-area{position:relative;overflow:hidden}.gantt-month-stripe{position:absolute;top:0;background:var(--month-alt-bg);pointer-events:none}.gantt-row-guide{position:absolute;left:0;border-bottom:1px solid var(--border);opacity:.5}.gantt-row-guide:nth-child(odd){background:var(--gantt-row-alt)}.gantt-col-guide{position:absolute;top:0;width:1px;background:var(--border);opacity:.7}.task-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:12px;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:box-shadow .1s;display:flex;align-items:center;min-height:24px}.task-card:hover{box-shadow:0 1px 4px #00000026;border-color:var(--accent)}.task-card:active{cursor:grabbing}.task-card.completed .task-title{text-decoration:line-through;opacity:.5}.task-card.dragging{box-shadow:0 4px 12px #0003}.task-card.ghost{opacity:.9;box-shadow:0 4px 12px #00000040;cursor:grabbing}.task-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.task-day-label{font-size:10px;color:var(--text-secondary);white-space:nowrap;margin-right:4px;flex-shrink:0}.task-dot{display:block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin:auto;flex-shrink:0}.task-card.completed .task-dot{background:var(--text-secondary)}.day-column{display:flex;flex-direction:column;flex-shrink:0;flex:0 0 auto;align-self:stretch;border-right:1px solid var(--border);position:relative}.day-column.alt-month{background:var(--month-alt-bg)}.day-column.alt-week{background:var(--week-alt-bg)}.day-column.today{background:var(--today-bg)}.day-column.drop-over{background:var(--drop-over-bg)}.day-header{height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--text-secondary);border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:24px;z-index:5;background:var(--surface)}.day-header.today-header{color:var(--accent);font-weight:700}.day-tasks{flex:1;padding:2px;display:flex;flex-direction:column;gap:2px;min-height:60px;position:relative}.day-add-hint{align-self:center;width:20px;height:20px;border-radius:50%;background:var(--hover);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;opacity:0;transition:opacity .15s;flex-shrink:0;margin-top:2px}.day-column:hover .day-add-hint{opacity:1}.day-add-hint:hover{background:var(--accent);color:#fff}.week-column{display:flex;flex-direction:column;flex-shrink:0;align-self:stretch;border-right:1px solid var(--border);position:relative}.week-column.alt-month{background:var(--month-alt-bg)}.week-column.drop-over{background:var(--drop-over-bg)}.week-column.current-week{background:var(--today-bg)}.week-col-header{height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--text-secondary);border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:0;z-index:5;background:var(--surface);isolation:isolate}.week-col-header.current-week-header{color:var(--accent);font-weight:700}.week-col-header.clickable{cursor:pointer}.week-col-header.clickable:hover{color:var(--accent);background:var(--hover)}.week-col-tasks{flex:1;padding:2px;display:flex;flex-direction:column;gap:2px;min-height:60px;position:relative}.week-add-hint{align-self:center;width:20px;height:20px;border-radius:50%;background:var(--hover);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;opacity:0;transition:opacity .15s;flex-shrink:0;margin-top:2px}.week-column:hover .week-add-hint{opacity:1}.week-add-hint:hover{background:var(--accent);color:#fff}.todo-section{display:flex;flex-direction:column;flex:1;min-height:100%;border-top:1px solid var(--border)}.week-header-row{display:flex;flex-direction:row;flex-shrink:0;position:sticky;top:0;z-index:6;background:var(--surface)}.week-header-cell.alt-month{background-image:linear-gradient(var(--month-alt-bg),var(--month-alt-bg))}.week-header-cell.alt-week{background-image:linear-gradient(var(--week-alt-bg),var(--week-alt-bg))}.week-header-cell{flex-shrink:0;height:24px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-secondary);border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);box-sizing:border-box;position:relative;z-index:6}.day-columns-row{display:flex;flex-direction:row;align-items:stretch;flex:1;min-height:200px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--surface);border-radius:8px;padding:20px;width:400px;max-width:90vw;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:14px}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:16px;font-weight:600}.modal-date{font-size:12px;color:var(--text-secondary);margin-top:2px;display:block}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-secondary);line-height:1;padding:0 4px}.modal-close:hover{color:var(--text-primary)}.modal-field{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary)}.modal-field input,.modal-field textarea{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:14px;color:var(--text-primary);font-family:inherit;resize:vertical}.modal-field input:focus,.modal-field textarea:focus{outline:none;border-color:var(--accent)}.modal-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.modal-actions{display:flex;gap:8px;align-items:center;margin-top:4px}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:6px 16px;font-size:13px;cursor:pointer;font-weight:500}.btn-primary:hover{opacity:.85}.btn-secondary{background:var(--hover);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;padding:6px 14px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:var(--border)}.btn-danger{background:none;color:var(--danger);border:1px solid var(--danger);border-radius:4px;padding:6px 14px;font-size:13px;cursor:pointer}.btn-danger:hover{background:var(--danger);color:#fff}.modal-field input[type=date]{cursor:pointer}.modal-field input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(40%) sepia(100%) saturate(500%) hue-rotate(190deg) brightness(120%);opacity:1;width:16px;height:16px}.phase-dates{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text-primary);transform:scale(1.1)}.color-custom{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);padding:0;cursor:pointer;background:none}.about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.about-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:360px;display:flex;flex-direction:column;gap:12px}.about-title{font-size:22px;font-weight:700;color:var(--text-primary)}.about-version{font-size:12px;color:var(--text-secondary);margin-top:-8px}.about-story{font-size:13px;line-height:1.6;color:var(--text-secondary);margin:4px 0}.about-links a{font-size:13px;color:var(--accent);text-decoration:none}.about-links a:hover{text-decoration:underline}.about-footer{font-size:11px;color:var(--text-secondary);opacity:.5}.about-close{align-self:flex-end;margin-top:8px;background:none;border:1px solid var(--border);border-radius:4px;padding:5px 16px;font-size:12px;color:var(--text-secondary);cursor:pointer}.about-close:hover{border-color:var(--accent);color:var(--accent)}.backlog-panel{flex-shrink:0;border-top:1px solid var(--border);background:var(--surface);display:flex;flex-direction:row;align-items:flex-start;gap:8px;padding:6px 10px;height:116px;transition:background .15s}.backlog-panel.drop-over{background:var(--drop-over-bg)}.backlog-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);white-space:nowrap;flex-shrink:0;padding-top:2px}.backlog-tasks{flex:1;display:flex;flex-direction:row;flex-wrap:wrap;gap:6px;overflow-y:auto;align-content:flex-start}.backlog-tasks::-webkit-scrollbar{width:4px}.backlog-tasks::-webkit-scrollbar-track{background:transparent}.backlog-tasks::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.backlog-tasks .task-card{width:160px;flex-shrink:0}.backlog-empty{font-size:12px;color:var(--text-secondary);opacity:.4;white-space:nowrap}.backlog-add-btn{flex-shrink:0;align-self:flex-start;width:28px;height:28px;background:none;border:1.5px dashed var(--accent);border-radius:6px;font-size:16px;line-height:1;color:var(--accent);cursor:pointer;transition:background .1s,color .1s;display:flex;align-items:center;justify-content:center}.backlog-add-btn:hover{background:var(--accent);color:#fff}
