*{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{width:100vw;height:100vh;margin:0;overflow:hidden}#root{width:100%;height:100%}.app{background-color:#fff;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.content-container{align-items:stretch;gap:20px;width:80%;height:60%;padding:0;display:flex}.chat-container{background-color:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;width:60%;height:100%;display:flex;overflow:hidden}.visualization-canvas{background-color:#fff;border:1px solid #000;border-radius:8px;width:40%;height:100%;overflow:hidden}.toolbar{background-color:#fff;border-bottom:1px solid #000;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.toolbar-right{gap:8px;display:flex}.toolbar-button{cursor:pointer;background-color:#fff;border:1px solid #000;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:400;transition:all .2s}.toolbar-button:hover{background-color:#f5f5f5}.toolbar-button:active{background-color:#e0e0e0}.messages-container{background-color:#f5f5f5;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.message-bubble{word-wrap:break-word;white-space:pre-wrap;background-color:#fff;border:1px solid #000;border-radius:12px;max-width:70%;padding:10px 14px;font-size:14px;line-height:1.6}.message-bubble strong{font-weight:600}.message-bubble.user-message{background-color:#f0f0f0;align-self:flex-end}.message-bubble.ai-message{align-self:flex-start}.loading{text-align:center;color:#666;padding:10px;font-size:14px}.input-container{background-color:#fff;border-top:1px solid #000;gap:8px;padding:12px;display:flex}.message-input{border:1px solid #000;border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:14px}.message-input:focus{border-color:#000}.send-button{cursor:pointer;background-color:#fff;border:1px solid #000;border-radius:20px;padding:10px 20px;font-size:14px;font-weight:500}.send-button:hover{background-color:#f5f5f5}.send-button:active{background-color:#e0e0e0}.send-button:disabled,.message-input:disabled{opacity:.5;cursor:not-allowed}.yes-no-buttons{justify-content:center;gap:12px;width:100%;padding:8px 0;display:flex}.yes-no-button{cursor:pointer;color:#007aff;background-color:#fff;border:2px solid #007aff;border-radius:8px;flex:1;max-width:150px;padding:12px 24px;font-size:16px;font-weight:600;transition:all .2s}.yes-no-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #007aff33}.yes-no-button:active:not(:disabled){transform:translateY(0)}.yes-no-button.yes-button{color:#34c759;border-color:#34c759}.yes-no-button.yes-button:hover:not(:disabled){color:#fff;background-color:#34c759;box-shadow:0 2px 8px #34c7594d}.yes-no-button.no-button{color:#ff3b30;border-color:#ff3b30}.yes-no-button.no-button:hover:not(:disabled){color:#fff;background-color:#ff3b30;box-shadow:0 2px 8px #ff3b304d}.yes-no-button:disabled{opacity:.5;cursor:not-allowed}.info-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.info-modal{background-color:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:80vh;display:flex;overflow:hidden}.info-header{border-bottom:1px solid #000;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.info-header h2{margin:0;font-size:20px;font-weight:600}.info-close-button{cursor:pointer;background-color:#fff;border:1px solid #000;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:20px;font-weight:700;line-height:1;transition:background-color .2s;display:flex}.info-close-button:hover{background-color:#f5f5f5}.info-close-button:active{background-color:#e0e0e0}.info-content{flex:1;padding:24px;overflow-y:auto}.info-content p{color:#333;margin:0 0 16px;font-size:14px;line-height:1.6}.info-content p:last-child{margin-bottom:0}.info-content strong{font-weight:600}.info-content ul{margin:12px 0 16px;padding-left:24px}.info-content li{color:#333;margin:8px 0;font-size:14px;line-height:1.6}.overlay-backdrop{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.essay-list-overlay{background-color:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;width:70%;max-width:800px;max-height:85vh;display:flex;box-shadow:0 4px 6px #0000001a}.overlay-header{border-bottom:1px solid #000;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.back-button{cursor:pointer;background-color:#fff;border:1px solid #000;border-radius:6px;margin-right:8px;padding:6px 12px;font-size:13px;transition:background-color .2s}.back-button:hover{background-color:#f5f5f5}.overlay-header h2{flex:1;margin:0;font-size:18px;font-weight:500}.close-button{cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:24px;transition:background-color .2s;display:flex}.close-button:hover{background-color:#f5f5f5}.overlay-content{flex:1;padding:20px;overflow-y:auto}.loading,.error{text-align:center;padding:20px;font-size:14px}.error{color:#d32f2f}.essay-list{flex-direction:column;gap:8px;display:flex}.essay-item{cursor:pointer;border-radius:6px;padding:10px 14px;font-size:14px;transition:font-weight .2s}.essay-item:hover{font-weight:700}.essay-reader{flex-direction:column;height:100%;display:flex}.essay-content{white-space:pre-wrap;word-wrap:break-word;color:#333;flex:1;padding:20px;font-size:14px;line-height:1.6;overflow-y:auto}.chat-tree-container{background-color:#fff;background-image:linear-gradient(#0000000d 1px,#0000 1px),linear-gradient(90deg,#0000000d 1px,#0000 1px);background-size:20px 20px;width:100%;height:100%;position:relative;overflow:hidden}.chat-tree-empty{color:#999;justify-content:center;align-items:center;height:100%;font-size:14px;display:flex}.chat-tree-svg{-webkit-user-select:none;user-select:none;touch-action:none;width:100%;height:100%}.zoom-controls{z-index:100;background:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;gap:4px;padding:8px;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #0000001a}.zoom-button{cursor:pointer;color:#000;background-color:#fff;border:1px solid #000;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:18px;font-weight:600;transition:all .2s;display:flex}.zoom-button:hover{background-color:#f5f5f5}.zoom-button:active{background-color:#e0e0e0}.zoom-level{text-align:center;color:#666;padding:4px 0;font-size:11px;font-weight:500}.tree-node{cursor:pointer;transition:all .2s}.tree-node:hover{stroke-width:2px;fill:#e0e0e0}.tree-node-text{cursor:pointer;pointer-events:none;-webkit-user-select:none;user-select:none}.tree-node-group{transform-origin:50%}.tree-node-group.visible{animation:.3s ease-out nodeAppear}@keyframes nodeAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.question-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.question-overlay-content{background:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:80vh;animation:.2s slideUp;display:flex;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.question-overlay-close{cursor:pointer;color:#000;z-index:10;background-color:#fff;border:1px solid #000;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:20px;font-weight:700;line-height:1;transition:background-color .2s;display:flex;position:absolute;top:12px;right:12px}.question-overlay-close:hover{background-color:#f5f5f5}.question-overlay-close:active{background-color:#e0e0e0}.question-overlay-body{flex:1;padding:48px 24px 24px;overflow-y:auto}.question-overlay-body p{color:#333;white-space:pre-wrap;word-wrap:break-word;margin:0;font-size:14px;line-height:1.6}.question-overlay-body::-webkit-scrollbar{width:8px}.question-overlay-body::-webkit-scrollbar-track{background:0 0}.question-overlay-body::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.question-overlay-body::-webkit-scrollbar-thumb:hover{background:#999}.speech-bubble-icon{pointer-events:all;filter:drop-shadow(0 1px 2px #0003)}.speech-bubble-icon:hover{filter:drop-shadow(0 2px 4px #0000004d);opacity:.8!important}.user-response-section{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:24px}.user-response-label{color:#666;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;font-size:12px;font-weight:600}.user-response-text{color:#333;white-space:pre-wrap;word-wrap:break-word;margin:0;font-size:14px;line-height:1.6}.session-landing{background-color:#fff;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.session-landing-box{background-color:#fff;border:1px solid #000;border-radius:8px;flex-direction:column;gap:16px;width:500px;max-width:90vw;padding:24px;display:flex}.session-landing-title{text-align:center;margin:0;font-size:24px;font-weight:600}.session-landing-new{gap:8px;display:flex}.session-landing-input{border:1px solid #000;border-radius:6px;outline:none;flex:1;padding:10px 14px;font-size:14px}.session-landing-input:focus{border-color:#000}.session-landing-input:disabled{opacity:.5;cursor:not-allowed}.session-landing-button{cursor:pointer;background-color:#fff;border:1px solid #000;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.session-landing-button:hover:not(:disabled){background-color:#f5f5f5}.session-landing-button:active:not(:disabled){background-color:#e0e0e0}.session-landing-button:disabled{opacity:.5;cursor:not-allowed}.session-landing-button-primary{color:#fff;background-color:#000}.session-landing-button-primary:hover:not(:disabled){background-color:#333}.session-landing-divider{background-color:#e0e0e0;height:1px;margin:8px 0}.session-landing-list{flex-direction:column;gap:8px;max-height:400px;display:flex;overflow-y:auto}.session-landing-item{cursor:pointer;border:1px solid #e0e0e0;border-radius:6px;padding:12px;transition:all .2s}.session-landing-item:hover{background-color:#f5f5f5;border-color:#000}.session-landing-item-name{margin-bottom:4px;font-size:16px;font-weight:500}.session-landing-item-meta{color:#666;flex-wrap:wrap;gap:12px;font-size:12px;display:flex}.session-landing-item-status{text-transform:uppercase;font-weight:500}.session-landing-loading,.session-landing-empty{text-align:center;color:#666;padding:20px;font-size:14px}.session-landing-item{position:relative}.session-landing-item-delete{color:#000;cursor:pointer;opacity:0;z-index:10;background-color:#0000;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin:0;padding:0;font-size:18px;font-weight:700;line-height:1;transition:opacity .2s,background-color .2s;display:flex;position:absolute;top:8px;right:8px}.session-landing-item-delete:before{content:"×";line-height:1;display:block}.session-landing-item:hover .session-landing-item-delete{opacity:1}.session-landing-item-delete:hover{background-color:#f5f5f5}.session-landing-item-delete:active{background-color:#e0e0e0}.session-landing-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.session-landing-confirm-dialog{background-color:#fff;border:1px solid #000;border-radius:8px;width:90%;max-width:400px;padding:24px}.session-landing-confirm-dialog h3{margin:0 0 12px;font-size:20px;font-weight:600}.session-landing-confirm-dialog p{color:#666;margin:0 0 20px;font-size:14px;line-height:1.5}.session-landing-confirm-buttons{justify-content:flex-end;gap:8px;display:flex}.session-landing-button-danger{color:#fff;background-color:#000;border-color:#000}.session-landing-button-danger:hover:not(:disabled){background-color:#333;border-color:#333}
