*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;font-family:system-ui,sans-serif;color:#1a1a1a;background:#f5f5f5}#root{height:100%}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;font-family:system-ui,sans-serif;font-size:14px;background:#f5f5f5}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:320px;min-width:220px;display:flex;flex-direction:column;border-right:1px solid #ddd;background:#fff;overflow:hidden}.panel{display:flex;flex-direction:column;flex:1 1 0;min-height:80px;border-bottom:1px solid #e0e0e0;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fafafa;border-bottom:1px solid #eee;flex-shrink:0}.panel-header h2{margin:0;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#555}.panel-list{overflow-y:auto;padding:4px 0;flex:1 1 0}.panel-item{display:flex;align-items:center;gap:6px;padding:4px 12px;min-height:32px;flex-wrap:nowrap}.panel-item:hover{background:#f8f8f8}.item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.color-swatch{display:inline-block;width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.15);flex-shrink:0}.complexity-badge{background:#e8e8e8;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600;color:#555;flex-shrink:0}.dep-ids{font-size:11px;color:#888;flex-shrink:0}.empty-hint{color:#aaa;font-size:12px;padding:8px 12px;margin:0}button{padding:3px 9px;font-size:12px;cursor:pointer;border:1px solid #ccc;border-radius:4px;background:#fff;flex-shrink:0}button:hover{background:#f0f0f0}button:disabled{opacity:.4;cursor:default}.panel-item input[type=color]{width:22px;height:22px;padding:0;border:none;cursor:pointer;flex-shrink:0}.chart-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.chart-config{display:flex;align-items:center;gap:24px;padding:8px 16px;border-bottom:1px solid #ddd;background:#fff;flex-shrink:0}.config-item{display:flex;align-items:center;gap:6px;font-size:13px}.mode-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;letter-spacing:.04em}.mode-api{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.mode-local{background:#e0e7ff;color:#3730a3;border:1px solid #a5b4fc}.save-error{font-size:12px;color:#dc2626;cursor:help}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:#666}.loading-screen.error{color:#dc2626}.chart-scroll{flex:1;overflow-x:auto;overflow-y:auto;padding:16px;background:#f9f9f9}.gantt-container{display:inline-block;min-width:100%}.empty-gantt{display:flex;align-items:center;justify-content:center;height:200px;color:#aaa;font-size:14px}.dialog-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:#fff;border-radius:10px;min-width:340px;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;padding:24px;gap:12px}.task-dialog{min-width:480px;max-width:560px;padding:0;gap:0;overflow:hidden}.task-dialog--split{min-width:800px;max-width:900px}.task-dialog-header{padding:18px 24px 14px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.task-dialog-header h3{margin:0;font-size:16px;font-weight:600;color:#111827}.task-dialog-content{display:flex;flex:1;overflow:hidden;min-height:0}.task-split-left{flex:1;padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;max-height:65vh;min-height:300px}.task-split-right{width:300px;flex-shrink:0;border-left:1px solid #e5e7eb;background:#fafafa;display:flex;flex-direction:column;max-height:65vh;min-height:300px}.comments-header{display:flex;align-items:center;gap:8px;padding:14px 16px 10px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.comments-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.comments-count{background:#e5e7eb;color:#374151;font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px}.task-dialog-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;max-height:65vh}.field-row{display:flex;gap:12px;align-items:flex-end}.field-grow{flex:1}.field-narrow{flex:0 0 100px}.field-id{flex:0 0 48px}.field-id input{min-width:0;width:100%}.field-complexity{flex:0 0 85px}.dialog label,.task-dialog-body label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;color:#374151}.dialog label span,.task-dialog-body label span{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.03em}.dialog label input,.dialog label select,.dialog label textarea,.task-dialog-body input,.task-dialog-body select,.task-dialog-body textarea{padding:7px 9px;border:1px solid #d1d5db;border-radius:5px;font-size:13px;font-family:inherit;color:#111827;background:#fff;transition:border-color .15s}.dialog label input:focus,.dialog label select:focus,.dialog label textarea:focus,.task-dialog-body input:focus,.task-dialog-body select:focus,.task-dialog-body textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1f}.dialog label input[type=color]{height:36px;padding:2px}.dialog label input:disabled,.task-dialog-body input:disabled{background:#f3f4f6;color:#6b7280}.task-dialog-body fieldset{border:1px solid #e5e7eb;border-radius:6px;padding:10px 14px;margin:0}.task-dialog-body fieldset legend{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;padding:0 4px}.dialog fieldset{border:1px solid #e5e7eb;border-radius:6px;padding:10px 14px}.dialog fieldset legend{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;padding:0 4px}.dep-group-label{margin:6px 0 2px;font-size:11px;font-weight:600;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;font-weight:400!important;font-size:13px!important;color:#374151!important;padding:3px 0;text-transform:none!important;letter-spacing:0!important}.comments-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:12px 16px}.comment-item{border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px;background:#f9fafb;display:flex;flex-direction:column;gap:6px}.comment-meta{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.comment-author{font-size:12px;font-weight:600;color:#374151}.comment-dates{font-size:11px;color:#9ca3af;white-space:nowrap}.comment-body{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.comment-text{font-size:13px;color:#111827;white-space:pre-wrap;flex:1;line-height:1.5}.comment-actions{display:flex;gap:4px;flex-shrink:0;align-items:center}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:3px 6px;color:#6b7280;border:1px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;line-height:1;flex-shrink:0}.icon-btn:hover{color:#111827;border-color:#9ca3af;background:#f3f4f6}.icon-btn--danger:hover{color:#dc2626;border-color:#fca5a5;background:#fef2f2}.comment-edit{display:flex;flex-direction:column;gap:6px}.comment-edit textarea{resize:vertical}.comment-edit-actions{display:flex;gap:6px;justify-content:flex-end}.comment-edit-actions button{font-size:12px;padding:4px 12px}.comment-new{display:flex;flex-direction:column;gap:6px;padding:10px 16px 12px;border-top:1px solid #e5e7eb;background:#fafafa;flex-shrink:0}.comment-new select{padding:6px 8px;border:1px solid #d1d5db;border-radius:5px;font-size:12px;font-family:inherit;background:#fff}.comment-new textarea{resize:none;padding:6px 8px;border:1px solid #d1d5db;border-radius:5px;font-size:12px;font-family:inherit}.comment-add-btn{align-self:flex-end;font-size:12px;padding:5px 14px;background:#2563eb;color:#fff;border:none;border-radius:5px;cursor:pointer}.comment-add-btn:hover:not(:disabled){background:#1d4ed8}.comment-add-btn:disabled{background:#93c5fd;border-color:#93c5fd;cursor:not-allowed}.empty-hint{font-size:12px;color:#9ca3af;margin:4px 0;font-style:italic}.task-dialog-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 24px;border-top:1px solid #f0f0f0;background:#fafafa;border-radius:0 0 10px 10px}.task-dialog-footer button{padding:7px 18px;font-size:13px;border-radius:5px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer}.task-dialog-footer button:hover{background:#f3f4f6}.task-dialog-footer .btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.task-dialog-footer .btn-primary:hover{background:#1d4ed8}.task-dialog-footer .btn-primary:disabled{background:#93c5fd;border-color:#93c5fd;cursor:not-allowed}.dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.dialog-actions button{padding:6px 16px;font-size:13px}.dialog-actions button:last-child{background:#2563eb;color:#fff;border-color:#2563eb}.dialog-actions button:last-child:hover:not(:disabled){background:#1d4ed8}.dialog-actions button:last-child:disabled{background:#93c5fd;border-color:#93c5fd;cursor:not-allowed}
