*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #212121;--bg-secondary: #171717;--bg-tertiary: #2f2f2f;--bg-hover: #3a3a3a;--text-primary: #ececec;--text-secondary: #9b9b9b;--border-color: #3a3a3a;--accent-color: #10a37f;--user-bg: #2f2f2f;--assistant-bg: transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{height:100vh;width:100vw}.app{display:flex;height:100vh;width:100vw}.app-upload{display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary)}.upload-area-container{display:flex;flex-direction:column;align-items:center;gap:16px}.upload-area{width:400px;padding:48px;border:2px dashed var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s ease;background-color:var(--bg-primary)}.upload-area:hover,.upload-area.dragging{border-color:var(--accent-color);background-color:var(--bg-tertiary)}.upload-area.loading{cursor:wait}.upload-content{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.upload-icon{color:var(--text-secondary)}.upload-text{font-size:18px;font-weight:500}.upload-subtext{color:var(--text-secondary);font-size:14px}.upload-formats{color:var(--text-secondary);font-size:12px;margin-top:8px}.upload-error{color:#ef4444;padding:12px 16px;background-color:#ef44441a;border-radius:8px;font-size:14px}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar{width:280px;min-width:280px;background-color:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border-color)}.sidebar-header{padding:16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.sidebar-header h1{font-size:16px;font-weight:600}.reset-button{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.reset-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar-controls{padding:8px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.conversation-count{font-size:12px;color:var(--text-secondary)}.sort-select{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;outline:none}.sort-select:hover{border-color:var(--text-secondary)}.sort-select:focus{border-color:var(--accent-color)}.conversation-list{flex:1;overflow-y:auto;padding:8px}.conversation-item{padding:12px;border-radius:8px;cursor:pointer;transition:background-color .15s ease;margin-bottom:2px;display:flex;align-items:center;justify-content:space-between;gap:8px}.conversation-item:hover{background-color:var(--bg-hover)}.conversation-item.selected{background-color:var(--bg-tertiary)}.conversation-info{flex:1;min-width:0}.conversation-title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.conversation-date{font-size:12px;color:var(--text-secondary)}.conversation-menu{position:relative}.menu-button{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s ease}.conversation-item:hover .menu-button{opacity:1}.menu-button:hover{background-color:var(--bg-primary);color:var(--text-primary)}.menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:4px;min-width:160px;z-index:100;box-shadow:0 4px 12px #0000004d}.menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;border-radius:4px;transition:background-color .15s ease;text-align:left}.menu-item:hover{background-color:var(--bg-hover)}.menu-item svg{color:var(--text-secondary)}.chat-view{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.chat-view-empty{align-items:center;justify-content:center}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-secondary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary);padding:48px;height:100%}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.chat-header{padding:16px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:16px}.chat-header-left{flex:1;min-width:0}.chat-header h2{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-date{font-size:12px;color:var(--text-secondary)}.chat-header-menu{position:relative}.chat-menu-button{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.chat-menu-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.chat-menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:4px;min-width:220px;z-index:100;box-shadow:0 4px 12px #0000004d}.chat-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;border-radius:4px;transition:background-color .15s ease;text-align:left}.chat-menu-item:hover{background-color:var(--bg-hover)}.chat-menu-item svg{color:var(--text-secondary);flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:24px 0;overscroll-behavior:contain}.scroll-buttons{position:absolute;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:10}.scroll-btn{width:36px;height:36px;border-radius:50%;background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:0 2px 8px #0003}.scroll-btn:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.message{display:flex;gap:16px;padding:24px 48px;max-width:900px;margin:0 auto}.message-user{background-color:var(--user-bg)}.message-assistant{background-color:var(--assistant-bg)}.message-highlight .message{animation:message-highlight-pulse 1.5s ease-out}@keyframes message-highlight-pulse{0%{box-shadow:inset 0 0 0 2px var(--accent-color);background-color:#10a37f1a}to{box-shadow:inset 0 0 0 0 transparent;background-color:transparent}}.message-avatar{width:32px;height:32px;min-width:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);color:var(--text-secondary)}.message-user .message-avatar{background-color:#5436da;color:#fff}.message-assistant .message-avatar{background-color:var(--accent-color);color:#fff}.message-system,.message-tool{background-color:#f973160d}.message-system .message-avatar,.message-tool .message-avatar{background-color:#f97316;color:#fff}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:center;gap:12px;margin-bottom:4px}.message-role{font-size:14px;font-weight:600}.message-timestamp{font-size:12px;color:var(--text-secondary)}.dictation-badge{display:inline-flex;align-items:center;padding:2px 6px;background-color:#10a37f26;color:#10a37f;border-radius:4px;font-size:11px}.dictation-badge svg{stroke:currentColor}.model-badge{display:inline-flex;align-items:center;padding:2px 8px;background-color:var(--bg-secondary);color:var(--text-secondary);border-radius:4px;font-size:11px;font-weight:500}.copy-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s ease}.copy-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.copy-btn.copied{color:var(--accent-color)}.message-menu{position:relative;display:inline-flex}.message-menu-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s ease}.message-menu-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.message-menu-dropdown{position:absolute;top:100%;right:0;z-index:100;min-width:160px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000004d;padding:4px;margin-top:4px}.message-menu-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;border-radius:6px;text-align:left}.message-menu-dropdown button:hover{background-color:var(--bg-hover)}.message-menu-dropdown button svg{color:var(--text-secondary);flex-shrink:0}.branch-indicator{display:flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:12px}.branch-btn{background:none;border:none;padding:2px;cursor:pointer;color:var(--text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.branch-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.branch-count{min-width:28px;text-align:center}.message-text{font-size:15px;line-height:1.7;word-wrap:break-word}.message-text p{margin:0 0 1em}.message-text p:last-child{margin-bottom:0}.message-text h1,.message-text h2,.message-text h3,.message-text h4{margin:1.5em 0 .5em;font-weight:600}.message-text h1:first-child,.message-text h2:first-child,.message-text h3:first-child{margin-top:0}.message-text ul,.message-text ol{margin:.5em 0;padding-left:1.5em}.message-text li{margin:.25em 0}.message-text code{background-color:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em}.message-text pre{background-color:var(--bg-secondary);padding:12px 16px;border-radius:8px;overflow-x:auto;margin:1em 0}.message-text pre code{background:none;padding:0;font-size:13px;line-height:1.5}.message-text blockquote{border-left:3px solid var(--border-color);margin:1em 0;padding-left:1em;color:var(--text-secondary)}.message-text a{color:var(--accent-color);text-decoration:none}.message-text a:hover{text-decoration:underline}.message-text table{border-collapse:collapse;margin:1em 0;width:100%}.message-text th,.message-text td{border:1px solid var(--border-color);padding:8px 12px;text-align:left}.message-text th{background-color:var(--bg-tertiary);font-weight:600}.message-attachments{margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.attachments-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.attachments-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px}.attachment-item{display:flex;align-items:center;gap:6px;background-color:var(--bg-tertiary);padding:6px 10px;border-radius:6px;font-size:13px;color:var(--text-primary)}.attachment-item svg{color:var(--text-secondary);flex-shrink:0}.citation-link,.citation-badge{display:inline;font-size:12px;font-weight:600;padding:1px 4px;margin:0 1px;border-radius:3px;vertical-align:super;line-height:1}.citation-link{background-color:var(--accent-color);color:#fff;text-decoration:none;cursor:pointer;transition:background-color .15s ease}.citation-link:hover{background-color:#0d8a6a}.citation-badge{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:help}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--bg-hover)}.tree-panel-content{scrollbar-gutter:stable}.tree-panel-content::-webkit-scrollbar{display:block}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-content{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:16px;font-weight:600}.modal-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:16px 20px}.json-content{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;color:var(--text-primary);background-color:var(--bg-secondary);padding:16px;border-radius:8px;margin:0}.tree-panel{position:relative;background-color:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:clip;contain:layout}.tree-panel-collapsed{width:40px!important;min-width:40px;align-items:center;justify-content:flex-start;padding-top:12px}.tree-panel-empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.tree-resize-handle{position:absolute;left:-3px;top:0;bottom:0;width:8px;cursor:col-resize;background-color:transparent;z-index:100}.tree-resize-handle:after{content:"";position:absolute;left:3px;top:0;bottom:0;width:2px;background-color:transparent;transition:background-color .15s ease}.tree-resize-handle:hover:after{background-color:var(--accent-color)}.tree-panel-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.tree-panel-header h3{font-size:14px;font-weight:600;margin:0}.tree-toggle-btn{background:none;border:none;padding:6px;cursor:pointer;color:var(--text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.tree-toggle-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.tree-toggle-btn.active{color:var(--accent-color)}.tree-panel-content{flex:1;min-height:0;height:100%;overflow:scroll;padding:16px;position:relative;overscroll-behavior:contain;will-change:scroll-position;transform:translateZ(0)}.tree-sticky-date{position:sticky;top:0;left:0;background-color:var(--bg-secondary);padding:4px 8px;margin:-16px -16px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);z-index:10;width:fit-content;min-width:calc(100% + 32px)}.tree-layout{display:flex;flex-direction:column;gap:2px;min-width:100%;width:max-content}.tree-layout.with-timeline{display:flex;flex-direction:row;gap:0;min-width:100%;width:max-content}.tree-timeline-column{width:52px;min-width:52px;flex-shrink:0;display:flex;flex-direction:column;border-right:2px solid var(--border-color);background-color:var(--bg-secondary);position:sticky;left:0;z-index:5}.tree-time-slot{min-height:30px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px}.tree-time-display{font-size:9px;color:var(--text-secondary);font-family:monospace}.tree-time-cell{width:52px;min-width:52px;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;padding-right:8px}.tree-nodes-container{flex:1;display:flex;flex-direction:column;min-width:0}.tree-root{padding:8px}.tree-row{display:flex;align-items:center;min-height:28px;padding-top:2px;padding-bottom:2px;position:relative}.tree-row[data-depth]:not([data-depth="0"]):before{content:"";position:absolute;left:calc(var(--depth) * 16px - 12px);top:0;width:10px;height:50%;border-left:2px solid var(--border-color);border-bottom:2px solid var(--border-color);border-bottom-left-radius:4px}.tree-node{position:relative;display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .15s ease;font-size:11px;width:fit-content;max-width:300px}.tree-node-branch-indicator{color:var(--accent-color);font-size:8px;margin-left:4px}.tree-node:hover{border-color:var(--text-secondary);background-color:var(--bg-hover)}.tree-node.on-path{border-color:var(--accent-color);background-color:#10a37f26}.tree-node-highlight .tree-node{animation:tree-node-highlight-pulse 1.5s ease-out}@keyframes tree-node-highlight-pulse{0%{box-shadow:0 0 0 3px var(--accent-color);transform:scale(1.05)}to{box-shadow:0 0 0 0 transparent;transform:scale(1)}}.tree-node.user .tree-node-icon{color:#5436da}.tree-node.assistant .tree-node-icon{color:var(--accent-color)}.tree-node.system .tree-node-icon,.tree-node.tool .tree-node-icon{color:#f97316}.tree-node-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.tree-node-preview{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node.on-path .tree-node-preview{color:var(--text-primary)}.tree-node-tooltip{width:300px;max-height:200px;overflow-y:auto;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:12px;box-shadow:0 4px 12px #0000004d}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tooltip-role{font-size:12px;font-weight:600;color:var(--text-primary)}.tooltip-time{font-size:11px;color:var(--text-secondary)}.tooltip-content{font-size:12px;line-height:1.5;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}
