@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}body{margin:0;background:#0b0c10;color:#e8eaed}.wrap{max-width:1200px;margin:24px auto;padding:0 16px 40px}h1{margin:0 0 8px;font-size:24px}.card{background:#111318;border:1px solid #23262e;border-radius:12px;padding:16px;margin:16px 0}label{display:block;font-size:13px;color:#b6b9c3;margin-bottom:6px}input[type=text],input[type=password],textarea,select,input[type=number]{width:100%;padding:10px 12px;background:#0e1015;color:#e8eaed;border:1px solid #2a2e37;border-radius:8px}textarea{resize:vertical;min-height:90px}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1 1 240px}.btn{cursor:pointer;background:#2d7cff;color:#fff;border:none;padding:10px 14px;border-radius:10px;font-weight:600}.btn.secondary{background:#21242c;color:#e8eaed;border:1px solid #2a2e37}.btn-compact{padding:6px 10px;font-size:12px;border-radius:8px}.actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.muted{color:#9aa0aa;font-size:12px}.small{font-size:12px}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid #2a2e37;background:#0e1015;font-size:12px}.chat-container{display:flex;flex-direction:column;height:600px;max-height:80vh;overflow:hidden}.chat-layout{display:flex;gap:16px;height:100%}.chat-sidebar{width:260px;min-width:220px;background:#0e1015;border:1px solid #23262e;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-history-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.chat-history-item{position:relative;border:1px solid #2a2e37;border-radius:10px;padding:10px;background:#0b0c10;cursor:pointer;transition:border-color .2s,transform .1s}.chat-history-item:hover{border-color:#2d7cff}.chat-history-item.active{border-color:#2d7cff;box-shadow:0 0 0 1px #2d7cff66}.chat-history-title{color:#e8eaed;font-weight:600;font-size:13px;margin-right:24px}.chat-history-meta{color:#9aa0aa;font-size:11px}.chat-history-delete{position:absolute;top:6px;right:6px;background:transparent;border:none;color:#9aa0aa;cursor:pointer;font-size:14px;padding:4px;line-height:1}.chat-history-delete:hover{color:#f66}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #23262e}.chat-tabs{display:flex;gap:2px;margin:0;padding:0 6px;border-bottom:1px solid #23262e;background:#0e1015;border-top-left-radius:10px;border-top-right-radius:10px}.tab{background:#0b0c10;color:#e8eaed;border:1px solid #2a2e37;border-bottom:none;border-radius:10px 10px 6px 6px;padding:9px 14px;cursor:pointer;position:relative;top:1px}.tab:hover{background:#111318;border-color:#3a3e47}.tab.active{border-color:#23262e;color:#fff;background:#111318;box-shadow:0 -1px #ffffff0a inset}.chat-tab-panel{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow:hidden}.chat-header label{margin:0;font-size:16px;font-weight:600}.chat-actions{display:flex;gap:8px;align-items:center}.chat-messages{flex:1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:16px;min-height:0}.message{display:flex;flex-direction:column;max-width:80%;word-wrap:break-word}.message.user{align-self:flex-end;align-items:flex-end}.message.assistant{align-self:flex-start;align-items:flex-start}.message-content{padding:12px 16px;border-radius:18px;line-height:1.4;white-space:pre-wrap;word-wrap:break-word}.message.user .message-content{background:#2d7cff;color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:#21242c;color:#e8eaed;border:1px solid #2a2e37;border-bottom-left-radius:4px}.message-time{font-size:11px;color:#9aa0aa;margin-top:4px;padding:0 8px}.message-model{margin-left:8px}.message-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}.branch-btn{height:28px}.chat-input-container{margin-top:16px;padding-top:16px;border-top:1px solid #23262e}.chat-input-wrapper{display:flex;gap:12px;align-items:flex-end}.chat-input-wrapper textarea{flex:1;min-height:40px;max-height:120px;resize:none;font-family:inherit;line-height:1.4;overflow:hidden}.chat-input-wrapper button{height:40px;padding:0 20px;white-space:nowrap}.input-controls{display:flex;align-items:flex-end;gap:8px;flex:1}#imageUploadBtn{height:40px;width:40px;padding:0;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.image-preview{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap;min-height:0}.image-preview-item{position:relative;width:60px;height:60px;border-radius:8px;overflow:hidden;border:1px solid #2a2e37;background:#0e1015}.image-preview-item img{width:100%;height:100%;object-fit:cover}.image-preview-item .remove-btn{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:#f44;color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.image-preview-item .remove-btn:hover{background:#f66}.message-images{margin-top:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.message-images img{width:100%;height:auto;border-radius:8px;border:1px solid #2a2e37;cursor:pointer;transition:opacity .2s}.message-images img:hover{opacity:.8}.chat-warning{color:#f66;background:#ff444414;border:1px solid rgba(255,68,68,.3);border-radius:8px;padding:10px 12px;font-size:12px;margin-bottom:12px}.model-actions{display:flex;gap:8px;font-size:12px;margin-top:8px}.model-actions a{color:#2d7cff;text-decoration:none}.model-actions a:hover{text-decoration:underline}.branch-panel{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0}.branch-header{display:flex;align-items:center;justify-content:space-between}.branch-tree{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto;min-height:0;padding:2px 0}.branch-tree-row{display:flex;justify-content:space-between;align-items:center;padding:0;border-radius:10px;background:transparent;cursor:pointer}.branch-tree-row:hover .branch-node{border-color:#3a3e47;background:#111318}.branch-node{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #2a2e37;padding:10px;border-radius:10px;background:#0e1015;flex:1;min-width:0}.branch-tree-row.active .branch-node{border-color:#2d7cff;box-shadow:0 0 0 1px #2d7cff66}.branch-tree-gutter{display:flex;align-items:stretch;margin-right:10px;flex-shrink:0}.tree-col{width:16px;position:relative}.tree-vline{position:absolute;left:7px;top:0;bottom:0;width:2px;background:transparent}.tree-vline.draw{background:#303544}.tree-self{width:18px}.tree-connector-up{position:absolute;left:7px;top:0;height:50%;width:2px;background:#303544}.tree-connector-down{position:absolute;left:7px;top:50%;bottom:0;width:2px;background:#303544}.tree-elbow{position:absolute;left:7px;top:50%;width:10px;height:2px;background:#303544}.tree-dot{position:absolute;left:3px;top:calc(50% - 4px);width:10px;height:10px;border-radius:50%;background:#0b0c10;border:2px solid #404657;box-sizing:border-box}.branch-tree-row.active .tree-dot{border-color:#2d7cff}.message-actions{margin-top:8px;display:flex}.message.assistant .message-actions{justify-content:flex-start}.message.user .message-actions{justify-content:flex-end}.branch-actions{display:flex;gap:8px;align-items:center}.branch-rename-input{width:260px;max-width:44vw;padding:6px 8px;border-radius:8px;background:#0b0c10;border:1px solid #3a3e47;color:#e8eaed}.branch-title{font-weight:600}.branch-graph-actions{display:flex;gap:8px;align-items:center}.branch-graph-hint{margin-top:-6px}.branch-graph-canvas{flex:1;min-height:0;border:1px solid #23262e;border-radius:12px;background:radial-gradient(1200px 500px at 20% 10%,#2d7cff14,#0000),#0b0c10;overflow:hidden}.branch-graph-svg{width:100%;height:100%;cursor:grab;touch-action:none}.branch-graph-svg:active{cursor:grabbing}.branch-graph-link{fill:none;stroke-width:3px;stroke-linecap:round;opacity:.85}.branch-graph-node{-webkit-user-select:none;user-select:none;cursor:grab}.branch-graph-dot{stroke:#3a3e47}.branch-graph-label{font-size:12px;fill:#e8eaed;paint-order:stroke;stroke:#0000008c;stroke-width:3px}.branch-graph-label.active{fill:#bcd6ff}.branch-graph-toggle{font-size:14px;fill:#9aa4b2;cursor:pointer}.branch-graph-rename{font-size:11px;fill:#9aa4b2;cursor:pointer;opacity:0}.branch-graph-node:hover .branch-graph-rename{opacity:1}.branch-graph-delete{font-size:11px;fill:#ff6b6b;cursor:pointer;opacity:0}.branch-graph-node:hover .branch-graph-delete{opacity:1}.branch-graph-rename:hover,.branch-graph-delete:hover{text-decoration:underline}.chat-branch-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid #23262e;border-radius:10px;background:#0e1015}.chat-branch-controls-right{display:flex;gap:8px;align-items:center}.model-links{margin:12px 0;line-height:1.5}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.model-controls-section{display:flex;justify-content:space-between;align-items:center;margin:12px 0;gap:20px;flex-wrap:wrap}.sort-section{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;justify-content:center}.sort-label{color:#e8eaed;font-size:14px;font-weight:500;margin:0;white-space:nowrap}.sort-select{background:#0e1015;color:#e8eaed;border:1px solid #2a2e37;border-radius:8px;padding:8px 12px;font-size:14px;min-width:160px;cursor:pointer;transition:border-color .2s}.sort-select:focus{outline:none;border-color:#2d7cff;box-shadow:0 0 0 2px #2d7cff33}.sort-select:hover{border-color:#3a3e47}.filter-btn{padding:6px 12px;background:#21242c;color:#e8eaed;border:1px solid #2a2e37;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s}.filter-btn:hover{background:#2a2e37}.filter-btn.active{background:#2d7cff;color:#fff;border-color:#2d7cff}.toggle-container{display:flex;align-items:center}.toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-input{display:none}.toggle-slider{position:relative;width:50px;height:28px;background:#2a2e37;border-radius:14px;transition:all .3s ease;border:1px solid #3a3e47}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:22px;height:22px;background:#9aa0aa;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 4px #0003}.toggle-input:checked+.toggle-slider{background:#2d7cff;border-color:#2d7cff}.toggle-input:checked+.toggle-slider:before{transform:translate(22px);background:#fff}.toggle-text{color:#e8eaed;font-size:14px;font-weight:500}.modal{display:flex;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#000000e6;align-items:center;justify-content:center}.modal-content{margin:auto;display:block;max-width:90%;max-height:90%;object-fit:contain}.model-selector-content{background:#111318;border:1px solid #23262e;border-radius:12px;max-width:900px;max-height:80vh;width:90%;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #23262e}.modal-header h2{margin:0;color:#e8eaed;font-size:20px}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.search-section{padding:20px;border-bottom:1px solid #23262e}.models-grid{flex:1;overflow-y:auto;padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.model-card{background:#0e1015;border:1px solid #2a2e37;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;position:relative}.model-card:hover{border-color:#2d7cff;background:#111318}.model-card.selected{border-color:#2d7cff;background:#2d7cff1a}.model-provider{position:absolute;top:8px;right:8px;background:#21242c;color:#b6b9c3;padding:2px 6px;border-radius:4px;font-size:10px;border:1px solid #2a2e37}.model-name{font-weight:600;color:#e8eaed;margin-bottom:4px;font-size:14px}.model-id{color:#9aa0aa;font-size:11px;margin-bottom:8px;font-family:monospace}.model-description{color:#b6b9c3;font-size:12px;margin-bottom:8px;line-height:1.4}.model-capabilities{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.capability-tag{background:#21242c;color:#e8eaed;padding:2px 6px;border-radius:4px;font-size:10px;border:1px solid #2a2e37}.capability-tag.text{background:#1a4d3a;border-color:#2d7cff}.capability-tag.image{background:#4a1a3a;border-color:#ff2d7c}.capability-tag.multimodal{background:#3a1a4a;border-color:#7c2dff}.model-pricing{color:#9aa0aa;font-size:11px;margin-bottom:4px}.model-context{color:#9aa0aa;font-size:11px}.model-metrics{display:flex;flex-direction:column;gap:2px;margin-top:8px;padding-top:8px;border-top:1px solid #2a2e37}.metric-item{color:#9aa0aa;font-size:10px;font-family:monospace;line-height:1.2}@media(max-width:960px){.chat-layout{flex-direction:column}.chat-sidebar{width:100%}}
