:root{--bg: #ffffff;--bg-sidebar: #fafafa;--bg-hover: #f5f5f5;--bg-soft: #f9f9f9;--bg-tint: #fbfbfa;--border: #e5e5e5;--border-soft: #eeeeee;--border-strong: #d1d1d1;--text-1: #202020;--text-2: #555555;--text-3: #808080;--text-4: #a8a8a8;--text-disabled: #bcbcbc;--accent: #dc4c3e;--accent-hover: #c4392d;--accent-soft: #fdebe9;--accent-tint: #fef5f4;--done: #058527;--done-soft: #e6f3ea;--locked: #c4c4c4;--locked-soft: #f0f0f0;--goal: #b8860b;--goal-soft: #fbf3e0;--warn: #d99326;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .1);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", ui-monospace, "JetBrains Mono", Menlo, Consolas, "Roboto Mono", monospace;--radius-sm: 4px;--radius: 6px;--radius-lg: 8px;--sidebar-w: 260px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text-1);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior:none;letter-spacing:-.005em}::selection{background:var(--accent-soft);color:var(--text-1)}button,input,textarea,select{font:inherit;color:inherit}button{background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-sans)}input,textarea{background:#fff;border:1px solid var(--border);color:var(--text-1);padding:7px 10px;border-radius:var(--radius-sm);outline:none;transition:border-color .12s,box-shadow .12s;font-family:var(--font-sans)}input:hover,textarea:hover{border-color:var(--border-strong)}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea{resize:vertical;min-height:64px;line-height:1.55}.app{display:flex;height:100vh;height:100dvh;position:relative;overflow:hidden}.sidebar{flex:0 0 var(--sidebar-w);width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.brand{padding:16px 18px 12px;display:flex;align-items:center;gap:10px}.brand-mark{width:28px;height:28px;border-radius:6px;background:var(--text-1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;letter-spacing:-.02em}.brand-name{font-weight:600;font-size:15px;color:var(--text-1);letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--text-3);margin-top:1px}.module-switcher{margin:4px 12px 14px;display:grid;grid-template-columns:1fr 1fr;gap:4px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);padding:4px;position:relative}.module-switcher button{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:3px;padding:8px 10px;border-radius:5px;color:var(--text-2);letter-spacing:-.005em;transition:background-color .12s,color .12s,box-shadow .12s;text-align:left;min-height:48px;position:relative}.module-switcher button:not(.disabled):hover{background:#00000008;color:var(--text-1)}.module-switcher button.active{background:#fff;color:var(--text-1);box-shadow:var(--shadow-sm)}.module-switcher .ring-name{font-size:13px;font-weight:600;letter-spacing:-.005em;line-height:1.2}.module-switcher .ring-label{font-size:10.5px;color:var(--text-4);letter-spacing:.08em;font-weight:500;line-height:1.1;display:inline-flex;align-items:center;gap:4px}.module-switcher .ring-num{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px;font-size:10px;color:var(--text-4);letter-spacing:0;line-height:1}.module-switcher button.active .ring-label,.module-switcher button.active .ring-num{color:var(--accent)}.module-switcher button.disabled{cursor:default;color:var(--text-4)}.module-switcher button.disabled .ring-name{color:var(--text-4)}.module-switcher button.disabled .ring-label:after{content:" · 待开发";color:var(--text-4)}.module-switcher .ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:50%;color:var(--text-3);pointer-events:none;z-index:1;font-size:13px;line-height:1;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.side-section{padding:0 12px;margin-top:8px}.side-section-head{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 6px;color:var(--text-3);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.side-section-head .add{width:20px;height:20px;border-radius:4px;color:var(--text-3);display:flex;align-items:center;justify-content:center}.side-section-head .add:hover{color:var(--accent);background:var(--accent-tint)}.side-section-head .add svg{width:12px;height:12px}.side-list{display:flex;flex-direction:column;gap:1px}.side-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:5px;font-size:14px;color:var(--text-1);cursor:pointer;transition:background-color .1s;min-height:32px}.side-item:hover{background:var(--bg-hover)}.side-item.active{background:#efece8;font-weight:500}.side-item .swatch{width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:var(--text-4)}.side-item .label{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;letter-spacing:-.005em}.side-item .count{flex:0 0 auto;font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.side-item.editing input{flex:1 1 auto;border:1px solid var(--accent);box-shadow:0 0 0 3px var(--accent-soft);padding:3px 6px;border-radius:4px;font-size:14px}.side-item .item-action{width:18px;height:18px;border-radius:3px;color:var(--text-3);display:none;align-items:center;justify-content:center}.side-item:hover .item-action{display:flex}.side-item .item-action:hover{color:var(--accent);background:var(--accent-tint)}.side-item .item-action svg{width:11px;height:11px}.side-spacer{flex:1 1 auto}.side-data{display:flex;gap:6px;padding:8px 14px 0}.side-data-btn{flex:1 1 0;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:6px 8px;font-size:12px;font-weight:500;color:var(--text-2);background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .12s,color .12s,background-color .12s}.side-data-btn:hover{border-color:var(--border-strong);color:var(--text-1);background:var(--bg-hover)}.side-footer{padding:12px 14px 14px;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-3);margin-top:10px}.side-footer .pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:#fff;border:1px solid var(--border-soft);border-radius:999px;font-size:11px;color:var(--text-3)}.side-footer .pill .dot{width:6px;height:6px;border-radius:50%;background:var(--done)}.main{flex:1 1 auto;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);min-width:0}.main-header{flex:0 0 auto;padding:18px 32px 14px;border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.main-title-row{display:flex;align-items:center;gap:10px;min-width:0}.main-title{font-size:22px;font-weight:700;color:var(--text-1);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-title input{font-size:22px;font-weight:700;letter-spacing:-.02em;padding:2px 6px;border:1px solid var(--accent);box-shadow:0 0 0 3px var(--accent-soft);border-radius:4px;min-width:200px}.main-subtitle{font-size:12.5px;color:var(--text-3);margin-top:4px;display:flex;gap:14px;align-items:center}.main-subtitle .meta-stat{display:inline-flex;align-items:center;gap:5px}.main-subtitle button.meta-stat{font:inherit;color:var(--text-3);cursor:pointer;padding:2px 9px;border-radius:999px;border:1px solid transparent;transition:background-color .12s,border-color .12s,color .12s}.main-subtitle button.meta-stat:hover{background:var(--bg-soft);color:var(--text-1)}.main-subtitle button.meta-stat.is-active{background:var(--bg-soft);border-color:var(--border);color:var(--text-1);font-weight:600}.main-subtitle button.meta-stat.done.is-active{background:var(--done-soft);border-color:#05852740;color:var(--done)}.main-subtitle button.meta-stat.active.is-active{background:var(--accent-tint);border-color:#dc4c3e40;color:var(--accent)}.main-subtitle button.meta-stat.goal.is-active{background:var(--goal-soft);border-color:#b8860b4d;color:var(--goal)}.main-subtitle .filter-clear{font:inherit;font-size:12px;color:var(--accent);cursor:pointer;padding:2px 8px;border-radius:999px;border:1px solid var(--accent-soft);background:var(--accent-tint)}.main-subtitle .filter-clear:hover{background:var(--accent-soft)}.main-subtitle .meta-stat .dot{width:6px;height:6px;border-radius:50%;background:var(--locked)}.main-subtitle .meta-stat.done .dot{background:var(--done)}.main-subtitle .meta-stat.active .dot{background:var(--accent)}.main-subtitle .meta-stat.goal .dot{background:transparent;border:1.5px solid var(--goal);width:8px;height:8px}.main-subtitle .archive-pill{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--text-1);padding:3px 8px;border-radius:5px;border:1px solid var(--border-soft);background:var(--bg-soft);cursor:pointer;transition:background-color .12s,border-color .12s;letter-spacing:-.005em}.main-subtitle .archive-pill:hover{background:#fff;border-color:var(--border-strong)}.main-subtitle .archive-pill .swatch{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.main-actions{flex:0 0 auto;display:flex;gap:8px;align-items:center}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background-color .1s,color .1s,border-color .1s,box-shadow .1s;cursor:pointer;border:1px solid transparent;white-space:nowrap}.btn svg{width:13px;height:13px;flex:0 0 auto}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-1)}.btn-outline{background:#fff;color:var(--text-2);border-color:var(--border)}.btn-outline:hover{border-color:var(--border-strong);color:var(--text-1)}.btn-danger{color:var(--accent)}.btn-danger:hover{background:var(--accent-tint)}.canvas{flex:1 1 auto;overflow:auto;position:relative}.diagram{position:relative;padding:24px 0 200px;min-height:100%}.diagram-rail{position:absolute;left:0;top:0;height:100%;pointer-events:none;z-index:1}.diagram-rail .track{fill:none;stroke:#d4d4d4;stroke-width:1.75;stroke-dasharray:4 4;transition:stroke .15s,opacity .15s}.diagram-rail .track.done{stroke:var(--done);stroke-dasharray:none;stroke-width:1.75}.diagram-rail .track.highlight{stroke:var(--accent);stroke-dasharray:none;stroke-width:2}.diagram-rail .track.done.highlight{stroke:var(--done);stroke-width:2.25}.diagram-rail .dot{fill:#fff;stroke:#c8c8c8;stroke-width:1.5}.diagram-rail .dot.done{fill:var(--done);stroke:var(--done)}.diagram-rail .dot.active{fill:#fff;stroke:var(--accent);stroke-width:2}.diagram-rail .dot.goal{fill:#fff;stroke:var(--goal);stroke-width:2}.diagram-rail .dot.goal.done{fill:var(--goal);stroke:var(--goal)}.diagram-rail .tail{stroke:#e3e3e3;stroke-width:1.25;fill:none}.diagram-rail .tail.active{stroke:#f5c8c1}.diagram-rail .tail.done{stroke:#b3d6bd}.group-bands{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.group-band{position:absolute;left:0;right:0;border:1px solid var(--border-soft);border-radius:10px}.group-band.is-sub{left:12px;right:12px;border-style:dashed;border-radius:8px}.group-band-label{position:absolute;top:3px;left:12px;display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.02em;padding:1px 9px;border-radius:999px;background:#fff;border:1px solid var(--border-soft);white-space:nowrap}.group-band-label.is-sub{top:2px;left:8px;font-size:10px;padding:0 7px}.node-card{position:absolute;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:pointer;z-index:2;transition:border-color .12s,background-color .12s,box-shadow .15s;display:flex;flex-direction:column;gap:4px}.node-group-bar{position:absolute;left:0;top:0;bottom:0;width:3px;border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius);z-index:1}.group-edit-row{display:flex;align-items:center;gap:8px}.group-edit-swatch{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.group-edit-input{flex:1 1 auto}.node-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.node-card.is-selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.node-card .row-1{display:flex;align-items:center;gap:10px}.status-check{width:18px;height:18px;border-radius:50%;flex:0 0 auto;border:1.5px solid var(--locked);background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;cursor:pointer;position:relative}.status-check:hover{background:var(--bg-hover)}.status-check svg{width:11px;height:11px}.node-card.is-active .status-check{border-color:var(--accent)}.node-card.is-active .status-check:hover{background:var(--accent-tint)}.node-card.is-active .status-check:after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .15s}.node-card.is-active .status-check:hover:after{opacity:1}.node-card.is-done .status-check{border-color:var(--done);background:var(--done);color:#fff}.node-card.is-done .status-check svg{color:#fff;display:block}.node-card.is-locked .status-check{border-color:var(--locked);background:var(--locked-soft);cursor:default}.node-card .title-wrap{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}.node-title{font-size:14.5px;font-weight:500;color:var(--text-1);line-height:1.35;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-card.is-done .node-title{color:var(--text-3);text-decoration:line-through;text-decoration-color:var(--text-4);text-decoration-thickness:1px}.node-card.is-locked .node-title{color:var(--text-3)}.node-note{font-size:12.5px;color:var(--text-3);line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-card.is-locked .node-note{color:var(--text-4)}.node-meta-row{display:flex;align-items:center;gap:10px;margin-top:4px;padding-left:28px}.node-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:999px;font-size:11px;font-weight:500;background:var(--bg-soft);color:var(--text-3);border:1px solid var(--border-soft)}.node-tag.merge{background:#fff;border-color:var(--border);color:var(--text-2)}.node-tag.goal{background:var(--goal-soft);color:var(--goal);border-color:#b8860b40;font-weight:600}.node-tag.active{background:var(--accent-tint);color:var(--accent);border-color:#dc4c3e2e}.node-tag.done{background:var(--done-soft);color:var(--done);border-color:#0585272e}.node-tag .ico{width:9px;height:9px;border-radius:50%;background:currentColor;opacity:.7}.node-hours{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);letter-spacing:-.01em;font-variant-numeric:tabular-nums;margin-left:auto}.node-card.is-active .node-hours{color:var(--text-2)}.node-card.is-done .node-hours{color:var(--done)}.node-progress{height:3px;background:var(--bg-soft);border-radius:2px;overflow:hidden;flex:1 1 auto;min-width:80px;max-width:160px}.node-progress>span{display:block;height:100%;background:var(--accent);border-radius:2px;transition:width .25s,background-color .15s}.node-card.is-done .node-progress>span{background:var(--done)}.node-card.is-locked .node-progress>span{background:var(--locked)}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--text-3);gap:6px;text-align:center;padding:40px}.empty-state h2{font-weight:600;font-size:18px;color:var(--text-1);margin:0}.empty-state p{margin:0;font-size:13.5px;max-width:380px;line-height:1.6}.empty-state .empty-illus{width:56px;height:56px;border:1.5px dashed var(--border-strong);border-radius:12px;margin-bottom:6px;display:flex;align-items:center;justify-content:center;color:var(--text-4)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;z-index:9;opacity:0;pointer-events:none;transition:opacity .2s ease}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;bottom:0;right:0;width:440px;max-width:100vw;background:#fff;border-left:1px solid var(--border);z-index:10;transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000000f}.drawer.open{transform:translate(0)}.drawer-head{padding:16px 20px 14px;border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.drawer-head-main{flex:1 1 auto;min-width:0;display:flex;align-items:flex-start;gap:12px}.drawer-head-main>.status-check{margin-top:5px}.drawer-status-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.drawer-title-edit{display:block;width:100%;font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--text-1);border:1px solid transparent;padding:3px 6px;background:transparent;line-height:1.35;border-radius:4px;margin-left:-6px}.drawer-title-edit:hover{border-color:var(--border)}.drawer-title-edit:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.drawer-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-3);flex:0 0 auto}.drawer-close:hover{color:var(--text-1);background:var(--bg-hover)}.drawer-close svg{width:14px;height:14px}.drawer-body{flex:1 1 auto;overflow-y:auto;padding:16px 20px 28px}.drawer-section+.drawer-section{margin-top:22px}.drawer-section-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.dep-list{display:flex;flex-direction:column;gap:4px}.dep-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);font-size:13px;cursor:pointer;transition:background-color .1s,border-color .1s}.dep-row:hover{background:var(--bg-hover);border-color:var(--border)}.dep-row .dep-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:var(--locked);border:1.5px solid var(--locked)}.dep-row.s-active .dep-dot{background:#fff;border-color:var(--accent)}.dep-row.s-done .dep-dot{background:var(--done);border-color:var(--done)}.dep-row.s-goal .dep-dot{background:#fff;border-color:var(--goal)}.dep-row .dep-name{flex:1 1 auto;font-size:13.5px;font-weight:500;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em}.dep-row.s-done .dep-name{color:var(--text-3);text-decoration:line-through;text-decoration-color:var(--text-4)}.dep-row .dep-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums}.dep-row .dep-remove{color:var(--text-4);font-size:12px;padding:2px 6px;border-radius:3px;opacity:0;transition:opacity .12s}.dep-row:hover .dep-remove{opacity:1}.dep-row .dep-remove:hover{color:var(--accent);background:var(--accent-tint)}.dep-empty{font-size:12.5px;color:var(--text-4);padding:4px 2px}.dep-add{position:relative}.dep-add-trigger{font-size:12px;font-weight:500;color:var(--accent);padding:3px 8px;border-radius:4px;transition:background-color .1s}.dep-add-trigger:hover{background:var(--accent-tint)}.dep-add-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:5;background:#fff;border:1px solid var(--border);border-radius:var(--radius);max-height:260px;overflow-y:auto;min-width:220px;padding:4px;box-shadow:var(--shadow-lg)}.dep-add-item{display:block;width:100%;padding:7px 10px;text-align:left;font-size:13px;color:var(--text-1);border-radius:4px}.dep-add-item:hover{background:var(--bg-hover)}.dep-add-item .item-sub{display:block;font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);margin-top:1px}.dep-add-empty{padding:8px 12px;font-size:12px;color:var(--text-4)}.hours-row{display:flex;gap:10px;align-items:stretch}.hours-field{flex:1 1 0;display:flex;flex-direction:column;gap:4px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);padding:9px 12px;transition:border-color .1s}.hours-field:hover{border-color:var(--border)}.hours-field label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}.hours-field .field-content{display:flex;align-items:baseline;gap:4px}.hours-field input{border:none;padding:0;font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--text-1);background:transparent;width:76px;font-variant-numeric:tabular-nums}.hours-field input:focus{border:none;box-shadow:none}.hours-field .unit{font-family:var(--font-mono);font-size:12px;color:var(--text-3)}.progress-strip{height:4px;background:var(--bg-soft);border-radius:2px;overflow:hidden;margin-top:12px}.progress-strip>span{display:block;height:100%;border-radius:2px;background:var(--accent);transition:width .28s}.materials{width:100%;min-height:130px;border:1px solid var(--border);border-radius:var(--radius);padding:11px 13px;background:#fff;font-size:13.5px;line-height:1.6;color:var(--text-1)}.materials::placeholder{color:var(--text-4)}.drawer-actions{flex:0 0 auto;padding:12px 20px 16px;border-top:1px solid var(--border-soft);background:#fff;display:flex;gap:8px;align-items:center}.drawer-actions .btn{padding:9px 14px;font-size:13px}.drawer-actions .btn-primary{flex:1 1 auto;justify-content:center}.drawer-actions .btn-primary.done{background:#fff;color:var(--done);border:1px solid var(--done)}.drawer-actions .btn-primary.done:hover{background:var(--done-soft)}.drawer-actions .btn-primary.locked{background:var(--bg-soft);color:var(--text-4);cursor:not-allowed}.drawer-actions .btn-primary.locked:hover{background:var(--bg-soft)}.goal-toggle{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500;color:var(--text-3);padding:4px 8px;border:1px solid var(--border);border-radius:999px;-webkit-user-select:none;user-select:none;cursor:pointer;background:#fff}.goal-toggle:hover{border-color:var(--border-strong);color:var(--text-2)}.goal-toggle.on{color:var(--goal);background:var(--goal-soft);border-color:#b8860b4d}.goal-toggle .ico{font-size:10px}.merge-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-weight:500;background:var(--accent-tint);color:var(--accent);border-radius:999px;border:1px solid rgba(220,76,62,.18)}.mounted-list{display:flex;flex-direction:column;gap:2px}.mounted-row{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:4px;transition:background-color .1s;font-size:13px}.mounted-row:hover{background:var(--bg-soft)}.mounted-row.is-done .mounted-title{color:var(--text-3);text-decoration:line-through;text-decoration-color:var(--text-4)}.mounted-row .mounted-check{flex:0 0 auto}.mounted-row .mounted-title{flex:1 1 auto;cursor:pointer;color:var(--text-1);letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mounted-row .mounted-title:hover{color:var(--accent)}.mounted-row .mounted-detach{flex:0 0 auto;color:var(--text-4);padding:2px 6px;border-radius:3px;font-size:11px;opacity:0;transition:opacity .12s}.mounted-row:hover .mounted-detach{opacity:1}.mounted-row .mounted-detach:hover{color:var(--accent);background:var(--accent-tint)}.mounted-done-divider{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:8px 4px 4px}.mounted-quick-add{margin-bottom:6px}.mounted-quick-add input{width:100%}.module-placeholder{flex:1 1 auto;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;padding:40px;text-align:center;background:var(--bg-tint)}.module-placeholder .badge{display:inline-block;padding:4px 10px;background:#fff;border:1px solid var(--border);border-radius:999px;font-size:11px;color:var(--text-3);font-weight:500;letter-spacing:.04em;text-transform:uppercase}.module-placeholder h2{margin:0;font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text-1)}.module-placeholder p{max-width:460px;margin:0;font-size:14px;line-height:1.65;color:var(--text-3)}.module-placeholder ul{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:6px;text-align:left;max-width:380px;width:100%}.module-placeholder ul li{font-size:13px;color:var(--text-2);padding:8px 12px;border:1px solid var(--border-soft);border-radius:6px;background:#fff;display:flex;gap:10px;align-items:center}.module-placeholder ul li .num{font-family:var(--font-mono);font-size:11px;color:var(--text-4);font-variant-numeric:tabular-nums}.task-tab-row{flex:0 0 auto;display:flex;gap:4px;padding:0 32px;border-bottom:1px solid var(--border-soft);background:var(--bg)}.task-tab{display:inline-flex;align-items:center;gap:8px;padding:11px 4px 13px;margin-right:18px;font-size:13.5px;font-weight:500;color:var(--text-3);border-bottom:2px solid transparent;transition:color .12s,border-color .12s;position:relative;top:1px}.task-tab:hover{color:var(--text-1)}.task-tab.active{color:var(--text-1);border-bottom-color:var(--accent)}.task-tab-count{font-family:var(--font-mono);font-size:11px;color:var(--text-3);background:var(--bg-soft);border:1px solid var(--border-soft);padding:1px 6px;border-radius:999px;font-variant-numeric:tabular-nums;font-weight:500}.task-tab.active .task-tab-count{background:var(--accent-tint);color:var(--accent);border-color:#dc4c3e33}.task-canvas{padding:0}.task-list{padding:16px 32px 40px;display:flex;flex-direction:column;gap:0}.task-row{display:flex;align-items:flex-start;gap:6px;padding:7px 0;border-bottom:1px solid var(--border-soft);position:relative;min-height:36px}.task-row:last-child{border-bottom:none}.task-row.is-done .task-title>span:last-child{color:var(--text-3);text-decoration:line-through;text-decoration-color:var(--text-4);text-decoration-thickness:1px}.task-row.is-done .task-note{color:var(--text-4)}.task-caret{flex:0 0 auto;width:18px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--text-3);border-radius:3px;margin-top:0}.task-caret:not(.empty):hover{color:var(--text-1);background:var(--bg-hover)}.task-caret.empty{pointer-events:none}.task-status-check{margin-top:4px;flex:0 0 auto}.task-title-wrap{flex:1 1 auto;min-width:0;padding:3px 4px 1px;border-radius:4px;cursor:text}.task-title-wrap:hover{background:var(--bg-soft)}.task-title{display:flex;align-items:center;gap:7px;font-size:14px;color:var(--text-1);letter-spacing:-.005em;line-height:1.5;font-weight:500;word-break:break-word}.task-title-input{width:100%;font-size:14px;font-weight:500;border:1px solid var(--accent);box-shadow:0 0 0 3px var(--accent-soft);padding:4px 7px;border-radius:4px;background:#fff;letter-spacing:-.005em}.task-edit{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px;padding:6px 8px 8px;background:#fff;border:1px solid var(--accent);border-radius:6px;box-shadow:0 0 0 3px var(--accent-soft),0 2px 8px #0000000a;outline:none}.task-edit .task-title-input{border:none;box-shadow:none;padding:4px 6px;font-size:14px;font-weight:500;background:transparent;border-radius:4px}.task-edit .task-title-input:focus{background:var(--bg-soft)}.task-edit .task-body-input{width:100%;border:none;box-shadow:none;padding:4px 6px;font-size:13px;font-family:var(--font-sans);font-weight:400;color:var(--text-2);line-height:1.55;background:transparent;resize:vertical;min-height:36px;letter-spacing:-.003em;border-radius:4px}.task-edit .task-body-input:focus{background:var(--bg-soft);outline:none}.task-edit .task-body-input::placeholder{color:var(--text-4)}.task-edit-hint{font-size:10.5px;color:var(--text-4);letter-spacing:.02em;padding:0 6px}.task-edit-hint kbd{display:inline-block;font-family:var(--font-mono);font-size:10px;padding:1px 5px;border:1px solid var(--border);border-bottom-width:1.5px;border-radius:3px;background:var(--bg-soft);color:var(--text-3);margin:0 1px}.task-row.is-editing{align-items:stretch;padding:4px 0}.task-row.is-editing .task-status-check,.task-row.is-editing .task-caret{margin-top:8px}.task-note{font-size:12.5px;color:var(--text-3);margin-top:2px;line-height:1.45}.task-context{font-size:11.5px;color:var(--text-4);margin-top:3px;display:inline-flex;align-items:center;gap:4px}.task-project{display:inline-flex;align-items:center;gap:5px;margin-top:5px;padding:2px 8px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:999px;font-size:11.5px;color:var(--text-2);letter-spacing:-.005em;transition:background-color .12s,border-color .12s;cursor:pointer;max-width:100%;overflow:hidden}.task-project:hover{background:#fff;border-color:var(--border-strong)}.task-project .swatch{width:7px;height:7px;border-radius:50%;flex:0 0 auto}.task-project .project-archive{font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.task-project .project-sep{color:var(--text-4);font-weight:400}.task-project .project-node{color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.task-row.is-done .task-project{opacity:.6}.task-row-actions{display:flex;align-items:center;gap:2px;flex:0 0 auto;padding-top:4px;padding-right:2px}.task-action{width:26px;height:26px;border-radius:4px;color:var(--text-4);display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s,color .12s,background-color .12s}.task-row:hover .task-action{opacity:1}.task-action:hover{color:var(--text-1);background:var(--bg-hover)}.task-action.danger:hover{color:var(--accent);background:var(--accent-tint)}.today-pill{display:inline-flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:600;letter-spacing:.04em;color:var(--accent);background:var(--accent-tint);border:1px solid rgba(220,76,62,.18);border-radius:999px;padding:1px 7px;height:19px;margin-right:4px;font-variant-numeric:tabular-nums}.task-row.is-done .today-pill{color:var(--text-3);background:var(--bg-soft);border-color:var(--border-soft)}.task-children{margin-left:24px;border-left:1px solid var(--border-soft);padding-left:0}.task-row-quickadd{padding:4px 0}.task-quick-add{display:flex;align-items:center;gap:6px;padding:8px 0;border-bottom:1px solid var(--border-soft)}.task-quick-add .quick-plus{width:18px;height:18px;margin-top:4px;border-radius:50%;border:1.5px dashed var(--border-strong);color:var(--text-4);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:400;line-height:1;flex:0 0 auto}.task-quick-add .task-title-input{border:none;box-shadow:none;background:transparent;padding:4px 6px;font-weight:400;color:var(--text-1)}.task-quick-add .task-title-input::placeholder{color:var(--text-4)}.task-quick-add:focus-within .quick-plus{border-style:solid;border-color:var(--accent);color:var(--accent)}.task-empty{padding:24px 4px;color:var(--text-3);font-size:13.5px;text-align:center}.today-wrap{padding:24px 32px 60px;max-width:760px}.today-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}.today-badge{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;letter-spacing:-.01em}.today-title-block h2{margin:0;font-size:18px;font-weight:700;color:var(--text-1);letter-spacing:-.015em;line-height:1.3}.today-title-block p{margin:4px 0 0;font-size:13px;color:var(--text-3);line-height:1.5}.today-list{padding:0;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.today-list .task-row{padding:9px 14px;border-bottom:1px solid var(--border-soft)}.today-list .task-row:last-child{border-bottom:none}.today-list .task-quick-add{padding:9px 14px;border-bottom:none;border-top:1px solid var(--border-soft);background:var(--bg-soft)}.today-done-block{margin-top:28px}.today-done-head{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:8px}.today-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 24px 80px;gap:4px}.today-empty-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;color:var(--text-4);margin-bottom:10px}.today-empty h2{margin:0;font-size:20px;font-weight:700;color:var(--text-1);letter-spacing:-.015em}.today-empty p{margin:4px 0 12px;font-size:13.5px;color:var(--text-3);line-height:1.6;max-width:380px}.mobile-bottom-tabs,.mobile-header,.mobile-menu-btn,.sidebar-mobile-close{display:none}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:20;opacity:0;pointer-events:none;transition:opacity .2s}@media(max-width:820px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(86vw,320px);z-index:21;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 18px #0000001f}.sidebar.is-mobile-open{transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar-mobile-close{display:inline-flex;align-items:center;justify-content:center;position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:6px;background:transparent;border:0;color:var(--text-3);cursor:pointer;z-index:1}.sidebar-mobile-close:hover{background:var(--bg-soft);color:var(--text-1)}.sidebar-mobile-close svg{width:14px;height:14px}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;margin-right:2px;background:transparent;border:0;color:var(--text-2);cursor:pointer;border-radius:6px}.mobile-menu-btn:active{background:var(--bg-soft)}.main{width:100%}.main-header{padding:14px 18px 12px}.main-title{font-size:18px}.drawer{width:100vw;border-left:none}.task-tab-row{padding:0 18px}.task-list{padding:12px 18px 80px}.today-wrap{padding:18px 16px 80px}.today-list .task-row{padding:8px 12px}.task-row .task-action{opacity:.55}.mobile-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:#fff}.mobile-header .brand-mark{width:24px;height:24px;font-size:12px}.mobile-header .archive-switch{flex:1 1 auto;display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:6px;font-size:14px;font-weight:500;color:var(--text-1)}.mobile-header .archive-switch .caret{color:var(--text-3);margin-left:auto}.mobile-bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);z-index:5;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-bottom-tabs button{flex:1 1 0;padding:10px 0 12px;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-3);font-size:11px;font-weight:500}.mobile-bottom-tabs button.active{color:var(--accent)}.mobile-bottom-tabs button svg{width:22px;height:22px}.canvas{padding-bottom:64px}.main-header{flex-direction:column;align-items:stretch;gap:8px}.main-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.main-subtitle{flex-wrap:wrap;gap:6px 10px;row-gap:6px}.main-subtitle>*{flex:0 0 auto}.main-subtitle .meta-stat,.main-subtitle .archive-pill,.main-subtitle .meta-edges,.main-subtitle .filter-clear{white-space:nowrap;max-width:100%}.main-subtitle .meta-stat .stat-text,.main-subtitle .meta-edges .stat-text{display:none}.main-subtitle .archive-pill{overflow:hidden;text-overflow:ellipsis;max-width:60vw}.main-actions{flex-wrap:wrap;gap:6px 8px;justify-content:flex-start}.main-actions>*{white-space:nowrap;flex:0 0 auto}}.archive-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:19;opacity:0;pointer-events:none;transition:opacity .2s}.archive-sheet-backdrop.open{opacity:1;pointer-events:auto}.archive-sheet{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top-left-radius:16px;border-top-right-radius:16px;z-index:20;transform:translateY(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);max-height:70vh;display:flex;flex-direction:column;box-shadow:0 -8px 28px #0000001a}.archive-sheet.open{transform:translateY(0)}.archive-sheet-handle{height:18px;display:flex;justify-content:center;align-items:center}.archive-sheet-handle:before{content:"";width:36px;height:4px;border-radius:2px;background:var(--border-strong)}.archive-sheet h3{margin:0;padding:4px 20px 12px;font-size:14px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.archive-sheet .side-list{padding:0 12px 20px;overflow-y:auto}@media(max-width:480px){.hours-row{flex-direction:column}}.sync-indicator{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border:1px solid var(--border-soft);border-radius:999px;background:#fff;color:var(--text-2);font:inherit;font-size:11px;cursor:pointer;transition:border-color .12s,background-color .12s}.sync-indicator:hover{border-color:var(--border-strong);background:var(--bg-soft)}.sync-dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}.sync-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;z-index:40}.sync-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:var(--bg);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:41;display:flex;flex-direction:column;overflow:hidden}.sync-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border-soft)}.sync-panel-head h3{margin:0;font-size:15px;font-weight:600;color:var(--text-1)}.sync-panel-body{flex:1 1 auto;overflow-y:auto;padding:14px 18px 24px;display:flex;flex-direction:column;gap:18px}.sync-section{display:flex;flex-direction:column;gap:8px}.sync-section h4{margin:0;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}.sync-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px}.sync-row-label{color:var(--text-3)}.sync-row-val{color:var(--text-1);font-weight:500;display:inline-flex;align-items:center;gap:5px;text-align:right;max-width:60%;word-break:break-word}.sync-row-warn .sync-row-val{color:var(--accent)}.sync-err-detail{margin:6px 0 0;padding:8px 10px;background:#dc464614;border-left:2px solid var(--accent);border-radius:4px;font-size:12px;line-height:1.55}.sync-err-detail-tag{font-family:var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);color:var(--accent);word-break:break-all}.sync-err-detail-hint{margin-top:4px;color:var(--text-2)}.sync-hint{margin:0;font-size:12.5px;color:var(--text-3);line-height:1.55}.sync-empty{font-size:12.5px;color:var(--text-4);padding:10px 0}.sync-snap-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.sync-snap-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--border-soft);border-radius:var(--radius-sm);background:#fff}.sync-snap-meta{display:flex;flex-direction:column;gap:1px}.sync-snap-id{font-family:var(--font-mono, monospace);font-size:12.5px;color:var(--text-1);font-variant-numeric:tabular-nums}.sync-snap-size{font-size:11px;color:var(--text-4)}.sync-snap-acts{display:flex;gap:4px}.sync-snap-acts .btn{padding:3px 8px;font-size:12px}.sync-login-form{display:flex;flex-direction:column;gap:8px}.sync-login-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-3)}.sync-login-row>span{flex:0 0 48px}.sync-login-row input{flex:1 1 auto;font:inherit;font-size:13px;padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text-1)}.sync-login-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.sync-envid-row>span{flex-basis:60px}.sync-envid-row input{font-family:var(--font-mono, monospace);font-size:12px}.sync-login-actions{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap}.sync-login-actions .btn{padding:5px 10px;font-size:12.5px}.sync-login-divider{text-align:center;font-size:11px;color:var(--text-4);margin:4px 0 2px;position:relative}.sync-login-divider:before,.sync-login-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border-soft)}.sync-login-divider:before{left:0}.sync-login-divider:after{right:0}.sync-login-divider span{background:var(--bg);padding:0 8px;position:relative}.sync-login-wechat{width:100%}.sync-login-msg{font-size:12.5px;color:var(--text-2);padding:8px 10px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius-sm);line-height:1.5}.global-search{position:relative;margin:0 12px 10px}.global-search-input{position:relative;display:flex;align-items:center;gap:6px;padding:7px 10px 7px 32px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);transition:border-color .12s,box-shadow .12s}.global-search.is-open .global-search-input,.global-search-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.global-search-input>svg:first-child{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-4);pointer-events:none}.global-search.is-open .global-search-input>svg:first-child,.global-search-input:focus-within>svg:first-child{color:var(--accent)}.global-search-input input{border:none;background:transparent;padding:0;font:inherit;font-size:13px;flex:1 1 auto;width:100%;min-width:0;letter-spacing:-.005em;color:var(--text-1)}.global-search-input input:focus{outline:none}.global-search-input input::placeholder{color:var(--text-4)}.global-search-clear{flex:0 0 auto;width:18px;height:18px;border-radius:50%;color:var(--text-4);font-size:11px;background:transparent;display:flex;align-items:center;justify-content:center;line-height:1;border:none;cursor:pointer}.global-search-clear:hover{color:var(--text-1);background:var(--bg-hover)}.global-search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:480px;overflow-y:auto;padding:4px}.search-empty{padding:18px 14px;text-align:center;font-size:12.5px;color:var(--text-3)}.search-group{padding:4px 0}.search-group+.search-group{border-top:1px solid var(--border-soft);margin-top:4px;padding-top:6px}.search-group-head{font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);padding:4px 10px 6px;display:flex;align-items:center;gap:6px}.search-group-ring{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:var(--bg-soft);border-radius:50%;color:var(--text-3);font-size:10px}.search-item{display:flex;flex-direction:column;align-items:flex-start;gap:1px;width:100%;padding:7px 10px;border-radius:var(--radius-sm);text-align:left;background:transparent;border:none;cursor:pointer;font:inherit;transition:background-color .1s}.search-item:hover{background:var(--bg-hover)}.search-item-title{font-size:13px;font-weight:500;color:var(--text-1);letter-spacing:-.005em;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-sub{font-size:11.5px;color:var(--text-3);width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-mark{background:var(--accent-tint);color:var(--accent);padding:0 2px;border-radius:2px;font-weight:600}:root{--rel-continue: #0d8a8a;--rel-continue-soft: #e2f1f0;--rel-branch: #b07535;--rel-branch-soft: #faeede;--rel-rebut: #c4392d;--rel-rebut-soft: #fbeae8;--rel-support: #b8860b;--rel-support-soft: #fbf3e0;--rel-related: #d99326;--rel-related-soft: #fcefdc}.rel-chip{display:inline-flex;align-items:center;gap:4px;padding:1px 7px;border-radius:999px;font-size:11px;font-weight:500;background:var(--bg-soft);color:var(--text-3);border:1px solid var(--border-soft);letter-spacing:-.003em}.rel-chip-dot{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7;flex:0 0 auto}.rel-chip.rel-continue{color:var(--rel-continue);background:var(--rel-continue-soft);border-color:#0d8a8a33}.rel-chip.rel-branch{color:var(--rel-branch);background:var(--rel-branch-soft);border-color:#b0753538}.rel-chip.rel-rebut{color:var(--rel-rebut);background:var(--rel-rebut-soft);border-color:#c4392d2e}.rel-chip.rel-support{color:var(--rel-support);background:var(--rel-support-soft);border-color:#b8860b38}.rel-chip.rel-related{color:var(--rel-related);background:var(--rel-related-soft);border-color:#d9932638}.cards-canvas{padding:0;background:var(--bg)}.card-search{position:relative;display:flex;align-items:center;gap:6px;padding:6px 10px 6px 30px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);width:240px;transition:border-color .12s,background-color .12s}.card-search:focus-within{background:#fff;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.card-search>svg:first-child{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-4)}.card-search input{border:none;background:transparent;padding:0;font:inherit;font-size:13px;flex:1 1 auto;width:100%;letter-spacing:-.005em}.card-search input:focus{outline:none}.card-search-clear{flex:0 0 auto;width:18px;height:18px;border-radius:50%;color:var(--text-4);font-size:12px;background:transparent;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer}.card-search-clear:hover{color:var(--text-1);background:var(--border)}.card-search-clear svg{width:8px;height:8px}.card-export{display:inline-flex;gap:2px}.ts-stream{position:relative;padding:24px 32px 80px;max-width:820px}.ts-axis-line{position:absolute;left:89px;top:30px;bottom:50px;width:2px;background:var(--border);border-radius:1px}.ts-row{position:relative;display:flex;align-items:flex-start;gap:0;margin-bottom:14px}.ts-axis-dot{position:absolute;left:51px;top:18px;width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--accent);z-index:1}.ts-row:hover .ts-axis-dot{background:var(--accent)}.ts-card{flex:1 1 auto;margin-left:80px;padding:14px 18px 16px;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .12s,box-shadow .15s,transform .12s;display:flex;flex-direction:column;gap:6px;min-width:0;position:relative}.ts-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.ts-card.is-highlight{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ts-card-time{position:absolute;left:-80px;top:18px;width:46px;font-family:var(--font-mono, monospace);font-size:10.5px;color:var(--text-4);text-align:right;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.ts-card-main{display:flex;flex-direction:column;gap:6px;min-width:0}.ts-card-tags{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.growth-tag{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;background:var(--bg-soft);color:var(--text-3);border:1px solid var(--border-soft);letter-spacing:-.003em;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.growth-tag.rel-continue{color:var(--rel-continue);background:var(--rel-continue-soft);border-color:#0d8a8a33}.growth-tag.rel-branch{color:var(--rel-branch);background:var(--rel-branch-soft);border-color:#b0753538}.growth-tag.rel-rebut{color:var(--rel-rebut);background:var(--rel-rebut-soft);border-color:#c4392d2e}.growth-tag.rel-support{color:var(--rel-support);background:var(--rel-support-soft);border-color:#b8860b38}.growth-tag.rel-related{color:var(--rel-related);background:var(--rel-related-soft);border-color:#d9932638}.growth-origin{color:var(--text-2);background:#fff;border-color:var(--border)}.growth-more{color:var(--text-4);font-weight:400;margin-left:2px}.growth-down,.growth-lateral{font-size:11px;color:var(--text-3);padding:2px 6px;border-radius:3px;font-weight:500;letter-spacing:-.003em}.growth-down{color:var(--text-2);background:var(--bg-soft)}.growth-lateral{color:var(--rel-related)}.ts-card-title{margin:0;font-size:15.5px;font-weight:600;letter-spacing:-.01em;color:var(--text-1);line-height:1.4}.ts-card-body{font-size:13px;color:var(--text-2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;white-space:pre-wrap;letter-spacing:-.003em}.ts-empty{padding:80px 24px;text-align:center;color:var(--text-3)}.ts-empty h3{margin:0;font-size:17px;font-weight:600;color:var(--text-1);letter-spacing:-.01em}.ts-empty p{margin:8px 0 0;font-size:13.5px;color:var(--text-3)}.lineage-wrap{max-width:720px;margin:0 auto;padding:24px 32px 60px;position:relative}.lineage-top-row{display:flex;align-items:center;gap:8px;margin-bottom:16px}.lineage-back{font:inherit;font-size:13px;font-weight:500;color:var(--text-2);padding:6px 12px;border-radius:var(--radius-sm);background:var(--bg-soft);border:1px solid var(--border-soft);cursor:pointer;transition:background-color .12s,color .12s,border-color .12s}.lineage-back:hover{background:#fff;color:var(--text-1);border-color:var(--border-strong)}.lineage-came-from{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:12.5px;padding:6px 12px;border-radius:var(--radius-sm);background:var(--accent-tint);border:1px solid rgba(220,76,62,.18);color:var(--accent);transition:background-color .12s,border-color .12s;cursor:pointer;max-width:320px;overflow:hidden}.lineage-came-from:hover{background:#fff;border-color:var(--accent)}.lineage-came-from .came-from-label{color:var(--text-3);font-weight:400}.lineage-came-from .came-from-title{font-weight:600;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.lineage-section{position:relative;padding:8px 0}.lineage-section-head{font-size:11.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);text-align:center;margin-bottom:10px}.lineage-section.lineage-down .lineage-section-head{margin-bottom:0;margin-top:10px}.lineage-neighbors{display:flex;flex-direction:column;gap:6px;max-width:540px;margin:0 auto}.lineage-neighbor{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);text-align:left;cursor:pointer;font:inherit;font-size:13px;color:var(--text-2);transition:border-color .12s,box-shadow .15s,transform .12s;min-width:0}.lineage-neighbor:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.lineage-neighbor .ln-title{font-weight:600;color:var(--text-1);letter-spacing:-.005em;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.lineage-neighbor .ln-body{font-size:12px;color:var(--text-3);flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.lineage-up-arrow,.lineage-down-arrow{text-align:center;font-size:16px;color:var(--text-4);line-height:1;padding:6px 0}.lineage-center{position:relative;background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:22px 26px 24px;margin:4px 0;box-shadow:0 4px 20px #0000000a}.lineage-time{font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-4);letter-spacing:-.01em;font-variant-numeric:tabular-nums}.lineage-title{margin:4px 0 14px;font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text-1);line-height:1.3}.lineage-body{font-size:14.5px;line-height:1.7;color:var(--text-1);letter-spacing:-.003em}.lineage-body p{margin:0 0 .6em}.lineage-body p:last-child{margin-bottom:0}.lineage-body-empty{color:var(--text-4);font-style:italic}.lineage-laterals{margin-top:16px;padding-top:14px;border-top:1px dashed var(--border)}.lineage-laterals-head{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}.lateral-list{display:flex;flex-wrap:wrap;gap:6px}.lateral-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius);background:var(--bg-soft);border:1px solid var(--border-soft);font:inherit;font-size:12.5px;color:var(--text-2);cursor:pointer;transition:background-color .12s,border-color .12s;max-width:100%}.lateral-chip:hover{background:#fff;border-color:var(--border-strong)}.lateral-chip.rel-continue .lateral-rel{color:var(--rel-continue)}.lateral-chip.rel-branch .lateral-rel{color:var(--rel-branch)}.lateral-chip.rel-rebut .lateral-rel{color:var(--rel-rebut)}.lateral-chip.rel-support .lateral-rel{color:var(--rel-support)}.lateral-chip.rel-related .lateral-rel{color:var(--rel-related)}.lateral-chip .lateral-rel{font-size:11px;font-weight:600}.lateral-chip .lateral-title{font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.lineage-continue-btn{display:block;width:100%;max-width:540px;margin:16px auto 0;padding:12px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);background:transparent;font:inherit;font-size:13.5px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all .12s}.lineage-continue-btn:hover{border-style:solid;border-color:var(--accent);color:var(--accent);background:var(--accent-tint)}.composer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:19}.composer{position:fixed;top:0;bottom:0;right:0;width:560px;max-width:100vw;z-index:20;background:#fff;border-left:1px solid var(--border);border-radius:0;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000000f;transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);overflow:hidden}.composer.open{transform:translate(0)}@media(max-width:768px){.composer{width:100vw;border-left:none}}.composer-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border-soft)}.composer-head h3{margin:0;font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--text-1)}.composer .drawer-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-3);cursor:pointer}.composer .drawer-close:hover{background:var(--bg-hover);color:var(--text-1)}.composer .drawer-close svg{width:12px;height:12px}.composer-body{flex:1 1 auto;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:10px}.composer-title{width:100%;font:inherit;font-size:17px;font-weight:600;letter-spacing:-.015em;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius)}.composer-title:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.composer-body-input{width:100%;font:inherit;font-size:14px;line-height:1.6;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);resize:vertical;letter-spacing:-.003em}.composer-body-input:focus{outline:none;border-color:var(--accent)}.composer-link{margin-top:4px;padding-top:12px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:10px}.composer-link-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none}.composer-link-toggle input{accent-color:var(--accent)}.composer-rel-row{display:flex;flex-wrap:wrap;gap:5px}.composer-rel-btn{padding:4px 12px;font:inherit;font-size:12.5px;font-weight:500;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--text-3);cursor:pointer;transition:all .12s}.composer-rel-btn:hover{color:var(--text-1);border-color:var(--border-strong)}.composer-rel-btn.active.rel-continue{background:var(--rel-continue-soft);border-color:var(--rel-continue);color:var(--rel-continue)}.composer-rel-btn.active.rel-branch{background:var(--rel-branch-soft);border-color:var(--rel-branch);color:var(--rel-branch)}.composer-rel-btn.active.rel-rebut{background:var(--rel-rebut-soft);border-color:var(--rel-rebut);color:var(--rel-rebut)}.composer-rel-btn.active.rel-support{background:var(--rel-support-soft);border-color:var(--rel-support);color:var(--rel-support)}.composer-rel-btn.active.rel-related{background:var(--rel-related-soft);border-color:var(--rel-related);color:var(--rel-related)}.composer-link-select{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font:inherit;font-size:13.5px;color:var(--text-1);cursor:pointer}.composer-link-select:focus{outline:none;border-color:var(--accent)}.composer-time-row{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12.5px;color:var(--text-2)}.composer-time-label{letter-spacing:-.003em}.composer-time-input{flex:1 1 auto;padding:6px 8px;border:1px solid var(--border);border-radius:5px;font:inherit;color:var(--text-1);background:#fff}.composer-time-input:focus{outline:none;border-color:var(--accent)}.composer-time-now{padding:4px 8px;border:1px solid var(--border);border-radius:5px;background:#fff;color:var(--text-2);font-size:12px;cursor:pointer}.composer-time-now:hover{border-color:var(--border-strong);color:var(--text-1)}.composer-ext-type-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.composer-ext-type-btn{padding:5px 10px;font-size:12.5px;font-weight:500;border-radius:5px;border:1px solid var(--border);background:#fff;color:var(--text-2);cursor:pointer;transition:all .12s;letter-spacing:-.003em}.composer-ext-type-btn:hover{border-color:var(--border-strong);color:var(--text-1)}.composer-ext-type-btn.active{background:var(--accent-tint);border-color:var(--accent);color:var(--accent)}.lateral-chip.is-external{background:#fff;border:1px dashed var(--border-strong);color:var(--text-2);text-decoration:none}.lateral-chip.is-external:hover{background:var(--bg-soft);border-style:solid;border-color:var(--border-strong)}.lateral-chip.is-external .lateral-ext-icon{font-size:11px;opacity:.85;margin:0 1px}.composer-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px 14px;border-top:1px solid var(--border-soft)}.composer-actions .btn:disabled{opacity:.45;cursor:not-allowed}.tl-stats-wrap{padding:18px 24px 40px;display:flex;flex-direction:column;gap:16px}.tl-stats-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tl-stats-label{font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:-.003em;padding:0 6px}.tl-stats-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;padding:14px 16px 16px}.tl-stats-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;font-size:13px;color:var(--text-2);margin-bottom:10px}.tl-stats-card-head strong{font-size:18px;color:var(--text-1);font-weight:600}.tl-stacked-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;background:var(--bg-soft)}.tl-stacked-seg{height:100%}.tl-stats-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;font-size:12.5px;color:var(--text-2)}.tl-stats-legend-item{display:inline-flex;align-items:center;gap:6px}.tl-monthbars{display:flex;align-items:flex-end;gap:4px;height:140px;padding-top:8px}.tl-monthbars-year{gap:8px}.tl-monthbar{flex:1 1 0;min-width:14px;display:flex;flex-direction:column;align-items:stretch;gap:4px;background:transparent;border:0;cursor:pointer;padding:0}.tl-monthbar:hover .tl-monthbar-stack{opacity:.85}.tl-monthbar-stack{display:flex;flex-direction:column-reverse;width:100%;min-height:2px;border-radius:3px;overflow:hidden;transition:opacity .15s}.tl-monthbar-stack span{display:block}.tl-monthbar-label{text-align:center;font-size:10px;color:var(--text-4);letter-spacing:-.003em}.tl-stats-rank{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.tl-stats-rank li{display:grid;grid-template-columns:minmax(110px,30%) 1fr auto;align-items:center;gap:10px;font-size:13px}.tl-stats-rank-name{color:var(--text-1);display:inline-flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl-stats-rank-sub{color:var(--text-4);font-size:11.5px}.tl-stats-rank-bar{height:8px;background:var(--bg-soft);border-radius:4px;overflow:hidden}.tl-stats-rank-bar span{display:block;height:100%;border-radius:4px}.tl-stats-rank-val{color:var(--text-2);font-size:12px;min-width:70px;text-align:right}.sync-actions-row{display:flex;gap:8px;flex-wrap:wrap}.life-types-backdrop{z-index:49}.life-types-composer{z-index:50}.tl-life-manage{color:var(--text-3);border-style:dashed!important}.tl-list-dot-plus{display:inline-flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px}.life-type-rows{display:flex;flex-direction:column;gap:8px}.life-type-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--border-soft);border-radius:6px;background:#fff}.life-type-color{width:28px;height:28px;padding:0;border:1px solid var(--border);border-radius:5px;background:transparent;cursor:pointer}.life-type-name{flex:1 1 auto;padding:5px 8px;border:1px solid var(--border);border-radius:5px;font:inherit;color:var(--text-1)}.life-type-name:focus{outline:none;border-color:var(--accent)}.life-type-del{width:26px;height:26px;border:1px solid var(--border);border-radius:5px;background:#fff;color:var(--text-3);cursor:pointer}.life-type-del:hover{color:var(--rel-rebut);border-color:var(--rel-rebut)}.cards-tree-wrap{position:relative;padding:30px 28px 60px;min-height:100%;width:100%}.cards-tree-grid{position:relative;z-index:2;display:flex;flex-direction:column;gap:36px;max-width:1100px;margin:0 auto}.cards-tree-grid .tree-rank{display:flex;justify-content:center;gap:14px;flex-wrap:nowrap}.cards-tree-node{flex:1 1 0;min-width:160px;max-width:240px;padding:10px 12px 11px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;font:inherit;text-align:left;display:flex;flex-direction:column;gap:6px;transition:border-color .12s,box-shadow .15s,transform .12s}.cards-tree-node:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.cards-tree-node.is-selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.cards-tree-title{font-size:13.5px;font-weight:600;color:var(--text-1);letter-spacing:-.005em;line-height:1.35;word-break:break-word}.cards-tree-body{font-size:11.5px;color:var(--text-3);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cards-tree-foot{display:flex;gap:6px;flex-wrap:wrap}.cards-tree-tag{font-size:10.5px;font-weight:500;padding:1px 7px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--text-3)}.cards-tree-tag.origin{background:var(--accent-tint);color:var(--accent);border-color:#dc4c3e2e}.cards-tree-arrows{position:absolute;left:0;top:0;pointer-events:none;z-index:1}.cards-tree-edge{fill:none;stroke-width:1.5;stroke-linecap:round}.cards-tree-edge.rel-continue{stroke:var(--rel-continue)}.cards-tree-edge.rel-branch{stroke:var(--rel-branch)}.cards-tree-edge.rel-rebut{stroke:var(--rel-rebut)}.cards-tree-edge.rel-support{stroke:var(--rel-support)}.cards-tree-edge.rel-related{stroke:var(--rel-related)}.cards-tree-edge-lateral{stroke-dasharray:4 4;opacity:.55}@media(max-width:820px){.ts-stream{padding:16px 14px 80px}.ts-axis-line{left:46px}.ts-axis-dot{left:27px}.ts-card-time{position:static;width:auto;text-align:left;margin-bottom:4px;left:0}.ts-card{margin-left:50px}.lineage-wrap{padding:16px 14px 80px}.lineage-title{font-size:19px}.lineage-body{font-size:14px}.cards-tree-wrap{padding:20px 14px 60px}.cards-tree-grid .tree-rank{gap:8px}.cards-tree-node{min-width:120px;padding:8px 10px}.cards-tree-title{font-size:12.5px}.card-search{width:140px}}.view-toggle{display:inline-flex;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);padding:2px;gap:2px}.view-toggle-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;font:inherit;font-size:12.5px;font-weight:500;color:var(--text-3);border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .12s;letter-spacing:-.005em}.view-toggle-btn:hover{color:var(--text-1)}.view-toggle-btn.active{background:#fff;color:var(--text-1);box-shadow:var(--shadow-sm)}.view-toggle-btn.active svg{color:var(--accent)}.view-toggle-btn svg{width:13px;height:13px;color:var(--text-4);flex:0 0 auto}.canvas.tree-canvas{overflow:auto;padding:0}.tree-canvas-inner{position:relative;padding:30px 28px 60px;min-height:100%}.tree-group-legend{display:flex;flex-wrap:wrap;gap:12px 16px;margin:0 0 18px;padding:6px 0 10px;border-bottom:1px dashed var(--border-soft);font-size:12px;color:var(--text-2)}.tree-group-legend-item{display:inline-flex;align-items:center;gap:6px;letter-spacing:-.003em}.tree-group-swatch{width:10px;height:10px;border-radius:3px;flex:0 0 auto}.tree-group-label{white-space:nowrap}.tree-grid{position:relative;z-index:2;display:flex;flex-direction:column;gap:28px}.tree-rank{display:flex;justify-content:center;gap:14px;flex-wrap:nowrap}.tree-node{flex:1 1 0;min-width:140px;max-width:240px;padding:10px 12px 11px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .12s,box-shadow .15s,transform .12s,opacity .15s;position:relative;display:flex;flex-direction:column;gap:6px}.tree-node:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.tree-node.is-selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.tree-node.is-dimmed{opacity:.28;filter:saturate(.6)}.tree-node.is-active{border-color:#dc4c3e66}.tree-node.is-done{background:var(--done-soft);border-color:#05852740}.tree-node.is-goal{border-color:var(--goal);border-width:1.5px;background:linear-gradient(180deg,var(--goal-soft),#fff)}.tree-node.is-goal.is-done{background:var(--goal-soft)}.tree-node-head{display:flex;align-items:flex-start;gap:7px}.tree-status{flex:0 0 auto;width:16px;height:16px;display:flex;align-items:center;justify-content:center;margin-top:2px}.tree-check{width:14px;height:14px;border-radius:50%;background:var(--done);display:inline-flex;align-items:center;justify-content:center}.tree-check svg{width:10px;height:10px}.tree-dot{width:9px;height:9px;border-radius:50%;border:1.5px solid}.tree-dot.dot-active{border-color:var(--accent);background:#fff}.tree-dot.dot-locked{border-color:var(--locked);background:var(--locked-soft)}.tree-title{flex:1 1 auto;font-size:13.5px;font-weight:600;color:var(--text-1);letter-spacing:-.005em;line-height:1.35;word-break:break-word}.tree-node.is-done .tree-title{color:var(--text-2)}.tree-node.is-goal .tree-title{font-weight:700}.tree-goal-mark{flex:0 0 auto;font-size:12px;color:var(--goal);margin-top:1px}.tree-body{font-size:11.5px;color:var(--text-3);line-height:1.45;letter-spacing:-.003em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tree-foot{display:flex;align-items:center;gap:8px;margin-top:2px}.tree-progress{flex:1 1 auto;height:3px;background:var(--bg-soft);border-radius:2px;overflow:hidden}.tree-progress>span{display:block;height:100%;background:var(--accent);border-radius:2px}.tree-node.is-done .tree-progress>span{background:var(--done)}.tree-node.is-locked .tree-progress>span{background:var(--locked)}.tree-hours{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.tree-arrows{position:absolute;left:0;top:0;pointer-events:none;z-index:1}.tree-arrow{fill:none;stroke:#d4d4d4;stroke-width:1.5;stroke-dasharray:4 4;transition:stroke .15s,stroke-width .15s}.tree-arrow.done{stroke:var(--done);stroke-dasharray:none;opacity:.7}.tree-arrow.highlight{stroke:var(--accent);stroke-dasharray:none;stroke-width:2;opacity:1}@media(max-width:768px){.tree-canvas-inner{padding:20px 14px 60px}.tree-rank{gap:8px}.tree-node{min-width:110px;padding:8px 10px}.tree-title{font-size:12.5px}.view-toggle-btn{padding:4px 8px;font-size:12px}}.main-actions .btn-ghost.is-active{background:var(--bg-soft);color:var(--text-1);font-weight:600}.tl-date-bar{display:flex;gap:6px;align-items:center;margin-top:10px;flex-wrap:wrap}.tl-date-input{font:inherit;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text-1);font-size:13px}.tl-date-input:hover{border-color:var(--border-strong)}.tl-date-bar .btn-ghost{padding:6px 10px;font-size:13px}.tl-root{padding:0}.tl-canvas-wrap{padding:12px 24px 24px 16px}.tl-canvas{position:relative;display:flex;align-items:flex-start}.tl-hours{position:relative;width:56px;flex:0 0 56px;height:1344px}.tl-hour-tick{position:absolute;left:0;right:0;height:0;border-top:1px dashed transparent}.tl-hour-label{position:absolute;top:-8px;right:8px;font-size:11px;color:var(--text-4);font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.tl-grid{position:relative;flex:1 1 auto;background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden;cursor:copy}.tl-hour-row{position:absolute;left:0;right:0;border-top:1px solid var(--border-soft);pointer-events:none}.tl-hour-row:nth-child(2n){background:#00000003}.tl-grid:hover{background:#dc4c3e03}.tl-block{position:absolute;left:4px;right:4px;border:none;border-radius:5px;padding:4px 8px;color:#fff;text-align:left;font:inherit;font-size:12px;line-height:1.35;cursor:pointer;display:flex;flex-direction:column;gap:1px;overflow:hidden;box-shadow:0 1px #0000000d inset,0 1px 2px #0000000f;transition:filter .12s}.tl-block:hover{filter:brightness(1.05)}.tl-block-time{font-size:11px;font-variant-numeric:tabular-nums;opacity:.92;font-weight:500}.tl-block-note{font-size:12px;opacity:.96;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-now-line{position:absolute;left:0;right:0;height:0;border-top:2px solid var(--accent);pointer-events:none;z-index:2}.tl-now-dot{position:absolute;left:-5px;top:-5px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px #dc4c3e2e}.tl-entry-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;z-index:40;opacity:0;pointer-events:none;transition:opacity .2s ease}.tl-entry-backdrop.open{opacity:1;pointer-events:auto}.tl-entry{position:fixed;top:0;right:0;bottom:0;width:440px;max-width:100vw;background:var(--bg);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:41;display:flex;flex-direction:column;overflow:hidden;transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1)}.tl-entry.open{transform:translate(0)}.tl-entry-body{flex:1 1 auto;overflow-y:auto;padding:14px 18px 18px;display:flex;flex-direction:column;gap:12px}.tl-entry-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;font-size:14px;padding:14px 18px 12px;border-bottom:1px solid var(--border-soft);background:var(--bg)}.tl-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-3);cursor:pointer}.tl-icon-btn:hover{background:var(--bg-hover);color:var(--text-1)}.tl-icon-btn svg{width:12px;height:12px}.tl-entry-times{display:flex;align-items:center;gap:8px}.tl-entry-times label{flex:1 1 0;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-3)}.tl-entry-times input{flex:1 1 0;font:inherit;font-size:13px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;color:var(--text-1);background:#fff}.tl-entry-times input:focus{outline:none;border-color:var(--accent)}.tl-entry-tilde{color:var(--text-3)}.tl-recent{display:flex;flex-direction:column;gap:6px}.tl-recent-label{font-size:11px;color:var(--text-4);text-transform:uppercase;letter-spacing:.04em}.tl-chips{display:flex;flex-wrap:wrap;gap:6px}.tl-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border:1px solid var(--border);border-radius:999px;background:#fff;font-size:12px;color:var(--text-2);cursor:pointer}.tl-chip:hover{border-color:var(--border-strong)}.tl-chip.active{background:var(--accent-tint);border-color:var(--accent);color:var(--accent)}.tl-chip-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--chip-color, #888)}.tl-tabs{display:flex;border-bottom:1px solid var(--border);margin-top:4px}.tl-tab{flex:1 1 0;padding:7px 0;border:none;background:transparent;font:inherit;font-size:13px;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tl-tab:hover{color:var(--text-1)}.tl-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.tl-search{font:inherit;font-size:13px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff}.tl-search:focus{outline:none;border-color:var(--accent)}.tl-list{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;padding:2px 0}.tl-list-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font:inherit;font-size:13px;color:var(--text-1);text-align:left}.tl-list-item:hover{background:var(--bg-hover)}.tl-list-item.active{background:var(--accent-tint);border-color:var(--accent);color:var(--accent)}.tl-list-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex:0 0 8px}.tl-empty-hint{color:var(--text-4);font-size:12.5px;padding:8px;text-align:center}.tl-note label{display:flex;flex-direction:column;gap:4px}.tl-note textarea{font:inherit;font-size:13px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;resize:vertical;min-height:56px;line-height:1.5;color:var(--text-1)}.tl-note textarea:focus{outline:none;border-color:var(--accent)}.tl-entry-actions{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:12px 18px calc(14px + env(safe-area-inset-bottom,0));border-top:1px solid var(--border-soft);background:var(--bg)}.tl-journal-wrap{padding:18px 24px 60px;display:flex;flex-direction:column;gap:20px;max-width:760px;margin:0 auto}.tl-journal-day{display:flex;flex-direction:column;gap:6px}.tl-journal-day-head{display:flex;align-items:baseline;justify-content:space-between;padding:0 2px 6px;border-bottom:1px solid var(--border-soft)}.tl-journal-day-title{font:inherit;font-size:14px;font-weight:600;color:var(--text-1);background:transparent;border:none;cursor:pointer;padding:4px 0;letter-spacing:-.005em}.tl-journal-day-title:hover{color:var(--accent)}.tl-journal-day-total{font-size:11.5px;color:var(--text-4);font-variant-numeric:tabular-nums}.tl-journal-list{display:flex;flex-direction:column;gap:4px}.tl-journal-item{display:grid;grid-template-columns:130px 130px 1fr;align-items:baseline;gap:12px;padding:8px 12px 9px 14px;background:#fff;border:1px solid var(--border-soft);border-left:3px solid #ccc;border-radius:var(--radius-sm);cursor:pointer;font:inherit;text-align:left;transition:border-color .12s,box-shadow .15s}.tl-journal-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.tl-journal-time{font-family:var(--font-mono, monospace);font-size:12px;color:var(--text-2);font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:6px}.tl-journal-dur{font-size:10.5px;color:var(--text-4)}.tl-journal-cat{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:500}.tl-journal-cat-dot{width:6px;height:6px;border-radius:50%}.tl-journal-note{font-size:13px;color:var(--text-1);line-height:1.55}.tl-journal-note-empty{color:var(--text-4);font-style:italic}.tl-search-view{padding:18px 24px 24px;display:flex;flex-direction:column;gap:14px}.tl-search-big{font:inherit;font-size:15px;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.tl-search-big:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}.tl-search-meta{font-size:12.5px;color:var(--text-3)}.tl-search-results{display:flex;flex-direction:column;gap:6px}.tl-search-row{text-align:left;border:1px solid var(--border-soft);border-radius:var(--radius);padding:10px 14px;background:#fff;cursor:pointer;font:inherit;display:flex;flex-direction:column;gap:4px}.tl-search-row:hover{border-color:var(--border-strong);background:var(--bg-soft)}.tl-search-row-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tl-search-cat{font-weight:600;font-size:13px;color:var(--text-1)}.tl-search-when{font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums}.tl-search-note{font-size:13px;color:var(--text-2);line-height:1.5}.tl-week{padding:6px 12px 10px;display:flex;flex-direction:column;gap:4px}.tl-week-day{display:grid;grid-template-columns:18px 1fr 36px;align-items:center;gap:8px;padding:4px;border-radius:var(--radius-sm)}.tl-week-day.today{background:var(--accent-tint)}.tl-week-label{font-size:11.5px;color:var(--text-3)}.tl-week-day.today .tl-week-label{color:var(--accent);font-weight:600}.tl-week-bar{height:8px;background:var(--border-soft);border-radius:999px;overflow:hidden;display:flex}.tl-week-bar span{display:inline-block;height:100%}.tl-week-hours{font-size:11px;color:var(--text-3);text-align:right;font-variant-numeric:tabular-nums}@media(max-width:820px){.tl-entry{width:100vw;max-width:100vw;border-left:none}}@media(max-width:768px){.tl-canvas-wrap{padding:8px 12px 20px 8px}.tl-hours{width:42px;flex-basis:42px}.tl-journal-wrap{padding:12px 12px 60px}.tl-journal-item{grid-template-columns:1fr;gap:4px}}.composer-attach{border:1.5px dashed var(--border);border-radius:6px;padding:8px 10px;background:var(--bg-soft);transition:border-color .12s,background-color .12s}.composer-attach.is-drop{border-color:var(--accent);background:var(--accent-tint)}.composer-attach-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.composer-attach-add{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#fff;border:1px solid var(--border);border-radius:5px;font-size:12.5px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all .12s}.composer-attach-add:hover{border-color:var(--accent);color:var(--accent)}.composer-attach-hint{font-size:11px;color:var(--text-4)}.composer-attach-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.composer-attach-item{position:relative;background:#fff;border:1px solid var(--border-soft);border-radius:5px;display:flex;align-items:center;gap:6px;padding:4px;max-width:100%}.composer-attach-item.is-image img{width:64px;height:64px;object-fit:cover;border-radius:3px;display:block}.composer-attach-item.is-file{padding:8px 10px}.attach-file-icon{font-size:20px;flex:0 0 auto}.attach-meta{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.composer-attach-item.is-image .attach-meta{display:none}.attach-name{font-size:12px;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.attach-size{font-size:10.5px;color:var(--text-4);font-family:var(--font-mono)}.attach-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:#fff;border:1px solid var(--border);color:var(--text-2);font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .12s,background-color .12s}.composer-attach-item:hover .attach-remove{opacity:1}.attach-remove:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.lineage-attachments{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.lineage-attach{text-decoration:none;color:inherit}.lineage-attach-image{display:block;border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:zoom-in;transition:border-color .12s,transform .12s}.lineage-attach-image:hover{border-color:var(--accent);transform:translateY(-1px)}.lineage-attach-image img{display:block;max-width:240px;max-height:200px;object-fit:cover}.lineage-attach-file{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text-1);font-size:13px;transition:border-color .12s,background-color .12s;max-width:280px}.lineage-attach-file:hover{border-color:var(--accent);background:var(--accent-tint)}.lineage-attach-file .attach-name{max-width:160px}.fab{position:fixed;right:20px;bottom:24px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #dc4c3e66,0 2px 6px #00000014;cursor:pointer;z-index:8;transition:background-color .12s,transform .12s,box-shadow .15s;border:none;padding:0}.fab:hover{background:var(--accent-hover, #c43d31);box-shadow:0 6px 18px #dc4c3e80,0 3px 8px #0000001a;transform:translateY(-1px)}.fab:active{transform:translateY(0)}@media(max-width:768px){.fab{width:56px;height:56px;right:16px;bottom:80px}.is-create-action{display:none!important}}.side-data-menu{position:relative}.side-data-popup{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:#fff;border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px #0000001a;padding:4px;z-index:9}.side-data-popup-item{display:block;width:100%;padding:6px 10px;background:none;border:none;text-align:left;font-size:12.5px;color:var(--text-2);cursor:pointer;border-radius:4px}.side-data-popup-item:hover{background:var(--bg-soft);color:var(--text-1)}
