@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.markdown-renderer{line-height:1.7;color:var(--text-primary);font-size:.95rem}.markdown-h1{font-size:1.75rem;font-weight:700;margin:1.5rem 0 1rem;color:var(--text-primary);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;padding-bottom:.5rem}.markdown-h1:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:2px}.markdown-h2{font-size:1.5rem;font-weight:600;margin:1.25rem 0 .75rem;color:var(--text-primary);position:relative;padding-bottom:.5rem}.markdown-h2:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:2px;background:var(--primary-gradient);border-radius:1px;opacity:.6}.markdown-h3{font-size:1.25rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text-primary)}.markdown-h4{font-size:1.1rem;font-weight:600;margin:.75rem 0 .5rem;color:var(--text-secondary)}.markdown-p{margin:.875rem 0;color:var(--text-primary);line-height:1.7}.markdown-ul,.markdown-ol{margin:.875rem 0;padding-left:1.5rem}.markdown-li{margin:.375rem 0;color:var(--text-primary);line-height:1.6}.markdown-ul .markdown-li::marker{color:#667eea}.markdown-ol .markdown-li::marker{color:#667eea;font-weight:600}.markdown-blockquote{border-left:4px solid #667eea;background:linear-gradient(135deg,rgba(102,126,234,.05) 0%,rgba(118,75,162,.05) 100%);margin:1.25rem 0;padding:1rem 1.5rem;border-radius:0 var(--radius-md) var(--radius-md) 0;position:relative;color:var(--text-secondary);font-style:italic}.markdown-blockquote:before{content:'"';position:absolute;top:-10px;left:10px;font-size:3rem;color:#667eea;opacity:.3;font-family:Georgia,serif}.markdown-pre{background:linear-gradient(135deg,#2d3748 0%,#1a202c 100%);color:#f7fafc;padding:1.5rem;border-radius:var(--radius-lg);overflow-x:auto;margin:1.25rem 0;font-family:Fira Code,Consolas,Monaco,Courier New,monospace;font-size:.875rem;line-height:1.6;position:relative;box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.1)}.markdown-pre:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-gradient);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.markdown-inline-code{background:rgba(102,126,234,.1);color:#667eea;padding:.25rem .5rem;border-radius:var(--radius-sm);font-family:Fira Code,Consolas,Monaco,Courier New,monospace;font-size:.875em;font-weight:500;border:1px solid rgba(102,126,234,.2)}.markdown-table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.9rem;background:var(--surface-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-medium)}.markdown-thead{background:var(--primary-gradient);color:#fff}.markdown-th{padding:1rem;text-align:left;font-weight:600;border:none;position:relative}.markdown-td{padding:.875rem 1rem;border:none;border-top:1px solid var(--border-light)}.markdown-tr:nth-child(2n){background:var(--surface-elevated)}.markdown-tr:hover{background:rgba(102,126,234,.05)}.markdown-strong{font-weight:700;color:var(--text-primary);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.markdown-em{font-style:italic;color:var(--text-secondary)}.markdown-link{color:#667eea;text-decoration:none;position:relative;font-weight:500;transition:all .2s ease}.markdown-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--primary-gradient);transition:width .3s ease}.markdown-link:hover{color:#764ba2}.markdown-link:hover:after{width:100%}.markdown-pre code{background:none;color:inherit;padding:0;font-size:inherit}.hljs{background:transparent!important;color:#ecf0f1!important}.hljs-keyword,.hljs-selector-tag,.hljs-built_in{color:#3498db!important}.hljs-string,.hljs-title,.hljs-section{color:#2ecc71!important}.hljs-comment,.hljs-quote{color:#95a5a6!important;font-style:italic}.hljs-number,.hljs-literal{color:#e67e22!important}.hljs-function,.hljs-class{color:#f39c12!important}.hljs-variable,.hljs-template-variable{color:#e74c3c!important}@media (max-width: 768px){.markdown-h1{font-size:1.5rem}.markdown-h2{font-size:1.3rem}.markdown-pre{font-size:.8rem;padding:.75rem}.markdown-table{font-size:.8rem}.markdown-th,.markdown-td{padding:.5rem}}.message-bubble{display:flex;margin-bottom:1.5rem;animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}.user-message{justify-content:flex-end}.ai-message{justify-content:flex-start}.message-content{max-width:100%;padding:1rem 1.5rem;border-radius:var(--radius-xl);word-wrap:break-word;position:relative;box-shadow:var(--shadow-light);border:1px solid var(--border-light)}.user-message .message-content{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-bottom-right-radius:var(--radius-sm);margin-left:2rem}.ai-message .message-content{background:var(--surface-color);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm);margin-right:2rem;border:1px solid var(--border-color)}.ai-message .message-content:before{content:"🤖";position:absolute;top:-8px;left:-8px;width:24px;height:24px;background:var(--surface-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-shadow:var(--shadow-medium);border:1px solid var(--border-color)}.user-message .message-content:before{content:"👤";position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:var(--surface-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-shadow:var(--shadow-medium);border:1px solid var(--border-color)}.message-text{margin-bottom:.5rem;line-height:1.6;font-size:.95rem}.message-meta{display:flex;justify-content:space-between;font-size:.75rem;opacity:.8;margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.user-message .message-meta{color:#ffffffe6}.ai-message .message-meta{color:var(--text-muted);border-top-color:var(--border-light)}.streaming-cursor{display:inline-block;width:2px;height:1.2em;background:currentColor;animation:typing-cursor 1.2s ease-in-out infinite;margin-left:2px;vertical-align:text-bottom}.streaming-indicator{color:#667eea;font-style:italic;font-size:.8rem;display:flex;align-items:center;gap:.5rem}.streaming-indicator:before{content:"";width:12px;height:12px;border:2px solid #667eea;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}.message-bubble.streaming{animation:streaming-glow 2s ease-in-out infinite}.message-bubble.streaming .ai-message .message-content{background:linear-gradient(135deg,var(--surface-color) 0%,rgba(102,126,234,.05) 100%);border-color:#667eea33}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes typing-cursor{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes streaming-glow{0%,to{box-shadow:var(--shadow-light)}50%{box-shadow:0 4px 20px #667eea4d}}@media (max-width: 768px){.message-content{max-width:85%;padding:.875rem 1.25rem}.user-message .message-content,.ai-message .message-content{margin-left:1rem;margin-right:1rem}}.chat-window{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--surface-elevated)}.messages-container{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:rgba(148,163,184,.2);border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.3)}.welcome-message{text-align:center;color:var(--text-muted);margin:4rem auto;max-width:500px;padding:3rem 2rem;background:var(--surface-color);border-radius:var(--radius-xl);border:2px dashed var(--border-light);position:relative}.welcome-message:before{content:"👋";font-size:3rem;display:block;margin-bottom:1rem}.welcome-message h2{margin-bottom:1rem;font-weight:600;font-size:1.5rem;color:var(--text-primary);letter-spacing:-.025em}.welcome-message p{font-size:1.1rem;line-height:1.6;color:var(--text-secondary)}.message-input{background:var(--surface-color);padding:1rem;border-top:1px solid var(--border-light);position:relative}.message-input:before{content:"";position:absolute;top:0;left:2rem;right:2rem;height:1px;background:linear-gradient(90deg,transparent,var(--border-light),transparent)}.input-container{display:flex;gap:1rem;align-items:flex-end;max-width:800px;margin:0 auto}.input-container textarea{flex:1;border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:1rem 1.5rem;resize:none;min-height:52px;max-height:120px;font-family:inherit;font-size:1rem;line-height:1;background:var(--surface-elevated);color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-light)}.input-container textarea::placeholder{color:var(--text-muted)}.input-container textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a,var(--shadow-medium);background:var(--surface-color)}.input-container textarea:disabled{background:var(--surface-dark);color:var(--text-muted);border-color:var(--border-light);cursor:not-allowed}.send-button{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:var(--radius-xl);padding:1rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:var(--shadow-medium);position:relative;overflow:hidden;min-width:100px;display:flex;align-items:center;justify-content:center;gap:.5rem}.send-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.send-button:hover:not(:disabled):before{left:100%}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-large)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background:linear-gradient(135deg,var(--text-muted) 0%,#94a3b8 100%);cursor:not-allowed;transform:none;box-shadow:var(--shadow-light)}.send-button:disabled:before{display:none}.send-button .loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.send-button:not(:disabled):after{content:"✈️";font-size:1rem}.send-button:disabled:after{content:"⏳";font-size:1rem}@media (max-width: 768px){.message-input{padding:1rem}.message-input:before{left:1rem;right:1rem}.input-container{gap:.75rem}.input-container textarea{padding:.875rem 1.25rem;font-size:.95rem}.send-button{padding:.875rem 1.5rem;font-size:.95rem;min-width:80px}}.app{width:80%}.chat-interface{width:100%;height:90vh;display:flex;flex-direction:column;background:var(--surface-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-large);overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.chat-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center;position:relative}.chat-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.chat-header h1{font-size:1.5rem;font-weight:600;margin:0;letter-spacing:-.025em;display:flex;align-items:center;gap:.5rem}.chat-header h1:before{content:"🤖";font-size:1.2em}.status-info{display:flex;align-items:center;gap:1.5rem}.api-status{display:flex;align-items:center;gap:.4rem;font-size:.875rem;background:rgba(255,255,255,.1);padding:.2rem 1rem;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.status-text{font-weight:500;letter-spacing:.025em}.status-dot{width:10px;height:10px;border-radius:50%;position:relative;box-shadow:0 0 10px currentColor}.status-dot.streaming{background:var(--success-color);color:var(--success-color);animation:pulse-success 2s infinite}.status-dot.fallback{background:var(--warning-color);color:var(--warning-color);animation:pulse-warning 2s infinite}.status-dot.loading{background:#94a3b8;color:#94a3b8;animation:loading-pulse 1.5s infinite}.refresh-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:.6rem;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.refresh-btn:hover{background:rgba(255,255,255,.2);transform:rotate(180deg)}.status-message{font-size:.8rem;background:rgba(255,255,255,.1);padding:.5rem;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}@keyframes pulse-success{0%,to{opacity:1;box-shadow:0 0 10px var(--success-color)}50%{opacity:.6;box-shadow:0 0 20px var(--success-color)}}@keyframes pulse-warning{0%,to{opacity:1;box-shadow:0 0 10px var(--warning-color)}50%{opacity:.6;box-shadow:0 0 20px var(--warning-color)}}@keyframes loading-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#383a42;background:#fafafa}.hljs-comment,.hljs-quote{color:#a0a1a7;font-style:italic}.hljs-doctag,.hljs-keyword,.hljs-formula{color:#a626a4}.hljs-section,.hljs-name,.hljs-selector-tag,.hljs-deletion,.hljs-subst{color:#e45649}.hljs-literal{color:#0184bb}.hljs-string,.hljs-regexp,.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string{color:#50a14f}.hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-type,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-number{color:#986801}.hljs-symbol,.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-title{color:#4078f2}.hljs-built_in,.hljs-title.class_,.hljs-class .hljs-title{color:#c18401}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--surface-color: #ffffff;--surface-elevated: #fafbfc;--surface-dark: #f1f5f9;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-light: #f1f5f9;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--shadow-light: 0 1px 2px rgba(0, 0, 0, .05);--shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-large: 0 20px 25px -5px rgba(0, 0, 0, .1);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--primary-gradient);background-attachment:fixed;color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(148,163,184,.3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.5)}button{font-family:inherit;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none}button:focus-visible{outline:2px solid #667eea;outline-offset:2px}input,textarea{font-family:inherit;border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1);outline:none}input:focus,textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}
