.CodeMirror{font-family:monospace;height:300px;color:#000;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{padding:0 4px}.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{background-color:#fff}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:#000}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid black;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0!important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor .CodeMirror-line::selection,.cm-fat-cursor .CodeMirror-line>span::selection,.cm-fat-cursor .CodeMirror-line>span>span::selection{background:transparent}.cm-fat-cursor .CodeMirror-line::-moz-selection,.cm-fat-cursor .CodeMirror-line>span::-moz-selection,.cm-fat-cursor .CodeMirror-line>span>span::-moz-selection{background:transparent}.cm-fat-cursor{caret-color:transparent}@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;left:0;right:0;top:-50px;bottom:0;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:#00f}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:700}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-variable-3,.cm-s-default .cm-type{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta,.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error,.cm-invalidchar{color:red}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0b0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#a22}.CodeMirror-matchingtag{background:#ff96004d}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:#fff}.CodeMirror-scroll{overflow:scroll!important;margin-bottom:-50px;margin-right:-50px;padding-bottom:50px;height:100%;outline:none;position:relative;z-index:0}.CodeMirror-sizer{position:relative;border-right:50px solid transparent}.CodeMirror-vscrollbar,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{position:absolute;z-index:6;display:none;outline:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-50px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:none!important;border:none!important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:transparent;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre.CodeMirror-line,.CodeMirror-wrap pre.CodeMirror-line-like{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;left:0;right:0;top:0;bottom:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;padding:.1px}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:none}.CodeMirror-scroll,.CodeMirror-sizer,.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors,.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:#ff06}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:""}span.CodeMirror-selectedtext{background:none}.cm-s-monokai.CodeMirror{background:#272822;color:#f8f8f2}.cm-s-monokai div.CodeMirror-selected{background:#49483e}.cm-s-monokai .CodeMirror-line::selection,.cm-s-monokai .CodeMirror-line>span::selection,.cm-s-monokai .CodeMirror-line>span>span::selection{background:#49483efc}.cm-s-monokai .CodeMirror-line::-moz-selection,.cm-s-monokai .CodeMirror-line>span::-moz-selection,.cm-s-monokai .CodeMirror-line>span>span::-moz-selection{background:#49483efc}.cm-s-monokai .CodeMirror-gutters{background:#272822;border-right:0px}.cm-s-monokai .CodeMirror-guttermarker{color:#fff}.cm-s-monokai .CodeMirror-guttermarker-subtle,.cm-s-monokai .CodeMirror-linenumber{color:#d0d0d0}.cm-s-monokai .CodeMirror-cursor{border-left:1px solid #f8f8f0}.cm-s-monokai span.cm-comment{color:#75715e}.cm-s-monokai span.cm-atom,.cm-s-monokai span.cm-number{color:#ae81ff}.cm-s-monokai span.cm-comment.cm-attribute{color:#97b757}.cm-s-monokai span.cm-comment.cm-def{color:#bc9262}.cm-s-monokai span.cm-comment.cm-tag{color:#bc6283}.cm-s-monokai span.cm-comment.cm-type{color:#5998a6}.cm-s-monokai span.cm-property,.cm-s-monokai span.cm-attribute{color:#a6e22e}.cm-s-monokai span.cm-keyword{color:#f92672}.cm-s-monokai span.cm-builtin{color:#66d9ef}.cm-s-monokai span.cm-string{color:#e6db74}.cm-s-monokai span.cm-variable{color:#f8f8f2}.cm-s-monokai span.cm-variable-2{color:#9effff}.cm-s-monokai span.cm-variable-3,.cm-s-monokai span.cm-type{color:#66d9ef}.cm-s-monokai span.cm-def{color:#fd971f}.cm-s-monokai span.cm-bracket{color:#f8f8f2}.cm-s-monokai span.cm-tag{color:#f92672}.cm-s-monokai span.cm-header,.cm-s-monokai span.cm-link{color:#ae81ff}.cm-s-monokai span.cm-error{background:#f92672;color:#f8f8f0}.cm-s-monokai .CodeMirror-activeline-background{background:#373831}.cm-s-monokai .CodeMirror-matchingbracket{text-decoration:underline;color:#fff!important}.ai-assistant{display:grid;grid-template-columns:300px 1fr;height:100vh;background-color:var(--background)}.chat-sidebar{background-color:var(--background-alt);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%}.sidebar-header{padding:var(--spacing-md);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-actions{display:flex;gap:var(--spacing-xs)}.sidebar-actions .btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.assistants-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.assistant-item{display:flex;align-items:center;margin-bottom:var(--spacing-xs);border-radius:var(--radius-md);transition:all .2s ease}.assistant-item-content{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;color:var(--text-secondary)}.assistant-item:hover{background-color:var(--background)}.assistant-item.active{background-color:#5046e51a}.assistant-item.active .assistant-item-content{color:var(--primary)}.assistant-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chats-section{border-top:1px solid var(--border);margin-top:var(--spacing-md);padding-top:var(--spacing-md);max-height:50%;display:flex;flex-direction:column}.chats-header{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);display:flex;align-items:center;justify-content:space-between;background-color:#5046e50d;border-radius:var(--radius-md)}.chat-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.chat-item{display:flex;align-items:center;margin-bottom:var(--spacing-xs);border-radius:var(--radius-md);transition:all .2s ease}.chat-item-content{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;color:var(--text-secondary)}.chat-item:hover{background-color:var(--background)}.chat-item.active{background-color:#5046e51a}.chat-item.active .chat-item-content{color:var(--primary)}.chat-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-delete{padding:var(--spacing-sm);color:var(--text-tertiary);opacity:0;transition:opacity .2s ease}.chat-item:hover .chat-delete{opacity:1}.chat-delete:hover{color:var(--danger)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--border)}.chat-main{display:flex;flex-direction:column;height:100vh}.chat-header{padding:var(--spacing-md);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background-color:var(--background)}.chat-actions{display:flex;gap:var(--spacing-md)}.model-selector{min-width:180px}.select-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--background);color:var(--text-primary);font-size:.875rem}.messages-container{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.message-wrapper{display:flex;flex-direction:column;max-width:80%}.message-wrapper.user{align-self:flex-end}.message-wrapper.assistant{align-self:flex-start}.message{padding:var(--spacing-md);border-radius:var(--radius-lg);background-color:var(--background-alt);color:var(--text-primary)}.message-wrapper.user .message{background-color:var(--primary);color:#fff}.message.loading{display:flex;align-items:center;justify-content:center;min-width:60px;min-height:40px;background-color:var(--background-alt);border:1px solid var(--border);padding:var(--spacing-md)}.loading-dots{display:flex;gap:6px}.loading-dots span{width:10px;height:10px;border-radius:50%;background-color:var(--text-secondary);animation:bounce 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input{padding:var(--spacing-md);border-top:1px solid var(--border);background-color:var(--background);display:flex;gap:var(--spacing-md)}.input-field{flex:1;padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-lg);background-color:var(--background-alt);resize:none;font-size:.875rem;line-height:1.5;transition:opacity .2s ease,background-color .2s ease}.input-field:disabled{opacity:.7;cursor:not-allowed;background-color:var(--background)}.send-button{align-self:flex-end;padding:var(--spacing-sm) var(--spacing-md)}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.empty-state-content{text-align:center;max-width:400px}.empty-state-icon{font-size:48px;color:var(--text-tertiary);margin-bottom:var(--spacing-md);display:block}@media (max-width: 768px){.ai-assistant{grid-template-columns:1fr}.chat-sidebar{display:none}.message-wrapper{max-width:90%}}.icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.chat-title{display:flex;flex-direction:column}.chat-subtitle{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.assistant-label{display:inline-flex;align-items:center;background-color:#5046e51a;color:var(--primary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-weight:500}.assistant-label:before{content:"🤖";font-size:.875rem;margin-right:.5rem}.code-block{position:relative;background-color:#f8f8f8;border:1px solid #e0e0e0;border-radius:var(--radius-md);padding:1rem;margin:1rem 0;overflow-x:auto;font-family:monospace;white-space:pre;line-height:1.5}.copyable-code-block{position:relative;margin:1.5rem 0}.copy-button{position:absolute;top:.5rem;right:.5rem;background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:.25rem .5rem;font-size:.75rem;cursor:pointer;opacity:.8;transition:opacity .2s ease}.copy-button:hover{opacity:1}.copy-button.copied{background-color:#4caf50;opacity:1}.message code{font-family:monospace;background-color:#0000000d;padding:.2em .4em;border-radius:3px;font-size:.9em}.message pre code{background-color:transparent;padding:0;border-radius:0}.copyable-code-container{position:relative;margin:1.5rem 0;border:1px solid var(--border);border-radius:var(--radius-md);background-color:#f8f8f8;overflow:hidden}.copyable-code-container .code-block{margin:0;border:none;border-radius:0;max-height:500px;overflow-y:auto}.copyable-code-container .copy-button{position:absolute;top:.5rem;right:.5rem;z-index:10}.copy-section{margin:1.5rem 0;padding:1rem;background-color:#f5f7fa;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d}.copy-section h3{margin-top:0;margin-bottom:.75rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.copy-section .copyable-code-container{margin-bottom:0}.codemirror-container{width:100%;height:400px;overflow:hidden;position:relative;border-radius:0}.code-editor-hidden{display:none}.CodeMirror{height:100%;font-family:Fira Code,Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.6;padding:0;border-radius:0}.CodeMirror-gutters{border-right:1px solid #333;background-color:#252526}.CodeMirror-linenumber{color:#6e7681}.code-editor-container{display:flex;flex-direction:column;position:relative;border:1px solid #333;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem;background-color:#1e1e1e}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#252526;border-bottom:1px solid #333}.editor-language{font-size:.8rem;color:#858585;font-weight:500;text-transform:uppercase;display:flex;align-items:center}.editor-language:before{content:"📄";margin-right:.5rem;font-size:1rem}.editor-language[data-language=html]:before{content:"🌐"}.editor-language[data-language=css]:before{content:"🎨"}.editor-language[data-language=javascript]:before,.editor-language[data-language=js]:before{content:"⚙️"}.editor-actions{display:flex;gap:.5rem;justify-content:flex-end;padding:.75rem 1rem;background-color:#252526;border-top:1px solid #333}.copy-button{display:flex;align-items:center;gap:.5rem;background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.copy-button:before{content:"📋";font-size:1rem}.copy-button:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.copy-button:active{transform:translateY(0);box-shadow:none}.copy-button.copied{background-color:#4caf50}.copy-button.copied:before{content:"✓"}.copy-section{margin:0;padding:0;background-color:transparent;border:none;box-shadow:none}.copy-section h3{margin-top:0;margin-bottom:1rem;font-size:1.1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center}.copy-section h3:before{content:"💻";margin-right:.5rem;font-size:1.2rem}
