pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#79c0ff}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-code,.hljs-comment,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#212121;--bg-secondary:#2f2f2f;--bg-tertiary:#383838;--border:#424242;--text:#e8e8e8;--text-secondary:#b4b4b4;--text-muted:#8e8e8e;--accent:#10a37f;--max-width:720px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;overscroll-behavior:none;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif}#app,.screen{flex-direction:column;height:100%;display:flex}.chat-header{padding:.75rem;padding-top:calc(.75rem + var(--safe-top));background:var(--bg);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.header-title{text-align:center;font-size:1rem;font-weight:600}.header-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.header-btn:active{background:var(--bg-secondary)}.header-spacer{width:36px}.sidebar-overlay{z-index:90;background:#00000080;position:fixed;inset:0}.sidebar{background:var(--bg-secondary);z-index:100;width:280px;padding-top:var(--safe-top);flex-direction:column;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{justify-content:space-between;align-items:center;padding:.75rem;display:flex}.sidebar-header h2{font-size:1rem;font-weight:600}.sidebar-nav{padding:.5rem}.sidebar-item{border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border-radius:10px;align-items:center;gap:.75rem;padding:.75rem;font-size:.875rem;display:flex}.sidebar-item:active{background:var(--bg-tertiary)}.messages{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;flex:1;padding:.5rem 0;overflow-y:auto}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:2rem;display:flex}.empty-avatar{opacity:.6;border-radius:12px;width:48px;height:48px;margin-bottom:1rem}.empty-state h2{margin-bottom:1.5rem;font-size:1.25rem;font-weight:500}.suggestions{flex-wrap:wrap;justify-content:center;gap:.5rem;max-width:400px;display:flex}.suggestion{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:.5rem 1rem;font-size:.8125rem;transition:background .15s,color .15s}.suggestion:hover,.suggestion:active{background:var(--bg-tertiary);color:var(--text)}.msg-row{max-width:var(--max-width);width:100%;margin:0 auto;padding:.75rem 1rem;animation:.2s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.msg-row--user{justify-content:flex-end;display:flex}.msg-row--user .msg-content{background:var(--bg-secondary);border-radius:18px 18px 4px;max-width:85%;padding:.625rem .875rem;display:inline-block}.msg-row--assistant{display:block}.msg-row--assistant .msg-content{background:0 0;padding:0}.msg-content{color:var(--text);word-wrap:break-word;overflow-wrap:break-word;font-size:.9375rem;line-height:1.6}.msg-content p{margin-bottom:.75rem}.msg-content p:last-child{margin-bottom:0}.msg-content strong{font-weight:600}.msg-content em{font-style:italic}.msg-content ul,.msg-content ol{margin:.5rem 0;padding-left:1.5rem}.msg-content li{margin-bottom:.25rem}.msg-content a{color:var(--accent);text-decoration:none}.msg-content a:hover{text-decoration:underline}.msg-content pre{background:#1e1e1e;border:none;border-radius:8px;margin:.75rem 0;padding:.875rem 1rem;font-size:.8125rem;line-height:1.5;overflow-x:auto}.msg-content pre code{font-size:inherit;color:inherit;background:0 0;border:none;padding:0}.msg-content code{background:#00000040;border-radius:4px;padding:.125rem .375rem;font-family:SF Mono,Fira Code,Menlo,monospace;font-size:.8125rem}.msg-content table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.875rem}.msg-content th,.msg-content td{border:1px solid var(--border);text-align:left;padding:.5rem .75rem}.msg-content th{background:var(--bg-tertiary);font-weight:600}.msg-content blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:.75rem 0;padding-left:1rem}.msg-content hr{border:none;border-top:1px solid var(--border);margin:1rem 0}.msg-images{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.msg-images img{object-fit:cover;border-radius:12px;max-width:200px;max-height:200px}.streaming-cursor:after{content:"";background:var(--accent);vertical-align:text-bottom;width:6px;height:16px;margin-left:2px;animation:.8s infinite blink-cursor;display:inline-block}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.scroll-btn{background:var(--bg-secondary);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;z-index:10;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:fixed;bottom:80px;right:1rem}.code-block-wrapper{position:relative}.copy-code-btn{background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;opacity:0;border:none;border-radius:4px;padding:4px 8px;font-size:.6875rem;transition:opacity .15s;position:absolute;top:6px;right:6px}.code-block-wrapper:hover .copy-code-btn{opacity:1}.copy-code-btn.copied{color:var(--accent)}.input-bar{padding:.5rem 1rem;padding-bottom:calc(.5rem + var(--safe-bottom));background:var(--bg);flex-shrink:0}.input-wrapper{max-width:var(--max-width);background:var(--bg-secondary);border:none;border-radius:24px;align-items:flex-end;gap:0;margin:0 auto;padding:.375rem .5rem .375rem 0;display:flex}.attach-btn{width:40px;height:36px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:flex}.attach-btn:active{color:var(--text)}.input-inner{flex-direction:column;flex:1;min-width:0;display:flex}.preview-bar{flex-wrap:wrap;gap:.5rem;padding:.5rem 0;display:flex}.preview-thumb{width:56px;height:56px;position:relative}.preview-thumb img{object-fit:cover;border-radius:8px;width:100%;height:100%}.preview-thumb .remove-preview{background:var(--bg-tertiary);width:20px;height:20px;color:var(--text);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;display:flex;position:absolute;top:-6px;right:-6px}.input-inner textarea{color:var(--text);resize:none;background:0 0;border:none;outline:none;max-height:150px;padding:.375rem 0;font-family:inherit;font-size:.9375rem;line-height:1.5}.input-inner textarea::placeholder{color:var(--text-muted)}#send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:opacity .15s,transform .1s;display:flex}#send-btn:disabled{opacity:.3;cursor:default}#send-btn:not(:disabled):active{transform:scale(.92)}
