:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background-color:#f1f5f9;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.page{--bg-card:#fff;--bg-soft:#f8fafc;--bg-soft-2:#f1f5f9;--text-main:#0f172a;--text-secondary:#475569;--line:#dbe3ef;--line-strong:#c6d3e3;--brand:#2563eb;--brand-soft:#e8f0ff;--danger:#be123c;background:radial-gradient(circle at 0 0,#f8fbff 0,#f2f6fb 34%,#eef3f8 100%);flex-direction:column;gap:14px;max-width:1560px;margin:0 auto;padding:18px;display:flex}.header,.control-panel,.toolbar,.report-export{border:1px solid var(--line);background:var(--bg-card);border-radius:14px;box-shadow:0 6px 18px #0f172a0d}.header{justify-content:space-between;align-items:flex-end;gap:12px;padding:14px 16px;display:flex}.header h1{letter-spacing:.2px;color:var(--text-main);margin:0;font-size:27px}.header p{color:var(--text-secondary);margin:5px 0 0;font-size:14px}.header-actions{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.save-state{color:#5b6b82;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:2px;padding:6px 10px;font-size:12px;display:flex}.hidden-file-input{display:none}.export-width{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:12px;display:flex}.export-width input{width:104px}.export-btn,.secondary-btn,.danger-btn,.control-panel button,.row-actions button,.delete-bar-btn{border:1px solid var(--line-strong);color:var(--text-main);cursor:pointer;background:#fff;border-radius:10px;font-weight:500;transition:all .18s}.export-btn:focus-visible,.secondary-btn:focus-visible,.danger-btn:focus-visible,.control-panel button:focus-visible,.row-actions button:focus-visible,.delete-bar-btn:focus-visible{outline-offset:1px;outline:2px solid #93c5fd}.export-btn:hover,.secondary-btn:hover,.danger-btn:hover,.control-panel button:hover,.row-actions button:hover,.delete-bar-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #0f172a14}.export-btn{color:#fff;background:linear-gradient(#3b82f6,#2563eb);border-color:#2158ce;padding:8px 12px}.export-btn:disabled{opacity:.64;cursor:not-allowed;box-shadow:none;transform:none}.secondary-btn{background:var(--bg-soft);padding:8px 12px}.secondary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.danger-btn{color:var(--danger);background:#fff1f2;border-color:#fecdd3;padding:8px 12px}.control-panel{background:linear-gradient(#fff,#fbfdff);grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:12px;padding:14px;display:grid}.mode-banner{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:8px 12px;font-size:13px}.control-panel label{color:#5b6b82;flex-direction:column;gap:6px;font-size:12px;font-weight:500;display:flex}.control-panel input,.control-panel select,.control-panel button,.progress-editor input[type=number],.export-width input{border:1px solid var(--line-strong);background:#fff;border-radius:10px;padding:8px 10px;font-size:14px}.control-panel input:focus,.control-panel select:focus,.progress-editor input:focus,.export-width input:focus{outline-offset:1px;outline:2px solid #bfdbfe}.control-panel button{background:var(--bg-soft);align-self:end;font-size:13px}.template-hint{color:#446287;background:#f7fbff;border:1px dashed #bfd1e7;border-radius:10px;align-self:end;padding:8px 10px;font-size:12px}.report-export{overflow:hidden}.report-title{color:var(--text-main);padding:14px 14px 4px;font-size:18px;font-weight:600}.board{border-top:1px solid var(--line);background:#fff;overflow:auto}.board::-webkit-scrollbar{width:10px;height:10px}.board::-webkit-scrollbar-thumb{background:#c5d1df;border-radius:999px}.board.is-dragging{cursor:grabbing}.board-header,.row{display:flex}.board-header{z-index:6;position:sticky;top:0;box-shadow:0 2px 6px #0f172a0f}.sidebar-header,.row-side{box-sizing:border-box;border-right:1px solid var(--line);background:var(--bg-soft);z-index:4;width:230px;padding:10px 12px;position:sticky;left:0}.timeline,.row-grid{grid-auto-columns:46px;grid-auto-flow:column;display:grid}.tick{border-right:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;color:#42526a;background:var(--bg-soft);padding:10px 4px;font-size:12px}.row-side{justify-content:space-between;align-items:center;gap:8px;height:52px;display:flex}.group-row-side{background:#edf4ff}.row-side strong{font-size:14px}.row-name{align-items:center;gap:6px;min-width:0;display:flex}.row-depth-1{margin-left:18px}.group-row-name strong{color:#1d4ed8}.group-summary-chip{color:#1e3a8a;background:#dbeafe;border:1px solid #bfdbfe;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;display:inline-flex}.collapse-btn{border:1px solid var(--line);color:#1d4ed8;cursor:pointer;background:#fff;border-radius:6px;width:18px;height:18px;padding:0;font-size:11px;line-height:1}.row-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;display:flex}.row-actions button{background:#fff;border-color:#d3dfeb;padding:4px 8px;font-size:11px}.row-grid{height:52px;position:relative}.grid-cell{border:none;border-right:1px solid #eef3f9;border-bottom:1px solid var(--line);background:0 0;margin:0;padding:0}.grid-cell:hover{background:#eaf3ff}.disabled-cell,.disabled-cell:hover{cursor:not-allowed;background:#f8fbff}.task-bar{color:#fff;-webkit-user-select:none;user-select:none;cursor:grab;z-index:2;border-radius:10px;justify-content:space-between;align-items:center;font-size:12px;display:flex;position:absolute;top:9px;overflow:visible;box-shadow:0 4px 12px #0f172a38}.task-bar.selected{outline-offset:1px;outline:2px solid #0f172a}.task-progress-fill{border-radius:inherit;z-index:0;background:#ffffff59;position:absolute;top:0;bottom:0;left:0}.task-progress-badge{color:#fff;z-index:4;background:#0f172a;border-radius:999px;padding:2px 6px;font-size:10px;line-height:1;position:absolute;top:-10px;right:-8px}.task-bar span{pointer-events:none}.task-title{white-space:nowrap;text-shadow:0 1px 2px #00000059;z-index:2;padding:0 8px;line-height:1.1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.task-title.mode-edge{text-align:left;top:50%;left:10px;transform:translateY(-50%)}.task-title.mode-center{text-align:center;top:50%;left:50%;transform:translate(-50%,-50%)}.task-title.mode-wrap{white-space:normal;text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;top:50%;left:8px;right:8px;overflow:hidden;transform:translateY(-50%)}.resize-handle{cursor:ew-resize;z-index:3;opacity:.9;width:10px;height:100%;position:relative}.resize-handle:after{content:"";background:#fffc;border-radius:999px;width:2px;position:absolute;top:20%;bottom:20%;left:50%;transform:translate(-50%)}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;display:flex}.progress-editor{align-items:center;gap:8px;margin-left:12px;display:flex}.progress-editor label{color:#475569;font-size:13px}.progress-editor input[type=range]{width:140px}.progress-editor input[type=number]{width:62px;padding:4px 6px}.color-dot{cursor:pointer;border:2px solid #e2e8f0;border-radius:999px;width:24px;height:24px}.color-dot.active{border-color:#0f172a;transform:scale(1.08)}.delete-bar-btn{margin-left:auto;padding:6px 10px}.report-export.exporting .row-actions,.report-export.exporting .collapse-btn,.report-export.exporting .resize-handle,.report-export.clean-mode .row-actions,.report-export.clean-mode .collapse-btn,.report-export.clean-mode .resize-handle{display:none!important}.report-export.exporting .row-side,.report-export.clean-mode .row-side{justify-content:flex-start}.guide-mask{z-index:300;background:#0f172a7a;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.guide-modal{border:1px solid var(--line);background:#fff;border-radius:16px;width:min(560px,100vw - 32px);padding:20px;box-shadow:0 24px 44px #0f172a40}.guide-modal h2{color:var(--text-main);margin:0 0 10px;font-size:20px}.guide-modal ol{color:#334155;margin:0;padding-left:20px;line-height:1.7}.guide-actions{justify-content:flex-end;margin-top:14px;display:flex}@media (width<=960px){.header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.control-panel{grid-template-columns:repeat(2,minmax(150px,1fr))}.row-actions{max-width:140px}}
