*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{color:#1e293b;-webkit-font-smoothing:antialiased;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}body{height:100vh;margin:0;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex}button{cursor:pointer;font-family:inherit}input{font-family:inherit}:root{--c-primary:#4f46e5;--c-primary-d:#4338ca;--c-bg:#f8fafc;--c-surface:#fff;--c-border:#e2e8f0;--c-text:#1e293b;--c-muted:#64748b;--c-sec-bg:#eef2ff;--c-sec-bdr:#c7d2fe;--header-h:48px}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-main{background:var(--c-bg);flex:1;display:flex;overflow:hidden}.pane{flex-direction:column;display:flex;overflow:hidden}.pane-visual{flex:1;min-width:0}.pane-text{border-left:1px solid var(--c-border);flex-shrink:0;width:360px}.pane-full{flex:1}.app-header{height:var(--header-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:12px;padding:0 14px;display:flex;box-shadow:0 1px 3px #0000000f}.header-brand{color:var(--c-primary);white-space:nowrap;align-items:center;gap:7px;font-size:14px;font-weight:700;display:flex}.header-file-ops{gap:5px;display:flex}.header-file-ops button{border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text);border-radius:6px;padding:4px 11px;font-size:13px;transition:background .12s}.header-file-ops button:hover{background:#f1f5f9}.header-file-ops .btn-save{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.header-file-ops .btn-save:hover{background:var(--c-primary-d)}.header-tabs{gap:3px;margin-left:auto;display:flex}.tab-btn{border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-muted);border-radius:6px;padding:4px 12px;font-size:13px;transition:all .12s}.tab-btn:hover{color:var(--c-text);background:#f1f5f9}.tab-btn.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-install{color:var(--c-primary);background:#eef2ff;border:1px solid #a5b4fc;border-radius:6px;align-items:center;gap:5px;margin-left:6px;padding:4px 12px;font-size:13px;font-weight:600;transition:all .12s;display:flex}.btn-install:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.drop-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;border:3px dashed var(--c-primary);background:#4f46e51f;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-hint{border:2px dashed var(--c-primary);color:var(--c-primary);background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:36px 52px;display:flex;box-shadow:0 8px 32px #4f46e52e}.drop-hint svg{opacity:.85}.drop-hint span{font-size:18px;font-weight:700}.drop-hint small{color:var(--c-muted);font-size:12px;font-weight:400}.panel-header{border-bottom:1px solid var(--c-border);color:var(--c-muted);background:#f1f5f9;flex-shrink:0;align-items:center;gap:10px;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.panel-hint{font-size:11px;font-weight:400}.gantt-editor{background:var(--c-surface);flex-direction:column;height:100%;display:flex}.gantt-titlebar{border-bottom:1px solid var(--c-border);background:#f8fafc;flex-shrink:0;align-items:center;gap:10px;padding:7px 12px;display:flex}.gantt-title-input{border:1px solid var(--c-border);max-width:340px;color:var(--c-text);background:#fff;border-radius:6px;flex:1;padding:4px 9px;font-size:14px;font-weight:600}.gantt-title-input:focus{border-color:var(--c-primary);outline:none;box-shadow:0 0 0 2px #4f46e526}.btn-add-section{border:1px dashed var(--c-primary);color:var(--c-primary);background:0 0;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500}.btn-add-section:hover{background:#4f46e50f}.gantt-scroll{flex:1;position:relative;overflow:auto}.gantt-inner{min-height:100%;display:inline-block;position:relative}.gantt-header{z-index:20;background:var(--c-surface);border-bottom:2px solid var(--c-border);display:flex;position:sticky;top:0}.cell-corner{border-right:2px solid var(--c-border);z-index:30;background:#f1f5f9;flex-shrink:0;position:sticky;left:0}.header-timeline{flex-shrink:0;overflow:hidden}.months-row,.days-row{width:100%;position:relative}.month-cell{color:var(--c-muted);border-right:1px solid var(--c-border);white-space:nowrap;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;position:absolute;top:0;bottom:0;overflow:hidden}.day-cell{color:#94a3b8;border-right:1px solid #f0f0f0;justify-content:center;align-items:center;font-size:10px;display:flex;position:absolute;top:0;bottom:0}.day-cell.is-weekend{color:#b0b8c8;background:#fafafa}.day-cell.is-today{color:var(--c-primary);background:#eef2ff;font-weight:700}.today-line{opacity:.55;pointer-events:none;z-index:8;background:#ef4444;width:2px;position:absolute;bottom:0}.cell-label{z-index:10;border-right:2px solid var(--c-border);background:#f8fafc;flex-shrink:0;position:sticky;left:0}.cell-timeline{flex-shrink:0;position:relative}.section-hdr-row{display:flex}.cell-sec-hdr{background:var(--c-sec-bg);border-bottom:1px solid var(--c-sec-bdr);align-items:center;gap:6px;height:32px;padding:4px 8px;display:flex}.sec-name-input{color:var(--c-primary);background:0 0;border:none;border-radius:3px;flex:1;min-width:0;padding:2px 3px;font-size:12px;font-weight:700}.sec-name-input:focus{box-shadow:0 0 0 1px var(--c-primary);background:#fff;outline:none}.sec-bg{background:var(--c-sec-bg);border-bottom:1px solid var(--c-sec-bdr);height:32px}.sec-actions{flex-shrink:0;gap:3px;display:flex}.sec-actions button{border:1px solid var(--c-border);width:20px;height:20px;color:var(--c-muted);background:#fff;border-radius:4px;justify-content:center;align-items:center;font-size:12px;line-height:1;transition:all .1s;display:flex}.sec-actions button:hover{color:var(--c-text);background:#f1f5f9}.task-row{display:flex}.gantt-section .task-row:last-child{border-bottom:1px solid var(--c-border)}.cell-task-lbl{cursor:pointer;border-bottom:1px solid #f0f4f8;align-items:center;padding:0 10px;font-size:12px;transition:background .1s;display:flex;overflow:hidden}.cell-task-lbl:hover{background:#f0f4ff}.cell-task-lbl span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.task-timeline{border-bottom:1px solid #f0f4f8;overflow:visible}.weekend-strip{pointer-events:none;background:#00000005;position:absolute;top:0;bottom:0}.task-bar{cursor:grab;-webkit-user-select:none;user-select:none;border-radius:4px;align-items:center;transition:box-shadow .1s,filter .1s;display:flex;position:absolute;overflow:hidden;box-shadow:0 1px 3px #0000002e}.task-bar:hover{filter:brightness(1.06);box-shadow:0 2px 8px #00000038}.task-bar:active{cursor:grabbing}.bar-label{color:#fff;white-space:nowrap;text-overflow:ellipsis;pointer-events:none;flex:1;padding:0 7px;font-size:11px;overflow:hidden}.resize-handle{opacity:0;cursor:col-resize;background:#0000002e;flex-shrink:0;width:7px;height:100%;transition:opacity .15s}.task-bar:hover .resize-handle{opacity:1}.resize-l{border-radius:4px 0 0 4px}.resize-r{border-radius:0 4px 4px 0}.milestone-bar{cursor:pointer;border-radius:3px;transform:rotate(45deg);box-shadow:0 1px 4px #0003;width:18px!important;height:18px!important}.milestone-bar:hover{filter:brightness(1.1)}.empty-section{height:36px;display:flex}.empty-hint{color:#94a3b8;cursor:pointer;align-items:center;padding:0 14px;font-size:12px;font-style:italic;display:flex}.empty-hint:hover{color:var(--c-primary)}.text-editor{flex-direction:column;height:100%;display:flex}.text-area{resize:none;color:#cdd6f4;tab-size:4;background:#1e1e2e;border:none;outline:none;flex:1;padding:12px 14px;font-family:Consolas,Monaco,Courier New,monospace;font-size:12.5px;line-height:1.65}.mermaid-preview{background:var(--c-surface);flex-direction:column;height:100%;display:flex}.preview-body{flex:1;padding:20px;overflow:auto}.preview-svg{justify-content:center;display:flex}.preview-svg svg{max-width:100%;height:auto}.preview-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:12px;padding:14px 16px;font-size:12px}.preview-error strong{margin-bottom:6px;display:block}.preview-error pre{white-space:pre-wrap;word-break:break-word}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:12px;width:420px;max-width:95vw;padding:22px 24px;box-shadow:0 20px 60px #00000038}.modal-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.modal-header h3{color:var(--c-text);font-size:15px;font-weight:700}.modal-close{color:var(--c-muted);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px}.modal-close:hover{color:var(--c-text);background:#f1f5f9}.modal-box form{flex-direction:column;gap:13px;display:flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--c-muted);font-size:12px;font-weight:600}.form-group input[type=text],.form-group input[type=date],.form-group input:not([type]){border:1px solid var(--c-border);color:var(--c-text);background:#fff;border-radius:6px;padding:6px 10px;font-size:13px}.form-group input:focus{border-color:var(--c-primary);outline:none;box-shadow:0 0 0 2px #4f46e526}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.modifier-chips{flex-wrap:wrap;gap:6px;display:flex}.modifier-chip{border:1px solid var(--c-border);color:var(--c-text);background:#fff;border-radius:20px;padding:3px 11px;font-size:12px;font-weight:500;transition:all .12s}.modifier-chip:hover{border-color:#94a3b8}.modifier-chip.active{color:#fff}.modal-actions{align-items:center;margin-top:4px;display:flex}.btn-primary,.btn-secondary,.btn-danger{border:1px solid;border-radius:6px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .12s}.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-primary:hover{background:var(--c-primary-d)}.btn-secondary{color:var(--c-text);border-color:var(--c-border);background:#fff}.btn-secondary:hover{background:#f1f5f9}.btn-danger{color:#ef4444;background:#fff;border-color:#fca5a5}.btn-danger:hover{background:#fef2f2}
