panopticon-cli 0.6.5 → 0.6.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/{agents-DfYify9s.js → agents-CfFDs52G.js} +14 -14
- package/dist/{agents-DfYify9s.js.map → agents-CfFDs52G.js.map} +1 -1
- package/dist/{agents-BKsVoIc9.js → agents-D_2oRFVf.js} +1 -1
- package/dist/{archive-planning-BJrZ3tmN.js → archive-planning-D97ziGec.js} +3 -3
- package/dist/{archive-planning-BJrZ3tmN.js.map → archive-planning-D97ziGec.js.map} +1 -1
- package/dist/{archive-planning-C3m3hfa5.js → archive-planning-DK90wn9Q.js} +1 -1
- package/dist/{browser-Cvdznzc0.js → browser-CX7jXfXX.js} +1 -1
- package/dist/{browser-Cvdznzc0.js.map → browser-CX7jXfXX.js.map} +1 -1
- package/dist/{clean-planning-DvhZAUv4.js → clean-planning-D_lz4aQq.js} +2 -2
- package/dist/{clean-planning-DvhZAUv4.js.map → clean-planning-D_lz4aQq.js.map} +1 -1
- package/dist/clean-planning-x1S-JdmO.js +2 -0
- package/dist/cli/index.js +291 -760
- package/dist/cli/index.js.map +1 -1
- package/dist/{close-issue-Dr7yZmrr.js → close-issue-CaFE0stN.js} +11 -7
- package/dist/close-issue-CaFE0stN.js.map +1 -0
- package/dist/close-issue-CjcfZI9s.js +2 -0
- package/dist/compact-beads-B0_qE1w3.js +2 -0
- package/dist/{compact-beads-BCOtIIRl.js → compact-beads-CjFkteSU.js} +2 -2
- package/dist/{compact-beads-BCOtIIRl.js.map → compact-beads-CjFkteSU.js.map} +1 -1
- package/dist/{config-CRzMQRgA.js → config-BQNKsi9G.js} +2 -2
- package/dist/{config-CRzMQRgA.js.map → config-BQNKsi9G.js.map} +1 -1
- package/dist/{config-BYgUzQ21.js → config-agyKgF5C.js} +1 -1
- package/dist/{config-yaml-BgOACZAB.js → config-yaml-DGbLSMCa.js} +1 -1
- package/dist/{config-yaml-BgOACZAB.js.map → config-yaml-DGbLSMCa.js.map} +1 -1
- package/dist/{config-yaml-fdyvyL0S.js → config-yaml-Dqt4FWQH.js} +1 -1
- package/dist/dashboard/{acceptance-criteria-e5iiHlRx.js → acceptance-criteria-Dk9hhiYj.js} +1 -1
- package/dist/dashboard/{acceptance-criteria-e5iiHlRx.js.map → acceptance-criteria-Dk9hhiYj.js.map} +1 -1
- package/dist/dashboard/{agent-enrichment-C67LJBgD.js → agent-enrichment-DdO7ZqjI.js} +11 -7
- package/dist/dashboard/agent-enrichment-DdO7ZqjI.js.map +1 -0
- package/dist/dashboard/{agent-enrichment-Cq0P1cNZ.js → agent-enrichment-dLeGE1fX.js} +1 -1
- package/dist/dashboard/{agents-YyO6t5Xa.js → agents-DCpQQ_W5.js} +14 -14
- package/dist/dashboard/{agents-YyO6t5Xa.js.map → agents-DCpQQ_W5.js.map} +1 -1
- package/dist/dashboard/{agents-BVBVCyat.js → agents-Dgh2TjSp.js} +1 -1
- package/dist/dashboard/{archive-planning-h-hAjk0P.js → archive-planning-BmW9UDTr.js} +3 -3
- package/dist/dashboard/{archive-planning-h-hAjk0P.js.map → archive-planning-BmW9UDTr.js.map} +1 -1
- package/dist/dashboard/{archive-planning-CScs1MOC.js → archive-planning-C3Ebf9yC.js} +1 -1
- package/dist/dashboard/{beads-qNB0yAHV.js → beads-Bv-AdX7G.js} +3 -3
- package/dist/dashboard/{beads-qNB0yAHV.js.map → beads-Bv-AdX7G.js.map} +1 -1
- package/dist/dashboard/{beads-D_FRedEJ.js → beads-By6-X07V.js} +1 -1
- package/dist/dashboard/clean-planning-D60L8rPY.js +2 -0
- package/dist/dashboard/{clean-planning-qafw99vY.js → clean-planning-VEJu5suh.js} +2 -2
- package/dist/dashboard/{clean-planning-qafw99vY.js.map → clean-planning-VEJu5suh.js.map} +1 -1
- package/dist/dashboard/close-issue-C2KeSKKJ.js +2 -0
- package/dist/dashboard/{close-issue-DfIggeZD.js → close-issue-DtKdsSTm.js} +11 -7
- package/dist/dashboard/close-issue-DtKdsSTm.js.map +1 -0
- package/dist/dashboard/compact-beads-C7BN5N11.js +2 -0
- package/dist/dashboard/{compact-beads-Dt0qTqsC.js → compact-beads-D8Vt3qyv.js} +2 -2
- package/dist/dashboard/{compact-beads-Dt0qTqsC.js.map → compact-beads-D8Vt3qyv.js.map} +1 -1
- package/dist/dashboard/{config-CUREjHP7.js → config-CDkGjnwy.js} +2 -2
- package/dist/dashboard/{config-CUREjHP7.js.map → config-CDkGjnwy.js.map} +1 -1
- package/dist/dashboard/{config-BeI3uy-8.js → config-CTXkBATQ.js} +1 -1
- package/dist/dashboard/{database-CozA13Wy.js → database-DhqASALP.js} +1 -1
- package/dist/dashboard/{database-C0y0hXBx.js → database-cxmQryoh.js} +2 -2
- package/dist/dashboard/{database-C0y0hXBx.js.map → database-cxmQryoh.js.map} +1 -1
- package/dist/dashboard/{dist-src-oG2iHzgI.js → dist-src-DTm11oQr.js} +1 -1
- package/dist/dashboard/{dist-src-oG2iHzgI.js.map → dist-src-DTm11oQr.js.map} +1 -1
- package/dist/dashboard/{event-store-D7kLBd07.js → event-store-VWWUmOfn.js} +1 -1
- package/dist/dashboard/{event-store-O9q0Gweh.js → event-store-vSmAA3Zp.js} +9 -4
- package/dist/dashboard/event-store-vSmAA3Zp.js.map +1 -0
- package/dist/dashboard/{factory-BnLdiQW-.js → factory-C8nhLGHB.js} +3 -3
- package/dist/dashboard/{factory-BnLdiQW-.js.map → factory-C8nhLGHB.js.map} +1 -1
- package/dist/dashboard/{feedback-writer-DyovUANg.js → feedback-writer-CudSe1WK.js} +2 -2
- package/dist/dashboard/{feedback-writer-DyovUANg.js.map → feedback-writer-CudSe1WK.js.map} +1 -1
- package/dist/dashboard/{feedback-writer-gSUv_W0h.js → feedback-writer-Wgv1cd1r.js} +1 -1
- package/dist/dashboard/{git-utils-BJRioREj.js → git-utils-C1m4SwAe.js} +1 -1
- package/dist/dashboard/{git-utils-BJRioREj.js.map → git-utils-C1m4SwAe.js.map} +1 -1
- package/dist/dashboard/{git-utils-BtCRddq3.js → git-utils-DQI8EYoj.js} +1 -1
- package/dist/dashboard/{github-app-XO-LBUGk.js → github-app-DClWjjHr.js} +1 -1
- package/dist/dashboard/{github-app-XO-LBUGk.js.map → github-app-DClWjjHr.js.map} +1 -1
- package/dist/dashboard/{health-events-db-584nYgJB.js → health-events-db-BMXQfInV.js} +1 -1
- package/dist/dashboard/{health-events-db-B3ChzN65.js → health-events-db-Do4NrOhC.js} +2 -2
- package/dist/dashboard/{health-events-db-B3ChzN65.js.map → health-events-db-Do4NrOhC.js.map} +1 -1
- package/dist/dashboard/{hooks-CKhs3N68.js → hooks-CB4T47NC.js} +1 -1
- package/dist/dashboard/{hooks-CErbP8Oq.js → hooks-CjqXOlNb.js} +2 -2
- package/dist/dashboard/{hooks-CErbP8Oq.js.map → hooks-CjqXOlNb.js.map} +1 -1
- package/dist/dashboard/hume-CA2pftu_.js +3 -0
- package/dist/dashboard/{hume-CX_U3Qha.js → hume-JsAlMOJC.js} +2 -2
- package/dist/dashboard/{hume-CX_U3Qha.js.map → hume-JsAlMOJC.js.map} +1 -1
- package/dist/dashboard/{inspect-agent-B57kGDUV.js → inspect-agent-7eour7EA.js} +3 -3
- package/dist/dashboard/{inspect-agent-B57kGDUV.js.map → inspect-agent-7eour7EA.js.map} +1 -1
- package/dist/dashboard/{io-yGovuG4U.js → io-CWlFW78i.js} +1 -1
- package/dist/dashboard/{io-AJg-mzFi.js → io-DKS6359z.js} +1 -1
- package/dist/dashboard/{io-AJg-mzFi.js.map → io-DKS6359z.js.map} +1 -1
- package/dist/dashboard/issue-id-vwYJdsf8.js +62 -0
- package/dist/dashboard/issue-id-vwYJdsf8.js.map +1 -0
- package/dist/dashboard/{issue-service-singleton-DQK42EqH.js → issue-service-singleton-Co__-6kL.js} +1 -1
- package/dist/dashboard/{issue-service-singleton-sb2HkB9f.js → issue-service-singleton-Wv4xBm3y.js} +7 -7
- package/dist/dashboard/{issue-service-singleton-sb2HkB9f.js.map → issue-service-singleton-Wv4xBm3y.js.map} +1 -1
- package/dist/dashboard/{label-cleanup-CZEsbtq9.js → label-cleanup-nVKTmIIW.js} +7 -4
- package/dist/dashboard/label-cleanup-nVKTmIIW.js.map +1 -0
- package/dist/dashboard/lifecycle-BcUmtkR4.js +7 -0
- package/dist/dashboard/{merge-agent-GLtMEsTu.js → merge-agent-CGN3TT0a.js} +1 -1
- package/dist/dashboard/{merge-agent-twroFuAh.js → merge-agent-yudQOPZc.js} +148 -46
- package/dist/dashboard/merge-agent-yudQOPZc.js.map +1 -0
- package/dist/dashboard/{paths-COdEvoXR.js → paths-BDyJ7BiV.js} +19 -2
- package/dist/dashboard/{paths-COdEvoXR.js.map → paths-BDyJ7BiV.js.map} +1 -1
- package/dist/dashboard/{pipeline-notifier-DM5AHG5Q.js → pipeline-notifier-CCSN-jar.js} +1 -1
- package/dist/dashboard/{pipeline-notifier-DM5AHG5Q.js.map → pipeline-notifier-CCSN-jar.js.map} +1 -1
- package/dist/dashboard/{plan-utils-BkCIhn3B.js → plan-utils-Bkcsqr_s.js} +3 -3
- package/dist/dashboard/{plan-utils-BkCIhn3B.js.map → plan-utils-Bkcsqr_s.js.map} +1 -1
- package/dist/dashboard/{prd-draft-D09Afalc.js → prd-draft-BD8oMkZ1.js} +2 -2
- package/dist/dashboard/{prd-draft-D09Afalc.js.map → prd-draft-BD8oMkZ1.js.map} +1 -1
- package/dist/dashboard/{projection-cache-DQ9zegkK.js → projection-cache-C0EL8s8h.js} +1 -1
- package/dist/dashboard/{projection-cache-DQ9zegkK.js.map → projection-cache-C0EL8s8h.js.map} +1 -1
- package/dist/dashboard/{projects-DyT3vSy-.js → projects-C5ozxjwP.js} +1 -1
- package/dist/dashboard/{projects-Cq3TWdPS.js → projects-CFVl4oHn.js} +25 -13
- package/dist/dashboard/projects-CFVl4oHn.js.map +1 -0
- package/dist/dashboard/{providers-Ck2sQd_F.js → providers-B5Y4H2Mg.js} +4 -4
- package/dist/dashboard/providers-B5Y4H2Mg.js.map +1 -0
- package/dist/dashboard/{providers-DVQnDekG.js → providers-csVZVPkE.js} +1 -1
- package/dist/dashboard/public/assets/{dist-CCJbQrSB.js → dist-CXaO6nOE.js} +1 -1
- package/dist/dashboard/public/assets/index-CzFZIb87.js +212 -0
- package/dist/dashboard/public/assets/index-OEEbThNN.css +1 -0
- package/dist/dashboard/public/index.html +2 -2
- package/dist/dashboard/rally-6McpKKRa.js +3 -0
- package/dist/dashboard/{rally-Cwuae-4C.js → rally-YjFRxIiC.js} +2 -2
- package/dist/dashboard/{rally-Cwuae-4C.js.map → rally-YjFRxIiC.js.map} +1 -1
- package/dist/dashboard/{rally-api-DSUxm7EO.js → rally-api-C0WqCSkT.js} +1 -1
- package/dist/dashboard/{rally-api-DSUxm7EO.js.map → rally-api-C0WqCSkT.js.map} +1 -1
- package/dist/dashboard/{rally-api-CEH5KZi4.js → rally-api-DNttdCW4.js} +1 -1
- package/dist/dashboard/{remote-BHTTMpJJ.js → remote-Cigqjj3f.js} +2 -2
- package/dist/dashboard/{remote-BXo_iIku.js → remote-ObpNZ7hF.js} +2 -2
- package/dist/dashboard/{remote-BXo_iIku.js.map → remote-ObpNZ7hF.js.map} +1 -1
- package/dist/dashboard/{remote-agents-CTKVhFFY.js → remote-agents-Bf3GuM7t.js} +1 -1
- package/dist/dashboard/{remote-agents-C0_0LLNd.js → remote-agents-DFyjT1Le.js} +1 -1
- package/dist/dashboard/{remote-agents-C0_0LLNd.js.map → remote-agents-DFyjT1Le.js.map} +1 -1
- package/dist/dashboard/{review-status-CK3eBGyb.js → review-status-BtXqWBhS.js} +1 -1
- package/dist/dashboard/{review-status-CV55Tl-n.js → review-status-Bymwzh2i.js} +44 -4
- package/dist/dashboard/{review-status-CV55Tl-n.js.map → review-status-Bymwzh2i.js.map} +1 -1
- package/dist/dashboard/server.js +559 -253
- package/dist/dashboard/server.js.map +1 -1
- package/dist/dashboard/{settings-CuHV-wcv.js → settings-BHlDG7TK.js} +2 -2
- package/dist/dashboard/settings-BHlDG7TK.js.map +1 -0
- package/dist/dashboard/settings-XWvDcj-D.js +2 -0
- package/dist/dashboard/{shadow-engineering-BUeZunaE.js → shadow-engineering-lIn1W_95.js} +1 -1
- package/dist/dashboard/{shadow-engineering-BUeZunaE.js.map → shadow-engineering-lIn1W_95.js.map} +1 -1
- package/dist/dashboard/{shadow-state-DHQ-kASN.js → shadow-state-BIexcxkv.js} +1 -1
- package/dist/dashboard/{shadow-state-DHQ-kASN.js.map → shadow-state-BIexcxkv.js.map} +1 -1
- package/dist/dashboard/{spawn-planning-session-8FFAqLdK.js → spawn-planning-session-33Jf-d5T.js} +6 -6
- package/dist/dashboard/{spawn-planning-session-8FFAqLdK.js.map → spawn-planning-session-33Jf-d5T.js.map} +1 -1
- package/dist/dashboard/{spawn-planning-session-U0Lqpjen.js → spawn-planning-session-D5hrVdWM.js} +1 -1
- package/dist/dashboard/{specialist-context-ColzlmGE.js → specialist-context-DGukHSn8.js} +6 -6
- package/dist/dashboard/{specialist-context-ColzlmGE.js.map → specialist-context-DGukHSn8.js.map} +1 -1
- package/dist/dashboard/{specialist-logs-BhmDpFIq.js → specialist-logs-CIw4qfTy.js} +1 -1
- package/dist/dashboard/{specialists-C6s3U6tX.js → specialists-B_zrayaP.js} +37 -36
- package/dist/dashboard/specialists-B_zrayaP.js.map +1 -0
- package/dist/dashboard/{specialists-Cny632-T.js → specialists-Cp-PgspS.js} +1 -1
- package/dist/dashboard/{test-agent-queue-tqI4VDsu.js → test-agent-queue-ypF_ecHo.js} +4 -4
- package/dist/dashboard/{test-agent-queue-tqI4VDsu.js.map → test-agent-queue-ypF_ecHo.js.map} +1 -1
- package/dist/dashboard/{tldr-daemon-BNFyS7W_.js → tldr-daemon-B_oLRD8z.js} +2 -2
- package/dist/dashboard/{tldr-daemon-BNFyS7W_.js.map → tldr-daemon-B_oLRD8z.js.map} +1 -1
- package/dist/dashboard/{tldr-daemon-A6JqC59u.js → tldr-daemon-Cfs0bXTi.js} +1 -1
- package/dist/dashboard/{tmux-DYGAVJfb.js → tmux-BzxdKItf.js} +1 -1
- package/dist/dashboard/{tmux-IlN1Slv-.js → tmux-LwG0tHhU.js} +2 -2
- package/dist/dashboard/{tmux-IlN1Slv-.js.map → tmux-LwG0tHhU.js.map} +1 -1
- package/dist/dashboard/{tracker-config-BzNLnmcE.js → tracker-config-BP59uH4V.js} +1 -1
- package/dist/dashboard/{tracker-config-CNM_5rEf.js → tracker-config-e7ph1QqT.js} +2 -2
- package/dist/dashboard/{tracker-config-CNM_5rEf.js.map → tracker-config-e7ph1QqT.js.map} +1 -1
- package/dist/dashboard/{tunnel-D2BkwU7k.js → tunnel-0RzzuXPf.js} +1 -1
- package/dist/dashboard/{tunnel-Dub2hiAA.js → tunnel-DldbBPWL.js} +2 -2
- package/dist/dashboard/{tunnel-Dub2hiAA.js.map → tunnel-DldbBPWL.js.map} +1 -1
- package/dist/dashboard/{types-CWA-o4UN.js → types-RKZjGE5N.js} +1 -1
- package/dist/dashboard/{types-CWA-o4UN.js.map → types-RKZjGE5N.js.map} +1 -1
- package/dist/dashboard/{vtt-parser-BAXygRf0.js → vtt-parser-99vFekRQ.js} +1 -1
- package/dist/dashboard/{vtt-parser-BAXygRf0.js.map → vtt-parser-99vFekRQ.js.map} +1 -1
- package/dist/dashboard/{work-agent-prompt-JYq_OugP.js → work-agent-prompt-fCg67nyo.js} +65 -10
- package/dist/dashboard/{work-agent-prompt-JYq_OugP.js.map → work-agent-prompt-fCg67nyo.js.map} +1 -1
- package/dist/dashboard/{work-type-router-Cxp8_ur2.js → work-type-router-CWVW2Wk_.js} +1 -1
- package/dist/dashboard/{work-type-router-Cxp8_ur2.js.map → work-type-router-CWVW2Wk_.js.map} +1 -1
- package/dist/dashboard/{work-type-router-Com2amST.js → work-type-router-Di5gCQwh.js} +1 -1
- package/dist/dashboard/{workflows-N1UTipYl.js → workflows-BSMipN07.js} +35 -17
- package/dist/dashboard/workflows-BSMipN07.js.map +1 -0
- package/dist/dashboard/workflows-DaYWQIS2.js +2 -0
- package/dist/dashboard/{workspace-config-cmp5_ipD.js → workspace-config-DVDR-Ukh.js} +1 -1
- package/dist/dashboard/workspace-config-DVDR-Ukh.js.map +1 -0
- package/dist/dashboard/{workspace-manager-CjpWPgzL.js → workspace-manager-BYfzs_t2.js} +1 -1
- package/dist/dashboard/{workspace-manager-D_y9ZmW_.js → workspace-manager-C7OfT62A.js} +44 -24
- package/dist/dashboard/workspace-manager-C7OfT62A.js.map +1 -0
- package/dist/{dns-BKzHm-2q.js → dns-D_aKQJjb.js} +1 -1
- package/dist/{dns-DZwOWvVO.js → dns-Yxq4NNS7.js} +1 -1
- package/dist/{dns-DZwOWvVO.js.map → dns-Yxq4NNS7.js.map} +1 -1
- package/dist/{factory-DFu3IT4r.js → factory-BRBGw6OB.js} +1 -1
- package/dist/{factory-DfzczxN1.js → factory-DzsOiZVc.js} +3 -3
- package/dist/{factory-DfzczxN1.js.map → factory-DzsOiZVc.js.map} +1 -1
- package/dist/{feedback-writer-CwdnOkPO.js → feedback-writer-ygXN5F9N.js} +2 -2
- package/dist/{feedback-writer-CwdnOkPO.js.map → feedback-writer-ygXN5F9N.js.map} +1 -1
- package/dist/{github-app-CHKwxOeQ.js → github-app-DykduJ0X.js} +1 -1
- package/dist/{github-app-CHKwxOeQ.js.map → github-app-DykduJ0X.js.map} +1 -1
- package/dist/hume-9nv1VmMV.js +3 -0
- package/dist/{hume-DnV-tDsh.js → hume-DoCbph2h.js} +2 -2
- package/dist/{hume-DnV-tDsh.js.map → hume-DoCbph2h.js.map} +1 -1
- package/dist/index.d.ts +17 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -7
- package/dist/issue-id-CAcekoIw.js +62 -0
- package/dist/issue-id-CAcekoIw.js.map +1 -0
- package/dist/{label-cleanup-31ElPqqv.js → label-cleanup-C8R9Rspn.js} +7 -4
- package/dist/label-cleanup-C8R9Rspn.js.map +1 -0
- package/dist/{manifest-DL0oDbpv.js → manifest-B4ghOD-V.js} +1 -1
- package/dist/{manifest-DL0oDbpv.js.map → manifest-B4ghOD-V.js.map} +1 -1
- package/dist/{merge-agent-VQH9z9t8.js → merge-agent-DlUiUanN.js} +86 -33
- package/dist/merge-agent-DlUiUanN.js.map +1 -0
- package/dist/{paths-lMaxrYtT.js → paths-CDJ_HsbN.js} +19 -2
- package/dist/{paths-lMaxrYtT.js.map → paths-CDJ_HsbN.js.map} +1 -1
- package/dist/{pipeline-notifier-OJ-d3Y60.js → pipeline-notifier-XgDdCdvT.js} +1 -1
- package/dist/{pipeline-notifier-OJ-d3Y60.js.map → pipeline-notifier-XgDdCdvT.js.map} +1 -1
- package/dist/{projects-CvLepaxC.js → projects-Bk-5QhFQ.js} +25 -13
- package/dist/projects-Bk-5QhFQ.js.map +1 -0
- package/dist/{projects-DMWmPeIU.js → projects-DhU7rAVN.js} +1 -1
- package/dist/{providers-DcCPZ5K4.js → providers-DSU1vfQF.js} +4 -4
- package/dist/providers-DSU1vfQF.js.map +1 -0
- package/dist/rally-DdPvGa-w.js +3 -0
- package/dist/{rally-uUUZXp1h.js → rally-Dy00NElU.js} +1 -1
- package/dist/{rally-uUUZXp1h.js.map → rally-Dy00NElU.js.map} +1 -1
- package/dist/{remote-CkLBqLJc.js → remote-CYiOJg0q.js} +2 -2
- package/dist/{remote-CkLBqLJc.js.map → remote-CYiOJg0q.js.map} +1 -1
- package/dist/{remote-agents-C5Bd2fgt.js → remote-agents-CZXrUF4f.js} +1 -1
- package/dist/{remote-agents-C5Bd2fgt.js.map → remote-agents-CZXrUF4f.js.map} +1 -1
- package/dist/{remote-agents-BTzD-wMQ.js → remote-agents-ycHHVsgf.js} +1 -1
- package/dist/{remote-workspace-Dxghqiti.js → remote-workspace-CA33UuVI.js} +4 -4
- package/dist/{remote-workspace-Dxghqiti.js.map → remote-workspace-CA33UuVI.js.map} +1 -1
- package/dist/{review-status-2TdtHNcs.js → review-status-D6H2WOw8.js} +1 -1
- package/dist/{review-status-Bm1bWNEa.js → review-status-DEDvCKMP.js} +44 -4
- package/dist/{review-status-Bm1bWNEa.js.map → review-status-DEDvCKMP.js.map} +1 -1
- package/dist/{tracker-C_62ukEq.js → settings-BcWPTrua.js} +7 -199
- package/dist/settings-BcWPTrua.js.map +1 -0
- package/dist/shadow-state-BZzxfEGw.js +2 -0
- package/dist/{shadow-state-CFFHf05M.js → shadow-state-CE3dQfll.js} +1 -1
- package/dist/{shadow-state-CFFHf05M.js.map → shadow-state-CE3dQfll.js.map} +1 -1
- package/dist/{specialist-context-BdNFsfMG.js → specialist-context-BAUWL1Fl.js} +6 -6
- package/dist/{specialist-context-BdNFsfMG.js.map → specialist-context-BAUWL1Fl.js.map} +1 -1
- package/dist/{specialist-logs-CLztE_bE.js → specialist-logs-DQKKQV9B.js} +1 -1
- package/dist/{specialists-aUoUVWsN.js → specialists-Bfb9ATzw.js} +1 -1
- package/dist/{specialists-DEKqgkxp.js → specialists-D7Kj5o6s.js} +35 -34
- package/dist/specialists-D7Kj5o6s.js.map +1 -0
- package/dist/sync-DMfgd389.js +693 -0
- package/dist/sync-DMfgd389.js.map +1 -0
- package/dist/sync-TL6y-8K6.js +2 -0
- package/dist/{tldr-daemon-BCEFPItr.js → tldr-daemon-CFx4LXAl.js} +2 -2
- package/dist/{tldr-daemon-BCEFPItr.js.map → tldr-daemon-CFx4LXAl.js.map} +1 -1
- package/dist/{tldr-daemon-xBAx4cBE.js → tldr-daemon-D_EooADG.js} +1 -1
- package/dist/{tmux-DN6H886Y.js → tmux-CBtui_Cl.js} +1 -1
- package/dist/{tmux-CKdNxxJx.js → tmux-D6Ah4I8z.js} +2 -2
- package/dist/{tmux-CKdNxxJx.js.map → tmux-D6Ah4I8z.js.map} +1 -1
- package/dist/tracker-BhYYvU3p.js +198 -0
- package/dist/tracker-BhYYvU3p.js.map +1 -0
- package/dist/{tracker-utils-CVU2W1sX.js → tracker-utils-ChQyut8w.js} +34 -12
- package/dist/tracker-utils-ChQyut8w.js.map +1 -0
- package/dist/{traefik-DHgBoWXX.js → traefik-C80EbDu_.js} +4 -4
- package/dist/{traefik-DHgBoWXX.js.map → traefik-C80EbDu_.js.map} +1 -1
- package/dist/{traefik-BR-edbZv.js → traefik-CgHl7Bge.js} +1 -1
- package/dist/{tunnel-BZO9Q5oe.js → tunnel-DXOJ1wMM.js} +1 -1
- package/dist/{tunnel-Bl1qNSyQ.js → tunnel-DzXEPwIc.js} +2 -2
- package/dist/{tunnel-Bl1qNSyQ.js.map → tunnel-DzXEPwIc.js.map} +1 -1
- package/dist/{types-DewGdaIP.js → types-BhJj1SP1.js} +1 -1
- package/dist/{types-DewGdaIP.js.map → types-BhJj1SP1.js.map} +1 -1
- package/dist/{work-type-router-CS2BB1vS.js → work-type-router-CHjciPyS.js} +3 -3
- package/dist/{work-type-router-CS2BB1vS.js.map → work-type-router-CHjciPyS.js.map} +1 -1
- package/dist/{workspace-config-CNXOpKuj.js → workspace-config-fUafvYMp.js} +1 -1
- package/dist/workspace-config-fUafvYMp.js.map +1 -0
- package/dist/workspace-manager-B9jS4Dsq.js +3 -0
- package/dist/{workspace-manager-CncdZkIy.js → workspace-manager-DuLhnzJV.js} +112 -27
- package/dist/workspace-manager-DuLhnzJV.js.map +1 -0
- package/package.json +2 -1
- package/scripts/post-merge-deploy.sh +25 -5
- package/scripts/record-cost-event.js +57 -7
- package/scripts/record-cost-event.js.map +1 -1
- package/skills/pan-help/SKILL.md +1 -1
- package/skills/pan-sync/SKILL.md +6 -6
- package/skills/workspace-add-repo/skill.md +46 -0
- package/templates/claude-md/sections/warnings.md +15 -2
- package/dist/clean-planning-sZXvy3Y5.js +0 -2
- package/dist/close-issue-Dml437qV.js +0 -2
- package/dist/close-issue-Dr7yZmrr.js.map +0 -1
- package/dist/compact-beads-iu218JcO.js +0 -2
- package/dist/dashboard/agent-enrichment-C67LJBgD.js.map +0 -1
- package/dist/dashboard/clean-planning-DCu3cOTu.js +0 -2
- package/dist/dashboard/close-issue-DfIggeZD.js.map +0 -1
- package/dist/dashboard/close-issue-DwdwYtar.js +0 -2
- package/dist/dashboard/compact-beads-DXY2fK2s.js +0 -2
- package/dist/dashboard/event-store-O9q0Gweh.js.map +0 -1
- package/dist/dashboard/hume-MZndNDVU.js +0 -3
- package/dist/dashboard/label-cleanup-CZEsbtq9.js.map +0 -1
- package/dist/dashboard/lifecycle-ZTYdrr2O.js +0 -7
- package/dist/dashboard/merge-agent-twroFuAh.js.map +0 -1
- package/dist/dashboard/projects-Cq3TWdPS.js.map +0 -1
- package/dist/dashboard/providers-Ck2sQd_F.js.map +0 -1
- package/dist/dashboard/public/assets/index-CpSmB2ts.css +0 -1
- package/dist/dashboard/public/assets/index-yarWhi0M.js +0 -214
- package/dist/dashboard/rally-CQ1OBJrJ.js +0 -3
- package/dist/dashboard/settings-CuHV-wcv.js.map +0 -1
- package/dist/dashboard/settings-DMeGBRsk.js +0 -2
- package/dist/dashboard/specialists-C6s3U6tX.js.map +0 -1
- package/dist/dashboard/workflows-B2ARUpOa.js +0 -2
- package/dist/dashboard/workflows-N1UTipYl.js.map +0 -1
- package/dist/dashboard/workspace-config-cmp5_ipD.js.map +0 -1
- package/dist/dashboard/workspace-manager-D_y9ZmW_.js.map +0 -1
- package/dist/hume-BjmwmJ9E.js +0 -3
- package/dist/label-cleanup-31ElPqqv.js.map +0 -1
- package/dist/merge-agent-VQH9z9t8.js.map +0 -1
- package/dist/projects-CvLepaxC.js.map +0 -1
- package/dist/providers-DcCPZ5K4.js.map +0 -1
- package/dist/rally-DR9x8--6.js +0 -3
- package/dist/shadow-state-p3jpGRPJ.js +0 -2
- package/dist/specialists-DEKqgkxp.js.map +0 -1
- package/dist/tracker-C_62ukEq.js.map +0 -1
- package/dist/tracker-utils-CVU2W1sX.js.map +0 -1
- package/dist/workspace-config-CNXOpKuj.js.map +0 -1
- package/dist/workspace-manager-CncdZkIy.js.map +0 -1
- package/dist/workspace-manager-Cx0r2Jnv.js +0 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.xterm{cursor:text;-webkit-user-select:none;user-select:none;position:relative}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{z-index:5;position:absolute;top:0}.xterm .xterm-helper-textarea{opacity:0;z-index:-5;white-space:nowrap;resize:none;border:0;width:0;height:0;margin:0;padding:0;position:absolute;top:0;left:-9999em;overflow:hidden}.xterm .composition-view{color:#fff;white-space:nowrap;z-index:1;background:#000;display:none;position:absolute}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{cursor:default;background-color:#000;position:absolute;inset:0;overflow-y:scroll}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;top:0;left:0}.xterm-char-measure-element{visibility:hidden;line-height:normal;display:inline-block;position:absolute;top:0;left:-9999em}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{z-index:10;color:#0000;pointer-events:none;position:absolute;inset:0}.xterm .xterm-accessibility-tree:not(.debug) ::-moz-selection{color:#0000}.xterm .xterm-accessibility-tree:not(.debug) ::selection{color:#0000}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre;font-family:monospace}.xterm .xterm-accessibility-tree>div{transform-origin:0;width:fit-content}.xterm .live-region{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:underline double;text-decoration:underline double}.xterm-underline-3{-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.xterm-underline-4{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.xterm-underline-5{-webkit-text-decoration:underline dashed;text-decoration:underline dashed}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:underline overline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;pointer-events:none;position:absolute;top:0;right:0}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;z-index:11;background:0 0;transition:opacity .1s linear}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{display:none;position:absolute}.xterm .xterm-scrollable-element>.shadow.top{width:100%;height:3px;box-shadow:var(--vscode-scrollbar-shadow,#000) 0 6px 6px -6px inset;display:block;top:0;left:3px}.xterm .xterm-scrollable-element>.shadow.left{width:3px;height:100%;box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset;display:block;top:3px;left:0}.xterm .xterm-scrollable-element>.shadow.top-left-corner{width:3px;height:3px;display:block;top:0;left:0}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}._missionControl_c8ljc_4{--mc-bg-main:#fff;--mc-bg-sidebar:#faf9f7;--mc-bg-secondary:#f7f6f3;--mc-bg-hover:#f3f2ef;--mc-bg-selected:#ede9e3;--mc-text-primary:#1a1a1a;--mc-text-secondary:#6b7280;--mc-text-muted:#9ca3af;--mc-border:#e5e7eb;--mc-border-strong:#d1d5db;--mc-accent:#2563eb;--mc-accent-hover:#1d4ed8;--mc-success:#059669;--mc-warning:#d97706;--mc-error:#dc2626;--mc-font-family:-apple-system, BlinkMacSystemFont, "Inter", "SF Pro", system-ui, sans-serif;--mc-font-mono:"SF Mono", "Monaco", "Menlo", "Consolas", monospace;--mc-font-size-xs:11px;--mc-font-size-sm:12px;--mc-font-size-base:14px;--mc-font-size-md:16px;--mc-font-size-lg:20px;--mc-font-size-xl:28px;--mc-line-height:1.5;--mc-space-1:4px;--mc-space-2:8px;--mc-space-3:12px;--mc-space-4:16px;--mc-space-5:20px;--mc-space-6:24px;--mc-space-8:32px;--mc-radius-sm:4px;--mc-radius:8px;--mc-radius-lg:12px;font-family:var(--mc-font-family);color:var(--mc-text-primary);line-height:var(--mc-line-height);height:100%}.dark ._missionControl_c8ljc_4{--mc-bg-main:#0c1018;--mc-bg-sidebar:#111520;--mc-bg-secondary:#0e1320;--mc-bg-hover:#161d2b;--mc-bg-selected:#1a2438;--mc-text-primary:#f3f4f6;--mc-text-secondary:#9ca3af;--mc-text-muted:#6b7280;--mc-border:#1e2a3a;--mc-border-strong:#2a3a50}._layout_c8ljc_64{background:var(--mc-bg-main);height:100%;display:flex;overflow:hidden}._sidebar_c8ljc_71{background:var(--mc-bg-sidebar);border-right:1px solid var(--mc-border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}._resizeHandle_c8ljc_80{cursor:col-resize;background:0 0;flex-shrink:0;width:4px;transition:background .15s;position:relative}._resizeHandle_c8ljc_80:hover,._resizeHandle_c8ljc_80:active{background:var(--mc-accent)}._sidebarHeader_c8ljc_94{padding:var(--mc-space-3) var(--mc-space-4) var(--mc-space-3);border-bottom:1px solid var(--mc-border);flex-shrink:0}._sidebarHeaderRow_c8ljc_100{margin-bottom:var(--mc-space-2);justify-content:space-between;align-items:center;gap:var(--mc-space-2);display:flex}._sidebarHeaderGroup_c8ljc_108{align-items:center;gap:var(--mc-space-2);display:flex}._sidebarTitle_c8ljc_114{font-size:var(--mc-font-size-md);margin:0;font-weight:600}._sidebarSubtitle_c8ljc_120{font-size:var(--mc-font-size-sm);color:var(--mc-text-secondary);margin:0}._segmentControl_c8ljc_127{background:var(--mc-bg-main);border-radius:var(--mc-radius);gap:2px;padding:2px;display:flex}._segmentButton_c8ljc_135{justify-content:center;align-items:center;gap:var(--mc-space-1);padding:var(--mc-space-1) var(--mc-space-2);border-radius:calc(var(--mc-radius) - 2px);font-size:var(--mc-font-size-xs);font-weight:500;font-family:var(--mc-font-family);color:var(--mc-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;flex:1;transition:background .15s,color .15s,box-shadow .15s;display:flex}._segmentButton_c8ljc_135:hover{color:var(--mc-text-primary)}._segmentButtonActive_c8ljc_158{background:var(--mc-bg-sidebar);color:var(--mc-text-primary);box-shadow:0 1px 2px #0000001a}._segmentCount_c8ljc_164{color:var(--mc-text-muted);background:var(--mc-bg-hover);border-radius:8px;padding:0 5px;font-size:10px;font-weight:600;line-height:16px}._projectTree_c8ljc_174{padding:var(--mc-space-2) 0;flex:1;overflow-y:auto}._projectNode_c8ljc_181{margin-bottom:var(--mc-space-1)}._projectHeader_c8ljc_185{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-4);cursor:pointer;font-size:var(--mc-font-size-sm);color:var(--mc-text-primary);text-align:left;background:0 0;border:none;width:100%;font-weight:600;transition:background .1s;display:flex}._projectHeader_c8ljc_185:hover{background:var(--mc-bg-hover)}._chevron_c8ljc_205{color:var(--mc-text-muted);flex-shrink:0;transition:transform .15s}._chevronOpen_c8ljc_211{transform:rotate(90deg)}._projectName_c8ljc_215{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}._featureCount_c8ljc_222{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-weight:400}._featureItem_c8ljc_229{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-4) var(--mc-space-2) var(--mc-space-8);cursor:pointer;font-size:var(--mc-font-size-sm);text-align:left;width:100%;color:var(--mc-text-primary);background:0 0;border:none;transition:background .1s;display:flex}._featureItem_c8ljc_229:hover{background:var(--mc-bg-hover)}._featureItemSelected_c8ljc_248{background:var(--mc-bg-selected)}._featureStatus_c8ljc_252{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}._featureLabel_c8ljc_261{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}._featureId_sidebar_c8ljc_268{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-family:var(--mc-font-mono);flex-shrink:0;min-width:56px}._featureState_c8ljc_276{color:var(--mc-text-muted);background:var(--mc-bg-hover);white-space:nowrap;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:10px}._featureCost_c8ljc_286{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-family:var(--mc-font-mono)}._emptyProject_c8ljc_292{padding:var(--mc-space-2) var(--mc-space-8);font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-style:italic}._content_c8ljc_300{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}._contentEmpty_c8ljc_308{color:var(--mc-text-muted);font-size:var(--mc-font-size-base);flex:1;justify-content:center;align-items:center;display:flex}._featureHeader_c8ljc_318{align-items:center;gap:var(--mc-space-3);padding:var(--mc-space-4) var(--mc-space-6);border-bottom:1px solid var(--mc-border);background:var(--mc-bg-main);display:flex}._featureTitle_c8ljc_327{font-size:var(--mc-font-size-lg);flex:1;margin:0;font-weight:600}._featureId_c8ljc_268{font-size:var(--mc-font-size-sm);color:var(--mc-text-muted);font-family:var(--mc-font-mono)}._badgeBar_c8ljc_341{gap:var(--mc-space-2);padding:var(--mc-space-3) var(--mc-space-6);border-bottom:1px solid var(--mc-border);background:var(--mc-bg-sidebar);display:flex}._badge_c8ljc_341{align-items:center;gap:var(--mc-space-1);padding:var(--mc-space-1) var(--mc-space-2);font-size:var(--mc-font-size-xs);border-radius:var(--mc-radius-sm);border:1px solid var(--mc-border);background:var(--mc-bg-main);cursor:pointer;color:var(--mc-text-secondary);transition:all .1s;display:inline-flex}._badge_c8ljc_341:hover{border-color:var(--mc-accent);color:var(--mc-accent)}._badgeDisabled_c8ljc_368{opacity:.4;cursor:default}._badgeDisabled_c8ljc_368:hover{border-color:var(--mc-border);color:var(--mc-text-secondary)}._activityContainer_c8ljc_379{padding:var(--mc-space-4) var(--mc-space-6);gap:var(--mc-space-4);flex-direction:column;flex:1;display:flex;overflow-y:auto}._agentSection_c8ljc_389{border:1px solid var(--mc-border);border-left:3px solid var(--mc-border);border-radius:var(--mc-radius);transition:box-shadow .15s,border-color .15s;overflow:clip}._agentSection_c8ljc_389:hover{border-color:var(--mc-border-strong)}._agentSectionExpanded_c8ljc_401{box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}._sectionHeader_c8ljc_405{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-3) var(--mc-space-4);background:var(--mc-bg-sidebar);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s;display:flex}._agentSectionExpanded_c8ljc_401 ._sectionHeader_c8ljc_405{border-bottom:1px solid var(--mc-border)}._sectionHeader_c8ljc_405:hover{background:var(--mc-bg-hover)}._sectionChevron_c8ljc_424{flex-shrink:0;align-items:center;display:flex}._sectionType_c8ljc_430{font-size:var(--mc-font-size-xs);text-transform:uppercase;letter-spacing:.05em;padding:2px var(--mc-space-2);border-radius:var(--mc-radius-sm);font-weight:600}._typePlanning_c8ljc_439{color:#1e40af;background:#dbeafe}._typeWork_c8ljc_444{color:#065f46;background:#d1fae5}._typeReview_c8ljc_449{color:#92400e;background:#fef3c7}._typeTest_c8ljc_454{color:#3730a3;background:#e0e7ff}._typeMerge_c8ljc_459{color:#9d174d;background:#fce7f3}._sectionModel_c8ljc_466{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-family:var(--mc-font-mono)}._sectionTime_c8ljc_472{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);margin-left:auto}._sectionCost_c8ljc_478{font-size:var(--mc-font-size-xs);color:var(--mc-success);padding:0 var(--mc-space-1);font-weight:500}._costSummary_c8ljc_485{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);text-align:right;padding:var(--mc-space-1) var(--mc-space-2);font-weight:500}._sectionStatus_c8ljc_493{border-radius:50%;flex-shrink:0;width:8px;height:8px}._statusRunning_c8ljc_500{background:var(--mc-success);animation:2s infinite _pulse_c8ljc_1}._statusCompleted_c8ljc_505{background:var(--mc-text-muted)}._statusFailed_c8ljc_509{background:var(--mc-error)}@keyframes _pulse_c8ljc_1{0%,to{opacity:1}50%{opacity:.5}}._sectionPreview_c8ljc_519{padding:var(--mc-space-2) var(--mc-space-4);font-size:var(--mc-font-size-xs);font-family:var(--mc-font-mono);color:var(--mc-text-muted);white-space:nowrap;text-overflow:ellipsis;background:var(--mc-bg-main);border-top:1px solid var(--mc-border);line-height:1.4;overflow:hidden}._sectionContent_c8ljc_532{padding:var(--mc-space-4);font-size:var(--mc-font-size-sm);font-family:var(--mc-font-mono);white-space:pre-wrap;word-break:break-word;background:var(--mc-bg-main);color:var(--mc-text-primary);line-height:1.6}._sectionContentConstrained_c8ljc_548{overflow-y:auto}._sectionResizeHandle_c8ljc_553{cursor:row-resize;background:var(--mc-bg-sidebar);border-top:1px solid var(--mc-border);justify-content:center;align-items:center;height:12px;transition:background .1s;display:flex}._sectionResizeHandle_c8ljc_553:hover{background:var(--mc-bg-hover)}._sectionResizeHandle_c8ljc_553:hover svg{opacity:1!important}._unreadDot_c8ljc_572{background:var(--mc-accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}._isolationOverlay_c8ljc_581{z-index:50;background:var(--mc-bg-main);flex-direction:column;display:flex;position:fixed;inset:0}._isolationHeader_c8ljc_590{align-items:center;gap:var(--mc-space-3);padding:var(--mc-space-3) var(--mc-space-6);border-bottom:1px solid var(--mc-border);background:var(--mc-bg-sidebar);display:flex}._isolationClose_c8ljc_599{padding:var(--mc-space-1) var(--mc-space-2);border:1px solid var(--mc-border);border-radius:var(--mc-radius-sm);background:var(--mc-bg-main);color:var(--mc-text-secondary);font-size:var(--mc-font-size-xs);cursor:pointer;transition:all .1s}._isolationClose_c8ljc_599:hover{border-color:var(--mc-text-secondary);color:var(--mc-text-primary)}._isolationContent_c8ljc_615{padding:var(--mc-space-6);font-family:var(--mc-font-mono);font-size:var(--mc-font-size-sm);white-space:pre-wrap;word-break:break-word;flex:1;line-height:1.6;overflow-y:auto}._modalOverlay_c8ljc_627{z-index:50;padding:var(--mc-space-8);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}._modalContent_c8ljc_638{background:var(--mc-bg-main);border-radius:var(--mc-radius-lg);flex-direction:column;width:100%;max-width:800px;max-height:80vh;display:flex;overflow:hidden}._modalHeader_c8ljc_649{padding:var(--mc-space-4) var(--mc-space-6);border-bottom:1px solid var(--mc-border);justify-content:space-between;align-items:center;display:flex}._modalTitle_c8ljc_657{font-size:var(--mc-font-size-md);margin:0;font-weight:600}._modalClose_c8ljc_663{padding:var(--mc-space-1);cursor:pointer;color:var(--mc-text-muted);border-radius:var(--mc-radius-sm);background:0 0;border:none;transition:all .1s}._modalClose_c8ljc_663:hover{color:var(--mc-text-primary);background:var(--mc-bg-hover)}._modalBody_c8ljc_678{padding:var(--mc-space-6);flex:1;overflow-y:auto}._uploadZone_c8ljc_685{border:2px dashed var(--mc-border);border-radius:var(--mc-radius);padding:var(--mc-space-8);text-align:center;cursor:pointer;color:var(--mc-text-muted);transition:all .15s}._uploadZone_c8ljc_685:hover,._uploadZoneActive_c8ljc_696{border-color:var(--mc-accent);color:var(--mc-accent);background:#2563eb0a}._uploadIcon_c8ljc_702{margin-bottom:var(--mc-space-2)}._uploadText_c8ljc_706{font-size:var(--mc-font-size-sm);margin:0}._uploadHint_c8ljc_711{font-size:var(--mc-font-size-xs);margin:var(--mc-space-1) 0 0}._artifactList_c8ljc_716{gap:var(--mc-space-2);margin-top:var(--mc-space-4);flex-direction:column;display:flex}._artifactItem_c8ljc_723{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-3);border:1px solid var(--mc-border);border-radius:var(--mc-radius-sm);font-size:var(--mc-font-size-sm);cursor:pointer;transition:all .1s;display:flex}._artifactItem_c8ljc_723:hover{background:var(--mc-bg-hover)}._artifactName_c8ljc_739{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}._artifactDate_c8ljc_746{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted)}._syncButton_c8ljc_752{align-items:center;gap:var(--mc-space-1);padding:var(--mc-space-1) var(--mc-space-3);font-size:var(--mc-font-size-xs);border:1px solid var(--mc-border);border-radius:var(--mc-radius-sm);background:var(--mc-bg-main);color:var(--mc-text-secondary);cursor:pointer;transition:all .1s;display:inline-flex}._syncButton_c8ljc_752:hover{border-color:var(--mc-accent);color:var(--mc-accent)}._syncButton_c8ljc_752:disabled{opacity:.5;cursor:not-allowed}@keyframes _spin_c8ljc_781{0%{transform:rotate(0)}to{transform:rotate(360deg)}}._spinning_c8ljc_781{animation:1s linear infinite _spin_c8ljc_781}._shadowToggle_c8ljc_786{align-items:center;gap:var(--mc-space-3);padding:var(--mc-space-3) var(--mc-space-4);border:1px solid var(--mc-border);border-radius:var(--mc-radius);margin-top:var(--mc-space-3);display:flex}._shadowLabel_c8ljc_796{flex:1}._shadowTitle_c8ljc_800{font-size:var(--mc-font-size-sm);margin:0;font-weight:500}._shadowDesc_c8ljc_806{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);margin:2px 0 0}._markdownContent_c8ljc_813{font-size:var(--mc-font-size-sm);line-height:1.7}._markdownContent_c8ljc_813 h1{font-size:var(--mc-font-size-lg);margin:var(--mc-space-6) 0 var(--mc-space-3);font-weight:600}._markdownContent_c8ljc_813 h2{font-size:var(--mc-font-size-md);margin:var(--mc-space-5) 0 var(--mc-space-2);font-weight:600}._markdownContent_c8ljc_813 h3{font-size:var(--mc-font-size-base);margin:var(--mc-space-4) 0 var(--mc-space-2);font-weight:600}._markdownContent_c8ljc_813 p{margin:0 0 var(--mc-space-3)}._markdownContent_c8ljc_813 ul,._markdownContent_c8ljc_813 ol{margin:0 0 var(--mc-space-3);padding-left:var(--mc-space-6)}._markdownContent_c8ljc_813 li{margin-bottom:var(--mc-space-1)}._markdownContent_c8ljc_813 code{font-family:var(--mc-font-mono);font-size:var(--mc-font-size-xs);padding:1px var(--mc-space-1);background:var(--mc-bg-hover);border-radius:3px}._markdownContent_c8ljc_813 pre{font-family:var(--mc-font-mono);font-size:var(--mc-font-size-xs);padding:var(--mc-space-3);border-radius:var(--mc-radius-sm);background:var(--mc-bg-sidebar);margin:0 0 var(--mc-space-3);overflow-x:auto}._markdownContent_c8ljc_813 pre code{background:0 0;padding:0}._markdownContent_c8ljc_813 table{border-collapse:collapse;width:100%;margin:0 0 var(--mc-space-3);font-size:var(--mc-font-size-xs)}._markdownContent_c8ljc_813 th,._markdownContent_c8ljc_813 td{padding:var(--mc-space-2) var(--mc-space-3);border:1px solid var(--mc-border);text-align:left}._markdownContent_c8ljc_813 th{background:var(--mc-bg-sidebar);font-weight:600}._markdownContent_c8ljc_813 tr:nth-child(2n){background:var(--mc-bg-hover)}._kbdHint_c8ljc_867{font-size:10px;font-family:var(--mc-font-mono);background:var(--mc-bg-sidebar);border:1px solid var(--mc-border-strong);box-shadow:0 1px 0 var(--mc-border);border-radius:3px;margin-right:4px;padding:1px 5px;display:inline-block}._isolationClose_c8ljc_599:hover ._kbdHint_c8ljc_867{border-color:var(--mc-text-secondary)}._deaconPanel_c8ljc_884{border-top:1px solid var(--mc-border);flex-shrink:0}._deaconHeader_c8ljc_889{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-4);cursor:pointer;transition:background .1s;display:flex}._deaconHeader_c8ljc_889:hover{background:var(--mc-bg-hover)}._deaconTitle_c8ljc_902{font-size:var(--mc-font-size-xs);color:var(--mc-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}._deaconMeta_c8ljc_910{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);margin-left:auto}._deaconActionCount_c8ljc_916{background:var(--mc-accent);color:#fff;text-align:center;border-radius:8px;min-width:16px;padding:0 5px;font-size:10px;line-height:16px}._deaconSpecialists_c8ljc_927{padding:0 var(--mc-space-4) var(--mc-space-2);gap:var(--mc-space-3);display:flex}._deaconSpecRow_c8ljc_933{align-items:center;gap:4px;display:flex}._deaconSpecDot_c8ljc_939{border-radius:50%;flex-shrink:0;width:6px;height:6px}._deaconSpecName_c8ljc_946{font-size:var(--mc-font-size-xs);color:var(--mc-text-secondary)}._deaconSpecFailures_c8ljc_951{color:var(--mc-error);font-size:10px;font-weight:600}._deaconActions_c8ljc_957{padding:0 var(--mc-space-4) var(--mc-space-2);border-top:1px solid var(--mc-border);margin-top:var(--mc-space-1);padding-top:var(--mc-space-2);max-height:120px;overflow-y:auto}._deaconAction_c8ljc_916{color:var(--mc-text-muted);padding:2px 0;font-size:10px;line-height:1.4}._deaconLogToggle_c8ljc_974{padding:var(--mc-space-2) var(--mc-space-4);color:var(--mc-text-muted);cursor:pointer;border-top:1px solid var(--mc-border);align-items:center;gap:6px;font-size:10px;transition:color .15s;display:flex}._deaconLogToggle_c8ljc_974:hover{color:var(--mc-text-secondary)}._deaconLogViewer_c8ljc_991{max-height:200px;padding:var(--mc-space-2) var(--mc-space-4);border-top:1px solid var(--mc-border);font-family:var(--mc-font-mono);background:#00000026;font-size:10px;line-height:1.5;overflow-y:auto}._deaconLogEmpty_c8ljc_1002{color:var(--mc-text-muted);padding:var(--mc-space-2) 0;font-style:italic}._deaconLogEntry_c8ljc_1008{white-space:nowrap;gap:6px;padding:1px 0;display:flex}._deaconLogTime_c8ljc_1015{color:var(--mc-text-muted);flex-shrink:0;min-width:60px}._deaconLogLevel_c8ljc_1021{text-transform:uppercase;flex-shrink:0;min-width:24px;font-weight:600}._deaconLogMessage_c8ljc_1028{color:var(--mc-text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}._sidebarFooter_c8ljc_1036{border-top:1px solid var(--mc-border);padding:var(--mc-space-2) var(--mc-space-4);flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}._versionLabel_c8ljc_1045{color:var(--mc-text-muted);font-size:10px;font-family:var(--mc-font-mono);letter-spacing:.03em}._conversationSection_c8ljc_1056{flex-shrink:0}._conversationHeader_c8ljc_1060{padding:var(--mc-space-1) var(--mc-space-2) var(--mc-space-1) 0;align-items:center;display:flex}._conversationToggle_c8ljc_1066{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-2) var(--mc-space-2) var(--mc-space-4);cursor:pointer;text-align:left;color:var(--mc-text-primary);font-size:var(--mc-font-size-sm);border-radius:var(--mc-radius-sm);background:0 0;border:none;flex:1;font-weight:600;transition:background .1s;display:flex}._conversationToggle_c8ljc_1066:hover{background:var(--mc-bg-hover)}._conversationTitle_c8ljc_1087{flex:1}._conversationAddBtn_c8ljc_1091{cursor:pointer;width:24px;height:24px;color:var(--mc-text-muted);border-radius:var(--mc-radius-sm);margin-right:var(--mc-space-2);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}._conversationAddBtn_c8ljc_1091:hover{background:var(--mc-bg-hover);color:var(--mc-accent)}._conversationList_c8ljc_1112{padding:var(--mc-space-1) 0}._conversationAddForm_c8ljc_1116{padding:var(--mc-space-1) var(--mc-space-3)}._conversationInput_c8ljc_1120{width:100%;padding:var(--mc-space-1) var(--mc-space-2);border:1px solid var(--mc-border-strong);border-radius:var(--mc-radius-sm);font-size:var(--mc-font-size-sm);font-family:var(--mc-font-family);color:var(--mc-text-primary);background:var(--mc-bg-main);box-sizing:border-box;outline:none}._conversationInput_c8ljc_1120:focus{border-color:var(--mc-accent);box-shadow:0 0 0 2px #2563eb26}._conversationError_c8ljc_1138{font-size:var(--mc-font-size-xs);color:var(--mc-error);margin-top:var(--mc-space-1)}._conversationEmpty_c8ljc_1144{padding:var(--mc-space-2) var(--mc-space-4) var(--mc-space-2) var(--mc-space-8);font-size:var(--mc-font-size-xs);color:var(--mc-text-muted)}@keyframes _shimmer_c8ljc_1{0%{background-position:-200px 0}to{background-position:200px 0}}._skeletonList_c8ljc_1156{padding:var(--mc-space-2) var(--mc-space-4) var(--mc-space-2) var(--mc-space-8);flex-direction:column;gap:8px;display:flex}._skeletonItem_c8ljc_1163{background:linear-gradient(90deg, var(--mc-bg-hover) 25%, var(--mc-bg-selected) 50%, var(--mc-bg-hover) 75%);background-size:400px 100%;border-radius:4px;width:100%;height:14px;animation:1.5s ease-in-out infinite _shimmer_c8ljc_1}._conversationItem_c8ljc_1172{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-2) var(--mc-space-2) var(--mc-space-8);cursor:pointer;font-size:var(--mc-font-size-sm);text-align:left;width:100%;color:var(--mc-text-primary);background:0 0;border:none;transition:background .1s;display:flex}._conversationItem_c8ljc_1172:hover{background:var(--mc-bg-hover)}._conversationItem_c8ljc_1172:hover ._conversationArchiveBtn_c8ljc_1191{opacity:1}._conversationItemSelected_c8ljc_1195{background:var(--mc-bg-selected)}._conversationDot_c8ljc_1199{flex-shrink:0}._conversationName_c8ljc_1203{text-overflow:ellipsis;white-space:nowrap;font-family:var(--mc-font-mono);font-size:var(--mc-font-size-xs);flex:1;overflow:hidden}._conversationArchiveBtn_c8ljc_1191{cursor:pointer;width:18px;height:18px;color:var(--mc-text-muted);border-radius:var(--mc-radius-sm);opacity:0;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:opacity .1s,background .1s,color .1s;display:flex}._conversationArchiveBtn_c8ljc_1191:hover{background:var(--mc-bg-hover);color:var(--mc-text-primary)}._conversationArchiveBtnLarge_c8ljc_1237{padding:var(--mc-space-2) var(--mc-space-4);background:var(--mc-bg-hover);color:var(--mc-text-secondary);border:1px solid var(--mc-border);border-radius:var(--mc-radius);font-size:var(--mc-font-size-sm);cursor:pointer;transition:background .1s}._conversationArchiveBtnLarge_c8ljc_1237:hover{background:var(--mc-bg-selected);color:var(--mc-text-primary)}._conversationModelBar_c8ljc_1254{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) var(--mc-space-3);border-bottom:1px solid var(--mc-border);background:var(--mc-bg-secondary);display:flex}._conversationModelLabel_c8ljc_1263{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);font-family:var(--mc-font-mono)}._conversationTerminal_c8ljc_1270{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}._conversationTerminalHeader_c8ljc_1278{align-items:center;gap:var(--mc-space-3);padding:var(--mc-space-3) var(--mc-space-4);border-bottom:1px solid var(--mc-border);background:var(--mc-bg-sidebar);flex-shrink:0;display:flex}._conversationTerminalTitle_c8ljc_1288{font-size:var(--mc-font-size-sm);color:var(--mc-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;align-items:center;gap:6px;font-weight:600;display:flex;overflow:hidden}._spinnerIcon_c8ljc_1306{color:var(--mc-accent);flex-shrink:0;animation:1s linear infinite _spin_c8ljc_781}._conversationTerminalStatus_c8ljc_1312{font-size:var(--mc-font-size-xs);color:var(--mc-text-muted);align-items:center;gap:var(--mc-space-1);display:flex}._conversationTerminalBody_c8ljc_1320{flex-direction:column;flex:1;display:flex;overflow:hidden}._conversationResumeOverlay_c8ljc_1327{justify-content:center;align-items:center;gap:var(--mc-space-4);color:var(--mc-text-secondary);flex-direction:column;flex:1;display:flex}._conversationResumeBar_c8ljc_1337{padding:var(--mc-space-3);border-top:1px solid var(--mc-border);justify-content:center;display:flex}._conversationResumeBtn_c8ljc_1344{padding:var(--mc-space-2) var(--mc-space-4);background:var(--mc-accent);color:#fff;border-radius:var(--mc-radius);font-size:var(--mc-font-size-sm);cursor:pointer;border:none;transition:background .1s}._conversationResumeBtn_c8ljc_1344:hover{background:var(--mc-accent-hover)}._conversationResumeBtn_c8ljc_1344:disabled{opacity:.6;cursor:not-allowed}._viewToggle_c8ljc_1365{background:var(--mc-bg-hover);border:1px solid var(--mc-border);border-radius:var(--mc-radius-sm);flex-shrink:0;align-items:center;gap:2px;padding:2px;display:flex}._viewToggleBtn_c8ljc_1376{padding:3px var(--mc-space-3);font-size:var(--mc-font-size-xs);cursor:pointer;color:var(--mc-text-secondary);background:0 0;border:none;border-radius:3px;font-weight:500;transition:background .1s,color .1s}._viewToggleBtn_c8ljc_1376:hover{background:var(--mc-bg-sidebar);color:var(--mc-text-primary)}._viewToggleBtnActive_c8ljc_1393{background:var(--mc-bg-sidebar);color:var(--mc-text-primary);box-shadow:0 1px 2px #0000000f}._conversationView_c8ljc_1400{flex-direction:column;flex:1;display:flex;overflow:hidden}._conversationEmptyState_c8ljc_1408{justify-content:center;align-items:center;gap:var(--mc-space-3);padding:var(--mc-space-8);color:var(--mc-text-secondary);flex-direction:column;flex:1;display:flex}._conversationEmptyStateTitle_c8ljc_1419{color:var(--mc-text-primary);text-align:center;font-size:20px;font-weight:600}._conversationEmptyStateSubtitle_c8ljc_1426{font-size:var(--mc-font-size-sm);color:var(--mc-text-muted);text-align:center}._conversationConnecting_c8ljc_1432{justify-content:center;align-items:center;gap:var(--mc-space-3);color:var(--mc-text-secondary);font-size:var(--mc-font-size-sm);flex-direction:column;flex:1;display:flex}._messagesTimeline_c8ljc_1445{padding:var(--mc-space-6) var(--mc-space-4) var(--mc-space-4);gap:var(--mc-space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}._messagesTimelineInner_c8ljc_1454{gap:var(--mc-space-3);flex-direction:column;width:100%;max-width:760px;margin:0 auto;display:flex}._userMessageRow_c8ljc_1464{justify-content:flex-end;padding:2px 0;display:flex}._userMessageBubble_c8ljc_1470{background:var(--mc-bg-selected);max-width:80%;padding:var(--mc-space-3) var(--mc-space-4);border-radius:18px 18px 4px}._userMessageText_c8ljc_1477{font-size:var(--mc-font-size-base);white-space:pre-wrap;word-break:break-word;margin:0;line-height:1.5}._assistantMessageRow_c8ljc_1486{max-width:100%;padding:2px 0}._messageTimestamp_c8ljc_1492{color:color-mix(in srgb, var(--mc-text-secondary) 30%, transparent);font-size:10px}._messageMetadata_c8ljc_1498{margin-top:var(--mc-space-1);align-items:center;gap:4px;padding-left:2px;display:flex}._messageSeparator_c8ljc_1506{color:color-mix(in srgb, var(--mc-text-secondary) 30%, transparent);font-size:10px}._workLogGroup_c8ljc_1512{border:1px solid var(--mc-border);border-radius:var(--mc-radius);padding:var(--mc-space-2) var(--mc-space-3);background:var(--mc-bg-hover);flex-direction:column;gap:4px;display:flex}._workLogEntry_c8ljc_1522{align-items:flex-start;gap:var(--mc-space-2);font-size:var(--mc-font-size-sm);color:var(--mc-text-secondary);min-height:20px;display:flex}._workLogTerminalIcon_c8ljc_1531{font-family:var(--mc-font-mono);flex-shrink:0;margin-top:1px;font-size:10px;font-weight:700;line-height:1}._workLogLabel_c8ljc_1540{color:var(--mc-text-primary);flex-shrink:0;font-weight:500}._workLogDetail_c8ljc_1546{color:var(--mc-text-muted);font-family:var(--mc-font-mono);font-size:var(--mc-font-size-xs);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}._workLogResult_c8ljc_1556{background:var(--mc-bg-secondary,#0003);font-family:var(--mc-font-mono);font-size:var(--mc-font-size-xs);color:var(--mc-text-secondary);white-space:pre-wrap;word-break:break-word;border-radius:4px;max-height:200px;margin:2px 0 4px 18px;padding:6px 8px;line-height:1.4;overflow-y:auto}._workLogExpandBtn_c8ljc_1571{cursor:pointer;color:var(--mc-accent);font-size:var(--mc-font-size-xs);background:0 0;border:none;align-self:flex-start;align-items:center;gap:4px;padding:2px 0;display:flex}._workingIndicator_c8ljc_1585{align-items:center;gap:var(--mc-space-2);padding:var(--mc-space-2) 0;color:var(--mc-text-muted);font-size:var(--mc-font-size-sm);display:flex}._workingDots_c8ljc_1594{gap:3px;display:flex}._workingDots_c8ljc_1594 span{background:var(--mc-text-muted);border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite _workingDotBounce_c8ljc_1}._workingDots_c8ljc_1594 span:nth-child(2){animation-delay:.2s}._workingDots_c8ljc_1594 span:nth-child(3){animation-delay:.4s}@keyframes _workingDotBounce_c8ljc_1{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}._workingLabel_c8ljc_1615{font-size:var(--mc-font-size-xs)}._chatMarkdown_c8ljc_1621{font-size:var(--mc-font-size-base);color:var(--mc-text-primary);word-break:break-word;line-height:1.6}._chatMarkdown_c8ljc_1621 p{margin:0 0 var(--mc-space-2)}._chatMarkdown_c8ljc_1621 p:last-child{margin-bottom:0}._chatMarkdown_c8ljc_1621 ul,._chatMarkdown_c8ljc_1621 ol{margin:var(--mc-space-2) 0;padding-left:24px}._chatMarkdown_c8ljc_1621 li{margin:2px 0}._chatMarkdown_c8ljc_1621 h1,._chatMarkdown_c8ljc_1621 h2,._chatMarkdown_c8ljc_1621 h3{margin:var(--mc-space-3) 0 var(--mc-space-2);color:var(--mc-text-primary);font-weight:600}._chatMarkdown_c8ljc_1621 h1{font-size:var(--mc-font-size-lg)}._chatMarkdown_c8ljc_1621 h2{font-size:var(--mc-font-size-md)}._chatMarkdown_c8ljc_1621 h3{font-size:var(--mc-font-size-base)}._chatMarkdown_c8ljc_1621 blockquote{border-left:3px solid var(--mc-border-strong);margin:var(--mc-space-2) 0;padding-left:var(--mc-space-3);color:var(--mc-text-secondary)}._chatMarkdown_c8ljc_1621 table{border-collapse:collapse;width:100%;font-size:var(--mc-font-size-sm);margin:var(--mc-space-2) 0}._chatMarkdown_c8ljc_1621 th,._chatMarkdown_c8ljc_1621 td{border:1px solid var(--mc-border);padding:var(--mc-space-1) var(--mc-space-2);text-align:left}._chatMarkdown_c8ljc_1621 th{background:var(--mc-bg-hover);font-weight:600}._chatMarkdown_c8ljc_1621 code:not(pre code){font-family:var(--mc-font-mono);background:var(--mc-bg-hover);border:1px solid var(--mc-border);border-radius:3px;padding:0 4px;font-size:.9em}._codeBlock_c8ljc_1668{margin:var(--mc-space-2) 0;border-radius:var(--mc-radius);border:1px solid var(--mc-border);position:relative;overflow:hidden}._codeBlock_c8ljc_1668:hover ._copyButton_c8ljc_1676{opacity:1}._copyButton_c8ljc_1676{top:var(--mc-space-2);right:var(--mc-space-2);z-index:1;background:var(--mc-bg-sidebar);border:1px solid var(--mc-border);border-radius:var(--mc-radius-sm);cursor:pointer;opacity:0;color:var(--mc-text-secondary);align-items:center;padding:3px 6px;transition:opacity .15s;display:flex;position:absolute}._copyButton_c8ljc_1676:hover{color:var(--mc-text-primary)}._shikiOutput_c8ljc_1697{font-size:var(--mc-font-size-sm);overflow-x:auto}._shikiOutput_c8ljc_1697 pre{padding:var(--mc-space-3) var(--mc-space-4)!important;background:var(--mc-bg-hover)!important;margin:0!important}._codePlain_c8ljc_1708{padding:var(--mc-space-3) var(--mc-space-4);background:var(--mc-bg-hover);font-family:var(--mc-font-mono);font-size:var(--mc-font-size-sm);white-space:pre;margin:0;overflow-x:auto}._mdLink_c8ljc_1718{color:var(--mc-accent);text-underline-offset:2px;text-decoration:underline}._mdFallback_c8ljc_1724{font-family:var(--mc-font-mono);font-size:var(--mc-font-size-sm);white-space:pre-wrap;word-break:break-word;margin:0}._composerFooter_c8ljc_1735{padding:var(--mc-space-3) var(--mc-space-4) var(--mc-space-4);flex-shrink:0}._composerBox_c8ljc_1741{border:1px solid var(--mc-border);border-radius:var(--mc-radius-lg);background:var(--mc-bg-main);flex-direction:column;max-width:760px;margin:0 auto;transition:border-color .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #0000000f}._composerBox_c8ljc_1741:focus-within{border-color:var(--mc-accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--mc-accent) 12%, transparent)}._composerBoxDisabled_c8ljc_1758{opacity:.6;pointer-events:none}._composerEditor_c8ljc_1764{min-height:60px;max-height:200px;padding:var(--mc-space-3) var(--mc-space-3) var(--mc-space-2);position:relative;overflow-y:auto}._composerEditorDisabled_c8ljc_1772{opacity:.6;pointer-events:none}._composerEditable_c8ljc_1777{min-height:36px;color:var(--mc-text-primary);font-size:14px;line-height:1.5;font-family:var(--mc-font-family);outline:none}._composerEditable_c8ljc_1777 p{margin:0}._composerPlaceholder_c8ljc_1788{top:var(--mc-space-3);left:var(--mc-space-3);color:var(--mc-text-muted);pointer-events:none;-webkit-user-select:none;user-select:none;font-size:14px;position:absolute}._slashMenu_c8ljc_1799{z-index:1000;background:var(--mc-bg-main);border:1px solid var(--mc-border);border-radius:var(--mc-radius);min-width:280px;max-width:320px;padding:var(--mc-space-1);position:fixed;overflow:hidden;box-shadow:0 4px 12px #0000001f}._slashMenuItem_c8ljc_1812{width:100%;padding:var(--mc-space-2) var(--mc-space-3);cursor:pointer;border-radius:var(--mc-radius-sm);text-align:left;background:0 0;border:none;flex-direction:column;align-items:flex-start;gap:2px;display:flex}._slashMenuItem_c8ljc_1812:hover,._slashMenuItemSelected_c8ljc_1827{background:var(--mc-bg-hover)}._slashMenuLabel_c8ljc_1831{font-size:var(--mc-font-size-base);font-family:var(--mc-font-mono);color:var(--mc-text-primary);font-weight:500}._slashMenuDescription_c8ljc_1838{font-size:var(--mc-font-size-sm);color:var(--mc-text-secondary)}._composerToolbar_c8ljc_1844{padding:0 var(--mc-space-2) var(--mc-space-3);align-items:center;gap:0;display:flex}._composerToolbarSpacer_c8ljc_1851{flex:1}._composerToolbarDivider_c8ljc_1856{background:var(--mc-border-strong);opacity:.5;width:1px;height:16px;margin:0 var(--mc-space-1);flex-shrink:0}._sendButton_c8ljc_1866{background:var(--mc-accent);color:#fff;border-radius:var(--mc-radius);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .1s;display:flex}._sendButton_c8ljc_1866:hover:not(:disabled){background:var(--mc-accent-hover)}._sendButton_c8ljc_1866:disabled{opacity:.4;cursor:not-allowed}._pickerContainer_c8ljc_1891{position:relative}._pickerBtn_c8ljc_1895{font-size:var(--mc-font-size-sm);border-radius:var(--mc-radius-sm);color:var(--mc-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:4px 8px;display:flex}._pickerBtn_c8ljc_1895:hover:not(:disabled){background:var(--mc-bg-hover);color:var(--mc-text-primary)}._pickerBtn_c8ljc_1895:disabled{opacity:.5;cursor:not-allowed}._pickerHint_c8ljc_1919{color:var(--mc-text-muted);padding:4px var(--mc-space-2);font-size:10px;font-style:italic}._pickerLabel_c8ljc_1926{font-size:var(--mc-font-size-sm)}._pickerProviderIcon_c8ljc_1931{flex-shrink:0;width:14px;height:14px}._pickerDropdown_c8ljc_1937{z-index:9999;background:var(--mc-bg-main);border:1px solid var(--mc-border);border-radius:var(--mc-radius);flex-direction:column;min-width:260px;max-width:calc(100vw - 16px);padding:4px;display:flex;position:fixed;box-shadow:0 4px 20px #0000001f}._pickerOption_c8ljc_1951{padding:var(--mc-space-2) var(--mc-space-3);font-size:var(--mc-font-size-sm);text-align:left;border-radius:var(--mc-radius-sm);cursor:pointer;color:var(--mc-text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;display:flex}._pickerOption_c8ljc_1951:hover{background:var(--mc-bg-hover)}._pickerOptionActive_c8ljc_1970{background:var(--mc-bg-selected);font-weight:500}._pickerGroupHeader_c8ljc_1975{padding:6px var(--mc-space-3) 2px;text-transform:uppercase;letter-spacing:.05em;color:var(--mc-text-muted);align-items:center;gap:6px;font-size:10px;font-weight:600;display:flex}._pickerGroupNoKey_c8ljc_1988{text-transform:uppercase;letter-spacing:.04em;background:color-mix(in srgb, var(--color-warning,#f59e0b) 12%, transparent);color:var(--color-warning,#f59e0b);border:1px solid color-mix(in srgb, var(--color-warning,#f59e0b) 22%, transparent);border-radius:3px;padding:1px 4px;font-size:9px;font-weight:600}._pickerGroupDisabled_c8ljc_2001{opacity:.45;pointer-events:none}._pickerOptionLabel_c8ljc_2006{text-align:left;white-space:nowrap;flex:1}._pickerCostBadge_c8ljc_2012{color:var(--mc-text-muted);white-space:nowrap;flex-shrink:0;font-size:10px}._pickerAuthBadge_c8ljc_2020{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;background:color-mix(in srgb, var(--color-primary,#6366f1) 18%, transparent);color:var(--color-primary,#6366f1);border:1px solid color-mix(in srgb, var(--color-primary,#6366f1) 30%, transparent);border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}._pickerAuthBadgeWarn_c8ljc_2034{white-space:nowrap;background:color-mix(in srgb, var(--color-warning,#f59e0b) 15%, transparent);color:var(--color-warning,#f59e0b);border:1px solid color-mix(in srgb, var(--color-warning,#f59e0b) 25%, transparent);border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:600}._restartPopover_c8ljc_2048{z-index:100;background:var(--mc-bg-primary);border:1px solid var(--mc-border);width:240px;padding:var(--mc-space-2);border-radius:6px;margin-top:4px;position:absolute;top:100%;right:0;box-shadow:0 4px 12px #0000004d}._restartPopoverTitle_c8ljc_2062{font-size:var(--mc-font-size-sm);color:var(--mc-text-primary);padding:2px 4px;font-weight:600}._restartPopoverDivider_c8ljc_2069{background:var(--mc-border);height:1px;margin:var(--mc-space-1) 0}._restartPopoverLabel_c8ljc_2075{cursor:pointer;font-size:var(--mc-font-size-sm);color:var(--mc-text-primary);border-radius:4px;align-items:center;gap:6px;padding:4px;transition:background .1s;display:flex}._restartPopoverLabel_c8ljc_2075:hover{background:var(--mc-bg-hover)}._restartPopoverLabel_c8ljc_2075 input[type=checkbox]{accent-color:var(--mc-accent);margin:0}._restartPopoverCount_c8ljc_2096{color:var(--mc-text-muted);font-size:var(--mc-font-size-xs);margin-left:auto}._restartPopoverActions_c8ljc_2102{justify-content:flex-end;gap:6px;padding-top:2px;display:flex}._restartPopoverCancel_c8ljc_2109{font-size:var(--mc-font-size-xs);color:var(--mc-text-secondary);border:1px solid var(--mc-border);cursor:pointer;background:0 0;border-radius:4px;padding:3px 10px;transition:background .1s}._restartPopoverCancel_c8ljc_2109:hover{background:var(--mc-bg-hover)}._restartPopoverConfirm_c8ljc_2124{font-size:var(--mc-font-size-xs);color:#fff;background:var(--mc-accent);cursor:pointer;border:none;border-radius:4px;padding:3px 10px;transition:opacity .1s}._restartPopoverConfirm_c8ljc_2124:hover{opacity:.9}._restartPopoverConfirm_c8ljc_2124:disabled{opacity:.5;cursor:not-allowed}._restartPopoverError_c8ljc_2144{color:var(--mc-error);font-size:var(--mc-font-size-xs);margin-top:2px;padding:4px}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-vietnamese-400-normal-B7xT_GF5.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-400-normal-BIWiOVfw.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-latin-ext-400-normal-CfP_5XZW.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-400-normal-DRPE3kg4.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-grotesk-latin-400-normal-CJ-V5oYT.woff2)format("woff2"),url(/assets/space-grotesk-latin-400-normal-BnQMeOim.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-vietnamese-600-normal-DUi7WF5p.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-600-normal-D6zpsUhD.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-ext-600-normal-DxxdqCpr.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-600-normal-VcznFIpX.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-600-normal-DjKNqYRj.woff2)format("woff2"),url(/assets/space-grotesk-latin-600-normal-BflQw4A9.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-vietnamese-700-normal-DMty7AZE.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-700-normal-Duxec5Rn.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-ext-700-normal-BQnZhY3m.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-700-normal-HVCqSBdx.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-700-normal-RjhwGPKo.woff2)format("woff2"),url(/assets/space-grotesk-latin-700-normal-CwsQ-cCU.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAASIABAAAAAACQQAAAQuAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGhwbHhwoBmA/U1RBVF4AdBEICoRkhAALIAABNgIkAzoEIAWFAAeBFAwHG2oHKJ6DceNW4lJEFHn9tEOE37LNsvkjHr7f739rn3u+OSrSxLQytE91Dw2PYtNVq3Qaw/vJ7fUBMdOj/u2ImB98cT5WUx9F13ZKt06mU7tG1sAYcM26yCRX4f/0904bmwq8hwkUUMTRX61pa9C3xlpAGYw1vOu8C2SBZZFlld7DAW82RJWmwYMI1AJCKBNCIASqdZGFmtPSNQRhMpR0EKjWTwm6z6sJ+4jqhxjovTinVdRpZaQjaQzAYjI8NgAKDJCokgunCn9oUQE8VZd/F//+v6P4F1U9gLr58yNI/dJX9BAshEoJbTDogz7ocKoUsPvES8UK/aQIUQgpGgECBVLkOEV6iASTYgNAPKdNXayhDPL7IJuAZnEYSZ0eOLc9i5Rv5/+lEi3sW/kfnCf/+fTe0sxS7CKLx5erRJkKOixEqQaoqrvx5HN4iz4VhX0gS6DjFIWUzn/fIXJRVFY1NFRVNVeFt+SYmrK6vCU6eJsnKnJj5HTESMTQZOTI3Y/tzr3rUcOsiRy/ciP50s3Mycgxmhz9GMXhjzVH30ut796NHP0UUa31/Zoa6vCH6iPvdIM0IRANaT60FablmZlZd+UKNFy9NrvnFGxb5NC2CRxR0/rIyF/WNn+35sv9r+tHVhkseuWGKkCPPh96+GXt8Lc/Sh24ujfjf+tNw1lZWreiPuHb/PSpyjdv2rf/++ZE5TSKjFdZxYsBvr1sEHl5STuHZqYR7jGYGvGBBdjcaB5bODY1GAxMjsd0wDMIzXAXODRd74DxNMtO4YuYHclgLQRzp9KlUmxptCwv9bYgvWGD2xBW7r9413fdJu+mxzvzAUYeeONQvZP4kgfqZle4jhH/MWh+UbxgtJdrLdXLymNL53PRU0D3Q6FcXTfGqGcul6vrqhgLGAVSv+IVIfZOHpu+mlLqSlnj903j8mazXDsba/wbxhS/4Oubh1c5/uXDgt4j5KtnGEy5BIJHo0ur+jD+r2qCkuP1aRVM8EpUoRYSJyqNRA38uwDvHBNo0AejO2Z+ZYLLal1QiFyFh1EDQOgSCSCpjwwKU8yDbIjroEwne0G5Qca49cYp4AlqtQNZfWTQoFb1tRpFYAmRD+HXTkV4uQhG2bg4OKmyoypAsUGtWgQXyFxYrkpODeUxvGqIZA61erXo0sFG1UBGuPgpuon8RNUG2DhovAjZCBuZwtXrU3mQGki9+pm0eVZAXoWxLWTQoYHBPrJR4WunNxIFbCHfkTyPK+sqxjxDmGArZvf79JGJ3GwEqjwc7a7NIrl/7bJ7Nzu4+n1Ow6shEPnUrtVo7cnd5Wi5qCUbBIQbNKCP95FMCSZylEV5VCiiMqqiOmrKZ/I/C0gI1fyuulVcM2E1r4MhtcV/fbCD+HwEvVzH1dGNAzFE0FTbKzyQz3gootrNbN2a4PuG0j0JOgE=)format("woff2"),url(data:font/woff;base64,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)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/jetbrains-mono-cyrillic-400-normal-BEIGL1Tu.woff2)format("woff2"),url(/assets/jetbrains-mono-cyrillic-400-normal-ugxPyKxw.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/jetbrains-mono-greek-400-normal-C190GLew.woff2)format("woff2"),url(/assets/jetbrains-mono-greek-400-normal-B9oWc5Lo.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA9UABAAAAAALMAAAA7zAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGnAbhWocghYGYD9TVEFUXgCDBBEICrBAp3ILgjgAATYCJAOEKAQgBYUAB4xODAcbIiYzo8LGAQCKfn4o/usELQ4rdj22ABHwitFYjZPqB3XSqAbV3C5dFkHYtTehxpeGbU+3+QexdERCkxARw9oNxAyetvXzdhdjl/7aiBiHgcqBjZywaGPSh4mNFccpF3DHlfyO8Jc/OiSe/kb7/iQYRAE23iScpHngiRRBFETNiZzQwc2HOllJ0fqXIjTY8RTYbDsklKc81hGPQcOJojhD/w80ll1aG/qiQErbzqOXjmvOVKd14tuv+Hxrlbarq/5xH7CiMPjaZXlrfNSp7uqaroZXvYAzc8A0kH2zs3MvHQBUORcJ2GG2cdFRgArh+Sgb7yOsjImpmgM0kq1FwhQCQzQ1Mt+j7at5GSAAIQAAKFLk6uMul4pIl4HIpEEUK0dUMiCMmhFWNoSDC+Exghgzi5i3hNhtN9qaINo+EbQj1tEIgJVLj5oebQ6I1/fyLMQYALYgALKS0yEOQCJG89uIiEPKyeRDVCmC0HgZ203jIg7kk6cHxfEKeBSDXtxd6n5yJzqpfSgXs9xMri1fPezlKMAVcCGEIhmwHiDRtJOyKfXkGsAVqI7ohIZs0rsDM/IU4fuQgkppCk2n+VRHy6mFttJ26t16mBjQPyIeYhvZnyXaiDSeaAYYXLiKPIm4uKh1zIq6gSRVU7WNPIV5v1PwBOy07RrrT6skwoEAtYyZeYgpBUABaDEmtPWRGP/UGABFgUUjchFXAghAgAYQpyPkCIBBoRwQgU/g3kQcyqTY9KSDItmjjmmkP+qJHG3C66hjXhtlhzwglI+1+4Be+T77hYQxxeNkCIDaKU+ANXhkMqePOVAQr7uwCjoBlCdtHQE8TNRd17//A/evkhSpkOMDA9VTmwAVAbLNlwMkoAG5qG2bWCYA/h3uEYgEhFqSmJJPpCIFbJHg1Aw5GaAujjqMzIHc8NrIHBEJJjGZP3cuFQZD9PvzLvZIaCIjBcTvEnIzTWiGjqdzlD+VAO2TUERK8smEi8lNNOguiAM9P6Gfo6bX8bD0v7V/cPwA/fDBi0BaGgUllWy5AATy6X9gAZqRVIsMLuVmqQ3QmrBbiFgTiWbxLDj1hBqINGLVYewQwySWWRyeQK1kXVJ0S2UjZ5WgXaIOSTodp42CUzqHXH226ZfJI4tXth45eqnslGdQgSGFhmmMyOdTbEyJcdv56U0pNa3MDJ1JVRZUmldtkcESglQkAOA8AMgAoBeYLQi+wDxAtwAAGlXJUdVLPLmo/TLRystE3SsqO29LUY0hsrtvBoXUw1Fy+XjIhqbj4rEZISsUysW1L68PlGRwyWImjWXjS9LFyUzjC7v7Z5hYsYKRhIH49EyxTJxutwOy2PRxp1R63SVViB+eNFYRywlEzJBIMDIl5Aa4PtbFOno416WTTkfVQwSPgIve66BCbLAuLmpCh59ln5uFECODSuUIJ2CJCCzDwbf+DV2/3yTtan5J1gEVuilcVASHULO9Bt+nWkIEHMMit5gOxaO4JpWjvdzOcySeFek9q4dy3jxi2BxHwsuuo2CzbQ+KJWxyqPUJljVCU3WT8JwlhZyLkKODRhZkQByHu8ERJIcGBexSmdwGPfMPbjnC0SwRUTyCAIwY4Mdr9zxJTKE5yp0mcEe9s3Umm/TZp2s4X/27cQUmhrd4Ow4ibPOTOxxT6w+S8ENc9AGE7meFOlNbuzjngJtzjFKcrMsxtf4G4UIPcNGXbvwNaeDea6+1L7kaYG+M13a455pruOh5Ww0HlhllPy/PsqS9Zr7ZV9cSLODAoItzBt2cI5i1brCxQRIcH6yr9wV5+XjhtlxuziH7LiqGTXVnkfCZntd1doJ5liyIno6X3GqH56fcnGNwE2IXvYhw5a/MJGsMns/TOawd+2HX5kOXxQZFsYkwmMetzGtqKDKSe+h9h7jX77z2Snb98vyL7rjmil1N3B/cCBfsC5rymA/ExpPlni/DL9i7eflmn66oxrSlMRRB/8Dbq/e/3aN95L3BG+dFd1d+uCVzKhQy5/+I77CmWJ/o2Hygaay8yleXU1c1NH2IpqHOYUtriyWHf3iZwxjZvNxm/Ti/O5+22uC3nVFxhu1wvQc08ZZ+nb5/9oBF38ehJXaKPt7K6/v34Ltqai21rbXDXI3BRDa+9XDSGp8gzZZarV2ag9v3RBzSNfFjU/M+uVduNDTsMNY0GCOHDU3O4dazeb3zFXjg0rlPuiV75+m+kzV3v5qc/PHdJ2j6pI+wDP+U7mFPW/uw23ltZemTVTo+3+KNa1yyuwdmfI41j1/yvbG3oaLR3G3Sd1xdrNOUfAou3jYw0z860D9jr+9sqU1IIHve9W56/fIEU2fztvaqHQ213trhKauqjXVmr/kFxP1m7bdCE88Plpb1m840l/VNQz72QvvMPlc5z9fvKPt1xBtXv9yVZ9nGmxscXiDfwGcI4LQ9duBaG7Nxjw2aWMuArp7In2qxObTwKfr40/iy/j34zhqeN59qHuZqDBaysQWiL/PZsk4cyV13mvbwWw7phfEDC/O+fm9/ram+sspcXxs5hm9pHjufSujGRbKXaTPmBAPPfMm45bau15+jR/bbBx80mR7sCth94rfB6Q6sngJcuO1v4a7Lu157ad9GKIlypuEea9GDnXs0IytDmZ2Rka2cVv4jrIHmaFZ3O9OWlWX7gLuRH1mMjsxE8VrEH/XNRrErsh61R6PD3e2d7dDsb3Z38k15W/kFkrwmHk+PhWNKx3nLMhHkSl5ZLMvHWPGPfwRB9AKr2QoSUb4qSlB18X715zkqwRI0G3lvUOptugtcID+tsKQForrC+pqxS4X1dcof21bf4OQcbZ2Le6y53kKao3rxNWE9f1a+S3t2tiIu5yej2d/W12RozBwrLh7LbDT0NkUDi+HBQPj0xIlAoKHFFxAMPB8Vce+KKo28Rq0SHV3LUk6MNLv35DMrCzVNmbxBeCGCKzMtu20y8f+SVD4h31Sosky03Upl9YJxzh+L0ZFANLR4LOpYj452tne145E/wok2e6JX/xBX/vH8WaFQojdWlrhzuOXjs1Zn3cCkT4qWSmZeqX/B4tciE4HBmUBZwGxtMDaqnCpdllPVaIzdNw9ZqfDU30ppYDgw2B+A5JP5L8bj4tgWoy/t6WRRcO2P8uFDakiP2fMWaviyaOYFr94gE0nEsXysWligOuHRC2TiH0XSJ/4WqQcjE4GxmUAocKlG+jECgZHFwGX8vabVzf8f4KQSi8Gp6laIdgV0q8OzbmjyaWdnW1MQXZoJDb7ZaEdzVzMoNQiAGESUwszDAIzTDIqSxGFoxoRZ/vTKM8CfyZ9V/ZAPfzZ/Ds4tMHm0dSxCkOPaNpKlK8/KwGQVCdzqbPDn1HKuiT8WHUnStEQYZB2TC6WJ6spymNIjBV7JK5lSs1C5qDoRSYBUSlgH31LlM7X5O4o8eBxrX3MDwtOG1iZdZ/NjXsu0gBJohRVmlQNfwVfQmsReAdZEAahljqkMaxLHg/gT+BONkwxcgT0CH/5k/pQrcCpMUYiGtPqbDGvVgALfitYyTHyI7iP25WqsSqAlstCbcmZ3k0PcRZlgbs0KCrwb7lImBTqQCCawVEpMWHur0DRm3+9sVAOK6UQiqESr8NaEtY8Vu86AIjK3KRZhXNwqD34Oc38umLZM7/33+38/uOj7///Z9yMAAHqAUtN3Bsa/l9rSiKVxlONqqbKozYWfYMRMRkicEE2FhIs4TuWQJL0RDNwCPy0hP1CbGAVY9Mb6W+DZ2p14CIQoIBjqGKpe6lOONhDJTUFBXMgZYOPct8C7Ffmf2jR2ksQ72U7f6SBu5gywoW8x2Qhy1APl1CZGAQ4ksGGD8loGsjY0UQKXmhdvpBboCNglmiU2XUCieL2dF1bDaTacoykaTjgFAhquyoFkiSk0LZyooeM7gQDVIlmNOwCPlICNKQpatkhBhUQJpdLCVwFqWj3FQ8sWeajTWbJiLeRJQlRmsyh1YLRZtAzVNr0dAoCqYN6wXLhzQGL8LY6mvwSAd1698ly88s2Xfwa7FbVA/wsgBhQAgABfG3dQHs2o/066DhB0wWo68NIlpR8Rtqkj9flbwtMc3oZyWoIn3n+L86o5vA1V8ng6L4C9+Ax3YgMBHN8Er4rV97ZRXgdo2vF244hH35wAzlOM0Y1BABGNnNCZ4UFNPID7U9KeSCgiP5EiDnMizejpExlFzj9RIM2BE2MU8pwgViH7TAQQSqpgnDuJJAk2kHIaYDNnhs+sFsvBuaf5DXMbXT9uwvLIbk49b4mBNm3JsEV+85YtKUHWb5rT5ywap9WpUZtWo6q5Fot8W89a0m4OaXOK2Ywat2KaD3NdRi1S/+eloldCT0fn1K5q61Mpa6eaNrKMB6WMQqn83IfXmTNv1eIRiaKj7aOsikMmoxej+EfqsmjOpFHDLnneylGLQxT66vnHnh/n12VXDN1Hw6/bcNpctWo3vrwApZvfrdEDiP8IzgPkeiYUoQlzDvYWB0cnZ6uLq5t7+aRk5I6TIFGS5IqkSJWWXjqFDEqZVLJky5FrG7W8quQrUEijSLESWtsz0tErVVa9chUqValmUMNoh1omZjxSM4s69Ro0atKspTe1smrLpl2HTl262dg5OLm4eezMw6tHrz79BgzyGarXsBGjxqJtJvhNmjJtxqw58xYsWrJsxS4Bu61aE7THXvvsFxJ2wEERhxx2xFHHrIs6fuE/r+1vm6/8jhhtDCwnASDGR1h4SGhYwEGU1Y/Xffk5G4u9XgIAYtxyGpZ5y9sDdNbyP142W5DgAhoE7i3q0c5x2vm9v24aZuNohdcxqSEAz8up00My03HSwmqPa8bMecG3Tjzb+f9EelEtg2vpzPeiIEEBwSA8IEDBwAE9F5Z6vQIQjAnLGTgWLO+uZTL/qwGEAYOAQpg3TefgwBCQgBDzqukKDBAOoU3KVtqIbBXK9XpEAAujuudkZN724kIGmrtVaS38ZZLrS9/4fsKMQhN3yXK5gvSBvJ2Y9/Nydbcvb0bm58+e3FhmGfGLJ9u7axl1F1LQTbaCeyrbu7wFCsorFgV4qnh+GUrWtaczqkSBB96AEeKRB94k2SyLuyw3qwrxeg3P5FNR1Av1Gsq2/ds6dPPkBAAA)format("woff2"),url(/assets/jetbrains-mono-vietnamese-400-normal-CqNFfHCs.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/jetbrains-mono-latin-ext-400-normal-Bc8Ftmh3.woff2)format("woff2"),url(/assets/jetbrains-mono-latin-ext-400-normal-fXTG6kC5.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/jetbrains-mono-latin-400-normal-V6pRDFza.woff2)format("woff2"),url(/assets/jetbrains-mono-latin-400-normal-6-qcROiO.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.god-view{--gv-bg:#0a0e1a;--gv-surface:#151b2bb3;--gv-surface-solid:#151b2b;--gv-border:#1e2638cc;--gv-border-bright:#00d4ff4d;--gv-blue:#00d4ff;--gv-pink:#ff2d7c;--gv-green:#39ff14;--gv-amber:#ffb800;--gv-purple:#9d4edd;--gv-text-primary:#e8edf8;--gv-text-secondary:#7a8aaa;--gv-text-dim:#4a5a7a;--gv-font-display:"Space Grotesk", system-ui, sans-serif;--gv-font-mono:"JetBrains Mono", "Fira Code", monospace;--gv-blur:blur(12px);--gv-glow-blue:0 0 20px #00d4ff4d;--gv-glow-pink:0 0 20px #ff2d7c4d;--gv-glow-green:0 0 20px #39ff144d;--gv-glow-amber:0 0 20px #ffb8004d;background:var(--gv-bg);color:var(--gv-text-primary);font-family:var(--gv-font-display);height:100%;position:relative;overflow:hidden}.gv-glass{background:var(--gv-surface);-webkit-backdrop-filter:var(--gv-blur);border:1px solid var(--gv-border);border-radius:12px}.gv-status-healthy{color:var(--gv-green)}.gv-status-warning{color:var(--gv-amber)}.gv-status-stuck{color:var(--gv-pink)}.gv-status-dead,.gv-status-stopped{color:var(--gv-text-dim)}@keyframes gv-breathe-blue{0%,to{box-shadow:0 0 8px #00d4ff26}50%{box-shadow:0 0 20px #00d4ff73}}@keyframes gv-breathe-green{0%,to{box-shadow:0 0 8px #39ff1426}50%{box-shadow:0 0 20px #39ff1473}}@keyframes gv-breathe-amber{0%,to{box-shadow:0 0 8px #ffb80026}50%{box-shadow:0 0 20px #ffb80073}}@keyframes gv-breathe-pink{0%,to{box-shadow:0 0 8px #ff2d7c26}50%{box-shadow:0 0 20px #ff2d7c73}}@keyframes gv-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.92)}}@keyframes gv-scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes gv-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes gv-logo-glow{0%,to{filter:drop-shadow(0 0 6px #00d4ff99)}50%{filter:drop-shadow(0 0 14px #00d4ff)}}.gv-breathe-healthy{animation:3s ease-in-out infinite gv-breathe-green}.gv-breathe-warning{animation:2s ease-in-out infinite gv-breathe-amber}.gv-breathe-stuck{animation:1.5s ease-in-out infinite gv-breathe-pink}.gv-breathe-dead{box-shadow:none}.gv-status-pill{letter-spacing:.05em;text-transform:uppercase;border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.gv-status-pill.healthy{color:var(--gv-green);background:#39ff1426;animation:2s ease-in-out infinite gv-pulse}.gv-status-pill.warning{color:var(--gv-amber);background:#ffb80026;animation:1.5s ease-in-out infinite gv-pulse}.gv-status-pill.stuck{color:var(--gv-pink);background:#ff2d7c26;animation:1s ease-in-out infinite gv-pulse}.gv-status-pill.dead,.gv-status-pill.stopped{color:var(--gv-text-dim);background:#4a5a7a33}.gv-mono{font-family:var(--gv-font-mono)}*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{background-color:var(--background);color:var(--foreground);min-height:100vh;margin:0;padding:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}html,body,#root{overscroll-behavior-y:none;width:100%;height:100%;overflow:hidden}.\!container{width:100%!important}.container{width:100%}@media (width>=640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (width>=768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (width>=1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (width>=1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (width>=1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.prose{color:var(--tw-prose-body);max-width:65ch}.prose :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-lead);margin-top:1.2em;margin-bottom:1.2em;font-size:1.25em;line-height:1.6}.prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-links);font-weight:500;text-decoration:underline}.prose :where(strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-bold);font-weight:600}.prose :where(a strong):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(blockquote strong):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(thead th strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em;list-style-type:decimal}.prose :where(ol[type=A]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=A s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=I]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type=I s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type="1"]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal}.prose :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em;list-style-type:disc}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-counters);font-weight:400}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-bullets)}.prose :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.25em;font-weight:600}.prose :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){border-color:var(--tw-prose-hr);border-top-width:1px;margin-top:3em;margin-bottom:3em}.prose :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-quotes);border-inline-start-width:.25rem;border-inline-start-color:var(--tw-prose-quote-borders);quotes:"“""”""‘""’";margin-top:1.6em;margin-bottom:1.6em;padding-inline-start:1em;font-style:italic;font-weight:500}.prose :where(blockquote p:first-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:open-quote}.prose :where(blockquote p:last-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:close-quote}.prose :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:0;margin-bottom:.888889em;font-size:2.25em;font-weight:800;line-height:1.11111}.prose :where(h1 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:900}.prose :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:2em;margin-bottom:1em;font-size:1.5em;font-weight:700;line-height:1.33333}.prose :where(h2 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:800}.prose :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.6em;margin-bottom:.6em;font-size:1.25em;font-weight:600;line-height:1.6}.prose :where(h3 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:700}.prose :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);margin-top:1.5em;margin-bottom:.5em;font-weight:600;line-height:1.5}.prose :where(h4 strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-weight:700}.prose :where(img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em;display:block}.prose :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-kbd);box-shadow:0 0 0 1px var(--tw-prose-kbd-shadows), 0 3px 0 var(--tw-prose-kbd-shadows);padding-top:.1875em;padding-inline-end:.375em;padding-bottom:.1875em;border-radius:.3125rem;padding-inline-start:.375em;font-family:inherit;font-size:.875em;font-weight:500}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-code);font-size:.875em;font-weight:600}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before,.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:"`"}.prose :where(a code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h1 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.875em}.prose :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.9em}.prose :where(h4 code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(blockquote code):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(thead th code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-pre-code);background-color:var(--tw-prose-pre-bg);padding-top:.857143em;padding-inline-end:1.14286em;padding-bottom:.857143em;border-radius:.375rem;margin-top:1.71429em;margin-bottom:1.71429em;padding-inline-start:1.14286em;font-size:.875em;font-weight:400;line-height:1.71429;overflow-x:auto}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:inherit;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit;background-color:#0000;border-width:0;border-radius:0;padding:0}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):before,.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:none}.prose :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){table-layout:auto;width:100%;margin-top:2em;margin-bottom:2em;font-size:.875em;line-height:1.71429}.prose :where(thead):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-th-borders)}.prose :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);vertical-align:bottom;padding-inline-end:.571429em;padding-bottom:.571429em;padding-inline-start:.571429em;font-weight:600}.prose :where(tbody tr):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-td-borders)}.prose :where(tbody tr:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:0}.prose :where(tbody td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:baseline}.prose :where(tfoot):not(:where([class~=not-prose],[class~=not-prose] *)){border-top-width:1px;border-top-color:var(--tw-prose-th-borders)}.prose :where(tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:top}.prose :where(th,td):not(:where([class~=not-prose],[class~=not-prose] *)){text-align:start}.prose :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-captions);margin-top:.857143em;font-size:.875em;line-height:1.42857}.prose{--tw-prose-body:#374151;--tw-prose-headings:#111827;--tw-prose-lead:#4b5563;--tw-prose-links:#111827;--tw-prose-bold:#111827;--tw-prose-counters:#6b7280;--tw-prose-bullets:#d1d5db;--tw-prose-hr:#e5e7eb;--tw-prose-quotes:#111827;--tw-prose-quote-borders:#e5e7eb;--tw-prose-captions:#6b7280;--tw-prose-kbd:#111827;--tw-prose-kbd-shadows:#1118271a;--tw-prose-code:#111827;--tw-prose-pre-code:#e5e7eb;--tw-prose-pre-bg:#1f2937;--tw-prose-th-borders:#d1d5db;--tw-prose-td-borders:#e5e7eb;--tw-prose-invert-body:#d1d5db;--tw-prose-invert-headings:#fff;--tw-prose-invert-lead:#9ca3af;--tw-prose-invert-links:#fff;--tw-prose-invert-bold:#fff;--tw-prose-invert-counters:#9ca3af;--tw-prose-invert-bullets:#4b5563;--tw-prose-invert-hr:#374151;--tw-prose-invert-quotes:#f3f4f6;--tw-prose-invert-quote-borders:#374151;--tw-prose-invert-captions:#9ca3af;--tw-prose-invert-kbd:#fff;--tw-prose-invert-kbd-shadows:#ffffff1a;--tw-prose-invert-code:#fff;--tw-prose-invert-pre-code:#d1d5db;--tw-prose-invert-pre-bg:#00000080;--tw-prose-invert-th-borders:#4b5563;--tw-prose-invert-td-borders:#374151;font-size:1rem;line-height:1.75}.prose :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;margin-bottom:.5em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(.prose>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(.prose>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(.prose>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;padding-inline-start:1.625em}.prose :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.571429em;padding-inline-end:.571429em;padding-bottom:.571429em;padding-inline-start:.571429em}.prose :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(.prose>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(.prose>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.prose-sm{font-size:.875rem;line-height:1.71429}.prose-sm :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em;margin-bottom:1.14286em}.prose-sm :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.888889em;margin-bottom:.888889em;font-size:1.28571em;line-height:1.55556}.prose-sm :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.33333em;margin-bottom:1.33333em;padding-inline-start:1.11111em}.prose-sm :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:.8em;font-size:2.14286em;line-height:1.2}.prose-sm :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.6em;margin-bottom:.8em;font-size:1.42857em;line-height:1.4}.prose-sm :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.55556em;margin-bottom:.444444em;font-size:1.28571em;line-height:1.55556}.prose-sm :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.42857em;margin-bottom:.571429em;line-height:1.42857}.prose-sm :where(img):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.71429em;margin-bottom:1.71429em}.prose-sm :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose-sm :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.71429em;margin-bottom:1.71429em}.prose-sm :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.142857em;padding-inline-end:.357143em;padding-bottom:.142857em;border-radius:.3125rem;padding-inline-start:.357143em;font-size:.857143em}.prose-sm :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.857143em}.prose-sm :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.9em}.prose-sm :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.888889em}.prose-sm :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.666667em;padding-inline-end:1em;padding-bottom:.666667em;border-radius:.25rem;margin-top:1.66667em;margin-bottom:1.66667em;padding-inline-start:1em;font-size:.857143em;line-height:1.66667}.prose-sm :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em;margin-bottom:1.14286em;padding-inline-start:1.57143em}.prose-sm :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.285714em;margin-bottom:.285714em}.prose-sm :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.428571em}.prose-sm :where(.prose-sm>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.571429em;margin-bottom:.571429em}.prose-sm :where(.prose-sm>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em}.prose-sm :where(.prose-sm>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.14286em}.prose-sm :where(.prose-sm>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em}.prose-sm :where(.prose-sm>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.14286em}.prose-sm :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.571429em;margin-bottom:.571429em}.prose-sm :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em;margin-bottom:1.14286em}.prose-sm :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.14286em}.prose-sm :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.285714em;padding-inline-start:1.57143em}.prose-sm :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2.85714em;margin-bottom:2.85714em}.prose-sm :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)),.prose-sm :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-sm :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){font-size:.857143em;line-height:1.5}.prose-sm :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:1em;padding-bottom:.666667em;padding-inline-start:1em}.prose-sm :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose-sm :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose-sm :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.666667em;padding-inline-end:1em;padding-bottom:.666667em;padding-inline-start:1em}.prose-sm :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose-sm :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose-sm :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.71429em;margin-bottom:1.71429em}.prose-sm :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose-sm :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.666667em;font-size:.857143em;line-height:1.33333}.prose-sm :where(.prose-sm>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose-sm :where(.prose-sm>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.prose-invert{--tw-prose-body:var(--tw-prose-invert-body);--tw-prose-headings:var(--tw-prose-invert-headings);--tw-prose-lead:var(--tw-prose-invert-lead);--tw-prose-links:var(--tw-prose-invert-links);--tw-prose-bold:var(--tw-prose-invert-bold);--tw-prose-counters:var(--tw-prose-invert-counters);--tw-prose-bullets:var(--tw-prose-invert-bullets);--tw-prose-hr:var(--tw-prose-invert-hr);--tw-prose-quotes:var(--tw-prose-invert-quotes);--tw-prose-quote-borders:var(--tw-prose-invert-quote-borders);--tw-prose-captions:var(--tw-prose-invert-captions);--tw-prose-kbd:var(--tw-prose-invert-kbd);--tw-prose-kbd-shadows:var(--tw-prose-invert-kbd-shadows);--tw-prose-code:var(--tw-prose-invert-code);--tw-prose-pre-code:var(--tw-prose-invert-pre-code);--tw-prose-pre-bg:var(--tw-prose-invert-pre-bg);--tw-prose-th-borders:var(--tw-prose-invert-th-borders);--tw-prose-td-borders:var(--tw-prose-invert-td-borders)}.pointer-events-none{pointer-events:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{top:0;bottom:0}.-top-3{top:-.75rem}.bottom-0{bottom:0}.bottom-4{bottom:1rem}.bottom-6{bottom:1.5rem}.left-0{left:0}.left-0\.5{left:.125rem}.left-1\/2{left:50%}.left-3{left:.75rem}.left-\[5px\]{left:5px}.right-0\.5{right:.125rem}.right-1{right:.25rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.right-8{right:2rem}.top-0{top:0}.top-0\.5{top:.125rem}.top-1{top:.25rem}.top-1\/2{top:50%}.top-10{top:2.5rem}.top-2{top:.5rem}.top-3{top:.75rem}.top-4{top:1rem}.isolate{isolation:isolate}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[60\]{z-index:60}.col-span-2{grid-column:span 2/span 2}.m-0{margin:0}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.-mb-px{margin-bottom:-1px}.-mt-0\.5{margin-top:-.125rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-12{margin-left:3rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-5{margin-left:1.25rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.\!grid{display:grid!important}.grid{display:grid}.contents{display:contents}.hidden{display:none}.size-1\.5{width:.375rem;height:.375rem}.size-10{width:2.5rem;height:2.5rem}.size-12{width:3rem;height:3rem}.size-3{width:.75rem;height:.75rem}.size-3\.5{width:.875rem;height:.875rem}.size-4{width:1rem;height:1rem}.size-5{width:1.25rem;height:1.25rem}.size-7{width:1.75rem;height:1.75rem}.size-9{width:2.25rem;height:2.25rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-32{height:8rem}.h-36{height:9rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-\[600px\]{height:600px}.h-\[60px\]{height:60px}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-0{max-height:0}.max-h-32{max-height:8rem}.max-h-40{max-height:10rem}.max-h-48{max-height:12rem}.max-h-64{max-height:16rem}.max-h-80{max-height:20rem}.max-h-\[2000px\]{max-height:2000px}.max-h-\[200px\]{max-height:200px}.max-h-\[400px\]{max-height:400px}.max-h-\[450px\]{max-height:450px}.max-h-\[500px\]{max-height:500px}.max-h-\[600px\]{max-height:600px}.max-h-\[60vh\]{max-height:60vh}.max-h-\[70vh\]{max-height:70vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.max-h-\[calc\(100vh-220px\)\]{max-height:calc(100vh - 220px)}.min-h-0{min-height:0}.min-h-\[120px\]{min-height:120px}.w-0\.5{width:.125rem}.w-1\.5{width:.375rem}.w-1\/2{width:50%}.w-1\/4{width:25%}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-32{width:8rem}.w-36{width:9rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-\[220px\]{width:220px}.w-\[700px\]{width:700px}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0}.min-w-24{min-width:6rem}.min-w-48{min-width:12rem}.min-w-\[100px\]{min-width:100px}.min-w-\[120px\]{min-width:120px}.min-w-\[140px\]{min-width:140px}.min-w-\[1rem\]{min-width:1rem}.min-w-\[280px\]{min-width:280px}.min-w-\[600px\]{min-width:600px}.min-w-max{min-width:max-content}.max-w-28{max-width:7rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-\[1200px\]{max-width:1200px}.max-w-\[120px\]{max-width:120px}.max-w-\[160px\]{max-width:160px}.max-w-\[200px\]{max-width:200px}.max-w-\[680px\]{max-width:680px}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.origin-left{transform-origin:0}.-translate-x-1\/2{--tw-translate-x:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-full{--tw-translate-x:-100%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0{--tw-translate-x:0px;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-1{--tw-translate-x:.25rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-5{--tw-translate-x:1.25rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-6{--tw-translate-x:1.5rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-2{--tw-rotate:2deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate:45deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-\[1\.02\]{--tw-scale-x:1.02;--tw-scale-y:1.02;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-\[pulse_2s_ease-in-out_infinite\]{animation:2s ease-in-out infinite pulse}@keyframes fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.3s ease-out fade-in}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.animate-slide-in-right{animation:.2s ease-out slide-in-right}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-context-menu{cursor:context-menu}.cursor-grab{cursor:grab}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.select-none{-webkit-user-select:none;user-select:none}.resize-none{resize:none}.resize{resize:both}.appearance-none{appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-\[2fr_minmax\(200px\,1\.5fr\)_120px\]{grid-template-columns:2fr minmax(200px,1.5fr) 120px}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.content-start{align-content:flex-start}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-0{gap:0}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.gap-y-1{row-gap:.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-border>:not([hidden])~:not([hidden]){border-color:var(--border)}.divide-divider>:not([hidden])~:not([hidden]){border-color:var(--divider)}.divide-gray-700>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(55 65 81/var(--tw-divide-opacity,1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:calc(var(--radius) + 8px)}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-2{border-left-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-t-4{border-top-width:4px}.border-border{border-color:var(--border)}.border-cyan-500\/30{border-color:#06b6d44d}.border-divider{border-color:var(--divider)}.border-divider-strong{border-color:var(--divider-strong)}.border-primary{border-color:var(--primary)}.border-purple-500{--tw-border-opacity:1;border-color:rgb(168 85 247/var(--tw-border-opacity,1))}.border-purple-500\/30{border-color:#a855f74d}.border-signal-review{border-color:var(--signal-review)}.border-success{border-color:var(--success)}.border-transparent{border-color:#0000}.border-warning{border-color:var(--warning)}.border-yellow-500{--tw-border-opacity:1;border-color:rgb(234 179 8/var(--tw-border-opacity,1))}.border-yellow-500\/30{border-color:#eab3084d}.border-l-blue-500{--tw-border-opacity:1;border-left-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-l-border{border-left-color:var(--border)}.border-l-content-muted{border-left-color:var(--content-muted)}.border-l-destructive{border-left-color:var(--destructive)}.border-l-muted-foreground{border-left-color:var(--muted-foreground)}.border-l-primary{border-left-color:var(--primary)}.border-l-warning{border-left-color:var(--warning)}.bg-\[\#10b981\]{--tw-bg-opacity:1;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.bg-\[\#3b82f6\]\/20{background-color:#3b82f633}.bg-\[\#a078f7\]{--tw-bg-opacity:1;background-color:rgb(160 120 247/var(--tw-bg-opacity,1))}.bg-\[\#a078f7\]\/40{background-color:#a078f766}.bg-\[\#fbbf24\]{--tw-bg-opacity:1;background-color:rgb(251 191 36/var(--tw-bg-opacity,1))}.bg-\[\#fbbf24\]\/20{background-color:#fbbf2433}.bg-accent{background-color:var(--accent)}.bg-accent-muted{background-color:var(--accent-muted)}.bg-amber-500\/15{background-color:#f59e0b26}.bg-amber-900\/20{background-color:#78350f33}.bg-background{background-color:var(--background)}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/40{background-color:#0006}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-black\/70{background-color:#000000b3}.bg-black\/80{background-color:#000c}.bg-blue-500\/20{background-color:#3b82f633}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-content-muted{background-color:var(--content-muted)}.bg-current{background-color:currentColor}.bg-cyan-500\/20{background-color:#06b6d433}.bg-cyan-900\/20{background-color:#164e6333}.bg-destructive{background-color:var(--destructive)}.bg-divider{background-color:var(--divider)}.bg-divider-strong{background-color:var(--divider-strong)}.bg-emerald-500\/15{background-color:#10b98126}.bg-emerald-500\/60{background-color:#10b98199}.bg-gray-500\/20{background-color:#6b728033}.bg-green-500\/20{background-color:#22c55e33}.bg-input{background-color:var(--input)}.bg-input-bg{background-color:var(--input-bg)}.bg-muted{background-color:var(--muted)}.bg-muted-foreground{background-color:var(--muted-foreground)}.bg-orange-500\/20{background-color:#f9731633}.bg-primary{background-color:var(--primary)}.bg-purple-500\/20{background-color:#a855f733}.bg-signal-review{background-color:var(--signal-review)}.bg-success{background-color:var(--success)}.bg-surface{background-color:var(--surface)}.bg-surface-2{background-color:var(--surface-2)}.bg-surface-active{background-color:var(--surface-active)}.bg-surface-emphasis{background-color:var(--surface-emphasis)}.bg-surface-overlay{background-color:var(--surface-overlay)}.bg-surface-raised{background-color:var(--surface-raised)}.bg-transparent{background-color:#0000}.bg-warning{background-color:var(--warning)}.bg-warning-foreground{background-color:var(--warning-foreground)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-500\/10{background-color:#eab3081a}.bg-opacity-20{--tw-bg-opacity:.2}.bg-opacity-50{--tw-bg-opacity:.5}.bg-\[radial-gradient\(circle_at_50\%_50\%\,\#3b82f6_0\%\,transparent_70\%\)\]{background-image:radial-gradient(circle,#3b82f6 0%,#0000 70%)}.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}.from-destructive{--tw-gradient-from:var(--destructive) var(--tw-gradient-from-position);--tw-gradient-to:#fff0 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-divider{--tw-gradient-from:var(--divider) var(--tw-gradient-from-position);--tw-gradient-to:#fff0 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-divider-strong{--tw-gradient-from:var(--divider-strong) var(--tw-gradient-from-position);--tw-gradient-to:#fff0 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from:#a855f7 var(--tw-gradient-from-position);--tw-gradient-to:#a855f700 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-500\/20{--tw-gradient-from:#a855f733 var(--tw-gradient-from-position);--tw-gradient-to:#a855f700 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-red-500\/30{--tw-gradient-from:#ef44444d var(--tw-gradient-from-position);--tw-gradient-to:#ef444400 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.via-primary{--tw-gradient-to:#fff0 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--primary) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}.to-blue-500\/20{--tw-gradient-to:#3b82f633 var(--tw-gradient-to-position)}.to-divider{--tw-gradient-to:var(--divider) var(--tw-gradient-to-position)}.to-divider-strong{--tw-gradient-to:var(--divider-strong) var(--tw-gradient-to-position)}.to-orange-500\/30{--tw-gradient-to:#f973164d var(--tw-gradient-to-position)}.to-warning{--tw-gradient-to:var(--warning) var(--tw-gradient-to-position)}.fill-current{fill:currentColor}.fill-warning{fill:var(--warning)}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-0{padding-left:0;padding-right:0}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-top:0;padding-bottom:0}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-2{padding-bottom:.5rem}.pb-20{padding-bottom:5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-10{padding-right:2.5rem}.pr-16{padding-right:4rem}.pr-3{padding-right:.75rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-1\.5{padding-top:.375rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-\[15vh\]{padding-top:15vh}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-display{font-family:Space Grotesk,system-ui,sans-serif}.font-mono{font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-tighter{letter-spacing:-.05em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-\[\#10b981\]{--tw-text-opacity:1;color:rgb(16 185 129/var(--tw-text-opacity,1))}.text-\[\#3b82f6\]{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-\[\#a078f7\]{--tw-text-opacity:1;color:rgb(160 120 247/var(--tw-text-opacity,1))}.text-\[\#fbbf24\]{--tw-text-opacity:1;color:rgb(251 191 36/var(--tw-text-opacity,1))}.text-accent{color:var(--accent)}.text-amber-400{--tw-text-opacity:1;color:rgb(251 191 36/var(--tw-text-opacity,1))}.text-amber-500{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-content{color:var(--content)}.text-content-body{color:var(--content-body)}.text-content-muted{color:var(--content-muted)}.text-content-subtle{color:var(--content-subtle)}.text-cyan-400{--tw-text-opacity:1;color:rgb(34 211 238/var(--tw-text-opacity,1))}.text-destructive{color:var(--destructive)}.text-destructive-foreground{color:var(--destructive-foreground)}.text-emerald-400{--tw-text-opacity:1;color:rgb(52 211 153/var(--tw-text-opacity,1))}.text-emerald-500{--tw-text-opacity:1;color:rgb(16 185 129/var(--tw-text-opacity,1))}.text-foreground{color:var(--foreground)}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-info{color:var(--info)}.text-muted-foreground{color:var(--muted-foreground)}.text-orange-400{--tw-text-opacity:1;color:rgb(251 146 60/var(--tw-text-opacity,1))}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-purple-400{--tw-text-opacity:1;color:rgb(192 132 252/var(--tw-text-opacity,1))}.text-signal-cost{color:var(--signal-cost)}.text-signal-cost-foreground{color:var(--signal-cost-foreground)}.text-signal-review{color:var(--signal-review)}.text-signal-review-foreground{color:var(--signal-review-foreground)}.text-success{color:var(--success)}.text-success-foreground{color:var(--success-foreground)}.text-text-muted{color:var(--text-muted)}.text-text-primary{color:var(--text-primary)}.text-text-secondary{color:var(--text-secondary)}.text-warning{color:var(--warning)}.text-warning-foreground{color:var(--warning-foreground)}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-300{--tw-text-opacity:1;color:rgb(253 224 71/var(--tw-text-opacity,1))}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.placeholder-gray-400::placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.placeholder-muted-foreground::placeholder{color:var(--muted-foreground)}.accent-\[\#a078f7\]{accent-color:#a078f7}.accent-primary{accent-color:var(--primary)}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-30{opacity:.3}.opacity-35{opacity:.35}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-\[0_0_15px_var\(--primary\)\]{--tw-shadow:0 0 15px var(--primary);--tw-shadow-colored:0 0 15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-\[\#a078f7\]\/20{--tw-shadow-color:#a078f733;--tw-shadow:var(--tw-shadow-colored)}.outline-none{outline-offset:2px;outline:2px solid #0000}.outline{outline-style:solid}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.ring-blue-500{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-property:opacity;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-1000{transition-duration:1s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.badge-bg-success{background:color-mix(in srgb, var(--success) 8%, transparent)}.badge-bg-warning{background:color-mix(in srgb, var(--warning) 8%, transparent)}.badge-bg-destructive{background:color-mix(in srgb, var(--destructive) 8%, transparent)}.badge-bg-signal-review{background:color-mix(in srgb, var(--signal-review) 8%, transparent)}.badge-bg-primary{background:color-mix(in srgb, var(--primary) 8%, transparent)}.badge-bg-muted{background:color-mix(in srgb, var(--foreground) 6%, transparent)}.badge-border-success{border-color:color-mix(in srgb, var(--success) 32%, transparent)}.badge-border-warning{border-color:color-mix(in srgb, var(--warning) 32%, transparent)}.badge-border-destructive{border-color:color-mix(in srgb, var(--destructive) 32%, transparent)}.badge-border-signal-review{border-color:color-mix(in srgb, var(--signal-review) 32%, transparent)}.badge-border-primary{border-color:color-mix(in srgb, var(--primary) 32%, transparent)}.badge-bg-signal-cost{background:color-mix(in srgb, var(--signal-cost) 8%, transparent)}.badge-shimmer-rtm{background:linear-gradient(90deg, color-mix(in srgb, var(--success) 8%, transparent) 0%, color-mix(in srgb, var(--success) 22%, transparent) 50%, color-mix(in srgb, var(--success) 8%, transparent) 100%);background-size:250% 100%;animation:2.8s ease-in-out infinite badge-shimmer}.no-transitions,.no-transitions *,.no-transitions :before,.no-transitions :after{transition-duration:0s!important;animation-duration:0s!important}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--radius:.625rem;--background:#fff;--foreground:#1f2937;--card:#fff;--card-foreground:#1f2937;--popover:#fff;--popover-foreground:#1f2937;--primary:oklch(48.8% .217 264);--primary-foreground:#fff;--secondary:#0000000a;--secondary-foreground:#1f2937;--accent:#0000000a;--accent-foreground:#1f2937;--muted:#0000000a;--muted-foreground:#6b7280;--border:#00000014;--input:#0000001a;--ring:oklch(48.8% .217 264);--destructive:#ef4444;--destructive-foreground:#b91c1c;--info:#3b82f6;--info-foreground:#1d4ed8;--success:#10b981;--success-foreground:#047857;--warning:#f59e0b;--warning-foreground:#b45309;--signal-review:#a855f7;--signal-review-foreground:#7e22ce;--signal-cost:#06b6d4;--signal-cost-foreground:#0e7490;--surface:#fff;--surface-raised:#f9fafb;--surface-2:#f5f6f8;--surface-active:#f3f4f6;--surface-hover:#f3f4f6;--surface-overlay:#fff;--surface-emphasis:#eff1f4;--divider:#00000014;--divider-strong:#00000024;--divider-focus:oklch(48.8% .217 264);--input-bg:#f9fafb;--text-primary:#1f2937;--text-secondary:#4b5563;--text-muted:#9ca3af;--content:#1f2937;--content-body:#374151;--content-muted:#6b7280;--content-subtle:#9ca3af;--accent-muted:#6366f114;--pan-panel-left:#f9fafb;--pan-panel-right:#fff;--pan-border:#00000014;--pan-text-secondary:#4b5563}.dark{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--background:#080b10;--foreground:#f3f4f6;--card:#0c1018;--card-foreground:#f3f4f6;--popover:#0c1018;--popover-foreground:#f3f4f6;--primary:oklch(58.8% .217 264);--primary-foreground:#fff;--secondary:#ffffff0a;--secondary-foreground:#f3f4f6;--accent:#ffffff0a;--accent-foreground:#f3f4f6;--muted:#ffffff0a;--muted-foreground:#9ca3af;--border:#ffffff0f;--input:#ffffff14;--ring:oklch(58.8% .217 264);--destructive:#f87171;--destructive-foreground:#fca5a5;--info:#3b82f6;--info-foreground:#60a5fa;--success:#10b981;--success-foreground:#34d399;--warning:#f59e0b;--warning-foreground:#fbbf24;--signal-review:#a855f7;--signal-review-foreground:#c084fc;--signal-cost:#06b6d4;--signal-cost-foreground:#22d3ee;--surface:#0c1018;--surface-raised:#111520;--surface-2:#0e1320;--surface-active:#1a2132;--surface-hover:#161d2b;--surface-overlay:#13192a;--surface-emphasis:#1e2640;--divider:#ffffff0f;--divider-strong:#ffffff1f;--divider-focus:oklch(58.8% .217 264);--input-bg:#ffffff0f;--text-primary:#f3f4f6;--text-secondary:#c9d1e0;--text-muted:#89a;--content:#f3f4f6;--content-body:#e5e7eb;--content-muted:#9ca3af;--content-subtle:#6b7280;--accent-muted:#8b5cf626;--pan-panel-left:#111520;--pan-panel-right:#0c1018;--pan-border:#ffffff0f;--pan-text-secondary:#c9d1e0}body:after{content:"";pointer-events:none;opacity:.035;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00000040}.dark ::-webkit-scrollbar-thumb{background:#ffffff1a}.dark ::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.terminal-output{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,monospace;font-size:13px;line-height:1.5}@keyframes badge-shimmer{0%{background-position:150%}to{background-position:-50%}}.prose-notes p{margin:0 0 .4em;line-height:1.5}.prose-notes p:last-child{margin-bottom:0}.prose-notes ol{margin:.3em 0;padding-left:1.25em;list-style:decimal}.prose-notes ul{margin:.3em 0;padding-left:1.25em;list-style:outside}.prose-notes li{margin-bottom:.2em;line-height:1.5}.prose-notes strong{font-weight:600}.prose-notes em{font-style:italic}.prose-notes code{background:color-mix(in srgb, currentColor 10%, transparent);border-radius:3px;padding:.1em .3em;font-family:ui-monospace,monospace;font-size:.85em}.prose-notes a{color:var(--primary);text-decoration:underline}.placeholder\:text-content-muted::placeholder{color:var(--content-muted)}.placeholder\:text-text-muted::placeholder{color:var(--text-muted)}.first\:mt-2:first-child{margin-top:.5rem}.last\:border-b-0:last-child{border-bottom-width:0}.last\:border-r-0:last-child{border-right-width:0}.hover\:border-\[\#a078f7\]:hover{--tw-border-opacity:1;border-color:rgb(160 120 247/var(--tw-border-opacity,1))}.hover\:border-divider:hover{border-color:var(--divider)}.hover\:border-divider-focus:hover{border-color:var(--divider-focus)}.hover\:border-divider-strong:hover{border-color:var(--divider-strong)}.hover\:bg-\[\#2769ec\]\/30:hover{background-color:#2769ec4d}.hover\:bg-\[\#a078f7\]\/90:hover{background-color:#a078f7e6}.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-divider-strong:hover{background-color:var(--divider-strong)}.hover\:bg-muted:hover{background-color:var(--muted)}.hover\:bg-surface:hover{background-color:var(--surface)}.hover\:bg-surface-emphasis:hover{background-color:var(--surface-emphasis)}.hover\:bg-surface-hover:hover{background-color:var(--surface-hover)}.hover\:bg-surface-overlay:hover{background-color:var(--surface-overlay)}.hover\:bg-surface-raised:hover{background-color:var(--surface-raised)}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/5:hover{background-color:#ffffff0d}.hover\:text-\[\#a078f7\]:hover{--tw-text-opacity:1;color:rgb(160 120 247/var(--tw-text-opacity,1))}.hover\:text-amber-300:hover{--tw-text-opacity:1;color:rgb(252 211 77/var(--tw-text-opacity,1))}.hover\:text-content:hover{color:var(--content)}.hover\:text-content-body:hover{color:var(--content-body)}.hover\:text-content-subtle:hover{color:var(--content-subtle)}.hover\:text-destructive:hover{color:var(--destructive)}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-primary:hover{color:var(--primary)}.hover\:text-success:hover{color:var(--success)}.hover\:text-text-secondary:hover{color:var(--text-secondary)}.hover\:text-warning:hover{color:var(--warning)}.hover\:text-warning-foreground:hover{color:var(--warning-foreground)}.hover\:opacity-80:hover{opacity:.8}.hover\:ring-1:hover{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.hover\:ring-white\/20:hover{--tw-ring-color:#fff3}.focus\:border-\[\#a078f7\]:focus{--tw-border-opacity:1;border-color:rgb(160 120 247/var(--tw-border-opacity,1))}.focus\:border-accent-muted:focus{border-color:var(--accent-muted)}.focus\:border-primary:focus{border-color:var(--primary)}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-\[\#a078f7\]:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(160 120 247/var(--tw-ring-opacity,1))}.focus\:ring-primary:focus{--tw-ring-color:var(--primary)}.focus\:ring-ring:focus{--tw-ring-color:var(--ring)}.focus\:ring-signal-review:focus{--tw-ring-color:var(--signal-review)}.focus\:ring-offset-background:focus{--tw-ring-offset-color:var(--background)}.focus\:ring-offset-surface:focus{--tw-ring-offset-color:var(--surface)}.focus-visible\:outline-none:focus-visible{outline-offset:2px;outline:2px solid #0000}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.active\:cursor-grabbing:active{cursor:grabbing}.active\:bg-\[\#2769ec\]\/50:active{background-color:#2769ec80}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:bg-divider{background-color:var(--divider)}.group:hover .group-hover\:opacity-100{opacity:1}.aria-selected\:bg-surface-overlay[aria-selected=true],.data-\[selected\=true\]\:bg-surface-overlay[data-selected=true]{background-color:var(--surface-overlay)}.group[data-selected=true] .group-data-\[selected\=true\]\:text-primary{color:var(--primary)}@media (width>=640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=768px){.md\:relative{position:relative}.md\:hidden{display:none}.md\:translate-x-0{--tw-translate-x:0px;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}}@media (width>=1024px){.lg\:w-2\/5{width:40%}.lg\:w-3\/5{width:60%}.lg\:w-5\/12{width:41.6667%}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:border-b-0{border-bottom-width:0}.lg\:border-r{border-right-width:1px}}@media (width>=1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.\[\&_\[cmdk-group-heading\]\]\:px-3 [cmdk-group-heading]{padding-left:.75rem;padding-right:.75rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-top:.375rem;padding-bottom:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-\[10px\] [cmdk-group-heading]{font-size:10px}.\[\&_\[cmdk-group-heading\]\]\:font-semibold [cmdk-group-heading]{font-weight:600}.\[\&_\[cmdk-group-heading\]\]\:uppercase [cmdk-group-heading]{text-transform:uppercase}.\[\&_\[cmdk-group-heading\]\]\:tracking-wider [cmdk-group-heading]{letter-spacing:.05em}.\[\&_\[cmdk-group-heading\]\]\:text-content-muted [cmdk-group-heading]{color:var(--content-muted)}.\[\&_\[cmdk-input-wrapper\]\]\:border-b [cmdk-input-wrapper]{border-bottom-width:1px}.\[\&_\[cmdk-input-wrapper\]\]\:border-divider [cmdk-input-wrapper]{border-color:var(--divider)}
|
|
@@ -18,9 +18,9 @@
|
|
|
18
18
|
}
|
|
19
19
|
})();
|
|
20
20
|
</script>
|
|
21
|
-
<script type="module" crossorigin src="/assets/index-
|
|
21
|
+
<script type="module" crossorigin src="/assets/index-CzFZIb87.js"></script>
|
|
22
22
|
<link rel="modulepreload" crossorigin href="/assets/chunk-BEqpzyXh.js">
|
|
23
|
-
<link rel="stylesheet" crossorigin href="/assets/index-
|
|
23
|
+
<link rel="stylesheet" crossorigin href="/assets/index-OEEbThNN.css">
|
|
24
24
|
</head>
|
|
25
25
|
<body>
|
|
26
26
|
<div id="root"></div>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { n as __esmMin } from "./chunk-DORXReHP.js";
|
|
2
|
-
import { n as init_rally_api, t as RallyRestApi } from "./rally-api-
|
|
2
|
+
import { n as init_rally_api, t as RallyRestApi } from "./rally-api-C0WqCSkT.js";
|
|
3
3
|
//#region ../../lib/tracker/interface.ts
|
|
4
4
|
var NotImplementedError, IssueNotFoundError, TrackerAuthError;
|
|
5
5
|
var init_interface = __esmMin((() => {
|
|
@@ -438,4 +438,4 @@ var init_rally = __esmMin((() => {
|
|
|
438
438
|
//#endregion
|
|
439
439
|
export { TrackerAuthError as a, NotImplementedError as i, init_rally as n, init_interface as o, IssueNotFoundError as r, RallyTracker as t };
|
|
440
440
|
|
|
441
|
-
//# sourceMappingURL=rally-
|
|
441
|
+
//# sourceMappingURL=rally-YjFRxIiC.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rally-Cwuae-4C.js","names":[],"sources":["../../src/lib/tracker/interface.ts","../../src/lib/tracker/rally.ts"],"sourcesContent":["/**\n * Issue Tracker Abstraction Layer\n *\n * Provides a unified interface for different issue tracking systems\n * (Linear, GitHub Issues, GitLab Issues, etc.)\n */\n\n// Supported tracker types\nexport type TrackerType = 'linear' | 'github' | 'gitlab' | 'rally';\n\n// Normalized issue state (lowest common denominator)\nexport type IssueState = 'open' | 'in_progress' | 'in_review' | 'closed';\n\n// Normalized issue format\nexport interface Issue {\n /** Tracker-specific unique ID */\n id: string;\n\n /** Human-readable reference (e.g., MIN-630, #42) */\n ref: string;\n\n /** Issue title */\n title: string;\n\n /** Issue description/body (markdown) */\n description: string;\n\n /** Normalized state */\n state: IssueState;\n\n /** Labels/tags */\n labels: string[];\n\n /** Assignee username/name */\n assignee?: string;\n\n /** Web URL to the issue */\n url: string;\n\n /** Which tracker this issue came from */\n tracker: TrackerType;\n\n /** Cross-tracker linked issue references */\n linkedIssues?: string[];\n\n /** Priority (1=urgent, 2=high, 3=normal, 4=low) */\n priority?: number;\n\n /** Due date (ISO string) */\n dueDate?: string;\n\n /** Creation timestamp (ISO string) */\n createdAt: string;\n\n /** Last update timestamp (ISO string) */\n updatedAt: string;\n\n /** Parent issue FormattedID (e.g., \"F1234\") for Rally hierarchy */\n parentRef?: string;\n\n /** Rally artifact type (e.g., \"HierarchicalRequirement\", \"PortfolioItem/Feature\") */\n artifactType?: string;\n\n /** Raw tracker state name before normalization (e.g., \"Discovering\", \"In-Progress\") */\n rawState?: string;\n}\n\n// Comment on an issue\nexport interface Comment {\n id: string;\n issueId: string;\n body: string;\n author: string;\n createdAt: string;\n updatedAt: string;\n}\n\n// Filters for listing issues\nexport interface IssueFilters {\n /** Filter by state */\n state?: IssueState;\n\n /** Filter by labels (AND logic) */\n labels?: string[];\n\n /** Filter by assignee */\n assignee?: string;\n\n /** Filter by team/project (tracker-specific) */\n team?: string;\n\n /** Search query for title/description */\n query?: string;\n\n /** Maximum number of results */\n limit?: number;\n\n /** Include closed issues (default: false) */\n includeClosed?: boolean;\n}\n\n// Data for creating a new issue\nexport interface NewIssue {\n title: string;\n description?: string;\n labels?: string[];\n assignee?: string;\n team?: string;\n priority?: number;\n dueDate?: string;\n}\n\n// Data for updating an issue\nexport interface IssueUpdate {\n title?: string;\n description?: string;\n state?: IssueState;\n labels?: string[];\n assignee?: string;\n priority?: number;\n dueDate?: string;\n}\n\n/**\n * Abstract interface for issue trackers.\n * Implementations must handle normalization to/from tracker-specific formats.\n */\nexport interface IssueTracker {\n /** Tracker type identifier */\n readonly name: TrackerType;\n\n /**\n * List issues matching filters\n */\n listIssues(filters?: IssueFilters): Promise<Issue[]>;\n\n /**\n * Get a single issue by ID or ref\n * @param id - Issue ID or human-readable ref (e.g., \"MIN-630\", \"#42\")\n */\n getIssue(id: string): Promise<Issue>;\n\n /**\n * Update an existing issue\n */\n updateIssue(id: string, update: IssueUpdate): Promise<Issue>;\n\n /**\n * Create a new issue\n */\n createIssue(issue: NewIssue): Promise<Issue>;\n\n /**\n * Get comments on an issue\n */\n getComments(issueId: string): Promise<Comment[]>;\n\n /**\n * Add a comment to an issue\n */\n addComment(issueId: string, body: string): Promise<Comment>;\n\n /**\n * Transition issue to a new state\n */\n transitionIssue(id: string, state: IssueState): Promise<void>;\n\n /**\n * Link a PR/MR to an issue\n */\n linkPR(issueId: string, prUrl: string): Promise<void>;\n}\n\n/**\n * Error thrown when a tracker feature is not implemented\n */\nexport class NotImplementedError extends Error {\n constructor(feature: string) {\n super(`Not implemented: ${feature}`);\n this.name = 'NotImplementedError';\n }\n}\n\n/**\n * Error thrown when an issue is not found\n */\nexport class IssueNotFoundError extends Error {\n constructor(id: string, tracker: TrackerType) {\n super(`Issue not found: ${id} (tracker: ${tracker})`);\n this.name = 'IssueNotFoundError';\n }\n}\n\n/**\n * Error thrown when tracker authentication fails\n */\nexport class TrackerAuthError extends Error {\n constructor(tracker: TrackerType, message: string) {\n super(`Authentication failed for ${tracker}: ${message}`);\n this.name = 'TrackerAuthError';\n }\n}\n","/**\n * Rally Tracker Adapter\n *\n * Implements IssueTracker interface for Broadcom Rally (formerly CA Agile Central).\n * Supports all Rally work item types: User Stories, Defects, Tasks, and Features.\n */\n\nimport { RallyRestApi } from './rally-api.js';\nimport type {\n Issue,\n IssueFilters,\n IssueState,\n IssueTracker,\n IssueUpdate,\n NewIssue,\n Comment,\n TrackerType,\n} from './interface.js';\nimport { IssueNotFoundError, TrackerAuthError, NotImplementedError } from './interface.js';\n\n// Map Rally ScheduleState/State to normalized IssueState.\n// Covers all standard states for User Stories, Defects, Tasks, and Features.\nconst STATE_MAP: Record<string, IssueState> = {\n // User Stories (ScheduleState)\n 'New': 'open',\n 'Idea': 'open',\n 'Defined': 'open',\n 'In-Progress': 'in_progress',\n 'Completed': 'closed',\n 'Accepted': 'closed',\n\n // Defects (State)\n 'Submitted': 'open',\n 'Open': 'in_progress', // \"Open\" defects are actively being worked\n 'Fixed': 'closed',\n 'Closed': 'closed',\n\n // Features / PortfolioItems (State)\n 'Discovering': 'open',\n 'Developing': 'in_progress',\n 'Done': 'closed',\n};\n\n// Rally artifact types we support\ntype RallyArtifactType = 'HierarchicalRequirement' | 'Defect' | 'Task' | 'PortfolioItem/Feature';\n\n/**\n * Type-specific query configuration.\n *\n * Rally WSAPI cannot filter generic Artifact by ScheduleState because not all\n * subtypes have that field. Instead, we query each type separately with its\n * own state field and merge the results. (PAN-168)\n */\ninterface ArtifactTypeQuery {\n /** WSAPI endpoint type (lowercase) */\n type: string;\n /** The state field used for filtering on this artifact type */\n stateField: 'ScheduleState' | 'State';\n /** State values that represent \"closed\" for this type */\n closedStates: string[];\n}\n\nconst QUERYABLE_TYPES: ArtifactTypeQuery[] = [\n { type: 'hierarchicalrequirement', stateField: 'ScheduleState', closedStates: ['Completed', 'Accepted'] },\n { type: 'defect', stateField: 'State', closedStates: ['Closed'] },\n { type: 'task', stateField: 'State', closedStates: ['Completed'] },\n { type: 'portfolioitem/feature', stateField: 'State', closedStates: ['Done'] },\n];\n\nconst FETCH_FIELDS = [\n 'ObjectID',\n 'FormattedID',\n 'Name',\n 'Description',\n 'ScheduleState',\n 'State',\n 'Tags',\n 'Owner',\n 'Priority',\n 'DueDate',\n 'CreationDate',\n 'LastUpdateDate',\n 'Parent',\n 'PortfolioItem',\n '_type',\n];\n\n// Rally priority strings to numbers\nconst PRIORITY_MAP: Record<string, number> = {\n 'Resolve Immediately': 0,\n High: 1,\n Normal: 2,\n Low: 3,\n};\n\n// Reverse priority mapping\nconst REVERSE_PRIORITY_MAP: Record<number, string> = {\n 0: 'Resolve Immediately',\n 1: 'High',\n 2: 'Normal',\n 3: 'Low',\n 4: 'Low',\n};\n\nexport interface RallyConfig {\n apiKey: string;\n server?: string; // Default: rally1.rallydev.com\n workspace?: string; // Rally workspace OID (e.g., \"/workspace/12345\")\n project?: string; // Rally project OID (e.g., \"/project/67890\")\n}\n\nexport class RallyTracker implements IssueTracker {\n readonly name: TrackerType = 'rally' as TrackerType;\n private restApi: RallyRestApi;\n private workspace?: string;\n private project?: string;\n\n constructor(config: RallyConfig) {\n if (!config.apiKey) {\n throw new TrackerAuthError('rally' as TrackerType, 'API key is required');\n }\n\n this.restApi = new RallyRestApi({\n apiKey: config.apiKey,\n server: config.server || 'https://rally1.rallydev.com',\n requestOptions: {\n headers: {\n 'X-RallyIntegrationType': 'Panopticon',\n 'X-RallyIntegrationName': 'Panopticon CLI',\n 'X-RallyIntegrationVendor': 'Mind Your Now',\n 'X-RallyIntegrationVersion': '0.2.0',\n },\n },\n });\n\n this.workspace = config.workspace;\n this.project = config.project;\n }\n\n /**\n * List issues by querying each artifact type separately and merging results.\n *\n * Rally WSAPI cannot apply ScheduleState filters across the generic Artifact\n * endpoint because not all subtypes have that field. We query each type with\n * its own state field, then merge and sort. (PAN-168)\n */\n async listIssues(filters?: IssueFilters): Promise<Issue[]> {\n if (process.env.DEBUG?.includes('rally')) {\n console.debug('[Rally] Query filters:', JSON.stringify(filters));\n }\n\n const limit = filters?.limit ?? 50;\n\n // Extract ObjectID from project ref for explicit query scoping\n // e.g., \"/project/822404704163\" → \"822404704163\"\n let projectObjectId: string | undefined;\n if (this.project) {\n const match = this.project.match(/\\/project\\/(\\d+)/);\n if (match) projectObjectId = match[1];\n }\n\n const queries = QUERYABLE_TYPES.map(async (artifactType) => {\n const queryString = this.buildQueryStringForType(filters, artifactType, projectObjectId);\n\n if (process.env.DEBUG?.includes('rally')) {\n console.debug(`[Rally] ${artifactType.type} query:`, queryString);\n }\n\n const query: any = {\n type: artifactType.type,\n fetch: FETCH_FIELDS,\n limit,\n query: queryString,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n if (this.project) {\n query.project = this.project;\n query.projectScopeDown = true;\n }\n\n try {\n const result = await this.queryRally(query);\n return result.Results.map((artifact: any) => this.normalizeIssue(artifact));\n } catch (error: any) {\n if (error.message?.includes('Unauthorized') || error.message?.includes('401')) {\n throw new TrackerAuthError('rally' as TrackerType, 'Invalid API key or insufficient permissions');\n }\n // Log and skip individual type failures so other types still return\n if (process.env.DEBUG?.includes('rally')) {\n console.debug(`[Rally] Failed to query ${artifactType.type}:`, error.message);\n }\n return [];\n }\n });\n\n const results = await Promise.all(queries);\n const allIssues = results.flat();\n\n // Sort by most recently updated first, then apply overall limit\n allIssues.sort(\n (a, b) => new Date(b.updatedAt).getTime() - new Date(a.updatedAt).getTime()\n );\n\n return allIssues.slice(0, limit);\n }\n\n async getIssue(id: string): Promise<Issue> {\n try {\n // Rally FormattedIDs look like: US123, DE456, TA789, F012\n const query: any = {\n type: 'artifact',\n fetch: [\n 'FormattedID',\n 'Name',\n 'Description',\n 'ScheduleState',\n 'State',\n 'Tags',\n 'Owner',\n 'Priority',\n 'DueDate',\n 'CreationDate',\n 'LastUpdateDate',\n 'Parent',\n '_type',\n ],\n query: `(FormattedID = \"${id}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n\n return this.normalizeIssue(result.Results[0]);\n } catch (error: any) {\n if (error instanceof IssueNotFoundError) throw error;\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n }\n\n async updateIssue(id: string, update: IssueUpdate): Promise<Issue> {\n const issue = await this.getIssue(id);\n\n // Get the Rally object reference\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', '_type'],\n query: `(FormattedID = \"${id}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n\n const artifact = result.Results[0];\n const updatePayload: Record<string, unknown> = {};\n\n if (update.title !== undefined) {\n updatePayload.Name = update.title;\n }\n if (update.description !== undefined) {\n updatePayload.Description = update.description;\n }\n if (update.state !== undefined) {\n const artifactType = (artifact._type || '').toLowerCase();\n const kind = artifactType.startsWith('portfolioitem') ? 'feature'\n : artifactType === 'defect' ? 'defect' : 'story';\n const rallyState = this.reverseMapState(update.state, kind);\n if (kind === 'story') {\n updatePayload.ScheduleState = rallyState;\n } else {\n updatePayload.State = rallyState;\n }\n }\n if (update.priority !== undefined) {\n updatePayload.Priority = REVERSE_PRIORITY_MAP[update.priority] || 'Normal';\n }\n if (update.dueDate !== undefined) {\n updatePayload.DueDate = update.dueDate;\n }\n\n if (Object.keys(updatePayload).length > 0) {\n await this.updateRally(artifact._type.toLowerCase(), artifact._ref, updatePayload);\n }\n\n return this.getIssue(id);\n }\n\n async createIssue(newIssue: NewIssue): Promise<Issue> {\n if (!this.project && !newIssue.team) {\n throw new Error('Project is required to create an issue. Set it in config or provide team field.');\n }\n\n const project = newIssue.team || this.project;\n\n // Default to HierarchicalRequirement (User Story) for new issues\n const createPayload: Record<string, unknown> = {\n Name: newIssue.title,\n Description: newIssue.description || '',\n Project: project,\n };\n\n if (newIssue.priority !== undefined) {\n createPayload.Priority = REVERSE_PRIORITY_MAP[newIssue.priority] || 'Normal';\n }\n if (newIssue.dueDate) {\n createPayload.DueDate = newIssue.dueDate;\n }\n if (this.workspace) {\n createPayload.Workspace = this.workspace;\n }\n\n const result = await this.createRally('hierarchicalrequirement', createPayload);\n\n // Fetch the created issue to return normalized format\n return this.getIssue(result.Object.FormattedID);\n }\n\n async getComments(issueId: string): Promise<Comment[]> {\n const issue = await this.getIssue(issueId);\n\n // Get the Rally object to find its Discussion\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', 'Discussion'],\n query: `(FormattedID = \"${issueId}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n return [];\n }\n\n const artifact = result.Results[0];\n if (!artifact.Discussion) {\n return [];\n }\n\n // Query ConversationPosts for this Discussion\n const postsQuery: any = {\n type: 'conversationpost',\n fetch: ['ObjectID', 'Text', 'User', 'CreationDate', 'PostNumber'],\n query: `(Discussion = \"${artifact.Discussion._ref}\")`,\n order: 'PostNumber',\n };\n\n const postsResult = await this.queryRally(postsQuery);\n\n return (postsResult.Results || []).map((post: any) => ({\n id: post.ObjectID,\n issueId,\n body: post.Text || '',\n author: post.User?._refObjectName || 'Unknown',\n createdAt: post.CreationDate,\n updatedAt: post.CreationDate, // Rally doesn't track comment updates separately\n }));\n }\n\n async addComment(issueId: string, body: string): Promise<Comment> {\n // Get the Rally object to find its Discussion\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', 'Discussion'],\n query: `(FormattedID = \"${issueId}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(issueId, 'rally' as TrackerType);\n }\n\n const artifact = result.Results[0];\n\n // If no Discussion exists, create one\n let discussionRef = artifact.Discussion?._ref;\n if (!discussionRef) {\n const discussionResult = await this.createRally('conversationpost', {\n Artifact: artifact._ref,\n Text: body,\n });\n\n return {\n id: discussionResult.Object.ObjectID,\n issueId,\n body,\n author: 'Panopticon',\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n };\n }\n\n // Add a post to existing Discussion\n const postResult = await this.createRally('conversationpost', {\n Artifact: artifact._ref,\n Text: body,\n });\n\n return {\n id: postResult.Object.ObjectID,\n issueId,\n body,\n author: 'Panopticon',\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n };\n }\n\n async transitionIssue(id: string, state: IssueState): Promise<void> {\n await this.updateIssue(id, { state });\n }\n\n async linkPR(issueId: string, prUrl: string): Promise<void> {\n // Add a comment with the PR link\n await this.addComment(issueId, `Linked Pull Request: ${prUrl}`);\n }\n\n // Private helper methods\n\n /**\n * Build a Rally WSAPI query string for a specific artifact type.\n *\n * Each artifact type has its own state field:\n * - HierarchicalRequirement: ScheduleState (Defined, In-Progress, Completed, Accepted)\n * - Defect: State (Submitted, Open, Fixed, Closed)\n * - Task: State (Defined, In-Progress, Completed)\n *\n * Rally WSAPI v2.0 requires binary-nested AND/OR with outer parentheses.\n * (PAN-166, PAN-168)\n */\n private buildQueryStringForType(\n filters: IssueFilters | undefined,\n artifactType: ArtifactTypeQuery,\n projectObjectId?: string,\n ): string {\n const conditions: string[] = [];\n\n // Explicit project scoping — more reliable than WSAPI project param alone\n if (projectObjectId) {\n conditions.push(`(Project.ObjectID = \"${projectObjectId}\")`);\n }\n\n if (filters?.state && !filters.includeClosed) {\n const kind = artifactType.type.startsWith('portfolioitem') ? 'feature'\n : artifactType.type === 'defect' ? 'defect' : 'story';\n const rallyState = this.reverseMapState(filters.state, kind);\n conditions.push(`(${artifactType.stateField} = \"${rallyState}\")`);\n }\n\n if (!filters?.includeClosed) {\n // Exclude closed states for this specific artifact type\n const closedConditions = artifactType.closedStates.map(\n (state) => `(${artifactType.stateField} != \"${state}\")`\n );\n // Rally WSAPI only supports binary AND — nest into pairs\n const closedExpr = closedConditions.reduce(\n (acc, cond) => (acc ? `(${acc} AND ${cond})` : cond),\n '',\n );\n conditions.push(closedExpr);\n }\n\n if (filters?.assignee) {\n conditions.push(`(Owner.Name contains \"${filters.assignee}\")`);\n }\n\n if (filters?.labels && filters.labels.length > 0) {\n const labelConditions = filters.labels.map(\n (label) => `(Tags.Name contains \"${label}\")`\n );\n // Rally WSAPI only supports binary AND — nest into pairs\n const labelExpr = labelConditions.reduce((acc, cond) => acc ? `(${acc} AND ${cond})` : cond, '');\n conditions.push(labelExpr);\n }\n\n if (filters?.query) {\n conditions.push(`((Name contains \"${filters.query}\") OR (Description contains \"${filters.query}\"))`);\n }\n\n // Rally WSAPI only supports binary (expr AND expr) — reduce into nested pairs\n return conditions.reduce((acc, cond) => acc ? `(${acc} AND ${cond})` : cond, '');\n }\n\n private normalizeIssue(rallyArtifact: any): Issue {\n // Determine state from ScheduleState (User Stories, Tasks) or State (Defects, Features)\n // For PortfolioItem/Feature, State is a Rally ref object with Name/_refObjectName, not a string\n const rawStateValue = rallyArtifact.ScheduleState || rallyArtifact.State || 'Defined';\n const stateValue = typeof rawStateValue === 'object' && rawStateValue !== null\n ? (rawStateValue.Name || rawStateValue._refObjectName || 'Defined')\n : rawStateValue;\n const state = this.mapState(stateValue);\n\n // Extract tags — ensure all entries are strings\n const labels: string[] = [];\n if (rallyArtifact.Tags && rallyArtifact.Tags._tagsNameArray) {\n for (const tag of rallyArtifact.Tags._tagsNameArray) {\n if (typeof tag === 'string') {\n labels.push(tag);\n } else if (tag?.Name) {\n labels.push(tag.Name);\n }\n }\n }\n\n // Map priority\n const priority = rallyArtifact.Priority\n ? PRIORITY_MAP[rallyArtifact.Priority] ?? 2\n : undefined;\n\n // Use ObjectID if available, fall back to FormattedID\n const objectId = rallyArtifact.ObjectID || rallyArtifact.FormattedID;\n const artifactType = rallyArtifact._type || 'artifact';\n\n // Build URL - Rally's web UI detail path\n const baseUrl = this.restApi.server.replace('/slm/webservice/', '');\n const url = `${baseUrl}/#/detail/${artifactType.toLowerCase()}/${objectId}`;\n\n // Resolve parent reference.\n // For User Stories, PortfolioItem links to the parent Feature (F-prefixed),\n // while Parent links to a parent Story in the hierarchy. Prefer PortfolioItem\n // so that stories are correctly grouped under their Feature. (PAN-202)\n let parentRef: string | undefined;\n if (rallyArtifact.PortfolioItem) {\n if (rallyArtifact.PortfolioItem.FormattedID) {\n parentRef = rallyArtifact.PortfolioItem.FormattedID;\n } else if (rallyArtifact.PortfolioItem._refObjectName) {\n parentRef = rallyArtifact.PortfolioItem._refObjectName;\n }\n } else if (rallyArtifact.Parent) {\n if (rallyArtifact.Parent.FormattedID) {\n parentRef = rallyArtifact.Parent.FormattedID;\n } else if (rallyArtifact.Parent._refObjectName) {\n parentRef = rallyArtifact.Parent._refObjectName;\n }\n }\n\n return {\n id: String(objectId),\n ref: rallyArtifact.FormattedID,\n title: rallyArtifact.Name || '',\n description: rallyArtifact.Description || '',\n state,\n labels,\n assignee: rallyArtifact.Owner?._refObjectName,\n url,\n tracker: 'rally' as TrackerType,\n priority,\n dueDate: rallyArtifact.DueDate,\n createdAt: rallyArtifact.CreationDate,\n updatedAt: rallyArtifact.LastUpdateDate,\n parentRef,\n artifactType,\n rawState: stateValue,\n };\n }\n\n private mapState(rallyState: string): IssueState {\n return STATE_MAP[rallyState] ?? 'open';\n }\n\n private reverseMapState(state: IssueState, kind: 'story' | 'defect' | 'feature' = 'story'): string {\n if (kind === 'feature') {\n // Features / PortfolioItems use State: Discovering, Developing, Done\n switch (state) {\n case 'open': return 'Discovering';\n case 'in_progress':\n case 'in_review': return 'Developing';\n case 'closed': return 'Done';\n default: return 'Discovering';\n }\n }\n if (kind === 'defect') {\n // Defects use State: Submitted, Open, Fixed, Closed\n switch (state) {\n case 'open': return 'Submitted';\n case 'in_progress':\n case 'in_review': return 'Open';\n case 'closed': return 'Closed';\n default: return 'Submitted';\n }\n }\n // User Stories / Tasks use ScheduleState: Defined, In-Progress, Completed\n switch (state) {\n case 'open': return 'Defined';\n case 'in_progress':\n case 'in_review': return 'In-Progress';\n case 'closed': return 'Completed';\n default: return 'Defined';\n }\n }\n\n // Rally API wrapper methods\n private async queryRally(queryConfig: any): Promise<any> {\n const result = await this.restApi.query(queryConfig);\n // Extract Results from WSAPI response format\n return {\n Results: result.QueryResult.Results,\n TotalResultCount: result.QueryResult.TotalResultCount,\n };\n }\n\n private async createRally(type: string, data: any): Promise<any> {\n const result = await this.restApi.create({\n type,\n data,\n fetch: ['FormattedID', 'ObjectID', '_ref'],\n });\n // Extract Object from WSAPI response format\n return {\n Object: result.CreateResult.Object,\n };\n }\n\n private async updateRally(type: string, ref: string, data: any): Promise<any> {\n const result = await this.restApi.update({\n type,\n ref,\n data,\n fetch: ['FormattedID', 'ObjectID'],\n });\n // Extract Object from WSAPI response format\n return {\n Object: result.OperationResult.Object,\n };\n }\n}\n"],"mappings":";;;;;AAgLa,uBAAb,cAAyC,MAAM;EAC7C,YAAY,SAAiB;AAC3B,SAAM,oBAAoB,UAAU;AACpC,QAAK,OAAO;;;AAOH,sBAAb,cAAwC,MAAM;EAC5C,YAAY,IAAY,SAAsB;AAC5C,SAAM,oBAAoB,GAAG,aAAa,QAAQ,GAAG;AACrD,QAAK,OAAO;;;AAOH,oBAAb,cAAsC,MAAM;EAC1C,YAAY,SAAsB,SAAiB;AACjD,SAAM,6BAA6B,QAAQ,IAAI,UAAU;AACzD,QAAK,OAAO;;;;;;;;iBChM8B;iBAW6C;AAIrF,aAAwC;EAE5C,OAAO;EACP,QAAQ;EACR,WAAW;EACX,eAAe;EACf,aAAa;EACb,YAAY;EAGZ,aAAa;EACb,QAAQ;EACR,SAAS;EACT,UAAU;EAGV,eAAe;EACf,cAAc;EACd,QAAQ;EACT;AAqBK,mBAAuC;EAC3C;GAAE,MAAM;GAA2B,YAAY;GAAiB,cAAc,CAAC,aAAa,WAAW;GAAE;EACzG;GAAE,MAAM;GAAU,YAAY;GAAS,cAAc,CAAC,SAAS;GAAE;EACjE;GAAE,MAAM;GAAQ,YAAY;GAAS,cAAc,CAAC,YAAY;GAAE;EAClE;GAAE,MAAM;GAAyB,YAAY;GAAS,cAAc,CAAC,OAAO;GAAE;EAC/E;AAEK,gBAAe;EACnB;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD;AAGK,gBAAuC;EAC3C,uBAAuB;EACvB,MAAM;EACN,QAAQ;EACR,KAAK;EACN;AAGK,wBAA+C;EACnD,GAAG;EACH,GAAG;EACH,GAAG;EACH,GAAG;EACH,GAAG;EACJ;AASY,gBAAb,MAAkD;EAChD,OAA6B;EAC7B;EACA;EACA;EAEA,YAAY,QAAqB;AAC/B,OAAI,CAAC,OAAO,OACV,OAAM,IAAI,iBAAiB,SAAwB,sBAAsB;AAG3E,QAAK,UAAU,IAAI,aAAa;IAC9B,QAAQ,OAAO;IACf,QAAQ,OAAO,UAAU;IACzB,gBAAgB,EACd,SAAS;KACP,0BAA0B;KAC1B,0BAA0B;KAC1B,4BAA4B;KAC5B,6BAA6B;KAC9B,EACF;IACF,CAAC;AAEF,QAAK,YAAY,OAAO;AACxB,QAAK,UAAU,OAAO;;;;;;;;;EAUxB,MAAM,WAAW,SAA0C;AACzD,OAAI,QAAQ,IAAI,OAAO,SAAS,QAAQ,CACtC,SAAQ,MAAM,0BAA0B,KAAK,UAAU,QAAQ,CAAC;GAGlE,MAAM,QAAQ,SAAS,SAAS;GAIhC,IAAI;AACJ,OAAI,KAAK,SAAS;IAChB,MAAM,QAAQ,KAAK,QAAQ,MAAM,mBAAmB;AACpD,QAAI,MAAO,mBAAkB,MAAM;;GAGrC,MAAM,UAAU,gBAAgB,IAAI,OAAO,iBAAiB;IAC1D,MAAM,cAAc,KAAK,wBAAwB,SAAS,cAAc,gBAAgB;AAExF,QAAI,QAAQ,IAAI,OAAO,SAAS,QAAQ,CACtC,SAAQ,MAAM,WAAW,aAAa,KAAK,UAAU,YAAY;IAGnE,MAAM,QAAa;KACjB,MAAM,aAAa;KACnB,OAAO;KACP;KACA,OAAO;KACR;AAED,QAAI,KAAK,UACP,OAAM,YAAY,KAAK;AAEzB,QAAI,KAAK,SAAS;AAChB,WAAM,UAAU,KAAK;AACrB,WAAM,mBAAmB;;AAG3B,QAAI;AAEF,aADe,MAAM,KAAK,WAAW,MAAM,EAC7B,QAAQ,KAAK,aAAkB,KAAK,eAAe,SAAS,CAAC;aACpE,OAAY;AACnB,SAAI,MAAM,SAAS,SAAS,eAAe,IAAI,MAAM,SAAS,SAAS,MAAM,CAC3E,OAAM,IAAI,iBAAiB,SAAwB,8CAA8C;AAGnG,SAAI,QAAQ,IAAI,OAAO,SAAS,QAAQ,CACtC,SAAQ,MAAM,2BAA2B,aAAa,KAAK,IAAI,MAAM,QAAQ;AAE/E,YAAO,EAAE;;KAEX;GAGF,MAAM,aADU,MAAM,QAAQ,IAAI,QAAQ,EAChB,MAAM;AAGhC,aAAU,MACP,GAAG,MAAM,IAAI,KAAK,EAAE,UAAU,CAAC,SAAS,GAAG,IAAI,KAAK,EAAE,UAAU,CAAC,SAAS,CAC5E;AAED,UAAO,UAAU,MAAM,GAAG,MAAM;;EAGlC,MAAM,SAAS,IAA4B;AACzC,OAAI;IAEF,MAAM,QAAa;KACjB,MAAM;KACN,OAAO;MACL;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACD;KACD,OAAO,mBAAmB,GAAG;KAC9B;AAED,QAAI,KAAK,UACP,OAAM,YAAY,KAAK;IAGzB,MAAM,SAAS,MAAM,KAAK,WAAW,MAAM;AAE3C,QAAI,CAAC,OAAO,WAAW,OAAO,QAAQ,WAAW,EAC/C,OAAM,IAAI,mBAAmB,IAAI,QAAuB;AAG1D,WAAO,KAAK,eAAe,OAAO,QAAQ,GAAG;YACtC,OAAY;AACnB,QAAI,iBAAiB,mBAAoB,OAAM;AAC/C,UAAM,IAAI,mBAAmB,IAAI,QAAuB;;;EAI5D,MAAM,YAAY,IAAY,QAAqC;AACnD,SAAM,KAAK,SAAS,GAAG;GAGrC,MAAM,QAAa;IACjB,MAAM;IACN,OAAO;KAAC;KAAY;KAAQ;KAAQ;IACpC,OAAO,mBAAmB,GAAG;IAC9B;AAED,OAAI,KAAK,UACP,OAAM,YAAY,KAAK;GAGzB,MAAM,SAAS,MAAM,KAAK,WAAW,MAAM;AAC3C,OAAI,CAAC,OAAO,WAAW,OAAO,QAAQ,WAAW,EAC/C,OAAM,IAAI,mBAAmB,IAAI,QAAuB;GAG1D,MAAM,WAAW,OAAO,QAAQ;GAChC,MAAM,gBAAyC,EAAE;AAEjD,OAAI,OAAO,UAAU,KAAA,EACnB,eAAc,OAAO,OAAO;AAE9B,OAAI,OAAO,gBAAgB,KAAA,EACzB,eAAc,cAAc,OAAO;AAErC,OAAI,OAAO,UAAU,KAAA,GAAW;IAC9B,MAAM,gBAAgB,SAAS,SAAS,IAAI,aAAa;IACzD,MAAM,OAAO,aAAa,WAAW,gBAAgB,GAAG,YACpD,iBAAiB,WAAW,WAAW;IAC3C,MAAM,aAAa,KAAK,gBAAgB,OAAO,OAAO,KAAK;AAC3D,QAAI,SAAS,QACX,eAAc,gBAAgB;QAE9B,eAAc,QAAQ;;AAG1B,OAAI,OAAO,aAAa,KAAA,EACtB,eAAc,WAAW,qBAAqB,OAAO,aAAa;AAEpE,OAAI,OAAO,YAAY,KAAA,EACrB,eAAc,UAAU,OAAO;AAGjC,OAAI,OAAO,KAAK,cAAc,CAAC,SAAS,EACtC,OAAM,KAAK,YAAY,SAAS,MAAM,aAAa,EAAE,SAAS,MAAM,cAAc;AAGpF,UAAO,KAAK,SAAS,GAAG;;EAG1B,MAAM,YAAY,UAAoC;AACpD,OAAI,CAAC,KAAK,WAAW,CAAC,SAAS,KAC7B,OAAM,IAAI,MAAM,kFAAkF;GAGpG,MAAM,UAAU,SAAS,QAAQ,KAAK;GAGtC,MAAM,gBAAyC;IAC7C,MAAM,SAAS;IACf,aAAa,SAAS,eAAe;IACrC,SAAS;IACV;AAED,OAAI,SAAS,aAAa,KAAA,EACxB,eAAc,WAAW,qBAAqB,SAAS,aAAa;AAEtE,OAAI,SAAS,QACX,eAAc,UAAU,SAAS;AAEnC,OAAI,KAAK,UACP,eAAc,YAAY,KAAK;GAGjC,MAAM,SAAS,MAAM,KAAK,YAAY,2BAA2B,cAAc;AAG/E,UAAO,KAAK,SAAS,OAAO,OAAO,YAAY;;EAGjD,MAAM,YAAY,SAAqC;AACvC,SAAM,KAAK,SAAS,QAAQ;GAG1C,MAAM,QAAa;IACjB,MAAM;IACN,OAAO;KAAC;KAAY;KAAQ;KAAa;IACzC,OAAO,mBAAmB,QAAQ;IACnC;AAED,OAAI,KAAK,UACP,OAAM,YAAY,KAAK;GAGzB,MAAM,SAAS,MAAM,KAAK,WAAW,MAAM;AAC3C,OAAI,CAAC,OAAO,WAAW,OAAO,QAAQ,WAAW,EAC/C,QAAO,EAAE;GAGX,MAAM,WAAW,OAAO,QAAQ;AAChC,OAAI,CAAC,SAAS,WACZ,QAAO,EAAE;GAIX,MAAM,aAAkB;IACtB,MAAM;IACN,OAAO;KAAC;KAAY;KAAQ;KAAQ;KAAgB;KAAa;IACjE,OAAO,kBAAkB,SAAS,WAAW,KAAK;IAClD,OAAO;IACR;AAID,YAFoB,MAAM,KAAK,WAAW,WAAW,EAEjC,WAAW,EAAE,EAAE,KAAK,UAAe;IACrD,IAAI,KAAK;IACT;IACA,MAAM,KAAK,QAAQ;IACnB,QAAQ,KAAK,MAAM,kBAAkB;IACrC,WAAW,KAAK;IAChB,WAAW,KAAK;IACjB,EAAE;;EAGL,MAAM,WAAW,SAAiB,MAAgC;GAEhE,MAAM,QAAa;IACjB,MAAM;IACN,OAAO;KAAC;KAAY;KAAQ;KAAa;IACzC,OAAO,mBAAmB,QAAQ;IACnC;AAED,OAAI,KAAK,UACP,OAAM,YAAY,KAAK;GAGzB,MAAM,SAAS,MAAM,KAAK,WAAW,MAAM;AAC3C,OAAI,CAAC,OAAO,WAAW,OAAO,QAAQ,WAAW,EAC/C,OAAM,IAAI,mBAAmB,SAAS,QAAuB;GAG/D,MAAM,WAAW,OAAO,QAAQ;AAIhC,OAAI,CADgB,SAAS,YAAY,KAOvC,QAAO;IACL,KANuB,MAAM,KAAK,YAAY,oBAAoB;KAClE,UAAU,SAAS;KACnB,MAAM;KACP,CAAC,EAGqB,OAAO;IAC5B;IACA;IACA,QAAQ;IACR,4BAAW,IAAI,MAAM,EAAC,aAAa;IACnC,4BAAW,IAAI,MAAM,EAAC,aAAa;IACpC;AASH,UAAO;IACL,KANiB,MAAM,KAAK,YAAY,oBAAoB;KAC5D,UAAU,SAAS;KACnB,MAAM;KACP,CAAC,EAGe,OAAO;IACtB;IACA;IACA,QAAQ;IACR,4BAAW,IAAI,MAAM,EAAC,aAAa;IACnC,4BAAW,IAAI,MAAM,EAAC,aAAa;IACpC;;EAGH,MAAM,gBAAgB,IAAY,OAAkC;AAClE,SAAM,KAAK,YAAY,IAAI,EAAE,OAAO,CAAC;;EAGvC,MAAM,OAAO,SAAiB,OAA8B;AAE1D,SAAM,KAAK,WAAW,SAAS,wBAAwB,QAAQ;;;;;;;;;;;;;EAgBjE,wBACE,SACA,cACA,iBACQ;GACR,MAAM,aAAuB,EAAE;AAG/B,OAAI,gBACF,YAAW,KAAK,wBAAwB,gBAAgB,IAAI;AAG9D,OAAI,SAAS,SAAS,CAAC,QAAQ,eAAe;IAC5C,MAAM,OAAO,aAAa,KAAK,WAAW,gBAAgB,GAAG,YACzD,aAAa,SAAS,WAAW,WAAW;IAChD,MAAM,aAAa,KAAK,gBAAgB,QAAQ,OAAO,KAAK;AAC5D,eAAW,KAAK,IAAI,aAAa,WAAW,MAAM,WAAW,IAAI;;AAGnE,OAAI,CAAC,SAAS,eAAe;IAM3B,MAAM,aAJmB,aAAa,aAAa,KAChD,UAAU,IAAI,aAAa,WAAW,OAAO,MAAM,IACrD,CAEmC,QACjC,KAAK,SAAU,MAAM,IAAI,IAAI,OAAO,KAAK,KAAK,MAC/C,GACD;AACD,eAAW,KAAK,WAAW;;AAG7B,OAAI,SAAS,SACX,YAAW,KAAK,yBAAyB,QAAQ,SAAS,IAAI;AAGhE,OAAI,SAAS,UAAU,QAAQ,OAAO,SAAS,GAAG;IAKhD,MAAM,YAJkB,QAAQ,OAAO,KACpC,UAAU,wBAAwB,MAAM,IAC1C,CAEiC,QAAQ,KAAK,SAAS,MAAM,IAAI,IAAI,OAAO,KAAK,KAAK,MAAM,GAAG;AAChG,eAAW,KAAK,UAAU;;AAG5B,OAAI,SAAS,MACX,YAAW,KAAK,oBAAoB,QAAQ,MAAM,+BAA+B,QAAQ,MAAM,KAAK;AAItG,UAAO,WAAW,QAAQ,KAAK,SAAS,MAAM,IAAI,IAAI,OAAO,KAAK,KAAK,MAAM,GAAG;;EAGlF,eAAuB,eAA2B;GAGhD,MAAM,gBAAgB,cAAc,iBAAiB,cAAc,SAAS;GAC5E,MAAM,aAAa,OAAO,kBAAkB,YAAY,kBAAkB,OACrE,cAAc,QAAQ,cAAc,kBAAkB,YACvD;GACJ,MAAM,QAAQ,KAAK,SAAS,WAAW;GAGvC,MAAM,SAAmB,EAAE;AAC3B,OAAI,cAAc,QAAQ,cAAc,KAAK;SACtC,MAAM,OAAO,cAAc,KAAK,eACnC,KAAI,OAAO,QAAQ,SACjB,QAAO,KAAK,IAAI;aACP,KAAK,KACd,QAAO,KAAK,IAAI,KAAK;;GAM3B,MAAM,WAAW,cAAc,WAC3B,aAAa,cAAc,aAAa,IACxC,KAAA;GAGJ,MAAM,WAAW,cAAc,YAAY,cAAc;GACzD,MAAM,eAAe,cAAc,SAAS;GAI5C,MAAM,MAAM,GADI,KAAK,QAAQ,OAAO,QAAQ,oBAAoB,GAAG,CAC5C,YAAY,aAAa,aAAa,CAAC,GAAG;GAMjE,IAAI;AACJ,OAAI,cAAc;QACZ,cAAc,cAAc,YAC9B,aAAY,cAAc,cAAc;aAC/B,cAAc,cAAc,eACrC,aAAY,cAAc,cAAc;cAEjC,cAAc;QACnB,cAAc,OAAO,YACvB,aAAY,cAAc,OAAO;aACxB,cAAc,OAAO,eAC9B,aAAY,cAAc,OAAO;;AAIrC,UAAO;IACL,IAAI,OAAO,SAAS;IACpB,KAAK,cAAc;IACnB,OAAO,cAAc,QAAQ;IAC7B,aAAa,cAAc,eAAe;IAC1C;IACA;IACA,UAAU,cAAc,OAAO;IAC/B;IACA,SAAS;IACT;IACA,SAAS,cAAc;IACvB,WAAW,cAAc;IACzB,WAAW,cAAc;IACzB;IACA;IACA,UAAU;IACX;;EAGH,SAAiB,YAAgC;AAC/C,UAAO,UAAU,eAAe;;EAGlC,gBAAwB,OAAmB,OAAuC,SAAiB;AACjG,OAAI,SAAS,UAEX,SAAQ,OAAR;IACE,KAAK,OAAQ,QAAO;IACpB,KAAK;IACL,KAAK,YAAa,QAAO;IACzB,KAAK,SAAU,QAAO;IACtB,QAAS,QAAO;;AAGpB,OAAI,SAAS,SAEX,SAAQ,OAAR;IACE,KAAK,OAAQ,QAAO;IACpB,KAAK;IACL,KAAK,YAAa,QAAO;IACzB,KAAK,SAAU,QAAO;IACtB,QAAS,QAAO;;AAIpB,WAAQ,OAAR;IACE,KAAK,OAAQ,QAAO;IACpB,KAAK;IACL,KAAK,YAAa,QAAO;IACzB,KAAK,SAAU,QAAO;IACtB,QAAS,QAAO;;;EAKpB,MAAc,WAAW,aAAgC;GACvD,MAAM,SAAS,MAAM,KAAK,QAAQ,MAAM,YAAY;AAEpD,UAAO;IACL,SAAS,OAAO,YAAY;IAC5B,kBAAkB,OAAO,YAAY;IACtC;;EAGH,MAAc,YAAY,MAAc,MAAyB;AAO/D,UAAO,EACL,SAPa,MAAM,KAAK,QAAQ,OAAO;IACvC;IACA;IACA,OAAO;KAAC;KAAe;KAAY;KAAO;IAC3C,CAAC,EAGe,aAAa,QAC7B;;EAGH,MAAc,YAAY,MAAc,KAAa,MAAyB;AAQ5E,UAAO,EACL,SARa,MAAM,KAAK,QAAQ,OAAO;IACvC;IACA;IACA;IACA,OAAO,CAAC,eAAe,WAAW;IACnC,CAAC,EAGe,gBAAgB,QAChC"}
|
|
1
|
+
{"version":3,"file":"rally-YjFRxIiC.js","names":[],"sources":["../../src/lib/tracker/interface.ts","../../src/lib/tracker/rally.ts"],"sourcesContent":["/**\n * Issue Tracker Abstraction Layer\n *\n * Provides a unified interface for different issue tracking systems\n * (Linear, GitHub Issues, GitLab Issues, etc.)\n */\n\n// Supported tracker types\nexport type TrackerType = 'linear' | 'github' | 'gitlab' | 'rally';\n\n// Normalized issue state (lowest common denominator)\nexport type IssueState = 'open' | 'in_progress' | 'in_review' | 'closed';\n\n// Normalized issue format\nexport interface Issue {\n /** Tracker-specific unique ID */\n id: string;\n\n /** Human-readable reference (e.g., MIN-630, #42) */\n ref: string;\n\n /** Issue title */\n title: string;\n\n /** Issue description/body (markdown) */\n description: string;\n\n /** Normalized state */\n state: IssueState;\n\n /** Labels/tags */\n labels: string[];\n\n /** Assignee username/name */\n assignee?: string;\n\n /** Web URL to the issue */\n url: string;\n\n /** Which tracker this issue came from */\n tracker: TrackerType;\n\n /** Cross-tracker linked issue references */\n linkedIssues?: string[];\n\n /** Priority (1=urgent, 2=high, 3=normal, 4=low) */\n priority?: number;\n\n /** Due date (ISO string) */\n dueDate?: string;\n\n /** Creation timestamp (ISO string) */\n createdAt: string;\n\n /** Last update timestamp (ISO string) */\n updatedAt: string;\n\n /** Parent issue FormattedID (e.g., \"F1234\") for Rally hierarchy */\n parentRef?: string;\n\n /** Rally artifact type (e.g., \"HierarchicalRequirement\", \"PortfolioItem/Feature\") */\n artifactType?: string;\n\n /** Raw tracker state name before normalization (e.g., \"Discovering\", \"In-Progress\") */\n rawState?: string;\n}\n\n// Comment on an issue\nexport interface Comment {\n id: string;\n issueId: string;\n body: string;\n author: string;\n createdAt: string;\n updatedAt: string;\n}\n\n// Filters for listing issues\nexport interface IssueFilters {\n /** Filter by state */\n state?: IssueState;\n\n /** Filter by labels (AND logic) */\n labels?: string[];\n\n /** Filter by assignee */\n assignee?: string;\n\n /** Filter by team/project (tracker-specific) */\n team?: string;\n\n /** Search query for title/description */\n query?: string;\n\n /** Maximum number of results */\n limit?: number;\n\n /** Include closed issues (default: false) */\n includeClosed?: boolean;\n}\n\n// Data for creating a new issue\nexport interface NewIssue {\n title: string;\n description?: string;\n labels?: string[];\n assignee?: string;\n team?: string;\n priority?: number;\n dueDate?: string;\n}\n\n// Data for updating an issue\nexport interface IssueUpdate {\n title?: string;\n description?: string;\n state?: IssueState;\n labels?: string[];\n assignee?: string;\n priority?: number;\n dueDate?: string;\n}\n\n/**\n * Abstract interface for issue trackers.\n * Implementations must handle normalization to/from tracker-specific formats.\n */\nexport interface IssueTracker {\n /** Tracker type identifier */\n readonly name: TrackerType;\n\n /**\n * List issues matching filters\n */\n listIssues(filters?: IssueFilters): Promise<Issue[]>;\n\n /**\n * Get a single issue by ID or ref\n * @param id - Issue ID or human-readable ref (e.g., \"MIN-630\", \"#42\")\n */\n getIssue(id: string): Promise<Issue>;\n\n /**\n * Update an existing issue\n */\n updateIssue(id: string, update: IssueUpdate): Promise<Issue>;\n\n /**\n * Create a new issue\n */\n createIssue(issue: NewIssue): Promise<Issue>;\n\n /**\n * Get comments on an issue\n */\n getComments(issueId: string): Promise<Comment[]>;\n\n /**\n * Add a comment to an issue\n */\n addComment(issueId: string, body: string): Promise<Comment>;\n\n /**\n * Transition issue to a new state\n */\n transitionIssue(id: string, state: IssueState): Promise<void>;\n\n /**\n * Link a PR/MR to an issue\n */\n linkPR(issueId: string, prUrl: string): Promise<void>;\n}\n\n/**\n * Error thrown when a tracker feature is not implemented\n */\nexport class NotImplementedError extends Error {\n constructor(feature: string) {\n super(`Not implemented: ${feature}`);\n this.name = 'NotImplementedError';\n }\n}\n\n/**\n * Error thrown when an issue is not found\n */\nexport class IssueNotFoundError extends Error {\n constructor(id: string, tracker: TrackerType) {\n super(`Issue not found: ${id} (tracker: ${tracker})`);\n this.name = 'IssueNotFoundError';\n }\n}\n\n/**\n * Error thrown when tracker authentication fails\n */\nexport class TrackerAuthError extends Error {\n constructor(tracker: TrackerType, message: string) {\n super(`Authentication failed for ${tracker}: ${message}`);\n this.name = 'TrackerAuthError';\n }\n}\n","/**\n * Rally Tracker Adapter\n *\n * Implements IssueTracker interface for Broadcom Rally (formerly CA Agile Central).\n * Supports all Rally work item types: User Stories, Defects, Tasks, and Features.\n */\n\nimport { RallyRestApi } from './rally-api.js';\nimport type {\n Issue,\n IssueFilters,\n IssueState,\n IssueTracker,\n IssueUpdate,\n NewIssue,\n Comment,\n TrackerType,\n} from './interface.js';\nimport { IssueNotFoundError, TrackerAuthError, NotImplementedError } from './interface.js';\n\n// Map Rally ScheduleState/State to normalized IssueState.\n// Covers all standard states for User Stories, Defects, Tasks, and Features.\nconst STATE_MAP: Record<string, IssueState> = {\n // User Stories (ScheduleState)\n 'New': 'open',\n 'Idea': 'open',\n 'Defined': 'open',\n 'In-Progress': 'in_progress',\n 'Completed': 'closed',\n 'Accepted': 'closed',\n\n // Defects (State)\n 'Submitted': 'open',\n 'Open': 'in_progress', // \"Open\" defects are actively being worked\n 'Fixed': 'closed',\n 'Closed': 'closed',\n\n // Features / PortfolioItems (State)\n 'Discovering': 'open',\n 'Developing': 'in_progress',\n 'Done': 'closed',\n};\n\n// Rally artifact types we support\ntype RallyArtifactType = 'HierarchicalRequirement' | 'Defect' | 'Task' | 'PortfolioItem/Feature';\n\n/**\n * Type-specific query configuration.\n *\n * Rally WSAPI cannot filter generic Artifact by ScheduleState because not all\n * subtypes have that field. Instead, we query each type separately with its\n * own state field and merge the results. (PAN-168)\n */\ninterface ArtifactTypeQuery {\n /** WSAPI endpoint type (lowercase) */\n type: string;\n /** The state field used for filtering on this artifact type */\n stateField: 'ScheduleState' | 'State';\n /** State values that represent \"closed\" for this type */\n closedStates: string[];\n}\n\nconst QUERYABLE_TYPES: ArtifactTypeQuery[] = [\n { type: 'hierarchicalrequirement', stateField: 'ScheduleState', closedStates: ['Completed', 'Accepted'] },\n { type: 'defect', stateField: 'State', closedStates: ['Closed'] },\n { type: 'task', stateField: 'State', closedStates: ['Completed'] },\n { type: 'portfolioitem/feature', stateField: 'State', closedStates: ['Done'] },\n];\n\nconst FETCH_FIELDS = [\n 'ObjectID',\n 'FormattedID',\n 'Name',\n 'Description',\n 'ScheduleState',\n 'State',\n 'Tags',\n 'Owner',\n 'Priority',\n 'DueDate',\n 'CreationDate',\n 'LastUpdateDate',\n 'Parent',\n 'PortfolioItem',\n '_type',\n];\n\n// Rally priority strings to numbers\nconst PRIORITY_MAP: Record<string, number> = {\n 'Resolve Immediately': 0,\n High: 1,\n Normal: 2,\n Low: 3,\n};\n\n// Reverse priority mapping\nconst REVERSE_PRIORITY_MAP: Record<number, string> = {\n 0: 'Resolve Immediately',\n 1: 'High',\n 2: 'Normal',\n 3: 'Low',\n 4: 'Low',\n};\n\nexport interface RallyConfig {\n apiKey: string;\n server?: string; // Default: rally1.rallydev.com\n workspace?: string; // Rally workspace OID (e.g., \"/workspace/12345\")\n project?: string; // Rally project OID (e.g., \"/project/67890\")\n}\n\nexport class RallyTracker implements IssueTracker {\n readonly name: TrackerType = 'rally' as TrackerType;\n private restApi: RallyRestApi;\n private workspace?: string;\n private project?: string;\n\n constructor(config: RallyConfig) {\n if (!config.apiKey) {\n throw new TrackerAuthError('rally' as TrackerType, 'API key is required');\n }\n\n this.restApi = new RallyRestApi({\n apiKey: config.apiKey,\n server: config.server || 'https://rally1.rallydev.com',\n requestOptions: {\n headers: {\n 'X-RallyIntegrationType': 'Panopticon',\n 'X-RallyIntegrationName': 'Panopticon CLI',\n 'X-RallyIntegrationVendor': 'Mind Your Now',\n 'X-RallyIntegrationVersion': '0.2.0',\n },\n },\n });\n\n this.workspace = config.workspace;\n this.project = config.project;\n }\n\n /**\n * List issues by querying each artifact type separately and merging results.\n *\n * Rally WSAPI cannot apply ScheduleState filters across the generic Artifact\n * endpoint because not all subtypes have that field. We query each type with\n * its own state field, then merge and sort. (PAN-168)\n */\n async listIssues(filters?: IssueFilters): Promise<Issue[]> {\n if (process.env.DEBUG?.includes('rally')) {\n console.debug('[Rally] Query filters:', JSON.stringify(filters));\n }\n\n const limit = filters?.limit ?? 50;\n\n // Extract ObjectID from project ref for explicit query scoping\n // e.g., \"/project/822404704163\" → \"822404704163\"\n let projectObjectId: string | undefined;\n if (this.project) {\n const match = this.project.match(/\\/project\\/(\\d+)/);\n if (match) projectObjectId = match[1];\n }\n\n const queries = QUERYABLE_TYPES.map(async (artifactType) => {\n const queryString = this.buildQueryStringForType(filters, artifactType, projectObjectId);\n\n if (process.env.DEBUG?.includes('rally')) {\n console.debug(`[Rally] ${artifactType.type} query:`, queryString);\n }\n\n const query: any = {\n type: artifactType.type,\n fetch: FETCH_FIELDS,\n limit,\n query: queryString,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n if (this.project) {\n query.project = this.project;\n query.projectScopeDown = true;\n }\n\n try {\n const result = await this.queryRally(query);\n return result.Results.map((artifact: any) => this.normalizeIssue(artifact));\n } catch (error: any) {\n if (error.message?.includes('Unauthorized') || error.message?.includes('401')) {\n throw new TrackerAuthError('rally' as TrackerType, 'Invalid API key or insufficient permissions');\n }\n // Log and skip individual type failures so other types still return\n if (process.env.DEBUG?.includes('rally')) {\n console.debug(`[Rally] Failed to query ${artifactType.type}:`, error.message);\n }\n return [];\n }\n });\n\n const results = await Promise.all(queries);\n const allIssues = results.flat();\n\n // Sort by most recently updated first, then apply overall limit\n allIssues.sort(\n (a, b) => new Date(b.updatedAt).getTime() - new Date(a.updatedAt).getTime()\n );\n\n return allIssues.slice(0, limit);\n }\n\n async getIssue(id: string): Promise<Issue> {\n try {\n // Rally FormattedIDs look like: US123, DE456, TA789, F012\n const query: any = {\n type: 'artifact',\n fetch: [\n 'FormattedID',\n 'Name',\n 'Description',\n 'ScheduleState',\n 'State',\n 'Tags',\n 'Owner',\n 'Priority',\n 'DueDate',\n 'CreationDate',\n 'LastUpdateDate',\n 'Parent',\n '_type',\n ],\n query: `(FormattedID = \"${id}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n\n return this.normalizeIssue(result.Results[0]);\n } catch (error: any) {\n if (error instanceof IssueNotFoundError) throw error;\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n }\n\n async updateIssue(id: string, update: IssueUpdate): Promise<Issue> {\n const issue = await this.getIssue(id);\n\n // Get the Rally object reference\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', '_type'],\n query: `(FormattedID = \"${id}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(id, 'rally' as TrackerType);\n }\n\n const artifact = result.Results[0];\n const updatePayload: Record<string, unknown> = {};\n\n if (update.title !== undefined) {\n updatePayload.Name = update.title;\n }\n if (update.description !== undefined) {\n updatePayload.Description = update.description;\n }\n if (update.state !== undefined) {\n const artifactType = (artifact._type || '').toLowerCase();\n const kind = artifactType.startsWith('portfolioitem') ? 'feature'\n : artifactType === 'defect' ? 'defect' : 'story';\n const rallyState = this.reverseMapState(update.state, kind);\n if (kind === 'story') {\n updatePayload.ScheduleState = rallyState;\n } else {\n updatePayload.State = rallyState;\n }\n }\n if (update.priority !== undefined) {\n updatePayload.Priority = REVERSE_PRIORITY_MAP[update.priority] || 'Normal';\n }\n if (update.dueDate !== undefined) {\n updatePayload.DueDate = update.dueDate;\n }\n\n if (Object.keys(updatePayload).length > 0) {\n await this.updateRally(artifact._type.toLowerCase(), artifact._ref, updatePayload);\n }\n\n return this.getIssue(id);\n }\n\n async createIssue(newIssue: NewIssue): Promise<Issue> {\n if (!this.project && !newIssue.team) {\n throw new Error('Project is required to create an issue. Set it in config or provide team field.');\n }\n\n const project = newIssue.team || this.project;\n\n // Default to HierarchicalRequirement (User Story) for new issues\n const createPayload: Record<string, unknown> = {\n Name: newIssue.title,\n Description: newIssue.description || '',\n Project: project,\n };\n\n if (newIssue.priority !== undefined) {\n createPayload.Priority = REVERSE_PRIORITY_MAP[newIssue.priority] || 'Normal';\n }\n if (newIssue.dueDate) {\n createPayload.DueDate = newIssue.dueDate;\n }\n if (this.workspace) {\n createPayload.Workspace = this.workspace;\n }\n\n const result = await this.createRally('hierarchicalrequirement', createPayload);\n\n // Fetch the created issue to return normalized format\n return this.getIssue(result.Object.FormattedID);\n }\n\n async getComments(issueId: string): Promise<Comment[]> {\n const issue = await this.getIssue(issueId);\n\n // Get the Rally object to find its Discussion\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', 'Discussion'],\n query: `(FormattedID = \"${issueId}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n return [];\n }\n\n const artifact = result.Results[0];\n if (!artifact.Discussion) {\n return [];\n }\n\n // Query ConversationPosts for this Discussion\n const postsQuery: any = {\n type: 'conversationpost',\n fetch: ['ObjectID', 'Text', 'User', 'CreationDate', 'PostNumber'],\n query: `(Discussion = \"${artifact.Discussion._ref}\")`,\n order: 'PostNumber',\n };\n\n const postsResult = await this.queryRally(postsQuery);\n\n return (postsResult.Results || []).map((post: any) => ({\n id: post.ObjectID,\n issueId,\n body: post.Text || '',\n author: post.User?._refObjectName || 'Unknown',\n createdAt: post.CreationDate,\n updatedAt: post.CreationDate, // Rally doesn't track comment updates separately\n }));\n }\n\n async addComment(issueId: string, body: string): Promise<Comment> {\n // Get the Rally object to find its Discussion\n const query: any = {\n type: 'artifact',\n fetch: ['ObjectID', '_ref', 'Discussion'],\n query: `(FormattedID = \"${issueId}\")`,\n };\n\n if (this.workspace) {\n query.workspace = this.workspace;\n }\n\n const result = await this.queryRally(query);\n if (!result.Results || result.Results.length === 0) {\n throw new IssueNotFoundError(issueId, 'rally' as TrackerType);\n }\n\n const artifact = result.Results[0];\n\n // If no Discussion exists, create one\n let discussionRef = artifact.Discussion?._ref;\n if (!discussionRef) {\n const discussionResult = await this.createRally('conversationpost', {\n Artifact: artifact._ref,\n Text: body,\n });\n\n return {\n id: discussionResult.Object.ObjectID,\n issueId,\n body,\n author: 'Panopticon',\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n };\n }\n\n // Add a post to existing Discussion\n const postResult = await this.createRally('conversationpost', {\n Artifact: artifact._ref,\n Text: body,\n });\n\n return {\n id: postResult.Object.ObjectID,\n issueId,\n body,\n author: 'Panopticon',\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n };\n }\n\n async transitionIssue(id: string, state: IssueState): Promise<void> {\n await this.updateIssue(id, { state });\n }\n\n async linkPR(issueId: string, prUrl: string): Promise<void> {\n // Add a comment with the PR link\n await this.addComment(issueId, `Linked Pull Request: ${prUrl}`);\n }\n\n // Private helper methods\n\n /**\n * Build a Rally WSAPI query string for a specific artifact type.\n *\n * Each artifact type has its own state field:\n * - HierarchicalRequirement: ScheduleState (Defined, In-Progress, Completed, Accepted)\n * - Defect: State (Submitted, Open, Fixed, Closed)\n * - Task: State (Defined, In-Progress, Completed)\n *\n * Rally WSAPI v2.0 requires binary-nested AND/OR with outer parentheses.\n * (PAN-166, PAN-168)\n */\n private buildQueryStringForType(\n filters: IssueFilters | undefined,\n artifactType: ArtifactTypeQuery,\n projectObjectId?: string,\n ): string {\n const conditions: string[] = [];\n\n // Explicit project scoping — more reliable than WSAPI project param alone\n if (projectObjectId) {\n conditions.push(`(Project.ObjectID = \"${projectObjectId}\")`);\n }\n\n if (filters?.state && !filters.includeClosed) {\n const kind = artifactType.type.startsWith('portfolioitem') ? 'feature'\n : artifactType.type === 'defect' ? 'defect' : 'story';\n const rallyState = this.reverseMapState(filters.state, kind);\n conditions.push(`(${artifactType.stateField} = \"${rallyState}\")`);\n }\n\n if (!filters?.includeClosed) {\n // Exclude closed states for this specific artifact type\n const closedConditions = artifactType.closedStates.map(\n (state) => `(${artifactType.stateField} != \"${state}\")`\n );\n // Rally WSAPI only supports binary AND — nest into pairs\n const closedExpr = closedConditions.reduce(\n (acc, cond) => (acc ? `(${acc} AND ${cond})` : cond),\n '',\n );\n conditions.push(closedExpr);\n }\n\n if (filters?.assignee) {\n conditions.push(`(Owner.Name contains \"${filters.assignee}\")`);\n }\n\n if (filters?.labels && filters.labels.length > 0) {\n const labelConditions = filters.labels.map(\n (label) => `(Tags.Name contains \"${label}\")`\n );\n // Rally WSAPI only supports binary AND — nest into pairs\n const labelExpr = labelConditions.reduce((acc, cond) => acc ? `(${acc} AND ${cond})` : cond, '');\n conditions.push(labelExpr);\n }\n\n if (filters?.query) {\n conditions.push(`((Name contains \"${filters.query}\") OR (Description contains \"${filters.query}\"))`);\n }\n\n // Rally WSAPI only supports binary (expr AND expr) — reduce into nested pairs\n return conditions.reduce((acc, cond) => acc ? `(${acc} AND ${cond})` : cond, '');\n }\n\n private normalizeIssue(rallyArtifact: any): Issue {\n // Determine state from ScheduleState (User Stories, Tasks) or State (Defects, Features)\n // For PortfolioItem/Feature, State is a Rally ref object with Name/_refObjectName, not a string\n const rawStateValue = rallyArtifact.ScheduleState || rallyArtifact.State || 'Defined';\n const stateValue = typeof rawStateValue === 'object' && rawStateValue !== null\n ? (rawStateValue.Name || rawStateValue._refObjectName || 'Defined')\n : rawStateValue;\n const state = this.mapState(stateValue);\n\n // Extract tags — ensure all entries are strings\n const labels: string[] = [];\n if (rallyArtifact.Tags && rallyArtifact.Tags._tagsNameArray) {\n for (const tag of rallyArtifact.Tags._tagsNameArray) {\n if (typeof tag === 'string') {\n labels.push(tag);\n } else if (tag?.Name) {\n labels.push(tag.Name);\n }\n }\n }\n\n // Map priority\n const priority = rallyArtifact.Priority\n ? PRIORITY_MAP[rallyArtifact.Priority] ?? 2\n : undefined;\n\n // Use ObjectID if available, fall back to FormattedID\n const objectId = rallyArtifact.ObjectID || rallyArtifact.FormattedID;\n const artifactType = rallyArtifact._type || 'artifact';\n\n // Build URL - Rally's web UI detail path\n const baseUrl = this.restApi.server.replace('/slm/webservice/', '');\n const url = `${baseUrl}/#/detail/${artifactType.toLowerCase()}/${objectId}`;\n\n // Resolve parent reference.\n // For User Stories, PortfolioItem links to the parent Feature (F-prefixed),\n // while Parent links to a parent Story in the hierarchy. Prefer PortfolioItem\n // so that stories are correctly grouped under their Feature. (PAN-202)\n let parentRef: string | undefined;\n if (rallyArtifact.PortfolioItem) {\n if (rallyArtifact.PortfolioItem.FormattedID) {\n parentRef = rallyArtifact.PortfolioItem.FormattedID;\n } else if (rallyArtifact.PortfolioItem._refObjectName) {\n parentRef = rallyArtifact.PortfolioItem._refObjectName;\n }\n } else if (rallyArtifact.Parent) {\n if (rallyArtifact.Parent.FormattedID) {\n parentRef = rallyArtifact.Parent.FormattedID;\n } else if (rallyArtifact.Parent._refObjectName) {\n parentRef = rallyArtifact.Parent._refObjectName;\n }\n }\n\n return {\n id: String(objectId),\n ref: rallyArtifact.FormattedID,\n title: rallyArtifact.Name || '',\n description: rallyArtifact.Description || '',\n state,\n labels,\n assignee: rallyArtifact.Owner?._refObjectName,\n url,\n tracker: 'rally' as TrackerType,\n priority,\n dueDate: rallyArtifact.DueDate,\n createdAt: rallyArtifact.CreationDate,\n updatedAt: rallyArtifact.LastUpdateDate,\n parentRef,\n artifactType,\n rawState: stateValue,\n };\n }\n\n private mapState(rallyState: string): IssueState {\n return STATE_MAP[rallyState] ?? 'open';\n }\n\n private reverseMapState(state: IssueState, kind: 'story' | 'defect' | 'feature' = 'story'): string {\n if (kind === 'feature') {\n // Features / PortfolioItems use State: Discovering, Developing, Done\n switch (state) {\n case 'open': return 'Discovering';\n case 'in_progress':\n case 'in_review': return 'Developing';\n case 'closed': return 'Done';\n default: return 'Discovering';\n }\n }\n if (kind === 'defect') {\n // Defects use State: Submitted, Open, Fixed, Closed\n switch (state) {\n case 'open': return 'Submitted';\n case 'in_progress':\n case 'in_review': return 'Open';\n case 'closed': return 'Closed';\n default: return 'Submitted';\n }\n }\n // User Stories / Tasks use ScheduleState: Defined, In-Progress, Completed\n switch (state) {\n case 'open': return 'Defined';\n case 'in_progress':\n case 'in_review': return 'In-Progress';\n case 'closed': return 'Completed';\n default: return 'Defined';\n }\n }\n\n // Rally API wrapper methods\n private async queryRally(queryConfig: any): Promise<any> {\n const result = await this.restApi.query(queryConfig);\n // Extract Results from WSAPI response format\n return {\n Results: result.QueryResult.Results,\n TotalResultCount: result.QueryResult.TotalResultCount,\n };\n }\n\n private async createRally(type: string, data: any): Promise<any> {\n const result = await this.restApi.create({\n type,\n data,\n fetch: ['FormattedID', 'ObjectID', '_ref'],\n });\n // Extract Object from WSAPI response format\n return {\n Object: result.CreateResult.Object,\n };\n }\n\n private async updateRally(type: string, ref: string, data: any): Promise<any> {\n const result = await this.restApi.update({\n type,\n ref,\n data,\n fetch: ['FormattedID', 'ObjectID'],\n });\n // Extract Object from WSAPI response format\n return {\n Object: result.OperationResult.Object,\n };\n }\n}\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rally-api-
|
|
1
|
+
{"version":3,"file":"rally-api-C0WqCSkT.js","names":[],"sources":["../../src/lib/tracker/rally-api.ts"],"sourcesContent":["/**\n * Rally WSAPI REST Client\n *\n * Thin wrapper around native fetch for Rally Web Services API v2.0.\n * Provides typed methods for query, create, and update operations.\n */\n\nexport interface RallyQueryConfig {\n type: string;\n fetch?: string[];\n query?: string;\n limit?: number;\n workspace?: string;\n project?: string;\n projectScopeDown?: boolean;\n order?: string;\n}\n\nexport interface RallyQueryResult {\n QueryResult: {\n Results: any[];\n TotalResultCount: number;\n Errors: string[];\n Warnings: string[];\n };\n}\n\nexport interface RallyCreateConfig {\n type: string;\n data: any;\n fetch?: string[];\n}\n\nexport interface RallyCreateResult {\n CreateResult: {\n Object: any;\n Errors: string[];\n Warnings: string[];\n };\n}\n\nexport interface RallyUpdateConfig {\n type: string;\n ref: string;\n data: any;\n fetch?: string[];\n}\n\nexport interface RallyUpdateResult {\n OperationResult: {\n Object: any;\n Errors: string[];\n Warnings: string[];\n };\n}\n\nexport interface RallyApiConfig {\n apiKey: string;\n server?: string;\n requestOptions?: {\n headers?: Record<string, string>;\n };\n}\n\nexport class RallyRestApi {\n private apiKey: string;\n public server: string;\n private customHeaders: Record<string, string>;\n\n constructor(config: RallyApiConfig) {\n this.apiKey = config.apiKey;\n this.server = config.server || 'https://rally1.rallydev.com';\n this.customHeaders = config.requestOptions?.headers || {};\n }\n\n /**\n * Query Rally artifacts\n */\n async query(config: RallyQueryConfig): Promise<RallyQueryResult> {\n const params = new URLSearchParams();\n\n if (config.query) {\n params.set('query', config.query);\n }\n\n if (config.fetch && config.fetch.length > 0) {\n params.set('fetch', config.fetch.join(','));\n }\n\n if (config.limit !== undefined) {\n params.set('pagesize', String(config.limit));\n }\n\n if (config.workspace) {\n params.set('workspace', config.workspace);\n }\n\n if (config.project) {\n params.set('project', config.project);\n if (config.projectScopeDown) {\n params.set('projectScopeDown', 'true');\n }\n }\n\n if (config.order) {\n params.set('order', config.order);\n }\n\n const url = `${this.server}/slm/webservice/v2.0/${config.type}?${params.toString()}`;\n\n const response = await fetch(url, {\n method: 'GET',\n headers: {\n 'ZSESSIONID': this.apiKey,\n 'Content-Type': 'application/json',\n ...this.customHeaders,\n },\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n throw new Error('Unauthorized: Invalid API key or insufficient permissions');\n }\n throw new Error(`Rally API query failed: ${response.status} ${response.statusText}`);\n }\n\n const result = await response.json() as RallyQueryResult;\n\n if (result.QueryResult.Errors && result.QueryResult.Errors.length > 0) {\n const errorDetail = result.QueryResult.Errors.join(', ');\n const queryDetail = config.query ? ` (Query: ${config.query})` : '';\n if (process.env.DEBUG?.includes('rally')) {\n console.error('[Rally WSAPI] Query failed:', { query: config.query, errors: result.QueryResult.Errors });\n }\n throw new Error(`Rally API query failed: ${errorDetail}${queryDetail}`);\n }\n\n return result;\n }\n\n /**\n * Create a Rally object\n */\n async create(config: RallyCreateConfig): Promise<RallyCreateResult> {\n const url = `${this.server}/slm/webservice/v2.0/${config.type}/create`;\n\n const body: any = {\n [config.type]: config.data,\n };\n\n const params = new URLSearchParams();\n if (config.fetch && config.fetch.length > 0) {\n params.set('fetch', config.fetch.join(','));\n }\n\n const finalUrl = params.toString() ? `${url}?${params.toString()}` : url;\n\n const response = await fetch(finalUrl, {\n method: 'POST',\n headers: {\n 'ZSESSIONID': this.apiKey,\n 'Content-Type': 'application/json',\n ...this.customHeaders,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(`Rally API create failed: ${response.status} ${response.statusText}`);\n }\n\n const result = await response.json() as RallyCreateResult;\n\n if (result.CreateResult.Errors && result.CreateResult.Errors.length > 0) {\n throw new Error(`Rally API create failed: ${result.CreateResult.Errors.join(', ')}`);\n }\n\n return result;\n }\n\n /**\n * Update a Rally object\n */\n async update(config: RallyUpdateConfig): Promise<RallyUpdateResult> {\n // Extract ObjectID from ref (e.g., \"/hierarchicalrequirement/12345\" -> \"12345\")\n const objectId = config.ref.split('/').pop();\n const url = `${this.server}/slm/webservice/v2.0/${config.type}/${objectId}`;\n\n const body: any = {\n [config.type]: config.data,\n };\n\n const params = new URLSearchParams();\n if (config.fetch && config.fetch.length > 0) {\n params.set('fetch', config.fetch.join(','));\n }\n\n const finalUrl = params.toString() ? `${url}?${params.toString()}` : url;\n\n const response = await fetch(finalUrl, {\n method: 'POST',\n headers: {\n 'ZSESSIONID': this.apiKey,\n 'Content-Type': 'application/json',\n ...this.customHeaders,\n },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n throw new Error(`Rally API update failed: ${response.status} ${response.statusText}`);\n }\n\n const result = await response.json() as RallyUpdateResult;\n\n if (result.OperationResult.Errors && result.OperationResult.Errors.length > 0) {\n throw new Error(`Rally API update failed: ${result.OperationResult.Errors.join(', ')}`);\n }\n\n return result;\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { a as deleteWorkspaceMetadata, c as loadWorkspaceMetadata, i as WORKSPACES_DIR, l as saveWorkspaceMetadata, n as getRemoteProvider, o as findRemoteWorkspaceMetadata, r as isRemoteAvailable, s as listWorkspaceMetadata, t as createFlyProviderFromConfig } from "./remote-
|
|
2
|
-
import { a as listRemoteAgents, c as sendToRemoteAgent, d as createFlyProvider, i as killRemoteAgent, l as spawnRemoteAgent, o as loadRemoteAgentState, r as isRemoteAgentRunning, s as pollRemoteAgentStatus, t as getRemoteAgentOutput, u as FlyProvider } from "./remote-agents-
|
|
1
|
+
import { a as deleteWorkspaceMetadata, c as loadWorkspaceMetadata, i as WORKSPACES_DIR, l as saveWorkspaceMetadata, n as getRemoteProvider, o as findRemoteWorkspaceMetadata, r as isRemoteAvailable, s as listWorkspaceMetadata, t as createFlyProviderFromConfig } from "./remote-ObpNZ7hF.js";
|
|
2
|
+
import { a as listRemoteAgents, c as sendToRemoteAgent, d as createFlyProvider, i as killRemoteAgent, l as spawnRemoteAgent, o as loadRemoteAgentState, r as isRemoteAgentRunning, s as pollRemoteAgentStatus, t as getRemoteAgentOutput, u as FlyProvider } from "./remote-agents-DFyjT1Le.js";
|
|
3
3
|
export { FlyProvider, WORKSPACES_DIR, createFlyProvider, createFlyProviderFromConfig, deleteWorkspaceMetadata, findRemoteWorkspaceMetadata, getRemoteAgentOutput, getRemoteProvider, isRemoteAgentRunning, isRemoteAvailable, killRemoteAgent, listRemoteAgents, listWorkspaceMetadata, loadRemoteAgentState, loadWorkspaceMetadata, pollRemoteAgentStatus, saveWorkspaceMetadata, sendToRemoteAgent, spawnRemoteAgent };
|